We're excited that you'd like to help us with our PowerDNS cookbook project!
When submitting an issue, please check the Issues section of this repository on Github to make sure it has not already been reported. If it has been reported, then please contribute to the conversation on the issue and provide any additional information you can. If it has not been reported, please be as detailed as possible.
- Fork the repository into your own account if you have not done so already.
- Commit changes to a git branch that is named after the changes you wish to contribute.
- Create a GitHub Pull Request for your change, following the Pull Request Requirements
- Perform a Code Review with the cookbook maintainers on the pull request.
In order to maintain a high standard of compatibility and consistency for the consumers of our cookbook we like to make sure all pull requests meet the following criteria:
- Tests: To ensure high quality code and protect against regressions in the future we require all changes have ample test coverage. This does not mean 100% coverage or even specific types of coverage. See the TESTING.md file for details on how to run the test suite.
- Passing Continuous Integration (CI): Speaking of tests, the contributed code must pass our full suite of tests on GitHub and show a green indicator meaning the latest build passes. If for some reason the build is failing before your pull request, please raise the issue in the pull request so we may address it.
Code review takes place in GitHub pull requests. See this article if you're not familiar with GitHub Pull Requests.
Once you open a pull request, cookbook maintainers will review your code using the built-in code review process in Github PRs. The process at this point is as follows:
- A cookbook maintainer will review your code and merge it if no changes are necessary. Your change will be merged into the cookbooks's
master
branch and will be noted in the cookbook'sCHANGELOG.md
at the time of release. - If a maintainer has feedback or questions on your changes they they will set
request changes
in the review and provide an explanation.
- DO include tests in your pull requests where applicable
- DONT modify or change the version number in the
metadata.rb
as we prefer to control the release cycle ourselves and it makes for code merging headaches that make everyone involved pretty sad - DONT modify the
CHANGELOG.md
in your pull request as well. The maintainers will auto-generate this before a new release. - DO remember that humans are handling your contributions so please be nice and polite when discussing anything in your pull request.