Skip to main content

Dev utility to verify hardcoded versions are in sync & updated

Project description

Install

pip install base-version-checker

Usage

.bumpversion.cfg

This file is highly recommended to get the most out of this tool. Without it you may get varied mileage from this as a git hook & when using bump2version. Here's a simplified example. Use version_checker -e ([bumpversion_cfg_example.txt]) for more details

[bumpversion]
current_version = 0.0.3

[bumpversion:file:Readme.md]
search = version_checker-{current_version}-py3-none-any.whl
replace = version_checker-{new_version}-py3-none-any.whl

[bumpversion:file:setup.cfg]
search = version = {current_version}
replace = version = {new_version}

[bumpversion:file:version.txt]

[bumpversion:file:kustomize/base/service.yaml]

[bumpversion:file:openapi-spec.json]
search = "version": "{current_version}"
replace = "version": "{new_version}"

[bumpversion:file:pom.xml]
search = <version>{current_version}</version> <!--this comment helps bumpversion find my (and only my) version!-->
replace = <version>{new_version}</version> <!--this comment helps bumpversion find my (and only my) version!-->

bump version cfg format

This format is driven by bump2version: https://github.com/c4urself/bump2version/blob/master/README.md I cannot assert that search & replace are regex compatibile, I would strongly recommend you stick to the above format.

  • [bumpversion]: top level of bumpversion cfg, this is the base for version synchronizing etc.
  • {current_version}: the checker & bump2version dryly replace this value with that reported at the top of the cfg
  • {new_version}: only used by bump2version and is replaced by the part update commanded (patch v minor v major)
  • [bumpversion:file:<file>]: section declaring a hardcoded version is present in a particular file
  • search: used by the checker and bumper to search for specific text other than the current_version
  • replace: used by the bumper only. the raw text to replace the search text

version_checker usage assuming a .bumpversion.cfg

# to run manually
version_checker -h
VERSION_BASE=origin/non-main-branch version_checker

# to see an example .bumpversion.cfg
version_checker --example-config

# to install as pre-push git hook
version_checker -i pre-push

# add & commit your files, push should throw errors if versions not in sync/updated
# the errors should tell you to do something like the following
bump2version patch
bump2version --help

environment variables

A few configurations can be modified by environment variables:

Environment Variable Default Description
VERSION_BASE origin/main or origin/master The base branch/commit to check versions against
VERSION_HEAD HEAD The current commit to check versions on
REPO_PATH . The path to the git repo
VERSION_FILE .bumpversion.cfg The config file with version configs to parse
VERSION_REGEX ([0-9]+\.?){3}?(\-([a-z]+)\.(\d+)) The version regex to search for, changes to this have not been tested much

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

base_version_checker-0.2.4.tar.gz (10.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

base_version_checker-0.2.4-py3-none-any.whl (13.3 kB view details)

Uploaded Python 3

File details

Details for the file base_version_checker-0.2.4.tar.gz.

File metadata

  • Download URL: base_version_checker-0.2.4.tar.gz
  • Upload date:
  • Size: 10.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for base_version_checker-0.2.4.tar.gz
Algorithm Hash digest
SHA256 e60f483aa7d7aa47f54a9308e4d304710b278d93c06243eac706df225af67416
MD5 8b0b6b634893930b0b1b85340a49279e
BLAKE2b-256 2d25df88b5735661d3ed91187dffb9ea6dbc02e01c14504681f8173b3b9f0e05

See more details on using hashes here.

File details

Details for the file base_version_checker-0.2.4-py3-none-any.whl.

File metadata

File hashes

Hashes for base_version_checker-0.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 247f8dbfdac0fc68348030c6a4eecbc6d4ab535c317754ce94b52f49871f3648
MD5 1a6952e50a6f5d97ca441a485e724acf
BLAKE2b-256 b69302e78e962b8829285ea256b5c2f84eb838caa400c38d42d90119ac359357

See more details on using hashes here.

Supported by

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