Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use GoReleaser to build binaries #16

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open

Conversation

bodgit
Copy link

@bodgit bodgit commented Aug 10, 2023

Description of the change

This PR changes the build process to instead use GoReleaser to build the release binaries.

Benefits

I use this action to automatically install tools from GitHub releases into my GitHub Actions workflows. It works mostly ok with your existing releases, downloading the latest release that matches the OS and architecture my workflow is running on, however because the binary within the release archive still has the OS and architecture as part of the filename, I have to make sure my workflow runs wait-for-port-$(uname -s)-$(uname -m | sed -e 's/x86_64/amd64/' -e 's/aarch64/arm64/') to ensure portability instead of just wait-for-port.

While I was trying to work out the cleanest way to change the binary filenames, I figured it would be just easier to use GoReleaser instead which is a popular tool for building Golang-based releases. This removes a lot of the boilerplate from your existing workflow. It also creates the releases for you with the changelog entries, etc. so you just need to push the new version tag.

Supporting more OS/architecture combinations is also easy to change by just updating the .goreleaser.yml configuration file.

Possible drawbacks

Anyone expecting the previous behaviour of the binary having the OS and architecture as part of the binary filename.

Applicable issues

Additional information

I've tuned the GoReleaser configuration so it creates release tarballs and checksums with the same filenames as previous releases.

I've disabled Cgo which means static stripped binaries are built as standard. Contrary to the comments in #9 the size of the binaries is almost exactly the same as the dynamically-linked versions, about 2 MiB so this means things will work on Alpine.

I've also updated the some of the actions to their latest versions, I'd recommend maybe enabling Dependabot to keep these updated.

This replaces most of the manual workflow steps. GoReleaser config
tweaked to match the current release filenames.

Signed-off-by: Matt Dainty <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Failed to run on Alpine
2 participants