Type annotate _pytest.debugging (a bit)

This commit is contained in:
Ran Benita 2020-05-01 14:40:16 +03:00
parent 216a010ab7
commit 01797e6370
4 changed files with 22 additions and 14 deletions

View File

@ -18,7 +18,7 @@ repos:
args: [--remove] args: [--remove]
- id: check-yaml - id: check-yaml
- id: debug-statements - id: debug-statements
exclude: _pytest/debugging.py exclude: _pytest/(debugging|hookspec).py
language_version: python3 language_version: python3
- repo: https://gitlab.com/pycqa/flake8 - repo: https://gitlab.com/pycqa/flake8
rev: 3.8.2 rev: 3.8.2

View File

@ -2,6 +2,9 @@
import argparse import argparse
import functools import functools
import sys import sys
from typing import Generator
from typing import Tuple
from typing import Union
from _pytest import outcomes from _pytest import outcomes
from _pytest.compat import TYPE_CHECKING from _pytest.compat import TYPE_CHECKING
@ -15,10 +18,11 @@ from _pytest.nodes import Node
from _pytest.reports import BaseReport from _pytest.reports import BaseReport
if TYPE_CHECKING: if TYPE_CHECKING:
from _pytest.capture import CaptureManager
from _pytest.runner import CallInfo from _pytest.runner import CallInfo
def _validate_usepdb_cls(value): def _validate_usepdb_cls(value: str) -> Tuple[str, str]:
"""Validate syntax of --pdbcls option.""" """Validate syntax of --pdbcls option."""
try: try:
modname, classname = value.split(":") modname, classname = value.split(":")
@ -70,7 +74,7 @@ def pytest_configure(config: Config) -> None:
# NOTE: not using pytest_unconfigure, since it might get called although # NOTE: not using pytest_unconfigure, since it might get called although
# pytest_configure was not (if another plugin raises UsageError). # pytest_configure was not (if another plugin raises UsageError).
def fin(): def fin() -> None:
( (
pdb.set_trace, pdb.set_trace,
pytestPDB._pluginmanager, pytestPDB._pluginmanager,
@ -90,13 +94,13 @@ class pytestPDB:
_wrapped_pdb_cls = None _wrapped_pdb_cls = None
@classmethod @classmethod
def _is_capturing(cls, capman): def _is_capturing(cls, capman: "CaptureManager") -> Union[str, bool]:
if capman: if capman:
return capman.is_capturing() return capman.is_capturing()
return False return False
@classmethod @classmethod
def _import_pdb_cls(cls, capman): def _import_pdb_cls(cls, capman: "CaptureManager"):
if not cls._config: if not cls._config:
import pdb import pdb
@ -135,10 +139,12 @@ class pytestPDB:
return wrapped_cls return wrapped_cls
@classmethod @classmethod
def _get_pdb_wrapper_class(cls, pdb_cls, capman): def _get_pdb_wrapper_class(cls, pdb_cls, capman: "CaptureManager"):
import _pytest.config import _pytest.config
class PytestPdbWrapper(pdb_cls): # Type ignored because mypy doesn't support "dynamic"
# inheritance like this.
class PytestPdbWrapper(pdb_cls): # type: ignore[valid-type,misc] # noqa: F821
_pytest_capman = capman _pytest_capman = capman
_continued = False _continued = False
@ -257,7 +263,7 @@ class pytestPDB:
return _pdb return _pdb
@classmethod @classmethod
def set_trace(cls, *args, **kwargs): def set_trace(cls, *args, **kwargs) -> None:
"""Invoke debugging via ``Pdb.set_trace``, dropping any IO capturing.""" """Invoke debugging via ``Pdb.set_trace``, dropping any IO capturing."""
frame = sys._getframe().f_back frame = sys._getframe().f_back
_pdb = cls._init_pdb("set_trace", *args, **kwargs) _pdb = cls._init_pdb("set_trace", *args, **kwargs)
@ -276,14 +282,14 @@ class PdbInvoke:
sys.stdout.write(err) sys.stdout.write(err)
_enter_pdb(node, call.excinfo, report) _enter_pdb(node, call.excinfo, report)
def pytest_internalerror(self, excrepr, excinfo): def pytest_internalerror(self, excrepr, excinfo) -> None:
tb = _postmortem_traceback(excinfo) tb = _postmortem_traceback(excinfo)
post_mortem(tb) post_mortem(tb)
class PdbTrace: class PdbTrace:
@hookimpl(hookwrapper=True) @hookimpl(hookwrapper=True)
def pytest_pyfunc_call(self, pyfuncitem): def pytest_pyfunc_call(self, pyfuncitem) -> Generator[None, None, None]:
wrap_pytest_function_for_tracing(pyfuncitem) wrap_pytest_function_for_tracing(pyfuncitem)
yield yield
@ -358,7 +364,7 @@ def _postmortem_traceback(excinfo):
return excinfo._excinfo[2] return excinfo._excinfo[2]
def post_mortem(t): def post_mortem(t) -> None:
p = pytestPDB._init_pdb("post_mortem") p = pytestPDB._init_pdb("post_mortem")
p.reset() p.reset()
p.interaction(None, t) p.interaction(None, t)

View File

@ -99,7 +99,7 @@ class FaultHandlerHooks:
yield yield
@pytest.hookimpl(tryfirst=True) @pytest.hookimpl(tryfirst=True)
def pytest_enter_pdb(self): def pytest_enter_pdb(self) -> None:
"""Cancel any traceback dumping due to timeout before entering pdb. """Cancel any traceback dumping due to timeout before entering pdb.
""" """
import faulthandler import faulthandler

View File

@ -15,7 +15,9 @@ from .deprecated import WARNING_CAPTURED_HOOK
from _pytest.compat import TYPE_CHECKING from _pytest.compat import TYPE_CHECKING
if TYPE_CHECKING: if TYPE_CHECKING:
import pdb
import warnings import warnings
from _pytest.config import Config from _pytest.config import Config
from _pytest.config import ExitCode from _pytest.config import ExitCode
from _pytest.config import PytestPluginManager from _pytest.config import PytestPluginManager
@ -773,7 +775,7 @@ def pytest_exception_interact(
""" """
def pytest_enter_pdb(config: "Config", pdb): def pytest_enter_pdb(config: "Config", pdb: "pdb.Pdb") -> None:
""" called upon pdb.set_trace(), can be used by plugins to take special """ called upon pdb.set_trace(), can be used by plugins to take special
action just before the python debugger enters in interactive mode. action just before the python debugger enters in interactive mode.
@ -782,7 +784,7 @@ def pytest_enter_pdb(config: "Config", pdb):
""" """
def pytest_leave_pdb(config: "Config", pdb): def pytest_leave_pdb(config: "Config", pdb: "pdb.Pdb") -> None:
""" called when leaving pdb (e.g. with continue after pdb.set_trace()). """ called when leaving pdb (e.g. with continue after pdb.set_trace()).
Can be used by plugins to take special action just after the python Can be used by plugins to take special action just after the python