Doctest integration for modules and test files ========================================================= By default all files matching the ``test*.txt`` pattern will be run through the python standard ``doctest`` module. You can change the pattern by issuing:: py.test --doctest-glob='*.rst' on the command line. You can also trigger running of doctests from docstrings in all python modules (including regular python test modules):: py.test --doctest-modules You can make these changes permanent in your project by putting them into a pytest.ini file like this: .. code-block:: ini # content of pytest.ini [pytest] addopts = --doctest-modules If you then have a text file like this:: # content of example.rst hello this is a doctest >>> x = 3 >>> x 3 and another like this:: # content of mymodule.py def something(): """ a doctest in a docstring >>> something() 42 """ return 42 then you can just invoke ``py.test`` without command line options:: $ py.test ======= test session starts ======== platform linux2 -- Python 2.7.10, pytest-2.8.1.dev1, py-1.4.30, pluggy-0.3.1 rootdir: $REGENDOC_TMPDIR, inifile: pytest.ini collected 1 items mymodule.py . ======= 1 passed in 0.12 seconds ======== It is possible to use fixtures using the ``getfixture`` helper:: # content of example.rst >>> tmp = getfixture('tmpdir') >>> ... >>> Also, :ref:`usefixtures` and :ref:`autouse` fixtures are supported when executing text doctest files. The standard ``doctest`` module provides some setting flags to configure the strictness of doctest tests. In py.test You can enable those flags those flags using the configuration file. To make pytest ignore trailing whitespaces and ignore lengthy exception stack traces you can just write:: # content of pytest.ini [pytest] doctest_optionflags= NORMALIZE_WHITESPACE IGNORE_EXCEPTION_DETAIL py.test also introduces a new ``ALLOW_UNICODE`` option flag: when enabled, the ``u`` prefix is stripped from unicode strings in expected doctest output. This allows doctests which use unicode to run in Python 2 and 3 unchanged. As with any other option flag, this flag can be enabled in ``pytest.ini`` using the ``doctest_optionflags`` ini option or by an inline comment in the doc test itself:: # content of example.rst >>> get_unicode_greeting() # doctest: +ALLOW_UNICODE 'Hello'