func/docs/RELEASING.md

2.9 KiB

Releasing

The project releases are primarily handled by the Knative hack infrastructure. When a new branch with a specific naming convention is pushed to GitHub, the Knative Prow system kicks into action, creating a new release. Unfortunately, this does not handle some niceties such as CHANGELOG.md updates. Follow this guide to create a new release, or push a patch for an existing release.

Prerequisites

You will need Node.js and NPM installed on your system to follow these steps. Managing the CHANGELOG.md and version.txt files is done with the npm package standard-version.

Creating a new release branch

Follow these steps to create a new release branch. Release branches use the release- prefix, and include the major and minor version numbers, for example, release-0.23.

Steps

When you are ready to create a new release, check out the repository's main branch, and perform the following steps.

  • Ensure you are on the most recent commit
git checkout main
git fetch
git reset --hard origin/main
  • Update CHANGELOG.md and version.txt. Running this will command will update both of these files, and commit the changes with a "release" commit. To see what will happen before actually doing it, use the --dry-run flag.
standard-version
  • Create the release branch and push it to GitHub
git push origin main:release-X.Y # X is the major version number, Y is the minor version number

At this point, prow will see the new branch and begin the release process. Once the release has been created in GitHub, update the release text to include the markdown from the CHANGELOG.txt changes.

Creating a patch release on an existing release branch

If a release branch already exists, but you need to release a new version with backported bug fixes, follow these steps.

Steps

When you are ready to create a patch release, check out the release branch to be updated, and perform the following steps.

  • Ensure you are on the latest commit from the release branch
git checkout release-X.Y # X=major version, Y=minor
git fetch
git reset --hard origin/release-X.Y
  • Backport the necessary changes/bug fixes onto this branch.
git cherry-pick [SHA]
  • Update CHANGELOG.md and version.txt on this branch. Running this will command will update both of these files, and commit the changes with a "release" commit. To see what will happen before actually doing it, use the --dry-run flag.
standard-version
  • Create the release branch and push it to GitHub
git push origin main:release-X.Y # X is the major version number, Y is the minor version number

At this point, prow will see the new branch and begin the release process. Once the release has been created in GitHub, update the release text to include the markdown from the CHANGELOG.txt changes.