Submitting Your Work
Guidelines on how to submit a Pull Request for Code for Life.
Your PR title needs to follow the Semantic PR or the Conventional Commits Specification e.g.
fix: fix the infamous bug. Common types:
We follow Semantic Versioning in this project. The build version automatically gets bumped up based on the content of the PR title and description.
On the PR description, please include fixes: #issue-number. This will link the PR to the issue you're working on.
By contributing to the project and/or associated repositories (Portal, Rapid Router and Aimmo, Appengine), you agree to abide by the licence including future changes. Update notices will be posted on the release page.
Include unit tests when you contribute new features, as they help to a) prove that your code works correctly, and b) guard against future breaking changes to lower the maintenance cost. It's important to minimise human checking.
Bug fixes also generally require unit tests, because the presence of bugs usually indicates insufficient test coverage.
We use pytest for python unit tests, and cypress for the UI/frontend. There are still older tests with selenium and python
unittest, but we aim to eventually migrate everything to
pytestand cypress. All tests can be run with running
pytest. To run selenium tests, you need chromedriver installed.
We perform code review process for every change, whether internally or externally. We use Reviewable for this. You should get an email notification when someone leaves a review for your PR. If not, please check your email settings, and keep an eye on the Reviewable section of your PR.
Click on the Reviewable button on the PR page to go to the corresponding Reviewable page
Based on the review, you may have to go back and make updates, or you could comment to answer questions or justify your code. This review process may go back and forth a few times.
We encourage a collaborative environment where anyone can review anyone's PR. Code reviewing is not reserved for core developers only, and multiple people can review someone's PR.
Once the review is complete and approved, the branch is ready to be merged.
Generally the core developers will need to merge the PR. You should get a notification when this happens.
If you're a regular developer and have obtained a write access to the repo, you will see a victory graphic appears on top of Reviewable page, and you can merge the PR by clicking the 'Merge & Delete branch':
Clicking the button will merge your branch to the main branch
At this point your work will have successfully merged into the main branch and go into the staging server. Next it will be deployed to production together with the other changes on the next deployment.
The Release Notes is updated on every deployment so please check the page for updates. Depending on what we're working on, we may deploy a couple of times a week or a couple of times a month.
If you have come this far, thank you. We appreciate the time and effort you have put into this 🙏. We hope that you've learned tonnes, enjoyed the process, and decide to continue helping us out.
There are many other ways that you can contribute. Testing, reporting issues, suggesting ideas, promoting the project - are some of the things that are very useful. Creating artwork or helping with translation are the others. Feedback for this documentation is very welcome too. Get in touch to find out how else you can help.
Last modified 5mo ago