Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix all mypy issues #3979

Merged
merged 44 commits into from
Mar 5, 2024
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
aaea47d
Fix all mypy issues
Avasam Jul 9, 2023
11fd06c
Ran black
Avasam Jul 9, 2023
8050560
Exclude tox from mypy check
Avasam Oct 1, 2023
765881a
Merge branch 'main' of https://github.com/pypa/setuptools into fix-al…
Avasam Oct 1, 2023
ddbf028
Fix all mypy issues again
Avasam Oct 1, 2023
5f287b8
Merge branch 'main' into fix-all-mypy-issues
Avasam Oct 21, 2023
37a2bb1
Address PR comments
Avasam Oct 22, 2023
f0e6bc5
Merge branch 'fix-all-mypy-issues' of https://github.com/Avasam/setup…
Avasam Oct 22, 2023
03afa45
Fix accidental line ending changes
Avasam Oct 22, 2023
dc946aa
Update .gitignore
Avasam Oct 27, 2023
f69eaa1
Merge branch 'main' of https://github.com/pypa/setuptools into fix-al…
Avasam Nov 22, 2023
f0697b4
No unused type: ignore
Avasam Nov 22, 2023
baa555b
TypeError: 'ABCMeta' object is not subscriptable
Avasam Nov 22, 2023
c367b9f
Fix RuffError
Avasam Nov 22, 2023
c7ed433
Merge branch 'main' into fix-all-mypy-issues
Avasam Dec 24, 2023
ebdabe4
Merge branch 'main' into fix-all-mypy-issues
Avasam Jan 12, 2024
82265ca
Merge branch 'main' of https://github.com/pypa/setuptools into fix-al…
Avasam Jan 24, 2024
7ddd2b2
Merge branch 'fix-all-mypy-issues' of https://github.com/Avasam/setup…
Avasam Jan 24, 2024
84bd5e3
Merge branch 'main' of https://github.com/pypa/setuptools into fix-al…
Avasam Jan 24, 2024
f76def7
Fix post-merge mypy issues
Avasam Jan 24, 2024
ace61b4
Merge branch 'main' into fix-all-mypy-issues
Avasam Feb 5, 2024
d114d18
Merge branch 'main' of https://github.com/pypa/setuptools into fix-al…
Avasam Feb 9, 2024
818b206
Merge branch 'fix-all-mypy-issues' of https://github.com/Avasam/setup…
Avasam Feb 9, 2024
3ed0dda
Merge branch 'main' into fix-all-mypy-issues
Avasam Feb 14, 2024
024e30e
Merge branch 'main' of https://github.com/pypa/setuptools into fix-al…
Avasam Feb 14, 2024
8fbe1bf
RUff format
Avasam Feb 14, 2024
c4dd3c9
Merge branch 'fix-all-mypy-issues' of https://github.com/Avasam/setup…
Avasam Feb 14, 2024
83c2b3d
Ignore more generated files
Avasam Feb 15, 2024
f4e1d21
Disable more mypy errors
Avasam Feb 19, 2024
6b5bbca
Globally ignore attr-defined for now
Avasam Feb 19, 2024
ecac670
Update more comments
Avasam Feb 19, 2024
f3779b1
Address PR comments and fix new exposed typing issues
Avasam Feb 22, 2024
379a041
Comments updates and don't touch vendored
Avasam Feb 22, 2024
555e9ff
Accidentally removed noqa
Avasam Feb 22, 2024
8aa568a
Update setuptools/tests/integration/test_pip_install_sdist.py
Avasam Feb 22, 2024
62a8099
Merge branch 'main' of https://github.com/pypa/setuptools into fix-al…
Avasam Feb 22, 2024
b3fde45
Post merge comments
Avasam Feb 22, 2024
8981ed4
Merge branch 'fix-all-mypy-issues' of https://github.com/Avasam/setup…
Avasam Feb 22, 2024
55eeabd
Document that usage of _config_vars is very purposeful Closes #4228
Avasam Feb 23, 2024
e9d79f0
sort nitpick_ignore
Avasam Feb 23, 2024
232bcd4
Make only comment on newline like others
Avasam Feb 23, 2024
7ba7133
Merge branch 'main' of https://github.com/pypa/setuptools into fix-al…
Avasam Feb 25, 2024
708fff7
Forgot to re-ignore
Avasam Feb 25, 2024
e1c064f
Merge branch 'main' of https://github.com/pypa/setuptools into fix-al…
Avasam Mar 5, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ lib
distribute.egg-info
setuptools.egg-info
.coverage
test_*
Avasam marked this conversation as resolved.
Show resolved Hide resolved
.eggs
.tox
.venv
Expand Down
5 changes: 0 additions & 5 deletions mypy.ini

