Yorkie is Apache 2.0 licensed and accepts contributions via GitHub pull requests. This document outlines some conventions on commit message formatting, contact points for developers, and other resources to help get contributions into Yorkie.
If you have any questions along the way, please don’t hesitate to ask us
- Discord: Yorkie Discord.
This is a rough outline of a contributor's workflow:
- Install prerequisites for developing Yorkie.
- Create a personal fork of the original repository.
- Clone the fork to your local working directory.
- Set environment for building and testing.
- Create a topic branch from where to base the contribution (usually main).
- Make commits of logical units.
- Make sure all tests pass, and add any new tests as appropriate.
- Make sure commit messages are in the proper format (see below).
- Push changes in a topic branch to the forked repository.
- Submit a pull request to the original repository.
- After receiving LGTM from maintainers, the PR will be merged.
Thanks for contributing!
Below are needed for developing and building Yorkie.
- Go (version 1.18+)
- Protobuf Compiler (version 3.4.0+)
- Docker
You must install required Go packages to build Yorkie executable.
make tools
make build # executable: ./bin/yorkie
You can set testing environment via Docker Compose. It is needed because integration tests require local applications like MongoDB and ETCD.
docker-compose -f build/docker/docker-compose.yml up --build -d
make test
You can automatically check the programmatic and stylistic errors of your code.
make lint
For developers, design documents about core features are provided. You can refer to the docs for understanding the overall structure of Yorkie.
The coding style suggested by the Golang community is used in Yorkie. See the style doc for details. We also recommended referring to Uber Go Style Guide.
If you make any changes to the code, run make fmt
to automatically format the code according to Go standards.
We follow a rough convention for commit messages that is designed to answer two questions: what changed and why. The subject line should feature the what and the body of the commit should describe the why.
Remove the synced seq when detaching the document
To collect garbage like CRDT tombstones left on the document, all
the changes should be applied to other replicas before GC. For this
, if the document is no longer used by this client, it should be
detached.
The first line is the subject and should be no longer than 70 characters, the second line is always blank, and other lines should be wrapped at 80 characters. This allows the message to be easier to read on GitHub as well as in various git tools.
Testing is the responsibility of all contributors, but it is also coordinated by maintainers. It is recommended to write them in order from successful cases to exceptional cases.
There are multiple types of tests. The location of the test code varies with type, as do the specifics of the environment needed to successfully run the test:
- Unit: These confirm that a particular function behaves as intended.
- Integration: These tests cover interactions of package components or interactions between Yorkie packages and some other non-Yorkie system resource (eg: MongoDB, ETCD).
- Benchmark: These confirm that the performance of the implemented function.
We are using Codecov for analyzing PR's code coverage. If you want to check the coverage of your code in local browser, you can run the command below.
make coverage
We require that all contributors sign our Contributor License Agreement ("CLA") before we can accept the contribution.
Open a pull request ("PR") to any of our open source projects to sign the CLA. A bot will comment on the PR asking you to sign the CLA if you haven't already.
Follow the steps given by the bot to sign the CLA. This will require you to log in with GitHub. We will only use this information for CLA tracking. You only have to sign the CLA once. Once you've signed the CLA, future contributions to the project will not require you to sign again.
If the bot still require you to sign the CLA although you had already signed, you can check your commit's author is equal to the Github account that you logged in.
Agreeing to a CLA explicitly states that you are entitled to provide a contribution, that you cannot withdraw permission to use your contribution at a later date, and that Yorkie Team has permission to use your contribution.
This removes any ambiguities or uncertainties caused by not having a CLA and allows users and customers to confidently adopt our projects. At the same time, the CLA ensures that all contributions to our open source projects are licensed under the project's respective open source license, such as Apache-2.0 License.
Requiring a CLA is a common and well-accepted practice in open source. Major open source projects require CLAs such as Apache Software Foundation projects, Facebook projects, Google projects, Python, Django, and more. Each of these projects remains licensed under permissive OSS licenses such as MIT, Apache, BSD, and more.