Skip to content

Release and deploy to Sonatype staging repo #146

Release and deploy to Sonatype staging repo

Release and deploy to Sonatype staging repo #146

# sets up java, maven and gpg
# sets up settings.xml in such a way that the build/deploy works
# releases the project with specified version
# deploys it to the sonatype staging repo
name: Release and deploy to Sonatype staging repo
env:
GITHUB_PAT: ${{ secrets.QUDTLIB_BOT_GITHUB_TOKEN }}
MAVEN_USERNAME: ${{ secrets.MAVEN_USERNAME }}
MAVEN_CENTRAL_TOKEN: ${{ secrets.MAVEN_CENTRAL_TOKEN }}
MAVEN_GPG_PASSPHRASE: ${{ secrets.MAVEN_GPG_PASSPHRASE }}
on:
workflow_dispatch:
inputs:
release_version:
description: 'Release version (such as 2.3.13)'
required: true
type: string
next_snapshot_version:
description: 'Next SNAPSHOT version (such as 2.4-SNAPSHOT)'
required: true
type: string
environment:
description: 'Environment to run tests against'
type: environment
required: true
secrets:
QUDTLIB_BOT_GITHUB_TOKEN:
required: true
MAVEN_USERNAME:
required: true
MAVEN_CENTRAL_TOKEN:
required: true
MAVEN_GPG_PASSPHRASE:
required: true
jobs:
build:
# setting the environment on the job is mandatory, otherwise it cannot access environment secrets.
environment: ${{ inputs.environment }}
runs-on: ubuntu-latest
steps:
- name: Check write access to repo
run: |
token_login=$(curl -H "Authorization: Bearer ${token}" https://api.github.com/user | jq -r '.login')
echo token login is ${token_login}
echo $(curl -H "Authorization: Bearer ${token}" https://api.github.com/repos/${repo}/collaborators/${token_login}/permission) > result
cat result | jq '.permission == "admin" // .permission == "write"' > /dev/null || ( echo "Token does not have write access to ${repo}" >> ${GITHUB_STEP_SUMMARY}; exit 1)
curl -sS -f -I -H "Authorization: Bearer ${token}" https://api.github.com | grep 'x-oauth-scopes:' | grep 'repo' > /dev/null && exit 0 || echo "Token does not have repo scope on ${repo}" >> ${GITHUB_STEP_SUMMARY}
env:
repo: ${{ github.repository }}
token: ${{ secrets.QUDTLIB_BOT_GITHUB_TOKEN }}
# check if a tag already exists for the version we want to publish - in that case the workflow
# will fail later, so let us make it fail fast
- name: Check if tag v${{ inputs.release_version }} exists
uses: mukunku/[email protected]
id: checkTag
with:
tag: v${{ inputs.release_version }}
env:
GITHUB_TOKEN: ${{ secrets.QUDTLIB_BOT_GITHUB_TOKEN }}
- name: Fail if tag v${{ inputs.release_version }} exists
if: steps.checkTag.outputs.exists == 'true'
run: |
echo Tag v${{ inputs.release_version }} already exists, release aborted >> $GITHUB_STEP_SUMMARY
exit 1
# Set up java with maven cache
- uses: actions/checkout@v3
- name: Set up JDK 11
uses: actions/setup-java@v3
with:
distribution: 'temurin'
java-version: '11'
cache: 'maven'
# import the secret key
- name: Set up Apache Maven Central
uses: actions/setup-java@v3
with: # running setup-java again overwrites the settings.xml
distribution: 'temurin'
java-version: '11'
server-id: ossrh # Value of the distributionManagement/repository/id field of the pom.xml
server-username: MAVEN_USERNAME # env variable for username in deploy
server-password: MAVEN_CENTRAL_TOKEN # env variable for token in deploy
gpg-private-key: ${{ secrets.MAVEN_GPG_PRIVATE_KEY }} # Value of the GPG private key to import
gpg-passphrase: MAVEN_GPG_PASSPHRASE # env variable for GPG private key passphrase
cache: 'maven'
# configure git
- name: setup git config
run: |
git config user.name ${{ github.actor }}
git config user.email "<>"
# because we protect the main branch, the action cannot push to the repository
# Therefore, we create a branch for the release, and if the release succeeds, we will
# submit a pull request
# Note: outputs the name of the new branch as ${{ steps.create_release_branch.outputs.branch_name }}
- name: create branch for this release
id: create_release_branch
run: |
BRANCH_NAME=release-$version-$(date +%s)
git checkout --track -b $BRANCH_NAME
echo "branch_name=$BRANCH_NAME" >> $GITHUB_OUTPUT
env:
version: ${{ inputs.release_version }}
# Push to the remote so we create the remote branch without any changes
# because the create-pull-request action (see below) will only include unpushed
# changes in the PR
- name: Push changes to repository
env:
GITHUB_TOKEN: ${{ secrets.QUDTLIB_BOT_GITHUB_TOKEN }}
run: git push origin
# Update changelog unreleased section with new version
- name: Update changelog
uses: superfaceai/release-changelog-action@v1
with:
path-to-changelog: CHANGELOG.md
version: ${{ inputs.release_version }}
operation: release
# Apply formatting (changelog was touched)
- name: Apply format using spotless:apply
run: mvn spotless:apply -DspotlessFiles='.*CHANGELOG.md'
# Commit changes
- name: Commit CHANGELOG.md
run: |
git add "CHANGELOG.md"
git commit -m "Update CHANGELOG.md for release ${{ inputs.release_version }}"
# build and deploy to staging
- name: Build with Maven, deploying to sonatype staging repo
run: mvn -B release:clean release:prepare release:perform -DtagNameFormat="v@{project.version}" -DreleaseVersion=${{ inputs.release_version }} -DdevelopmentVersion=${{ inputs.next_snapshot_version }} -Darguments=-Dgpg.passphrase="$MAVEN_GPG_PASSPHRASE"
env:
password: ${{ secrets.QUDTLIB_BOT_GITHUB_TOKEN }}
MAVEN_GPG_PASSPHRASE: ${{ secrets.MAVEN_GPG_PASSPHRASE }}
# Read version changelog
- id: get-changelog
name: Get version changelog
uses: superfaceai/release-changelog-action@v1
with:
path-to-changelog: CHANGELOG.md
version: ${{ inputs.release_version }}
operation: read
# create the pull request
- name: Create Pull Request
uses: peter-evans/create-pull-request@v4
with:
token: ${{ secrets.QUDTLIB_BOT_GITHUB_TOKEN }}
title: Release ${{ inputs.release_version }}
base: main
branch: ${{ steps.create_release_branch.outputs.branch_name }}
delete-branch: true
body: |
# Changes
${{ steps.get-changelog.outputs.changelog }}
# Release info
Automated release through workflow: '${{ github.workflow }}'
Triggered by: ${{ github.triggering_actor }}
Version: ${{ inputs.release_version }}
Next development version: ${{ inputs.next_snapshot_version }}
# Next Steps
Please rebase this PR on top of `main` after publishing the release via the
[Sonatype Repository Manager](https://s01.oss.sonatype.org/).
# print the summary
- name: Print summary
run: echo "Release ${{ inputs.release_version }} deployed to sonatype staging repo. Please go there, close the repo and publish it." >> $GITHUB_STEP_SUMMARY