From e4522444b37696c483bbd5b542fbddd47723c80b Mon Sep 17 00:00:00 2001 From: Mohsin Zaidi <2236875+smrz2001@users.noreply.github.com> Date: Mon, 22 Jan 2024 11:34:57 -0500 Subject: [PATCH] feat: updated release workflow --- .github/workflows/cd-to-infra.yml | 21 +++++++++++++++++---- .github/workflows/publish-release.yml | 20 ++++++++++++++------ ci-scripts/release_pr.sh | 15 ++++++++------- 3 files changed, 39 insertions(+), 17 deletions(-) diff --git a/.github/workflows/cd-to-infra.yml b/.github/workflows/cd-to-infra.yml index 8966ee022..78e3f0a8c 100644 --- a/.github/workflows/cd-to-infra.yml +++ b/.github/workflows/cd-to-infra.yml @@ -1,10 +1,13 @@ name: Continuous Deployment to Infra +permissions: + contents: write + on: push: branches: [ "main" ] + # Trigger on all release events until we can figure out the optimal selection release: - types: [created, published, edited, prereleased, released] env: AWS_REGION: ${{ secrets.AWS_REGION }} @@ -37,7 +40,7 @@ jobs: run: | SHA_TAG=$(echo ${{ github.SHA }} | head -c 12) DEPLOY_TAG=$SHA_TAG - if [[ ${{ contains(github.event.head_commit.message, 'chore: Release') }} == 'true' ]]; then + if [[ ${{ contains(github.event.head_commit.message, 'chore: version v') }} == 'true' ]]; then RELEASE_TAG=$(cargo metadata --format-version=1 --no-deps | jq '.packages[0].version' | tr -d '"') # Use the release tag to deploy, if one is available. DEPLOY_TAG=$RELEASE_TAG @@ -60,7 +63,17 @@ jobs: echo "Workflow triggered by: ${{ github.event_name }}" if [[ "${{ github.event_name }}" == "release" ]]; then echo "Release action: ${{ github.event.action }}" - if [[ "${{ github.event.action }}" == "prereleased" ]]; then + # For some reason, GitHub won't trigger the "created" or "prereleased" events when a pre-release is created + # from the "publish-release.yml" workflow. This is despite using a PAT to create the pre-release, which is + # the recommended way to trigger one workflow from another. + # + # This would imply that there was some issue with the repo or workflow configuration but GitHub does trigger + # the "published" workflow. Because of this, we're detecting pre-releases through the "published" event and + # its "prerelease" flag. + # + # Strangely enough, the "edited" and "released" events are triggered when promoting the pre-release to a + # release through the GitHub console (╯°□°)╯︵ ┻━┻ + if [[ "${{ github.event.action }}" == "published" && "${{ github.event.release.prerelease }}" == "true" ]]; then DEPLOY_ENV="tnet" elif [[ "${{ github.event.action }}" == "released" ]]; then DEPLOY_ENV="prod" @@ -68,7 +81,7 @@ jobs: else DEPLOY_ENV="qa" fi + echo "DEPLOY_ENV is $DEPLOY_ENV" if [[ -n "$DEPLOY_ENV" ]]; then make DEPLOY_ENV="$DEPLOY_ENV" DEPLOY_TAG=${{ needs.publish.outputs.deploy_tag }} schedule-k8s-deployment fi - echo "DEPLOY_ENV is $DEPLOY_ENV" diff --git a/.github/workflows/publish-release.yml b/.github/workflows/publish-release.yml index f892e46eb..9cc8e438a 100644 --- a/.github/workflows/publish-release.yml +++ b/.github/workflows/publish-release.yml @@ -5,16 +5,17 @@ permissions: contents: write on: + # Run this workflow against any branch that updates the TOML file. This can be used to create (pre)releases from any + # branch (e.g. for hotfixes) without affecting the main branch. push: - branches: [ "main" ] paths: - 'Cargo.toml' jobs: - # Build and packages all the things + # Build and package all the things build-binaries: if: | - contains(github.event.head_commit.message, 'chore: Release') + contains(github.event.head_commit.message, 'chore: version v') strategy: matrix: # For these target platforms @@ -82,8 +83,8 @@ jobs: runs-on: ubuntu-latest env: CARGO_REGISTRY_TOKEN: ${{ secrets.CARGO_TOKEN }} - GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + GH_TOKEN: ${{ secrets.GH_TOKEN_PAT }} + GITHUB_TOKEN: ${{ secrets.GH_TOKEN_PAT }} steps: - uses: actions/checkout@v3 with: @@ -96,8 +97,15 @@ jobs: ls artifacts/**/* - name: Install Rust toolchain uses: dtolnay/rust-toolchain@stable + - run: | + git config user.email "github@3box.io" + git config user.name "Github Automation" - id: release run: | export TAG=$(cargo metadata --format-version=1 --no-deps | jq '.packages[0].version' | tr -d '"') echo "Releasing "$TAG - gh release create "v${TAG}" -n "Release of ${TAG}" -t "v${TAG}" --latest artifacts/**/*.tar.gz \ No newline at end of file + # Generate a GitHub pre-release. This will trigger the "published" event that will deploy to Clay. When the + # pre-release is promoted to a release from the GitHub console, the "released" event will trigger and deploy + # to Prod. + current_branch=$(git rev-parse --abbrev-ref HEAD) + gh release create "v${TAG}" -t "v${TAG}" --target "$current_branch" --generate-notes --prerelease artifacts/**/*.tar.gz diff --git a/ci-scripts/release_pr.sh b/ci-scripts/release_pr.sh index 2b9d3aafa..3c94f0ade 100755 --- a/ci-scripts/release_pr.sh +++ b/ci-scripts/release_pr.sh @@ -63,16 +63,17 @@ cargo update -p ceramic-api-server # Commit the specified packages # `cargo release commit` currently fails to build a good commit message. # Using git commit directly for now -branch="release-v${version}" -git checkout -b "$branch" -msg="chore: release version v${version}" +current_branch=$(git rev-parse --abbrev-ref HEAD) +pr_branch="version-v${version}" +git checkout -b "$pr_branch" +msg="chore: version v${version}" git commit -am "$msg" -git push --set-upstream origin $branch +git push --set-upstream origin "$pr_branch" -# Create a PR +# Create a PR against the branch this workflow is running on gh pr create \ - --base main \ - --head "$branch" \ + --base "$current_branch" \ + --head "$pr_branch" \ --label release \ --title "$msg" \ --body "$release_notes"