...
Channels where we receive input
How we choose work to be done
UX design
UI design
Jira
Sprint planning
…and everything else leading up to…
Development
We follow the development process below to have:
Code changes that maintain the existing code’s design and style
Code changes that do not decrease test coverage or maintainability
Commit messages and Pull Requests that are in a consistent format
Pull Requests that are easy and fast to review to avoid review bottlenecks
After a developer is assigned a Jira task, they begin work.
Make sure that the Jira task has a clear description, and then move it to
IN PROGRESS
Expand | ||
---|---|---|
| ||
Ideally the description in the Jira task is written in a way that it can be copied and pasted as the description of the Pull Request. This is very subjective, but the description should:
|
Unless you’re the person most familiar with the area of the codebase that you are changing, first discuss the changes with that person
Expand | ||||
---|---|---|---|---|
| There
| |||
This is important because you don’t want to spend time on a Pull Request only to find out that it has to be completely redone because of its core design. Also, there will always be improvements underway in the CHEFS code, and any new work must align with those improvements - so following the existing design/code might not be the best approach. The end goal of these improvements is code that is:
Information that everyone should be familiar with: |
If necessary, break the Jira task into smaller pieces of work
Expand | ||
---|---|---|
| ||
The goal for all developers is to create Pull Requests that are easy and fast to review. If a task contains a large amount of work, break it down into smaller stand-alone tasks. Jira subtasks are one way of recording this, and allow the subtask to go through the various Jira Kanban stages. |
Using the
type
from Conventional Commits, decide what the primary type of work is, such asfeat
for a new feature
Expand | ||
---|---|---|
| ||
|
Ensure that the
main
branch in your cloned fork is up to date
Expand | ||
---|---|---|
| ||
The
|
With an example Jira task
FORMS-1234
that is a newfeat
, create a branch off yourmain
with a name likefeat/1234-new-map-component
Expand | ||
---|---|---|
| ||
You can name the branch anything you want, but:
|
Crank out some code and tests (or tests and code, for TDD bonus points) and whatever
...
documentation that needs to be created or updated
Periodically commit your work with messages like:
Code Block
...
feat: FORMS-1234
...
new
...
map
...
component
...
for dropping a pin
...
...
...
Added
...
a
...
new
...
map
...
component
...
that
...
allows
...
the
...
user
...
to
...
drop
...
a "pin"
...
on the map, and
...
the
...
location is
...
saved as either Lat/Lon or UTM coordinates.
Expand | ||||
---|---|---|---|---|
| We want everyone to use this standard way of writing commit messages so that in the future we can use them to automatically generate a changelog
| |||
It’s only a recommendation that “working” commit messages use this format - these commit messages will eventually be squashed, and it’s only the final commit message that must be in this format. It’s a good idea to always use this format to be familiar with how the final commit message must look.
|
Run the unit tests using
Terminal
→Run Task...
→Unit Tests
and check the test coverage of your new code
Expand | ||
---|---|---|
| ||
Test coverage reports appear in:
Refer to the backend unit test documentation for details on:
|
Publish your branch
...
Create a Pull Request (format, draft, read diff)
...
GitHub Actions
...
Do a self review (diff)
...
(somewhere above: limit size of change)
...
Run the deploy Action
...
test
...
Mark as ready for review
...
Add reviewers
...
Talk to reviewers
...
Keep up to date
...
Deploy Action
...
merge and message
...
Push Action
...
Undeploy Action
...
Code Climate / etc?
...
to your fork, for example by using the “Publish” button in VS Code
Start to create a Pull Request for your branch, for example by using “New pull request” in the GitHub web site
Enter the “title” for your Pull Request in the format
feat: FORMS-1234 new map component for dropping a pin
Expand | ||
---|---|---|
| ||
We use the format
Please make the description meaningful:
If your changes won’t fit in a short description, it’s possible that your Pull Request is changing too many things. |
Enter the GitHub “description” for your Pull Request using the template provided. The template contains comments to help make the process easier
Before clicking the create button, read through all the file diffs
Expand | ||
---|---|---|
| ||
This is a chance to do a self-review of your changes before creating the PR
|
Click the “Draft pull request” button to create the Pull Request
Wait for the automatically-run “Tests” GitHub Action to complete successfully
Expand | ||
---|---|---|
| ||
The “Tests” GitHub Action runs:
Note that the test coverage is not uploaded to Code Climate, as Actions run from Pull Requests do not have access to the GitHub Secrets needed to authenticate with Code Climate. |
Using your Pull Request number, run the “PR Deploy” Action
Expand | ||
---|---|---|
| ||
There are various ways to tell this:
|
Test your changes in the deployed Pull Request instance
Do a self-review of your Pull Request
Expand | ||
---|---|---|
| ||
Pull Requests should be created so that can be easily and quickly reviewed. By reading through every line of your code changes (because the reviewer should also be reading every line) you check that the Pull Request will make sense to your reviewers. It might help to add a GitHub comment to your code changes to explain them better. It might help to split your Pull Request into smaller pieces if it is too large: small Pull Requests that take five or ten minutes to review will get a more thorough review than Pull Requests that take hours or days. |
Click the “Ready to review” button to take your Pull Request out of “draft”
If necessary, add reviewers
Expand | ||
---|---|---|
| ||
Ideally every developer would review and understand every change in every Pull Request, but that’s not practical. Code reviews have many purposes:
There are two ways of looking at Pull Requests:
We can use the Ship / Show / Ask approach to Pull Requests:
|
Tell your reviewers about the Pull Request
Expand | ||
---|---|---|
| ||
This step really depends on the reviewer. Some people notice right away that they have been asked to do a review, but that isn’t guaranteed. It doesn’t hurt to post in the team channel on Discord that something is ready for review and “mention” the reviewers. If your change is complex or if your team members are less familiar with that part of the code, it might be good to set up a meeting to explain the changes |
In Jira move the task to
PULL REQUEST (PR)
Keep your branch up to date with
main
and re-run the “PR Deploy” Action
Expand | ||
---|---|---|
| ||
It depends! It’s good to always be up to date because the testing and review is more meaningful if the base branch is up to date. However, it can also waste a lot of time if one person is putting in multiple small changes and you’re trying to update for every merge. Find a balance between having a current base and spending time keeping it current. You can use the GitHub web site to update your branch, but note that this leaves the branch in your local environment out of sync. This might be OK if the update is for completely different parts of the code, but if there are conflicts then it's better to update locally and push to your branch. |
Expand | ||
---|---|---|
| ||
If you or others are testing the deployed code, but the code is not up to date with main, then bugs could sneak through. When you look at your Pull Request there will be comments in the timeline for commits, and comments from the |
Wait for approval (if needed) and merge your changes with the properly formatted commit message like:
Code Block |
---|
feat: FORMS-1234 new map component for dropping a pin
Added a new map component that allows the user to drop a "pin" on the map,
and the location is saved as either Lat/Lon or UTM coordinates. |
Expand | ||
---|---|---|
| ||
This format must be followed as we eventually want to introduce automated changelogs and versioning. |
Monitor the
Push
Action
Expand | ||
---|---|---|
| ||
The
Once you have merged your changes, ensure that they are deployed through all environments. Do not leave a deployment “hanging” and deployed to only the lower environments, as the next merge will probably cause it to go all the way to prod. If the change is tested and approved, it should go to prod as soon as possible. |
Run the
PR Undeploy
Action with your Pull Request number
Expand | ||
---|---|---|
| ||
Maybe? Merge can only be done by people with write access to the repo, so in theory on merge we would have access to the GitHub secrets and could undeploy automatically if we can figure out the PR number. If this doesn’t work then the “dumb” way of doing it would be to figure out with PRs are deployed and then see if they are open or not. |
Check Code Climate
Expand | ||
---|---|---|
| ||
We use Code Climate to monitor maintainability and code coverage. However, it will probably be replaced by SonarCloud in the near future. But it doesn’t hurt to check that your changes didn’t decrease our maintainability or code coverage. |
Move Jira task to
DONE
Celebrate 🎉