mirror of
https://github.com/ansible-collections/hetzner.hcloud.git
synced 2026-02-04 08:01:49 +00:00
ci: setup release-please (#317)
##### SUMMARY The current release process for this project requires multiple manual local steps to prepare and then tag the release. This introduces the standard release-please workflow we have in most of our integrations. Release-please will open a new PR whenever there is a releasable change and it updates the CHANGELOG & other files automatically in this PR. Once the PR is merged a new tag is created. This repository has some additional complexity as it uses `antsibull-changelog` to maintain the user-facing changelog. This is implemented ina second job in the `release-please` workflow which executes when the release-please PR is updated and then runs `antsibull-changelog release` against the version. The resulting changes are pushed as a second commit to the same PR.
This commit is contained in:
parent
0f057b185f
commit
eb4114bad3
7 changed files with 88 additions and 45 deletions
77
.github/workflows/release-please.yml
vendored
Normal file
77
.github/workflows/release-please.yml
vendored
Normal file
|
|
@ -0,0 +1,77 @@
|
|||
on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
|
||||
name: release-please
|
||||
|
||||
jobs:
|
||||
release-please:
|
||||
# The secret HCLOUD_BOT_TOKEN is only available on the main repo, not in forks.
|
||||
if: github.repository == 'ansible-collections/hetzner.hcloud'
|
||||
|
||||
runs-on: ubuntu-latest
|
||||
outputs:
|
||||
pr-updated: ${{ steps.outputs.outputs.pr-updated }}
|
||||
branch: ${{ steps.outputs.outputs.branch }}
|
||||
version: ${{ steps.outputs.outputs.version }}
|
||||
|
||||
steps:
|
||||
- id: release
|
||||
uses: google-github-actions/release-please-action@v3
|
||||
with:
|
||||
token: ${{ secrets.HCLOUD_BOT_TOKEN }}
|
||||
release-type: simple
|
||||
package-name: hetzner.hcloud
|
||||
|
||||
# We use antsibull-changelog for the actual user-facing changelog.
|
||||
changelog-path: changelogs/dev-changelog.md
|
||||
|
||||
extra-files: |
|
||||
galaxy.yml
|
||||
plugins/module_utils/version.py
|
||||
|
||||
- name: Prepare outputs
|
||||
id: outputs
|
||||
if: steps.release.outputs.pr != ''
|
||||
run: |
|
||||
echo "pr-updated=true" >> "$GITHUB_OUTPUT"
|
||||
echo "branch=${{ fromJSON(steps.release.outputs.pr).headBranchName }}" >> "$GITHUB_OUTPUT"
|
||||
echo "version=$(echo "${{ fromJSON(steps.release.outputs.pr).title }}" | awk '{print $3}')" >> "$GITHUB_OUTPUT"
|
||||
|
||||
antsibull-changelog:
|
||||
runs-on: ubuntu-latest
|
||||
needs: [release-please]
|
||||
if: needs.release-please.outputs.pr-updated
|
||||
steps:
|
||||
- name: Setup python
|
||||
uses: actions/setup-python@v4
|
||||
with:
|
||||
python-version: 3.x
|
||||
- name: Install dependencies
|
||||
run: pip install antsibull-changelog
|
||||
|
||||
- uses: actions/checkout@v3
|
||||
with:
|
||||
ref: ${{ needs.release-please.outputs.branch }}
|
||||
|
||||
- name: antsibull-changelog
|
||||
run: antsibull-changelog release --version "${{ needs.release-please.outputs.version }}"
|
||||
|
||||
- name: Check for diff
|
||||
id: antsibull-diff
|
||||
run: |
|
||||
if [[ $(git status --porcelain) ]]; then
|
||||
echo "changed=true" >> "$GITHUB_OUTPUT"
|
||||
fi
|
||||
|
||||
- name: Commit & Push
|
||||
if: ${{ steps.antsibull-diff.outputs.changed }}
|
||||
run: |
|
||||
git config user.name "Hetzner Cloud Bot"
|
||||
git config user.email "45457231+hcloud-bot@users.noreply.github.com"
|
||||
|
||||
git add changelogs/ CHANGELOG.rst
|
||||
git commit -m "chore(main): changelog for version ${{ needs.release-please.outputs.version }}"
|
||||
|
||||
git push origin ${{ needs.release-please.outputs.branch }}
|
||||
Loading…
Add table
Add a link
Reference in a new issue