- Kubeflow Pipelines Release Process
Kubeflow Pipelines has weekly patch releases and monthly minor releases. Patch releases only contain bug fixes, while minor releases have new features additionally.
Releases are tagged with tags like X.Y.Z
, e.g. 1.0.2
. A special format like
1.0.0-rc.2
is a pre-release. It is the second release candidate before
releasing the final 1.0.0
.
A release branch has the name structure release-X.Y
where X.Y
stands for the
minor version. Releases like X.Y.Z
will all be released from the branch
release-X.Y
.
For example, 1.0.2
release should be on release-1.0
branch.
The following section targets contributors. No need to read further if you only want to use Kubeflow Pipelines.
After the release-X.Y
release branch is cut, pull requests (PRs) merged to
master will be only get released in the next minor release X.(Y+1).0
.
If you want your PR released earlier in a patch release X.Y.(Z+1)
:
- The PR must already get merged to master branch.
- The PR should be a bug fix.
- The PR should be cherry picked to corresponding release branch
release-X.Y
.
Choose one of the following options for cherry picking your PR to release branch.
Contributors should ask OWNERS who approved the PR to add a cherrypick-approved
label if they want the PR cherry picked to release branch.
Release manager will periodically or before release, search all merged PRs with
cherrypick-approved
and cherry pick them into current release branch.
- Find the commit you want to cherry pick on master as $COMMIT_SHA.
- Find the active release branch name $BRANCH, e.g. release-1.0
-
git checkout $BRANCH git checkout -b <cherry-pick-pr-branch-name> git cherry-pick $COMMIT_SHA
- Resolve merge conflicts if any
git push origin HEAD
- Create a PR and remember to update PR's destination branch to
release-$VERSION
- Ask the same OWNERS that would normally need to approve this PR
Kubeflow has a cherry pick helper script: https://github.com/kubeflow/kubeflow/blob/master/hack/cherry-picks.md
It automates the process using hub
CLI tool and bash, so it takes some one off efforts to set up for the first time.
After that, this is convenient to do a lot of cherry picks, because for each PR you'd only need to specify release branch and PR number.
Known caveats:
- It may produce PR title that is duplicative, you can edit the title after cherry picking.
The following sections target release managers. You don't need to read further if you only want to use or contribute to this repo.
- OS: Linux (MacOS not supported yet due to different behavior of sed)
- Permissions needed
- Can create a branch in github.com/kubeflow/pipelines.
- Can trigger cloudbuild jobs in ml-pipeline-test GCP project.
- Tools that should be in your
$PATH
- jq 1.6 https://stedolan.github.io/jq/download/
- yq https://github.com/mikefarah/yq/releases/tag/3.3.0
- jdk 8
- node 12
- bazel 0.24.0
- Preparations
- Clone github.com/kubeflow/pipelines repo into
$KFP_REPO
. cd $KFP_REPO
- Clone github.com/kubeflow/pipelines repo into
- Choose a good commit on master branch with commit hash as
$COMMIT_SHA
. - Choose the next release branch's
$MINOR_VERSION
in formatx.y
, e.g.1.0
,1.1
... - Make a release branch of format
release-$MINOR_VERSION
, e.g.release-1.0
,release-1.1
. Branch from the commit and push to kubeflow pipelines upstream repo.git checkout $COMMIT_SHA git checkout -b release-$MINOR_VERSION git push upstream HEAD
Do the following things before a release:
- Cherry pick all merged PRs with
cherrypick-approved
label:-
Search all merged PRs with
cherrypick-approved
label, but nocherrypicked
label using this link -
Use the git cherry-pick option to pick these PR commits into the release branch one by one in a batch and add
cherrypicked
label to these PRs.NOTE: if there are merge conflicts for a PR, ask the PR author or area OWNER to create a cherry pick PR by themselves following other two options.
-
git push upstream release-$VERSION
directly to the release branch.
-
- Verify cloudbuild and postsubmit tests are passing.
-
Choose the release's complete
$VERSION
following semantic versioning, e.g.1.0.0-rc.1
1.0.0-rc.2
1.0.0
1.0.1
1.1.0
- ...
-
Update all version refs in release branch by
./hack/release.sh $VERSION release-$MINOR_VERSION
It will prompt you whether to push it to release branch. Press
y
and hitEnter
.Note, the script will clone kubeflow/pipelines repo into a temporary location on your computer, make those changes and attempt to push to upstream, so that it won't interfere with your current git repo.
-
View related cloudbuild jobs' statuses by clicking the latest commit's status icon in the release branch. The page will look like https://github.com/kubeflow/pipelines/runs/775788343.
-
Wait and make sure the
build-each-commit
cloudbuild job that builds all images in gcr.io/ml-pipeline-test succeeded. If it fails, please click "View more details on Google Cloud Build" and then "Retry". -
Select the
release-on-tag
cloudbuild job that copies built images and artifacts to public image registry and gcs bucket. This job should have already failed because artifacts haven't been built. Now, please click "View more details on Google Cloud Build" and then "Retry", because after waiting for previous step, artifacts are now ready.TODO: we should have an automation KFP cluster, and the waiting and submiting
release-on-tag
cloudbuild task should happen automatically. -
Search "PyPI" in Google internal release doc for getting password of kubeflow-pipelines user.
-
Release
kfp-server-api
python packages to PyPI.git checkout $BRANCH git pull upstream cd backend/api/python_http_client rm -r dist python3 setup.py --quiet sdist python3 -m twine upload --username kubeflow-pipelines dist/*
-
Release
kfp
python packages to PyPI.pip3 install twine --user gsutil cp gs://ml-pipeline/release/$TAG_NAME/kfp.tar.gz kfp-$TAG_NAME.tar.gz python3 -m twine upload --username kubeflow-pipelines kfp-$TAG_NAME.tar.gz
!!! The file name must contain the version. See kubeflow#1292
-
Create a GitHub release using
$VERSION
git tag and titleVersion $VERSION
, fill in the description. Detailed steps:-
Typing in version tag field to search and select the "$VERSION" tag published in release instructions above. Its format is like
X.Y.Z
orX.Y.Z-rc.N
. -
Use this template for public releases and replace the
$TAG_NAME
with real values.To deploy Kubeflow Pipelines in an existing cluster, follow the instruction in [here](https://www.kubeflow.org/docs/pipelines/standalone-deployment-gcp/) or via UI [here](https://console.cloud.google.com/ai-platform/pipelines) Install python SDK (python 3.5 above) by running: ``` python3 -m pip install kfp kfp-server-api --upgrade ``` See the [Change Log](https://github.com/kubeflow/pipelines/blob/$TAG_NAME/CHANGELOG.md)
Use this template for prereleases (release candidates) and PLEASE CHECK the This is a prerelease checkbox in the GitHub release UI.
To deploy Kubeflow Pipelines in an existing cluster, follow the instruction in [here](https://www.kubeflow.org/docs/pipelines/standalone-deployment-gcp/). Install python SDK (python 3.5 above) by running: ``` python3 -m pip install kfp kfp-server-api --pre --upgrade ``` See the [Change Log](https://github.com/kubeflow/pipelines/blob/$TAG_NAME/CHANGELOG.md)
-
Update master branch to the same version.
export TAG_NAME=<TAG_NAME> git checkout master git pull git checkout -b <your-branch-name> # This avoids line break at end of line. echo -n $TAG_NAME > VERSION # This takes a while. ./hack/release-imp.sh git checkout $TAG_NAME -- CHANGELOG.md git add -A git commit -m "chore(release): bump version to $TAG_NAME on master branch"
-
If current release is not a prerelease, create a PR to update version in kubeflow documentation website: https://github.com/kubeflow/website/blob/master/layouts/shortcodes/pipelines/latest-version.html
Note, there MUST NOT be a line ending in the file. Editing on GitHub always add a line ending for you so you cannot create a PR on GitHub UI. Instead, you can checkout the repo locally and
echo -n 1.0.0 > layouts/shortcodes/pipelines/latest-version.html
and create a PR to update the version, e.g. kubeflow/website#1942.
The script ./hack/release-imp.sh
does the following:
- Generate
./CHANGELOG.md
using commit history. - Regenerate open api specs based on proto files.
- Regenerate
kfp-server-api
python package. - Update all version refs in this repo to
./VERSION
by calling each of the./**/hack/release.sh
scripts. The individual scripts are responsible for updating version refs to their own folder.
The script ./hack/release.sh
is a wrapper on top of ./hack/release-imp.sh
, it
- Clones github.com/kubeflow/pipelines repo to a temporary path.
- Checkout
release-$MINOR
branch. - Runs
./hack/release-imp.sh
. - Runs git commit and tag.
- After confirming with user input, pushes to upstream branch.