This file was deleted.

18 changes: 10 additions & 8 deletions pkg_resources/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
import time
import re
import types
from typing import TYPE_CHECKING, Optional
import zipfile
import zipimport
import warnings
Expand All @@ -43,11 +44,7 @@
import importlib
from pkgutil import get_importer

try:
import _imp
except ImportError:
# Python 3.2 compatibility
import imp as _imp
import _imp
Avasam marked this conversation as resolved.
Show resolved Hide resolved

try:
FileExistsError
Expand All @@ -68,8 +65,11 @@
from os import open as os_open
from os.path import isdir, split

importlib_machinery: Optional[types.ModuleType]
try:
import importlib.machinery as importlib_machinery
import importlib.machinery

importlib_machinery = importlib.machinery
Avasam marked this conversation as resolved.
Show resolved Hide resolved

# access attribute to force import under delayed import mechanisms.
importlib_machinery.__name__
Expand Down Expand Up @@ -2231,7 +2231,8 @@ def resolve_egg_link(path):
if hasattr(pkgutil, 'ImpImporter'):
register_finder(pkgutil.ImpImporter, find_on_path)

register_finder(importlib_machinery.FileFinder, find_on_path)
if importlib_machinery:
register_finder(importlib_machinery.FileFinder, find_on_path)
Avasam marked this conversation as resolved.
Show resolved Hide resolved

_declare_state('dict', _namespace_handlers={})
_declare_state('dict', _namespace_packages={})
Expand Down Expand Up @@ -2398,7 +2399,8 @@ def file_ns_handler(importer, path_item, packageName, module):
register_namespace_handler(pkgutil.ImpImporter, file_ns_handler)

register_namespace_handler(zipimport.zipimporter, file_ns_handler)
register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler)
if importlib_machinery:
register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler)


def null_ns_handler(importer, path_item, packageName, module):
Expand Down
8 changes: 8 additions & 0 deletions pkg_resources/extern/__init__.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import importlib.util
import sys
from typing import TYPE_CHECKING


class VendorImporter:
Expand Down Expand Up @@ -78,3 +79,10 @@ def install(self):
'more_itertools',
)
VendorImporter(__name__, names).install()

if TYPE_CHECKING:
from . import packaging as packaging
Avasam marked this conversation as resolved.
Show resolved Hide resolved
import platformdirs as platformdirs
import jaraco as jaraco
import importlib_resources as importlib_resources
import more_itertools as more_itertools
Avasam marked this conversation as resolved.
Show resolved Hide resolved
Avasam marked this conversation as resolved.
Show resolved Hide resolved
14 changes: 14 additions & 0 deletions pkg_resources/extern/packaging/__init__.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
from packaging import *
from . import _elffile as _elffile
from . import _manylinux as _manylinux
from . import _musllinux as _musllinux
from . import _parser as _parser
from . import _structures as _structures
from . import _tokenizer as _tokenizer
from . import markers as markers
from . import metadata as metadata
from . import requirements as requirements
from . import specifiers as specifiers
from . import tags as tags
from . import utils as utils
from . import version as version
Avasam marked this conversation as resolved.
Show resolved Hide resolved
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/_elffile.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging._elffile import *
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/_manylinux.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging._manylinux import *
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/_musllinux.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging._musllinux import *
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/_parser.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging._parser import *
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/_structures.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging._structures import *
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/_tokenizer.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging._tokenizer import *
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/markers.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging.markers import *
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/metadata.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging.metadata import *
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/requirements.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging.requirements import *
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/specifiers.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging.specifiers import *
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/tags.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging.tags import *
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/utils.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging.utils import *
1 change: 1 addition & 0 deletions pkg_resources/extern/packaging/version.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from packaging.version import *
3 changes: 2 additions & 1 deletion pkg_resources/tests/test_pkg_resources.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
import stat
import distutils.dist
import distutils.command.install_egg_info
from typing import List

