279 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			279 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			Python
		
	
	
	
from __future__ import absolute_import, division, print_function
 | 
						|
 | 
						|
 | 
						|
import pytest
 | 
						|
 | 
						|
 | 
						|
def test_yield_tests_deprecation(testdir):
 | 
						|
    testdir.makepyfile(
 | 
						|
        """
 | 
						|
        def func1(arg, arg2):
 | 
						|
            assert arg == arg2
 | 
						|
        def test_gen():
 | 
						|
            yield "m1", func1, 15, 3*5
 | 
						|
            yield "m2", func1, 42, 6*7
 | 
						|
        def test_gen2():
 | 
						|
            for k in range(10):
 | 
						|
                yield func1, 1, 1
 | 
						|
    """
 | 
						|
    )
 | 
						|
    result = testdir.runpytest("-ra")
 | 
						|
    result.stdout.fnmatch_lines(
 | 
						|
        [
 | 
						|
            "*yield tests are deprecated, and scheduled to be removed in pytest 4.0*",
 | 
						|
            "*2 passed*",
 | 
						|
        ]
 | 
						|
    )
 | 
						|
    assert result.stdout.str().count("yield tests are deprecated") == 2
 | 
						|
 | 
						|
 | 
						|
def test_funcarg_prefix_deprecation(testdir):
 | 
						|
    testdir.makepyfile(
 | 
						|
        """
 | 
						|
        def pytest_funcarg__value():
 | 
						|
            return 10
 | 
						|
 | 
						|
        def test_funcarg_prefix(value):
 | 
						|
            assert value == 10
 | 
						|
    """
 | 
						|
    )
 | 
						|
    result = testdir.runpytest("-ra")
 | 
						|
    result.stdout.fnmatch_lines(
 | 
						|
        [
 | 
						|
            (
 | 
						|
                "*pytest_funcarg__value: "
 | 
						|
                'declaring fixtures using "pytest_funcarg__" prefix is deprecated '
 | 
						|
                "and scheduled to be removed in pytest 4.0.  "
 | 
						|
                "Please remove the prefix and use the @pytest.fixture decorator instead."
 | 
						|
            ),
 | 
						|
            "*1 passed*",
 | 
						|
        ]
 | 
						|
    )
 | 
						|
 | 
						|
 | 
						|
def test_pytest_setup_cfg_deprecated(testdir):
 | 
						|
    testdir.makefile(
 | 
						|
        ".cfg",
 | 
						|
        setup="""
 | 
						|
        [pytest]
 | 
						|
        addopts = --verbose
 | 
						|
    """,
 | 
						|
    )
 | 
						|
    result = testdir.runpytest()
 | 
						|
    result.stdout.fnmatch_lines(
 | 
						|
        ["*pytest*section in setup.cfg files is deprecated*use*tool:pytest*instead*"]
 | 
						|
    )
 | 
						|
 | 
						|
 | 
						|
def test_pytest_custom_cfg_deprecated(testdir):
 | 
						|
    testdir.makefile(
 | 
						|
        ".cfg",
 | 
						|
        custom="""
 | 
						|
        [pytest]
 | 
						|
        addopts = --verbose
 | 
						|
    """,
 | 
						|
    )
 | 
						|
    result = testdir.runpytest("-c", "custom.cfg")
 | 
						|
    result.stdout.fnmatch_lines(
 | 
						|
        ["*pytest*section in custom.cfg files is deprecated*use*tool:pytest*instead*"]
 | 
						|
    )
 | 
						|
 | 
						|
 | 
						|
def test_str_args_deprecated(tmpdir, testdir):
 | 
						|
    """Deprecate passing strings to pytest.main(). Scheduled for removal in pytest-4.0."""
 | 
						|
    from _pytest.main import EXIT_NOTESTSCOLLECTED
 | 
						|
 | 
						|
    warnings = []
 | 
						|
 | 
						|
    class Collect(object):
 | 
						|
        def pytest_logwarning(self, message):
 | 
						|
            warnings.append(message)
 | 
						|
 | 
						|
    ret = pytest.main("%s -x" % tmpdir, plugins=[Collect()])
 | 
						|
    msg = (
 | 
						|
        "passing a string to pytest.main() is deprecated, "
 | 
						|
        "pass a list of arguments instead."
 | 
						|
    )
 | 
						|
    assert msg in warnings
 | 
						|
    assert ret == EXIT_NOTESTSCOLLECTED
 | 
						|
 | 
						|
 | 
						|
