Skip to content

Latest commit

 

History

History
 
 

release

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 

Creating a new release of google-cloud-cpp

Unless there are no changes, we create releases for google-cloud-cpp at the beginning of each month, usually on the first business day. We also create releases if there is a major announcement or change to the status of one of the libraries (like reaching the "Alpha" or "Beta" milestone).

The intended audience of this document are developers in the google-cloud-cpp project that need to create a new release. We expect the reader to be familiar the project itself, git, GitHub, and semantic versioning.

0. Verify most recent googleapis SHA adheres to policy

In order to ensure that our released version includes a SHA of the service proto definitions that is both current and stable (googleapis-sha-update-policy), aim for a commit SHA from 5-7 days ago (TODO(#13062): automate this update process).

1. Preparing for a release

To create a new release you need to perform some maintenance tasks, these are enumerated below.

a. Verify CI passing

Before beginning the release process, verify all CI builds are passing on the main branch. This is displayed in the GitHub page for the project.

b. Create a PR to prepare the pre-release

Update the root CMakeLists.txt

Set the pre-release version (PROJECT_VERSION_PRE_RELEASE) to the empty string.

set(PROJECT_VERSION_PRE_RELEASE "")

Update the version info

Run any CMake-based build to update google/cloud/internal/version_info.h and MODULE.bazel. If you do not feel like waiting for a build, make the corresponding changes in these files manually.

Update CHANGELOG.md

To update the CHANGELOG.md file, first change the "TBD" placeholder in the latest release header to the current YYYY-MM.

Then run the script

git fetch upstream
release/changes.sh

to output a summary of the potentially interesting changes since the previous release. Paste that output below the release header updated above, and manually tweak as needed.

NOTE: If you can, add the script output into the PR description so that reviewers know what you removed. Or, better yet, leave the description alone, and use the script output verbatim in the PR (except, perhaps, for obvious duplications), and then let the normal review/edit/push cycle deal with any cleanups.

  • A change in an existing library warrants its own library section.
  • Library sections should be listed in alphabetical order (Update sections in release/changes.sh).
  • Do not list changes for libraries under development.
  • Do not list changes for internal components.
  • A change that affects all libraries should only be documented in the Common Libraries section.

Run checkers

ci/cloudbuild/build.sh -t checkers-pr

Send a PR with all these changes

git add .
git checkout -b release-changelog
git commit -am "docs(release): update changelog for the $(date +%Y-%m) release"
git push

2. Bump the version number in main

Working in your fork of google-cloud-cpp: bump the version numbers to the next version, i.e., one version past the release you just did above. Then send the PR for review against main. You need to:

a. Make the following changes

  • In the top-level CMakeLists.txt file:
    • a. Increment the version number in the project() function.
    • b. Set the pre-release version (PROJECT_VERSION_PRE_RELEASE) to "rc".
  • In the CHANGELOG.md file:
    • Add a "vX.Y.Z - TBD" header, corresponding to the new version number.

b. Run the following script

  • Update the ABI baseline to include the new version numbers in the inline namespace by running ci/cloudbuild/build.sh -t check-api-pr. This will leave the updated ABI files in ci/abi-dumps, and also update the google/cloud/internal/version_info.h and MODULE.bazel files.

This will step will take a while. You can leave this and move onto step 3.

c. Send the PR for review

NOTE: Do NOT send this PR for review before the release is created in step 3.

git add .
git checkout -b bump-rc
git commit -am "chore: version bump to $(sed -n 's/.* VERSION //p' CMakeLists.txt)-rc"
git push

NOTE: The Renovate bot will automatically update the Bazel deps in the quickstart WORKSPACE.bazel files after it sees the new release published. Watch for this PR to come through, kick off the builds, approve, and merge it.

3. Creating the release

NOTE: Do NOT create the release branch before the PR created in step 1 is merged.

We want to create the release from a stable point in the default branch (main), and we want this point to include the updated release notes. There may be exceptions to this guideline, you are encouraged to use your own judgment.

a. Run the release script

We next need to create the release tag, the release branch, and create the release in the GitHub UI. We use a script (release/release.sh) to automate said steps.

No PR is needed for this step.

First run the following command -- which will NOT make any changes to the repo -- and verify that the output and version numbers look correct.

release/release.sh googleapis/google-cloud-cpp

If the output from the previous command looks OK, rerun the command with the -f flag, which will make the changes and push them to the remote repo.

release/release.sh -f googleapis/google-cloud-cpp

NOTE: This script can be run from any directory. It operates only on the specified repo.

b. Publish the release

Review the new release in the GitHub web UI (the link to the pre-release will be output from the release.sh script that was run in the previous step). If everything looks OK:

  1. Uncheck the pre-release checkbox.
  2. Check the latest release checkbox.
  3. Click the update release button.

4. Check the published reference docs

The publish-docs-release build should start automatically when you create the release branch. This build will upload the docs for the new release to the following URLs:

It can take up to a day after the build finishes for the new docs to show up at the above URL. You can watch the status of the build at https://console.cloud.google.com/cloud-build/builds;region=us-east1?project=cloud-cpp-testing-resources&query=tags%3D%22publish-docs%22

5. Review the protections for the v[0-9].* branches

We use the GitHub Branch Settings to protect the release branches against accidental mistakes. From time to time changes in the release branch naming conventions may require you to change these settings. Please note that we use more strict settings for release branches than for main, in particular:

  • We require at least one review, but stale reviews are dismissed.

  • The Require status checks to pass before merging option is set. This prevents merges into the release branches that break the build.

    • The Require branches to be up to date before merging sub-option is set. This prevents two merges that do not conflict, but nevertheless break if both are pushed, to actually merge.
    • At a minimum the cla/google, asan-pr, and clang-tidy-pr checks should be marked as "required". You may consider adding additional builds if it would prevent embarrassing failures, but consider the tradeoff of merges blocked by flaky builds.
  • The Include administrators checkbox is turned on, we want to stop ourselves from making mistakes.

  • Turn on the Restrict who can push to matching branches. Only Google team members should be pushing to release branches.

6. Push the release to Microsoft vcpkg

PR#32391 is probably a good example of the changes you will need to make.

a. Get to your clone of vckpkg

Clone the fork

git clone git@github.com:<username>/vcpkg.git

Sync the master branch in your fork to the upstream version

cd vcpkg
git pull upstream master

b. Make a PR for the version update

Save the version as an environment variable

VERSION=... # e.g. v2.13.0

Create a feature branch.

git checkout -b google-cloud-cpp-update-to-${VERSION}

Update the version and list of features (any new GA libraries):

In ports/google-cloud-cpp/vcpkg.json

  • a. Update the version field
  • b. Either update or remove the port-version field
  • c. Add a new entry for any new features
  • d. Format the changes
./bootstrap-vcpkg.sh
./vcpkg format-manifest ports/google-cloud-cpp/vcpkg.json

Update the SHA512

SHA512=($(curl -fSsL https://github.com/googleapis/google-cloud-cpp/archive/${VERSION}.tar.gz | sha512sum))
sed -i "s/SHA512 .*/SHA512 ${SHA512[0]}/" ports/google-cloud-cpp/portfile.cmake

Commit the changes

git commit -m"[google-cloud-cpp] update to the latest release (${VERSION})" ports

Update the version information (you really do need two commits)

./vcpkg x-add-version google-cloud-cpp --overwrite-version
git commit --amend --no-edit .

Test the changes

Remove any older versions
./vcpkg remove --outdated --recurse
Install the new libraries
for feature in <new_features>; do ./vcpkg remove google-cloud-cpp; ./vcpkg install "google-cloud-cpp[core,${feature}]" || break; done
Install all the libraries
./vcpkg remove google-cloud-cpp && ./vcpkg install 'google-cloud-cpp[*]'

Push the branch to your fork

git push origin

Make the PR with the following description

Updates google-cloud-cpp to the latest release (vX.YZ.A)

Tested locally (on x64-linux) with:

```
for feature in ; do ./vcpkg remove google-cloud-cpp; ./vcpkg install "google-cloud-cpp[core,${feature}]" || break; done
```

and

```
./vcpkg remove google-cloud-cpp && ./vcpkg install 'google-cloud-cpp[*]'
```

7. Monitor the automation on Conda

On Conda things are mostly automated. A robot will create a PR, similar to PR#138. If you want, subscribe to notifications in the conda feedstock repository or just look at the PRs in that repository over the next 24 hours.

8. [optional] Push the release to Conan

The documentation has moved to the How-To Guide: Update Conan Package.

Creating a patch release of google-cloud-cpp on an existing release branch

In your development fork:

  • We will use BRANCH=v2.15.x and PATCH=v2.15.1 as an example.
  • Set these shell variables to appropriate values.
  • Create a new branch
    git branch chore-prepare-for-${PATCH}-release upstream/${BRANCH}
    git checkout chore-prepare-for-${PATCH}-release
  • Bump the version numbers for the patch release
    • Update the minor version in the top-level CMakeLists.txt file.
    git commit -m"chore: prepare for ${PATCH}"
  • If this is the first patch release for that branch, you need to update the GCB triggers.
    • Update the Google Cloud Build trigger definitions to compile this branch:
      ci/cloudbuild/convert-to-branch-triggers.sh --branch "${BRANCH}"
    • Actually create the triggers in GCB:
      for trigger in $(git ls-files -- ci/cloudbuild/triggers/*.yaml ); do
        ci/cloudbuild/trigger.sh --import "${trigger}";
      done
    • Remove any old triggers for the same major version, e.g.:
      gcloud builds triggers list \
          --project=cloud-cpp-testing-resources \
          --filter=name:v2-10-x --format='value(id)' | \
          xargs -n 1 gcloud builds triggers delete \
              --project=cloud-cpp-testing-resources
    • Commit these changes:
      git commit -m"Updated GCB triggers" ci
  • Push the branch and then create a PR:
    git push --set-upstream origin "$(git branch --show-current)"

Send this PR for review and merge it before continuing

  • Create a new branch off the release branch, which now contains the new patch version and baseline ABI dumps.
    git fetch upstream
    git branch my-patch upstream/${BRANCH}
    git checkout my-patch
  • Create or cherry-pick commits with the desired changes.
  • Update CHANGELOG.md to reflect the changes made.
  • After merging the PR(s) with all the above changes, create the tag:
    git fetch upstream ${BRANCH}
    git checkout upstream/${BRANCH}
    git tag ${PATCH}
    git push upstream ${PATCH}
  • Use the Release UI on GitHub to create a pre-release from the new tag. Uncheck the "Set as the latest release" box if this is not the latest release.
  • After review, publish the release.
  • Update our vcpkg port.