Skip to content

update ci (again) to prevent ignoring manual releases #47

update ci (again) to prevent ignoring manual releases

update ci (again) to prevent ignoring manual releases #47

Workflow file for this run

name: Release
on:
push:
branches: [ "main" ]
tags:
- 'v*.*.*' # Trigger on tag pushes
workflow_dispatch:
inputs:
tag:
description: 'Optional tag to release (e.g., v2.0.0)'
required: false
permissions:
contents: write
actions: write
jobs:
test:
name: Run Tests & Generate Coverage Badge
runs-on: ubuntu-latest
outputs:
coverage: ${{ steps.coverage.outputs.coverage }}
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Setup Go
uses: actions/setup-go@v4
with:
go-version-file: 'go.mod'
- name: Run Tests and Generate Coverage
id: coverage
run: |
go test -v ./... -covermode=count -coverprofile=coverage.out
COVERAGE=$(go tool cover -func=coverage.out | grep total | awk '{print $3}' | sed 's/%//')
echo "Coverage: $COVERAGE%"
echo "coverage=$COVERAGE" >> $GITHUB_ENV
echo "coverage=$COVERAGE" >> $GITHUB_OUTPUT
if (( $(echo "$COVERAGE < 80" | bc -l) )); then
echo "Test coverage is below 80%, failing the build."
exit 1
fi
go tool cover -func=coverage.out -o=coverage.out
- name: Go Coverage Badge
uses: tj-actions/coverage-badge-go@v3
with:
filename: coverage.out
coverage: ${{ env.coverage }}
- name: Verify Changed Files
uses: tj-actions/verify-changed-files@v16
id: verify-changed-files
with:
files: README.md
- name: Commit Changes
if: steps.verify-changed-files.outputs.files_changed == 'true'
run: |
git config --local user.email "[email protected]"
git config --local user.name "GitHub Action"
git add README.md
git commit -m "chore: Updated coverage badge."
- name: Push Changes
if: steps.verify-changed-files.outputs.files_changed == 'true'
uses: ad-m/github-push-action@master
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
branch: ${{ github.head_ref }}
release:
name: Create Release
needs: test
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Fetch All Tags
run: git fetch --tags
- name: Determine Tag
id: version
run: |
# Fetch latest semver tag globally
latest_tag=$(git tag --list 'v*.*.*' --sort=-v:refname | head -n 1 || echo "v0.0.0")
echo "Latest tag: $latest_tag"
if [ -n "${{ github.event.inputs.tag }}" ]; then
# Manual workflow_dispatch tag
new_tag="${{ github.event.inputs.tag }}"
elif [[ "${GITHUB_REF}" == refs/heads/main ]]; then
# Auto-increment patch for main
IFS='.' read -r major minor patch <<<"${latest_tag#v}"
if [ "$patch" -lt 9 ]; then
patch=$((patch + 1))
else
patch=0
if [ "$minor" -lt 9 ]; then
minor=$((minor + 1))
else
minor=0
major=$((major + 1))
fi
fi
new_tag="v${major}.${minor}.${patch}"
else
# Triggered by tag push
new_tag="${GITHUB_REF##*/}"
fi
# Create tag if missing
if ! git rev-parse "$new_tag" >/dev/null 2>&1; then
git tag "$new_tag"
git push origin "$new_tag"
fi
echo "tag=$new_tag" >> $GITHUB_OUTPUT
- name: Create GitHub Release with Notes
uses: softprops/action-gh-release@v2
with:
tag_name: ${{ steps.version.outputs.tag }}
name: ${{ steps.version.outputs.tag }}
generate_release_notes: true
body: |
🚀 **Automated Release**
- **Triggered by:** [@${{ github.actor }}](https://github.com/${{ github.actor }})
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}