We welcome contributions and improvements! Feel free to submit PRs.
The process for making a successful contribution is:
- Make your change
- Build any generated files:
make build
- Run unit tests:
make test
- Create your PR!
- Wait for checks to pass
- Lint checks
- Unit tests
- Integration tests
The Kubernetes Monitoring Helm chart has a few design idioms with the goal of making it an easy and pleasant experience for users and maintainers. These should guide your contributions:
Many users will not know about the particular observability systems and why one is better than another. Instead of asking if they want to deploy a particular system, ask what outcome they want.
Bad:
mega-widget:
enabled: true
megaQuarkMode: blue
Good:
quantumObservability:
enabled: true
quarkMode: blue
If a user encounters an error, we want to provide them with a suggestion for how to fix it.
Bad:
Error: megaQuarkMode not set!
Good:
Error: The Quantum Observability feature requires a quark mode!
Please set:
quantumObservability:
quarkMode: <favorite color>
This Helm chart is essentially a package of observability collection systems and a utility to generate configurations for those systems. It should be possible for a user to modify that configuration without needing to know the actual config language syntax.
Bad:
quantumObservability:
extraDiscoveryRules: |
// Keep only the production namespace
rule {
source_labels = ["__meta_kubernetes_namespace"]
regex = "production"
action = keep
}
Good:
quantumObservability:
namespaces: [production]
We want to make it easy to contribute to this project. We have a lot of test automation to ensure that changes are high quality and robust.
This is a bit hard to qualify, but using this chart should be simple and easy with predictable and intuitive defaults. Sometimes, going too far with this can lead to a chart that does things that are unexpected.
No magic:
quantumObservability:
extraQuarkLabellingRules: ""
Some magic:
quantumObservability:
# Add quark labels from Kubernetes pod labels
quarkLabelsFromPodLabels: {}
More magic:
quantumObservability:
# Add quark labels from Kubernetes pod labels
quarkLabelsFromPodLabels:
position: app.kubernetes.io/position
Too much magic:
quantumObservability:
# This will automatically add `position` from the `app.kubernetes.io/position` label
quarkLabelsFromPodLabels: {}
This repository heavily makes use of automation and tooling to generate files and run tests. The following tools are required to work on this repository:
- Helm
- Docker - Used for running some tools in containers and required for
kind
. - chart-testing - Used for linting Helm charts.
- kind - Used for creating local Kubernetes clusters for integration testing.
- Grafana Alloy - Used for linting the generated config files.
- yamllint - Used for linting YAML files.
Some tools are optional. If they are not present on your system, the equivalent Docker image will be run. Consider installing them for a better experience:
- helm-docs - Used for generating Helm chart README.md files.
- helm unittest - Used for executing Helm chart unit tests.
- Flux CLI - Used for executing Helm chart integration and platform tests.
- shellspec - Used for executing some unit tests.
- vendir - Used for downloading Alloy Module
Each chart has a Makefile with targets to automate much of the process.
Each component has its own guide for contributing:
Lots of files in this repository are generated in order to reduce duplication and ensure consistency. To build these
files, run make build
.
You can also run make build
from inside the specific Chart directory to build only the files for that Chart.
These files are generated and any changes should be included in your PR:
README.md
- The README file for the chart, this is generated from the values.yaml file.CHART.lock
- The lock file for the chart dependencies, this is generated from the Chart.yaml file.values.schema.json
- The JSON schema for the values.yaml file, this is generated from the values.yaml file and any modification files found in theschema-mods
directories.docs/examples
- The examples directory contains usage examples that are rendered from the chart. This works in thek8s-monitoring
andk8s-monitoring-v1
charts.
Some charts will also generate additional templates and docs based on other files. For example, the
feature-integrations
chart creates docs and templates based on each supported integration's own values.yaml file.
If your chart is dependent on external charts, you can update the dependencies by:
- Set the dependency's version in Chart.yaml.
- Update the Chart.lock file by running
make -C charts/<the chart you are modifying> build
.
If you made a change to a feature Helm chart, you'll also need to update the main k8s-monitoring
Helm chart to include
your changes. To do this, run the following command:
rm charts/k8s-monitoring/Chart.lock
make -C charts/k8s-monitoring build
Include the modified chart bundles and Chart.lock file in your PR.
Each chart contains unit tests and some contain integration tests. Unit tests run quickly and test parts of the chart that don't require a Kubernetes cluster. Integration tests require a Kubernetes cluster and test the chart in a real environment with dependencies.
Unit tests can be run with make test
. You can also run make test
from inside the specific Chart directory to run
only the tests for that Chart.
Integration tests run with a Kubernetes Cluster. The process for running the test is different for the v1 and v2 charts.
To run the integration tests for the k8s-monitoring-v1
chart, use the setup-local-test-cluster.sh
script to build a
Kubernetes cluster using kind and deploy the telemetry data sources, data stores and Grafana. If you provide a values
file as an argument to that script (i.e. setup-local-test-cluster.sh values.yaml
), it installs the k8s-monitoring Helm'
chart and runs helm test as well.
To run the integration tests for the k8s-monitoring
chart, use the following commands:
./scripts/run-cluster-test.sh charts/k8s-monitoring/tests/integration/<test dir>
This will create a new Kubernetes cluster using kind, deploy any required dependencies, deploy the k8s-monitoring
Helm
chart, and deploy the k8s-monitoring-test
chart which contains the tests.
You can modify the behavior of the test by setting environment variables:
DELETE_CLUSTER
- If set tofalse
, the cluster will not be deleted after the test completes.CREATE_CLUSTER
- If set tofalse
, the script will not create a new cluster, but will use whatever cluster your kubectl is configured to use.DEPLOY_GRAFANA
- If set tofalse
, the script will not deploy Grafana. Grafana is only deployed to make debugging easier, because it will be pre-configured to connect to the database instances.
Creating new releases is typically only done by maintainers, most often Grafana Labs employees.
The process for creating a new release is:
- Update the chart version and push to main
- Ensure the CI tests on main are successful
- Run the appropriate release GitHub Action workflow.
Use the set-version.sh script to update the version and regenerate the files that contain version numbers. For example:
% ./scripts/set-version.sh 1.2.3
This will also set the App Version to the latest release of the Kubernetes Monitoring in Grafana Cloud. If you do not have access to that GitHub repository, you can set the App version in the second argument to the set-version.sh script. For example:
% ./scripts/set-version.sh 1.2.3 3.1.2
The helm-release-v1.yml GitHub workflow handles the details of packaging the v1 Chart, creating the release on this repository, creating a release on the grafana/helm-charts repository, and finally updating the Helm chart repository.