From 0a1571ba03d8a87e0ad47e70f93e990128b5fd13 Mon Sep 17 00:00:00 2001 From: Chris Jerdonek Date: Tue, 23 Jul 2019 05:18:59 -0400 Subject: [PATCH] Fix a NoneType AttributeError when evaluating hashes. --- news/6772.bugfix | 2 ++ src/pip/_internal/models/link.py | 4 ++-- tests/unit/test_link.py | 10 ++++++++++ 3 files changed, 14 insertions(+), 2 deletions(-) create mode 100644 news/6772.bugfix diff --git a/news/6772.bugfix b/news/6772.bugfix new file mode 100644 index 00000000000..b85e44c8aaf --- /dev/null +++ b/news/6772.bugfix @@ -0,0 +1,2 @@ +Fix a ``NoneType`` ``AttributeError`` when evaluating hashes and no hashes +are provided. diff --git a/src/pip/_internal/models/link.py b/src/pip/_internal/models/link.py index 01983e7079c..d42be28c460 100644 --- a/src/pip/_internal/models/link.py +++ b/src/pip/_internal/models/link.py @@ -200,11 +200,11 @@ def has_hash(self): return self.hash_name is not None def is_hash_allowed(self, hashes): - # type: (Hashes) -> bool + # type: (Optional[Hashes]) -> bool """ Return True if the link has a hash and it is allowed. """ - if not self.has_hash: + if hashes is None or not self.has_hash: return False # Assert non-None so mypy knows self.hash_name and self.hash are str. assert self.hash_name is not None diff --git a/tests/unit/test_link.py b/tests/unit/test_link.py index a1d8d40a8bc..8a8182d3919 100644 --- a/tests/unit/test_link.py +++ b/tests/unit/test_link.py @@ -117,3 +117,13 @@ def test_is_hash_allowed__no_hash(self): } hashes = Hashes(hashes_data) assert not link.is_hash_allowed(hashes) + + @pytest.mark.parametrize('hashes, expected', [ + (None, False), + # Also test a success case to show the test is correct. + (Hashes({'sha512': [128 * 'a']}), True), + ]) + def test_is_hash_allowed__none_hashes(self, hashes, expected): + url = 'https://example.com/wheel.whl#sha512={}'.format(128 * 'a') + link = Link(url) + assert link.is_hash_allowed(hashes) == expected