Skip to content

Commit

Permalink
Support pre-releases in release tooling (#1425)
Browse files Browse the repository at this point in the history
  • Loading branch information
alcaeus authored and jyemin committed Sep 4, 2024
1 parent 779684b commit 86a847b
Show file tree
Hide file tree
Showing 3 changed files with 82 additions and 27 deletions.
22 changes: 13 additions & 9 deletions .github/workflows/bump-and-tag.sh
Original file line number Diff line number Diff line change
@@ -1,18 +1,22 @@
#!/usr/bin/env bash
set -e

# This script assumes that release X.Y.Z will always be created from X.Y.Z-SNAPSHOT"
echo "Replace snapshot version with release version ${RELEASE_VERSION} in build.gradle"
sed --in-place "s/version = '.*-SNAPSHOT'/version = '${RELEASE_VERSION}'/g" build.gradle
if [ "$#" -ne 3 ]; then
echo "Usage: $0 <current version> <release version> <next version>" >&2
exit 1
fi

echo "Create package commit for ${RELEASE_VERSION}"
git commit -m "Version: bump ${RELEASE_VERSION}" build.gradle
CURRENT_VERSION=$1
RELEASE_VERSION=$2
NEXT_VERSION=$3

SCRIPT_DIR=$(dirname ${BASH_SOURCE[0]})

echo "Bump version in build.gradle to ${RELEASE_VERSION}"
${SCRIPT_DIR}/bump-version.sh "${RELEASE_VERSION_WITHOUT_SUFFIX}-SNAPSHOT" "${RELEASE_VERSION}"

echo "Create release tag for ${RELEASE_VERSION}"
git tag -a -m "${RELEASE_VERSION}" r${RELEASE_VERSION}

echo "Bump to snapshot version for ${NEXT_VERSION}"
sed --in-place "s/version = '${RELEASE_VERSION}'/version = '${NEXT_VERSION}-SNAPSHOT'/g" build.gradle

echo "Create commit for version bump to ${NEXT_VERSION}"
git commit -m "Version: bump ${NEXT_VERSION}-SNAPSHOT" build.gradle
${SCRIPT_DIR}/bump-version.sh "${RELEASE_VERSION}" "${NEXT_VERSION}-SNAPSHOT"
13 changes: 13 additions & 0 deletions .github/workflows/bump-version.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
#!/usr/bin/env bash
set -e

if [ "$#" -ne 2 ]; then
echo "Usage: $0 <old version> <new version>" >&2
exit 1
fi

FROM_VERSION=$1
TO_VERSION=$2

sed --in-place "s/version = '${FROM_VERSION}'/version = '${TO_VERSION}'/g" build.gradle
git commit -m "Version: bump ${TO_VERSION}" build.gradle
74 changes: 56 additions & 18 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -32,63 +32,101 @@ jobs:
- name: "Store version numbers in env variables"
# The awk command to increase the version number was copied from
# StackOverflow: https://stackoverflow.com/a/61921674/3959933
# Variables set here:
# RELEASE_VERSION: The version the deployment is expected to create
# RELEASE_VERSION_WITHOUT_SUFFIX: The version without any stability
# suffixes. Example: 5.2.0-beta0 => 5.2.0
# NEXT_VERSION: The next version to be released. For pre-releases, the
# next version is a snapshot of the pre-release version. Examples:
# 5.2.0 => 5.2.1; 5.2.0-beta0 => 5.2.0
# RELEASE_BRANCH: The name of the stable branch for this release series
# Example: 5.2.0 => 5.2.x
# Example: 5.2.0-beta1 => <current branch>
run: |
echo RELEASE_VERSION=${{ inputs.version }} >> $GITHUB_ENV
echo NEXT_VERSION=$(echo ${{ inputs.version }} | awk -F. -v OFS=. '{$NF += 1 ; print}') >> $GITHUB_ENV
echo RELEASE_BRANCH=$(echo ${{ inputs.version }} | awk -F. -v OFS=. '{$NF = "x" ; print}') >> $GITHUB_ENV
echo RELEASE_VERSION_WITHOUT_SUFFIX=$(echo ${{ inputs.version }} | awk -F- '{print $1}') >> $GITHUB_ENV
if [[ "${{ inputs.version }}" =~ (alpha|beta|rc)[0-9]+$ ]]; then
echo NEXT_VERSION=$(echo ${{ inputs.version }} | awk -F- '{print $1}') >> $GITHUB_ENV
echo RELEASE_BRANCH=${{ github.ref_name }} >> $GITHUB_ENV
else
echo NEXT_VERSION=$(echo ${{ inputs.version }} | awk -F. -v OFS=. '{$NF += 1 ; print}') >> $GITHUB_ENV
echo RELEASE_BRANCH=$(echo ${{ inputs.version }} | awk -F. -v OFS=. '{$NF = "x" ; print}') >> $GITHUB_ENV
fi
- name: "Ensure current snapshot version matches release version"
run: |
grep -q "version = '${{ env.RELEASE_VERSION_WITHOUT_SUFFIX }}-SNAPSHOT'" build.gradle
if [[ $? != 0 ]]; then
echo '❌ Release failed: version in build.gradle is not a snapshot for release version ${{ inputs.version }}' >> $GITHUB_STEP_SUMMARY
exit 1
fi
- name: "Ensure release tag does not already exist"
run: |
if [[ $(git tag -l r${RELEASE_VERSION}) == r${RELEASE_VERSION} ]]; then
if [[ $(git tag -l r${{ env.RELEASE_VERSION }}) == r${{ env.RELEASE_VERSION }} ]]; then
echo '❌ Release failed: tag for version ${{ inputs.version }} already exists' >> $GITHUB_STEP_SUMMARY
exit 1
fi
# For patch releases (A.B.C where C != 0), we expect the release to be
# triggered from the A.B.x maintenance branch
# triggered from the A.B.x maintenance branch. We use the release version
# without suffixes to avoid mistakes when making pre-releases
- name: "Fail if patch release is created from wrong release branch"
if: ${{ !endsWith(inputs.version, '.0') && env.RELEASE_BRANCH != github.ref_name }}
if: ${{ !endsWith(env.RELEASE_VERSION_WITHOUT_SUFFIX, '.0') && env.RELEASE_BRANCH != github.ref_name }}
run: |
echo '❌ Release failed due to branch mismatch: expected ${{ inputs.version }} to be released from ${{ env.RELEASE_BRANCH }}, got ${{ github.ref_name }}' >> $GITHUB_STEP_SUMMARY
exit 1
# For non-patch releases (A.B.C where C == 0), we expect the release to
# be triggered from master or the A.B.x maintenance branch
# be triggered from master or the A.B.x maintenance branch. This includes
# pre-releases for any non-patch releases, e.g. 5.2.0-beta1
- name: "Fail if non-patch release is created from wrong release branch"
if: ${{ endsWith(inputs.version, '.0') && env.RELEASE_BRANCH != github.ref_name && github.ref_name != 'master' }}
if: ${{ endsWith(env.RELEASE_VERSION_WITHOUT_SUFFIX, '.0') && env.RELEASE_BRANCH != github.ref_name && github.ref_name != 'master' }}
run: |
echo '❌ Release failed due to branch mismatch: expected ${{ inputs.version }} to be released from ${{ env.RELEASE_BRANCH }} or master, got ${{ github.ref_name }}' >> $GITHUB_STEP_SUMMARY
exit 1
# If a non-patch release is created from a branch other than its
# maintenance branch, create that branch from the current one and push it
- name: "Create new release branch for non-patch release"
if: ${{ endsWith(inputs.version, '.0') && env.RELEASE_BRANCH != github.ref_name }}
run: |
echo '🆕 Creating new release branch ${RELEASE_BRANCH} from ${{ github.ref_name }}' >> $GITHUB_STEP_SUMMARY
git checkout -b ${RELEASE_BRANCH}
# Set commit author information to the user that triggered the release workflow
- name: "Set git author information"
run: |
GITHUB_USER_NAME=$(gh api users/${{ github.actor }} --jq '.name')
GITHUB_USER_ID=$(gh api users/${{ github.actor }} --jq '.id')
git config user.name "${GITHUB_USER_NAME}}"
git config user.name "${GITHUB_USER_NAME}"
git config user.email "${GITHUB_USER_ID}+${{ github.actor }}@users.noreply.github.com"
# If a non-patch release is created from a branch other than its
# maintenance branch, create that branch from the current one and push it
# Pre-releases don't have this behaviour, so we can check the full release
# version including stability suffixes to exclude those
- name: "Create new release branch for non-patch release"
if: ${{ endsWith(env.RELEASE_VERSION, '.0') && env.RELEASE_BRANCH != github.ref_name }}
run: |
echo '🆕 Creating new release branch ${{ env.RELEASE_BRANCH }} from ${{ github.ref_name }}' >> $GITHUB_STEP_SUMMARY
git checkout -b ${{ env.RELEASE_BRANCH }}
NEXT_MINOR_VERSION=$(echo "${{ env.RELEASE_VERSION }}" | awk -F. -v OFS=. '{$2 += 1 ; $NF = 0 ; print}')
echo "➡️ Bumping version for ${{ github.ref_name }} branch to ${NEXT_MINOR_VERSION}" >> $GITHUB_STEP_SUMMARY
git checkout ${{ github.ref_name }}
.github/workflows/bump-version.sh "${{ env.RELEASE_VERSION_WITHOUT_SUFFIX }}-SNAPSHOT" "${NEXT_MINOR_VERSION}-SNAPSHOT"
git push origin ${{ github.ref_name }}
git checkout ${{ env.RELEASE_BRANCH }}
# This step bumps version numbers in build.gradle and creates git artifacts for the release
- name: "Bump version numbers and create release tag"
run: .github/workflows/bump-and-tag.sh
run: .github/workflows/bump-and-tag.sh "${{ env.RELEASE_VERSION_WITHOUT_SUFFIX }}" "${{ env.RELEASE_VERSION }}" "${{ env.NEXT_VERSION }}"

- name: "Push release branch and tag"
run: |
git push origin ${RELEASE_BRANCH}
git push origin ${{ env.RELEASE_BRANCH }}
git push origin r${{ env.RELEASE_VERSION }}
- name: "Create draft release with generated changelog"
run: |
if [[ "${{ inputs.version }}" =~ (alpha|beta|rc) ]]; then
PRERELEASE="--prerelease --latest=false"
fi
echo "RELEASE_URL=$(\
gh release create r${RELEASE_VERSION} \
${PRERELEASE} \
--target ${{ env.RELEASE_BRANCH }} \
--title "Java Driver ${{ env.RELEASE_VERSION }} ($(date '+%B %d, %Y'))" \
--generate-notes \
Expand Down

0 comments on commit 86a847b

Please sign in to comment.