Skip to content

Release

Release #26

Workflow file for this run

name: Release
on:
workflow_dispatch:
inputs:
prerelease:
description: "Prerelease"
required: true
type: boolean
draft:
description: "Draft"
required: true
type: boolean
version-increment-type:
description: 'Which part of the version to increment:'
required: true
type: choice
options:
- major
- minor
- patch
default: 'patch'
permissions:
contents: write
jobs:
release:
name: Version Bump and Release
runs-on: ubuntu-latest
steps:
# Check out the repo with credentials that can bypass branch protection, and fetch git history instead of just latest commit
- uses: actions/checkout@v4
with:
token: ${{ secrets.AUTOMATION_USER_TOKEN }}
fetch-depth: 0
- uses: DevCycleHQ/release-action/[email protected]
id: prepare-release
with:
github-token: ${{ secrets.AUTOMATION_USER_TOKEN }}
prerelease: ${{ github.event.inputs.prerelease }}
draft: ${{ github.event.inputs.draft }}
version-increment-type: ${{ github.event.inputs.version-increment-type }}
- name: Update version in code
run: |
sed -i "s/^const VERSION = \".*\"/const VERSION = \"${{steps.prepare-release.outputs.next-release-tag}}\"/" ./version.go
- name: Commit and push
run: |
git config --global user.email "[email protected]"
git config --global user.name "DevCycle Automation"
git add ./version.go
git commit -m "Release ${{steps.prepare-release.outputs.next-release-tag}}"
git push origin HEAD:main
if: inputs.draft != true
- uses: DevCycleHQ/release-action/[email protected]
id: create-release
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
tag: ${{ steps.prepare-release.outputs.next-release-tag }}
target: main
prerelease: ${{ github.event.inputs.prerelease }}
draft: ${{ github.event.inputs.draft }}
changelog: ${{ steps.prepare-release.outputs.changelog }}
- name: Display link to release
run: |
echo "::notice title=Release ID::${{ steps.create-release.outputs.release-id }}"
echo "::notice title=Release URL::${{ steps.create-release.outputs.release-url }}"