From ba0ab7f771f508a52865ba5598c87588de4ca8c5 Mon Sep 17 00:00:00 2001 From: Bernat Gabor Date: Sat, 4 Apr 2020 09:15:26 +0100 Subject: [PATCH] Support wheels without python-requires tag Signed-off-by: Bernat Gabor --- docs/changelog/1757.bugfix.rst | 2 ++ src/virtualenv/seed/embed/wheels/acquire.py | 4 +++- tests/unit/config/test_env_var.py | 2 +- tests/unit/seed/embed/wheels/test_acquire.py | 11 +++++++++++ 4 files changed, 17 insertions(+), 2 deletions(-) create mode 100644 docs/changelog/1757.bugfix.rst create mode 100644 tests/unit/seed/embed/wheels/test_acquire.py diff --git a/docs/changelog/1757.bugfix.rst b/docs/changelog/1757.bugfix.rst new file mode 100644 index 000000000..822322edc --- /dev/null +++ b/docs/changelog/1757.bugfix.rst @@ -0,0 +1,2 @@ +Allow seed wheel files inside the :option:`extra-search-dir` folders that do not have ``Requires-Python`` +metadata specified, these are considered compatible with all python versions - by :user:`gaborbernat`. diff --git a/src/virtualenv/seed/embed/wheels/acquire.py b/src/virtualenv/seed/embed/wheels/acquire.py index dd25acccd..7f8730237 100644 --- a/src/virtualenv/seed/embed/wheels/acquire.py +++ b/src/virtualenv/seed/embed/wheels/acquire.py @@ -87,7 +87,9 @@ def wheel_support_py(filename, py_version): with ZipFile(ensure_text(str(filename)), "r") as zip_file: metadata = zip_file.read(name).decode("utf-8") marker = "Requires-Python:" - requires = next(i[len(marker) :] for i in metadata.splitlines() if i.startswith(marker)) + requires = next((i[len(marker) :] for i in metadata.splitlines() if i.startswith(marker)), None) + if requires is None: # if it does not specify a python requires the assumption is compatible + return True py_version_int = tuple(int(i) for i in py_version.split(".")) for require in (i.strip() for i in requires.split(",")): # https://www.python.org/dev/peps/pep-0345/#version-specifiers diff --git a/tests/unit/config/test_env_var.py b/tests/unit/config/test_env_var.py index d104ba61c..35d084ceb 100644 --- a/tests/unit/config/test_env_var.py +++ b/tests/unit/config/test_env_var.py @@ -37,7 +37,7 @@ def test_value_bad(monkeypatch, caplog, empty_conf): assert "invalid literal" in caplog.messages[0] -def test_extra_search_dir(tmp_path, monkeypatch): +def test_extra_search_dir_via_env_var(tmp_path, monkeypatch): monkeypatch.chdir(tmp_path) value = "a{}0{}b{}c".format(os.linesep, os.linesep, os.pathsep) monkeypatch.setenv(str("VIRTUALENV_EXTRA_SEARCH_DIR"), str(value)) diff --git a/tests/unit/seed/embed/wheels/test_acquire.py b/tests/unit/seed/embed/wheels/test_acquire.py new file mode 100644 index 000000000..49f743336 --- /dev/null +++ b/tests/unit/seed/embed/wheels/test_acquire.py @@ -0,0 +1,11 @@ +from virtualenv.seed.embed.wheels.acquire import get_bundled_wheel, wheel_support_py + + +def test_wheel_support_no_python_requires(mocker): + wheel = get_bundled_wheel(package="setuptools", version_release=None) + zip_mock = mocker.MagicMock() + mocker.patch("virtualenv.seed.embed.wheels.acquire.ZipFile", new=zip_mock) + zip_mock.return_value.__enter__.return_value.read = lambda name: b"" + + supports = wheel_support_py(wheel, "3.8") + assert supports is True