We welcome your contributions!
After you fork and clone the repo, the process for submitting a pull request is fairly straightforward and generally follows this workflow:
- Create a feature branch
- Make your changes
- Rebase
- Write unit tests
- Create a pull request
- Update the pull request
git checkout master
git pull upstream master
git checkout -b <name-of-the-feature>
Modify the files, build, test, lint and eventually commit your code using the following command:
git add <path/to/file/to/commit>
git commit
git push origin <name-of-the-feature>
The above commands commit the files into your feature branch. You can keep pushing new changes into the same branch until you are ready to create a pull request.
Sometimes your feature branch gets stale with respect to the master branch, and requires a rebase. The following steps can help:
git checkout <name-of-the-feature>
git fetch upstream
git rebase upstream/master
Note: If no conflicts arise, these commands ensure that your changes are applied on top of the latest changes from the master branch. Any conflicts must be manually resolved.
We use the Jest testing framework. You must test your code to verify that the function works as expected. Create unit tests in the /src/test/
subfolder
npm test
If you've never created a pull request before, follow [these instructions][creating-a-pull-request]. Fill up the pull request template to inform us of your change.
git fetch origin
git rebase origin/${base_branch}
# If there were no merge conflicts in the rebase
git push origin ${feature_branch}
# If there was a merge conflict that was resolved
git push origin ${feature_branch} --force
note: If more changes are needed as part of the pull request, just keep committing and pushing your feature branch as described above and the pull request automatically updates.