From 8256a9689bfdae9c751336e5154e1cffba468f30 Mon Sep 17 00:00:00 2001 From: Joe Martin Date: Thu, 9 Jan 2025 12:50:04 -0800 Subject: [PATCH] fix: update prerelease workflow to include commit hash in snapshot versioning --- .github/workflows/create-prerelease.yml | 46 +++++++++++++++---------- 1 file changed, 27 insertions(+), 19 deletions(-) diff --git a/.github/workflows/create-prerelease.yml b/.github/workflows/create-prerelease.yml index 41f80af..f2c1e3a 100644 --- a/.github/workflows/create-prerelease.yml +++ b/.github/workflows/create-prerelease.yml @@ -48,6 +48,7 @@ jobs: if [[ "${{ github.event_name }}" == "workflow_dispatch" ]]; then # Manual build: Use version input TAG="${{ inputs.version }}" + echo "Triggered manually with version: ${TAG}" elif [[ "${{ github.event_name }}" == "push" ]]; then # Push event: Extract tag from GITHUB_REF @@ -62,12 +63,18 @@ jobs: VERSION=${TAG#v} # Check if it's a snapshot - if [[ "$VERSION" == *-SNAPSHOT-* || ${{ inputs.preRelease }} == true ]]; then + if [[ "$VERSION" == *-SNAPSHOT-* ]]; then + SNAPSHOT="true" + elif [[ ${{ inputs.preRelease }} == true ]]; then SNAPSHOT="true" + COMMIT=$(git rev-parse --short HEAD) + VERSION="${VERSION}-SNAPSHOT-${COMMIT}" else SNAPSHOT="false" fi + + # Output the results echo "VERSION=${VERSION}" >> $GITHUB_ENV echo "SNAPSHOT=${SNAPSHOT}" >> $GITHUB_ENV @@ -82,23 +89,25 @@ jobs: JF_URL: https://aerospike.jfrog.io JF_ACCESS_TOKEN: ${{ secrets.JFROG_ACCESS_TOKEN }} JF_PROJECT: ${{ env.JFROG_CLI_BUILD_PROJECT }} - - name: 'Alias go to jf go' - run: | - # This will set up jf go build instead of go build. This lets us also include build number and build name - # for jfrog builds. - # Write the function to a script using a heredoc - cat << EOF > ~/go-setup.sh - #!/bin/bash - go() { - if [[ "\$1" == "build" ]]; then - shift - jf go build --build-name=$JFROG_CLI_BUILD_NAME --build-number=$VERSION --project=$JFROG_CLI_BUILD_PROJECT "\$@" - else - command go "\$@" - fi - } - EOF - chmod +x ~/go-setup.sh + # Enable when we can use jf from makefiles differentiating between deb, rpm, pkg etc. + # Each of those types should be in a different jfrog build. Also will need to run go-setup.sh before build steps are called. + # - name: 'Alias go to jf go' + # run: | + # # This will set up jf go build instead of go build. This lets us also include build number and build name + # # for jfrog builds. + # # Write the function to a script using a heredoc + # cat << EOF > ~/go-setup.sh + # #!/bin/bash + # go() { + # if [[ "\$1" == "build" ]]; then + # shift + # jf go build --build-name=$JFROG_CLI_BUILD_NAME --build-number=$VERSION --project=$JFROG_CLI_BUILD_PROJECT "\$@" + # else + # command go "\$@" + # fi + # } + # EOF + # chmod +x ~/go-setup.sh - name: 'Install Homebrew' run: /bin/bash -c "NONINTERACTIVE=1 $(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)" - name: 'Install Dependencies' @@ -130,7 +139,6 @@ jobs: env: ADDCOMMIT: ${{ steps.parse-version.outputs.is-snapshot }} run: | - ~/go-setup.sh buildcmd="build-prerelease" [ "${ADDCOMMIT}" = "false" ] && buildcmd="build-official" export PATH=$PATH:/usr/local/bin:/usr/local/go/bin