Release process and checklist for hubble
.
These variables will be used in the commands throughout the README to allow copy-pasting.
Identify which commit will serve as the release point.
New major and minor version with .0
patch have to stem from the master
branch, while new patch releases have to stem from their respective minor
branches.
export RELEASE_HASH=<commit hash, i.e. 37c8023>
If releasing a new version 5.4.0 with the latest release being 5.3.8, for example, they will look as follows:
export MAJOR=5
export MINOR=4
export PATCH=0
export LAST_RELEASE=5.3.8
If a .0
patch version is being created, a new major.minor
branch has to be
made first. That branch will serve for tagging all releases, as well as
pointing to the latest patch release.
git switch -c v$MAJOR.$MINOR $RELEASE_HASH
NOTE: Do not directly commit to this branch. Follow the process and open a Pull Request from the prep branch.
This branch will be used to prepare all the necessary things to get ready for release.
git switch -c v$MAJOR.$MINOR.$PATCH-prep
Using https://github.com/cilium/release, prepare the release notes between the last minor version (latest patch) and current.
./release --repo cilium/hubble --base v$LAST_RELEASE --head v$MAJOR.$MINOR
**Bugfixes:**
* api: fix potential panic in endpoint's EqualsByID (#199, @Rolinh)
**Other Changes:**
* actions: Trigger on release branches (#233, @michi-covalent)
* Add changelog (#203, @glibsm)
* Adjust to moved PolicyMatchType location (#222, @tgraf)
* api: Small fixes to the protoc invocations in Makefile (#206, @gandro)
... etc ...
Modify CHANGELOG.md
with the generated release notes. Keep them handy, as
the same notes will be used in the github release.
$EDITOR CHANGELOG.md
...
git add CHANGELOG.md
git commit -s -m "Modify changelog for $MAJOR.$MINOR.$PATCH release"
Usually this only consists of dropping the -dev
suffix from the string.
Commit and push the changes to the prep branch
git add VERSION
git commit -s -m "Modify version to $MAJOR.$MINOR.$PATCH"
The pull request has to be v$MAJOR.$MINOR.$PATCH-prep -> v$MAJOR.$MINOR
Once the pull request is approved and merged, a tag can be created.
Identify the right commit and tag the release.
Example:
git tag -a v0.7.1 -m 'v0.7.1' <commit-sha>
Then push the tag.
Example:
git push origin v0.7.1
After branching out from the tree for release, the version need to be updated to reflect the next planned release, i.e.
VERSION="$MAJOR.<$MINOR+1>.0-dev"
Once the release PR has been merged, the changelog in the master branch needs to be updated as well. Make sure to copy the generated release notes to the changelog in the master.
Update the Releases section of the README.md
to point to the latest GitHub
release. This section lists all currently supported releases in a table. The
version in this table needs to be updated to match the new release.
When a tag is pushed, a Github Action job takes care of creating a new Github draft release, building artifacts and attaching them to the draft release.
The release notes need to be manually added before manually publishing the release.
After v$MAJOR.$MINOR.$PATCH
is released, the next commit should restore the
v$MAJOR.$MINOR
branch to the v$MAJOR.$MINOR.{$PATCH+1}-dev
to separate
unreleased hubble versions in a branch from releases.
Post a release announcement message in the Cilium Slack #hubble channel.
Example:
 Hubble CLI v0.8.2 is released 
Release notes and binaries: https://github.com/cilium/hubble/releases/tag/v0.8.2
Notable changes:
- Change 1
- Change 2
- ...
Hubble's installation instruction in the Cilium documentation uses the version specified in
stable.txt
in the master branch. There are a couple of things to consider when deciding
whether to update stable.txt
. Let's say stable.txt
is currently pointing to v0.6.1
:
- If this is a minor or patch release relative to the current stable version (i.e.
v0.7.0
orv0.6.2
), updatestable.txt
so that people start picking up the new features / bug fixes included in this release. - If this is a patch release of a previous version (e.g.
v0.5.2
), don't updatestable.txt
. - If this is a major release (e.g.
v1.0.0
), the installation instructions in older Cilium documentation versions need to be updated to point to a compatible version of Hubble. Then, ensure the version specified instable.txt
is compatible with the current stable Cilium version.
To update stable.txt
, do:
git switch -c update-stable-txt master
echo v$MAJOR.$MINOR.$PATCH > stable.txt
git add stable.txt
git commit -as -m "Point stable.txt to $MAJOR.$MINOR.$PATCH"
git push
and then open a pull request against the master branch.
The Homebrew formula for Hubble can be updated using the command:
brew bump-formula-pr --version=$MAJOR.$MINOR.$PATCH hubble
This will automatically create a PR against https://github.com/Homebrew/homebrew-core
bumping the version. This assumes a GitHub access token exported in
$HOMEBREW_GITHUB_API_TOKEN
, see brew bump-formula-pr --help
for details.