Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

  • 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.

  1. Make sure that the Jira task has a clear description, and then move it to IN PROGRESS

Expand
titleWhat makes a good Jira description

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:

  • Clearly describe the change that is needed

  • Be written in plain language - if it’s very technical then perhaps add a “Background” section that explains things in plain language

  • Contain an “Acceptance Criteria” section detailing what is needed for the task to be considered done

  1. 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
titleWhy is this important?

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:

  • necessary (YAGNI - don’t maintain, document, test, etc, code that we don’t need)

  • correct (it should work!)

  • simple (“as simple as possible but no simpler”)

  • documented

  • easy to read

  • easy to understand

  • easy to modify

  • easy to fully test

  • consistent (to reduce cognitive load)

Information that everyone should be familiar with:

  1. If necessary, break the Jira task into smaller pieces of work

Expand
titleWhy is this important?

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.

  1. Using the type from Conventional Commits, decide what the primary type of work is

...

  1. , such as feat for a new feature

Expand
titleList of the commit "type" values that we use
  • build: change in build system or dependencies

  • ci: change in continuous integration / deployment

  • docs: change to documentation

  • feat: a new feature is being added

  • fix: an existing bug or defect is being fixed

  • perf: change to improve performance

  • refactor: change to improve code quality

  • revert: reverts changes in a previous commit

  • style: change to code style/formatting

  • test: add missing tests or correct existing tests

  1. Ensure that the main branch in your cloned fork is up to date

Expand
titleThe fetch/rebase GitHub workflow

...

The fetch and rebase GitHub workflow used by Kubernetes is a common way to keep cloned repos in sync with the origin and upstream repos.

Note: Some people prefer to pull and create merge commits, and that’s fine because we squash commits when a Pull Request is merged into upstream/main.

  1. With an example Jira task FORMS-1234 that is a new feat, create a branch off your main with a name like

...

  1. feat/1234-new-map-component

...

Expand
titleWhy this format is recommended

You can name the branch anything you want, but:

  • the

...

  • feat/

...

  • prefix groups branches

...

  • of the same type in the tools

...

  • the task number 1234 makes it easy to find the corresponding ticket in Jira

...

  1. Crank out some code and tests (or tests and code,

...

  1. for TDD

...

  1. This is a test

Expand
titleNote

These are some notes

  1. This is a second test

Expand
titleDetails

These are the details

...

  1. bonus points) and whatever documentation that needs to be created or updated

  2. 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
titleWhy this format is recommended

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.

Tip: In the VS Code commit message input box, the up arrow allows you to scroll back through previous commit messages that you used.

  1. Run the unit tests using TerminalRun Task...Unit Tests and check the test coverage of your new code

Expand
titleEverything you ever wanted to know about the unit tests

Test coverage reports appear in:

  • Frontend: app/frontend/coverage/index.html

  • Backend: app/coverage/lcov-report/index.html

Refer to the backend unit test documentation for details on:

  • test writing strategy

  • running tests on the command line

  • running with and without the coverage report

  • running single specs or single tests

  1. Publish your branch to your fork, for example by using the “Publish” button in VS Code

  2. Start to create a Pull Request for your branch, for example by using “New pull request” in the GitHub web site

  3. Enter the “title” for your Pull Request in the format feat: FORMS-1234 new map component for dropping a pin

Expand
titleWhy this format is mandatory

We use the format type: FORMS-NNNN description for our Pull Request titles so that:

  • the type of change is obvious from the name of the Pull Request

  • it is easy to find all Pull Requests for a given type like feat or test

  • it is easy to find the Pull Request for a given FORMS-NNNN Jira task

  • the description makes it easy to scan Pull Requests to find a change that happened

Please make the description meaningful:

  • BAD: feat: FORMS-1234 add feature

  • GOOD: feat: FORMS-1234 add map component

  • BAD: fix: FORMS-2345 fix bug

  • GOOD: fix: FORMS-2345 fix layout bug with Data Grid

  • BAD: test: FORMS-3456 add tests

  • GOOD: test: FORMS-3456 finish test coverage for email service

If your changes won’t fit in a short description, it’s possible that your Pull Request is changing too many things.

  1. Enter the GitHub “description” for your Pull Request using the template provided. The template contains comments to help make the process easier

  2. Before clicking the create button, read through all the file diffs

