Skip to main content

An interactive pip requirements upgrader. It also updates the version in your requirements.txt file.

Project description

pip-upgrader
=========
.. image:: https://travis-ci.org/simion/pip-upgrader.svg?branch=master
:target: https://travis-ci.org/simion/pip-upgrader
.. image:: https://coveralls.io/repos/github/simion/pip-upgrader/badge.svg?branch=master
:target: https://coveralls.io/github/simion/pip-upgrader?branch=master


An interactive pip requirements upgrader. Because upgrading requirements, package by package, is a pain in the ass.
It also updates the version in your requirements.txt file.


Purpose
-------

This cli tools helps you interactively(or not) upgrade packages from requirements file,
and also **update the pinned version from requirements file(s)**.

If no requirements are given, the command **attempts to detect the requirements file(s)** in the current directory.

Quick preview:

.. image:: https://raw.githubusercontent.com/simion/pip-upgrader/master/demo.gif

Installation
------------

::

pip install pip-upgrader

**Note:** this packages installs the following requirements: :code:`'docopt', 'packaging', 'requests', 'terminaltables', 'colorclass'`

To avoid installing all these dependencies in your project, you can install :code:`pip-upgrader` in your system, rather than your virtualenv.
If you install it in your system, and need to upgrade it, run :code:`pip install -U pip-upgrader`

Usage
-----
**Activate your virtualenv** (important, because it will also install the new versions of upgraded packages in current virtualenv)

**CD into your project.**
Then:
::

$ pip-upgrade

Arguments:
::

requirements_file(s) The requirement FILE, or WILDCARD PATH to multiple files. (positional arguments)
--prerelease Include prerelease versions for upgrade, when querying pypi repositories.
-p <package> Pre-choose which packages tp upgrade. Skips any prompt.
--dry-run Simulates the upgrade, but does not execute the actual upgrade.
--skip-package-installation Only upgrade the version in requirements files, don't install the new package.
--skip-virtualenv-check Disable virtualenv check. Allows installing the new packages outside the virtualenv.
--use-default-index Skip searching for custom index-url in pip configuration file(s).

Examples:

::

pip-upgrade # auto discovers requirements file. Prompts for selecting upgrades
pip-upgrade requirements.txt
pip-upgrade requirements/dev.txt requirements/production.txt

# skip prompt and manually choose some/all packages for upgrade
pip-upgrade requirements.txt -p django -p celery
pip-upgrade requirements.txt -p all

# include pre-release versions
pip-upgrade --prerelease

To use ``pip-upgrader`` on install requirements located in a ``setup.py`` file,
try this:

.. code-block:: sh

./setup.py egg_info
pip-upgrade $(./setup.py --name | tr -- - _)*.egg-info/requires.txt

This will display any versions that can be upgraded, and helps you to manually maintain the ``install_requires`` in ``setup.py``.

Final notes
-----------
If you encounter any bugs, please open an issue and it will be magically resolved :)


**Frequently asked questions**

- **Will you support for Pipfile/pipenv?** There's no need for that. You can do `pipenv lock -r > requirements.txt` and check for updates. It depends if you have frozen the versions in Pipfile or not. If they are "*", just run `pipenv lock` and latest versions will be fetched and locked in Pipfile.lock


Have fun! :)

Contributing
------------
Clone the repository, create a virtualenv, then run:
::

pip install -e .[test]
py.test

This command will :

- run tests
- print coverage report
- print pep8 errors

For detailed coverage report, after *py.test* run
::

coverage html && open htmlcov/index.html

**Testing against all python version**
Make sure you have python 2.7, 3.5, 3.6 installed (maybe use pyenv). Then:
::

pip install tox

tox


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

pip_upgrader-1.4.11.tar.gz (5.8 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pip_upgrader-1.4.11-py2.py3-none-any.whl (17.1 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pip_upgrader-1.4.11.tar.gz.

File metadata

  • Download URL: pip_upgrader-1.4.11.tar.gz
  • Upload date:
  • Size: 5.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.3

File hashes

Hashes for pip_upgrader-1.4.11.tar.gz
Algorithm Hash digest
SHA256 4ff7b91d971057e4354cb49f36924909205f3252f8efcc7930980a014f4778f1
MD5 a1a30c75f57e1bf1c89115eb7ca93ddf
BLAKE2b-256 e3fdfd45cebf0178d7d82072aba1785ae783463947aca6e0fb1465626d234ee0

See more details on using hashes here.

File details

Details for the file pip_upgrader-1.4.11-py2.py3-none-any.whl.

File metadata

  • Download URL: pip_upgrader-1.4.11-py2.py3-none-any.whl
  • Upload date:
  • Size: 17.1 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.3

File hashes

Hashes for pip_upgrader-1.4.11-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 5810360b96e0686f9aa25fa4f18bb6497d909353e471e0e7c8fdf2cb5144ec94
MD5 9d4a1ef931638e4976b0dd8fb360c1d2
BLAKE2b-256 04c3c1286a8da3d04209d5365362f8e14160143159247df52f60335b13b64813

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page