from unittest import mock

Expand Down Expand Up @@ -42,7 +43,7 @@ def __call__(self):


class TestZipProvider:
finalizers = []
finalizers: List[EggRemover] = []

ref_time = datetime.datetime(2013, 5, 12, 13, 25, 0)
"A reference time for a file modification"
Expand Down
20 changes: 20 additions & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -11,3 +11,23 @@ extend_exclude = "_vendor"

[tool.pytest-enabler.mypy]
# disabled


[tool.mypy]
# CI should test for all versions, local development gets hints for oldest supported
python_version = "3.8"
strict = false
# TODO: Not all dependencies are typed. setuptools itself should be typed too
# TODO: Test environment is not yet properly configured to install all imported packages
ignore_missing_imports = true
# required to support namespace packages: https://github.com/python/mypy/issues/14057
explicit_package_bases = true
exclude = [
"^build/",
"^.tox/",
# Duplicate module name
"^pkg_resources/tests/data/my-test-package-source/setup.py$",
# Vendored
"^.+?/_vendor",
"^setuptools/_distutils",
]
2 changes: 1 addition & 1 deletion setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ testing =
pytest-cov; \
# coverage seems to make PyPy extremely slow
python_implementation != "PyPy"
pytest-mypy >= 0.9.1; \
pytest-mypy >= 0.10.3; \
Avasam marked this conversation as resolved.
Show resolved Hide resolved
# workaround for jaraco/skeleton#22
python_implementation != "PyPy"
pytest-enabler >= 2.2
Expand Down
3 changes: 2 additions & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -88,5 +88,6 @@ def _restore_install_lib(self):

if __name__ == '__main__':
# allow setup.py to run from another directory
here and os.chdir(here)
if here:
os.chdir(here)
Avasam marked this conversation as resolved.
Show resolved Hide resolved
dist = setuptools.setup(**setup_params)
2 changes: 1 addition & 1 deletion setuptools/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -109,7 +109,7 @@ def setup(**attrs):
_Command = monkey.get_unpatched(distutils.core.Command)


class Command(_Command):
class Command(_Command): # type: ignore[valid-type, misc] # https://github.com/python/mypy/issues/14458
abravalheri marked this conversation as resolved.
Show resolved Hide resolved
"""
Setuptools internal actions are organized using a *command design pattern*.
This means that each action (or group of closely related actions) executed during
Expand Down
2 changes: 1 addition & 1 deletion setuptools/command/_requirestxt.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ def _prepare(


def _convert_extras_requirements(
extras_require: _StrOrIter,
extras_require: Mapping[str, _StrOrIter],
) -> Mapping[str, _Ordered[Requirement]]:
"""
Convert requirements in `extras_require` of the form
Expand Down
38 changes: 21 additions & 17 deletions setuptools/command/build_ext.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,30 +3,33 @@
import itertools
from importlib.machinery import EXTENSION_SUFFIXES
from importlib.util import cache_from_source as _compiled_file_name
from typing import Dict, Iterator, List, Tuple
from typing import TYPE_CHECKING, Dict, Iterator, List, Tuple
from pathlib import Path

from distutils.command.build_ext import build_ext as _du_build_ext
from distutils.ccompiler import new_compiler
from distutils.sysconfig import customize_compiler, get_config_var
from distutils import log

