-
Notifications
You must be signed in to change notification settings - Fork 1.1k
ReleaseProcess
We are using the Cockpituous continuous delivery tools for Cockpit. Contact Stef or Martin for help if you need to use it or something broke with it.
We release every other Wednesday, at the end of each agile Sprint. Detailled release procedure:
-
Issues and PRs that are urgent for the next release should have a release-blocker label. Review the list, and ask team members if they still have anything for the current release.
-
Find out the previous release:
PREV=$(git describe --abbrev=0 --tags); echo $PREV
-
Look at the list of closed issues with the release-note label for likely inclusions into the release notes. Review the changes since the previous release with
git shortlog $PREV..
and pick out other noteworthy bits. Stick to new features and ignore changes to tests and bug fixes. Do the same for our other projects, in particular cockpit-podman and cockpit-machines. -
From that, draft a new release note blog post on the cockpit-project.org repo in a pull request (from your own forked repo). Describe user-visible changes from a user's (not developer's) point of view. Include screencasts, screenshots, and thank external contributors. Use the
main
branch in your repository, then you get an automatically rendered page once you enable GitHub pages for your cloned repo.Our web site repository has a generate-release-notes.rb script which automates this process. Use that script to create a first draft, and iterate on changing the original PRs (and re-generating the blog post) for as long as possible to keep them in sync.
As an example, look at the release notes of Cockpit 169 (with a video) which was done in PR #177, or Cockpit 171 (with external contributions) which was done in PR #185. Both PRs refer to the preview page.
Let some native English speaker review the blog post for correct spelling, grammar, and legibility. Usually Garrett and Allison. Ask them to start reviewing the headings first (as that blocks the next step), and the contents later.
Finally, remove the
release-note
label for the PRs which got included. -
If you have a GPG key, make sure it's added and verified in your GitHub profile so that the release actually appears as signed. If you don't have nor want one, ask someone else in the team to push the tag for you.
-
The headings of the release notes become the "release news" summary which appears on the GitHub release page and downstream package changelogs. They are taken from the signed release tag.
Create that tag with:
git tag -s $((${PREV%.*} + 1))
(or-a
if you don't have a GPG key). As the tag description, use the format as documented in cockpituous release:123 - Add this cool new feature - Support Python 3 - Fix wrong color on the bikeshed
Push it to cockpit's main:
git push origin $((PREV + 1))
(you might use a different origin name). -
This should trigger cockpituous release through the release workflow, which will call cockpituous' release-runner on cockpit's release script. You can watch the progress on Actions page.
Depending on how loaded the Fedora koji and COPR builders are, this can easily take an hour or two.
-
Repeat the tagging for the other projects which should be released.
-
Verify that the new version is:
- current and verified on the GitHub project release page
- built in COPR
- built on Dockerhub into a current cockit/ws container
- current on the cockpit documentation site.
- present on Fedora bodhi for testing and landing.
-
Add the bodhi URLs to the release announcement blog post and merge it.
-
Create a textual release announcement and send it to [email protected] and CC: [email protected] (requires mailing list membership). Also BCC: two Red Hat internal mailing lists (ask Martin or Stef about these).
Use the header, footer, and formatting like in the Cockpit 248 announcement.
-
Ask Martin to upload the new release to Debian. This step is not currently automated.
-
Ask Jelle to upload the new release to Arch Linux. This step is not currently automated.
-
Ask Martin or Garrett to announce the new release on Twitter
-
Test the packages on bodhi on your machine:
alias kojiget='koji download-build --arch=noarch --arch=x86_64' kojiget cockpit-172-1.fc28 rpm --freshen --verbose *.rpm
Make sure the update works, go through all the pages in Cockpit (make sure you disable your
~/.local/share/cockpit
for this!), and report back on bodhi with a +1. After getting enough karma (usually after a day or two), the package should automatically be pushed to stable.