-
Notifications
You must be signed in to change notification settings - Fork 3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #7335 from sbidoul/subdirectory-cache-key-sbi
Include subdirectory URL fragments in cache keys
- Loading branch information
Showing
3 changed files
with
59 additions
and
12 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
Include ``subdirectory`` URL fragments in cache keys. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,13 +1,44 @@ | ||
import os | ||
|
||
from pip._internal.cache import WheelCache | ||
from pip._internal.models.format_control import FormatControl | ||
from pip._internal.models.link import Link | ||
from pip._internal.utils.compat import expanduser | ||
from pip._internal.utils.misc import ensure_dir | ||
|
||
|
||
def test_expands_path(): | ||
wc = WheelCache("~/.foo/", None) | ||
assert wc.cache_dir == expanduser("~/.foo/") | ||
|
||
|
||
def test_falsey_path_none(): | ||
wc = WheelCache(False, None) | ||
assert wc.cache_dir is None | ||
|
||
|
||
class TestWheelCache: | ||
def test_subdirectory_fragment(): | ||
""" | ||
Test the subdirectory URL fragment is part of the cache key. | ||
""" | ||
wc = WheelCache("~/.foo/", None) | ||
link1 = Link("git+https://g.c/o/r#subdirectory=d1") | ||
link2 = Link("git+https://g.c/o/r#subdirectory=d2") | ||
assert wc.get_path_for_link(link1) != wc.get_path_for_link(link2) | ||
|
||
def test_expands_path(self): | ||
wc = WheelCache("~/.foo/", None) | ||
assert wc.cache_dir == expanduser("~/.foo/") | ||
|
||
def test_falsey_path_none(self): | ||
wc = WheelCache(False, None) | ||
assert wc.cache_dir is None | ||
def test_wheel_name_filter(tmpdir): | ||
""" | ||
Test the wheel cache filters on wheel name when several wheels | ||
for different package are stored under the same cache directory. | ||
""" | ||
wc = WheelCache(tmpdir, FormatControl()) | ||
link = Link("https://g.c/package.tar.gz") | ||
cache_path = wc.get_path_for_link(link) | ||
ensure_dir(cache_path) | ||
with open(os.path.join(cache_path, "package-1.0-py3-none-any.whl"), "w"): | ||
pass | ||
# package matches wheel name | ||
assert wc.get(link, "package", [("py3", "none", "any")]) is not link | ||
# package2 does not match wheel name | ||
assert wc.get(link, "package2", [("py3", "none", "any")]) is link |