Contributions are welcome via GitHub Pull Requests. This document outlines the process to help get your contribution accepted.
Any type of contribution is welcome; from new features, bug fixes, documentation improvements or even adding charts to the repository.
- Fork this repository, develop, and test your changes.
- Submit a pull request.
NOTE: To make the Pull Requests' (PRs) testing and merging process easier, please submit changes to multiple charts in separate PRs.
When submitting a PR make sure that it:
- Must pass CI jobs for linting and test the changes on top of different k8s platforms. (Automatically done by the Bitnami CI/CD pipeline).
- Must follow Helm best practices.
- Implements changes in both files if the chart contains a values-production.yaml and a values.yaml.
- Has the "edits and maintainers" option enabled to allow our CI/CD to modify the PR (
bitnami-bot
will update values*.yaml). Find more information in this link. - Any change to a chart requires a version bump following semver principles.
- A chart's
README.md
must include configuration options. - A chart's
NOTES.txt
must include relevant post-installation information. - The title of the PR starts with chart name (e.g.
[bitnami/chart]
)
- Changes are automatically linted and tested using the
ct
tool as a GitHub action. Those tests are based onhelm install
,helm lint
andhelm test
commands and provide quick feedback about the changes in the PR. For those tests, the chart is installed on top of kind and this step is not blocking (as opposed to 3rd step). - Changes are manually reviewed by Bitnami team members.
- Once the changes are accepted, the PR is tested into the Bitnami CI pipeline, the chart is installed and tested (verification and functional tests) on top of different k8s platforms.
- If everything works fine, the
bitnami-bot
will add a new commit to the PR updating all the Docker images tags and dependencies. If something fails, the review process continues. - When the PR passes all tests it is merged in the GitHub master branch and the new version of the chart is pushed to the registry. Please note that may be a slight difference between the appearance of the code in GitHub and the chart in the registry.
There are only three major requirements to add a new chart in our catalog:
- The chart should use Bitnami based container images. If they don't exist, you can open a GitHub issue and we will work together to create them.
- Follow the same structure/patterns that the rest of the Bitnami charts and the Best Practices for Creating Production-Ready Helm charts guide.
- Use an OSI approved license for all the software.