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.3.0.tar.gz (10.4 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.3.0-py3-none-any.whl (13.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: base_version_checker-0.3.0.tar.gz
  • Upload date:
  • Size: 10.4 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.3.0.tar.gz
Algorithm Hash digest
SHA256 bb021260fc03298fc4ac80a2ec5589991c1cfed61d516eaf58e80987c0944db6
MD5 2ee3ed46fa0cecb4e059888e76f418bb
BLAKE2b-256 6df79ae3fa73fe09253d3bdae9832253b45eeab8f0100068fa4928b9e9e7bcdb

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for base_version_checker-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c1e7a7a552f71f854a4643bd3c6ed83aab32bb37b0032a501cb248d8f96bf258
MD5 038c53f75e8a5893a6783edd38342518
BLAKE2b-256 c5aeaf2f07625915c1751af7a72f2e902e21af896e2fed2858e1531cab5f0b3f

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