ooni-probe is a Free and Open Source software project that welcomes new contributions.
For guidelines on what coding style we follow refer to the coding style document.
You should first create a fork of ooni-probe by clicking on the fork button and cloning your fork with:
git clone [email protected]:username/ooni-probe.git
cd ooni-probe
git remote add upstream https://github.com/TheTorProject/ooni-probe.git
Branches should be created from the master
branch with an accurately
labelled name.
If you want to work on a new feature you could name your branch
feature/myfeature
, if you are fixing a bug you could name it bug/1234
.
Create your branch from master
like so:
git checkout -b mybranch
Then you can start hacking
Make sure git knows your username and email address with the following:
git config --global user.name "Jane Doe"
git config --global user.email "[email protected]"
Try to keep the commits made on the branch small (a good branch should only address one specific issue).
Make sure all the existing unittests for ooni-probe are passing.
trial ooni
If you add extra code or modify existing code, be sure that it is covered by the existing unittests and if not write them. In general, it would be good for pull requests not to reduce the current code coverage of the project.
If you are submitting a branch fixing a bug, you should also be submitting a unittest that is capable of reproducing the bug you are attempting to fix.
You can then push your feature branch to your remote and open a pull request.
Small pull requests should be tagged as hotfix
and can be self
merged. All other pull request should be reviewed by another core
developer who will take responsibility of the merge. The repository
should be configured such that it is not possible to merge into
master
(or stable
) if unit tests are not passing.
If the diff is small, squash merge is preferred, otherwise preserve the history. In general it is a good idea to keep your branches in sync with master and rebase them from time to time before the review has happenned. However if the review has already begun it's better to merge and resolve the conflicts locally and push the merge commit, to allow the reviewer to see how the conflicts were resolved.
Before a release, review the code base, fixing simple bugs directly and opening issues to describe more complex required fixes and refactoring opportunities. Also during such review make sure that the documentation is up to date with the code.