Skip to main content

Devpi-builder takes a requirements.txt and incrementally fills a devpi index with wheels of the listed python packages.

Project description

Brandon the Devpi Builder

Build Status Coverage Status Latest Version Requirements Status

Brandon, the devpi builder, takes a requirements.txt and incrementally fills a devpi index with wheels of the listed python packages.

Brandon by Example

Given a requirements.txt, we can upload all listed packages to the index opensource/Debian_7 on a local devpi using the following command:

$ devpi-builder requirements.txt http://localhost:3141/opensource/Debian_7 opensource mypassword

Example of such a requirements.txt:

progressbar==0.2.2
progressbar==0.2.1
PyYAML==3.11

Commandline Usage

usage: devpi-builder [-h] [--blacklist BLACKLIST] [--pure-index PURE_INDEX]
                     [--junit-xml JUNIT_XML] [--dry-run]
                     requirements index user password

Create wheels for all given project versions and upload them to the given
index.

positional arguments:
  requirements          requirements.txt style file specifying which project
                        versions to package.
  index                 The index to upload the packaged software to.
  user                  The user to log in as.
  password              Password of the user.

optional arguments:
  -h, --help            show this help message and exit
  --blacklist BLACKLIST
                        Packages matched by this requirements.txt style file
                        will never be build.
  --pure-index PURE_INDEX
                        The index to use for pure packages. Any non-pure
                        package will be uploaded to the index given as
                        positional argument. Packages already found in the
                        pure index will not be built, either.
  --junit-xml JUNIT_XML
                        Write information about the build success / failure to
                        a JUnit-compatible XML file.
  --dry-run             Build missing wheels, but do not modify the state of
                        the devpi server.

Features

  • Read a requirements.txt stile input file.

  • Support multiple versions of a package in the same file

  • Only build packages not yet in the target index.

  • Support a black-list for packages to never be built and uploaded (certain packages like numpy are fragile regarding their interdependency with other packages).

  • Can use separate indices for plain python packages and those with binary contents.

  • Can log build results to a JUnit compatible XML file, thus that it can be parsed by Jenkins.

License

New BSD

Changelog

This lists the most important changes for each release.

v2.0.0 (Jan 20 2016)

  • Enable compatibility with pip >= 8.0 by relying on pip’s default download cache mechanism instead of explicitly requiring a download cache. This effectively disables caching for people still using pip < 6.0. Thanks Christian Stefanescu.

  • Support for dry-running the wheel build without changing the devpi server state.

  • Python 3.5 is now officially supported.

  • Python 3.2 is no longer supported.

v1.0.0 (May 22 2015)

  • Use devpi-plumber instead of a custom devpi wrapper.

  • Check the blacklist first when deciding whether to build a package.

v0.4.0 (Nov 13 2014)

  • Only consider a package to exist if it is a wheel and it is compatible with the current system. Thanks Michael Still and David Szotten

  • Fix source distribution by adding missing README.md. Thanks Mikhail Lukyanchenko.

v0.3.0 (Aug 15 2014)

  • support for special-case handling of pure python wheels

  • optional support for report skipped packages in a JUnit-compatible XML

  • Python 3 support

v0.2.1 (Aug 07 2014)

  • fix crash if a build wheel could cannot be found (because pip<=1.5.2 skipped it)

v0.2.0 (Aug 01 2014)

  • support for package blacklisting to never build certain wheels

  • build as many packages as possible. Do not stop if one fails.

v0.1.0 (Aug 01 2014)

  • Initial release

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

devpi-builder-2.0.0.tar.gz (15.8 kB view details)

Uploaded Source

Built Distribution

devpi_builder-2.0.0-py2.py3-none-any.whl (10.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file devpi-builder-2.0.0.tar.gz.

File metadata

File hashes

Hashes for devpi-builder-2.0.0.tar.gz
Algorithm Hash digest
SHA256 8d350c817e7f0a96277d13b6ff762ec7ae2455aa9f8a4690e0940dc85919ce08
MD5 d4a18ce8995acb914cffc981f964cd78
BLAKE2b-256 8dbca2e23a6436a33a3973b14d73f48023dea2c5b925b4d4ba3867c606d6d7d2

See more details on using hashes here.

File details

Details for the file devpi_builder-2.0.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for devpi_builder-2.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 1d1757530dde9b7d320ea2f1e2f05a1b09bf59ef31a2b6a1e0b927235948c863
MD5 2c0e284800590206623a381b6bacb6ed
BLAKE2b-256 c165fe5134e95415be0408760446bf53eef46831a966222f4a1b485fc5ecc4b8

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