157 lines
4.8 KiB
Markdown
157 lines
4.8 KiB
Markdown
|
# Contribution guide
|
||
|
|
||
|
First, thank you for contributing! We love and encourage pull requests from
|
||
|
everyone. Please follow the guidelines:
|
||
|
|
||
|
- Check the open [issues](https://git.frostfs.info/TrueCloudLab/frostfs-node/issues) and
|
||
|
[pull requests](https://git.frostfs.info/TrueCloudLab/frostfs-node/pulls) for existing
|
||
|
discussions.
|
||
|
|
||
|
- Open an issue first, to discuss a new feature or enhancement.
|
||
|
|
||
|
- Write tests, and make sure the test suite passes locally and on CI.
|
||
|
|
||
|
- Open a pull request, and reference the relevant issue(s).
|
||
|
|
||
|
- Make sure your commits are logically separated and have good comments
|
||
|
explaining the details of your change.
|
||
|
|
||
|
- After receiving feedback, amend your commits or add new ones as
|
||
|
appropriate.
|
||
|
|
||
|
- **Have fun!**
|
||
|
|
||
|
## Development Workflow
|
||
|
|
||
|
Start by forking the `frostfs-node` repository, make changes in a branch and then
|
||
|
send a pull request. We encourage pull requests to discuss code changes. Here
|
||
|
are the steps in details:
|
||
|
|
||
|
### Set up your Forgejo repository
|
||
|
Fork [FrostFS node upstream](https://git.frostfs.info/TrueCloudLab/frostfs-node) source
|
||
|
repository to your own personal repository. Copy the URL of your fork (you will
|
||
|
need it for the `git clone` command below).
|
||
|
|
||
|
```sh
|
||
|
$ git clone https://git.frostfs.info/TrueCloudLab/frostfs-node
|
||
|
```
|
||
|
|
||
|
### Set up git remote as ``upstream``
|
||
|
```sh
|
||
|
$ cd frostfs-node
|
||
|
$ git remote add upstream https://git.frostfs.info/TrueCloudLab/frostfs-node
|
||
|
$ git fetch upstream
|
||
|
$ git merge upstream/master
|
||
|
...
|
||
|
```
|
||
|
|
||
|
### Create your feature branch
|
||
|
Before making code changes, make sure you create a separate branch for these
|
||
|
changes. Maybe you will find it convenient to name branch in
|
||
|
`<type>/<Issue>-<changes_topic>` format.
|
||
|
|
||
|
```
|
||
|
$ git checkout -b feature/123-something_awesome
|
||
|
```
|
||
|
|
||
|
### Test your changes
|
||
|
After your code changes, make sure
|
||
|
|
||
|
- To add test cases for the new code.
|
||
|
- To run `make lint` and `make staticcheck-run`
|
||
|
- To squash your commits into a single commit or a series of logically separated
|
||
|
commits run `git rebase -i`. It's okay to force update your pull request.
|
||
|
- To run `make test` and `make all` completes.
|
||
|
|
||
|
### Commit changes
|
||
|
After verification, commit your changes. This is a [great
|
||
|
post](https://chris.beams.io/posts/git-commit/) on how to write useful commit
|
||
|
messages. Try following this template:
|
||
|
|
||
|
```
|
||
|
[#Issue] <component> Summary
|
||
|
|
||
|
Description
|
||
|
|
||
|
<Macros>
|
||
|
|
||
|
<Sign-Off>
|
||
|
```
|
||
|
|
||
|
```
|
||
|
$ git commit -sam '[#123] Add some feature'
|
||
|
```
|
||
|
|
||
|
### Push to the branch
|
||
|
Push your locally committed changes to the remote origin (your fork)
|
||
|
```
|
||
|
$ git push origin feature/123-something_awesome
|
||
|
```
|
||
|
|
||
|
### Create a Pull Request
|
||
|
Pull requests can be created via Forgejo. Refer to [this
|
||
|
document](https://docs.codeberg.org/collaborating/pull-requests-and-git-flow/) for
|
||
|
detailed steps on how to create a pull request. After a Pull Request gets peer
|
||
|
reviewed and approved, it will be merged.
|
||
|
|
||
|
## DCO Sign off
|
||
|
|
||
|
All authors to the project retain copyright to their work. However, to ensure
|
||
|
that they are only submitting work that they have rights to, we are requiring
|
||
|
everyone to acknowledge this by signing their work.
|
||
|
|
||
|
Any copyright notices in this repository should specify the authors as "the
|
||
|
contributors".
|
||
|
|
||
|
To sign your work, just add a line like this at the end of your commit message:
|
||
|
|
||
|
```
|
||
|
Signed-off-by: Samii Sakisaka <samii@ivunojikan.co.jp>
|
||
|
|
||
|
```
|
||
|
|
||
|
This can easily be done with the `--signoff` option to `git commit`.
|
||
|
|
||
|
By doing this you state that you can certify the following (from [The Developer
|
||
|
Certificate of Origin](https://developercertificate.org/)):
|
||
|
|
||
|
```
|
||
|
Developer Certificate of Origin
|
||
|
Version 1.1
|
||
|
|
||
|
Copyright (C) 2004, 2006 The Linux Foundation and its contributors.
|
||
|
1 Letterman Drive
|
||
|
Suite D4700
|
||
|
San Francisco, CA, 94129
|
||
|
|
||
|
Everyone is permitted to copy and distribute verbatim copies of this
|
||
|
license document, but changing it is not allowed.
|
||
|
|
||
|
|
||
|
Developer's Certificate of Origin 1.1
|
||
|
|
||
|
By making a contribution to this project, I certify that:
|
||
|
|
||
|
(a) The contribution was created in whole or in part by me and I
|
||
|
have the right to submit it under the open source license
|
||
|
indicated in the file; or
|
||
|
|
||
|
(b) The contribution is based upon previous work that, to the best
|
||
|
of my knowledge, is covered under an appropriate open source
|
||
|
license and I have the right under that license to submit that
|
||
|
work with modifications, whether created in whole or in part
|
||
|
by me, under the same open source license (unless I am
|
||
|
permitted to submit under a different license), as indicated
|
||
|
in the file; or
|
||
|
|
||
|
(c) The contribution was provided directly to me by some other
|
||
|
person who certified (a), (b) or (c) and I have not modified
|
||
|
it.
|
||
|
|
||
|
(d) I understand and agree that this project and the contribution
|
||
|
are public and that a record of the contribution (including all
|
||
|
personal information I submit with it, including my sign-off) is
|
||
|
maintained indefinitely and may be redistributed consistent with
|
||
|
this project or the open source license(s) involved.
|
||
|
```
|