Checks pinned versions with overrides in a cascaded buildout
Project description
plone.versioncheck
Checks pinned versions with overrides in a cascaded buildout
Requirements: Python 3.10 or later
Features
1. Checks buildouts [versions] sections while stepping through the cascaded extends
- Command line script collects the inherited version pins, remembers where a version pin comes from
- It displays the result in order to enable a human to check that pins and overrides are OK
- Output is colored; this helps to identify packages which have newer versions available
- Machine readable output as JSON on demand
2. Checks Python Package Index (PyPI) for newer versions
- Detects if a newer major, minor or bugfix (or a prerelease) is available
- Uses async HTTP requests with concurrent processing for 10-50x faster PyPI checks
- Configurable concurrency limit (default: 20 concurrent requests)
3. Buildout extension records the current versions state and requirements
- Versions state and requirements are written to a file
- Versions from the file will be consumed by the command line tool
- Orphaned version pins are detected
- It shows which package pulled in another package as dependency
It works best with semantically and only with syntactically correct version numbers!
Usage
Install with your buildout
Add a section to install it as a script and add it as an extension to your buildout:
[buildout]
...
extensions =
plone.versioncheck
parts =
...
ploneversioncheck
...
...
[ploneversioncheck]
recipe = zc.recipe.egg
eggs = plone.versioncheck
...
Run buildout as usual.
Now a file .plone.versioncheck.tracked.json was generated in the buildout-directory.
This file will be used by bin/versioncheck to figure out which packages were finally used.
Run buildout again to regenerate this file.
Command line
usage: versioncheck [-h] [-p] [-n] [-N] [-r] [-d] [-i] [-e EXCLUDE_CFG] [-m]
[--no-cache] [-b] [-o [OUTPUT]] [--no-colors]
[--debug-limit DEBUG_LIMIT]
[buildout]
Fetch information about pinned versions and its overrides in simple and complex/cascaded buildouts.
positional arguments:
buildout path to buildout.cfg or other *.cfg file
optional arguments:
-h, --help show this help message and exit
-p, --pypi check PyPI for newer versions
-n, --newer display only packages with newer version than active
-N, --newer-orphaned display orphaned packages only when newer versions
available
-r, --required-by show information about requirements (only if tracking
file is available)
-d, --show-release-dates
show information about release dates (only for package
lookup from PyPI)
-i, --ignore-tracking
ignore tracking file (if present)
-e EXCLUDE_CFG, --exclude-cfg EXCLUDE_CFG
exclude in listing when cfg-filename pattern matches
(fnmatch) the given expression
-m, --machine show as machine readable output (json)
--no-cache do not use a cache for PyPI
-b, --browser show as html for webbrowser
-o [OUTPUT], --output [OUTPUT]
safe output to output-file
--no-colors do not show colors
--debug-limit DEBUG_LIMIT
Limit the number of PyPI versions fetched for
debugging
States and color codes:
[A]ctive (white)
[D]evelop (green)
[O]rphaned (magenta)
[I]nherited (older or same versions are gray, newer are yellow)
[U]pdate of final release on PyPI available (cyan)
[P]rerelease update on PyPI available (blue)
[X] unpinned (red)
[r] Requirement (gray)
[a] Annotation (gray)
Color of package name helps to indicate overall state of a package.
Files created
If the extension was used, a file .plone.versioncheck.tracked.json will be created.
It contains the information from last buildout run, including version states and dependency tree.
Note: HTTP caching is currently disabled. The performance gains from async concurrent requests (10-50x speedup) far outweigh the caching benefits. Caching may be re-enabled in a future release.
Output explained
Legend of states and colors
[D]evelopment Egg
- A development egg is usually active
- Description shows location
- Color: Green
[A]ctive Pin
- Pinned version. Package is used and recent, all seems fine
- Color: White
[I]nherited Pin
- Unused pin. If older than active, the pin color is gray; if newer, it is yellow
[O]rphaned
- If tracked, it shows whether the package in the given configuration was used at all
- Be careful with this information!
- I.e. in a development buildout file, other packages are used than in a live or continuous integration buildout!
- Color: Magenta
[X] Unpinned
- Tracked, but no pin in
[versions]sections were found - Color: Red
[U]pdate final release
- At PyPI there is a newer final version available (major, minor or bugfix)
- Descriptions shows on which level
- Color: Cyan
[P]rerelease update
- At PyPI there is a newer prerelease version available (major, minor or bugfix)
- Descriptions shows on which level
- Only if there is no final release update available
- Color: Blue
[r] Required by
- If tracked and option
--required-bywas given, show packages this package is required by - Valid for current active/used version
- Keep in mind this is based on the declared requirements, missing or implicit requirements are not covered
[a] Annotation
- It is possible to annotate the reason why a version was chosen
- The information is parsed out of a section
[versionannotations] - In this section key is the name of the package and value the text annotations to be displayed
- The value can span more than one line using indent (as usual)
Order of versions
Order of versions is the buildout resolution order (how they are resolved by buildout in the extends chain/tree). After that, the PyPI releases are shown (major, minor, pre, then the prereleases)
Example, given in each a version of my.pkg was declared:
-
buildout.cfgwithmy.pkg=3.0.3buildout.cfgextendsfoo.cfgwithmy.pkg=3.0.1buildout.cfgextendsbar.cfgwithmy.pkg=2.0foo.cfgextendsbaz.cfgwithmy.pkg=3.1
-
found a newer versions at pypi
- major
my.pkg=4.0 - minor
my.pkg=3.2 - major prerelease
my.pkg=5.1b2
- major
Output looks like so:
my.pkg
3.0.3............... A buildout.cfg
2.0 ................ I bar.cfg
3.0.1 .............. I foo.cfg
3.1 ................ I baz.cfg
4.0 ................ U Major
3.2 ................ U Minor
5.1b2............... P Majorpre
Example
Here w/o colors, run on buildout.coredev:
$ ./bin/versioncheck -p buildout.cfg
accesscontrol
3.0.12 .... A versions.cfg
2.13.13 ... I http://dist.plone.org/versions/zope-2-13-23-versions.cfg
acquisition
4.2.2 ..... A versions.cfg
2.13.9 .... I http://dist.plone.org/versions/zope-2-13-23-versions.cfg
alabaster
0.7.7 ..... X unpinned
archetypes.multilingual
3.0.1 ..... A versions.cfg
archetypes.referencebrowserwidget
2.5.6 ..... A versions.cfg
archetypes.schemaextender
2.1.5 ..... A versions.cfg
argcomplete
1.0.0 ..... A tests.cfg
argh
0.26.1 .... A tests.cfg
argparse
(unset) ... A versions.cfg
1.1 ....... I http://dist.plone.org/versions/zopetoolkit-1-0-8-ztk-versions.cfg
Can not check legacy version number. U Error
autopep8
1.2.1 ..... A tests.cfg
[... skipped a bunch ...]
coverage
3.7.1 ..... A tests.cfg
3.5.2 ..... I http://dist.plone.org/versions/zopetoolkit-1-0-8-ztk-versions.cfg
4.0.3 ..... U Major
4.1b1 ..... P Majorpre
cssmin
0.2.0 ..... A versions.cfg
cssselect
0.9.1 ..... A versions.cfg
datetime
3.0.3 ..... A versions.cfg
2.12.8 .... I http://dist.plone.org/versions/zope-2-13-23-versions.cfg
4.0.1 ..... U Major
decorator
4.0.6 ..... A versions.cfg
[... skipped a bunch ...]
plone.app.textfield
1.2.6 ..... A versions.cfg
plone.app.theming
1.2.17.dev0 D /home/workspacejensens/coredev5/src/plone.app.theming/src
1.2.16 .... I versions.cfg
plone.app.tiles
2.1.0 ..... A versions.cfg
2.2.0 ..... U Minor
[... skipped a bunch ...]
Source Code and Contributions
If you want to help with the development (improvement, update, bug-fixing, ...) of plone.versioncheck this is a great idea!
Please follow the contribution guidelines.
Maintainer of plone.versioncheck is Jens Klein and the Plone contributors.
We appreciate any contribution and if a release is needed to be done on PyPI, please just contact one of us (best by opening an issue).
Development
Requirements
- Python 3.10 or later
- uv package manager
Setup
Clone the project and set up the development environment:
# Install uv if not already installed
curl -LsSf https://astral.sh/uv/install.sh | sh
# Create virtual environment
uv venv --python 3.10
# Activate virtual environment
source .venv/bin/activate # Linux/macOS
# or: .venv\Scripts\activate # Windows
# Install in development mode with all extras
uv pip install -e ".[test,typecheck,develop]"
# Install pre-commit hooks
pre-commit install
Running Tests
# Run all tests with coverage
pytest
# Run tests for specific module
pytest tests/test_pypi.py
# Run linting and type checking
pre-commit run --all-files
Code Quality
The project uses:
- ruff for linting and formatting
- isort for import sorting (Plone profile)
- pyright for type checking
- pre-commit for automated quality checks
- pre-commit.ci for automated PR checks
Test coverage requirement: 77% minimum (currently ~78%)
Pre-commit hooks will automatically fix issues when possible. On pull requests, pre-commit.ci will run all checks and auto-commit fixes.
License
The project is licensed under the GPLv2.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file plone_versioncheck-2.0.1.tar.gz.
File metadata
- Download URL: plone_versioncheck-2.0.1.tar.gz
- Upload date:
- Size: 33.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3f746030343a2c8eec06e94dc21f287d3aa677e3a748a2df6d96f6dc8d88aad2
|
|
| MD5 |
969239fb72ddaab5542b7b56203975a8
|
|
| BLAKE2b-256 |
b0810f81f29b4a8669ed0a4ff82f4025cd4ad98c70ceacd7f23238d272a3bc1b
|
Provenance
The following attestation bundles were made for plone_versioncheck-2.0.1.tar.gz:
Publisher:
release.yaml on plone/plone.versioncheck
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
plone_versioncheck-2.0.1.tar.gz -
Subject digest:
3f746030343a2c8eec06e94dc21f287d3aa677e3a748a2df6d96f6dc8d88aad2 - Sigstore transparency entry: 742221519
- Sigstore integration time:
-
Permalink:
plone/plone.versioncheck@d5d913d053e9f958c5cb8ba2ab939da86562ae05 -
Branch / Tag:
refs/tags/v2.0.1 - Owner: https://github.com/plone
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yaml@d5d913d053e9f958c5cb8ba2ab939da86562ae05 -
Trigger Event:
release
-
Statement type:
File details
Details for the file plone_versioncheck-2.0.1-py2.py3-none-any.whl.
File metadata
- Download URL: plone_versioncheck-2.0.1-py2.py3-none-any.whl
- Upload date:
- Size: 21.2 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
11a243d88c940855f39d8b7ebb6eb38f09708c35c2cd9b2c8fa1e573a9047271
|
|
| MD5 |
76d43b0b229ed72fba602f1fee61d335
|
|
| BLAKE2b-256 |
0aa0f685ba3af4969d347bb143006942b61e0617e568ecb02599e0376ba0f4ba
|
Provenance
The following attestation bundles were made for plone_versioncheck-2.0.1-py2.py3-none-any.whl:
Publisher:
release.yaml on plone/plone.versioncheck
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
plone_versioncheck-2.0.1-py2.py3-none-any.whl -
Subject digest:
11a243d88c940855f39d8b7ebb6eb38f09708c35c2cd9b2c8fa1e573a9047271 - Sigstore transparency entry: 742221522
- Sigstore integration time:
-
Permalink:
plone/plone.versioncheck@d5d913d053e9f958c5cb8ba2ab939da86562ae05 -
Branch / Tag:
refs/tags/v2.0.1 - Owner: https://github.com/plone
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yaml@d5d913d053e9f958c5cb8ba2ab939da86562ae05 -
Trigger Event:
release
-
Statement type: