2.8 KiB
2.8 KiB
Release Action
This action will create a github release and optionally upload an artifact to it.
Action Inputs
- allowUpdates: An optional flag which indicates if we should update a release if it already exists. Defaults to false.
- artifact: An optional set of paths representing artifacts to upload to the release. This may be a single path or a comma delimited list of paths (or globs).
- artifacts: An optional set of paths representing artifacts to upload to the release. This may be a single path or a comma delimited list of paths (or globs).
- artifactContentType: The content type of the artifact. Defaults to raw.
- body: An optional body for the release.
- bodyFile: An optional body file for the release. This should be the path to the file.
- commit: An optional commit reference. This will be used to create the tag if it does not exist.
- draft: Optionally marks this release as a draft release. Set to
trueto enable. - name: An optional name for the release. If this is omitted the tag will be used.
- omitBody: Indicates if the release body should be omitted. This is primarily useful for preserving the release body during updates.
- omitName: Indicates if the release name should be omitted. This is primarily useful for preserving the release name during updates.
- prerelease: Optionally marks this release as prerelease. Set to true to enable.
- replacesArtifacts: Indicates if existing release artifacts should be replaced. Defaults to true.
- tag: An optional tag for the release. If this is omitted the git ref will be used (if it is a tag).
- token: (Required) The Github token. Typically this will be
${{ secrets.GITHUB_TOKEN }}. - omitBodyDuringUpdate: Indicates if the release body should be omitted during updates. The body will still be applied for newly created releases. This will preserve the existing body during updates.
- omitNameDuringUpdate: Indicates if the release name should be omitted during updates. The name will still be applied for newly created releases. This will preserve the existing name during updates.
Example
This example will create a release when tag is pushed:
name: Releases
on:
push:
tags:
- '*'
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
- uses: ncipollo/release-action@v1
with:
artifacts: "release.tar.gz,foo/*.txt"
bodyFile: "body.md"
token: ${{ secrets.GITHUB_TOKEN }}
Notes
- You must provide a tag either via the action input or the git ref (i.e push / create a tag). If you do not the action will fail.
- If the tag of the release you are creating does not exist yet, you should set both the
tagandcommitaction inputs.commitcan point to a commit hash or a branch name (ex -master).