Skip to content

Commit

Permalink
Remove the unneeded logger argument from is_secure_origin().
Browse files Browse the repository at this point in the history
  • Loading branch information
cjerdonek committed Aug 22, 2019
1 parent a6cdb49 commit cbd6217
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 19 deletions.
5 changes: 2 additions & 3 deletions src/pip/_internal/download.py
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,6 @@
from pip._internal.vcs import vcs

if MYPY_CHECK_RUNNING:
from logging import Logger
from typing import (
IO, Callable, Dict, Iterator, List, Optional, Text, Tuple, Union,
)
Expand Down Expand Up @@ -688,8 +687,8 @@ def iter_secure_origins(self):
for host in self.pip_trusted_hosts:
yield ('*', host, '*')

def is_secure_origin(self, logger, location):
# type: (Logger, Link) -> bool
def is_secure_origin(self, location):
# type: (Link) -> bool
# Determine if this url used a secure transport mechanism
parsed = urllib_parse.urlparse(str(location))
origin = (parsed.scheme, parsed.hostname, parsed.port)
Expand Down
2 changes: 1 addition & 1 deletion src/pip/_internal/index.py
Original file line number Diff line number Diff line change
Expand Up @@ -999,7 +999,7 @@ def find_all_candidates(self, project_name):
(Link(url) for url in index_url_loc),
(Link(url) for url in fl_url_loc),
)
if self.session.is_secure_origin(logger, link)
if self.session.is_secure_origin(link)
]

logger.debug('%d location(s) to search for versions of %s:',
Expand Down
40 changes: 25 additions & 15 deletions tests/unit/test_download.py
Original file line number Diff line number Diff line change
Expand Up @@ -700,21 +700,22 @@ def test_iter_secure_origins__insecure_hosts_empty(self):
assert actual[0] == ('https', '*', '*')

@pytest.mark.parametrize(
("location", "trusted", "expected"),
'location, trusted, expected',
[
("http://pypi.org/something", [], True),
("https://pypi.org/something", [], False),
("git+http://pypi.org/something", [], True),
("git+https://pypi.org/something", [], False),
("git+ssh://[email protected]/something", [], False),
("http://localhost", [], False),
("http://127.0.0.1", [], False),
("http://example.com/something/", [], True),
("http://example.com/something/", ["example.com"], False),
("http://eXample.com/something/", ["example.cOm"], False),
("http://pypi.org/something", [], False),
("https://pypi.org/something", [], True),
("git+http://pypi.org/something", [], False),
("git+https://pypi.org/something", [], True),
("git+ssh://[email protected]/something", [], True),
("http://localhost", [], True),
("http://127.0.0.1", [], True),
("http://example.com/something/", [], False),
("http://example.com/something/", ["example.com"], True),
# Try changing the case.
("http://eXample.com/something/", ["example.cOm"], True),
],
)
def test_secure_origin(self, location, trusted, expected):
def test_is_secure_origin(self, caplog, location, trusted, expected):
class MockLogger(object):
def __init__(self):
self.called = False
Expand All @@ -723,9 +724,18 @@ def warning(self, *args, **kwargs):
self.called = True

session = PipSession(insecure_hosts=trusted)
logger = MockLogger()
session.is_secure_origin(logger, location)
assert logger.called == expected
actual = session.is_secure_origin(location)
assert actual == expected

log_records = [(r.levelname, r.message) for r in caplog.records]
if expected:
assert not log_records
return

assert len(log_records) == 1
actual_level, actual_message = log_records[0]
assert actual_level == 'WARNING'
assert 'is not a trusted or secure host' in actual_message


@pytest.mark.parametrize(["input_url", "url", "username", "password"], [
Expand Down

0 comments on commit cbd6217

Please sign in to comment.