Skip to content

Latest commit

 

History

History
68 lines (48 loc) · 3.36 KB

CONTRIBUTING.md

File metadata and controls

68 lines (48 loc) · 3.36 KB

Contributing to grafana-agent-operator

Overview

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.

Setup

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

Developing + Testing

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.

Build

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'

Code Overview

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 binary
  • self.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.