These steps provide a no-frills guide to performing an official release of Tekton Chains. To follow these steps you'll need a checkout of the chains repo, a terminal window and a text editor.
-
Setup a context to connect to the dogfooding cluster if you haven't already.
-
Install the rekor CLI if you haven't already.
-
cdto root of Chains git checkout. -
Install kustomize if you haven't already.
-
Select the commit you would like to build the release from (NOTE: the commit is full (40-digit) hash.)
- Select the most recent commit on the main branch if you are cutting a major or minor release i.e.
x.0.0or0.x.0 - Select the most recent commit on the
release-<version number>xbranch, e.g.release-v0.26.xif you are patching a release i.e.v0.26.2.
- Select the most recent commit on the main branch if you are cutting a major or minor release i.e.
-
Ensure the correct version of the release pipeline is installed on the cluster. To do that, the selected commit should be checked-out locally
kubectl --context dogfooding apply -f release/release-pipeline.yaml
-
Create a
release.envfile with environment variables for bash scripts in later steps, and source it:cat <<EOF > release.env TEKTON_VERSION= # Example: v0.26.2 TEKTON_RELEASE_GIT_SHA= # SHA of the release to be released, e.g. 5b082b1106753e093593d12152c82e1c4b0f37e5 TEKTON_OLD_VERSION= # Example: v0.26.1 TEKTON_PACKAGE=tektoncd/chains TEKTON_REPO_NAME=chains EOF . ./release.env
-
Confirm commit SHA matches what you want to release.
git show $TEKTON_RELEASE_GIT_SHA -
Create a workspace template file:
WORKSPACE_TEMPLATE=$(mktemp /tmp/workspace-template.XXXXXX.yaml) cat <<'EOF' > $WORKSPACE_TEMPLATE spec: accessModes: - ReadWriteOnce resources: requests: storage: 1Gi EOF
-
Execute the release pipeline (takes ~45 mins).
The minimum required tkn version is v0.30.0 or later
If you are back-porting include this flag:
--param=releaseAsLatest="false"tkn --context dogfooding pipeline start chains-release \ --filename=release/release-pipeline.yaml \ --param package=github.com/tektoncd/chains \ --param repoName="${TEKTON_REPO_NAME}" \ --param gitRevision="${TEKTON_RELEASE_GIT_SHA}" \ --param imageRegistry=ghcr.io \ --param imageRegistryPath=tektoncd/chains \ --param imageRegistryRegions="" \ --param imageRegistryUser=tekton-robot \ --param serviceAccountImagesPath=credentials \ --param versionTag="${TEKTON_VERSION}" \ --param releaseBucket=tekton-releases \ --param koExtraArgs="" \ --workspace name=release-secret,secret=oci-release-secret \ --workspace name=release-images-secret,secret=ghcr-creds \ --workspace name=workarea,volumeClaimTemplateFile="${WORKSPACE_TEMPLATE}" \ --tasks-timeout 2h \ --pipeline-timeout 3h
Accept the default values of the parameters (except for "releaseAsLatest" if backporting).
-
Watch logs of chains-release.
-
Once the pipeline is complete, check its results:
tkn --context dogfooding pr describe <pipeline-run-name> (...) 📝 Results NAME VALUE ∙ commit-sha 420adfcdf225326605f2b2c2264b42a2f7b86e4e ∙ release-file https://infra.tekton.dev/tekton-releases/chains/previous/v0.13.0/release.yaml ∙ release-file-no-tag https://infra.tekton.dev/tekton-releases/chains/previous/v0.13.0/release.notags.yaml (...)
The
commit-shashould match$TEKTON_RELEASE_GIT_SHA. The two URLs can be opened in the browser or viacurlto download the release manifests. -
The YAMLs are now released! Anyone installing Tekton Chains will get the new version. Time to create a new GitHub release announcement:
- Find the Rekor UUID for the release
RELEASE_FILE=https://infra.tekton.dev/tekton-releases/chains/previous/${TEKTON_VERSION}/release.yaml CONTROLLER_IMAGE_SHA=$(curl -L $RELEASE_FILE | egrep 'ghcr.io.*controller' | cut -d'@' -f2) REKOR_UUID=$(rekor-cli search --sha $CONTROLLER_IMAGE_SHA | grep -v Found | head -1) echo -e "CONTROLLER_IMAGE_SHA: ${CONTROLLER_IMAGE_SHA}\nREKOR_UUID: ${REKOR_UUID}"
-
Create a pod template file.
POD_TEMPLATE=$(mktemp /tmp/pod-template.XXXXXX.yaml) cat <<'EOF' > $POD_TEMPLATE securityContext: fsGroup: 65532 runAsUser: 65532 runAsNonRoot: true EOF
-
Execute the Draft Release Pipeline.
tkn pipeline start \ --workspace name=shared,volumeClaimTemplateFile="${WORKSPACE_TEMPLATE}" \ --workspace name=credentials,secret=oci-release-secret \ --pod-template "${POD_TEMPLATE}" \ -p package="${TEKTON_PACKAGE}" \ -p git-revision="$TEKTON_RELEASE_GIT_SHA" \ -p release-tag="${TEKTON_VERSION}" \ -p previous-release-tag="${TEKTON_OLD_VERSION}" \ -p repo-name="${TEKTON_REPO_NAME}" \ -p bucket="tekton-releases" \ -p rekor-uuid="$REKOR_UUID" \ release-draft-oci
-
Watch logs of resulting pipeline run on pipeline
release-draft -
On successful completion, a URL will be logged. Visit that URL and look through the release notes.
-
Manually add upgrade and deprecation notices based on the generated release notes
-
Double-check that the list of commits here matches your expectations for the release. You might need to remove incorrect commits or copy/paste commits from the release branch. Refer to previous releases to confirm the expected format.
-
Un-check the "This is a pre-release" checkbox since you're making a legit for-reals release!
-
Publish the GitHub release once all notes are correct and in order.
-
Create a branch for the release named
release-<version number>x, e.g.release-v0.26.xand push it to the repo https://github.com/tektoncd/chains. (This can be done on the Github UI.) Make sure to fetch the commit specified inTEKTON_RELEASE_GIT_SHAto create the released branch.Background: The reason why we need to create a branch for the release named
release-<version number>xis for future patch releases. Cherrypicked PRs for the patch release will be merged to this branch. For example, v0.26.0 has been already released, but later on we found that an important PR should have been included to that release. Therefore, we need to do a patch release i.e. v0.26.1 by cherrypicking this PR, which will trigger tekton-robot to create a new PR to merge the changes to the release-v0.26.x branch. -
Edit
releases.mdon themainbranch, add an entry for the release.- In case of a patch release, replace the latest release with the new one, including links to docs and examples. Append the new release to the list of patch releases as well.
- In case of a minor or major release, add a new entry for the release, including links to docs and example
- Check if any release is EOL, if so move it to the "End of Life Releases" section
-
Push & make PR for updated
releases.md -
Test release that you just made against your own cluster (note
--context my-dev-cluster):# Test latest kubectl --context my-dev-cluster apply --filename https://infra.tekton.dev/tekton-releases/chains/latest/release.yaml# Test backport kubectl --context my-dev-cluster apply --filename https://infra.tekton.dev/tekton-releases/chains/previous/$TEKTON_VERSION/release.yaml
-
Announce the release in Slack channels #general, #chains and #announcements.
Congratulations, you're done!
-
Configure
kubectlto connect to the dogfooding cluster:The dogfooding cluster is currently an OKE cluster in oracle cloud. we need the Oracle Cloud CLI client. Install oracle cloud cli (https://docs.oracle.com/en-us/iaas/Content/API/SDKDocs/cliinstall.htm)
oci ce cluster create-kubeconfig --cluster-id <CLUSTER-OCID> --file $HOME/.kube/config --region <CLUSTER-REGION> --token-version 2.0.0 --kube-endpoint PUBLIC_ENDPOINT
-
Give the context a short memorable name such as
dogfooding:kubectl config current-context
get the context name and replace with current_context_name
kubectl config rename-context <current_context_name> dogfooding
-
Important: Switch
kubectlback to your own cluster by default.kubectl config use-context my-dev-cluster
The easiest way to cherry-pick a commit into a release branch is to use the "cherrypicker" plugin (see https://prow.tekton.dev/plugins for documentation).
To use the plugin, comment "/cherry-pick " on the pull request containing the commits that need to be cherry-picked.
Make sure this command is on its own line, and use one comment per branch that you're cherry-picking onto.
Automation will create a pull request cherry-picking the commits into the named branch, e.g. release-v0.26.x.
The cherrypicker plugin isn't able to resolve merge conflicts. If there are merge conflicts, you'll have to manually cherry-pick following these steps:
- Fetch the branch you're backporting to and check it out:
git fetch upstream <branchname>
git checkout upstream/<branchname>- (Optional) Rename the local branch to make it easier to work with:
git switch -c <new-name-for-local-branch>-
Find the 40-character commit hash to cherry-pick. Note: automation creates a new commit when merging contributors' commits into main. You'll need to use the hash of the commit created by tekton-robot.
-
Cherry-pick the commit onto the branch:
git cherry-pick <commit-hash>- Resolve any merge conflicts.
- Finish the cherry-pick:
git add <changed-files>
git cherry-pick --continue- Push your changes to your fork and open a pull request against the upstream branch.