from setuptools.errors import BaseError
from setuptools.extension import Extension, Library

try:
# Attempt to use Cython for building extensions, if available
from Cython.Distutils.build_ext import build_ext as _build_ext
if TYPE_CHECKING:
from setuptools.dist import Distribution
from distutils.command.build_ext import build_ext as _build_ext
else:
try:
# Attempt to use Cython for building extensions, if available
from Cython.Distutils.build_ext import build_ext as _build_ext

# Additionally, assert that the compiler module will load
# also. Ref #1229.
__import__('Cython.Compiler.Main')
except ImportError:
_build_ext = _du_build_ext
# Additionally, assert that the compiler module will load
# also. Ref #1229.
__import__('Cython.Compiler.Main')
except ImportError:
from distutils.command.build_ext import build_ext as _build_ext
Avasam marked this conversation as resolved.
Show resolved Hide resolved

# make sure _config_vars is initialized
get_config_var("LDSHARED")
from distutils.sysconfig import _config_vars as _CONFIG_VARS # noqa
from distutils.sysconfig import _config_vars as _CONFIG_VARS # type: ignore # noqa # Not publicly exposed in distutils stubs


def _customize_compiler_for_shlib(compiler):
Expand Down Expand Up @@ -81,6 +84,7 @@ def get_abi3_suffix():
class build_ext(_build_ext):
editable_mode: bool = False
inplace: bool = False
distribution: "Distribution"

def run(self):
"""Build extensions in build directory, then copy if --inplace"""
Expand Down Expand Up @@ -127,7 +131,7 @@ def _get_output_mapping(self) -> Iterator[Tuple[str, str]]:
return

build_py = self.get_finalized_command('build_py')
opt = self.get_finalized_command('install_lib').optimize or ""
opt = self.get_finalized_command('install_lib').optimize or "" # type: ignore[attr-defined] # TODO: Fix in distutils stubs

