UNCLASSIFIED - NO CUI

Skip to content

chore(deps): update all dependencies (major)

renovate requested to merge renovate/major-all into development

This MR contains the following updates:

Package Update Change
ansible (source) major ==2.9.27 -> ==8.4.0
certifi major ==2022.12.7 -> ==2023.7.22
cryptography (changelog) major ==3.3.2 -> ==41.0.3
jmespath major ==0.10.0 -> ==1.0.1
pipenv major ==2022.1.8 -> ==2023.9.8
urllib3 (changelog) major ==1.26.16 -> ==2.0.4

Dependency Lookup Warnings

Warnings were logged while processing this repo. Please check the logs for more information.


Release Notes

ansible/ansible

v2.10.7

Compare Source

v2.10.6

Compare Source

v2.10.5

Compare Source

v2.10.4

Compare Source

v2.10.3

Compare Source

v2.10.2

Compare Source

v2.10.1

Compare Source

v2.10.0

Compare Source

certifi/python-certifi

v2023.7.22

Compare Source

v2023.5.7

Compare Source

pyca/cryptography

v41.0.3

Compare Source

v41.0.2

Compare Source

v41.0.1

Compare Source

v41.0.0

Compare Source

v40.0.2

Compare Source

v40.0.1

Compare Source

v40.0.0

Compare Source

v39.0.2

Compare Source

v39.0.1

Compare Source

v39.0.0

Compare Source

v38.0.4

Compare Source

v38.0.3

Compare Source

v38.0.2

Compare Source

v38.0.1

Compare Source

v38.0.0

Compare Source

v37.0.4

Compare Source

v37.0.3

Compare Source

v37.0.2

Compare Source

v37.0.1

Compare Source

v37.0.0

Compare Source

v36.0.2

Compare Source

v36.0.1

Compare Source

v36.0.0

Compare Source

v35.0.0

Compare Source

v3.4.8

Compare Source

v3.4.7

Compare Source

v3.4.6

Compare Source

v3.4.5

Compare Source

v3.4.4

Compare Source

v3.4.3

Compare Source

v3.4.2

Compare Source

v3.4.1

Compare Source

v3.4

Compare Source

jmespath/jmespath.py

v1.0.1

Compare Source

