GitHub Action for running
semantic-release
. Respects any .releaserc.js configuration file in your repo. Exports environment variables for you to use in subsequent actions containing version numbers.
See action.yml
- Use major version
(recommended by GitHub):
uses: codfish/semantic-release-action@v1
- Use latest version:
uses: codfish/semantic-release-action@master
- Use specific version:
uses: codfish/[email protected]
Basic Usage:
steps:
- uses: actions/checkout@master
- uses: codfish/semantic-release-action@master
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
Using output variables set by semantic-release-action
:
steps:
- uses: actions/checkout@master
# you'll need to add an `id` in order to access output variables
- uses: codfish/semantic-release-action@master
id: semantic
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
- run: echo ${{ steps.semantic.outputs.release-version }}
- run: echo "$OUTPUTS"
env:
OUTPUTS: ${{ toJson(steps.semantic.outputs) }}
- uses: codfish/some-other-action@master
with:
release-version: ${{ steps.semantic.outputs.release-version }}
Only run an action if a new version was created:
steps:
- uses: actions/checkout@master
# you'll need to add an `id` in order to access output variables
- uses: codfish/semantic-release-action@master
id: semantic
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
- name: docker push version
if: steps.semantic.outputs.new-release-published == 'true'
run: |
docker tag some-image some-image:$TAG
docker push some-image:$TAG
env:
TAG: v$RELEASE_VERSION
Using environment variables set by semantic-release-action
:
steps:
- uses: actions/checkout@master
- uses: codfish/semantic-release-action@master
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
- run: |
echo $RELEASE_VERSION
echo $RELEASE_MAJOR
echo $RELEASE_MINOR
echo $RELEASE_PATCH
If you're not publishing to npm and only want to use this action for GitHub releases, you need to
include a .releaserc.js
file in your repo, instructing semantic-release
to not publish to the
npm
registry.
Example .releaserc.js
if you're not publishing to npm:
module.exports = {
branch: 'master',
plugins: [
'@semantic-release/commit-analyzer',
'@semantic-release/release-notes-generator',
['@semantic-release/npm', { npmPublish: false }],
'@semantic-release/github',
],
};
It's fairly easy to run semantic-release
as a "host action," aka something that simply runs
directly on the VM.
steps:
- run: npx semantic-release
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
If you're just publishing a node package, then this could still work well for you. The problem I found with this is when I was in projects where I had subsequent steps/actions in which I wanted to know whether a new version was cut.
Use Case: For instance, in an application where I'm using
semantic-release
to manage GitHub releases, but also building and pushing docker images. Dockerhub has a nice GitHub integration to handle this for us, but some other registries do not. If I need to cut a new release, then update a docker registry by adding a new tagged build, I'll want to runsemantic-release
and then build a docker image, tag it with a version and push it up. In my case I like to push up tags forlatest
, the semver (i.e.v1.8.3
), and just the major the version (i.e.v1
).
I want to know 1) if semantic-release cut a new version and 2) what the version is.
There's a number of ways to handle this, but the most elegant way I found to do it was to abstract it into it's own custom action. It abstracts away whatever logic you need to figure out what that new release number is.
This also scales well, just in case I want to add some flexibility and functionality to this action, I can easily leverage it across any project.
Docs: https://help.github.com/en/articles/metadata-syntax-for-github-actions#inputs
Input Variable | Description |
---|---|
branch | The branch on which releases should happen. |
semantic-release-action
sets both output variables and environment variables because why not?
Allows users the ability to use whichever they want. I don't know or understand every use case there
might be so this is a way to cover more cases.
Docs: https://help.github.com/en/articles/metadata-syntax-for-github-actions#outputs
Output Variables:
Output Variable | Description |
---|---|
new-release-published | Either 'true' when a new release was published or 'false' when no release was published. Allows other actions to run or not-run based on this |
release-version | The new releases' semantic version, i.e. 1.8.3 |
release-major | The new releases' major version number, i.e. 1 |
release-minor | The new releases' minor version number, i.e. 8 |
release-patch | The new releases' patch version number, i.e. 3 |
Environment Variables:
Environment Variable | Description |
---|---|
NEW_RELEASE_PUBLISHED | Either 'true' when a new release was published or 'false' when no release was published. Allows other actions to run or not-run based on this |
RELEASE_VERSION | The new releases' semantic version, i.e. 1.8.3 |
RELEASE_MAJOR | The new releases' major version number, i.e. 1 |
RELEASE_MINOR | The new releases' minor version number, i.e. 8 |
RELEASE_PATCH | The new releases' patch version number, i.e. 3 |