for ext in self.extensions:
inplace_file, regular_file = self._get_inplace_equivalent(build_py, ext)
Expand Down Expand Up @@ -338,7 +342,7 @@ def _write_stub_file(self, stub_file: str, ext: Extension, compile=False):
log.info("writing stub loader for %s to %s", ext._full_name, stub_file)
if compile and os.path.exists(stub_file):
raise BaseError(stub_file + " already exists! Please delete.")
if not self.dry_run:
if not self.dry_run: # type: ignore[attr-defined] # TODO: Fix in distutils stubs
f = open(stub_file, 'w')
f.write(
'\n'.join(
Expand Down Expand Up @@ -376,13 +380,13 @@ def _write_stub_file(self, stub_file: str, ext: Extension, compile=False):
def _compile_and_remove_stub(self, stub_file: str):
from distutils.util import byte_compile

byte_compile([stub_file], optimize=0, force=True, dry_run=self.dry_run)
optimize = self.get_finalized_command('install_lib').optimize
byte_compile([stub_file], optimize=0, force=True, dry_run=self.dry_run) # type: ignore[attr-defined] # TODO: Fix in distutils stubs
optimize = self.get_finalized_command('install_lib').optimize # type: ignore[attr-defined] # TODO: Fix in distutils stubs
if optimize > 0:
byte_compile(
[stub_file], optimize=optimize, force=True, dry_run=self.dry_run
[stub_file], optimize=optimize, force=True, dry_run=self.dry_run # type: ignore[attr-defined] # TODO: Fix in distutils stubs
)
if os.path.exists(stub_file) and not self.dry_run:
if os.path.exists(stub_file) and not self.dry_run: # type: ignore[attr-defined] # TODO: Fix in distutils stubs
os.unlink(stub_file)


Expand Down
2 changes: 1 addition & 1 deletion setuptools/command/build_py.py
Original file line number Diff line number Diff line change
Expand Up @@ -219,7 +219,7 @@ def _filter_build_files(self, files: Iterable[str], egg_info: str) -> Iterator[s
This function should filter this case of invalid files out.
"""
build = self.get_finalized_command("build")
build_dirs = (egg_info, self.build_lib, build.build_temp, build.build_base)
build_dirs = (egg_info, self.build_lib, build.build_temp, build.build_base) # type: ignore[attr-defined] # TODO: Fix in distutils stubs
norm_dirs = [os.path.normpath(p) for p in build_dirs if p]

for file in files:
Expand Down
17 changes: 13 additions & 4 deletions setuptools/command/easy_install.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@
from distutils.command import install
import sys
import os
from typing import TYPE_CHECKING, Dict, List, Optional, Union
import zipimport
import shutil
import tempfile
Expand Down Expand Up @@ -78,6 +79,8 @@
from .._path import ensure_directory
from ..extern.jaraco.text import yield_lines

_FileDescriptorOrPath = Union[int, str, bytes, os.PathLike[str], os.PathLike[bytes]]


# Turn on PEP440Warnings
warnings.filterwarnings("default", category=pkg_resources.PEP440Warning)
Expand Down Expand Up @@ -1774,7 +1777,7 @@ def _wrap_lines(cls, lines):


if os.environ.get('SETUPTOOLS_SYS_PATH_TECHNIQUE', 'raw') == 'rewrite':
PthDistributions = RewritePthDistributions
PthDistributions = RewritePthDistributions # type: ignore[misc] # Overwriting type


def _first_line_re():
Expand Down Expand Up @@ -2024,7 +2027,13 @@ def is_python_script(script_text, filename):
from os import chmod as _chmod
except ImportError:
abravalheri marked this conversation as resolved.
Show resolved Hide resolved
# Jython compatibility
def _chmod(*args):
def _chmod(
path: _FileDescriptorOrPath,
mode: int,
*,
dir_fd: Optional[int] = None,
follow_symlinks: bool = True,
) -> None:
pass


Expand All @@ -2042,8 +2051,8 @@ class CommandSpec(list):
those passed to Popen.
"""

options = []
split_args = dict()
options: List[str] = []
split_args: Dict[str, bool] = dict()

@classmethod
def best(cls):
Expand Down
2 changes: 1 addition & 1 deletion setuptools/command/editable_wheel.py
Original file line number Diff line number Diff line change
Expand Up @@ -272,7 +272,7 @@ def _run_build_commands(
self._run_install("data")
return files, mapping

def _run_build_subcommands(self):
def _run_build_subcommands(self) -> None:
"""
Issue #3501 indicates that some plugins/customizations might rely on:

Expand Down
3 changes: 2 additions & 1 deletion setuptools/command/rotate.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
from distutils.errors import DistutilsOptionError
import os
import shutil
from typing import List

from setuptools import Command

Expand All @@ -17,7 +18,7 @@ class rotate(Command):
('keep=', 'k', "number of matching distributions to keep"),
]

boolean_options = []
boolean_options: List[str] = []

def initialize_options(self):
self.match = None
Expand Down
2 changes: 1 addition & 1 deletion setuptools/command/upload_docs.py
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ def has_sphinx(self):
and metadata.entry_points(group='distutils.commands', name='build_sphinx')
)

sub_commands = [('build_sphinx', has_sphinx)]
sub_commands = [('build_sphinx', has_sphinx)] # type: ignore[list-item] # TODO: Fix in distutils stubs

def initialize_options(self):
upload.initialize_options(self)
Expand Down
2 changes: 1 addition & 1 deletion setuptools/config/_validate_pyproject/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
from .error_reporting import detailed_errors, ValidationError
from .extra_validations import EXTRA_VALIDATIONS
from .fastjsonschema_exceptions import JsonSchemaException, JsonSchemaValueException
from .fastjsonschema_validations import validate as _validate
from .fastjsonschema_validations import validate as _validate # type: ignore[attr-defined] # mypy false-positive. Pyright is fine here
Avasam marked this conversation as resolved.
Show resolved Hide resolved

__all__ = [
"validate",
Expand Down
Loading