def test_getfuncargvalue_is_deprecated(request):
 | 
						|
    pytest.deprecated_call(request.getfuncargvalue, "tmpdir")
 | 
						|
 | 
						|
 | 
						|
def test_resultlog_is_deprecated(testdir):
 | 
						|
    result = testdir.runpytest("--help")
 | 
						|
    result.stdout.fnmatch_lines(["*DEPRECATED path for machine-readable result log*"])
 | 
						|
 | 
						|
    testdir.makepyfile(
 | 
						|
        """
 | 
						|
        def test():
 | 
						|
            pass
 | 
						|
    """
 | 
						|
    )
 | 
						|
    result = testdir.runpytest("--result-log=%s" % testdir.tmpdir.join("result.log"))
 | 
						|
    result.stdout.fnmatch_lines(
 | 
						|
        [
 | 
						|
            "*--result-log is deprecated and scheduled for removal in pytest 4.0*",
 | 
						|
            "*See https://docs.pytest.org/*/usage.html#creating-resultlog-format-files for more information*",
 | 
						|
        ]
 | 
						|
    )
 | 
						|
 | 
						|
 | 
						|
@pytest.mark.filterwarnings("always:Metafunc.addcall is deprecated")
 | 
						|
def test_metafunc_addcall_deprecated(testdir):
 | 
						|
    testdir.makepyfile(
 | 
						|
        """
 | 
						|
        def pytest_generate_tests(metafunc):
 | 
						|
            metafunc.addcall({'i': 1})
 | 
						|
            metafunc.addcall({'i': 2})
 | 
						|
        def test_func(i):
 | 
						|
            pass
 | 
						|
    """
 | 
						|
    )
 | 
						|
    res = testdir.runpytest("-s")
 | 
						|
    assert res.ret == 0
 | 
						|
    res.stdout.fnmatch_lines(
 | 
						|
        ["*Metafunc.addcall is deprecated*", "*2 passed, 2 warnings*"]
 | 
						|
    )
 | 
						|
 | 
						|
 | 
						|
def test_terminal_reporter_writer_attr(pytestconfig):
 | 
						|
    """Check that TerminalReporter._tw is also available as 'writer' (#2984)
 | 
						|
    This attribute is planned to be deprecated in 3.4.
 | 
						|
    """
 | 
						|
    try:
 | 
						|
        import xdist  # noqa
 | 
						|
 | 
						|
        pytest.skip("xdist workers disable the terminal reporter plugin")
 | 
						|
    except ImportError:
 | 
						|
        pass
 | 
						|
    terminal_reporter = pytestconfig.pluginmanager.get_plugin("terminalreporter")
 | 
						|
    assert terminal_reporter.writer is terminal_reporter._tw
 | 
						|
 | 
						|
 | 
						|
@pytest.mark.parametrize("plugin", ["catchlog", "capturelog"])
 | 
						|
def test_pytest_catchlog_deprecated(testdir, plugin):
 | 
						|
    testdir.makepyfile(
 | 
						|
        """
 | 
						|
        def test_func(pytestconfig):
 | 
						|
            pytestconfig.pluginmanager.register(None, 'pytest_{}')
 | 
						|
    """.format(
 | 
						|
            plugin
 | 
						|
        )
 | 
						|
    )
 | 
						|
    res = testdir.runpytest()
 | 
						|
    assert res.ret == 0
 | 
						|
    res.stdout.fnmatch_lines(
 | 
						|
        ["*pytest-*log plugin has been merged into the core*", "*1 passed, 1 warnings*"]
 | 
						|
    )
 | 
						|
 | 
						|
 | 
						|
