Skip to main content

Checks egg updates in your Buildout configurations.

Project description

Build Status - develop branch Coverage of the code

Parses a zc.buildout file containing a versions section of the pinned versions of the eggs, and checks if any updates are available.

Usage

If you use the practical convention to pin the versions of all the eggs used in your buildout into a file, you will find this package useful for checking if any newest version of the eggs are available on Pypi.

Here an example of a version file:

$ cat versions.cfg
[versions]
Pillow                          = 2.0.0
pytz                            = 2012j
South                           = 0.8.1
django                          = 1.5
django-tagging                  = 0.3.1

Now let’s execute the check-buildout-updates script:

$ ./check-buildout-updates
[versions]
Pillow                          = 2.1.0
pytz                            = 2013b
South                           = 0.8.2
django                          = 1.5.2

You can now update the versions.cfg file accordingly to your needs.

Options

usage: check-buildout-updates [-h] [-s SOURCE] [-i INCLUDES] [-e EXCLUDES]
                              [-w] [--indent INDENTATION]
                              [--sorting {alpha,length}]
                              [--service-url SERVICE_URL] [--timeout TIMEOUT]
                              [-t THREADS] [-v] [-q]

Check availables updates from a version section of a buildout script

optional arguments:
  -h, --help            show this help message and exit
  -s SOURCE, --source SOURCE
                        The file where versions are pinned (default:
                        versions.cfg)
  -i INCLUDES, --include INCLUDES
                        Include package when checking updates (can be used
                        multiple times)
  -e EXCLUDES, --exclude EXCLUDES
                        Exclude package when checking updates (can be used
                        multiple times)
  -w, --write           Write the updates in the source file
  --indent INDENTATION  Spaces used when indenting "key = value" (default: 32)
  --sorting {alpha,length}
                        Sorting algorithm used on the keys when writing source
                        file (default: None)
  --service-url SERVICE_URL
                        The service to use for checking the packages (default:
                        http://pypi.python.org/pypi)
  --timeout TIMEOUT     Timeout for each request (default: 10s)
  -t THREADS, --threads THREADS
                        Threads used for checking the versions in parallel
  -v                    Increase verbosity (specify multiple times for more)
  -q                    Decrease verbosity (specify multiple times for more)

Buildout integration

You can easily integrate this script into your buildout script to automaticly find and write the updates.

[buildout]
parts                   = evolution

[evolution]
recipe                  = zc.recipe.egg
eggs                    = buildout-versions-checker
scripts                 = check-buildout-updates=evolve
arguments               = '-s versions.cfg -w'

With this part into your buildout, a new script named ./bin/evolve will be created. It will check for the available updates of the eggs listed in the versions section of the versions.cfg file, then write the updates found.

Python compatibility

Buildout-versions-checker has been originally developed for Python 2.7, but has been ported and tested for Python 3.2 and 3.3.

Requirements

  • six >= 1.4.1

  • futures >= 2.1.4

Extras

Buildout-versions-checker also provides extra scripts for simplify the maintenance of yours versions files.

indent-buildout

indent-buildout is designed for just (re)indenting your buildout files. Because the buildout files are sometimes mixed with spaces and tabulations which may affect viewing and editing.

$ ./indent-buildout buildout.cfg versions.cfg

find-unused-versions

find-unused-versions just check if your have not pinned eggs which are not used in your installation. For better results, run the script after a full and fresh install.

$ ./find-unused-versions

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

buildout-versions-checker-1.6.tar.gz (13.2 kB view details)

Uploaded Source

Built Distribution

buildout_versions_checker-1.6-py2.py3-none-any.whl (17.5 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file buildout-versions-checker-1.6.tar.gz.

File metadata

File hashes

Hashes for buildout-versions-checker-1.6.tar.gz
Algorithm Hash digest
SHA256 93b4c9d71ac0ee29afac40681c69e787b614278fdb58b769844d6c328316749d
MD5 1a6938e0f7db86f452eb0f39f7f0a6ec
BLAKE2b-256 111f72fbf0a1066ec5ac796a218f5b27811b9c38b5fc538ae2b80699cd00fe4b

See more details on using hashes here.

File details

Details for the file buildout_versions_checker-1.6-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for buildout_versions_checker-1.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 481bbe59461ad0b68cf534a9b034ece909a97bf032528a229500979141922938
MD5 8151fd7a1fae4429b5cc079ac6887b83
BLAKE2b-256 1376d86ac9d96e4e7330e0148ee4ffd044fafad785840388a3de15a3b5b922f9

See more details on using hashes here.

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