Manages pip requirements files for multiple environments, e.g. production and development
Project description
pipwrap simplifies handling Python project requirements across multiple environments. pip freeze > requirements.txt gets your project started, but do you really want mock, coverage, etc. installed on your production server? If you’ve ever found yourself sifting through the output of pip freeze trying to figure out what packages you’ve installed but didn’t yet add to one of your requirements files, then pipwrap is the tool for you.
Features
Create or update requirements files based on installed packages
Remove stray packages in virtualenv
List discrepancies between installed packages and requirements files
Installation
You can get pipwrap from PyPI with:
pip install pipwrap
The development version can be installed with:
pip install -e git://github.com/jessamynsmith/pipwrap.git#egg=pipwrap
If you are developing locally, your version can be installed from the working directory with:
python setup.py.install
Usage
Note: You may ignore warnings about “Recursive requirements not supported.” These are due to current limitations of the requirements-parser library.
Getting Started with pipwrap
(Optional) Create requirements files with a list of your packages
Interactively populate requirements files from currently installed packages:
pipwrap -r
Create a top-level requirements.txt file that points to your production requirements, e.g. “-r production.txt”
Keeping requirements up to date with pipwrap
Interactively update requirements files from currently installed packages:
pipwrap -r # Adds packages in virtualenv
pipwrap -rc # Adds packages in virtualenv and removes packages not in virtualenv
Remove stray packages in virtualenv:
pipwrap -x
See discrepancies between installed packages and requirements files:
pipwrap -l
NOTE: This last option can be used to determine what the other options would do. Any packages in the “Packages installed but not present in requirements” section would be uninstalled with the -x option or added to requirements with the -r option. Any packages in the “Packages present in requirements but not installed” section would be removed from the requirements files with the -rc option.
Development
Fork the project on github and git clone your fork, e.g.:
git clone https://github.com/<username>/pipwrap.git
Create a virtualenv and install dependencies:
mkvirtualenv pipwrap pip install -r requirements/package.txt -r requirements/test.txt
Run tests with coverage (should be 100%) and check code style:
coverage run -m nose coverage report -m flake8
Verify all supported Python versions:
pip install tox tox
Install your local copy:
python setup.py.install
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
File details
Details for the file pipwrap-0.2.1.tar.gz
.
File metadata
- Download URL: pipwrap-0.2.1.tar.gz
- Upload date:
- Size: 7.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 89d0cda6e92f3b74d483bebc72322c13d37906f293f3f30869b930542647eb70 |
|
MD5 | 82a0a2aa1ff0c002ad642c930d2a3903 |
|
BLAKE2b-256 | da2ab14d9fdf352c1767f71738bd7277f94fa20c9c6b009b88ed541ac2b615f2 |