def test_pytest_plugins_in_non_top_level_conftest_deprecated(testdir):
 | 
						|
    from _pytest.deprecated import PYTEST_PLUGINS_FROM_NON_TOP_LEVEL_CONFTEST
 | 
						|
 | 
						|
    subdirectory = testdir.tmpdir.join("subdirectory")
 | 
						|
    subdirectory.mkdir()
 | 
						|
    # create the inner conftest with makeconftest and then move it to the subdirectory
 | 
						|
    testdir.makeconftest(
 | 
						|
        """
 | 
						|
        pytest_plugins=['capture']
 | 
						|
    """
 | 
						|
    )
 | 
						|
    testdir.tmpdir.join("conftest.py").move(subdirectory.join("conftest.py"))
 | 
						|
    # make the top level conftest
 | 
						|
    testdir.makeconftest(
 | 
						|
        """
 | 
						|
        import warnings
 | 
						|
        warnings.filterwarnings('always', category=DeprecationWarning)
 | 
						|
    """
 | 
						|
    )
 | 
						|
    testdir.makepyfile(
 | 
						|
        """
 | 
						|
        def test_func():
 | 
						|
            pass
 | 
						|
    """
 | 
						|
    )
 | 
						|
    res = testdir.runpytest_subprocess()
 | 
						|
    assert res.ret == 0
 | 
						|
    res.stderr.fnmatch_lines(
 | 
						|
        "*" + str(PYTEST_PLUGINS_FROM_NON_TOP_LEVEL_CONFTEST).splitlines()[0]
 | 
						|
    )
 | 
						|
 | 
						|
 | 
						|
def test_pytest_plugins_in_non_top_level_conftest_deprecated_no_top_level_conftest(
 | 
						|
    testdir
 | 
						|
):
 | 
						|
    from _pytest.deprecated import PYTEST_PLUGINS_FROM_NON_TOP_LEVEL_CONFTEST
 | 
						|
 | 
						|
    subdirectory = testdir.tmpdir.join("subdirectory")
 | 
						|
    subdirectory.mkdir()
 | 
						|
    testdir.makeconftest(
 | 
						|
        """
 | 
						|
        import warnings
 | 
						|
        warnings.filterwarnings('always', category=DeprecationWarning)
 | 
						|
        pytest_plugins=['capture']
 | 
						|
    """
 | 
						|
    )
 | 
						|
    testdir.tmpdir.join("conftest.py").move(subdirectory.join("conftest.py"))
 | 
						|
 | 
						|
    testdir.makepyfile(
 | 
						|
        """
 | 
						|
        def test_func():
 | 
						|
            pass
 | 
						|
    """
 | 
						|
    )
 | 
						|
 | 
						|
    res = testdir.runpytest_subprocess()
 | 
						|
    assert res.ret == 0
 | 
						|
    res.stderr.fnmatch_lines(
 | 
						|
        "*" + str(PYTEST_PLUGINS_FROM_NON_TOP_LEVEL_CONFTEST).splitlines()[0]
 | 
						|
    )
 | 
						|
 | 
						|
 | 
						|
def test_pytest_plugins_in_non_top_level_conftest_deprecated_no_false_positives(
 | 
						|
    testdir
 | 
						|
):
 | 
						|
    from _pytest.deprecated import PYTEST_PLUGINS_FROM_NON_TOP_LEVEL_CONFTEST
 | 
						|
 | 
						|
    subdirectory = testdir.tmpdir.join("subdirectory")
 | 
						|
    subdirectory.mkdir()
 | 
						|
    testdir.makeconftest(
 | 
						|
        """
 | 
						|
        pass
 | 
						|
    """
 | 
						|
    )
 | 
						|
    testdir.tmpdir.join("conftest.py").move(subdirectory.join("conftest.py"))
 | 
						|
 | 
						|
    testdir.makeconftest(
 | 
						|
        """
 | 
						|
        import warnings
 | 
						|
        warnings.filterwarnings('always', category=DeprecationWarning)
 | 
						|
        pytest_plugins=['capture']
 | 
						|
    """
 | 
						|
    )
 | 
						|
    testdir.makepyfile(
 | 
						|
        """
 | 
						|
        def test_func():
 | 
						|
            pass
 | 
						|
    """
 | 
						|
    )
 | 
						|
    res = testdir.runpytest_subprocess()
 | 
						|
    assert res.ret == 0
 | 
						|
    assert (
 | 
						|
        str(PYTEST_PLUGINS_FROM_NON_TOP_LEVEL_CONFTEST).splitlines()[0]
 | 
						|
        not in res.stderr.str()
 | 
						|
    )
 | 
						|
 | 
						|
 | 
						|
def test_call_fixture_function_deprecated():
 | 
						|
    """Check if a warning is raised if a fixture function is called directly (#3661)"""
 | 
						|
 | 
						|
    @pytest.fixture
 | 
						|
    def fix():
 | 
						|
        return 1
 | 
						|
 | 
						|
    with pytest.deprecated_call():
 | 
						|
        assert fix() == 1
 |