Contributions to this repo are very welcome! We follow a fairly standard pull request process for contributions, subject to the following guidelines:
- File a GitHub issue or write an RFC
- Update the documentation
- Update the tests
- Update the code
- Create a pull request
- Merge and release
Before starting any work, we recommend filing a GitHub issue in this repo. This is your chance to ask questions and get feedback from the maintainers and the community before you sink a lot of time into writing (possibly the wrong) code. If there is anything you're unsure about, just ask!
Sometimes, the scope of the feature proposal is large enough that it requires major updates to the code base to
implement. In these situations, a maintainer may suggest writing up an RFC that describes the feature in more details
than what can be reasonably captured in a Github Issue. RFCs are written in markdown and live in the directory
_docs/rfc
.
To write an RFC:
- Clone the repository
- Create a new branch
- Copy the template (
_docs/rfc/TEMPLATE.md
) to a new file in the same directory. - Fill out the template
- Open a PR for comments, prefixing the title with the term
[RFC]
to indicate that it is an RFC PR.
We recommend updating the documentation before updating any code (see Readme Driven Development). This ensures the documentation stays up to date and allows you to think through the problem at a high level before you get lost in the weeds of coding.
We also recommend updating the automated tests before updating any code (see Test Driven Development). That means you add or update a test case, verify that it's failing with a clear error message, and then make the code changes to get that test to pass. This ensures the tests stay up to date and verify all the functionality in this Module, including whatever new functionality you're adding in your contribution. Check out Developing cloud-nuke for instructions on running the automated tests.
At this point, make your code changes and use your new test case to verify that everything is working. Check out
Developing cloud-nuke for instructions on how to build and run cloud-nuke
locally.
We have a style guide for the Go programming language, in which we documented some best practices for writing Go code. Please ensure your code adheres to the guidelines outlined in the guide.
Create a pull request with your changes. Please make sure to include the following:
- A description of the change, including a link to your GitHub issue.
- The output of your automated test run, preferably in a GitHub Gist. We cannot run automated tests for pull requests automatically due to security concerns, so we need you to manually provide this test output so we can verify that everything is working.
- Any notes on backwards incompatibility.
The maintainers for this repo will review your code and provide feedback. If everything looks good, they will merge the code and release a new version, which you'll be able to find in the releases page.