Skip to main content

Easy semantic versioning for projects in Git

Project description

VerNum

Version numbering for project releases

Rat icons created by Freepik - Flaticon

Warning: Breaking Changes

Starting in VerNum v4.0.0:

  • No longer generates a .version file - file generation is the responsibility of an outer script
  • Includes alpha and beta increments
  • Supports the --set-current option to receive the current version number from a source other than Git tags
  • Requires an increment - patch is no longer the default
  • No longer checks Git status before proceeding
  • No longer provides the option to automatically update the Git tag, and no longer supports the dry-run option

Default functionality

  • Read the Git tags in the current branch that match the pattern e.g. "v5.6.1" and pick the highest value
  • Increment the version number for major, minor, patch, alpha, or beta releases
  • Return the new version for later use

Installation

Requires Python 3 to run the command; your project can be anything.

pip3 install vernum

Usage (CLI)

Requirements:

  • CD to the root of the project before running it
  • Be on the branch that you use for releases (i.e. master)
  • Be fully up-to-date in git (i.e. merged, committed, and pushed)

Then run the command, specifying the increment to trigger the change:

  • major change e.g. 5.6.2 to 6.0.0
  • minor change e.g. 5.6.2 to 5.7.0
  • patch change e.g. 5.6.2 to 5.6.3
  • beta change e.g. 5.7.beta3 to 5.7.beta4
  • alpha change e.g. 5.7.alpha8 to 5.7.alpha9
  • Leave it out for no change, just to view the current version

Source of truth

The default behaviour assumes that the source of truth for the current version comes from the highest valued Git tag in the current branch (based on a regular expression match) but VerNum does not actually update the Git tag. Note that a "v" at the beginning of the input version number is optional; it's not included in the output.

Alternatively, use the --set-current option to define a different current version to reference rather than a Git tag. The override is useful for:

  • Bootstrapping a repo that has previous versions
  • Using a downstream system as the source of truth for version numbers (such as an artifact repository)
  • Fixing errors in the Git tag history

To update the Git tag, try something like:

vernum patch
git tag -a "cat $(.version)" -m "cat $(.version)"
git push origin "cat $(.version)"

Usage (GitLab CI/CD)

VerNum is designed for use withing GitLab CI/CD, and includes a CI/CD configuration template to support the most common use cases.

Use the provided vernum.gitlab-ci.yml to use it in GitLab. Here's an example:

include:
  - project: 'vernum/vernum'
    ref: stable
    file: 'vernum.gitlab-ci.yml'

stages:
  - Build
  - Test
  - Pre-release
  - Release
  - Post-release

deliver:
    stage: Post-release
    script:
        - echo "Edit this script to deploy or distribute v$(cat .version)"

The CI/CD template will provide a set of manual jobs following the rules:

  • Numbered version increments (patch, minor, major) only on the default branch
  • Alpha and beta increments only on branches that start with next-

Usage:

  1. Go to the pipeline view in GitLab for the project and choose the latest pipeline on the appropriate branch
  2. Confirm the pipeline represents the commit you intend to release
  3. Go into the "Latest version info" when it's done, and confirm that the latest version number is accurate
  4. Click the "play" button on the appropriate release job (major, minor, alpha, etc.)
  5. After the release job is complete play the "Increment Version" job - it will fail if played too soon
  6. When the "Mark Release in GitLab" job is complete, go into it to confirm the new version

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

vernum-5.1.0.tar.gz (4.3 kB view details)

Uploaded Source

Built Distribution

vernum-5.1.0-py3-none-any.whl (5.2 kB view details)

Uploaded Python 3

File details

Details for the file vernum-5.1.0.tar.gz.

File metadata

  • Download URL: vernum-5.1.0.tar.gz
  • Upload date:
  • Size: 4.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.11.6 Linux/5.4.109+

File hashes

Hashes for vernum-5.1.0.tar.gz
Algorithm Hash digest
SHA256 fe6569b97f6390204b08fa2a0123078398ff2e8547bb4917979fb69cb7a59fab
MD5 d990b6f85b5c2bf2f254b791b95c2f4a
BLAKE2b-256 550f9392b38e8dd77a7da81121c1545ca7cb88aab3369a5364b07c5e94e48ba7

See more details on using hashes here.

File details

Details for the file vernum-5.1.0-py3-none-any.whl.

File metadata

  • Download URL: vernum-5.1.0-py3-none-any.whl
  • Upload date:
  • Size: 5.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.11.6 Linux/5.4.109+

File hashes

Hashes for vernum-5.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 09d6b4e43378dab937549b417ff836081730aee731571b2321d8ed3c53d71364
MD5 97b0f6a4744cb0fdab33066708318d75
BLAKE2b-256 33492e49a06710d4ae3fad0c4075328bdfc01d06e4c1f42d60919901324cfcdc

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page