Skip to content

Latest commit

 

History

History
187 lines (138 loc) · 6.08 KB

CONTRIBUTING.md

File metadata and controls

187 lines (138 loc) · 6.08 KB

Contributing to grafana-operator

Thank you for investing your time in contributing to our project.

Development

The operator uses unit tests and Kuttl for e2e tests to make sure that the operator is working as intended, we use make to generate a number of docs and scripts for us.

The operator use a submodule for grafonnet-lib, one of the first things you have to do is to run make submodule.

NOTE: please, run make all before opening a PR to make sure your changes are compliant with our standards and all automatically generated files (like CRDs) are up-to-date.

Code standards

We use a number of code standards in the project that we apply using a number of different tools. As a part of the CI solution these settings will be validated, but all of them can be tested using the Makefile before pushing.

Before pushing any code we recommend that you run the following make commands.

make submodule
make test
make code/golangci-lint

Depending on what you have changed these commands will update a number of different files.

KO

To speed up multi-arch image builds and avoid burden of maintaining a Dockerfile, we are using ko.

For more information on how to push the container image to your remote repository take a look at the official docs.

Local development using make run

Some of us use kind some use crc, below you can find an example on how to integrate with a kind cluster. When adding a grafanadashboard to our grafana instances through the operator and using make test to run the operator we need a way to send data in to the grafana instance.

There are multiple ways of doing so but this is one of them using kind.

cat <<EOF | kind create cluster --config=-
kind: Cluster
apiVersion: kind.x-k8s.io/v1alpha4
nodes:
- role: control-plane
  kubeadmConfigPatches:
  - |
    kind: InitConfiguration
    nodeRegistration:
      kubeletExtraArgs:
        node-labels: "ingress-ready=true"
  extraPortMappings:
  - containerPort: 80
    hostPort: 80
    protocol: TCP
  - containerPort: 443
    hostPort: 443
    protocol: TCP
EOF

When the kind cluster is up and running setup your ingress.

kubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/main/deploy/static/provider/kind/deploy.yaml

To get the operator to create a dashboard through the ingress object we have added a feature in the operator.

Notice the spec.client.preferIngress: true This should only be used during development.

In this example we are using nip.io which will steer traffic to your local deployment through a DNS response (e.g. nslookup grafana.127.0.0.1.nip.io will respond with 127.0.0.1).

apiVersion: grafana.integreatly.org/v1beta1
kind: Grafana
metadata:
  name: grafana
  labels:
    dashboards: "grafana"
spec:
  client:
    preferIngress: true
  config:
    log:
      mode: "console"
    auth:
      disable_login_form: "false"
    security:
      admin_user: root
      admin_password: secret
  ingress:
    spec:
      ingressClassName: nginx
      rules:
        - host: grafana.127.0.0.1.nip.io
          http:
            paths:
              - backend:
                  service:
                    name: grafana-service
                    port:
                      number: 3000
                path: /
                pathType: Prefix

This makes the grafana client in the operator to use the ingress address instead of the service name.

# Will install the CRD:s
make install
# Will run the operator from your console
make run

Now you should be ready to develop the operator.

E2e tests using Kuttl

As mentioned above we use Kuttl to run e2e tests for the operator, we normally run Kuttl on Kind

The make e2e command will

# Build the container
make ko-build-kind
# Create grafana-operator-system namespace
kubectl create ns grafana-operator-system
# Run the Kuttl tests
VERSION=latest make e2e

Helm

We support helm as a deployment solution and it can be found under deploy/helm.

The grafana-operator helm chart is currently manually created. When CRD:s is upgraded the helm chart will also get an update.

But if you generate new RBAC rules or create new deployment options for the operator you will need to add them manually.

Chart.yaml appVersion follows the grafana-operator version but the helm chart is versioned separately.

If you add update the chart don't forget to run make helm-docs, which will update the helm specific README file.

Kustomize

Kustomize, amongst other methods, can be used to install the operator.

To make sure its copy of CRDs is up-to-date, please, run make all. NOTE: there's an option to call make kustomize-crd directly, though it assumes the CRDs have already been generated from Go code through make manifests. make all is just a simpler option to run since it doesn't require you to remember all previous steps.

Documentation

All documentation is stored under docs, for our homepage we are using hugo and the docsy theme.

If you don't feel the needs to preview the changes that you have done to the docs all you need to do is to edit them. But if you want to see how your changes will look you need to install hugo locally.

Hugo

When installing hugo install the extended edition, you can easily find it on there github page. We are currently using 0.111.2 but it probably works with other versions as well.

To develop locally you need to also follow the docsy pre-req. But in most cases it should work to just run

cd hugo
# Install npm dependencies
npm ci
# Download hugo module
hugo mod get

To look at your changes with hot reload.

hugo serve