From d858e8379c9dfac2078c56c5ce223c27616a5827 Mon Sep 17 00:00:00 2001 From: Chris Dent Date: Mon, 28 Nov 2016 21:02:38 +0000 Subject: [PATCH] Add docs explaining use of new pytest technique loader.rst has been expanded to explain both ways for loading tests using pytest, hopefully with sufficient context to explain why it is like it is. With any luck this will help make the obvious cleaner solution more apparent as we iterate into the future. --- docs/source/loader.rst | 43 +++++++++++++++++++++++++------- docs/source/pytest3.0-example.py | 30 ++++++++++++++++++++++ 2 files changed, 64 insertions(+), 9 deletions(-) create mode 100644 docs/source/pytest3.0-example.py diff --git a/docs/source/loader.rst b/docs/source/loader.rst index aca6842..496ed4f 100644 --- a/docs/source/loader.rst +++ b/docs/source/loader.rst @@ -67,7 +67,35 @@ pytest .. _pytest_loader: Since pytest does not support the ``load_tests`` system, a different -way of generating tests is required. A test file must be created +way of generating tests is required. Two techniques are supported. + +The original method (described below) used yield statements to +generate tests which pytest would collect. This style of tests is +deprecated as of ``pytest>=3.0`` so a new style using pytest +fixtures has been developed. + +pytest >= 3.0 +------------- + +In the newer technique, a test file is created that uses the +``pytest_generate_tests`` hook. Special care must be taken to always +import the ``test_pytest`` method which is the base test that the +pytest hook parametrizes to generate the tests from the YAML files. +Without the method, the hook will not be called and no tests generated. + +Here is a simple example file: + +.. literalinclude:: pytest3.0-example.py + :language: python + +This can then be run with the usual pytest commands. For example:: + + py.test -svx pytest3.0-example.py + +pytest < 3.0 +------------ + +When using the older technique, test file must be created that calls :meth:`~gabbi.driver.py_test_generator` and yields the generated tests. That will look a bit like this: @@ -78,14 +106,11 @@ This can then be run with the usual pytest commands. For example:: py.test -svx pytest-example.py -.. warning:: In ``pytest>=3.0`` yield tests are deprecated and using - them will cause pytest to produce a warning. If you - wish to ignore and hide these warnings add the - ``--disable-pytest-warnings`` parameter to the - invocation of ``py.test`` or use a version of pytest - earlier than version ``3.0``. A new way of creating gabbi - tests that works more effectively with modern pytest is - being developed. +The older technique will continue to work with all versions of +``pytest<4.0`` but ``>=3.0`` will produce warnings. If you want to +use the older technique but not see the warnings add +``--disable-pytest-warnings`` parameter to the invocation of +``py.test``. .. _source distribution: https://github.com/cdent/gabbi .. _the tutorial repo: https://github.com/cdent/gabbi-demo diff --git a/docs/source/pytest3.0-example.py b/docs/source/pytest3.0-example.py new file mode 100644 index 0000000..85f7c30 --- /dev/null +++ b/docs/source/pytest3.0-example.py @@ -0,0 +1,30 @@ +"""A sample pytest module for pytest >= 3.0.""" + +# For pathname munging +import os + +# The module that py_test_generator comes from. +from gabbi import driver + +# We need test_pytest so that pytest test collection works properly. +# Without this, the pytest_generate_tests method below will not be +# called. +from gabbi.driver import test_pytest # noqa + +# We need access to the WSGI application that hosts our service +from myapp import wsgiapp + +# We're using fixtures in the YAML files, we need to know where to +# load them from. +from myapp.test import fixtures + +# By convention the YAML files are put in a directory named +# "gabbits" that is in the same directory as the Python test file. +TESTS_DIR = 'gabbits' + + +def pytest_generate_tests(metafunc): + test_dir = os.path.join(os.path.dirname(__file__), TESTS_DIR) + driver.py_test_generator( + test_dir, intercept=wsgiapp.app, + fixture_module=fixtures, metafunc=metafunc)