Skip to content

A GitHub CLI extension to determine the next semantic version.

License

Notifications You must be signed in to change notification settings

koozz/gh-semver

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

40 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gh-semver

This GitHub CLI extension can be used determine the semantic version to release.

First it will search all tags and traverse up and down the git log to find the latest tag and inspect all commits made since against the conventional commits standard v1.0.0.

Prerequisites

Usage (commandline)

Install the extension by running:

gh extension install koozz/gh-semver

Run this extension with its keyword (default is semver):

gh semver

View more options with:

gh semver -help

In case of a newer version, upgrade by running:

gh extension upgrade koozz/gh-semver

Usage (GitHub Actions)

This extension can be used in a GitHub Actions workflow to determine the next semantic version.

In your workflow;

  • make sure the checkout has fetch-depth: 0
  • install the extension
  • call the extension
  • use the version as you see fit
# ...

    steps:
      - name: Checkout repository
        uses: actions/checkout@v3
        with:
          fetch-depth: 0
      - name: SemVer
        id: semver
        env:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
        run: |
          gh extension install koozz/gh-semver
          gh semver -action
      - name: Tag
        run: |
          git tag ${{ steps.semver.outputs.version }}

# ...

Or let the extension create the tag:

# ...

    steps:
      - name: Checkout repository
        uses: actions/checkout@v3
        with:
          fetch-depth: 0
      - name: SemVer
        env:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
        run: |
          gh extension install koozz/gh-semver
          gh semver -tag
          git push --tags

# ...

Example can be found in .github/workflows/auto-tag-main.yml

Roadmap

Things on the roadmap:

  • Semantic Versioning(-ish) for modules in a mono-repo;
    • Limit versioning to a directory within the repository.
    • Prefix the version with a module name.
  • Tests to make the software more robust and reliable.

Issues?

Help me out and describe the issue as complete a possible.

License

Apache 2.0

About

A GitHub CLI extension to determine the next semantic version.

Topics

Resources

License

Stars

Watchers

Forks

Sponsor this project

Contributors 3

  •  
  •  
  •  

Languages