Skip to content

Update release-bump.yml #1

Update release-bump.yml

Update release-bump.yml #1

Workflow file for this run

name: Release - Bump Version
## Release automation for pact's published packages in brew
# Designed to run systems in kadena-io/homebrew-pact
# There is a
run-name: "Release homebrew pact ${{ inputs.release_sha }} from ${{ github.sha}}"
on:
workflow_dispatch:
inputs:
pact_intel:
description: "url of latest pact release package for intel"
type: string
required: false
pact_arm:
description: "url of latest pact release package for arm"
type: string
required: false
pact_head:
description: "url of latest pact-5 release package for arm"
type: string
required: false
workflow_call:
inputs:
pact_intel:
description: "url of latest pact release package for intel"
type: string
required: false
pact_arm:
description: "url of latest pact release package for arm"
type: string
required: false
pact_head:
description: "url of latest pact-5 release package for arm"
type: string
required: false
jobs:
Update-References:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
repository: kadena-io/homebrew-pact
ssh-key: ${{ secrets.GH_DEPLOYKEY_PACTBREW }}
- name: Update GHC version if needed
run: |
# we fire this function for every possible url so stop if no url was passed to script
# get release to calculate sha (and exit if the curl fails)
# escape the release URL / characters
# replace the release url and sha
# blank out variables to prevent conflicts
replace_in_rb() {
ON_TARGET=$1
RELEASE_URL=$2
HEAD_SEARCH=$3
if [[ -z "$RELEASE_URL" ]]; then
echo "$ON_TARGET is blank, not updating url"
return 0
else
echo "$ON_TARGET will be updated to $RELEASE_URL"
fi
curl -L "$RELEASE_URL" --output target.tar.gz || exit 1
RELEASE_SHA=`sha256sum target.tar.gz | awk '{ print $1 }'`
RELEASE_URL=$(printf '%s\n' "$RELEASE_URL" | sed 's:[\\/&]:\\&:g; $!s/$/\\/')
sed -i --regexp-extended -z "s/($HEAD_SEARCH)($ON_TARGET do\n[ ]*)url \"([a-z0-9:\/\.\-]+)\"(\n[ ]*sha256 \")([0-9a-f]+)\"/\1\2url \"$RELEASE_URL\"\4$RELEASE_SHA\"/" pact.rb
ON_TARGET=""
RELEASE_URL=""
HEAD_SEARCH=""
}
replace_in_rb on_intel "${{ inputs.pact_intel }}"
replace_in_rb on_arm "${{ inputs.pact_arm }}"
replace_in_rb on_arm "${{ inputs.pact_head }}" '\<head do\>\n[ ]*'
- name: Validate pact arm nightly release
run: |
brew install --build-from-source pact.rb --head
pact -v
brew unlink pact
- name: Validate pact arm release
brew install --build-from-source pact.rb --head
pact -v
brew unlink pact
- name: Update master branch with new homebrew
run: |
git config --local user.name "Kadena DevOps"
git config --local user.email "[email protected]"
git add pact.rb
git commit --allow-empty -m "pact package version update"
# allow empty in case this is a re-run
git status
git tag chainweb-${{ inputs.VERSION_NEW }}
git push
git push --force origin --tags