-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
148 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,148 @@ | ||
# Release Process | ||
|
||
## Branches and Tags | ||
|
||
``` | ||
========================= main branch (edge channel) =======================> | ||
\ \ \ | ||
\___v0.7.0 tag \ \ | ||
\ \ v0.9.0 tag__\ | ||
\ v0.8.0 tag__\ \ | ||
v0.7.1 tag__\ \ v0.9 branch (beta channel) | ||
\___v0.7.2 tag \___v0.8.1 tag | ||
\ \ | ||
\ \ | ||
v0.7 branch v0.8 branch (stable channel) | ||
``` | ||
|
||
### `main` branch | ||
|
||
All new development occurs on the `main` branch. | ||
|
||
Bug fixes that affect a `vX.Y` branch are first made on `main`. This is to | ||
allow a fix some soak time on `main` before it is applied to one or more | ||
stabilization branches. | ||
|
||
Merging to `main` first also helps ensure that fixes applied to one release | ||
are present for future releases. (Sometimes the joy of landing a critical | ||
release blocker in a branch causes you to forget to propagate back to | ||
`main`!)" | ||
|
||
Once the bug fix lands on `main` it is cherry-picked into the `vX.Y` branch | ||
and potentially the `vX.Y-1` branch. The exception to this rule is when a bug | ||
fix for `vX.Y` doesn't apply to `main` or `vX.Y-1`. | ||
|
||
Immediately after a new stabilization branch is forged, the `Cargo.toml` minor | ||
version (_Y_) in the `main` branch is incremented by the release engineer. | ||
Incrementing the major version of the `main` branch is outside the scope of | ||
this document. | ||
|
||
### v*X.Y* stabilization branches | ||
|
||
These are stabilization branches for a given milestone. They are created off | ||
the `main` branch as late as possible prior to the milestone release. | ||
|
||
### v*X.Y.Z* release tag | ||
|
||
The release tags are created as desired by the owner of the given stabilization | ||
branch, and cause that _X.Y.Z_ release to be shipped to https://crates.io | ||
|
||
Immediately after a new v*X.Y.Z* branch tag has been created, the `Cargo.toml` | ||
patch version number (_Z_) of the stabilization branch is incremented by the | ||
release engineer. | ||
|
||
## Channels | ||
|
||
Channels are used by end-users (humans and bots) to consume the branches | ||
described in the previous section, so they may automatically update to the most | ||
recent version matching their desired stability. | ||
|
||
There are three release channels that map to branches as follows: | ||
|
||
- edge - tracks the `main` branch, least stable. | ||
- beta - tracks the largest (and latest) `vX.Y` stabilization branch, more stable. | ||
- stable - tracks the second largest `vX.Y` stabilization branch, most stable. | ||
|
||
## Steps to Create a Branch | ||
|
||
### Create the new branch | ||
|
||
1. Check out the latest commit on `main` branch: | ||
``` | ||
git fetch --all | ||
git checkout upstream/main | ||
``` | ||
1. Determine the new branch name. The name should be "v" + the first 2 version fields | ||
from Cargo.toml. For example, a Cargo.toml with version = "0.9.0" implies | ||
the next branch name is "v0.9". | ||
1. Create the new branch and push this branch to the `kug` repository: | ||
``` | ||
git checkout -b <branchname> | ||
git push -u origin <branchname> | ||
``` | ||
|
||
Alternatively use the Github UI. | ||
|
||
### Update `main` branch to the next release minor version | ||
|
||
1. After the new branch has been created and pushed, update the Cargo.toml files on **main** to the next semantic version (e.g. 0.9.0 -> 0.10.0) with: | ||
``` | ||
$ scripts/increment-cargo-version.sh minor | ||
``` | ||
1. Push all the changed Cargo.toml and Cargo.lock files to the `main` branch with something like: | ||
``` | ||
git co -b version_update | ||
git ls-files -m | xargs git add | ||
git commit -m 'Bump version to X.Y+1.0' | ||
git push -u origin version_update | ||
``` | ||
1. Confirm that your freshly cut release branch is shown as `BETA_CHANNEL` and the previous release branch as `STABLE_CHANNEL`: | ||
``` | ||
ci/channel-info.sh | ||
``` | ||
|
||
### Miscellaneous Clean up | ||
|
||
1. TODO: docs update | ||
|
||
## Steps to Create a Release | ||
|
||
### Create the Release Tag on GitHub | ||
|
||
1. Go to [GitHub Releases](https://github.com/kuglabs/kug/releases) for tagging a release. | ||
1. Click "Draft new release". The release tag must exactly match the `version` | ||
field in `/Cargo.toml` prefixed by `v`. | ||
1. If the Cargo.toml version field is **0.12.3**, then the release tag must be **v0.12.3** | ||
1. Make sure the Target Branch field matches the branch you want to make a release on. | ||
1. If you want to release v0.12.0, the target branch must be v0.12 | ||
1. Fill the release notes. | ||
1. If this is the first release on the branch (e.g. v0.13.**0**), paste in [this | ||
template](https://raw.githubusercontent.com/kuglabs/kug/main/.github/RELEASE_TEMPLATE.md). Engineering Lead can provide summary contents for release notes if needed. | ||
1. If this is a patch release, review all the commits since the previous release on this branch and add details as needed. | ||
1. Click "Save Draft", then confirm the release notes look good and the tag name and branch are correct. | ||
1. Ensure all desired commits (usually backports) are landed on the branch by now. | ||
1. Ensure the release is marked **"This is a pre-release"**. This flag will need to be removed manually after confirming the Linux binary artifacts appear at a later step. | ||
1. Go back into edit the release and click "Publish release" while being marked as a pre-release. | ||
1. Confirm there is new git tag with intended version number at the intended revision after running `git fetch` locally. | ||
|
||
### Update release branch with the next patch version | ||
|
||
[This action](https://github.com/kuglabs/kug/blob/main/.github/workflows/increment-cargo-version-on-release.yml) ensures that publishing a release will trigger the creation of a PR to update the Cargo.toml files on **release branch** to the next semantic version (e.g. 0.9.0 -> 0.9.1). Ensure that the created PR makes it through CI and gets submitted. | ||
|
||
### Prepare for the next release | ||
|
||
1. Go to [GitHub Releases](https://github.com/kuglabs/kug/releases) and create a new draft release for `X.Y.Z+1` with empty release notes. This allows people to incrementally add new release notes until it's time for the next release | ||
1. Also, point the branch field to the same branch and mark the release as **"This is a pre-release"**. | ||
1. Go to the [Github Milestones](https://github.com/kuglabs/kug/milestones). Create a new milestone for the `X.Y.Z+1`, move over | ||
unresolved issues still in the `X.Y.Z` milestone, then close the `X.Y.Z` milestone. | ||
|
||
### Verify release automation success | ||
|
||
Go to [Releases](https://github.com/kuglabs/kug/releases) and click on the latest release that you just published. | ||
Verify that all of the build artifacts are present, then uncheck **"This is a pre-release"** for the release. | ||
|
||
Build artifacts can take up to 60 minutes after creating the tag before appearing. To check for progress: | ||
|
||
- The Windows release artifacts are produced by GitHub Actions. Look for a job under the tag name of the release: https://github.com/kuglabs/kug/actions. | ||
- Linux and macOS release artifacts TODO: setup buildkite pipeline |