235 lines
6.5 KiB
ReStructuredText
235 lines
6.5 KiB
ReStructuredText
|
|
.. _usage:
|
|
|
|
How to invoke pytest
|
|
==========================================
|
|
|
|
.. seealso:: :ref:`Complete pytest command-line flag reference <command-line-flags>`
|
|
|
|
In general, pytest is invoked with the command ``pytest`` (see below for :ref:`other ways to invoke pytest
|
|
<invoke-other>`). This will execute all tests in all files whose names follow the form ``test_*.py`` or ``\*_test.py``
|
|
in the current directory and its subdirectories. More generally, pytest follows :ref:`standard test discovery rules
|
|
<test discovery>`.
|
|
|
|
|
|
.. _select-tests:
|
|
|
|
Specifying which tests to run
|
|
------------------------------
|
|
|
|
Pytest supports several ways to run and select tests from the command-line.
|
|
|
|
**Run tests in a module**
|
|
|
|
.. code-block:: bash
|
|
|
|
pytest test_mod.py
|
|
|
|
**Run tests in a directory**
|
|
|
|
.. code-block:: bash
|
|
|
|
pytest testing/
|
|
|
|
**Run tests by keyword expressions**
|
|
|
|
.. code-block:: bash
|
|
|
|
pytest -k "MyClass and not method"
|
|
|
|
This will run tests which contain names that match the given *string expression* (case-insensitive),
|
|
which can include Python operators that use filenames, class names and function names as variables.
|
|
The example above will run ``TestMyClass.test_something`` but not ``TestMyClass.test_method_simple``.
|
|
|
|
.. _nodeids:
|
|
|
|
**Run tests by node ids**
|
|
|
|
Each collected test is assigned a unique ``nodeid`` which consist of the module filename followed
|
|
by specifiers like class names, function names and parameters from parametrization, separated by ``::`` characters.
|
|
|
|
To run a specific test within a module:
|
|
|
|
.. code-block:: bash
|
|
|
|
pytest test_mod.py::test_func
|
|
|
|
|
|
Another example specifying a test method in the command line:
|
|
|
|
.. code-block:: bash
|
|
|
|
pytest test_mod.py::TestClass::test_method
|
|
|
|
**Run tests by marker expressions**
|
|
|
|
.. code-block:: bash
|
|
|
|
pytest -m slow
|
|
|
|
Will run all tests which are decorated with the ``@pytest.mark.slow`` decorator.
|
|
|
|
For more information see :ref:`marks <mark>`.
|
|
|
|
**Run tests from packages**
|
|
|
|
.. code-block:: bash
|
|
|
|
pytest --pyargs pkg.testing
|
|
|
|
This will import ``pkg.testing`` and use its filesystem location to find and run tests from.
|
|
|
|
|
|
Getting help on version, option names, environment variables
|
|
--------------------------------------------------------------
|
|
|
|
.. code-block:: bash
|
|
|
|
pytest --version # shows where pytest was imported from
|
|
pytest --fixtures # show available builtin function arguments
|
|
pytest -h | --help # show help on command line and config file options
|
|
|
|
|
|
.. _durations:
|
|
|
|
Profiling test execution duration
|
|
-------------------------------------
|
|
|
|
.. versionchanged:: 6.0
|
|
|
|
To get a list of the slowest 10 test durations over 1.0s long:
|
|
|
|
.. code-block:: bash
|
|
|
|
pytest --durations=10 --durations-min=1.0
|
|
|
|
By default, pytest will not show test durations that are too small (<0.005s) unless ``-vv`` is passed on the command-line.
|
|
|
|
|
|
Managing loading of plugins
|
|
-------------------------------
|
|
|
|
Early loading plugins
|
|
~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
You can early-load plugins (internal and external) explicitly in the command-line with the ``-p`` option::
|
|
|
|
pytest -p mypluginmodule
|
|
|
|
The option receives a ``name`` parameter, which can be:
|
|
|
|
* A full module dotted name, for example ``myproject.plugins``. This dotted name must be importable.
|
|
* The entry-point name of a plugin. This is the name passed to ``setuptools`` when the plugin is
|
|
registered. For example to early-load the `pytest-cov <https://pypi.org/project/pytest-cov/>`__ plugin you can use::
|
|
|
|
pytest -p pytest_cov
|
|
|
|
|
|
Disabling plugins
|
|
~~~~~~~~~~~~~~~~~~
|
|
|
|
To disable loading specific plugins at invocation time, use the ``-p`` option
|
|
together with the prefix ``no:``.
|
|
|
|
Example: to disable loading the plugin ``doctest``, which is responsible for
|
|
executing doctest tests from text files, invoke pytest like this:
|
|
|
|
.. code-block:: bash
|
|
|
|
pytest -p no:doctest
|
|
|
|
|
|
.. _invoke-other:
|
|
|
|
Other ways of calling pytest
|
|
-----------------------------------------------------
|
|
|
|
.. _invoke-python:
|
|
|
|
Calling pytest through ``python -m pytest``
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
You can invoke testing through the Python interpreter from the command line:
|
|
|
|
.. code-block:: text
|
|
|
|
python -m pytest [...]
|
|
|
|
This is almost equivalent to invoking the command line script ``pytest [...]``
|
|
directly, except that calling via ``python`` will also add the current directory to ``sys.path``.
|
|
|
|
|
|
.. _`pytest.main-usage`:
|
|
|
|
Calling pytest from Python code
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
You can invoke ``pytest`` from Python code directly:
|
|
|
|
.. code-block:: python
|
|
|
|
retcode = pytest.main()
|
|
|
|
this acts as if you would call "pytest" from the command line.
|
|
It will not raise :class:`SystemExit` but return the :ref:`exit code <exit-codes>` instead.
|
|
You can pass in options and arguments:
|
|
|
|
.. code-block:: python
|
|
|
|
retcode = pytest.main(["-x", "mytestdir"])
|
|
|
|
You can specify additional plugins to ``pytest.main``:
|
|
|
|
.. code-block:: python
|
|
|
|
# content of myinvoke.py
|
|
import pytest
|
|
import sys
|
|
|
|
|
|
class MyPlugin:
|
|
def pytest_sessionfinish(self):
|
|
print("*** test run reporting finishing")
|
|
|
|
|
|
if __name__ == "__main__":
|
|
sys.exit(pytest.main(["-qq"], plugins=[MyPlugin()]))
|
|
|
|
Running it will show that ``MyPlugin`` was added and its
|
|
hook was invoked:
|
|
|
|
.. code-block:: pytest
|
|
|
|
$ python myinvoke.py
|
|
.FEsxX. [100%]*** test run reporting finishing
|
|
|
|
================================== ERRORS ==================================
|
|
_______________________ ERROR at setup of test_error _______________________
|
|
|
|
@pytest.fixture
|
|
def error_fixture():
|
|
> assert 0
|
|
E assert 0
|
|
|
|
test_example.py:6: AssertionError
|
|
================================= FAILURES =================================
|
|
________________________________ test_fail _________________________________
|
|
|
|
def test_fail():
|
|
> assert 0
|
|
E assert 0
|
|
|
|
test_example.py:14: AssertionError
|
|
========================= short test summary info ==========================
|
|
FAILED test_example.py::test_fail - assert 0
|
|
ERROR test_example.py::test_error - assert 0
|
|
|
|
.. note::
|
|
|
|
Calling ``pytest.main()`` will result in importing your tests and any modules
|
|
that they import. Due to the caching mechanism of python's import system,
|
|
making subsequent calls to ``pytest.main()`` from the same process will not
|
|
reflect changes to those files between the calls. For this reason, making
|
|
multiple calls to ``pytest.main()`` from the same process (in order to re-run
|
|
tests, for example) is not recommended.
|