Skip to content

Latest commit

 

History

History
53 lines (35 loc) · 3.78 KB

release_process.md

File metadata and controls

53 lines (35 loc) · 3.78 KB

Release and deployment process

  • PRs may be deployed to staging before merge to confirm they work in that environment.
  • Most PRs (beyond documentation changes) should be deployed to production after merge to get features out to users.
  • Most redeployments will also be new versioned releases, but a release is not strictly necessary for every redeployment.

Release schedule

  • Software releases are made in advance of Feature Refinement meetings with Product Owners. This is managed through an automated reminder on the RDSS team Slack channel the morning prior. Whoever acknowledges the reminder first is taking point on putting out the release by doing so. Any additional features/bug fixes/code work that happens after the release is not guaranteed as a subject of review during the next day's meeting.
  • As much as possible, software releases of completed features and bug fixes are completed the day before expected demos, such as during the RDOS Repository Roundup meeting or larger public demos. The team self manages in terms of reminding each other and taking point on performing these releases/being aware of the state of the software in the leadup to the demo.

Release

Release pre-requisites

We use Intuit Auto to automate the deployment. To install 'auto' via brew:

  1. brew tap intuit/auto https://github.com/intuit/auto
  2. brew install auto
  3. Create a new Github Token with write:packages privs.
  • When creating a new token, select Generate new token (classic)
  • For the note section of the new token, add something like RDSS Release Process to help identify what this token is used for.
  • For the privs section, select the following: Under "repo" repo:status, repo_deployment, public_repo. Selecting these will ensure that you will have the appropriate access to deploying RDSS applications.
  1. Add the token to the approapriate startup file (e.g. .bash_profile, .zshrc) for your shell. Something like: echo 'export GH_TOKEN="YourTokenHere"' >> ~/.bash_profile

Release process

  • git checkout main
  • git pull for latest changes to MAIN branch
  • git tag -l will show what tags exist
    • For information on the latest release to know what the new version of the tag should be, you may navigate to the Releases section in the repository of the application you want to deploy. The version will be displayed on the right side of the repository in Github.
  • git tag <versionOfTheTag> create the tag
  • git push --tags push the new tag on Github
  • auto release will create a new release on Github
  • Review the generated release notes and edit them as needed

Deployment

Deployment pre-requiusites

Deployment process

For the deployment process to be completed, once you have generated the release notes on Github, you are then able to deploy.

From the MAIN branch, execute the following: BRANCH=<versionOfTheTag> bundle exec cap staging deploy

Review these changes on the appropriate staging environment, and if you run into any bugs or unexpected results, please let someone on the RDSS team know as soon as possible. There may need to be a ticket created to address this bug.

If there are no issues with your latest deployment after reviewing staging, you may deploy those changes to production

BRANCH=<versionOfTheTag> bundle exec cap production deploy

After you have successfully deployed to both staging and production, and have reviewed the application in the browser to check for any bugs present, send deployment notes generated from the Releases page of the latest version in Github and paste them to the #digital_open_data_and_research Slack channel.