Type annotate _pytest.debugging (a bit)
This commit is contained in:
parent
216a010ab7
commit
01797e6370
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue