Skip to main content

Bump semver for git repos with a single command.

Project description

bumpsemver

Current version: 0.2.0

A utility to simplify the version bumping for git repos.

Overview

This application is a rework of the famous bumpversion tool. The
original repo seems like abandoned. Several fundamental changes are introduced, which make the fork-and-extend approach infeasible:

  1. dropped Python 2 support
  2. boosted the test coverage to 95%+
  3. dropped many irrelevant feature to reduce complexity. (e.g. customized version component support)
  4. introduced JSON support to make it work for package-lock.json
  5. narrowed the versioning scheme to semver-only

Installation

pip3 install bumpsemver

Usage

This application supports both the CLI mode and config file mode. To maximum possible extent it is compatible with the classical bumpversion.

Command Line Interface

bumpsemver [options] part [file]

options

[optional]

Most of the configuration values described below can also be given as an option on the command-line. Additionally, the following options are available:

--dry-run Don't touch any files, just pretend. Best used with --verbose.

--allow-dirty Normally, bumpsemver will abort if the working directory is dirty to protect yourself from releasing unversioned files and/or overwriting unsaved changes. Use this option to override this check.

--verbose Print useful information to stderr

-h, --help Print help and exit

part

required

The part of the version to increase. As we support semver only, the valid values include: major, minor, and patch.

For example, bumping file src/VERSION from 0.5.1 to 0.6.0:

bumpsemver --current-version 0.5.1 minor src/VERSION

file

[optional]
default: none

The file that will be modified.

If not given, the list of [bumpversion:file:…] sections from the configuration file will be used. If no files are mentioned on the configuration file either, then no files will be modified.

For example, bumping file setup.py from 1.1.9 to 2.0.0:

bumpsemver --current-version 1.1.9 major setup.py

Configuration file

It is mandatory for all the Sherlock CMI projects to use the configuration file with default name. By doing this, the command bumpsemver part without any parameter will bump the version number distributed at various places in a consistent manner.

Options on the command line take precedence over those from the config file, which take precedence over those from the defaults.

Example .bumpsemver.cfg:

[bumpversion]
current_version = 0.2.9
commit = True
tag = True

[bumpversion:file:README]

.bumpsemver.cfg -- Global configuration

General configuration is grouped in a [bumpversion] section.

current_version

required
default: none

The current version of the software package before bumping.

Also available as CLI argument --current-version (e.g. bumpsemver --current-version 0.5.1 patch)

tag = (True | False)

[optional]
default: False (Don't create a git tag)

Whether to create a git tag, that is the new version, prefixed with the character "r". Don't forget to git-push with the --tags flag.

Also available as CLI argument --tag or --no-tag.

sign_tags = (True | False)

[optional]
default: False (Don't sign tags)

Whether to sign tags.

Also available as CLI argument --sign-tags or --no-sign-tags.

tag_name =

[optional]
default: v{new_version}

The name of the tag that will be created. Only valid when tag = True.

It can be a template using the Python Format String Syntax.
Available in the template context are current_version and new_version as well as current_[part] and new_[part] (e.g. 'current_major' or 'new_patch'). You can also use the variables now or utcnow to get a current timestamp. Both accept datetime formatting (when used like as in {now:%d.%m.%Y}).

Also available as CLI argument --tag-name, for example: bumpsemver --tag-name 'release-{new_version}' patch

In addition, it is also possible to provide a tag message by using CLI --tag-message TAG_MESSAGE. Example usage: bumpsemver --tag-name 'release-{new_version}' --tag-message "Release {new_version}" patch

If neither tag message or sign tag is provided, we use a lightweight tag in git. Otherwise, we utilize an annotated git tag. Read more about Git tagging here.

commit = (True | False)

[optional]
default: False (Don't create a commit)

Whether to create a commit using git.

Also available as CLI argument --commit or --no-commit.

message =

[optional]
default: [OPS] bumped version: {current_version} → {new_version}

The commit message to use when creating a commit. Only valid when using --commit / commit = True.

It can be a template using the Python Format String Syntax.
Available in the template context are current_version and new_version as well as current_[part] and new_[part] (e.g. 'current_major' or 'new_patch'). You can also use the variables now or utcnow to get a current timestamp. Both accept datetime formatting (when used like as in {now:%d.%m.%Y}).

Also available as CLI argument --message, for example: bumpsemver --tag-name 'release-{new_version}' patch

In addition, it is also possible to provide a tag message by using CLI --tag-message TAG_MESSAGE. Example usage: bumpsemver --message '[{now:%Y-%m-%d}] Jenkins Build {$BUILD_NUMBER}: {new_version}' patch

.bumpsemver.cfg -- File specific configuration

This configuration is in the section: [bumpversion:file:…] or [bumpversion:json:…]

Note: The configuration file format requires each section header to be unique. If you want to process a certain file multiple times (e.g. multiple location to be replaced separately), you may append a description between parens to the file keyword: [bumpversion:file (special one):…]. It does not matter what inside the parens, just make it unique. e.g.

[bumpversion:file(1):README.md]
search = current version: {current_version}
replace = current version: {new_version}

[bumpversion:file(2):README.md]
search = **Version: {current_version}**
replace = current version: {new_version}
search =

default: {current_version}

Template string how to search for the string to be replaced in the file. Useful if the remotest possibility exists that the current version number might be present multiple times in the file and you mean to only bump one of the occurrences.

replace =

default: {new_version}

Template to create the string that will replace the current version number in the file.

Given this requirements.txt:

    Django>=1.5.6,<1.6
    MyProject==1.5.6

using the following .bumpsemver.cfg will ensure only the line containing MyProject will be changed:

[bumpversion]
current_version = 1.5.6

[bumpversion:file:requirements.txt]
search = MyProject=={current_version}
replace = MyProject=={new_version}

With [bumpversion:file:…], the specified file is processed as plain text file, which in fact makes this application programming language neutral. However, it will be very error prone for complex file for example package-lock.json.

For randomly sampled 30 projects written in node.js/TypeScript, the classical bumpversion or the renovated bump2version both made 100% mistakes which changed something shouldn't be changed. There are too many "version": "1.2.3" in that file. To address this issue, bumpsemver added the support of json file.

To use it:

[bumpversion:json:package-lock.json]
version_key = version 

Value of the parameter version_key is a JSONPath string. For the typical package.json or package-lock.json, using version or its jQuery-style alternative $.version is sufficient. Otherwise, anything can be selected with JSONPath is support, so, nothing we can't do. The underlying JSONPath processor is jsonpath-ng. Checkout their document for some examples and hints.

The suffix is also supported for json file:

[bumpversion:json(1):example.json]
version_key = version

[bumpversion:json( same file):example.json]
version_key = dependencies[2].*.version

[bumpversion:json (once again):example.json]
version_key = dependencies[0].*.lodash.dependencies[1].version

Test

Test in Docker container (recommended):

make test

Local test in the working environment (not recommended):

tox

To test the compatibility with a specific version of Python, put the version(s) into ./python-versions.txt one version per line. Then run:

make test

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

bumpsemver-0.2.0.tar.gz (29.2 kB view hashes)

Uploaded Source

Built Distribution

bumpsemver-0.2.0-py2.py3-none-any.whl (18.1 kB view hashes)

Uploaded Python 2 Python 3

Supported by

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