Expand
titleWhy this is recommended

This is a chance to do a self-review of your changes before creating the PR

  • are the changes too big (too many files, too many lines) to be easily and quickly reviewed?

  • is the Pull Request doing too many different things? Can it be broken down into smaller PRs?

  • did reading the code remind you of work you forgot to do?

  • did you leave yourself ‘todo’ items that need to be completed?

  • is every changed line necessary? Was anything accidentally committed?

  • are there tests to cover the code changes / additions?

  • are there documentation updates for the code changes / additions?

  1. Click the “Draft pull request” button to create the Pull Request

  2. Wait for the automatically-run “Tests” GitHub Action to complete successfully

Expand
titleWhat tests are run?

The “Tests” GitHub Action runs:

  • GitHub CodeQL tests to look for security issues

  • Backend Jest unit tests, and saves test coverage as an artifact

  • Frontend Jest unit tests, and saves test coverage as an artifact

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.

  1. Using your Pull Request number, run the “PR Deploy” Action

Expand
titleHow do I know when the changes are deployed?

There are various ways to tell this:

  • Watching the Action you will see the Deploy step complete and display the URL of the deployment

  • Unless you have the notification disabled, you should receive an email

  • The Action will add a comment to the Pull Request

  1. Test your changes in the deployed Pull Request instance

  2. Do a self-review of your Pull Request

Expand
titleWhy is a self-review needed?

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.

  1. Click the “Ready to review” button to take your Pull Request out of “draft”

  2. If necessary, add reviewers

Expand
titleIf necessary?!!

Ideally every developer would review and understand every change in every Pull Request, but that’s not practical. Code reviews have many purposes:

  • Sharing knowledge: more people understanding the changes means better team knowledge of the code

  • Enforcing consistency: the code should look like a team effort, not a dozen people doing things their own way - this reduces cognitive load when working with the code

  • Preventing bugs: the goal of a review is not to test that someone’s code works, that’s the developer’s job. Reviewers very familiar with the code being changed, though, are likely to catch bugs introduced by people less familiar with the code - this is a great learning opportunity.

There are two ways of looking at Pull Requests:

  1. Those that use existing concepts / designs vs. those that introduce new concepts / designs

  2. Those that are simple changes vs. those that are complex changes

We can use the Ship / Show / Ask approach to Pull Requests:

  • Existing concepts / designs + simple changes: Ship it (example: dependency update, typo fix, small bug). Show or Ask for a review if you are uncertain or otherwise feel it’s necessary

  • Existing concepts / designs + complex changes: Show / tell other developers about the changes but doesn’t necessarily need a review (example: new feature that’s very similar to existing features). Ask for a review if you are uncertain or otherwise feel it’s necessary

  • New concepts / designs + simple changes: Ask for a review (example: small bugfix that needs a big new way of doing things)

  • New concepts / designs + complex changes: Ask for a review (example: new feature that’s different from anything we have)

  1. Tell your reviewers about the Pull Request

Expand
titleIs this always needed?

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

  1. In Jira move the task to PULL REQUEST (PR)

  2. Keep your branch up to date with main and re-run the “PR Deploy” Action

Expand
titleHow often should I update?

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
titleDo I have to re-run the Action?

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 PR Deploy Action. If there are commits after the last PR Deploy, then it should be deployed again. Retesting might be wanted if there were merge conflicts or other contention between the new main and the Pull Request code.

  1. 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
titleWhy is this format mandatory?

This format must be followed as we eventually want to introduce automated changelogs and versioning.

  1. Monitor the Push Action

Expand
titleWhat does this Action do?

The Push Action runs on merge, and:

  1. Builds the application

  2. Does a no-outage deployment to dev

  3. Waits for gatekeeper approval to deploy to test

  4. Does a no-outage deployment to test

  5. Waits for gatekeeper approval to deploy to prod

  6. Does a no-outage deployment to prod

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.

  1. Run the PR Undeploy Action with your Pull Request number

Expand
titleCan this be automated?

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.

  1. Check Code Climate

Expand
titleWhat's Code Climate?

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.

  1. Move Jira task to DONE

  2. Celebrate 🎉