Project

General

Profile

Release Checklist » History » Version 14

Ward Vandewege, 06/05/2021 12:06 PM

1 1 Peter Amstutz
h1. Release Checklist
2
3
Pre-process:
4
5
# Create an issue for the release.
6
# Add each of the following steps (starting at step 1) as tasks with the step number in the subject
7
# Assign each task
8
# The current task goes into the "In Progress" column
9
# When the current task is finished, move it to resolved, and move the next task into "In Progress"
10
# Notify the assignee of the next task that it is ready to begin
11
12 3 Peter Amstutz
|_.Step|_.Who|_.What|
13
|0|engineering|Write lots of great code, build new features|
14
|0|engineering|Go through https://dev.arvados.org/projects/arvados/wiki/Manual_testing_plan|
15 8 Peter Amstutz
|1|engineering|Prepare release branch ready for release candidate.  Update @provision.sh@ for upcoming version.|
16 3 Peter Amstutz
|2|engineering|Review release branch, make sure all commits that need to be in the release are in the release, make sure that dependencies of Python and Ruby packages have upper version pins (to ensure that 3rd party dependencies updated post-stable-release don't break our code)|
17 4 Peter Amstutz
|3|product mgr|Create a redmine release for the next patch release beyond this one so that future bugfixes can be assigned to it, if there's a chance that such a release will be made.|
18 3 Peter Amstutz
|4|engineering|Record git commits that will be used to build the release following the instructions at https://dev.arvados.org/projects/ops/wiki/Arvados_Release_lifecycle#Cut-off-commits-Choosing-a-Version|
19
|5|release eng|Build release candidate packages|
20
|6|product mgr|Send out draft release notes|
21
|7|everyone|Review release notes|
22 7 Peter Amstutz
|8|ops|Test installer formula / provision scripts with RC packages - [[Installer development process]]|
23 6 Peter Amstutz
|9|ops|Deploy RC packages to playground ^1^|
24 10 Peter Amstutz
|10|bfx|Run "bam-to-vcf pipeline":https://dev.arvados.org/issues/17049#note-7 on playground ^1^|
25 6 Peter Amstutz
|11|ops|Deploy RC packages to su92l ^1^|
26
|12|everyone|Test playground/su92l ^1^|
27
|13|product mgr|Sign off on last built RC as the release|
28
|14|release eng|Push packages to stable repos (https://dev.arvados.org/projects/ops/wiki/Promoting_Packages_to_Stable)|
29
|15|release eng|Publish arvados/jobs docker image, Python packages and Ruby gems|
30
|16|release eng|Publish formula / installer for the release|
31
|17|release eng|Publish arvados/arvbox-demo docker image with https://ci.arvados.org/view/Release%20Pipeline/job/build-and-release-arvbox-image/|
32 11 Ward Vandewege
|18|release eng|Tag the commits in each repo used to build the release in git. Please create an annotated tag, with this message: "Release X.Y.Z, release notes at https://arvados.org/release-notes/X.Y.Z/". That will make https://github.com/arvados/arvados/releases look really good.|
33 14 Ward Vandewege
|19|release eng|(major releases only, unless there is a change worthy in the point release) Update the "Upgrading Arvados and Release notes" doc page with the title and date of the release
34 13 Peter Amstutz
|19|release eng|Ensure new release is published on https://doc.arvados.org ; ensure that release notes & any other materials are pointing to correct version of the docs.|
35 12 Peter Amstutz
|20|product mgr|Add release notes to https://arvados.org/release-notes/X.Y.Z.html and Update release list at https://arvados.org|
36
|21|product mgr|Send release notes to arvados and arvados-dev mailing list, tweet from the Arvados account about the new release, announce on gitter, notify customers, etc|
37
|22|release eng|Duplicate the jenkins configuration for tests to versioned names so that future point releases remain testable after master moves on|
38 1 Peter Amstutz
39
^1^ If issues are discovered in these steps, get a fix developed, reviewed and merged, and then update the ops ticket from step 3 with the relevant new git commit(s), notify ops, and resume the checklist from step 4.