-
Notifications
You must be signed in to change notification settings - Fork 716
Release Process
The Release Team is currently responsible for the long-term maintenance of our primary chart repositories (such as rancher/charts
and rancher/system charts
).
-
(Existing charts only)
: Chart owners are responsible for the overall maintenance and PR reviews associated with the charts they own.- This includes PRs updating an existing chart and bringing it into the rancher/charts repository if they have a separate upstream repository.
-
(New charts only)
: Chart owners are responsible for new charts that must be added to the rancher/charts repository and any upstream repository associated with the chart.- A review from a member of the Rancher Charts Team is required for the first version of a new chart only to ensure it complies with all the requirements (eg., the CRD template is correct, required annotations were added, images are mirrored, etc...).
- The Release Team sets up new
dev-v2.x
andrelease-v2.x
branches when a new Rancherminor
version update is introduced and forward-port all charts. - The Release Team is responsible for verifying if charts in previous release lines have been forward-ported before a chart release and forward-porting any charts that may need to be added.
-
Except for release PRs,
no PRs should be made to a release branch
(e.g.,release-v2.x
). All work should be made to an existing dev branch (e.g.,dev-v2.x
) or a new staging branch in the Rancher organization made for independent work, such as in emergency or out-of-band releases (e.g.,dev-v2.7-oob-longhorn
,dev-v2.7.1
, etc.). -
(OOB only)
Any team requesting an OOB release for their chart is responsible for creating a GitHub issue stating the chart name, version, and Rancher release line they want to release and assigning it to the Release team. Once the chart has been released, the Release engineer who completed the OOB release is responsible for notifying the requester team of its completion and requesting that the issue be closed.
Starting on 17/May/2024
there is a new asset lifecycle in place.
We will keep only the relevant assets in the corresponding branch.
This means a cycle of always 3 active branches, with each branch always holding up to 2 previous versions before it.
In a nutshell:
- release-v2.7 hold chart versions for Rancher: (2.5; 2.6; 2.7)
- release-v2.8 hold chart versions for Rancher: (2.6; 2.7; 2.8)
- release-v2.9 hold chart versions for Rancher: (2.7; 2.8; 2.9)
flowchart LR;
subgraph BigBox[Assets Lifecycle]
direction LR
subgraph A[release-v2.7]
direction LR
A1[10.1.2] --- A2[100.0.0+up0.0.0] --- A3[102.0.0+up0.0.0]
end
subgraph B[release-v2.8]
direction LR
B1[100.0.0+up0.0.0] --- B2[102.0.0+up0.0.0] --- B3[103.0.0+up0.0.0]
end
subgraph C[release-v2.9]
direction LR
C1[102.0.0+up0.0.0] --- C2[103.0.0+up0.0.0] --- C3[104.0.0+up0.0.0]
end
A2 -.-> B1
A3 -.-> B2
B2 -.-> C1
B3 -.-> C2
end
Only for branch lines >= 2.9
(i.e., release-v2.9
; release-v2.10
; etc...)
-
Pre-requisites:
ecm-distro-tools
- Configure ecm-distro-tools release binary on your path
- Configure the
Charts options
on the~/.ecm-distro-tools/config.json
accordingly to your dev environment:
Charts
Workspace: /<path_to_your_cloned_charts_repository>/charts
ChartsRepoURL: https://github.com/rancher/charts
ChartsForkURL: <your_forked_repo_for_charts_URL>
BranchLines: [2.10 2.9 2.8]
-
Pre-requisites:
charts repository
- The chart(s) (is/are) already merged on the corresponding
dev-v2.*
branch - You have cloned the git repository of the
charts repository
locally, which is up-to-date with the remote changes.- i.e., `git fetch; git checkout <some_dev_branch>; git pull <some_dev_branch>;
- Name the remotes in your local git repo to something like:
- The chart(s) (is/are) already merged on the corresponding
release-work/charts » git remote -v
nicholasSUSE https://github.com/nicholasSUSE/charts (fetch)
nicholasSUSE https://github.com/nicholasSUSE/charts (push)
upstream https://github.com/rancher/charts (fetch)
upstream https://github.com/rancher/charts (push)
- Fetch && Checkout the target
release-v2.X
branch. - Create a new branch from it, usually using a standard like: (e.g.,
1st-batch-release-2.X.Y
,oob-release-monitoring,
fp-from-dev-2X-release-2X
). - Get the list of available charts for releasing:
release list charts 2.X
- Update the local branch (The auto-completion will help a lot):
release update charts 2.9 <chart_name> <version>
- Repeat this step until updating all charts to be released
- Create the Pull Request:
release push charts 2.9 --debug
- Use the debug to inspect what you will push.
- After the command execution, it will give you the Pull Request URL if successful.
- Edit the Pull Request:
- The Pull Request was created with a good template; refine the title with versions and place the Release Team as a reviewer; some examples:
- Final validations:
- Wait for all GitHub Actions jobs to complete.
- At your local repository, execute: #Release validation and validation scripts section
- Ask for a review. The reviewer must only approve after all jobs are complete.
- After having one approval,
-
ONLY AFTER ALL PREVIOUS JOBS ARE COMPLETE
: If you proceed and a job fails later, you will have pushed a faulty image to the Prime registry! -
add the
regsync-ready
label to the Pull Request. - The regsync GitHub action will start to sync the images to the Prime registry.
-
- Wait for all GitHub Actions jobs to be completed again.
- You should see an extra commit after the jobs finish that was automatically created from the Generate-Regsync-Config workflow build job.
-
Merge!
This will release the charts. - Wait for the git mirror to synchronize and propagate the changes. (more info at section: X)
- Notify the company of any relevant QA tests.
- Forward-port any charts, if needed, to newer branch lines. see: #Forward-porting charts
- Update Confluence Table.
- Only for the latest active release branch
- Wait for the completion of git-pages workflow
- If it fails, there is a warning automation. (troubleshoot info on the notes for the step below)
- Only for Rancher Minor Version Updates (i.e,. rancher v2.
X
to a new rancher v2.X+1
)- If you created a new branch line and it is the first time you have released it. (e.g.,
release-v2.11
for release cycle2.11.0
) - Update the feature charts https://github.com/rancher/charts/settings/pages to the new release branch. This is where the icons rancher/rancher are loaded from and the main
index.yaml
feed is loaded for helm CLI like helm repo add rancher-chartscharts.rancher.io
.- It shouldn't affect the rancher-tagged releases, as those are pinned to specific release branches.
- If you created a new branch line and it is the first time you have released it. (e.g.,
Troubleshoot: Once you modify to switch the branch from the prior release branch (i.e., release-v2.6) to the new release branch (i.e., release-v2.7), you may need to file an empty commit PR like https://github.com/rancher/charts/pull/2220 to have Github Pages pick it up and deploy the latest
index.yaml
. Upon making these changes, ensure the current index matches the contents of charts.rancher.io/index.yaml in the release-v2.7 branch.
Only for branch lines < 2.9
(i.e., release-v2.8
; release-v2.7
; release-v2.6
; etc...)
The steps below work under the assumption your rancher/charts fork is:
- clean
- up to date
- the remote for rancher/charts is named upstream
(For releases in 2.8) Make sure that the generated-changes folder for the charts from dev-v2.7 is copied correctly to dev-v2.8 since Mapps has copied it from release-v2.7 and there might be some changes in dev-v2.7 which are yet to be released and are required in dev-v2.8 as well.
- Open a PR on GitHub from dev-v2.x to its respective release-v2.x branch and set the title to [release-v2.x] Charts release for Rancher vX.X.X (Where vX.X.X corresponds to the Rancher version being released)
- Get sign-off from QA and Manager to proceed with the release validation
- Post a comment in the PR with the release validation checklist
- Run validation scripts and fill up the checklist (see Validation Scripts section below for instructions)
- Request a review from a rancher/charts committer (anyone who can review)
- The reviewer must approve only after all checks have been done and verified. This is because, once approval is given on the PR, the regsync Github Action will start the syncing of images to the Prime registry. Link
- After the GitHub Action is completed and the CI check is green, anyone who has permission to merge can merge the PR.
- Notify your manager and QA in the rancher release coordination channel (or any relevant channel) that the charts have been released for QA to start their post-charts release Apps & Marketplace validation
- Empty the release.yaml in the release-* branch and do the sync up.
- Complete post-release cleanup and sync (see section below for post-release cleanup steps)
- Forward-port any charts that need to be forward-ported to newer version lines (see the section below for chart forward-porting steps)
- Change the branch references in rancher/rancher from dev to release like this PR https://github.com/rancher/rancher/pull/42952
- Update the latest versions into the table and also any new net charts and their latest versions in the Matrix table like in the Apps & Marketplace section of Rancher Manager v2.7.6
- Update dates of the Mapps responsible tasks in the release Checklist page of confluence like v2.7.7 Release Coordination Master Page Only for Minor Versions:
- Update the feature charts https://github.com/rancher/charts/settings/pages to the new release branch. This is where the icons rancher/rancher are loaded from and the main index.yaml feed is loaded for helm CLI like helm repo add rancher-charts charts.rancher.io. It shouldn't affect the actual rancher-tagged releases as those are pinned to specific release branches.
Note: Once you modify to switch the branch from the prior release branch (i.e. release-v2.6) to the new release branch (i.e. release-v2.7), you may need to file an empty commit PR like https://github.com/rancher/charts/pull/2220 to have Github Pages pick it up and deploy the latest index. yaml. On making these changes, ensure the contents of charts.rancher.io/index.yaml matches the current index.yaml in the release-v2.7 branch.
- Create a branch off the release-v2.x branch from your forked repository
- Cherry-pick the commits from the dev-v2.x branch associated with the chart(s) that need to be released (this should include changes made to the packages, charts, and assets directories)
- We need to push our branch in the forked repository to rancher/charts the repository. This is required since we need to create a PR from a branch belonging to rancher/charts for the regsync Github Action to run.
- Get sign-off from QA and Manager to proceed with the release validation
- Add the release validation checklist to the PR description
- Run validation scripts and fill up the checklist (see Validation Scripts section below for instructions)
- Request a review from a rancher/charts committer (anyone who is able to review)
- The reviewer must approve only after all checks have been done and verified. This is because once approval is given on the PR, the regsync Github Action will start the syncing of images to the Prime registry. Link
- After the GitHub Action is completed and the CI check is green, the PR can be merged by anyone who has permission to merge.
- Repeat steps 1 through 10 until all batches have been merged.
- Notify your manager and QA in the rancher release coordination the charts have been released in order for QA to start their post charts release Apps & Marketplace validation
- Empty the release.yaml in the release-* branch and do the sync up.
- Complete post-release cleanup and sync (see section below for post-release cleanup steps)
- Forward-port any charts that need to be forward-ported to newer version lines (see section below for chart forward-porting steps)
- Change the branch references in rancher/rancher from dev to release like this PR https://github.com/rancher/rancher/pull/42952
- Update latest versions into the table and also any new net charts and their latest versions in the Matrix table like in Apps & Marketplace section of Rancher Manager v2.7.6
- Update dates of the Mapps responsible tasks in the release Checklist page of confluence like v2.7.7 Release Coordination Master Page
- Only for Minor Versions: Update the feature charts https://github.com/rancher/charts/settings/pages to the new release branch. This is where the icons rancher/rancher are loaded from and the main index.yaml feed is loaded for helm CLI like helm repo add rancher-charts charts.rancher.io. It shouldn't affect the actual rancher-tagged releases as those are pinned to specific release branches.
Note: Once you modify to switch the branch from the prior release branch (i.e. release-v2.6) to the new release branch (i.e. release-v2.7), you may need to file an empty commit PR like https://github.com/rancher/charts/pull/2220 to have Github Pages pick it up and deploy the latest index. yaml. On making these changes, ensure the contents of charts.rancher.io/index.yaml matches the current index.yaml in the release-v2.7 branch.
- (For releases in 2.8) Make sure that the generated-changes folder for the charts from dev-v2.7 is copied correctly to dev-v2.8 since Mapps has copied it from release-v2.7 and there might some changes in dev-v2.7 which are yet to be released and are required in dev-v2.8 as well.
- Make sure to get sign off from the feature chart team QA or owner before starting the release.
- Create a branch off the release-v2.x branch from your forked repository
- Cherry pick the commits from the dev-v2.x branch associated with the chart(s) that need to be released OOB (this should include changes made to the packages, charts, and assets directories)
- We need to push our branch in the forked repository directly to the rancher/charts repository and then create a Pull Request from the pushed branch to the production branch. This is required since we need to create a PR from a branch belonging to rancher/charts for the regsync Github Action to run.
- Make sure your upstream points to rancher/charts and then execute this command git push --set-upstream upstream oob-july . Here oob-july is the branch your created in step 1.
- Open a PR on GitHub to the release-v2.x branch and set the title to[release-v2.x] OOB Charts release for and add the issue(s) associated with the OOB release to the description of the PR.
- Wait for the CI checks to pass and give the thumb's up to the bot's validation comment.
- Run validation scripts and fill up the checklist (see section below for release validation steps)
- Request a review from a rancher/charts committer (anyone who is able to review).
- After approving the PR, add the "regsync-ready"label to it. This will trigger the prime registry image sync action. Link
- After the GitHub Action is completed and the CI check is green, the PR can be merged by anyone who has permission to merge.
- Notify the authors of the issues associated with the OOB release that the chart(s) have been released and request for them to close the issue
- After the PR is approved and merged, do the sync-up.
- Complete post release clean-up and sync-up (see section below: clean-up and sync-up branches post chart release)
- Forward-port any charts that need to be forward-ported to newer version lines (see section below for chart forward-porting steps) If the versioning scheme changes, i.e from 2.x.x to 102.x.x, do not forget to notify the respective teams
- Update release confluence page.
- Checkout the corresponding dev branch in your fork.
- Remove the charts released from the release.yaml
- Merge the upstream release-v2.x branch onto the dev-v2.x branch to bring the merge commit from the release and any other commits back into dev and sync up the branches (the CI validation will fail for new PRs made to dev if this step is not done)
- If any of the released charts are not in the dev branch: Run make validate to regenerate release.yaml. The validation is expected to fail and generate a new release.yaml if there are any new charts in dev-v2.x; commit the changes made to release.yaml and the next make validate run should pass. If it fails before a new release.yaml is generated, it is likely that something went wrong during the merge of release into dev.
- Open the PR with the changes to the upstream dev-v* branch
- After getting the approvals, merge it without the squash option.
-
Important: Do not
Squash and Commit
- Do:
Create a merge commit
- is the only way to create the merge commit, so that the release-v* branch is in sync with its respective dev-v* branch. You will enable under your GH Repo settings the option: Allow merge commits Execute the merge and disable again the option.
-
Important: Do not
Any charts released in an older version line need to be forward-ported to newer version lines. E.g a chart released in 2.5 needs to be forward-ported to 2.6 and 2.7, and a chart released in 2.6 needs to be forward-ported to 2.7 and so on.
- Checkout the dev-v2.x branch where x corresponds to the branch where you want to forward-port a chart into.
- Run the following command: make forward-port CHART=rancher-chart VERSION=100.0.0+up1.2.3 BRANCH=dev-v2.x-1 UPSTREAM=upstream
- Commit the output of the command with a comment "make forward-port "
- Repeat for all charts that need to be forward-ported including CRD charts as these are done separately
- Open a pull request to the corresponding dev-v2.x branch with the forward port commits and ask for a review.
- Once the pull request is approved, merge it.
Validation scripts are located in the rancher/charts repository in scripts/release-validation here https://github.com/rancher/charts/tree/dev-v2.7/scripts/release-validation
Currently they need to be ran inside the rancher-validation directory for them to work properly, and it is best to direct the output of the scripts to a file for review (except the diff-with-released script since it creates a directory for you)
- Run make unzip to regenerate the charts/ from scratch, then git diff to check differences between assets/ and charts/ yields NO differences or innocuous differences (addresses Checkpoint 1 in the pr-template-checklist, and it is best done first as the repository should be in a clean state)
- Run the last-released script (./last-released.sh > last-released.log) to address item in the Checkpoint 0 of the pr-template-checklist.
- Run the validate-annotations (./validate-annotations.sh > validate-annotations.log) and validate-index (./validate-index.sh > validate-index.log) to address Checkpoint 2 of the pr-template-checklist
Repository: https://github.com/rancher/system-charts/
Releasing system charts is simpler that other repositories, because it does not use rancher/charts-build-scripts to build, maintain, and release charts (although it follows the same dev-v2.x and release-v2.x branch strategy as other Rancher repositories).
- Open a PR on GitHub from dev-v2.x to its respective release-v2.x branch and set the title to [release-v2.x] System Charts release for Rancher vX.X.X (where vX.X.X corresponds to the Rancher version being released)
- Validate the following:
- New images are mirrored
- New chart versions are exactly one version up over the previous version and none of the versions that has already been released were modified
- The questions.yaml in the charts to be released have rancher_min_version and rancher_max_version set correctly.
Note: Generally we release one new chart version or each minor version line of the chart for each Rancher version line and hide the previous version so that only one chart is available per Rancher version. All charts should have a rancher_min_version and rancher_max_version set, except for the latest version in a version line (i.e. If you have a chart with versions 0.1.0 0.1.1, 0.2.0, and 0.2.1 only versions 0.1.1 and 0.2.1 should not have a rancher_max_version set). Examples:
- questions.yaml of latest monitoring chart: https://github.com/rancher/system-charts/blob/dev-v2.7/charts/rancher-monitoring/v0.3.2/questions.yml
- questions.yaml of monitoring chart previous to latest: https://github.com/rancher/system-charts/blob/dev-v2.7/charts/rancher-monitoring/v0.3.1/questions.yml
- Get sign off from QA to proceed with the release
- Merge PR (this step releases the charts)