💸Save up to $132K/month in CI costs!👉 Try Free
Skip to main content
← Back to workflows

How to create GitHub Releases using GitHub Actions?

softprops/action-gh-release -
GitHub Action
v2.0.5
4,080
Contributors
Contributor - softpropsContributor - filips123Contributor - rhalaly

Optimize Your CI/CD Pipeline

Get instant insights into your CI/CD performance and costs. Reduce build times by up to 45% and save on infrastructure costs.

45% Faster Builds
60% Cost Reduction
Usage
name: A GitHub Action for creating GitHub Releases
on: push
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Release
uses: softprops/action-gh-release@v2
if: startsWith(github.ref, 'refs/tags/')

action-gh-release logo

action-gh-release

GitHub Action for creating GitHub Releases


How to create GitHub Releases using GitHub Actions?

action-gh-release is a GitHub Action that simplifies the creation of GitHub Releases across multiple OS environments like Linux, Windows, and macOS. It's particularly useful because it triggers only when you push tags, making it highly efficient for managing releases without cluttering the workflow with non-tag pushes.

Here’s a quick guide on how it works:

  1. Tag-Based Triggers: The action only runs when you push tags. You can set this up in your workflow file using conditions in the step.if field or by specifying tag patterns directly in the push configurations.

  2. Setting Up the Workflow:

    • Main Job: Set to run on the latest Ubuntu environment.
    • Steps Include:
      • Checkout: Fetch your code.
      • Conditional Release: Trigger the release process using softprops/action-gh-release@v2 if the commit starts with a tag reference.
  3. Uploading Assets:

    • You can specify which files to upload by listing them or using glob patterns. For instance, to upload Release.txt and LICENSE, you simply specify these in the files field under the release step.
  4. Customizing Release Notes:

    • The action supports external release notes, allowing you to use any changelog generator or manually create them. Simply point to the file containing the release notes using the body_path attribute.
  5. Handling Paths in Windows:

    • Remember to use forward slashes in file paths to avoid issues in pattern matching.
  6. Advanced Options:

    • You have various optional settings like draft, prerelease status, assets uploads, and more, which you can tailor according to your needs.

This setup not only makes your release process smoother but also ensures that every release is consistent and well-documented.