Release with commit
ActionsTags
(2)This GitHub Action (written in TypeScript) wraps the GitHub Release API, specifically the Create a Release endpoint, to allow you to leverage GitHub Actions to create releases.
Most release actions either expect you to push a tag first, or they assume you are already using a commit-message convention like Conventional Commits.
This action is meant for a smaller, simpler case: “when the latest commit message looks like a release commit, create a release from it.”
- Triggered by the commit message — on each push, the action checks the head commit message against the regexp you provide. If it matches, a release is created. If not, nothing happens. You do not need to push a tag separately.
- Use regex captures in the release — captured values like $1, $2, and so on can be used in tag_name, release_name, and body, so the commit message can directly shape the release.
- No required convention — you do not have to use Conventional Commits or set up a release plugin. Pick the pattern that fits your project.
Create a workflow .yml file in your .github/workflows directory. An example workflow is available below. For more information, reference the GitHub Help Documentation for Creating a workflow file.
For more information on these inputs, see the API Documentation
regexp: The pattern of commit message. Create a release if commit message match this.regexp_options: The option ofregexp. for more details, see Advanced Searching With Flagstag_name: The name of the tag for this release.release_name: The name of the release.body: Text describing the contents of the release. Optional, and not needed if usingbody_path.body_path: A file with contents describing the release. Optional, and not needed if usingbody.draft:trueto create a draft (unpublished) release,falseto create a published one. Default:falseprerelease:trueto identify the release as a prerelease.falseto identify the release as a full release. Defaultfalsegenerate_release_notes:trueto let GitHub automatically generate the release name and body from merged pull requests since the previous release. When enabled,release_name(name) andbody/body_path(body) are used only if you set them explicitly; anything left unspecified is generated by GitHub. Defaultfalse
For more information on these outputs, see the API Documentation for an example of what these outputs look like
id: The release IDhtml_url: The URL users can navigate to in order to view the release. i.e.https://github.com/octocat/Hello-World/releases/v1.0.0upload_url: The URL for uploading assets to the release, which could be used by GitHub Actions for additional uses, for example the@actions/upload-release-assetGitHub Actioncreated: The Boolean value of whether a release was createdtag_name: The name of the created tag_name
On every push to a commit message matching the regexp, create a release:
name: Release with commit
on:
push:
branches:
- master
jobs:
release:
runs-on: ubuntu-latest
steps:
- uses: ChanTsune/release-with-commit@v4.0.1
with:
regexp: "Release ((\\d+([.]\\d+)*)-(alpha|beta|rc)\\d*)((\\s|\\S)*)"
regexp_options: "us"
release_name: "version $1"
tag_name: "v$1"
body: "$5"
draft: false
prerelease: false
env:
GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}' # This token is provided by Actions, you do not need to create your own tokenThis will create a Release, as well as a release event, which could be handled by a third party service, or by GitHub Actions for additional uses, for example the @actions/upload-release-asset GitHub Action. This uses the GITHUB_TOKEN provided by the virtual environment, so no new token is needed.
We would love you to contribute to @ChanTsune/release-with-commit, pull requests are welcome! Please see the CONTRIBUTING.md for more information.
The scripts and documentation in this project are released under the MIT License
Release with commit is not certified by GitHub. It is provided by a third-party and is governed by separate terms of service, privacy policy, and support documentation.