update configuration examples to new mark api

This commit is contained in:
Ronny Pfannschmidt 2018-03-30 08:36:58 +02:00
parent e4a52c1795
commit 7454a381e2
4 changed files with 30 additions and 34 deletions

View File

@ -330,11 +330,10 @@ specifies via named environments::
"env(name): mark test to run only on named environment") "env(name): mark test to run only on named environment")
def pytest_runtest_setup(item): def pytest_runtest_setup(item):
envmarker = item.get_marker("env") envnames = [mark.args[0] for mark in item.iter_markers() if mark.name == "env"]
if envmarker is not None: if envnames:
envname = envmarker.args[0] if item.config.getoption("-E") not in envnames:
if envname != item.config.getoption("-E"): pytest.skip("test requires env in %r" % envnames)
pytest.skip("test requires env %r" % envname)
A test file using this local plugin:: A test file using this local plugin::
@ -403,10 +402,9 @@ Below is the config file that will be used in the next examples::
import sys import sys
def pytest_runtest_setup(item): def pytest_runtest_setup(item):
marker = item.get_marker('my_marker') for marker in item.iter_markers():
if marker is not None: if marker.name == 'my_marker':
for info in marker: print(marker)
print('Marker info name={} args={} kwars={}'.format(info.name, info.args, info.kwargs))
sys.stdout.flush() sys.stdout.flush()
A custom marker can have its argument set, i.e. ``args`` and ``kwargs`` properties, defined by either invoking it as a callable or using ``pytest.mark.MARKER_NAME.with_args``. These two methods achieve the same effect most of the time. A custom marker can have its argument set, i.e. ``args`` and ``kwargs`` properties, defined by either invoking it as a callable or using ``pytest.mark.MARKER_NAME.with_args``. These two methods achieve the same effect most of the time.
@ -426,7 +424,7 @@ However, if there is a callable as the single positional argument with no keywor
The output is as follows:: The output is as follows::
$ pytest -q -s $ pytest -q -s
Marker info name=my_marker args=(<function hello_world at 0xdeadbeef>,) kwars={} Mark(name='my_marker', args=(<function hello_world at 0xdeadbeef>,), kwargs={})
. .
1 passed in 0.12 seconds 1 passed in 0.12 seconds
@ -460,10 +458,9 @@ test function. From a conftest file we can read it like this::
import sys import sys
def pytest_runtest_setup(item): def pytest_runtest_setup(item):
g = item.get_marker("glob") for mark in item.iter_markers():
if g is not None: if mark.name == 'glob':
for info in g: print ("glob args=%s kwargs=%s" %(mark.args, mark.kwargs))
print ("glob args=%s kwargs=%s" %(info.args, info.kwargs))
sys.stdout.flush() sys.stdout.flush()
Let's run this without capturing output and see what we get:: Let's run this without capturing output and see what we get::
@ -494,11 +491,10 @@ for your particular platform, you could use the following plugin::
ALL = set("darwin linux win32".split()) ALL = set("darwin linux win32".split())
def pytest_runtest_setup(item): def pytest_runtest_setup(item):
if isinstance(item, item.Function): supported_platforms = ALL.intersection(mark.name for mark in item.iter_markers())
plat = sys.platform plat = sys.platform
if not item.get_marker(plat): if supported_platforms and plat not in supported_platforms:
if ALL.intersection(item.keywords): pytest.skip("cannot run on platform %s" % (plat))
pytest.skip("cannot run on platform %s" %(plat))
then tests will be skipped if they were specified for a different platform. then tests will be skipped if they were specified for a different platform.
Let's do a little test file to show how this looks like:: Let's do a little test file to show how this looks like::
@ -532,7 +528,7 @@ then you will see two tests skipped and two executed tests as expected::
test_plat.py s.s. [100%] test_plat.py s.s. [100%]
========================= short test summary info ========================== ========================= short test summary info ==========================
SKIP [2] $REGENDOC_TMPDIR/conftest.py:13: cannot run on platform linux SKIP [2] $REGENDOC_TMPDIR/conftest.py:12: cannot run on platform linux
=================== 2 passed, 2 skipped in 0.12 seconds ==================== =================== 2 passed, 2 skipped in 0.12 seconds ====================

View File

@ -389,7 +389,7 @@ Now we can profile which test functions execute the slowest::
========================= slowest 3 test durations ========================= ========================= slowest 3 test durations =========================
0.30s call test_some_are_slow.py::test_funcslow2 0.30s call test_some_are_slow.py::test_funcslow2
0.20s call test_some_are_slow.py::test_funcslow1 0.20s call test_some_are_slow.py::test_funcslow1
0.16s call test_some_are_slow.py::test_funcfast 0.10s call test_some_are_slow.py::test_funcfast
========================= 3 passed in 0.12 seconds ========================= ========================= 3 passed in 0.12 seconds =========================
incremental testing - test steps incremental testing - test steps

View File

@ -260,10 +260,10 @@ Alternatively, you can integrate this functionality with custom markers:
def pytest_collection_modifyitems(session, config, items): def pytest_collection_modifyitems(session, config, items):
for item in items: for item in items:
marker = item.get_marker('test_id') for marker in item.iter_markers():
if marker is not None: if marker.name == 'test_id':
test_id = marker.args[0] test_id = marker.args[0]
item.user_properties.append(('test_id', test_id)) item.user_properties.append(('test_id', test_id))
And in your tests: And in your tests: