Merge pull request #5886 from nicoddemus/setup-plan-custom-items-5884

Fix --setup-only and --setup-show for custom pytest items
This commit is contained in:
Anthony Sottile 2019-09-28 18:08:36 -07:00 committed by GitHub
commit b62276826c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 36 additions and 8 deletions

View File

@ -0,0 +1 @@
Fix ``--setup-only`` and ``--setup-show`` for custom pytest items.

View File

@ -107,8 +107,8 @@ def show_test_item(item):
tw = item.config.get_terminal_writer() tw = item.config.get_terminal_writer()
tw.line() tw.line()
tw.write(" " * 8) tw.write(" " * 8)
tw.write(item._nodeid) tw.write(item.nodeid)
used_fixtures = sorted(item._fixtureinfo.name2fixturedefs.keys()) used_fixtures = sorted(getattr(item, "fixturenames", []))
if used_fixtures: if used_fixtures:
tw.write(" (fixtures used: {})".format(", ".join(used_fixtures))) tw.write(" (fixtures used: {})".format(", ".join(used_fixtures)))

View File

@ -88,3 +88,30 @@ def tw_mock():
fullwidth = 80 fullwidth = 80
return TWMock() return TWMock()
@pytest.fixture
def dummy_yaml_custom_test(testdir):
"""Writes a conftest file that collects and executes a dummy yaml test.
Taken from the docs, but stripped down to the bare minimum, useful for
tests which needs custom items collected.
"""
testdir.makeconftest(
"""
import pytest
def pytest_collect_file(parent, path):
if path.ext == ".yaml" and path.basename.startswith("test"):
return YamlFile(path, parent)
class YamlFile(pytest.File):
def collect(self):
yield YamlItem(self.fspath.basename, self)
class YamlItem(pytest.Item):
def runtest(self):
pass
"""
)
testdir.makefile(".yaml", test1="")

View File

@ -6,8 +6,8 @@ def mode(request):
return request.param return request.param
def test_show_only_active_fixtures(testdir, mode): def test_show_only_active_fixtures(testdir, mode, dummy_yaml_custom_test):
p = testdir.makepyfile( testdir.makepyfile(
''' '''
import pytest import pytest
@pytest.fixture @pytest.fixture
@ -21,7 +21,7 @@ def test_show_only_active_fixtures(testdir, mode):
''' '''
) )
result = testdir.runpytest(mode, p) result = testdir.runpytest(mode)
assert result.ret == 0 assert result.ret == 0
result.stdout.fnmatch_lines( result.stdout.fnmatch_lines(

View File

@ -1,6 +1,6 @@
def test_show_fixtures_and_test(testdir): def test_show_fixtures_and_test(testdir, dummy_yaml_custom_test):
""" Verifies that fixtures are not executed. """ """ Verifies that fixtures are not executed. """
p = testdir.makepyfile( testdir.makepyfile(
""" """
import pytest import pytest
@pytest.fixture @pytest.fixture
@ -11,7 +11,7 @@ def test_show_fixtures_and_test(testdir):
""" """
) )
result = testdir.runpytest("--setup-plan", p) result = testdir.runpytest("--setup-plan")
assert result.ret == 0 assert result.ret == 0
result.stdout.fnmatch_lines( result.stdout.fnmatch_lines(