Prioritizing pip Features

Problem

The pip development team is small, and has limited time and energy to work on issues reported via the issue tracker. There is also a significant backlog of issues (782 as of November, 2020) for the team to respond to. For the team to prioritize their work based on what will have the most impact, we need to develop a better understanding of what users want from pip.

Skip to recommendations

Research

To help answer this question, we developed a “buy a feature” survey, with the following scenario:

Help us to understand what's important to you by participating in our "buy a feature" game:

You have an allocated budget of $200 to spend on redesigning pip.

With your $200 budget, “buy” the functionality you’d most like to keep.

You don’t have to spend the whole $200, but you should also not overspend your budget!

We asked users to spend their first $100 on features related to pip install, and to spend their remaining $100 on other pip features. We also gave users an additional $10 to suggest a new feature:

survey question where users are asked to buy features for pip install

survey question where users are asked to buy features other than pip install

survey question where users are asked to spend an additional ten dollars

Results

We received 1076 responses, 1070 of which were valid. The most popular features included the core competencies of pip:

  • Recreating an environment from a list of installed dependencies;

  • Install, uninstall, and upgrade packages from a virtual control system, file, or local directory;

  • Warn about broken or conflicting dependencies.

pip install

The top ten features related to pip install were:

pip install results

  1. Install and uninstall packages

  2. Upgrade packages to the latest version

  3. Warn about broken dependencies

  4. Install a package from a version control system (e.g. Git, Mercurial, etc.)

  5. Install packages as specified in a file

  6. Install a package from a local directory

  7. Verify downloaded packages against hashes

  8. Install packages from an alternative package index, or indexes (default is PyPI only)

  9. Install a package from wheels (no need for compiling code)

  10. Control where you want your installed package to live on your computer

Other pip functionality

The top ten features related to other pip functionality were:

other pip functionality results

  1. Generate a list of installed packages that can be used to recreate the environment

  2. Check that your installed packages do not have dependency conflicts

  3. Run pip without requiring any user input (e.g. in CI)

  4. Show information about all installed packages

  5. Show information about a single installed package

  6. Search pypi.org for packages

  7. Show information about pip (version information, help information, etc.)

  8. Download packages, build wheels and keep them in a directory for offline use

  9. Manage pip’s default configuration (e.g. by using configuration files)

  10. Customise pip’s output (e.g. reduce or increase verbosity, suppress colors, send output to a log)

Results varied by the amount of Python experience the user had.

See how likely users are to select a feature based on their experience level

Verify downloaded packages against hashes

screenshot of verify downloaded packages against hashes

Warn about broken dependencies

Screenshot of Warn about broken dependencies

Upgrade packages to the latest version

Screenshot of Upgrade packages to the latest version

Install packages from an alternative package index, or indexes

Screenshot of Install packages from an alternative package index, or indexes

Install packages as specified in a file

Screenshot of Install packages as specified in a file

Install and uninstall packages

Screenshot of Install and uninstall packages

Install packages from a version control system

Screenshot of Install packages from a version control system

Install a package from wheels

Screenshot of Install a package from wheels

Install apackage from a local directory

Screenshot of Install apackage from a local directory

Control where you want your installed package to live on your computer

Screenshot of Control where you want your installed package to live on your computer

Recommendations

Environment recreation

Environment recreation is already included in pip as part of the requirements.txt feature; however, with it’s popularity and demand, we recommend that pip should improve it’s support of this feature.

  • Improve environment recreation user output and help guides directly in the pip CLI;

  • Improve pip documentation & user guide to prominently feature environment recreation as a core feature of pip;

  • Improve environment recreation process itself by considering virtual environments as a core competency “built-in” to pip.

Recreating an environment from a list of installed dependencies was the most valued feature request overall as well as in each user group, except for those with less than 6 months of experience and those with 16-19 years of experience (for which it was the second most valued).

When asked to enter a feature request with freetext, users placed the words ‘built-in,’ ‘virtual,’ ‘automatic,’ and ‘isolation’ alongside the word ‘environment,’ which suggest that users expect pip to recreate environments with a high level of intelligence and usability.

Selected direct quotes

Make pip warn you when you are not in virtualenv

Automatic virtual env creation with a command line argument

Eliminate virtual environments. Just use ./python_modules/ like everyone else

I would love to see pip manage the python version and virtual env similar to the minicona

Would spend all my $200 on this: Integrate pipenv or venv into pip so installing an application doesn’t install it’s dependencies in the system package store. And allow pinning dependency versions for application packages (like how pip-compile does it)

Dependency management

We recommend that the pip team improve warning and error messages related to dependencies (e.g., conflicts) with practical hints for resolution. This can be rolled out in multiple timescales, including:

  • Give hints to the user on how to resolve this issue directly alongside the error message;

  • Prominently include virtual environment creation in the documentation, upon pip install conflict errors, and if possible as a built-in feature of pip;

  • Upgrading the dependency resolver (in progress).

It is clear that dependency management, including warning about conflicting packages and upgrades, is important for pip users. By helping users better manage their dependencies through virtual environments, pip can reduce the overall warnings and conflict messages that users encounter.