This documents explains the processes and practices recommended for contributing enhancements to the Grafana Agent charm.
- Generally, before developing enhancements to this charm, you should consider opening an issue explaining your use case.
- If you would like to chat with us about your use-cases or proposed implementation, you can reach us at Canonical Mattermost public channel or Discourse. The primary authors of this charm are available on the Mattermost channel as
@dylanstathis
and@jose-masson
. - It is strongly recommended that prior to engaging in any enhancements to this charm you familiarise your self with Juju.
- Familiarising yourself with the Charmed Operator Framework library will help you a lot when working on PRs.
- All enhancements require review before being merged. Besides the code quality and test coverage, the review will also take into account the resulting user experience for Juju administrators using this charm. Please help us out in having easier reviews by rebasing onto the
main
branch, avoid merge commits and enjoy a linear Git history.
A typical setup using snaps, for deployments to a microk8s cluster can be done using the following commands
sudo snap install microk8s --classic
microk8s.enable dns storage
sudo snap install juju --classic
juju bootstrap microk8s microk8s
juju create-storage-pool operator-storage kubernetes storage-class=microk8s-hostpath
All tests can be executed by running tox
without arguments.
To run individual test environments:
tox -e fmt # Apply coding style standards to code
tox -e integration # Run integration tests
tox -e lint # Check your code complies to linting rules
tox -e static # Run static analysis
tox -e unit # Run unit tests
Unit tests are implemented using the Operator Framework test harness.
Install the charmcraft tool and build the charm in this git repository:
tox -e render-k8s
charmcraft pack
Deploy the charm with:
juju deploy ./grafana-agent-k8s_ubuntu-20.04-amd64.charm --resource agent-image='ghcr.io/canonical/grafana-agent:latest'
The core implementation of this charm is represented by the GrafanaAgentOperatorCharm
class.
GrafanaAgentOperatorCharm
responds to the following events:
self.on.install
: In this event we patch K8s service ports.self.on.agent_pebble_ready
: In this event the charm builds the Pebble layer to be added in the workload charm. This Pebble layer will manage the execution of Promtail binaryself.on["send-remote-write"].relation_changed
: In this event the Grafana agent config is updated with remote-write settings.self._scrape.on.targets_changed
: In this event the Grafana agent config is updated with scrape settings.self._loki_consumer.on.loki_push_api_endpoint_joined
: In this event the Grafana agent config is updated with Loki settings.self._loki_consumer.on.loki_push_api_endpoint_departed
: In this event the Grafana agent config is updated with Loki settings.