Code Contribution Guide
In this code contribution guide, you will learn about the following:
- How to run Karpor locally
- How to create a pull request
- Code review guidelines
- Formatting guidelines for pull requests
- Updating Documentation and Website
Running Karpor Locallyâ
This guide will help you get started with Karpor development.
Prerequisitesâ
- Golang version 1.22+
Installing Golang
- Install go1.22+ from the official website. Extract the binary files and place them at a location, assuming it is located under the home directory
~/go/
, here is an example command, you should choose the correct binary file for your system.
wget https://go.dev/dl/go1.22.5.linux-amd64.tar.gz
tar xzf go1.22.5.linux-amd64.tar.gz
If you would like to maintain multiple versions of golang in your local development environment, you can download the package and extract it to a location, like ~/go/go1.22.1
, and then alter the path in the command below accordingly.
- Set environment variables for Golang
export PATH=~/go/bin/:$PATH
export GOROOT=~/go/
export GOPATH=~/gopath/
If the gopath
folder does not exist, create it with mkdir ~/gopath
. These commands will add the go binary folder to the PATH
environment variable (making it the primary choice for go) and set the GOROOT
environment to this go folder. Please add these lines to your ~/.bashrc
or ~/.zshrc
file, so you won't need to set these environment variables every time you open a new terminal.
- (Optional) Some regions, such as China, may have slow connection to the default go registry; you can configure GOPROXY to speed up the download process.
go env -w GOPROXY=https://goproxy.cn,direct
- Kubernetes version v1.20+ configured with
~/.kube/config
. - golangci-lint version v1.52.2+, it will be installed automatically if you run
make lint
, if the installation fails, you can install it manually.
Manually installing golangci-lint
You can install it manually following the guide, or use the command:
cd ~/go/ && curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s v1.52.2
Buildingâ
- Clone this project
git clone git@github.com:KusionStack/karpor.git
- Build locally
Executing make build-all
will build the executables for all platforms; if you only want to build for a specific platform, execute make build-${PlatformName}
, e.g., make build-darwin
. To see all available commands, execute make help
.
Testingâ
It's essential to write tests to maintain code quality, you can run all unit tests by executing the following command in the project root directory:
make test
If you need to generate extra coverage report files, execute:
make cover
Then you can view the content of the coverage report in a browser by running:
make cover-html
Creating a Pull Requestâ
We are thrilled that you are considering contributing to the Karpor project!
This document will guide you through the process of creating a pull request.
Before you beginâ
We know you are excited to create your first pull request. Before we get started, make sure your code follows the relevant code conventions.
Your First Pull Requestâ
Before submitting your PR, run the following commands to ensure they all succeed:
make test
make lint
If this is your first time contributing to an open-source project on GitHub, please make sure to read the instructions on creating a pull request.
To increase the chances of your pull request being accepted, please ensure your pull request follows these guidelines:
- The title and description match the implementation.
- The commits in the pull request follow the formatting guidelines.
- The pull request closes a related issue.
- The pull request includes necessary tests to verify the expected behavior.
- If your pull request has conflicts, please rebase your branch onto the main branch.
If the pull request fixes a bug:
- The pull request description must contain
Closes #<issue number>
orFixes #<issue number>
. - To prevent regressions, the pull request should include tests that replicate the bug being fixed.
Code Reviewâ
Once you have created a pull request, the next step is to have others review your changes. Review is a learning opportunity for both reviewers and the author of the pull request.
If you believe a specific person should review your pull request, you can tag them in the description or a comment.
Tag a user by typing an @
symbol followed by their username.
We recommend that you read How to do a code review to learn more about code reviews.
Formatting Guidelinesâ
A well-crafted pull request can minimize the time to get your changes accepted. These guidelines will help you write well-formulated commit messages and descriptions for your pull requests.
Commit Message Formatâ
More see: Commit Conventions
Pull Request Titleâ
When accepting pull requests, the Karpor team merges all commits into one.
The pull request title becomes the subject line of the merged commit message.
We still encourage contributors to write informative commit messages, as they will be part of the Git commit body.
We use the pull request titles when generating change logs for releases. Hence, we strive to make the titles as informative as possible.
Make sure your pull request title uses the same format as the commit message subject line. If the format is not followed, we will add a title-needs-formatting
label on the pull request.
Passing All CI Checksâ
Before merging, all testing CIs should pass:
- Coverage should not drop. Currently, the pull request coverage should be at least 60%.
- Karpor uses a CLA for the contributor agreement. It requires you to sign for every commit before merging the pull request.
Updating Documentation and Websiteâ
If your pull request has been merged, and it is a new feature or enhancement, you need to update the documentation and send a pull request to the kusionstack.io repository.
Learn how to write documentation through the following guide:
Awesome, you've completed the lifecycle of code contribution!