Skip to content
You're viewing an older version of this GitHub Action. Do you want to see the latest version instead?
git-pull-request

GitHub Action

Next Semantic Version

v1.0.4

Next Semantic Version

git-pull-request

Next Semantic Version

Guess the next semantic version only from existing git tags and recently merged pull-requests labels

Installation

Copy and paste the following snippet into your .yml file.

              

- name: Next Semantic Version

uses: fabien-marty/[email protected]

Learn more about this action in fabien-marty/github-next-semantic-version-action

Choose a version

github-next-semantic-version-action

What is it?

This is a GitHub Action that provides the github-next-semantic-version tool/feature inside a GHA Workflow. This tool guess the next semantic version** from:

  • existing git tags (read from a locally cloned git repository)
  • and recently merged pull-requests labels (read from the GitHub API)

Unlinke plenty of "similar" tools, we don't use any "commit message parsing" here but only configurable PR labels.

Usage

- uses: actions/checkout@v4
  with:
    fetch-tags: true # we need to fetch tags to determine the latest version
    fetch-depth: 0 # fetch-tags is not enough because of a GHA bug: https://github.com/actions/checkout/issues/1471

- id: version
  uses: fabien-marty/github-next-semantic-version-action@v1
  with:
    github-token: ${{ github.token }} # Let's use the default value of the current workflow
    repository: ${{ github.repository }} # Let's use the default value of the current workflow
    repository-owner: ${{ github.repository_owner }} # Let's use the default value of the current workflow

- name: Use results
  run: |
    echo "Latest version is ${{ steps.version.outputs.latest-version }}"
    echo "Next version is ${{ steps.version.outputs.next-version }}"

Outputs

Inputs

  • log-level: Log Level (DEBUG, INFO or WARNING), default to INFO
  • github-token: GitHub Token (in most cases, you can use ${{ github.token }} as value)
  • repository: Full repository name (example: octocat/Hello-World, in most cases, you want to use ${{ github.repository }} as value)
  • repository-owner: repository owner (example: octocat), in most cases, you want to use ${{ github.repository-owner }} as value)
  • major-labels: coma separated list of PR labels to search for determining a major release (default to: major,breaking,Type: Major)
  • minor-labels: coma separated list of PR labels to search for determining a minor release (default to: minor,Type: Minor, Type: Feature)
  • ignore-labels: coma separated list of PR labels to search for ignoring a PR (default to: Type: Hidden), can be useful with dont-increment-if-no-pr option
  • dont-increment-if-no-pr: Do not increment if no PR found (or only ignored PRs), default to false, can be useful to determine automatically if a release is needed
  • consider-also-non-merged-prs: If set to true (default to false), consider also "non merged" PRs to compute the next version