First, thank you for contributing to kbcli!
This document provides guidelines for how to contribute to kbcli.
Before contributing to kbcli go through the issues and pull requests, make sure you are familiar with GitHub and the pull request workflow.
To submit a proposed change, read the following workflow:
- Before you create a new issue, please search on the open issues page to see if the issue or feature request has already been filed.
- If you find your issue already exists, make relevant comments or add your reaction.
- If you can not find your issue exists, choose a specific issue type and open a new issue.
Currently, there are 4 types of issues:
- Bug report: You’ve found a bug with the code, and want to report or track the bug. Show more details, and let us know about an unexpected error, a crash, or an incorrect behavior.
- Feature request: Suggest a new feature. This allows feedback from others before the code is written.
- Improvement request: Suggest an improvement idea for this project. Use this issue type for document related improvements.
- Report a security vulnerability: Review our security policy first and then report a vulnerability.
- Fork the kbcli repository to your GitHub account, create a new branch and clone to your host.
- Branch naming style should match the pattern:
feature/|bugfix/|release/|hotfix/|support/|dependabot/
. kbcli performs a pull request check to verify the pull request branch name.
- Branch naming style should match the pattern:
- Run
make kbcli
in your terminal to build kbcli. The binary is located in.bin/kbcli
. - To install KubeBlocks and play with
kbcli
prepare environment using this guide.
To check if the local changes made in the CLI are working as desired, perform the below steps:
- Run
make help
to check all available commands. - Use
./bin/kbcli
instead of kbcli to perform tasks with your local build. For example -./bin/kbcli --help
. - Run
make test
to run all the tests. - To run cases by module
go test ./path/to/your/module...
The pull request title must follow the format outlined in the conventional commits spec. Because kbcli squashes commits before merging branches, this means that the pull request title must conform to this format. kbcli performs a pull request check to verify the pull request title in case you forget.
The following are all good examples of pull request titles:
feat(apps): add foo bar baz feature
fix(kbcli): fix foo bar baz bug
chore: tidy up Makefile
docs: fix typos
Wait for the CI process to finish and make sure all checks are green.
All pull requests should be reviewed and a pull request needs at least be approved by two maintainers before merging.
All pull requests are squashed and merged. After the code review is finished, the pull request will be merged into the main branch.
To protect all users of KubeBlocks, the following legal requirements are made. If you have additional questions, please contact us at kubeblocks@apecloud.com
.