Skip to content

Auto Update Go Patch #5

Auto Update Go Patch

Auto Update Go Patch #5

name: Auto Update Go Patch
on:
schedule:
- cron: '0 0 * * *'
workflow_dispatch: # Allows manual triggering of the workflow
permissions:
pull-requests: write
contents: write
env:
GH_TOKEN: ${{ github.token }}
jobs:
bump-golang-patch-main:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- uses: actions/cache@v4
with:
path: |
~/.cache/go-build
~/go/pkg/mod
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
restore-keys: |
${{ runner.os }}-go-
- name: Update to latest go version allowable from current Dockerfile
id: update-go-mod-patch
run: |
CONTAINER_NAME=$(cat Dockerfile | grep golang: | head -n 1 | cut -d ' ' -f 3)
GO_VERSION=$(docker run --rm $CONTAINER_NAME go version | cut -d ' ' -f 3 | cut -d 'o' -f 2)
echo "Latest golang version allowed by image: $GO_VERSION"
echo "Updating go.mod go version to latest patch version"
go get go@$GO_VERSION toolchain@none
go mod tidy
echo "container-name=$CONTAINER_NAME" >> $GITHUB_ENV
echo "updated-go-version=$GO_VERSION" >> $GITHUB_ENV
- name: Create PR with updated go.mod if needed
run: |
if ! git diff --exit-code -- go.mod go.sum; then
git config --global user.email "actions@github.com"
git config --global user.name "GitHub Action"
git checkout -B actions/update-go-mod-patch
git add go.mod go.sum
git commit -m "Update go.mod and go.sum"
echo "Pushing to $GITHUB_REPOSITORY at actions/update-go-mod-patch"
git push --force --set-upstream origin actions/update-go-mod-patch
echo "PRing to $GITHUB_REPOSITORY main"
gh pr create --title "Update Go to $updated-go-version" --body "Updated Go to match latest patch available from Dockerfile image: $container-name" --base main --repo $GITHUB_REPOSITORY
fi;
cat go.mod