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](https://travis-ci.org/blue-yonder/devpi-builder.svg?branch=master)](https://travis-ci.org/blue-yonder/devpi-builder)
[![Coverage Status](https://coveralls.io/repos/blue-yonder/devpi-builder/badge.png?branch=master)](https://coveralls.io/r/blue-yonder/devpi-builder?branch=master)
[![Latest Version](https://pypip.in/version/devpi-builder/badge.svg)](https://pypi-hypernode.com/pypi/devpi-builder/)
[![Requirements Status](https://requires.io/github/blue-yonder/devpi-builder/requirements.png?branch=master)](https://requires.io/github/blue-yonder/devpi-builder/requirements/?branch=master)

Brandon, the devpi-builder, takes a `requirements.txt` and incrementally fills a [devpi](http://doc.devpi.net/latest/) 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]
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.

Features & Backlog
------------------

* [x] Read a `requirements.txt` stile input file.
* [x] Support multiple versions of a package in the same file
* [x] Only build packages not yet in the target index.
* [x] Support a black-list for packages to never be built and uploaded (certain packages like numpy are fragile regarding their interdependency with other packages).
* [ ] Support extras requirements of packages
* [x] Can use separate indices for plain python packages and those with binary contents.
* [x] Can log build results to a JUnit compatible XML file, thus that it can be parsed by Jenkins.


License
-------

[New BSD](https://github.com/blue-yonder/devpi-builder/blob/master/COPYING)


Changelog
=========

v1.0.0
------

- Use [devpi-plumber](https://github.com/blue-yonder/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-1.0.0.tar.gz (14.8 kB view details)

Uploaded Source

Built Distribution

devpi_builder-1.0.0-py2.py3-none-any.whl (10.0 kB view details)

Uploaded Python 2 Python 3

File details

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

File metadata

File hashes

Hashes for devpi-builder-1.0.0.tar.gz
Algorithm Hash digest
SHA256 bb8de8fc7b2ad06e50db1bcd4e5cd2e1ab128c5860916a5100c0d5e969dbc031
MD5 31cf0cec3ca831dd37bc91abfc3094af
BLAKE2b-256 b4c6b2d85326f92b1d95c61f1025ed6c7e74b595666a8bdac7edefb7d0875785

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for devpi_builder-1.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 71e901883eeba5f6dd18738a0505b6310f04562247e1b7ac8be24fabcf113f23
MD5 00933cdb0b4a71862a23921bab55011f
BLAKE2b-256 af9636a81fff754ea03af7fcb6f6e16b708498c2437c028b8a9282cd2dab7f4f

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