- 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.
- 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.
We use Intuit Auto to automate the deployment. To install 'auto' via brew:
brew tap intuit/auto https://github.com/intuit/auto
brew install auto
- 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.
- 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
git checkout main
git pull
for latest changes toMAIN
branchgit 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 taggit push --tags
push the new tag on Githubauto release
will create a new release on Github- Review the generated release notes and edit them as needed
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.