Pull requests, feeback/feature requests are all welcome. This guide will be updated overtime.
To build helmsman from source, you need go:1.13+. Follow the steps below:
git clone https://github.com/Praqma/helmsman.git
make build
master
is where Helmsman latest code lives.
1.x
this is where Helmsman versions 1.x lives.
Helmsman v1.x supports helm v2.x only and will no longer be supported except for bug fixes and minor changes.
- If your PR is for Helmsman v1.x, it should target the
1.x
branch. - Please make sure you state the purpose of the pull request and that the code you submit is documented. If in doubt, this guide offers some good tips on writing a PR.
- Please make sure you update the documentation with new features or the changes your PR adds. The following places are required.
- Update existing how_to guides or create new ones.
- If necessary, Update the Desired State File spec
- If adding new flags, Update the cmd reference
- Please add tests wherever possible to test your new changes.
Contribution to the documentation can be done via pull requests or by opening an issue.
Please provide details of the issue, versions of helmsman, helm and kubernetes and all possible logs.
Release is automated from CicrcleCI based on Git tags. Goreleaser is used to release the binaries and update the release notes on Github while the CircleCI pipeline builds a set of docker images and pushes them to dockerhub.
The following steps are needed to cut a release (They assume that you are on master and the code is up to date):
- Change the version variable in main.go and in .version
- Update the release-notes.md file with new version and changelog.
- (Optional), if new helm versions are required, update the circleci config and add more docker commands.
- Commit your changes locally.
- Create a git tag with the following command:
git tag -a <semantic version number> -m "<semantic version number>" <your-last-commit-sha>
- Push your commit and tag with
git push --follow-tags
- This should trigger the pipeline on circleci which eventually releases to Github and dockerhub.