Thank you for your interest in contributing to our project. Whether it's a bug report, new feature, correction, or additional documentation, we greatly value feedback and contributions from our community.
Please read through this document before submitting any issues or pull requests to ensure we have all the necessary information to effectively respond to your bug report or contribution.
We welcome you to use the GitHub issue tracker to report bugs or suggest features.
When filing an issue, please check existing open, or recently closed, issues to make sure somebody else hasn't already reported the issue. Please try to include as much information as you can. Details like these are incredibly useful:
- A reproducible test case or series of steps
- The version of our code being used
- Any modifications you've made relevant to the bug
- Anything unusual about your environment or deployment
Contributions via pull requests are much appreciated. Before sending us a pull request, please ensure that:
- You are working against the latest source on the main branch.
- You check existing open, and recently merged, pull requests to make sure someone else hasn't addressed the problem already.
- You open an issue to discuss any significant work - we would hate for your time to be wasted.
To send us a pull request, please:
- Fork the repository.
- Modify the source; please focus on the specific change you are contributing. If you also reformat all the code, it will be hard for us to focus on your change.
- Ensure local tests pass.
- Commit to your fork using clear commit messages.
- Send us a pull request, answering any default questions in the pull request interface.
- Pay attention to any automated CI failures reported in the pull request, and stay involved in the conversation.
GitHub provides additional document on forking a repository and creating a pull request.
As required by our security team, it's essential to install git-secrets in your development environment. This prevents the inadvertent committing of credentials into the repository. Please follow the instructions here to install git-secretes. If you have concerns regarding its requirement, kindly consult the maintainers.
We use GitHub Actions to enforce some restrictions when we merge a pull request, which maintains the quality of our repository code. Therefore, we recommend using the following tools to accommodate smoothly merge process of your pull request.
For local development, you can use rustfmt
and clippy
to maintain the quality of our source code.
Also, it is enforced by our GitHub Actions.
Before starting, please ensure both components are installed;
rustup component add rustfmt clippy
Additionally, we use pre-commit
hooks to execute automated linting and basic checks.
Please set it up before creating a commit;
brew install pre-commit # (or appropriate for your platform: https://pre-commit.com/)
pre-commit install
We also use trycmd to conduct snapshot testing for CLI. If the snapshot is needed to be updated, run command;
MacOS and Linux
TRYCMD=overwrite cargo test --test cli_tests
Windows (PowerShell)
$Env:TRYCMD='overwrite'
cargo test --test cli_tests
[Environment]::SetEnvironmentVariable('TRYCMD',$null)
Please note that we use different snapshots for the Windows environment. Therefore, you need to update snapshot both Linux and Windows after modifying the behavior of CLI output.
We temporarily disable the bot command currently.
If you want to update snapshots of commands, you can use the bot command /snapshot
in your pull request.
Please note that you must type a command exactly as written.
The bot creates diff files for both Windows and Linux. You can use generated diff to patch your commit.
For example, if you have developed in a Linux environment and modified the command option,
you must also update the snapshot for the Windows environment.
In this case, you can create a pull request for draft mode and execute /snapshot
to create a diff file for Windows.
Generated diff can be copied into a file and applied by git diff <file-name>
command.
Looking at the existing issues is a great way to find something to contribute on. As our projects, by default, use the default GitHub issue labels (enhancement/bug/duplicate/help wanted/invalid/question/wontfix), looking at any 'help wanted' issues is a great place to start.
This project has adopted the Amazon Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opensource-codeofconduct@amazon.com with any additional questions or comments.
If you discover a potential security issue in this project we ask that you notify AWS/Amazon Security via our vulnerability reporting page. Please do not create a public github issue.
See the LICENSE file for our project's licensing. We will ask you to confirm the licensing of your contribution.