GitHub Action
Octo Release Couscous
Automate drafting release notes process for your project.
A GitHub action to automatically draft a GitHub release based on a newly created version tag.
The drafted release notes will include the commit messages between the created version tag and the one before it.
Couscous originated as a Maghrebi dish of small steamed balls of crushed durum wheat semolina that is traditionally served with a stew spooned on top.
I took this excerpt from Wikipedia and didn't know it existed before naming the action. The idea for the name came from Github's randomly generated name suggestions on creating a repository so I just sticked with it.
Example: Let's assume the history of your repository looks like this:
┌────┐ ┌────┐
│ v1 │ │ v2 │ # Release Notes will include
└────┘ └────┘
│ │ ━━━━▶ - D
▼ ▼ - C
A ─ ─ B ─ ─ C ─ ─ D
Here, v2
is the last created version tag. When octorelease-couscous
runs, it will draft a release with the commit messages for C
and D
as the release notes.
If the created version tag is the first one in the repository, then all commit messages from the beginning of the repository's history will be included in the release notes:
╔════╗ # Release Notes will include
║ v1 ║
╚════╝ - D
│ ━━━━▶ - C
▼ - B
A ─ ─ B ─ ─ C ─ ─ D - A
In this case, the release notes will contain the messages for A
, B
, C
and D
.
A version tag is an annotated tag whose name starts with the prefix v
followed by one or more characters. This means v1
, v.1
, v1.0.0
and v1.0.0-beta1
are all valid version tags. To learn more about semver
or Semantic Versioning read here.
(Required) The GITHUB_TOKEN
is used to access the current repository from the GitHub REST API to get commit details.
The URL of the GitHub release draft cooked up. Defaults to an empty string.
An example of a workflow that listens for the create
event and automatically creates a release draft with the commit messages as release notes. It also prints the URL of the release page to the build log.
name: Test
on:
create:
jobs:
release:
name: Release
runs-on: [windows-latest, ubuntu-latest]
steps:
- name: Create a release draft for a version tag
id: create-release-draft
uses: kartik918/octorelease-couscous@v1
with:
repo-token: ${{ secrets.GITHUB_TOKEN }}
- name: Print the URL of the release draft
if: steps.create-release-draft.outputs.release-url != ''
run: echo ${{ steps.create-release-draft.outputs.release-url }}
I made the following graphic to explain (my future self) how a release couscous is prepared (I should stop with the puns).
- GitHub REST API
- Built upon gh-action Typescript template