Merge pull request #6981 from RonnyPfannschmidt/deprecate-pytest.collect

deprecate the pytest.collect module
This commit is contained in:
Ronny Pfannschmidt 2020-03-30 22:32:47 +02:00 committed by GitHub
commit 93b3fee783
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 54 additions and 30 deletions

View File

@ -0,0 +1 @@
Deprecate the ``pytest.collect`` module as it's just aliases into ``pytest``.

View File

@ -336,30 +336,6 @@ def safe_isclass(obj: object) -> bool:
return False return False
COLLECT_FAKEMODULE_ATTRIBUTES = (
"Collector",
"Module",
"Function",
"Instance",
"Session",
"Item",
"Class",
"File",
"_fillfuncargs",
)
def _setup_collect_fakemodule() -> None:
from types import ModuleType
import pytest
# Types ignored because the module is created dynamically.
pytest.collect = ModuleType("pytest.collect") # type: ignore
pytest.collect.__all__ = [] # type: ignore # used for setns
for attr_name in COLLECT_FAKEMODULE_ATTRIBUTES:
setattr(pytest.collect, attr_name, getattr(pytest, attr_name)) # type: ignore
class CaptureIO(io.TextIOWrapper): class CaptureIO(io.TextIOWrapper):
def __init__(self) -> None: def __init__(self) -> None:
super().__init__(io.BytesIO(), encoding="UTF-8", newline="", write_through=True) super().__init__(io.BytesIO(), encoding="UTF-8", newline="", write_through=True)

View File

@ -56,6 +56,12 @@ COLLECT_DIRECTORY_HOOK = PytestDeprecationWarning(
"Please use collect_ignore in conftests or pytest_collection_modifyitems." "Please use collect_ignore in conftests or pytest_collection_modifyitems."
) )
PYTEST_COLLECT_MODULE = UnformattedWarning(
PytestDeprecationWarning,
"pytest.collect.{name} was moved to pytest.{name}\n"
"Please update to the new name.",
)
TERMINALWRITER_WRITER = PytestDeprecationWarning( TERMINALWRITER_WRITER = PytestDeprecationWarning(
"The TerminalReporter.writer attribute is deprecated, use TerminalReporter._tw instead at your own risk.\n" "The TerminalReporter.writer attribute is deprecated, use TerminalReporter._tw instead at your own risk.\n"

View File

@ -2,9 +2,9 @@
""" """
pytest: unit and functional testing with Python. pytest: unit and functional testing with Python.
""" """
from . import collect
from _pytest import __version__ from _pytest import __version__
from _pytest.assertion import register_assert_rewrite from _pytest.assertion import register_assert_rewrite
from _pytest.compat import _setup_collect_fakemodule
from _pytest.config import cmdline from _pytest.config import cmdline
from _pytest.config import ExitCode from _pytest.config import ExitCode
from _pytest.config import hookimpl from _pytest.config import hookimpl
@ -46,7 +46,6 @@ from _pytest.warning_types import PytestUnhandledCoroutineWarning
from _pytest.warning_types import PytestUnknownMarkWarning from _pytest.warning_types import PytestUnknownMarkWarning
from _pytest.warning_types import PytestWarning from _pytest.warning_types import PytestWarning
set_trace = __pytestPDB.set_trace set_trace = __pytestPDB.set_trace
__all__ = [ __all__ = [
@ -55,6 +54,7 @@ __all__ = [
"approx", "approx",
"Class", "Class",
"cmdline", "cmdline",
"collect",
"Collector", "Collector",
"deprecated_call", "deprecated_call",
"exit", "exit",
@ -93,7 +93,3 @@ __all__ = [
"xfail", "xfail",
"yield_fixture", "yield_fixture",
] ]
_setup_collect_fakemodule()
del _setup_collect_fakemodule

38
src/pytest/collect.py Normal file
View File

@ -0,0 +1,38 @@
import sys
import warnings
from types import ModuleType
import pytest
from _pytest.deprecated import PYTEST_COLLECT_MODULE
COLLECT_FAKEMODULE_ATTRIBUTES = [
"Collector",
"Module",
"Function",
"Instance",
"Session",
"Item",
"Class",
"File",
"_fillfuncargs",
]
class FakeCollectModule(ModuleType):
def __init__(self):
super().__init__("pytest.collect")
self.__all__ = list(COLLECT_FAKEMODULE_ATTRIBUTES)
self.__pytest = pytest
def __dir__(self):
return dir(super()) + self.__all__
def __getattr__(self, name):
if name not in self.__all__:
raise AttributeError(name)
warnings.warn(PYTEST_COLLECT_MODULE.format(name=name), stacklevel=2)
return getattr(pytest, name)
sys.modules["pytest.collect"] = FakeCollectModule()

View File

@ -25,6 +25,13 @@ def test_resultlog_is_deprecated(testdir):
) )
@pytest.mark.parametrize("attribute", pytest.collect.__all__) # type: ignore
# false positive due to dynamic attribute
def test_pytest_collect_module_deprecated(attribute):
with pytest.warns(DeprecationWarning, match=attribute):
getattr(pytest.collect, attribute)
def test_terminal_reporter_writer_attr(pytestconfig): def test_terminal_reporter_writer_attr(pytestconfig):
"""Check that TerminalReporter._tw is also available as 'writer' (#2984) """Check that TerminalReporter._tw is also available as 'writer' (#2984)
This attribute has been deprecated in 5.4. This attribute has been deprecated in 5.4.