All Projects → actions → Create Release

actions / Create Release

Licence: mit
An Action to create releases via the GitHub Release API

Programming Languages

javascript
184084 projects - #8 most used programming language

Projects that are alternatives of or similar to Create Release

Release It
🚀 Automate versioning and package publishing
Stars: ✭ 4,773 (+389.04%)
Mutual labels:  release, release-automation
release-changelog-builder-action
A GitHub action that builds your release notes / changelog fast, easy and exactly the way you want.
Stars: ✭ 515 (-47.23%)
Mutual labels:  release, release-automation
Git Changelog Lib
Library for parsing and generating a changelog, or releasenotes, from a GIT repository
Stars: ✭ 117 (-88.01%)
Mutual labels:  release, release-automation
attribution
Generate changelogs from commit tags and shortlogs
Stars: ✭ 20 (-97.95%)
Mutual labels:  release, release-automation
Releaser Tools
Create a GitHub/GitLab/etc. release using a project's commit messages and metadata.
Stars: ✭ 283 (-71%)
Mutual labels:  release, release-automation
Axion Release Plugin
Gradle release & version management plugin.
Stars: ✭ 372 (-61.89%)
Mutual labels:  release, release-automation
Semantic Release
📦🚀 Fully automated version management and package publishing
Stars: ✭ 14,364 (+1371.72%)
Mutual labels:  release, release-automation
generate-changelog
generates changelog from git based on jira tickets
Stars: ✭ 18 (-98.16%)
Mutual labels:  release, release-automation
Upload Release Asset
An Action to upload a release asset via the GitHub Release API
Stars: ✭ 537 (-44.98%)
Mutual labels:  release, release-automation
Gh Action Pypi Publish
GitHub Action, for publishing distribution files to PyPI
Stars: ✭ 317 (-67.52%)
Mutual labels:  release, release-automation
Github Release Notes
Node module to create a release or a changelog from a tag and uses issues or commits to creating the release notes.
Stars: ✭ 705 (-27.77%)
Mutual labels:  release, release-automation
Shipjs
Take control of what is going to be your next release.
Stars: ✭ 668 (-31.56%)
Mutual labels:  release
Scorecardpy
Scorecard Development in python, 评分卡
Stars: ✭ 433 (-55.64%)
Mutual labels:  release
Ngc
NewGoCommand - An opinionated and lightweight project starter. (WORK IN PROGRESS)
Stars: ✭ 16 (-98.36%)
Mutual labels:  release
React Native Version
🔢 Version your React Native or Expo app in a `npm version` fashion.
Stars: ✭ 408 (-58.2%)
Mutual labels:  release
Guessit
GuessIt is a python library that extracts as much information as possible from a video filename.
Stars: ✭ 643 (-34.12%)
Mutual labels:  release
Environmentswitcher
🔥No repackage, switch environment with one click.(无需重新打包,一键切换环境 )
Stars: ✭ 401 (-58.91%)
Mutual labels:  release
Devops Readme.md
What to Read to Learn More About DevOps
Stars: ✭ 398 (-59.22%)
Mutual labels:  release
Githubupdates
Cocoa framework to install application updates from GitHub releases.
Stars: ✭ 393 (-59.73%)
Mutual labels:  release
Fugitive
Simple command line tool to make git more intuitive, along with useful GitHub addons.
Stars: ✭ 20 (-97.95%)
Mutual labels:  release

GitHub Action - Releases API

Please note: This repository is currently unmaintained by a team of developers at GitHub. The repository is here and you can use it as an example, or in Actions. However please be aware that we are not going to be updating issues or pull requests on this repository.

Maintained Actions:

To reflect this state we’ve marked this repository as Archived.

If you are having an issue or question about GitHub Actions then please contact customer support.

If you have found a security issue please submit it here.


This GitHub Action (written in JavaScript) wraps the GitHub Release API, specifically the Create a Release endpoint, to allow you to leverage GitHub Actions to create releases.

GitHub Actions status

Usage

Pre-requisites

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.

Inputs

For more information on these inputs, see the API Documentation

  • tag_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 using body_path.
  • body_path: A file with contents describing the release. Optional, and not needed if using body.
  • draft: true to create a draft (unpublished) release, false to create a published one. Default: false
  • prerelease: true to identify the release as a prerelease. false to identify the release as a full release. Default: false
  • commitish : Any branch or commit SHA the Git tag is created from, unused if the Git tag already exists. Default: SHA of current commit
  • owner: The name of the owner of the repo. Used to identify the owner of the repository. Used when cutting releases for external repositories. Default: Current owner
  • repo: The name of the repository. Used to identify the repository on which to release. Used when cutting releases for external repositories. Default: Current repository

body_path

The body_path is valuable for dynamically creating a .md within code commits and even within the Github Action steps leading up to the create-release.

Outputs

For more information on these outputs, see the API Documentation for an example of what these outputs look like

  • id: The release ID
  • html_url: The URL users can navigate to in order to view the release. i.e. https://github.com/octocat/Hello-World/releases/v1.0.0
  • upload_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-asset GitHub Action

Example workflow - create a release

On every push to a tag matching the pattern v*, create a release:

on:
  push:
    # Sequence of patterns matched against refs/tags
    tags:
      - 'v*' # Push events to matching v*, i.e. v1.0, v20.15.10

name: Create Release

jobs:
  build:
    name: Create Release
    runs-on: ubuntu-latest
    steps:
      - name: Checkout code
        uses: actions/[email protected]
      - name: Create Release
        id: create_release
        uses: actions/[email protected]
        env:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # This token is provided by Actions, you do not need to create your own token
        with:
          tag_name: ${{ github.ref }}
          release_name: Release ${{ github.ref }}
          body: |
            Changes in this Release
            - First Change
            - Second Change
          draft: false
          prerelease: false

This 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.

Contributing

We would love you to contribute to @actions/create-release, pull requests are welcome! Please see the CONTRIBUTING.md for more information.

License

The scripts and documentation in this project are released under the MIT License

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].