From d0bf65e6c80fce555adb3dfa2ab38f0ef94b5764 Mon Sep 17 00:00:00 2001 From: holger krekel Date: Sun, 16 Dec 2012 11:28:17 +0100 Subject: [PATCH] adding an example on how to do interact with the list of collected tests once before any tests are run --- doc/en/example/index.txt | 1 + doc/en/example/special.txt | 57 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 58 insertions(+) create mode 100644 doc/en/example/special.txt diff --git a/doc/en/example/index.txt b/doc/en/example/index.txt index 7af2a3cac..eb02e6c69 100644 --- a/doc/en/example/index.txt +++ b/doc/en/example/index.txt @@ -29,5 +29,6 @@ The following examples aim at various use cases you might encounter. simple.txt parametrize.txt markers.txt + special.txt pythoncollection.txt nonpython.txt diff --git a/doc/en/example/special.txt b/doc/en/example/special.txt new file mode 100644 index 000000000..7b09a1476 --- /dev/null +++ b/doc/en/example/special.txt @@ -0,0 +1,57 @@ + +A sesssion-fixture which can look at all collected tests +---------------------------------------------------------------- + +A session-scoped fixture effectively has access to all +collected test items. Here is an example of a fixture +function which walks all collected tests and looks +if their test class defines a ``callme`` method and +calls it:: + + # content of conftest.py + + import pytest + + @pytest.fixture(scope="session", autouse=True) + def callattr_ahead_of_alltests(request): + print "callattr_ahead_of_alltests called" + seen = set([None]) + session = request.node + for item in session.items: + instance = item.getparent(pytest.Instance) + if instance not in seen: + if hasattr(instance.obj, "callme"): + instance.obj.callme() + seen.add(instance) + +test classes may now define a ``callme`` method which +will be called ahead of running any tests:: + + # content of test_module.py + + class TestHello: + def callme(self): + print "callme called!" + + def test_method1(self): + print "test_method1 called" + + def test_method2(self): + print "test_method1 called" + + class TestOther: + def callme(self): + print "callme other called" + def test_other(self): + print "test other" + +If you run this without output capturing:: + + $ py.test -q -s test_module.py + ... + callattr_ahead_of_alltests called + callme called! + callme other called + test_method1 called + test_method1 called + test other