Skip to content

Commit

Permalink
feat: add release-please CI action (#108)
Browse files Browse the repository at this point in the history
Add release-please to the release ci action. This will automatically collect
commits merged to main since the last release. Then once the release pr
is merged it will create a tag, create a github release, build the artifacts
using goreleaser, and post the artifacts to the github release.
  • Loading branch information
derektamsen authored May 13, 2024
1 parent 47c6c6b commit baa9627
Show file tree
Hide file tree
Showing 3 changed files with 38 additions and 2 deletions.
16 changes: 14 additions & 2 deletions .github/workflows/release.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,28 @@ name: Release

on:
push:
tags: [ 'v*' ]
branches:
- main

permissions:
contents: write
pull-requests: write

jobs:
release-please:
runs-on: ubuntu-latest
outputs:
releases_created: ${{ steps.release.outputs.releases_created }}
steps:
- id: release
uses: google-github-actions/release-please-action@v4
with:
release-type: simple

goreleaser:
runs-on: ubuntu-latest

needs: release-please
if: ${{ needs.release-please.outputs.releases_created == 'true' }}
steps:
- name: Checkout
uses: actions/checkout@v4
Expand Down
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# Changelog
23 changes: 23 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,29 @@ through cgo to manage the encrypted devices. On debian/ubuntu you can run:
You should then see the form post data printed to stdout from
`cryptservermock`.

Releasing
---------

This repo uses the [relase-please](https://github.com/googleapis/release-please)
action. Release please leverages [conventional commits](https://www.conventionalcommits.org)
formatting to automatically collect release notes to create the next semver tag.
Once the release pr is merged release please will tag the next version and run
goreleaser which will automatically build the binaries and attach them to the
github release. The release pr will continue to collect changes since the last
time a release was tagged.

1. Create and merge any number of prs to main following conventional commits
formatting. You can continue to merge changes to main and release please will
continue to append changes to the open release pr since the last release was
tagged.
2. When you are ready to release the changes created in step 1,
[merge the open release pr](https://github.com/square/luks2crypt/labels/autorelease%3A%20pending).
This will trigger CI to create a new tag and github release. CI will also run
[goreleaser](https://goreleaser.com) which will build the binaries and update
the github release with the artifacts.
3. The changes merged in step 1 are now available on the
[latest github release](https://github.com/square/luks2crypt/releases/latest)

License
-------

Expand Down

0 comments on commit baa9627

Please sign in to comment.