Skip to content

Release Manager's checklist

Gareth Rees edited this page Jun 6, 2019 · 120 revisions

This is a checklist of things to do in order to make a new release of alaveteli, which involves creating a release branch according to the git flow model, updating translations, and letting various people know. For more details on translation, see the translation documentation. For more details on git flow, see this description.

The process begins when the develop branch (almost) reflects the desired state of the new release.

Before the release candidate date

  • Make sure any recent migrations have corresponding model annotations (bundle exec annotate). Make sure you don't have any feature branch migrations applied to your development database while running this.
  • Remove any deprecated code scheduled for removal in this release - you can find it by grepping for [DEPRECATION] in the code
  • Test supported operating systems to make sure there haven't been dependency/install regressions
script/test-vagrant-provisioning
  • Add a description of the release to the Changes file in the release branch - this should include:
    • A list of all major features
git log --oneline --topo-order --show-linear-break master...develop
  • Are there any migrations?
git diff --name-only master..develop db/migrate
  • Is commonlib updated?
  • Are templates changed? (needs a note for people who customise them in their theme)
git --no-pager diff --name-only --diff-filter=DMRT master..develop app/views
  • Anything else re-users need to know?
  • Pick a date for the release branch to be cut ("release candidate date")
  • Make an announcement to the translators that they should ensure they have any pending translations saved in Transifex before the release candidate date
  • Make an announcement to the developers that all new strings should be committed before the release candidate date

On the release candidate date

  • Update the new relic gem if needed
bundle update newrelic_rpm
tx pull -a -f
# For some reason tx doesn't pull the en locale with -a
tx pull -l en -f
  • Convert the translations to a standard msgmerge format
bundle exec rake gettext:clean
bundle exec rake gettext:clean_alaveteli_pro
  • Check the translations for XSS insertion
  • Commit the translations (This is important! There's no revision history in Transifex!)
git add locale/
git commit -m 'Update translations'
bundle exec rake gettext:store_model_attributes
bundle exec rake gettext:find
  • Reupload the POT and PO files to Transifex from the current development branch
tx push -s -t --skip
tx push -s -t --skip -l en

NOTE: Transifex don't support en_RW, so you get what looks like an error when pushing the translations:

Pushing translations for resource alaveteli.apppot:
Pushing source file (locale/en/app.po)
Pushing 'aln' translations (file: locale/aln/app.po)
Pushing 'en_RW' translations (file: locale/en_RW/app.po)
Exception: Not Found
  • Re-pull from Transifex to remove the fuzzy strings from the local PO files
tx pull -a -f
tx pull -l en -f

  • Manually clean files not supported by Transifex (en_RW, en_UG)
msgattrib --no-fuzzy -o locale/LANG/app.po locale/LANG/app.po
  • Clean the pulled files and run the specs.
bundle exec rake gettext:clean
bundle exec rake gettext:clean_alaveteli_pro
bundle exec rspec

You may need to manually remove obsolete msgids.

find locale/* -name *.po | xargs -I % msgattrib --no-obsolete -o % %
bundle exec rake gettext:remove_fuzzy
bundle exec rake gettext:clean
bundle exec rake gettext:clean_alaveteli_pro

Assuming the specs pass, commit.

git add locale/
git commit -m 'Generate translations'
  • Run brakeman
# Make sure brakeman is up to date
gem update brakeman
# Generate a report
brakeman
open tmp/brakeman.html

# Compare new/fixed against last release
git checkout master
brakeman
git checkout develop
brakeman -o tmp/brakeman-compare.json --compare tmp/brakeman.json
open tmp/brakeman.json
  • Look for deprecation notices; remove code
  • Test/fix the release
    • Test the happy paths of new features
    • Check that bugfixes actually fix the bugs
  • Create the release branch from the develop branch - call it release/[release number]
git checkout -b release/[release number] develop
git push origin release/[release number]
  • Send a message to the dev group to let people know they can try the release branch
  • Make sure that all dependent themes (alavetelitheme, whatdotheyknow-theme) have develop branches that are compatible with the release branch
  • Send a message to the designers to review how design changes have integrated
  • Fix any issues reported by testers & designers

On the release date

  • Download and commit all the current translations to the current release branch
tx pull -a -f
# You may need to manually remove obsolete msgids
# https://gist.github.com/crowbot/2a2e576d791ceac5f24f564f1d32db89.
find locale/* -name *.po | xargs -I % msgattrib --no-obsolete -o % %
find locale_alaveteli_pro/* -name *.po | xargs -I % msgattrib --no-obsolete -o % %
bundle exec rake gettext:clean
bundle exec rake gettext:clean_alaveteli_pro
bundle exec rspec && git commit -m "Update translations" locale/
  • Check doc/CHANGES.md is up to date with any fixes made on the release branch.
  • Update the current version in doc/CHANGES.md
  • Update the ALAVETELI_VERSION constant in the release branch (config/initializers/alaveteli.rb).
  • Merge the release branch into master
git checkout master
git merge --no-ff release/[release number]
  • Tag that commit on the master branch with the release number
git tag -a [release number] -m "[release number]"
  • Push the release and the tag
git push origin master --tags
  • Merge the release back into the develop and wdtk branches
git checkout develop
git merge --no-ff master
git push origin develop

git checkout wdtk
git merge --no-ff develop
git push origin wdtk
  • Make sure that all dependent themes (alavetelitheme, whatdotheyknow-theme) have master branches that are compatible with the release branch
  • Tag all the dependent themes with a use-with-alaveteli-x.x.x tag
  • Send a message to the dev group with a link to the Changes file
  • Delete any topic branches that have been now merged to master (find candidates with git branch --merged master)
  • Add the release details to the GitHub releases page
  • Tweet and/or blog about the new release!
Clone this wiki locally