⚠️ Follow these instructions instead of modifying or running this chart
If you make changes to these helm charts, however simple, we won't be able to support you. Most people who modify or use a non-standard way of running this chart run into issues. We strongly recommend following the official instructions to deploy PostHog.
If there are changes you need, please raise a PR or reach out on Slack so we can help you.
🦔 PostHog is a developer-friendly, open-source product analytics suite.
This Helm chart bootstraps a PostHog installation on a Kubernetes cluster using the Helm package manager.
- Kubernetes >=1.20 <= 1.23
- Helm 3+
Deployment instructions for the major cloud service providers and on-premise deploys are available here.
We document detailed changes for each major release in the upgrade notes.
The main purpose of this repository is to continue evolving our Helm chart, making it faster and easier to use. We welcome all contributions to the community and are excited to welcome you aboard.
This repo uses several types of test suite targeting different goals:
- lint tests: to verify if the Helm templates can be rendered without errors
- unit tests: to verify if the rendered Helm templates are as we expect
- integration tests: to verify if applying the rendered Helm templates against a Kubernetes target cluster gives us the stack and PostHog installation we expect
We use helm lint
that can be invoked via: helm lint --strict --set “cloud=local” charts/posthog
In order to run the test suite, you need to install the helm-unittest
plugin. You can do that by running: helm plugin install https://github.com/quintush/helm-unittest
For more information about how it works and how to write test cases, please look at the upstream documentation or to the tests already available in this repo.
To run the test suite you can execute: helm unittest --helm3 --strict --file 'tests/*.yaml' --file 'tests/clickhouse-operator/*.yaml' charts/posthog
- kubetest: to verify if applying the rendered Helm templates against a Kubernetes target cluster gives us the stack we expect (example: are the disks encrypted? Can this pod communicate with this service?)
- k6: HTTP test used to verify the reliability, performance and compliance of the PostHog installation (example: is the PostHog ingestion working correctly?)
- e2e - k3s: to verify Helm install/upgrade commands on a local k3s cluster
- e2e - Amazon Web Services, e2e - DigitalOcean, e2e - Google Cloud Platform: to verify Helm install command on the officially supported cloud platforms
Add one of the following labels to your PR before merging to bump the version and release it to the Helm repository:
bump patch
bump minor
bump major