nose: type annotate with some resulting refactoring
This commit is contained in:
parent
096bae6c68
commit
3dde519f53
|
@ -1,33 +1,35 @@
|
||||||
"""Run testsuites written for nose."""
|
"""Run testsuites written for nose."""
|
||||||
from _pytest import python
|
|
||||||
from _pytest import unittest
|
|
||||||
from _pytest.config import hookimpl
|
from _pytest.config import hookimpl
|
||||||
from _pytest.fixtures import getfixturemarker
|
from _pytest.fixtures import getfixturemarker
|
||||||
from _pytest.nodes import Item
|
from _pytest.nodes import Item
|
||||||
|
from _pytest.python import Function
|
||||||
|
from _pytest.unittest import TestCaseFunction
|
||||||
|
|
||||||
|
|
||||||
@hookimpl(trylast=True)
|
@hookimpl(trylast=True)
|
||||||
def pytest_runtest_setup(item) -> None:
|
def pytest_runtest_setup(item: Item) -> None:
|
||||||
if is_potential_nosetest(item):
|
if not isinstance(item, Function):
|
||||||
if not call_optional(item.obj, "setup"):
|
return
|
||||||
|
# Don't do nose style setup/teardown on direct unittest style classes.
|
||||||
|
if isinstance(item, TestCaseFunction):
|
||||||
|
return
|
||||||
|
|
||||||
|
# Capture the narrowed type of item for the teardown closure,
|
||||||
|
# see https://github.com/python/mypy/issues/2608
|
||||||
|
func = item
|
||||||
|
|
||||||
|
if not call_optional(func.obj, "setup"):
|
||||||
# Call module level setup if there is no object level one.
|
# Call module level setup if there is no object level one.
|
||||||
call_optional(item.parent.obj, "setup")
|
assert func.parent is not None
|
||||||
|
call_optional(func.parent.obj, "setup") # type: ignore[attr-defined]
|
||||||
|
|
||||||
|
def teardown_nose() -> None:
|
||||||
|
if not call_optional(func.obj, "teardown"):
|
||||||
|
assert func.parent is not None
|
||||||
|
call_optional(func.parent.obj, "teardown") # type: ignore[attr-defined]
|
||||||
|
|
||||||
# XXX This implies we only call teardown when setup worked.
|
# XXX This implies we only call teardown when setup worked.
|
||||||
item.addfinalizer(lambda: teardown_nose(item))
|
func.addfinalizer(teardown_nose)
|
||||||
|
|
||||||
|
|
||||||
def teardown_nose(item) -> None:
|
|
||||||
if is_potential_nosetest(item):
|
|
||||||
if not call_optional(item.obj, "teardown"):
|
|
||||||
call_optional(item.parent.obj, "teardown")
|
|
||||||
|
|
||||||
|
|
||||||
def is_potential_nosetest(item: Item) -> bool:
|
|
||||||
# Extra check needed since we do not do nose style setup/teardown
|
|
||||||
# on direct unittest style classes.
|
|
||||||
return isinstance(item, python.Function) and not isinstance(
|
|
||||||
item, unittest.TestCaseFunction
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
def call_optional(obj: object, name: str) -> bool:
|
def call_optional(obj: object, name: str) -> bool:
|
||||||
|
|
Loading…
Reference in New Issue