Skip to content

Commit 2a0acb5

Browse files
authored
Update and provide fixes for mypy pre-commit (#12389)
* Update mypy to 1.6.1 * Fix mypy "Source file found twice under different module names" error * Ignore type of intialized abstract class in tests * Use more specific type ignore method-assign * Type ignore for message.get_all * Remove unused type ignore * Add SizedBuffer type for xmlrpc.client.Transport subclass * Add Self type for RequestHandlerClass in test * Add type ignore for shutil.rmtree onexc handler * Quote SizedBuffer * Add news entry * Remove no longer correct comment * Update self import * Also ignore type onerror=handler * Update news entry * Update news entry
1 parent 6852908 commit 2a0acb5

File tree

14 files changed

+38
-32
lines changed

14 files changed

+38
-32
lines changed

.pre-commit-config.yaml

Lines changed: 8 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -28,20 +28,20 @@ repos:
2828
args: [--fix, --exit-non-zero-on-fix]
2929

3030
- repo: https://github.com/pre-commit/mirrors-mypy
31-
rev: v0.961
31+
rev: v1.6.1
3232
hooks:
3333
- id: mypy
3434
exclude: tests/data
3535
args: ["--pretty", "--show-error-codes"]
3636
additional_dependencies: [
37-
'keyring==23.0.1',
38-
'nox==2021.6.12',
37+
'keyring==24.2.0',
38+
'nox==2023.4.22',
3939
'pytest',
40-
'types-docutils==0.18.3',
41-
'types-setuptools==57.4.14',
42-
'types-freezegun==1.1.9',
43-
'types-six==1.16.15',
44-
'types-pyyaml==6.0.12.2',
40+
'types-docutils==0.20.0.3',
41+
'types-setuptools==68.2.0.0',
42+
'types-freezegun==1.1.10',
43+
'types-six==1.16.21.9',
44+
'types-pyyaml==6.0.12.12',
4545
]
4646

4747
- repo: https://github.com/pre-commit/pygrep-hooks

news/12389.bugfix.rst

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
Update mypy to 1.6.1 and fix/ignore types

src/pip/_internal/locations/_distutils.py

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -56,8 +56,7 @@ def distutils_scheme(
5656
try:
5757
d.parse_config_files()
5858
except UnicodeDecodeError:
59-
# Typeshed does not include find_config_files() for some reason.
60-
paths = d.find_config_files() # type: ignore
59+
paths = d.find_config_files()
6160
logger.warning(
6261
"Ignore distutils configs in %s due to encoding errors.",
6362
", ".join(os.path.basename(p) for p in paths),

src/pip/_internal/metadata/_json.py

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -64,10 +64,10 @@ def sanitise_header(h: Union[Header, str]) -> str:
6464
key = json_name(field)
6565
if multi:
6666
value: Union[str, List[str]] = [
67-
sanitise_header(v) for v in msg.get_all(field)
67+
sanitise_header(v) for v in msg.get_all(field) # type: ignore
6868
]
6969
else:
70-
value = sanitise_header(msg.get(field))
70+
value = sanitise_header(msg.get(field)) # type: ignore
7171
if key == "keywords":
7272
# Accept both comma-separated and space-separated
7373
# forms, for better compatibility with old data.

src/pip/_internal/network/xmlrpc.py

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,8 @@
1313
if TYPE_CHECKING:
1414
from xmlrpc.client import _HostType, _Marshallable
1515

16+
from _typeshed import SizedBuffer
17+
1618
logger = logging.getLogger(__name__)
1719

1820

@@ -33,7 +35,7 @@ def request(
3335
self,
3436
host: "_HostType",
3537
handler: str,
36-
request_body: bytes,
38+
request_body: "SizedBuffer",
3739
verbose: bool = False,
3840
) -> Tuple["_Marshallable", ...]:
3941
assert isinstance(host, str)

src/pip/_internal/utils/misc.py

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -141,9 +141,9 @@ def rmtree(
141141
)
142142
if sys.version_info >= (3, 12):
143143
# See https://docs.python.org/3.12/whatsnew/3.12.html#shutil.
144-
shutil.rmtree(dir, onexc=handler)
144+
shutil.rmtree(dir, onexc=handler) # type: ignore
145145
else:
146-
shutil.rmtree(dir, onerror=handler)
146+
shutil.rmtree(dir, onerror=handler) # type: ignore
147147

148148

149149
def _onerror_ignore(*_args: Any) -> None:

tests/conftest.py

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,7 @@
1414
from pathlib import Path
1515
from textwrap import dedent
1616
from typing import (
17+
TYPE_CHECKING,
1718
Any,
1819
AnyStr,
1920
Callable,
@@ -58,6 +59,9 @@
5859
from tests.lib.server import MockServer, make_mock_server
5960
from tests.lib.venv import VirtualEnvironment, VirtualEnvironmentType
6061

62+
if TYPE_CHECKING:
63+
from pip._vendor.typing_extensions import Self
64+
6165

6266
def pytest_addoption(parser: Parser) -> None:
6367
parser.addoption(
@@ -941,7 +945,7 @@ def html_index_with_onetime_server(
941945
"""
942946

943947
class InDirectoryServer(http.server.ThreadingHTTPServer):
944-
def finish_request(self, request: Any, client_address: Any) -> None:
948+
def finish_request(self: "Self", request: Any, client_address: Any) -> None:
945949
self.RequestHandlerClass(
946950
request,
947951
client_address,

tests/lib/configuration_helpers.py

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -38,7 +38,7 @@ def overridden() -> None:
3838
old()
3939

4040
# https://github.com/python/mypy/issues/2427
41-
self.configuration._load_config_files = overridden # type: ignore[assignment]
41+
self.configuration._load_config_files = overridden # type: ignore[method-assign]
4242

4343
@contextlib.contextmanager
4444
def tmpfile(self, contents: str) -> Iterator[str]:

tests/lib/test_wheel.py

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -19,12 +19,12 @@
1919

2020
def test_message_from_dict_one_value() -> None:
2121
message = message_from_dict({"a": "1"})
22-
assert set(message.get_all("a")) == {"1"}
22+
assert set(message.get_all("a")) == {"1"} # type: ignore
2323

2424

2525
def test_message_from_dict_multiple_values() -> None:
2626
message = message_from_dict({"a": ["1", "2"]})
27-
assert set(message.get_all("a")) == {"1", "2"}
27+
assert set(message.get_all("a")) == {"1", "2"} # type: ignore
2828

2929

3030
def message_from_bytes(contents: bytes) -> Message:
@@ -67,7 +67,7 @@ def test_make_metadata_file_custom_value_list() -> None:
6767
f = default_make_metadata(updates={"a": ["1", "2"]})
6868
assert f is not None
6969
message = default_metadata_checks(f)
70-
assert set(message.get_all("a")) == {"1", "2"}
70+
assert set(message.get_all("a")) == {"1", "2"} # type: ignore
7171

7272

7373
def test_make_metadata_file_custom_value_overrides() -> None:
@@ -101,7 +101,7 @@ def default_wheel_metadata_checks(f: File) -> Message:
101101
assert message.get_all("Wheel-Version") == ["1.0"]
102102
assert message.get_all("Generator") == ["pip-test-suite"]
103103
assert message.get_all("Root-Is-Purelib") == ["true"]
104-
assert set(message.get_all("Tag")) == {"py2-none-any", "py3-none-any"}
104+
assert set(message.get_all("Tag")) == {"py2-none-any", "py3-none-any"} # type: ignore
105105
return message
106106

107107

@@ -122,7 +122,7 @@ def test_make_wheel_metadata_file_custom_value_list() -> None:
122122
f = default_make_wheel_metadata(updates={"a": ["1", "2"]})
123123
assert f is not None
124124
message = default_wheel_metadata_checks(f)
125-
assert set(message.get_all("a")) == {"1", "2"}
125+
assert set(message.get_all("a")) == {"1", "2"} # type: ignore
126126

127127

128128
def test_make_wheel_metadata_file_custom_value_override() -> None:

tests/unit/metadata/test_metadata.py

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,7 @@ def test_dist_get_direct_url_no_metadata(mock_read_text: mock.Mock) -> None:
2323
class FakeDistribution(BaseDistribution):
2424
pass
2525

26-
dist = FakeDistribution()
26+
dist = FakeDistribution() # type: ignore
2727
assert dist.direct_url is None
2828
mock_read_text.assert_called_once_with(DIRECT_URL_METADATA_NAME)
2929

@@ -35,7 +35,7 @@ def test_dist_get_direct_url_invalid_json(
3535
class FakeDistribution(BaseDistribution):
3636
canonical_name = cast(NormalizedName, "whatever") # Needed for error logging.
3737

38-
dist = FakeDistribution()
38+
dist = FakeDistribution() # type: ignore
3939
with caplog.at_level(logging.WARNING):
4040
assert dist.direct_url is None
4141

@@ -84,7 +84,7 @@ def test_dist_get_direct_url_valid_metadata(mock_read_text: mock.Mock) -> None:
8484
class FakeDistribution(BaseDistribution):
8585
pass
8686

87-
dist = FakeDistribution()
87+
dist = FakeDistribution() # type: ignore
8888
direct_url = dist.direct_url
8989
assert direct_url is not None
9090
mock_read_text.assert_called_once_with(DIRECT_URL_METADATA_NAME)

0 commit comments

Comments
 (0)