Ceph-csi is written in Go and if you are new to the language, it is highly encouraged to:
- Take the A Tour of Go course.
- Set up Go development environment on your machine.
- Read Effective Go for best practices.
- Download Go (>=1.11.x) and install it on your system.
- Setup the GOPATH environment.
- Ceph-CSI uses the native Ceph libaries through the go-ceph
package. It is required to install the
Ceph C headers in order to compile Ceph-CSI. The packages are called
libcephfs-devel
,librados-devel
andlibrbd-devel
on many Linux distributions. See the go-ceph installaton instructions for more details. - Run
$ go get -d github.com/ceph/ceph-csi
This will just download the source and not build it. The downloaded source will be at$GOPATH/src/github.com/ceph/ceph-csi
- Fork the ceph-csi repo on Github.
- Add your fork as a git remote:
$ git remote add fork https://github.com/<your-github-username>/ceph-csi
Editors: Our favorite editor is vim with the vim-go plugin, but there are many others like vscode
To build ceph-csi locally run:
$ make
To build ceph-csi in a container:
$ make containerized-build
The built binary will be present under _output/
directory.
ceph-csi repository currently follows GitHub's [Fork & Pull] (https://help.github.com/articles/about-pull-requests/) workflow for code contributions.
Please read the coding guidelines document before submitting a PR.
Here is a short guide on how to work on a new patch. In this example, we will work on a patch called hellopatch:
$ git checkout master
$ git pull
$ git checkout -b hellopatch
Do your work here and commit.
Run the test suite, which includes linting checks, static code check, and unit tests:
$ make test
You will need to provide unit tests and functional tests for your changes wherever applicable.
Once you are ready to push, you will type the following:
$ git push fork hellopatch
Creating A Pull Request: When you are satisfied with your changes, you will then need to go to your repo in GitHub.com and create a pull request for your branch. Automated tests will be run against the pull request. Your pull request will be reviewed and merged.
If you are planning on making a large set of changes or a major architectural change it is often desirable to first build a consensus in an issue discussion and/or create an initial design doc PR. Once the design has been agreed upon one or more PRs implementing the plan can be made.
Review Process: Once your PR has been submitted for review the following critieria will need to be met before it will be merged:
- Each PR needs reviews accepting the change from at least two developers
- for merging
- It is common to request reviews from those reviewers automatically suggested
- by github
- Each PR needs to have been open for at least 24 working hours to allow for
- community feedback
- The 24 working hours counts hours occuring Mon-Fri in the local timezone
- of the submitter
- Each PR must be fully updated to master and tests must have passed
When the criteria are met, a project maintainer can merge your changes into the project's master branch.
The flow for getting a fix into a release branch is:
- Open a PR to merge the changes to master following the process outlined above.
- Add the backport label to that PR such as
backport-to-release-vX.Y.Z
- After your PR is merged to master, the mergify bot will automatically open a PR with your commits backported to the release branch
- If there are any conflicts you will need to resolve them by pulling the branch, resolving the conflicts and force push back the branch
- After the CI is green, the bot will automatically merge the backport PR.