=====

  • Add support for Python 3.11 (issue #&#8203;285 <https://github.com/jmespath/jmespath.py/issues/285>__)
  • Fix boolean correctness for floats (issue #&#8203;281 <https://github.com/jmespath/jmespath.py/issues/281>__)
  • Fix Python 3.9 warning about random sampling used in parser cache. (issue #&#8203;216 <https://github.com/jmespath/jmespath.py/issues/216>__)
  • Fix Python 3.8 warning for type comparisons (issue #&#8203;210 <https://github.com/jmespath/jmespath.py/issues/268>__)

v1.0.0

Compare Source

=====

  • Drop support for Python versions less than 3.7 (including Python 2). (issue 268 <https://github.com/jmespath/jmespath.py/issues/268>__)
pypa/pipenv

v2023.9.8

Compare Source

=====================

v2023.9.7

Compare Source

=====================

v2023.9.1

Compare Source

v2023.8.28

Compare Source

Bug Fixes

  • Revert change that caused the credentials in source url issue. #​5878
  • Do not treat named requirements as file installs just becacuse a match path exists; better handling of editable keyword for local file installs. Handle additional edge cases in the setup.py ast parser logic for trying to determine local install package name. #​5885

v2023.8.26

Compare Source

Bug Fixes

  • Additional property caching to avoid duplication of sources in the resolver. #​5863
  • Fix recent regressions with local/editable file installs. #​5870
  • Fixes the vcs subdirectory fragments regression; fixes sys_platform markers regression. #​5871
  • Fix regression that caused printing non-printable ascii characters when help was called. #​5872

v2023.8.25

Compare Source

Bug Fixes

  • Fix regression of hash collection when downloading package from private indexes when the hash is not found in the index href url fragment. #​5866

v2023.8.23

Compare Source

Bug Fixes

  • More gracefully handle @​ symbols in vcs URLs to address recent regression with vcs URLs. #​5849

v2023.8.22

Compare Source

Bug Fixes

  • Fix regression with ssh:// vcs URLs introduced in 2023.8.21 whereby ssh vcs URLs are expected to have at least one @ symbol. #​5846

v2023.8.21

Compare Source

Bug Fixes

  • Add back some relevant caching to increase performance after the major refactor released with 2023.8.19 #​5841
  • Fix some edge cases around vcs dependencies without a ref, and older Pipfile/lockfile formats. #​5843

Vendored Libraries

  • Remove unused command line interface for vendored packages. #​5840

v2023.8.20

Compare Source

Bug Fixes

  • Fix the expected output of the version command. #​5838

v2023.8.19

Compare Source

Features & Improvements

  • The --categories option now works with requirements.txt file. #​5722

Bug Fixes

  • Drop requirementslib for managing pip lines and InstallRequirements, bring remaining requirementslib functionality into pipenv. Fixes numerous reports about extras installs with vcs and file installs; format pip lines correctly to not generate deprecation warnings. #​5793

Vendored Libraries

Improved Documentation

  • Added documentation on how to move or rename a project directory #​5129

Removals and Deprecations

  • The --skip-lock flag which was deprecated, has now been removed to unblock modernizing the pipenv resolver code. #​5805

v2023.7.23

Compare Source

Features & Improvements

  • Upgrades pip==23.2 which includes everything from the pip changelog. Drops the "install_compatatability_finder" pip internals patch. #​5808

Bug Fixes

  • Fix issue parsing some Pipfiles with separate packages.<pkg> sections (tomlkit OutOfOrderTableProxy) #​5794
  • Fix all ruff linter warnings #​5807
  • Restore running Resolver in sub-process using the project python by default; maintains ability to run directly by setting PIPENV_RESOLVER_PARENT_PYTHON environment variable to 1 (useful for internal debugging). #​5809
  • Fix error when a Windows path begins with a '' with pythonfinder==2.0.5. #​5812

Vendored Libraries

  • Remove usage of click.secho in some modules. #​5804

2023.7.11 (2023-07-11)

Bug Fixes

  • Invoke the resolver in the same process as pipenv rather than utilizing subprocess. #​5787
  • Fix regression markers being included as None/null in requirements command. #​5788

v2023.7.11

Compare Source

What's Changed

Full Changelog: https://github.com/pypa/pipenv/compare/v2023.7.9...v2023.7.11

v2023.7.9

Compare Source

Bug Fixes

  • Drop the --keep-outdated flag and --selective-upgrade flags that have been deprecated in favor of update/upgrade commands. #​5730
  • Fix regressions in the requirements command related to standard index extras and handling of local file requirements. #​5784

v2023.7.4

Compare Source

Bug Fixes

  • Fixes regression on Pipfile requirements syntax. Ensure default operator is provided to requirement lib to avoid crash. #​5765
  • Ensure hashes included in a generated requirements file are after any markers. #​5777

v2023.7.3

Compare Source

Bug Fixes

  • Fix regression with --system flag usage. #​5773

v2023.7.1

Compare Source

Bug Fixes

  • Patch _get_requests_session method to consider PIP_CLIENT_CERT value when present. #​5746
  • Fix regression in requirements command that was causing package installs after upgrade to requirementslib==3.0.0. #​5755
  • Fix error: invalid command 'egg_info' edge case with requirementslib 3.0.0. It exposed pipenv resolver sometimes was using a different python than expected. #​5760
  • Fix issue in requirementslib 3.0.0 where dependencies defined in pyproject.toml were not being included in the lock file. #​5766

Removals and Deprecations

v2023.6.26

Compare Source

Improved Documentation

v2023.6.18

Compare Source

Bug Fixes

  • Fixes resolver to only consider the default index for packages when a secondary index is not specified. This brings the code into alignment with stated assumptions about index restricted packages behavior of pipenv. #​5737

Removals and Deprecations

  • Deprecation of --skip-lock flag as it bypasses the security benefits of pipenv. Plus it lacks proper deterministic support of installation from multiple package indexes. #​5737

v2023.6.12

Compare Source

Bug Fixes

  • Remove the sys.path modifications and as a result fixes keyring support. #​5719

v2023.6.11

Compare Source

Vendored Libraries

  • Upgrades to pipdeptree==2.8.0 which fixes edge cases of the pipenv graph command. #​5720

v2023.6.2

Compare Source

Improved Documentation

v2023.5.19

Compare Source

Bug Fixes

  • Consider --index argument in update and upgrade commands. #​5692

Vendored Libraries

  • Upgrade pythonfinder==2.0.0 which also brings in pydantic==1.10.7. #​5677

v2023.4.29

Compare Source

Vendored Libraries

  • Vendor in pip==23.1.2 latest. #​5671
  • Vendor in requirementslib==2.3.0 which drops usage of vistir. #​5672

v2023.4.20

Compare Source

Features & Improvements

  • Checks environment variable PIP_TRUSTED_HOSTS when evaluating an index specified at the command line when adding to Pipfile.

    For example, this command line

    PIP_TRUSTED_HOSTS=internal.mycompany.com pipenv install pypkg --index=https://internal.mycompany.com/pypi/simple

    will add the following to the Pipfile:

    [[source]]
    url = 'https://internal.mycompany.com/pypi/simple'
    verify_ssl = false
    name = 'Internalmycompany'
    
    [packages]
    pypkg = {version="*", index="Internalmycompany"}

    This allows users with private indexes to add them to Pipfile initially from command line with correct permissions using environment variable PIP_TRUSTED_HOSTS. #​5572

  • Vendor in the updates, upgrades and fixes provided by pip==23.1. #​5655

  • Replace flake8 and isort with ruff. #ruff

Bug Fixes

  • Fix regression with --skip-lock option with install command. #​5653

Vendored Libraries

  • Vendor in latest python-dotenv==1.0.0 #​5656
  • Vendor in latest available dependencies: attrs==23.1.0 click-didyoumean==0.3.0 click==8.1.3 markupsafe==2.1.2 pipdeptree==2.7.0 shellingham==1.5.0.post1 tomlkit==0.11.7 #​5657
  • Vendor in latest requirementslib==2.2.5 which includes updates for pip 23.1 #​5659

Improved Documentation

  • Made documentation clear about tilde-equals operator for package versions. #​5594

v2023.3.20

Compare Source

No significant changes.

v2023.3.18

Compare Source

Bug Fixes

  • Fix import error in virtualenv utility for creating new environments caused by 2023.3.18 release. #​5636

v2023.2.18

Compare Source

Features & Improvements

  • pipenv now reads the system pip.conf or pip.ini file in order to determine pre-defined indexes to use for package resolution and installation. #​5297
  • Behavior change for pipenv check now checks the default packages group of the lockfile. Specifying --categories to override which categories to check against. Pass --use-installed to get the prior behavior of checking the packages actually installed into the environment. #​5600

Bug Fixes

  • Fix regression with detection of CI env variable being set to something other than a truthy value. #​5554
  • Fix --categories argument inconsistency between requirements command and install/sync by allowing comma separated values or spaces. #​5570
  • Use Nushell overlays when running pipenv shell. #​5603

Vendored Libraries

  • Vendor in the pip==23.0 release. #​5586
  • Vendor in pip==23.0.1 minor pt release. Updates pythonfinder==1.3.2. #​5614

Improved Documentation

  • Make some improvements to the contributing guide. #​5611

v2023.2.4

Compare Source

Bug Fixes

  • Fix overwriting of output in verbose mode #​5530
  • Fix for resolution error when direct url includes an extras. #​5536

Removals and Deprecations

  • Remove pytest-pypi package since it's not used anymore #​5556
  • Remove deprecated --three flag from the CLI. #​5576

v2022.12.19

Compare Source

Bug Fixes

  • Fix for requirementslib hanging during install of remote wheels files. #​5546

v2022.12.17

Compare Source

Bug Fixes

  • virtualenv creation no longer uses --creator=venv by default; introduced two environment variables: PIPENV_VIRTUALENV_CREATOR -- May be specified to instruct virtualenv which --creator= to use. PIPENV_VIRTUALENV_COPIES -- When specified as truthy, instructs virtualenv to not use symlinks. #​5477
  • Fix regression where path is not propagated to the Pipfile.lock. #​5479
  • Solve issue where null markers were getting added to lock file when extras were provided. #​5486
  • Fix: update --outdated raises NonExistentKey with outdated dev packages #​5540

Vendored Libraries

  • Vendor in pip==22.3.1 which is currently the latest version of pip. #​5520
    • Bump version of requirementslib to 2.2.1
    • Bump version of vistir to 0.7.5
    • Bump version of colorama to 0.4.6 #​5522
  • Bump plette version to 0.4.4 #​5539

v2022.11.30

Compare Source

Bug Fixes

  • Fix regression: pipenv does not sync indexes to lockfile. #​5508

v2022.11.25

Compare Source

Bug Fixes

  • Solving issue where pipenv check command has been broken in the published wheel distribution. #​5493

v2022.11.24

Compare Source

Bug Fixes

  • Stop building universal wheels since Python 2 is no longer supported. #​5496

v2022.11.23

Compare Source

Features & Improvements

  • Find nushell activate scripts. #​5470

Vendored Libraries

    • Drop unused code from cerberus
    • Drop unused module wheel #​5467
    • Replace yaspin spinner with rich spinner.
    • Bump vistir version to 0.7.4 #​5468
  • Bump version of requirementslib to 2.2.0 Drop yaspin which is no longer used. Bump vistir to version 0.7.4 Remove parse. Remove termcolor. Remove idna. #​5481

v2022.11.11

Compare Source

Bug Fixes

  • Fix regression of lock generation that caused the keep-outdated behavior to be default. #​5456

v2022.11.5

Compare Source

Bug Fixes

  • Rollback the change in version of colorama due to regressions in core functionality. #​5459

v2022.11.4

Compare Source

Features & Improvements

  • Allow pipenv settings to be explicitly disabled more easily by assigning to the environment variable a falsy value. #​5451

Bug Fixes

  • Provide an install iteration per index when install_search_all_sources is false (default behavior). This fixes regression where install phase was using unexpected index after updating pip==22.3 #​5444

Vendored Libraries

  • Drop tomli, which is not used anymore. Bump attrs version see #​5449. Drop distlib, colorama and platformdirs - use the ones from pip._vendor. #​5450

v2022.10.25

Compare Source

Features & Improvements

  • Add support to export requirements file for a specified set of categories. #​5431

Vendored Libraries

  • Remove appdirs.py in favor of platformdirs. #​5420

Removals and Deprecations

  • Remove usage of vistir.cmdparse in favor of pipenv.cmdparse #​5419

v2022.10.12

Compare Source

Improved Documentation

  • Update pipenv docs for with example for callabale package functions in Pipfile scripts #​5396

v2022.10.11

Compare Source

Bug Fixes

  • Revert decision to change the default isolation level because it caused problems with existing workflows; solution is to recommend users that have issues requiring pre-requisites to pass --extra-pip-args="--no-build-isolation" in their install or sync commands. #​5399

v2022.10.10

Compare Source

Features & Improvements

  • Add ability for callable scripts in Pipfile under [scripts]. Callables can now be added like: <pathed.module>:<func> and can also take arguments. For example: func = {call = "package.module:func('arg1', 'arg2')"} then this can be activated in the shell with pipenv run func #​5294

Bug Fixes

  • Fixes regression from 2022.10.9 where Pipfile with pipenv section began generating new hash, and also fix regression where lock phase did not update the hash value. #​5394

v2022.10.9

Compare Source

Behavior Changes

  • New pipfiles show python_full_version under [requires] if specified. Previously creating a new pipenv project would only specify in the Pipfile the major and minor version, i.e. "python_version = 3.7". Now if you create a new project with a fully named python version it will record both in the Pipfile. So: "python_version = 3.7" and "python_full_version = 3.7.2" #​5345

Relates to dev process changes

  • Silence majority of pytest.mark warnings by registering custom marks. Can view a list of custom marks by running pipenv run pytest --markers

v2022.10.4

Compare Source

Bug Fixes

  • Use --creator=venv when creating virtual environments to avoid issue with sysconfig posix_prefix on some systems. #​5075
  • Prefer to use the lockfile sources if available during the install phase. #​5380

Vendored Libraries

  • Drop vendored six - we no longer depend on this library, as we migrated from pipfile to plette. #​5187

v2022.9.24

Compare Source

Bug Fixes

  • Update requirementslib==2.0.3 to always evaluate the requirement markers fresh (without lru_cache) to fix marker determinism issue. #​4660

v2022.9.21

Compare Source

Bug Fixes

  • Fix regression to install --skip-lock with update to plette. #​5368

v2022.9.20

Compare Source

Behavior Changes

  • Remove usage of pipfile module in favour of Plette. pipfile is not actively maintained anymore. Plette is actively maintained, and has stricter checking of the Pipefile and Pipefile.lock. As a result, Pipefile with unnamed package indices will fail to lock. If a Pipefile was hand crafeted, and the source is anonymous an error will be thrown. The solution is simple, add a name to your index, e.g, replace:

    [[source]]
    url = "https://pypi.acme.com/simple"
    verify_ssl = true

    With:

    [[source]]
    url = "https://pypi.acme.com/simple"
    verify_ssl = true
    name = acmes_private_index  `#&#8203;5339 <https://github.com/pypa/pipenv/issues/5339>`_

Bug Fixes

  • Modernize pipenv path patch with importlib.util to eliminate import of pkg_resources #​5349

Vendored Libraries

  • Remove iso8601 from vendored packages since it was not used. #​5346

v2022.9.8

Compare Source

Features & Improvements

  • It is now possible to supply additional arguments to pip install by supplying --extra-pip-args="<arg1> <arg2>" See the updated documentation Supplying additional arguments to pip for more details. #​5283

Bug Fixes

  • Make editable detection better because not everyone specifies editable entry in the Pipfile for local editable installs. #​4784
  • Add error handling for when the installed package setup.py does not contain valid markers. #​5329
  • Load the dot env earlier so that PIPENV_CUSTOM_VENV_NAME is more useful across projects. #​5334

Vendored Libraries

  • Bump version of shellingham to support nushell. #​5336
  • Bump plette to version v0.3.0 #​5337
  • Bump version of pipdeptree #​5343

Removals and Deprecations

  • Add deprecation warning to the --three flag. Pipenv now uses python3 by default. #​5328

Relates to dev process changes

  • Convert the test runner to use pypiserver as a standalone process for all tests that referencce internal pypi artifacts. General refactoring of some test cases to create more variety in packages selected--preferring lighter weight packages--in existing test cases.

v2022.9.4

Compare Source

Bug Fixes

  • Fix the issue from 2022.9.2 where tarball URL packages were being skipped on batch_install. #​5306

v2022.9.2

Compare Source

Bug Fixes

  • Update requirementslib==2.0.3 to always evaluate the requirement markers fresh (without lru_cache) to fix marker determinism issue. #​4660

v2022.8.31

Compare Source

Features & Improvements

  • Performance optimization to batch_install results in a faster and less CPU intensive pipenv sync or pipenv install experience. #​5301

Bug Fixes

  • pipenv now uses a NamedTemporaryFile for rsolver constraints and drops internal env var PIPENV_PACKAGES. #​4925

Removals and Deprecations

  • Remove no longer used method which_pip. #​5314
  • Drop progress bar file due to recent performance optimization to combine batch_install requirements in at most two invocations of pip install. To see progress of install pass --verbose flag and pip progress will be output in realtime. #​5315

v2022.8.30

Compare Source

Bug Fixes

  • Fix an issue when using pipenv install --system on systems that having the python executable pointing to Python 2 and a Python 3 executable being python3. #​5296
  • Sorting constraints before resolving, which fixes pipenv lock generates nondeterminism environment markers. #​5299
  • Fix #​5273, use our own method for checking if a package is a valid constraint. #​5309

Vendored Libraries

  • Vendor in requirementslib==2.0.1 which fixes issue with local install not marked editable, and vendor in vistir==0.6.1 which drops python2 support. Drops orderedmultidict from vendoring. #​5308

v2022.8.24

Compare Source

Bug Fixes

  • Remove eager and unnecessary importing of setuptools and pkg_resources to avoid conflict upgrading setuptools. Roll back sysconfig patch of pip because it was problematic for some --system commands. #​5228

Vendored Libraries

  • Vendor in requirementslib==2.0.0 and drop pip-shims entirely. #​5228
  • Vendor in pythonfinder==1.3.1 #​5292

v2022.8.19

Compare Source

Bug Fixes

  • Fix issue where resolver is provided with install_requires constraints from setup.py that depend on editable dependencies and could not resolve them. #​5271
  • Fix for pipenv lock fails for packages with extras as of 2022.8.13. #​5274
  • Revert the exclusion of BAD_PACKAGES from batch_install in order for pipenv to install specific versions of setuptools. To prevent issue upgrading setuptools this patches _USE_SYSCONFIG_DEFAULT to use sysconfig for 3.7 and above whereas pip default behavior was 3.10 and above. #​5275

v2022.8.17

Compare Source

Bug Fixes

  • Fix "The Python interpreter can't be found" error when running pipenv install --system with a python3 but no python. #​5261
  • Revise pip import patch to include only pipenv from site-packages and removed --ignore-installed argument from pip install in order to fix regressions with --use-site-packages. #​5265

v2022.8.15

Compare Source

Bug Fixes

  • pip_install method was using a different way of finding the python executable than other pipenv commands, which caused an issue with skipping package installation if it was already installed in site-packages. #​5254

v2022.8.14

Compare Source

Bug Fixes

  • Removed packaging library from BAD_PACKAGES constant to allow it to be installed, which fixes regression from pipenv==2022.8.13. #​5247

v2022.8.13

Compare Source

Bug Fixes

  • If environment variable CI or TF_BUILD is set but does not evaluate to False it is now treated as True. #​5128
  • Fix auto-complete crashing on 'install' and 'uninstall' keywords #​5214
  • Address remaining pipenv commands that were still referencing the user or system installed pip to use the vendored pip internal to pipenv. #​5229
  • Use packages as constraints when locking dev-packages in Pipfile. Use packages as constraints when installing new dev-packages. #​5234

Vendored Libraries

  • Vendor in minor pip update 22.2.2 #​5230

Improved Documentation

  • Add documentation for environment variables the configure pipenv. #​5235

Removals and Deprecations

  • The deprecated way of generating requirements install -r or lock -r has been removed in favor of the pipenv requirements command. #​5200

v2022.8.5

Compare Source

Features & Improvements

  • support PIPENV_CUSTOM_VENV_NAME to be the venv name if specified, update relevant docs. #​4974

Bug Fixes

  • Remove usages of pip_shims from the non vendored pipenv code, but retain initialization for requirementslib still has usages. #​5204
  • Fix case sensitivity of color name red in exception when getting hashes from pypi in _get_hashes_from_pypi. #​5206
  • Write output from subprocess_run directly to stdout instead of creating temporary file. Remove deprecated distutils.sysconfig, use sysconfig. #​5210

Vendored Libraries

    • Rename patched notpip to pip in order to be clear that its a patched version of pip.
    • Remove the part of _post_pip_import.patch that overrode the standalone pip to be the user installed pip, now we fully rely on our vendored and patched pip, even for all types of installs.
    • Vendor in the next newest version of pip==22.2
    • Modify patch for pipdeptree to not use pip-shims #​5188
    • Remove vendored urllib3 in favor of using it from vendored version in pip._vendor #​5215

Removals and Deprecations

  • Remove tests that have been for a while been marked skipped and are no longer relevant. #​5165

v2022.7.24

Compare Source

Bug Fixes

  • Re-enabled three installs tests again on the Windows CI as recent refactor work has fixed them. #​5064
  • Support ANSI NO_COLOR environment variable and deprecate PIPENV_COLORBLIND variable, which will be removed after this release. #​5158
  • Fixed edge case where a non-editable file, url or vcs would overwrite the value no_deps for all other requirements in the loop causing a retry condition. #​5164
  • Vendor in latest requirementslib for fix to lock when using editable VCS module with specific @ git reference. #​5179

Vendored Libraries

  • Remove crayons and replace with click.secho and click.styles per #​3741 #​3741
  • Vendor in latest version of pip==22.1.2 which upgrades pipenv from pip==22.0.4. Vendor in latest version of requirementslib==1.6.7 which includes a fix for tracebacks on encountering Annotated variables. Vendor in latest version of pip-shims==0.7.3 such that imports could be rewritten to utilize packaging from vendor'd pip. Drop the packaging requirement from the vendor directory in pipenv. #​5147
  • Remove unused vendored dependency normailze-charset. #​5161
  • Remove obsolete package funcsigs. #​5168
  • Bump vendored dependency pyparsing==3.0.9. #​5170

v2022.7.4

Compare Source

Behavior Changes

  • Adjust pipenv requirements to add markers and add an --exclude-markers option to allow the exclusion of markers. #​5092

Bug Fixes

  • Stopped expanding environment variables when using pipenv requirements #​5134

Vendored Libraries

  • Depend on requests and certifi from vendored pip and remove them as explicit vendor dependencies. #​5000
  • Vendor in the latest version of requirementslib==1.6.5 which includes bug fixes for beta python versions, projects with an at sign (@​) in the path, and a setuptools deprecation warning. #​5132

Relates to dev process changes

  • Switch from using type comments to type annotations.

v2022.6.7

Compare Source

What's Changed

Full Changelog: https://github.com/pypa/pipenv/compare/v2022.5.2...v2022.6.7

v2022.5.2

Compare Source

Bug Fixes

  • Fixes issue of pipenv lock -r command printing to stdout instead of stderr. #​5091

v2022.4.30

Compare Source

Bug Fixes

  • Fixes issue of requirements command problem by modifying to print -e and path of the editable package. #​5070
  • Revert specifier of setuptools requirement in setup.py back to what it was in order to fix FileNotFoundError: [Errno 2] issue report. #​5075
  • Fixes issue of requirements command where git requirements cause the command to fail, solved by using existing convert_deps_to_pip function. #​5076

Vendored Libraries

  • Vendor in requirementslib==1.6.4 to Fix SetuptoolsDeprecationWarning setuptools.config.read_configuration became deprecated. #​5081

Removals and Deprecations

  • Remove more usage of misc functions of vistir. Many of this function are available in the STL or in another dependency of pipenv. #​5078

v2022.4.21

Compare Source

Removals and Deprecations

  • Updated setup.py to remove support for python 3.6 from built pipenv packages' Metadata. #​5065

v2022.4.20

Compare Source

Features & Improvements

  • Added new Pipenv option install_search_all_sources that allows installation of packages from an existing Pipfile.lock to search all defined indexes for the constrained package version and hash signatures. #​5041

Bug Fixes

  • allow the user to disable the no_input flag, so the use of e.g Google Artifact Registry is possible. #​4706
  • Fixes case where packages could fail to install and the exit code was successful. #​5031

Vendored Libraries

  • Updated vendor version of pip from 21.2.2 to 22.0.4 which fixes a number of bugs including several reports of pipenv locking for an infinite amount of time when using certain package constraints. This also drops support for python 3.6 as it is EOL and support was removed in pip 22.x #​4995

Removals and Deprecations

  • Removed the vendor dependency more-itertools as it was originally added for zipp, which since stopped using it. #​5044
  • Removed all usages of pipenv.vendor.vistir.compat.fs_str, since this function was used for PY2-PY3 compatibility and is no longer needed. #​5062

Relates to dev process changes

  • Added pytest-cov and basic configuration to the project for generating html testing coverage reports.
  • Make all CI jobs run only after the lint stage. Also added a makefile target for vendoring the packages.

v2022.4.8

Compare Source

Features & Improvements

  • Implements a pipenv requirements command which generates a requirements.txt compatible output without locking. #​4959
  • Internal to pipenv, the utils.py was split into a utils module with unused code removed. #​4992

Bug Fixes

  • Pipenv will now ignore .venv in the project when PIPENV_VENV_IN_MROJECT variable is False. Unset variable maintains the existing behavior of preferring to use the project's .venv should it exist. #​2763
  • Fix an edge case of hash collection in index restricted packages whereby the hashes for some packages would be missing from the Pipfile.lock following package index restrictions added in pipenv==2022.3.23. #​5023

Improved Documentation

  • Pipenv CLI documentation generation has been fixed. It had broke when click was vendored into the project in 2021.11.9 because by default sphinx-click could no longer determine the CLI inherited from click. #​4778
  • Improve documentation around extra indexes and index restricted packages. #​5022

Removals and Deprecations

  • Removes the optional install argument --extra-index-url as it was not compatible with index restricted packages. Using the --index argument is the correct way to specify a package should be pulled from the non-default index. #​5022

Relates to dev process changes

  • Added code linting using pre-commit-hooks, black, flake8, isort, pygrep-hooks, news-fragments and check-manifest. Very similar to pip's configuration; adds a towncrier new's type process for change to Development processes.

v2022.3.28

Compare Source

Bug Fixes

  • Environment variables were not being loaded when the --quiet flag was set #​5010
  • It would appear that requirementslib was not fully specifying the subdirectory to build_pep517 and and when a new version of setuptools was released, the test test_lock_nested_vcs_direct_url broke indicating the Pipfile.lock no longer contained the extra dependencies that should have been resolved. This regression affected pipenv>=2021.11.9 but has been fixed by a patch to requirementslib. #​5019

Vendored Libraries

  • Vendor in pip==21.2.4 (from 21.2.2) in order to bring in requested bug fix for python3.6. Note: support for 3.6 will be dropped in a subsequent release. #​5008

v2022.3.24

Compare Source

Features & Improvements

  • It is now possible to silence the Loading .env environment variables message on pipenv run with the --quiet flag or the PIPENV_QUIET environment variable. #​4027

Bug Fixes

  • Fixes issue with new index safety restriction, whereby an unnamed extra sources index caused and error to be thrown during install. #​5002
  • The text Loading .env environment variables... has been switched back to stderr as to not break requirements.txt generation. Also it only prints now when a .env file is actually present. #​5003

v2022.3.23

Compare Source

Features & Improvements

  • Use environment variable PIPENV_SKIP_LOCK to control the behaviour of lock skipping. #​4797
  • New CLI command verify, checks the Pipfile.lock is up-to-date #​4893

Behavior Changes

  • Pattern expansion for arguments was disabled on Windows. #​4935

Bug Fixes

  • Python versions on Windows can now be installed automatically through pyenv-win #​4525
  • Patched our vendored Pip to fix: Pipenv Lock (Or Install) Does Not Respect Index Specified For A Package. #​4637
  • If PIP_TARGET is set to environment variables, Refer specified directory for calculate delta, instead default directory #​4775
  • Remove remaining mention of python2 and --two flag from codebase. #​4938
  • Use CI environment value, over mere existence of name #​4944
  • Environment variables from dot env files are now properly expanded when included in scripts. #​4975

Vendored Libraries

  • Updated vendor version of pythonfinder from 1.2.9 to 1.2.10 which fixes a bug with WSL (Windows Subsystem for Linux) when a path can not be read and Permission Denied error is encountered. #​4976

Removals and Deprecations

  • Removes long broken argument --code from install and --unused from check. Check command no longer takes in arguments to ignore. Removed the vendored dependencies: pipreqs and yarg #​4998
urllib3/urllib3

v2.0.4

Compare Source

==================

  • Added support for union operators to HTTPHeaderDict (#&#8203;2254 <https://github.com/urllib3/urllib3/issues/2254>__)
  • Added BaseHTTMResponse to urllib3.__all__ (#&#8203;3078 <https://github.com/urllib3/urllib3/issues/3078>__)
  • Fixed urllib3.connection.HTTPConnection to raise the http.client.connect audit event to have the same behavior as the standard library HTTP client (#&#8203;2757 <https://github.com/urllib3/urllib3/issues/2757>__)
  • Relied on the standard library for checking hostnames in supported PyPy releases (#&#8203;3087 <https://github.com/urllib3/urllib3/issues/3087>__)

v2.0.3

Compare Source

==================

  • Allowed alternative SSL libraries such as LibreSSL, while still issuing a warning as we cannot help users facing issues with implementations other than OpenSSL. (#&#8203;3020 <https://github.com/urllib3/urllib3/issues/3020>__)
  • Deprecated URLs which don't have an explicit scheme (#&#8203;2950 <https://github.com/urllib3/urllib3/pull/2950>_)
  • Fixed response decoding with Zstandard when compressed data is made of several frames. (#&#8203;3008 <https://github.com/urllib3/urllib3/issues/3008>__)
  • Fixed assert_hostname=False to correctly skip hostname check. (#&#8203;3051 <https://github.com/urllib3/urllib3/issues/3051>__)

v2.0.2

Compare Source

==================

  • Fixed HTTMResponse.stream() to continue yielding bytes if buffered decompressed data was still available to be read even if the underlying socket is closed. This prevents a compressed response from being truncated. (#&#8203;3009 <https://github.com/urllib3/urllib3/issues/3009>__)

v2.0.1

Compare Source

==================

  • Fixed a socket leak when fingerprint or hostname verifications fail. (#&#8203;2991 <https://github.com/urllib3/urllib3/issues/2991>__)
  • Fixed an error when HTTMResponse.read(0) was the first read call or when the internal response body buffer was otherwise empty. (#&#8203;2998 <https://github.com/urllib3/urllib3/issues/2998>__)

v2.0.0

Compare Source

==================

Read the v2.0 migration guide <https://urllib3.readthedocs.io/en/latest/v2-migration-guide.html>__ for help upgrading to the latest version of urllib3.

Removed

  • Removed support for Python 2.7, 3.5, and 3.6 (#&#8203;883 <https://github.com/urllib3/urllib3/issues/883>**, #&#8203;2336 <https://github.com/urllib3/urllib3/issues/2336>**).
  • Removed fallback on certificate commonName in match_hostname() function. This behavior was deprecated in May 2000 in RFC 2818. Instead only subjectAltName is used to verify the hostname by default. To enable verifying the hostname against commonName use SSLContext.hostname_checks_common_name = True (#&#8203;2113 <https://github.com/urllib3/urllib3/issues/2113>__).
  • Removed support for Python with an ssl module compiled with LibreSSL, CiscoSSL, wolfSSL, and all other OpenSSL alternatives. Python is moving to require OpenSSL with PEP 644 (#&#8203;2168 <https://github.com/urllib3/urllib3/issues/2168>__).
  • Removed support for OpenSSL versions earlier than 1.1.1 or that don't have SNI support. When an incompatible OpenSSL version is detected an ImportError is raised (#&#8203;2168 <https://github.com/urllib3/urllib3/issues/2168>__).
  • Removed the list of default ciphers for OpenSSL 1.1.1+ and SecureTransport as their own defaults are already secure (#&#8203;2082 <https://github.com/urllib3/urllib3/issues/2082>__).
  • Removed urllib3.contrib.appengine.AppEngineManager and support for Google App Engine Standard Environment (#&#8203;2044 <https://github.com/urllib3/urllib3/issues/2044>__).
  • Removed deprecated Retry options method_whitelist, DEFAULT_REDIRECT_HEADERS_BLACKLIST (#&#8203;2086 <https://github.com/urllib3/urllib3/issues/2086>__).
  • Removed urllib3.HTTMResponse.from_httplib (#&#8203;2648 <https://github.com/urllib3/urllib3/issues/2648>__).
  • Removed default value of None for the request_context parameter of urllib3.PoolManager.connection_from_pool_key. This change should have no effect on users as the default value of None was an invalid option and was never used (#&#8203;1897 <https://github.com/urllib3/urllib3/issues/1897>__).
  • Removed the urllib3.request module. urllib3.request.RequestMethods has been made a private API. This change was made to ensure that from urllib3 import request imported the top-level request() function instead of the urllib3.request module (#&#8203;2269 <https://github.com/urllib3/urllib3/issues/2269>__).
  • Removed support for SSLv3.0 from the urllib3.contrib.pyopenssl even when support is available from the compiled OpenSSL library (#&#8203;2233 <https://github.com/urllib3/urllib3/issues/2233>__).
  • Removed the deprecated urllib3.contrib.ntlmpool module (#&#8203;2339 <https://github.com/urllib3/urllib3/issues/2339>__).
  • Removed DEFAULT_CIPHERS, HAS_SNI, USE_DEFAULT_SSLCONTEXT_CIPHERS, from the private module urllib3.util.ssl_ (#&#8203;2168 <https://github.com/urllib3/urllib3/issues/2168>__).
  • Removed urllib3.exceptions.SNIMissingWarning (#&#8203;2168 <https://github.com/urllib3/urllib3/issues/2168>__).
  • Removed the _prepare_conn method from HTTPConnectionPool. Previously this was only used to call HTTPSConnection.set_cert() by HTTPSConnectionPool (#&#8203;1985 <https://github.com/urllib3/urllib3/issues/1985>__).
  • Removed tls_in_tls_required property from HTTPSConnection. This is now determined from the scheme parameter in HTTPConnection.set_tunnel() (#&#8203;1985 <https://github.com/urllib3/urllib3/issues/1985>__).
  • Removed the strict parameter/attribute from HTTPConnection, HTTPSConnection, HTTPConnectionPool, HTTPSConnectionPool, and HTTMResponse (#&#8203;2064 <https://github.com/urllib3/urllib3/issues/2064>__).

Deprecated

  • Deprecated HTTMResponse.getheaders() and HTTMResponse.getheader() which will be removed in urllib3 v2.1.0. Instead use HTTMResponse.headers and HTTMResponse.headers.get(name, default). (#&#8203;1543 <https://github.com/urllib3/urllib3/issues/1543>**, #&#8203;2814 <https://github.com/urllib3/urllib3/issues/2814>**).
  • Deprecated urllib3.contrib.pyopenssl module which will be removed in urllib3 v2.1.0 (#&#8203;2691 <https://github.com/urllib3/urllib3/issues/2691>__).
  • Deprecated urllib3.contrib.securetransport module which will be removed in urllib3 v2.1.0 (#&#8203;2692 <https://github.com/urllib3/urllib3/issues/2692>__).
  • Deprecated ssl_version option in favor of ssl_minimum_version. ssl_version will be removed in urllib3 v2.1.0 (#&#8203;2110 <https://github.com/urllib3/urllib3/issues/2110>__).
  • Deprecated the strict parameter of PoolManager.connection_from_context() as it's not longer needed in Python 3.x. It will be removed in urllib3 v2.1.0 (#&#8203;2267 <https://github.com/urllib3/urllib3/issues/2267>__)
  • Deprecated the NewConnectionError.pool attribute which will be removed in urllib3 v2.1.0 (#&#8203;2271 <https://github.com/urllib3/urllib3/issues/2271>__).
  • Deprecated format_header_param_html5 and format_header_param in favor of format_multipart_header_param (#&#8203;2257 <https://github.com/urllib3/urllib3/issues/2257>__).
  • Deprecated RequestField.header_formatter parameter which will be removed in urllib3 v2.1.0 (#&#8203;2257 <https://github.com/urllib3/urllib3/issues/2257>__).
  • Deprecated HTTPSConnection.set_cert() method. Instead pass parameters to the HTTPSConnection constructor (#&#8203;1985 <https://github.com/urllib3/urllib3/issues/1985>__).
  • Deprecated HTTPConnection.request_chunked() method which will be removed in urllib3 v2.1.0. Instead pass chunked=True to HTTPConnection.request() (#&#8203;1985 <https://github.com/urllib3/urllib3/issues/1985>__).

Added

  • Added top-level urllib3.request function which uses a preconfigured module-global PoolManager instance (#&#8203;2150 <https://github.com/urllib3/urllib3/issues/2150>__).
  • Added the json parameter to urllib3.request(), PoolManager.request(), and ConnectionPool.request() methods to send JSON bodies in requests. Using this parameter will set the header Content-Type: application/json if Content-Type isn't already defined. Added support for parsing JSON response bodies with HTTMResponse.json() method (#&#8203;2243 <https://github.com/urllib3/urllib3/issues/2243>__).
  • Added type hints to the urllib3 module (#&#8203;1897 <https://github.com/urllib3/urllib3/issues/1897>__).
  • Added ssl_minimum_version and ssl_maximum_version options which set SSLContext.minimum_version and SSLContext.maximum_version (#&#8203;2110 <https://github.com/urllib3/urllib3/issues/2110>__).
  • Added support for Zstandard (RFC 8878) when zstandard 1.18.0 or later is installed. Added the zstd extra which installs the zstandard package (#&#8203;1992 <https://github.com/urllib3/urllib3/issues/1992>__).
  • Added urllib3.response.BaseHTTMResponse class. All future response classes will be subclasses of BaseHTTMResponse (#&#8203;2083 <https://github.com/urllib3/urllib3/issues/2083>__).
  • Added FullPoolError which is raised when PoolManager(block=True) and a connection is returned to a full pool (#&#8203;2197 <https://github.com/urllib3/urllib3/issues/2197>__).
  • Added HTTPHeaderDict to the top-level urllib3 namespace (#&#8203;2216 <https://github.com/urllib3/urllib3/issues/2216>__).
  • Added support for configuring header merging behavior with HTTPHeaderDict When using a HTTPHeaderDict to provide headers for a request, by default duplicate header values will be repeated. But if combine=True is passed into a call to HTTPHeaderDict.add, then the added header value will be merged in with an existing value into a comma-separated list (X-My-Header: foo, bar) (#&#8203;2242 <https://github.com/urllib3/urllib3/issues/2242>__).
  • Added NameResolutionError exception when a DNS error occurs (#&#8203;2305 <https://github.com/urllib3/urllib3/issues/2305>__).
  • Added proxy_assert_hostname and proxy_assert_fingerprint kwargs to ProxyManager (#&#8203;2409 <https://github.com/urllib3/urllib3/issues/2409>__).
  • Added a configurable backoff_max parameter to the Retry class. If a custom backoff_max is provided to the Retry class, it will replace the Retry.DEFAULT_BACKOFF_MAX (#&#8203;2494 <https://github.com/urllib3/urllib3/issues/2494>__).
  • Added the authority property to the Url class as per RFC 3986 3.2. This property should be used in place of netloc for users who want to include the userinfo (auth) component of the URI (#&#8203;2520 <https://github.com/urllib3/urllib3/issues/2520>__).
  • Added the scheme parameter to HTTPConnection.set_tunnel to configure the scheme of the origin being tunnelled to (#&#8203;1985 <https://github.com/urllib3/urllib3/issues/1985>__).
  • Added the is_closed, is_connected and has_connected_to_proxy properties to HTTPConnection (#&#8203;1985 <https://github.com/urllib3/urllib3/issues/1985>__).
  • Added optional backoff_jitter parameter to Retry. (#&#8203;2952 <https://github.com/urllib3/urllib3/issues/2952>__)

Changed

  • Changed urllib3.response.HTTMResponse.read to respect the semantics of io.BufferedIOBase regardless of compression. Specifically, this method:

    • Only returns an empty bytes object to indicate EOF (that is, the response has been fully consumed).
    • Never returns more bytes than requested.
    • Can issue any number of system calls: zero, one or multiple.

    If you want each urllib3.response.HTTMResponse.read call to issue a single system call, you need to disable decompression by setting decode_content=False (#&#8203;2128 <https://github.com/urllib3/urllib3/issues/2128>__).

  • Changed urllib3.HTTPConnection.getresponse to return an instance of urllib3.HTTMResponse instead of http.client.HTTMResponse (#&#8203;2648 <https://github.com/urllib3/urllib3/issues/2648>__).

  • Changed ssl_version to instead set the corresponding SSLContext.minimum_version and SSLContext.maximum_version values. Regardless of ssl_version passed SSLContext objects are now constructed using ssl.MROTOCOL_TLS_CLIENT (#&#8203;2110 <https://github.com/urllib3/urllib3/issues/2110>__).

  • Changed default SSLContext.minimum_version to be TLSVersion.TLSv1_2 in line with Python 3.10 (#&#8203;2373 <https://github.com/urllib3/urllib3/issues/2373>__).

  • Changed ProxyError to wrap any connection error (timeout, TLS, DNS) that occurs when connecting to the proxy (#&#8203;2482 <https://github.com/urllib3/urllib3/pull/2482>__).

  • Changed urllib3.util.create_urllib3_context to not override the system cipher suites with a default value. The new default will be cipher suites configured by the operating system (#&#8203;2168 <https://github.com/urllib3/urllib3/issues/2168>__).

  • Changed multipart/form-data header parameter formatting matches the WHATWG HTML Standard as of 2021-06-10. Control characters in filenames are no longer percent encoded (#&#8203;2257 <https://github.com/urllib3/urllib3/issues/2257>__).

  • Changed the error raised when connecting via HTTPS when the ssl module isn't available from SSLError to ImportError (#&#8203;2589 <https://github.com/urllib3/urllib3/issues/2589>__).

  • Changed HTTPConnection.request() to always use lowercase chunk boundaries when sending requests with Transfer-Encoding: chunked (#&#8203;2515 <https://github.com/urllib3/urllib3/issues/2515>__).

  • Changed enforce_content_length default to True, preventing silent data loss when reading streamed responses (#&#8203;2514 <https://github.com/urllib3/urllib3/issues/2514>__).

  • Changed internal implementation of HTTPHeaderDict to use dict instead of collections.OrderedDict for better performance (#&#8203;2080 <https://github.com/urllib3/urllib3/issues/2080>__).

  • Changed the urllib3.contrib.pyopenssl module to wrap OpenSSL.SSL.Error with ssl.SSLError in PyOpenSSLContext.load_cert_chain (#&#8203;2628 <https://github.com/urllib3/urllib3/issues/2628>__).

  • Changed usage of the deprecated socket.error to OSError (#&#8203;2120 <https://github.com/urllib3/urllib3/issues/2120>__).

  • Changed all parameters in the HTTPConnection and HTTPSConnection constructors to be keyword-only except host and port (#&#8203;1985 <https://github.com/urllib3/urllib3/issues/1985>__).

  • Changed HTTPConnection.getresponse() to set the socket timeout from HTTPConnection.timeout value before reading data from the socket. This previously was done manually by the HTTPConnectionPool calling HTTPConnection.sock.settimeout(...) (#&#8203;1985 <https://github.com/urllib3/urllib3/issues/1985>__).

  • Changed the _proxy_host property to _tunnel_host in HTTPConnectionPool to more closely match how the property is used (value in HTTPConnection.set_tunnel()) (#&#8203;1985 <https://github.com/urllib3/urllib3/issues/1985>__).

  • Changed name of Retry.BACK0FF_MAX to be Retry.DEFAULT_BACKOFF_MAX.

  • Changed TLS handshakes to use SSLContext.check_hostname when possible (#&#8203;2452 <https://github.com/urllib3/urllib3/pull/2452>__).

  • Changed server_hostname to behave like other parameters only used by HTTPSConnectionPool (#&#8203;2537 <https://github.com/urllib3/urllib3/pull/2537>__).

  • Changed the default blocksize to 16KB to match OpenSSL's default read amounts (#&#8203;2348 <https://github.com/urllib3/urllib3/pull/2348>__).

  • Changed HTTMResponse.read() to raise an error when calling with decode_content=False after using decode_content=True to prevent data loss (#&#8203;2800 <https://github.com/urllib3/urllib3/issues/2800>__).

Fixed

  • Fixed thread-safety issue where accessing a PoolManager with many distinct origins would cause connection pools to be closed while requests are in progress (#&#8203;1252 <https://github.com/urllib3/urllib3/issues/1252>__).
  • Fixed an issue where an HTTPConnection instance would erroneously reuse the socket read timeout value from reading the previous response instead of a newly configured connect timeout. Instead now if HTTPConnection.timeout is updated before sending the next request the new timeout value will be used (#&#8203;2645 <https://github.com/urllib3/urllib3/issues/2645>__).
  • Fixed socket.error.errno when raised from pyOpenSSL's OpenSSL.SSL.SysCallError (#&#8203;2118 <https://github.com/urllib3/urllib3/issues/2118>__).
  • Fixed the default value of HTTPSConnection.socket_options to match HTTPConnection (#&#8203;2213 <https://github.com/urllib3/urllib3/issues/2213>__).
  • Fixed a bug where headers would be modified by the remove_headers_on_redirect feature (#&#8203;2272 <https://github.com/urllib3/urllib3/issues/2272>__).
  • Fixed a reference cycle bug in urllib3.util.connection.create_connection() (#&#8203;2277 <https://github.com/urllib3/urllib3/issues/2277>__).
  • Fixed a socket leak if HTTPConnection.connect() fails (#&#8203;2571 <https://github.com/urllib3/urllib3/pull/2571>__).
  • Fixed urllib3.contrib.pyopenssl.WrappedSocket and urllib3.contrib.securetransport.WrappedSocket close methods (#&#8203;2970 <https://github.com/urllib3/urllib3/issues/2970>__)

Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever MR becomes conflicted, or you tick the rebase/retry checkbox.

👻 Immortal: This MR will be recreated if closed unmerged. Get config help if that's undesired.


  • If you want to rebase/retry this MR, check this box

This MR has been generated by Renovate Bot.

Merge request reports