2021-03-17 04:26:05 +08:00
.. _`api-reference`:
2020-01-10 05:06:15 +08:00
2019-07-15 22:25:33 +08:00
API Reference
=============
2018-02-08 06:53:31 +08:00
This page contains the full reference to pytest's API.
2018-02-27 07:13:33 +08:00
.. contents ::
2018-02-28 04:32:34 +08:00
:depth: 3
2018-02-27 07:27:15 +08:00
:local:
2022-01-26 04:39:13 +08:00
Constants
---------
pytest.__version__
~~~~~~~~~~~~~~~~~~
The current pytest version, as a string::
>>> import pytest
>>> pytest.__version__
'7.0.0'
.. _`version-tuple`:
pytest.version_tuple
~~~~~~~~~~~~~~~~~~~~
.. versionadded :: 7.0
The current pytest version, as a tuple::
>>> import pytest
>>> pytest.version_tuple
(7, 0, 0)
For pre-releases, the last component will be a string with the prerelease version::
>>> import pytest
>>> pytest.version_tuple
(7, 0, '0rc1')
2018-03-02 05:07:06 +08:00
Functions
---------
2018-02-27 07:27:15 +08:00
2018-02-28 05:26:40 +08:00
pytest.approx
2018-03-02 05:07:06 +08:00
~~~~~~~~~~~~~
2018-02-27 07:34:53 +08:00
2020-06-14 21:52:09 +08:00
.. autofunction :: pytest.approx
2018-02-27 07:27:15 +08:00
2018-02-28 04:15:08 +08:00
pytest.fail
~~~~~~~~~~~
2018-02-27 07:34:53 +08:00
2018-03-02 05:07:06 +08:00
**Tutorial** : :ref: `skipping`
2021-11-08 22:31:14 +08:00
.. autofunction :: pytest.fail(reason, [pytrace=True, msg=None])
2018-02-27 07:34:53 +08:00
2018-02-28 04:15:08 +08:00
pytest.skip
~~~~~~~~~~~
2018-02-27 07:34:53 +08:00
2021-11-08 22:31:14 +08:00
.. autofunction :: pytest.skip(reason, [allow_module_level=False, msg=None])
2018-02-27 07:34:53 +08:00
2019-08-10 03:35:03 +08:00
.. _`pytest.importorskip ref`:
2018-02-28 04:15:08 +08:00
pytest.importorskip
~~~~~~~~~~~~~~~~~~~
2018-02-27 07:34:53 +08:00
2020-06-14 21:52:09 +08:00
.. autofunction :: pytest.importorskip
2018-02-27 07:34:53 +08:00
2018-02-28 04:15:08 +08:00
pytest.xfail
~~~~~~~~~~~~
2018-02-27 07:34:53 +08:00
2020-06-14 21:52:09 +08:00
.. autofunction :: pytest.xfail
2018-02-27 07:34:53 +08:00
2018-02-28 04:15:08 +08:00
pytest.exit
2018-03-02 05:07:06 +08:00
~~~~~~~~~~~
2018-02-27 07:34:53 +08:00
2021-11-08 22:31:14 +08:00
.. autofunction :: pytest.exit(reason, [returncode=False, msg=None])
2018-02-27 07:34:53 +08:00
2018-02-28 04:15:08 +08:00
pytest.main
2018-03-02 05:07:06 +08:00
~~~~~~~~~~~
2018-02-27 07:34:53 +08:00
2023-08-06 18:39:11 +08:00
**Tutorial** : :ref: `pytest.main-usage`
2020-06-14 21:52:09 +08:00
.. autofunction :: pytest.main
2018-02-27 07:27:15 +08:00
2018-03-01 07:34:20 +08:00
pytest.param
2019-03-16 19:06:33 +08:00
~~~~~~~~~~~~
2018-03-01 07:34:20 +08:00
2018-03-02 04:54:54 +08:00
.. autofunction :: pytest.param(*values, [id], [marks])
2018-03-01 07:34:20 +08:00
2018-02-28 04:15:08 +08:00
pytest.raises
2018-03-02 05:07:06 +08:00
~~~~~~~~~~~~~
2018-02-27 07:57:02 +08:00
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `assertraises`
2018-02-28 04:58:51 +08:00
2019-11-13 04:32:05 +08:00
.. autofunction :: pytest.raises(expected_exception: Exception [, *, match])
2018-02-27 07:57:02 +08:00
:with: excinfo
2018-02-27 07:27:15 +08:00
2018-02-28 04:15:08 +08:00
pytest.deprecated_call
2018-03-02 05:07:06 +08:00
~~~~~~~~~~~~~~~~~~~~~~
2018-02-27 07:34:53 +08:00
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `ensuring_function_triggers`
2018-02-28 04:58:51 +08:00
2021-10-30 02:18:12 +08:00
.. autofunction :: pytest.deprecated_call([match])
2018-02-27 07:57:02 +08:00
:with:
2018-02-08 06:53:31 +08:00
2018-03-02 04:54:54 +08:00
pytest.register_assert_rewrite
2018-03-02 05:07:06 +08:00
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2018-03-02 04:54:54 +08:00
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `assertion-rewriting`
2018-03-02 04:54:54 +08:00
.. autofunction :: pytest.register_assert_rewrite
2018-02-28 05:26:40 +08:00
pytest.warns
2018-03-02 05:07:06 +08:00
~~~~~~~~~~~~
2018-02-28 05:26:40 +08:00
**Tutorial** : :ref: `assertwarnings`
2018-03-02 04:54:54 +08:00
.. autofunction :: pytest.warns(expected_warning: Exception, [match])
2018-02-28 05:26:40 +08:00
:with:
2018-10-02 22:39:08 +08:00
pytest.freeze_includes
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `freezing-pytest`
2018-10-02 22:39:08 +08:00
.. autofunction :: pytest.freeze_includes
2018-03-02 05:20:55 +08:00
.. _`marks ref`:
2018-03-01 07:34:20 +08:00
Marks
-----
Marks can be used apply meta data to *test functions* (but not fixtures), which can then be accessed by
fixtures or plugins.
2018-04-06 00:39:57 +08:00
2018-03-23 00:02:30 +08:00
.. _`pytest.mark.filterwarnings ref`:
pytest.mark.filterwarnings
~~~~~~~~~~~~~~~~~~~~~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `filterwarnings`
2018-03-23 00:02:30 +08:00
Add warning filters to marked test items.
.. py:function :: pytest.mark.filterwarnings(filter)
:keyword str filter:
A *warning specification string* , which is composed of contents of the tuple `` (action, message, category, module, lineno) ``
2021-08-26 22:05:03 +08:00
as specified in :ref: `python:warning-filter` section of
2018-03-23 00:02:30 +08:00
the Python documentation, separated by `` ":" `` . Optional fields can be omitted.
2018-10-28 13:12:12 +08:00
Module names passed for filtering are not regex-escaped.
2018-03-23 00:02:30 +08:00
For example:
.. code-block :: python
2020-03-12 16:38:00 +08:00
@pytest.mark.filterwarnings("ignore:.*usage will be deprecated.* :DeprecationWarning")
2018-03-23 00:02:30 +08:00
def test_foo():
...
2018-03-01 07:34:20 +08:00
.. _`pytest.mark.parametrize ref`:
pytest.mark.parametrize
~~~~~~~~~~~~~~~~~~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `parametrize`
2018-03-01 07:34:20 +08:00
2020-12-27 02:49:17 +08:00
This mark has the same signature as :py:meth: `pytest.Metafunc.parametrize` ; see there.
2018-03-01 07:34:20 +08:00
.. _`pytest.mark.skip ref`:
pytest.mark.skip
~~~~~~~~~~~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `skip`
2018-03-01 07:34:20 +08:00
Unconditionally skip a test function.
2021-03-04 18:56:21 +08:00
.. py:function :: pytest.mark.skip(reason=None)
2018-03-01 07:34:20 +08:00
:keyword str reason: Reason why the test function is being skipped.
.. _`pytest.mark.skipif ref`:
pytest.mark.skipif
~~~~~~~~~~~~~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `skipif`
2018-03-01 07:34:20 +08:00
Skip a test function if a condition is `` True `` .
.. py:function :: pytest.mark.skipif(condition, *, reason=None)
:type condition: bool or str
:param condition: ``True/False`` if the condition should be skipped or a :ref:`condition string <string conditions>`.
:keyword str reason: Reason why the test function is being skipped.
2018-07-07 07:55:42 +08:00
.. _`pytest.mark.usefixtures ref`:
pytest.mark.usefixtures
~~~~~~~~~~~~~~~~~~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `usefixtures`
2018-07-07 07:55:42 +08:00
Mark a test function as using the given fixture names.
.. py:function :: pytest.mark.usefixtures(*names)
2020-07-14 15:55:17 +08:00
:param args: The names of the fixture to use, as strings.
2018-07-07 07:55:42 +08:00
2020-07-22 10:00:47 +08:00
.. note ::
When using `usefixtures` in hooks, it can only load fixtures when applied to a test function before test setup
(for example in the `pytest_collection_modifyitems` hook).
2020-10-22 18:11:49 +08:00
Also note that this mark has no effect when applied to **fixtures** .
2020-07-22 10:00:47 +08:00
2018-07-07 07:55:42 +08:00
2018-03-01 07:34:20 +08:00
.. _`pytest.mark.xfail ref`:
pytest.mark.xfail
~~~~~~~~~~~~~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `xfail`
2018-03-01 07:34:20 +08:00
Marks a test function as *expected to fail* .
2023-08-12 23:02:13 +08:00
.. py:function :: pytest.mark.xfail(condition=None, *, reason=None, raises=None, run=True, strict=xfail_strict)
2018-03-01 07:34:20 +08:00
:type condition: bool or str
2019-03-17 17:14:40 +08:00
:param condition:
Condition for marking the test function as xfail (`` True/False `` or a
2020-03-28 03:46:42 +08:00
:ref: `condition string <string conditions>` ). If a bool, you also have
to specify `` reason `` (see :ref: `condition string <string conditions>` ).
2020-07-14 15:55:17 +08:00
:keyword str reason:
Reason why the test function is marked as xfail.
:keyword Type[Exception] raises:
2022-06-16 23:39:41 +08:00
Exception subclass (or tuple of subclasses) expected to be raised by the test function; other exceptions will fail the test.
2018-03-01 07:34:20 +08:00
:keyword bool run:
2023-08-12 23:02:13 +08:00
Whether the test function should actually be executed. If `` False `` , the function will always xfail and will
2019-03-17 17:14:40 +08:00
not be executed (useful if a function is segfaulting).
2018-03-01 07:34:20 +08:00
:keyword bool strict:
2023-08-12 23:02:13 +08:00
* If `` False `` the function will be shown in the terminal output as `` xfailed `` if it fails
2018-03-01 07:34:20 +08:00
and as `` xpass `` if it passes. In both cases this will not cause the test suite to fail as a whole. This
2019-03-17 17:14:40 +08:00
is particularly useful to mark *flaky* tests (tests that fail at random) to be tackled later.
2018-03-01 07:34:20 +08:00
* If `` True `` , the function will be shown in the terminal output as `` xfailed `` if it fails, but if it
unexpectedly passes then it will **fail** the test suite. This is particularly useful to mark functions
that are always failing and there should be a clear indication if they unexpectedly start to pass (for example
a new release of a library fixes a known bug).
2023-08-12 23:02:13 +08:00
Defaults to :confval: `xfail_strict` , which is `` False `` by default.
2018-03-01 07:34:20 +08:00
2020-07-14 15:55:17 +08:00
Custom marks
2018-03-01 07:34:20 +08:00
~~~~~~~~~~~~
Marks are created dynamically using the factory object `` pytest.mark `` and applied as a decorator.
For example:
.. code-block :: python
2018-06-03 11:29:28 +08:00
@pytest.mark.timeout(10, "slow", method="thread")
2018-03-01 07:34:20 +08:00
def test_function():
...
2020-12-20 04:19:51 +08:00
Will create and attach a :class: `Mark <pytest.Mark>` object to the collected
2020-09-05 01:46:15 +08:00
:class: `Item <pytest.Item>` , which can then be accessed by fixtures or hooks with
2018-04-06 00:39:57 +08:00
:meth: `Node.iter_markers <_pytest.nodes.Node.iter_markers>` . The `` mark `` object will have the following attributes:
2018-03-01 07:34:20 +08:00
.. code-block :: python
2018-06-03 11:29:28 +08:00
mark.args == (10, "slow")
mark.kwargs == {"method": "thread"}
2018-02-28 05:26:40 +08:00
2020-11-30 23:48:08 +08:00
Example for using multiple custom markers:
.. code-block :: python
@pytest.mark.timeout(10, "slow", method="thread")
@pytest.mark.slow
def test_function():
...
2022-07-20 06:01:23 +08:00
When :meth: `Node.iter_markers <_pytest.nodes.Node.iter_markers>` or :meth: `Node.iter_markers_with_node <_pytest.nodes.Node.iter_markers_with_node>` is used with multiple markers, the marker closest to the function will be iterated over first. The above example will result in `` @pytest.mark.slow `` followed by `` @pytest.mark.timeout(...) `` .
2018-02-09 05:57:26 +08:00
2020-02-22 21:56:19 +08:00
.. _`fixtures-api`:
2018-02-09 05:57:26 +08:00
Fixtures
--------
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `fixture`
2018-02-28 04:58:51 +08:00
2018-02-09 05:57:26 +08:00
Fixtures are requested by test functions or other fixtures by declaring them as argument names.
Example of a test requiring a fixture:
.. code-block :: python
def test_output(capsys):
2018-06-03 11:29:28 +08:00
print("hello")
2018-02-09 05:57:26 +08:00
out, err = capsys.readouterr()
2018-06-03 11:29:28 +08:00
assert out == "hello\n"
2018-02-09 05:57:26 +08:00
Example of a fixture requiring another fixture:
.. code-block :: python
@pytest.fixture
2021-03-14 03:22:54 +08:00
def db_session(tmp_path):
fn = tmp_path / "db.file"
return connect(fn)
2018-02-09 05:57:26 +08:00
For more details, consult the full :ref: `fixtures docs <fixture>` .
2020-02-22 21:56:19 +08:00
.. _`pytest.fixture-api`:
2018-03-02 05:07:06 +08:00
@pytest.fixture
~~~~~~~~~~~~~~~
2018-02-09 05:57:26 +08:00
2018-03-02 05:07:06 +08:00
.. autofunction :: pytest.fixture
2018-02-09 05:57:26 +08:00
:decorator:
2020-02-22 21:56:19 +08:00
.. fixture :: capfd
2018-02-09 05:57:26 +08:00
capfd
~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `captures`
2018-02-28 04:58:51 +08:00
2020-09-28 03:20:31 +08:00
.. autofunction :: _pytest.capture.capfd()
2018-02-09 06:29:04 +08:00
:no-auto-options:
2018-02-09 05:57:26 +08:00
2022-08-17 22:40:03 +08:00
2020-02-22 21:56:19 +08:00
.. fixture :: capfdbinary
2018-03-01 07:52:41 +08:00
capfdbinary
~~~~~~~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `captures`
2018-03-01 07:52:41 +08:00
2020-09-28 03:20:31 +08:00
.. autofunction :: _pytest.capture.capfdbinary()
2018-03-01 07:52:41 +08:00
:no-auto-options:
2022-08-17 22:40:03 +08:00
.. fixture :: caplog
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
caplog
~~~~~~
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
**Tutorial** : :ref: `logging`
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
.. autofunction :: _pytest.logging.caplog()
:no-auto-options:
2020-02-22 21:56:19 +08:00
2022-08-17 22:40:03 +08:00
Returns a :class: `pytest.LogCaptureFixture` instance.
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
.. autoclass :: pytest.LogCaptureFixture()
:members:
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
.. fixture :: capsys
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
capsys
~~~~~~
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
**Tutorial** : :ref: `captures`
2020-02-22 21:56:19 +08:00
2022-08-17 22:40:03 +08:00
.. autofunction :: _pytest.capture.capsys()
:no-auto-options:
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
.. autoclass :: pytest.CaptureFixture()
:members:
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
.. fixture :: capsysbinary
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
capsysbinary
~~~~~~~~~~~~
2020-02-22 21:56:19 +08:00
2022-08-17 22:40:03 +08:00
**Tutorial** : :ref: `captures`
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
.. autofunction :: _pytest.capture.capsysbinary()
:no-auto-options:
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
.. fixture :: cache
2019-05-04 03:30:16 +08:00
2022-08-17 22:40:03 +08:00
config.cache
~~~~~~~~~~~~
2020-02-22 21:56:19 +08:00
2022-08-17 22:40:03 +08:00
**Tutorial** : :ref: `cache`
2019-05-04 03:30:16 +08:00
2022-08-17 22:40:03 +08:00
The `` config.cache `` object allows other plugins and fixtures
to store and retrieve values across test runs. To access it from fixtures
request `` pytestconfig `` into your fixture and get it with `` pytestconfig.cache `` .
2019-05-04 03:30:16 +08:00
2022-08-17 22:40:03 +08:00
Under the hood, the cache plugin uses the simple
`` dumps `` /`` loads `` API of the :py:mod: `json` stdlib module.
2019-05-04 03:30:16 +08:00
2022-08-17 22:40:03 +08:00
`` config.cache `` is an instance of :class: `pytest.Cache` :
2020-02-22 21:56:19 +08:00
2022-08-17 22:40:03 +08:00
.. autoclass :: pytest.Cache()
:members:
2020-02-22 21:56:19 +08:00
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
.. fixture :: doctest_namespace
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
doctest_namespace
~~~~~~~~~~~~~~~~~
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
**Tutorial** : :ref: `doctest`
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
.. autofunction :: _pytest.doctest.doctest_namespace()
2018-03-01 07:52:41 +08:00
2020-02-22 21:56:19 +08:00
.. fixture :: monkeypatch
2018-03-01 07:52:41 +08:00
monkeypatch
~~~~~~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `monkeypatching`
2018-03-01 07:52:41 +08:00
.. autofunction :: _pytest.monkeypatch.monkeypatch()
:no-auto-options:
2020-11-07 01:27:33 +08:00
Returns a :class: `~pytest.MonkeyPatch` instance.
2018-03-01 07:52:41 +08:00
2020-11-07 01:27:33 +08:00
.. autoclass :: pytest.MonkeyPatch
2018-03-01 07:52:41 +08:00
:members:
2020-02-22 21:56:19 +08:00
2022-08-17 22:40:03 +08:00
.. fixture :: pytestconfig
pytestconfig
~~~~~~~~~~~~
.. autofunction :: _pytest.fixtures.pytestconfig()
2020-10-12 23:13:06 +08:00
.. fixture :: pytester
2019-11-25 11:06:30 +08:00
2020-10-12 23:13:06 +08:00
pytester
~~~~~~~~
.. versionadded :: 6.2
2018-03-01 07:52:41 +08:00
2020-09-28 03:20:31 +08:00
Provides a :class: `~pytest.Pytester` instance that can be used to run and test pytest itself.
2020-10-12 23:13:06 +08:00
It provides an empty directory where pytest can be executed in isolation, and contains facilities
to write tests, configuration files, and match against expected output.
2018-03-01 07:52:41 +08:00
2020-10-12 23:13:06 +08:00
To use it, include in your topmost `` conftest.py `` file:
2018-03-01 07:52:41 +08:00
2019-08-07 04:25:54 +08:00
.. code-block :: python
2019-08-07 04:34:58 +08:00
pytest_plugins = "pytester"
2018-03-01 07:52:41 +08:00
2020-09-28 03:20:31 +08:00
.. autoclass :: pytest.Pytester()
2018-08-20 12:11:31 +08:00
:members:
2018-03-01 07:52:41 +08:00
2021-10-22 16:34:36 +08:00
.. autoclass :: pytest.RunResult()
2018-03-01 07:52:41 +08:00
:members:
2021-10-22 16:34:36 +08:00
.. autoclass :: pytest.LineMatcher()
2018-03-01 07:52:41 +08:00
:members:
2020-11-22 02:45:20 +08:00
:special-members: __str__
2018-03-01 07:52:41 +08:00
2021-10-22 16:34:36 +08:00
.. autoclass :: pytest.HookRecorder()
:members:
.. autoclass :: pytest.RecordedHookCall()
2020-10-13 23:01:11 +08:00
:members:
2020-10-12 23:13:06 +08:00
2022-08-17 22:40:03 +08:00
.. fixture :: record_property
2020-10-12 23:13:06 +08:00
2022-08-17 22:40:03 +08:00
record_property
~~~~~~~~~~~~~~~~~~~
2020-10-12 23:13:06 +08:00
2022-08-17 22:40:03 +08:00
**Tutorial** : :ref: `record_property example`
2018-03-01 07:52:41 +08:00
2022-08-17 22:40:03 +08:00
.. autofunction :: _pytest.junitxml.record_property()
.. fixture :: record_testsuite_property
record_testsuite_property
~~~~~~~~~~~~~~~~~~~~~~~~~
**Tutorial** : :ref: `record_testsuite_property example`
.. autofunction :: _pytest.junitxml.record_testsuite_property()
2020-10-13 23:01:11 +08:00
2020-02-22 21:56:19 +08:00
.. fixture :: recwarn
2018-03-01 07:52:41 +08:00
recwarn
~~~~~~~
**Tutorial** : :ref: `assertwarnings`
2020-09-28 03:20:31 +08:00
.. autofunction :: _pytest.recwarn.recwarn()
2018-03-01 07:52:41 +08:00
:no-auto-options:
2020-09-28 03:20:31 +08:00
.. autoclass :: pytest.WarningsRecorder()
2018-03-01 07:52:41 +08:00
:members:
2022-08-17 22:40:03 +08:00
.. fixture :: request
request
~~~~~~~
**Example** : :ref: `request example`
The `` request `` fixture is a special fixture providing information of the requesting test function.
.. autoclass :: pytest.FixtureRequest()
:members:
.. fixture :: testdir
testdir
~~~~~~~
Identical to :fixture: `pytester` , but provides an instance whose methods return
legacy `` py.path.local `` objects instead when applicable.
New code should avoid using :fixture: `testdir` in favor of :fixture: `pytester` .
.. autoclass :: pytest.Testdir()
:members:
:noindex: TimeoutExpired
2020-02-22 21:56:19 +08:00
.. fixture :: tmp_path
2019-03-02 04:09:07 +08:00
tmp_path
~~~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `tmp_path`
2019-03-02 04:09:07 +08:00
2020-09-28 03:20:31 +08:00
.. autofunction :: _pytest.tmpdir.tmp_path()
2019-03-02 04:09:07 +08:00
:no-auto-options:
2021-03-14 01:45:11 +08:00
.. fixture :: tmp_path_factory
2020-02-22 21:56:19 +08:00
2019-03-02 04:09:07 +08:00
tmp_path_factory
~~~~~~~~~~~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `tmp_path_factory example`
2019-03-02 04:09:07 +08:00
.. _`tmp_path_factory factory api`:
2020-09-28 03:20:31 +08:00
`` tmp_path_factory `` is an instance of :class: `~pytest.TempPathFactory` :
2019-03-02 04:09:07 +08:00
2020-09-28 03:20:31 +08:00
.. autoclass :: pytest.TempPathFactory()
2021-04-14 17:06:35 +08:00
:members:
2019-03-02 04:09:07 +08:00
2020-02-22 21:56:19 +08:00
.. fixture :: tmpdir
2018-03-01 07:52:41 +08:00
tmpdir
~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `tmpdir and tmpdir_factory`
2018-03-01 07:52:41 +08:00
2021-10-29 18:11:12 +08:00
.. autofunction :: _pytest.legacypath.LegacyTmpdirPlugin.tmpdir()
2018-03-01 07:52:41 +08:00
:no-auto-options:
2020-02-22 21:56:19 +08:00
.. fixture :: tmpdir_factory
2018-03-01 07:52:41 +08:00
tmpdir_factory
~~~~~~~~~~~~~~
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `tmpdir and tmpdir_factory`
2018-03-01 07:52:41 +08:00
2021-05-31 15:36:18 +08:00
`` tmpdir_factory `` is an instance of :class: `~pytest.TempdirFactory` :
2018-03-01 07:52:41 +08:00
2020-09-28 03:20:31 +08:00
.. autoclass :: pytest.TempdirFactory()
2021-04-14 17:06:35 +08:00
:members:
2018-03-01 07:52:41 +08:00
.. _`hook-reference`:
Hooks
-----
2022-05-10 22:27:21 +08:00
**Tutorial** : :ref: `writing-plugins`
2018-03-01 07:52:41 +08:00
.. currentmodule :: _pytest.hookspec
Reference to all hooks which can be implemented by :ref: `conftest.py files <localplugin>` and :ref: `plugins <plugins>` .
Bootstrapping hooks
~~~~~~~~~~~~~~~~~~~
Bootstrapping hooks called for plugins registered early enough (internal and setuptools plugins).
2021-12-08 22:19:09 +08:00
.. hook :: pytest_load_initial_conftests
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_load_initial_conftests
2021-12-08 22:19:09 +08:00
.. hook :: pytest_cmdline_preparse
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_cmdline_preparse
2021-12-08 22:19:09 +08:00
.. hook :: pytest_cmdline_parse
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_cmdline_parse
2021-12-08 22:19:09 +08:00
.. hook :: pytest_cmdline_main
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_cmdline_main
2018-02-09 05:57:26 +08:00
2019-05-15 07:49:47 +08:00
.. _`initialization-hooks`:
2018-03-01 07:52:41 +08:00
Initialization hooks
~~~~~~~~~~~~~~~~~~~~
2018-02-09 05:57:26 +08:00
2018-03-01 07:52:41 +08:00
Initialization hooks called for plugins and `` conftest.py `` files.
2018-02-09 05:57:26 +08:00
2021-12-08 22:19:09 +08:00
.. hook :: pytest_addoption
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_addoption
2021-12-08 22:19:09 +08:00
.. hook :: pytest_addhooks
2018-03-02 04:55:45 +08:00
.. autofunction :: pytest_addhooks
2021-12-08 22:19:09 +08:00
.. hook :: pytest_configure
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_configure
2021-12-08 22:19:09 +08:00
.. hook :: pytest_unconfigure
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_unconfigure
2021-12-08 22:19:09 +08:00
.. hook :: pytest_sessionstart
2018-03-30 06:48:48 +08:00
.. autofunction :: pytest_sessionstart
2021-12-08 22:19:09 +08:00
.. hook :: pytest_sessionfinish
2018-03-30 06:48:48 +08:00
.. autofunction :: pytest_sessionfinish
2018-02-28 04:58:51 +08:00
2021-12-08 22:19:09 +08:00
.. hook :: pytest_plugin_registered
2019-03-08 22:21:56 +08:00
.. autofunction :: pytest_plugin_registered
2018-03-01 07:52:41 +08:00
Collection hooks
~~~~~~~~~~~~~~~~
2018-02-09 05:57:26 +08:00
2018-03-01 07:52:41 +08:00
`` pytest `` calls the following hooks for collecting files and directories:
2018-02-09 06:08:44 +08:00
2021-12-08 22:19:09 +08:00
.. hook :: pytest_collection
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_collection
2021-12-08 22:19:09 +08:00
.. hook :: pytest_ignore_collect
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_ignore_collect
2021-12-08 22:19:09 +08:00
.. hook :: pytest_collect_file
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_collect_file
2021-12-08 22:19:09 +08:00
.. hook :: pytest_pycollect_makemodule
2019-03-08 22:21:56 +08:00
.. autofunction :: pytest_pycollect_makemodule
2018-02-28 04:58:51 +08:00
2018-03-01 07:52:41 +08:00
For influencing the collection of objects in Python modules
you can use the following hook:
2018-02-09 06:08:44 +08:00
2021-12-08 22:19:09 +08:00
.. hook :: pytest_pycollect_makeitem
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_pycollect_makeitem
2021-12-08 22:19:09 +08:00
.. hook :: pytest_generate_tests
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_generate_tests
2021-12-08 22:19:09 +08:00
.. hook :: pytest_make_parametrize_id
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_make_parametrize_id
2018-02-09 06:08:44 +08:00
2021-12-25 19:53:30 +08:00
Hooks for influencing test skipping:
.. hook :: pytest_markeval_namespace
.. autofunction :: pytest_markeval_namespace
2018-03-01 07:52:41 +08:00
After collection is complete, you can modify the order of
items, delete or otherwise amend the test items:
2018-02-09 06:08:44 +08:00
2021-12-08 22:19:09 +08:00
.. hook :: pytest_collection_modifyitems
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_collection_modifyitems
2018-02-09 06:08:44 +08:00
2020-10-17 19:26:30 +08:00
.. note ::
If this hook is implemented in `` conftest.py `` files, it always receives all collected items, not only those
under the `` conftest.py `` where it is implemented.
2020-10-17 19:42:15 +08:00
2019-03-08 22:21:56 +08:00
.. autofunction :: pytest_collection_finish
2020-06-14 21:31:55 +08:00
Test running (runtest) hooks
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2020-09-05 01:46:15 +08:00
All runtest related hooks receive a :py:class: `pytest.Item <pytest.Item>` object.
2020-06-14 21:31:55 +08:00
2021-12-08 22:19:09 +08:00
.. hook :: pytest_runtestloop
2020-06-14 21:31:55 +08:00
.. autofunction :: pytest_runtestloop
2021-12-08 22:19:09 +08:00
.. hook :: pytest_runtest_protocol
2020-06-14 21:31:55 +08:00
.. autofunction :: pytest_runtest_protocol
2021-12-08 22:19:09 +08:00
.. hook :: pytest_runtest_logstart
2020-06-14 21:31:55 +08:00
.. autofunction :: pytest_runtest_logstart
2021-12-08 22:19:09 +08:00
.. hook :: pytest_runtest_logfinish
2020-06-14 21:31:55 +08:00
.. autofunction :: pytest_runtest_logfinish
2021-12-08 22:19:09 +08:00
.. hook :: pytest_runtest_setup
2020-06-14 21:31:55 +08:00
.. autofunction :: pytest_runtest_setup
2021-12-08 22:19:09 +08:00
.. hook :: pytest_runtest_call
2020-06-14 21:31:55 +08:00
.. autofunction :: pytest_runtest_call
2021-12-08 22:19:09 +08:00
.. hook :: pytest_runtest_teardown
2020-06-14 21:31:55 +08:00
.. autofunction :: pytest_runtest_teardown
2021-12-08 22:19:09 +08:00
.. hook :: pytest_runtest_makereport
2020-06-14 21:31:55 +08:00
.. autofunction :: pytest_runtest_makereport
For deeper understanding you may look at the default implementation of
2020-09-06 16:52:30 +08:00
these hooks in `` _pytest.runner `` and maybe also
in `` _pytest.pdb `` which interacts with `` _pytest.capture ``
2020-06-14 21:31:55 +08:00
and its input/output capturing in order to immediately drop
into interactive debugging when a test failure occurs.
2021-12-08 22:19:09 +08:00
.. hook :: pytest_pyfunc_call
2020-06-14 21:31:55 +08:00
.. autofunction :: pytest_pyfunc_call
2018-03-01 07:52:41 +08:00
Reporting hooks
~~~~~~~~~~~~~~~
2018-02-27 07:27:15 +08:00
2018-03-01 07:52:41 +08:00
Session related reporting hooks:
2018-02-27 07:27:15 +08:00
2021-12-08 22:19:09 +08:00
.. hook :: pytest_collectstart
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_collectstart
2021-12-08 22:19:09 +08:00
.. hook :: pytest_make_collect_report
2019-03-08 22:21:56 +08:00
.. autofunction :: pytest_make_collect_report
2021-12-08 22:19:09 +08:00
.. hook :: pytest_itemcollected
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_itemcollected
2021-12-08 22:19:09 +08:00
.. hook :: pytest_collectreport
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_collectreport
2021-12-08 22:19:09 +08:00
.. hook :: pytest_deselected
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_deselected
2021-12-08 22:19:09 +08:00
.. hook :: pytest_report_header
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_report_header
2021-12-08 22:19:09 +08:00
.. hook :: pytest_report_collectionfinish
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_report_collectionfinish
2021-12-08 22:19:09 +08:00
.. hook :: pytest_report_teststatus
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_report_teststatus
2021-12-25 19:53:30 +08:00
.. hook :: pytest_report_to_serializable
.. autofunction :: pytest_report_to_serializable
.. hook :: pytest_report_from_serializable
.. autofunction :: pytest_report_from_serializable
2021-12-08 22:19:09 +08:00
.. hook :: pytest_terminal_summary
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_terminal_summary
2021-12-08 22:19:09 +08:00
.. hook :: pytest_fixture_setup
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_fixture_setup
2021-12-08 22:19:09 +08:00
.. hook :: pytest_fixture_post_finalizer
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_fixture_post_finalizer
2021-12-08 22:19:09 +08:00
.. hook :: pytest_warning_recorded
2020-05-25 08:43:23 +08:00
.. autofunction :: pytest_warning_recorded
2018-02-27 07:27:15 +08:00
2019-06-27 06:10:54 +08:00
Central hook for reporting about test execution:
2018-02-28 04:58:51 +08:00
2021-12-08 22:19:09 +08:00
.. hook :: pytest_runtest_logreport
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_runtest_logreport
2018-02-27 07:27:15 +08:00
2019-06-27 06:10:54 +08:00
Assertion related hooks:
2018-02-28 04:13:14 +08:00
2021-12-08 22:19:09 +08:00
.. hook :: pytest_assertrepr_compare
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_assertrepr_compare
2021-12-08 22:19:09 +08:00
.. hook :: pytest_assertion_pass
2019-06-27 06:10:54 +08:00
.. autofunction :: pytest_assertion_pass
2018-02-28 04:13:14 +08:00
2018-03-01 07:52:41 +08:00
Debugging/Interaction hooks
~~~~~~~~~~~~~~~~~~~~~~~~~~~
2018-02-28 04:19:57 +08:00
2018-03-01 07:52:41 +08:00
There are few hooks which can be used for special
reporting or interaction with exceptions:
2018-02-28 04:19:57 +08:00
2021-12-08 22:19:09 +08:00
.. hook :: pytest_internalerror
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_internalerror
2021-12-08 22:19:09 +08:00
.. hook :: pytest_keyboard_interrupt
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_keyboard_interrupt
2021-12-08 22:19:09 +08:00
.. hook :: pytest_exception_interact
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_exception_interact
2021-12-08 22:19:09 +08:00
.. hook :: pytest_enter_pdb
2018-03-01 07:52:41 +08:00
.. autofunction :: pytest_enter_pdb
2021-12-25 19:53:30 +08:00
.. hook :: pytest_leave_pdb
.. autofunction :: pytest_leave_pdb
2018-02-28 04:58:51 +08:00
2018-02-28 04:32:34 +08:00
2023-06-14 14:19:56 +08:00
Collection tree objects
-----------------------
2018-02-28 04:48:19 +08:00
2023-06-14 14:19:56 +08:00
These are the collector and item classes (collectively called "nodes") which
make up the collection tree.
2018-02-28 04:32:34 +08:00
2023-06-14 14:19:56 +08:00
Node
~~~~
2018-02-28 04:48:19 +08:00
2023-06-14 14:19:56 +08:00
.. autoclass :: _pytest.nodes.Node()
2018-03-01 07:52:41 +08:00
:members:
2018-02-28 05:03:35 +08:00
2018-03-01 07:52:41 +08:00
Collector
~~~~~~~~~
2018-02-28 04:48:19 +08:00
2020-09-05 01:46:15 +08:00
.. autoclass :: pytest.Collector()
2018-03-01 07:52:41 +08:00
:members:
:show-inheritance:
2018-02-28 04:48:19 +08:00
2023-06-14 14:19:56 +08:00
Item
~~~~
2020-06-14 21:02:25 +08:00
2023-06-14 14:19:56 +08:00
.. autoclass :: pytest.Item()
2020-06-14 21:02:25 +08:00
:members:
:show-inheritance:
2023-06-14 14:19:56 +08:00
File
~~~~
2018-02-28 04:48:19 +08:00
2023-06-14 14:19:56 +08:00
.. autoclass :: pytest.File()
2018-02-28 04:48:19 +08:00
:members:
2023-06-14 14:19:56 +08:00
:show-inheritance:
2018-02-28 04:48:19 +08:00
2023-06-14 14:19:56 +08:00
FSCollector
~~~~~~~~~~~
2018-02-28 05:03:35 +08:00
2023-06-14 14:19:56 +08:00
.. autoclass :: _pytest.nodes.FSCollector()
2018-03-01 07:52:41 +08:00
:members:
2023-06-14 14:19:56 +08:00
:show-inheritance:
2018-02-28 05:03:35 +08:00
2023-06-14 14:19:56 +08:00
Session
~~~~~~~
2019-06-15 23:18:21 +08:00
2023-06-14 14:19:56 +08:00
.. autoclass :: pytest.Session()
2019-06-15 23:18:21 +08:00
:members:
2023-06-14 14:19:56 +08:00
:show-inheritance:
2019-06-15 23:18:21 +08:00
2023-06-14 14:19:56 +08:00
Package
~~~~~~~
2020-08-28 06:49:58 +08:00
2023-06-14 14:19:56 +08:00
.. autoclass :: pytest.Package()
2020-08-28 06:49:58 +08:00
:members:
:show-inheritance:
2023-06-14 14:19:56 +08:00
Module
~~~~~~
2019-06-15 23:18:21 +08:00
2023-06-14 14:19:56 +08:00
.. autoclass :: pytest.Module()
2018-03-01 07:52:41 +08:00
:members:
:show-inheritance:
2018-02-28 05:03:35 +08:00
2023-06-14 14:19:56 +08:00
Class
~~~~~
2018-02-28 05:03:35 +08:00
2023-06-14 14:19:56 +08:00
.. autoclass :: pytest.Class()
2018-03-01 07:52:41 +08:00
:members:
:show-inheritance:
2018-02-28 05:03:35 +08:00
2018-03-01 07:52:41 +08:00
Function
~~~~~~~~
2018-02-28 05:03:35 +08:00
2020-09-05 01:46:15 +08:00
.. autoclass :: pytest.Function()
2018-03-01 07:52:41 +08:00
:members:
:show-inheritance:
2018-02-28 05:03:35 +08:00
2020-10-31 19:45:34 +08:00
FunctionDefinition
~~~~~~~~~~~~~~~~~~
.. autoclass :: _pytest.python.FunctionDefinition()
:members:
:show-inheritance:
2018-03-01 07:52:41 +08:00
2023-06-14 14:19:56 +08:00
Objects
-------
Objects accessible from :ref: `fixtures <fixture>` or :ref: `hooks <hook-reference>`
or importable from `` pytest `` .
CallInfo
~~~~~~~~
.. autoclass :: pytest.CallInfo()
:members:
CollectReport
~~~~~~~~~~~~~
.. autoclass :: pytest.CollectReport()
:members:
:show-inheritance:
:inherited-members:
Config
~~~~~~
.. autoclass :: pytest.Config()
:members:
ExceptionInfo
~~~~~~~~~~~~~
.. autoclass :: pytest.ExceptionInfo()
:members:
ExitCode
~~~~~~~~
.. autoclass :: pytest.ExitCode
:members:
FixtureDef
~~~~~~~~~~
2023-07-14 15:59:00 +08:00
.. autoclass :: pytest.FixtureDef()
2018-02-28 05:03:35 +08:00
:members:
2018-03-01 07:52:41 +08:00
:show-inheritance:
2018-02-28 05:03:35 +08:00
2018-03-01 07:52:41 +08:00
MarkDecorator
~~~~~~~~~~~~~
2020-12-20 21:11:01 +08:00
.. autoclass :: pytest.MarkDecorator()
2018-02-28 05:03:35 +08:00
:members:
2018-02-28 05:26:40 +08:00
2018-04-06 00:39:57 +08:00
2018-03-01 07:52:41 +08:00
MarkGenerator
~~~~~~~~~~~~~
2018-02-28 05:26:40 +08:00
2020-12-20 21:36:24 +08:00
.. autoclass :: pytest.MarkGenerator()
2018-03-01 07:52:41 +08:00
:members:
2018-02-28 05:26:40 +08:00
2018-04-06 00:39:57 +08:00
Mark
~~~~
2020-12-20 04:19:51 +08:00
.. autoclass :: pytest.Mark()
2018-04-06 00:39:57 +08:00
:members:
2018-03-01 07:52:41 +08:00
Metafunc
~~~~~~~~
2018-02-28 05:26:40 +08:00
2020-12-27 02:49:17 +08:00
.. autoclass :: pytest.Metafunc()
2018-02-28 05:26:40 +08:00
:members:
2018-03-01 07:52:41 +08:00
Parser
2018-02-28 05:26:40 +08:00
~~~~~~
2021-05-24 04:45:49 +08:00
.. autoclass :: pytest.Parser()
2018-03-01 07:52:41 +08:00
:members:
2018-02-28 05:26:40 +08:00
2021-05-24 04:45:49 +08:00
OptionGroup
~~~~~~~~~~~
.. autoclass :: pytest.OptionGroup()
:members:
2018-02-28 05:26:40 +08:00
2018-03-01 07:52:41 +08:00
PytestPluginManager
~~~~~~~~~~~~~~~~~~~
2018-02-28 05:26:40 +08:00
2021-05-24 17:16:16 +08:00
.. autoclass :: pytest.PytestPluginManager()
2018-03-01 07:52:41 +08:00
:members:
:undoc-members:
2020-09-05 01:14:39 +08:00
:inherited-members:
2018-03-01 07:52:41 +08:00
:show-inheritance:
2018-02-28 05:26:40 +08:00
2018-03-01 07:52:41 +08:00
TestReport
~~~~~~~~~~
2018-02-28 05:26:40 +08:00
2021-11-03 02:32:54 +08:00
.. autoclass :: pytest.TestReport()
2018-03-01 07:52:41 +08:00
:members:
2020-03-05 13:00:11 +08:00
:show-inheritance:
2018-03-01 07:52:41 +08:00
:inherited-members:
2023-05-19 19:24:28 +08:00
TestShortLogReport
~~~~~~~~~~~~~~~~~~
.. autoclass :: pytest.TestShortLogReport()
:members:
2023-08-26 14:53:45 +08:00
Result
2018-03-01 07:52:41 +08:00
~~~~~~~
2023-08-26 14:53:45 +08:00
Result object used within :ref: `hook wrappers <hookwrapper>` , see :py:class: `Result in the pluggy documentation <pluggy.Result>` for more information.
2020-03-05 12:55:04 +08:00
2021-07-18 19:05:58 +08:00
Stash
~~~~~
.. autoclass :: pytest.Stash
:special-members: __setitem__, __getitem__, __delitem__, __contains__, __len__
:members:
.. autoclass :: pytest.StashKey
:show-inheritance:
:members:
2020-07-10 20:50:03 +08:00
Global Variables
----------------
2018-03-02 05:20:55 +08:00
2020-07-10 20:50:03 +08:00
pytest treats some global variables in a special manner when defined in a test module or
`` conftest.py `` files.
2018-03-02 05:20:55 +08:00
2020-07-10 20:50:03 +08:00
.. globalvar :: collect_ignore
2019-02-07 00:15:28 +08:00
**Tutorial** : :ref: `customizing-test-collection`
Can be declared in *conftest.py files* to exclude test directories or modules.
2021-03-15 04:50:27 +08:00
Needs to be a list of paths (`` str `` , :class: `pathlib.Path` or any :class: `os.PathLike` ).
2019-02-07 00:15:28 +08:00
.. code-block :: python
collect_ignore = ["setup.py"]
2020-07-10 20:50:03 +08:00
.. globalvar :: collect_ignore_glob
2019-02-07 00:15:28 +08:00
**Tutorial** : :ref: `customizing-test-collection`
Can be declared in *conftest.py files* to exclude test directories or modules
with Unix shell-style wildcards. Needs to be `` list[str] `` where `` str `` can
contain glob patterns.
.. code-block :: python
collect_ignore_glob = ["*_ignore.py"]
2020-07-10 20:50:03 +08:00
.. globalvar :: pytest_plugins
2018-03-02 05:20:55 +08:00
**Tutorial** : :ref: `available installable plugins`
Can be declared at the **global** level in *test modules* and *conftest.py files* to register additional plugins.
Can be either a `` str `` or `` Sequence[str] `` .
.. code-block :: python
pytest_plugins = "myapp.testsupport.myplugin"
.. code-block :: python
pytest_plugins = ("myapp.testsupport.tools", "myapp.testsupport.regression")
2020-07-10 20:50:03 +08:00
.. globalvar :: pytestmark
2018-03-02 05:20:55 +08:00
**Tutorial** : :ref: `scoped-marking`
Can be declared at the **global** level in *test modules* to apply one or more :ref: `marks <marks ref>` to all
2020-07-10 20:50:03 +08:00
test functions and methods. Can be either a single mark or a list of marks (applied in left-to-right order).
2018-03-02 05:20:55 +08:00
.. code-block :: python
import pytest
2018-06-03 11:29:28 +08:00
2018-03-02 05:20:55 +08:00
pytestmark = pytest.mark.webtest
.. code-block :: python
import pytest
2018-06-03 11:29:28 +08:00
Fix pytestmark syntax in reference.rst
pytest 4.3.1 throws an error if `pytestmark` is set to a tuple of marks; it appears to insist on a list.
With `pytestmark = [pytest.mark.api, pytest.mark.good]`:
```
============================== test session starts ==============================
platform win32 -- Python 3.6.3, pytest-4.3.1, py-1.8.0, pluggy-0.9.0
rootdir: C:\Temp\git\sphobjinv, inifile: tox.ini
plugins: timeout-1.3.3
collected 48 items / 41 deselected / 7 selected
tests\test_api_good.py ....... [100%]
==================== 7 passed, 41 deselected in 0.15 seconds ====================
```
With `pytestmark = (pytest.mark.api, pytest.mark.good)`:
```
==================================== ERRORS =====================================
____________________ ERROR collecting tests/test_api_good.py ____________________
env\lib\site-packages\_pytest\runner.py:226: in from_call
result = func()
env\lib\site-packages\_pytest\runner.py:289: in <lambda>
call = CallInfo.from_call(lambda: list(collector.collect()), "collect")
env\lib\site-packages\_pytest\python.py:435: in collect
self._inject_setup_module_fixture()
env\lib\site-packages\_pytest\python.py:447: in _inject_setup_module_fixture
setup_module = _get_non_fixture_func(self.obj, "setUpModule")
env\lib\site-packages\_pytest\python.py:255: in obj
self.own_markers.extend(get_unpacked_marks(self.obj))
env\lib\site-packages\_pytest\mark\structures.py:244: in get_unpacked_marks
return normalize_mark_list(mark_list)
env\lib\site-packages\_pytest\mark\structures.py:259: in normalize_mark_list
raise TypeError("got {!r} instead of Mark".format(mark))
E TypeError: got (MarkDecorator(mark=Mark(name='api', args=(), kwargs={})), MarkDecorator(mark=Mark(name='good', args=(), kwargs={}))) instead of Mark
!!!!!!!!!!!!!!!!!!!! Interrupted: 1 errors during collection !!!!!!!!!!!!!!!!!!!!
==================== 19 deselected, 1 error in 0.27 seconds =====================
```
2019-03-22 03:14:28 +08:00
pytestmark = [pytest.mark.integration, pytest.mark.slow]
2018-03-02 05:20:55 +08:00
2018-03-07 07:40:07 +08:00
Environment Variables
---------------------
Environment variables that can be used to change pytest's behavior.
2023-02-19 05:52:14 +08:00
.. envvar :: CI
2023-05-18 21:10:44 +08:00
When set (regardless of value), pytest acknowledges that is running in a CI process. Alternative to `` BUILD_NUMBER `` variable.
2023-02-19 05:52:14 +08:00
.. envvar :: BUILD_NUMBER
2023-05-18 21:10:44 +08:00
When set (regardless of value), pytest acknowledges that is running in a CI process. Alternative to CI variable.
2023-02-19 05:52:14 +08:00
2020-03-27 09:40:25 +08:00
.. envvar :: PYTEST_ADDOPTS
2018-03-07 07:40:07 +08:00
This contains a command-line (parsed by the py:mod: `shlex` module) that will be **prepended** to the command line given
by the user, see :ref: `adding default options` for more information.
2020-07-10 19:49:10 +08:00
.. envvar :: PYTEST_CURRENT_TEST
This is not meant to be set by users, but is set by pytest internally with the name of the current test so other
processes can inspect it, see :ref: `pytest current test env` for more information.
2020-03-27 09:40:25 +08:00
.. envvar :: PYTEST_DEBUG
2018-03-07 07:40:07 +08:00
When set, pytest will print tracing and debug information.
2020-07-10 19:49:10 +08:00
.. envvar :: PYTEST_DISABLE_PLUGIN_AUTOLOAD
When set, disables plugin auto-loading through setuptools entrypoints. Only explicitly specified plugins will be
loaded.
2020-03-27 09:40:25 +08:00
.. envvar :: PYTEST_PLUGINS
2018-03-07 07:40:07 +08:00
Contains comma-separated list of modules that should be loaded as plugins:
.. code-block :: bash
2018-06-06 06:27:59 +08:00
export PYTEST_PLUGINS=mymodule.plugin,xdist
2018-03-07 07:40:07 +08:00
2021-06-11 23:04:27 +08:00
.. envvar :: PYTEST_THEME
Sets a `pygment style <https://pygments.org/docs/styles/> `_ to use for the code output.
.. envvar :: PYTEST_THEME_MODE
Sets the :envvar: `PYTEST_THEME` to be either *dark* or *light* .
2020-07-10 19:49:10 +08:00
.. envvar :: PY_COLORS
2018-08-07 04:17:24 +08:00
2020-07-10 19:49:10 +08:00
When set to `` 1 `` , pytest will use color in terminal output.
When set to `` 0 `` , pytest will not use color.
`` PY_COLORS `` takes precedence over `` NO_COLOR `` and `` FORCE_COLOR `` .
2018-03-07 07:40:07 +08:00
2020-07-10 19:49:10 +08:00
.. envvar :: NO_COLOR
2018-03-07 07:40:07 +08:00
2020-07-10 19:49:10 +08:00
When set (regardless of value), pytest will not use color in terminal output.
`` PY_COLORS `` takes precedence over `` NO_COLOR `` , which takes precedence over `` FORCE_COLOR `` .
See `no-color.org <https://no-color.org/> `__ for other libraries supporting this community standard.
.. envvar :: FORCE_COLOR
When set (regardless of value), pytest will use color in terminal output.
`` PY_COLORS `` and `` NO_COLOR `` take precedence over `` FORCE_COLOR `` .
2018-03-07 07:40:07 +08:00
2019-05-09 03:42:49 +08:00
Exceptions
----------
2020-09-05 01:46:15 +08:00
.. autoclass :: pytest.UsageError()
2020-07-23 08:36:51 +08:00
:show-inheritance:
.. _`warnings ref`:
Warnings
--------
Custom warnings generated in some situations such as improper usage or deprecated features.
.. autoclass :: pytest.PytestWarning
:show-inheritance:
.. autoclass :: pytest.PytestAssertRewriteWarning
:show-inheritance:
.. autoclass :: pytest.PytestCacheWarning
:show-inheritance:
.. autoclass :: pytest.PytestCollectionWarning
:show-inheritance:
.. autoclass :: pytest.PytestConfigWarning
:show-inheritance:
.. autoclass :: pytest.PytestDeprecationWarning
:show-inheritance:
.. autoclass :: pytest.PytestExperimentalApiWarning
:show-inheritance:
2022-05-25 20:48:02 +08:00
.. autoclass :: pytest.PytestReturnNotNoneWarning
:show-inheritance:
2022-10-10 07:10:45 +08:00
.. autoclass :: pytest.PytestRemovedIn8Warning
:show-inheritance:
2023-06-23 20:25:52 +08:00
.. autoclass :: pytest.PytestRemovedIn9Warning
:show-inheritance:
2020-07-23 08:36:51 +08:00
.. autoclass :: pytest.PytestUnhandledCoroutineWarning
:show-inheritance:
.. autoclass :: pytest.PytestUnknownMarkWarning
:show-inheritance:
2020-11-14 05:47:19 +08:00
.. autoclass :: pytest.PytestUnraisableExceptionWarning
:show-inheritance:
.. autoclass :: pytest.PytestUnhandledThreadExceptionWarning
:show-inheritance:
2020-07-23 08:36:51 +08:00
Consult the :ref: `internal-warnings` section in the documentation for more information.
2019-05-09 03:42:49 +08:00
2018-03-02 05:20:55 +08:00
2018-03-08 07:45:41 +08:00
.. _`ini options ref`:
Configuration Options
---------------------
2022-06-14 19:24:35 +08:00
Here is a list of builtin configuration options that may be written in a `` pytest.ini `` (or `` .pytest.ini `` ),
`` pyproject.toml `` , `` tox.ini `` , or `` setup.cfg `` file, usually located at the root of your repository.
To see each file format in details, see :ref: `config file formats` .
2018-03-08 07:45:41 +08:00
2019-01-10 05:52:08 +08:00
.. warning ::
2020-06-08 21:03:10 +08:00
Usage of `` setup.cfg `` is not recommended except for very simple use cases. `` .cfg ``
2019-01-10 05:52:08 +08:00
files use a different parser than `` pytest.ini `` and `` tox.ini `` which might cause hard to track
down problems.
2020-06-08 21:03:10 +08:00
When possible, it is recommended to use the latter files, or `` pyproject.toml `` , to hold your pytest configuration.
2019-01-07 04:47:40 +08:00
2020-06-08 21:03:10 +08:00
Configuration options may be overwritten in the command-line by using `` -o/--override-ini `` , which can also be
2018-03-08 07:45:41 +08:00
passed multiple times. The expected format is `` name=value `` . For example::
pytest -o console_output_style=classic -o cache_dir=/tmp/mycache
.. confval :: addopts
Add the specified `` OPTS `` to the set of command line arguments as if they
had been specified by the user. Example: if you have this ini file content:
.. code-block :: ini
# content of pytest.ini
[pytest]
addopts = --maxfail=2 -rf # exit after 2 failures, report fail info
2019-10-01 22:17:26 +08:00
issuing `` pytest test_hello.py `` actually means:
2018-03-08 07:45:41 +08:00
2019-08-07 04:25:54 +08:00
.. code-block :: bash
2018-03-08 07:45:41 +08:00
pytest --maxfail=2 -rf test_hello.py
Default is to add no options.
2018-03-13 06:33:34 +08:00
.. confval :: cache_dir
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
Sets a directory where stores content of cache plugin. Default directory is
2018-05-30 19:24:10 +08:00
`` .pytest_cache `` which is created in :ref: `rootdir <rootdir>` . Directory may be
2018-03-13 06:33:34 +08:00
relative or absolute path. If setting relative path, then directory is created
relative to :ref: `rootdir <rootdir>` . Additionally path may contain environment
variables, that will be expanded. For more information about cache plugin
please refer to :ref: `cache_provider` .
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
.. confval :: console_output_style
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
Sets the console output style while running tests:
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
* `` classic `` : classic pytest output.
* `` progress `` : like classic pytest output, but with a progress indicator.
2023-03-08 04:49:37 +08:00
* `` progress-even-when-capture-no `` : allows the use of the progress indicator even when `` capture=no `` .
2018-08-27 10:21:00 +08:00
* `` count `` : like progress, but shows progress as the number of tests completed instead of a percent.
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
The default is `` progress `` , but you can fallback to `` classic `` if you prefer or
the new mode is causing unexpected problems:
2018-03-08 07:45:41 +08:00
.. code-block :: ini
# content of pytest.ini
[pytest]
2018-03-13 06:33:34 +08:00
console_output_style = classic
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
.. confval :: doctest_encoding
2018-03-08 07:45:41 +08:00
2019-04-28 23:37:58 +08:00
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
Default encoding to use to decode text files with docstrings.
2021-03-12 04:30:47 +08:00
:ref: `See how pytest handles doctests <doctest>` .
2018-03-08 07:45:41 +08:00
.. confval :: doctest_optionflags
One or more doctest flag names from the standard `` doctest `` module.
2021-03-12 04:30:47 +08:00
:ref: `See how pytest handles doctests <doctest>` .
2018-03-08 07:45:41 +08:00
2018-03-13 06:27:17 +08:00
2018-03-13 06:33:34 +08:00
.. confval :: empty_parameter_set_mark
2018-03-13 06:27:17 +08:00
2019-04-28 23:37:58 +08:00
2018-03-13 06:27:17 +08:00
2018-03-13 06:33:34 +08:00
Allows to pick the action for empty parametersets in parameterization
2018-03-08 07:45:41 +08:00
2018-05-13 18:06:09 +08:00
* `` skip `` skips tests with an empty parameterset (default)
* `` xfail `` marks tests with an empty parameterset as xfail(run=False)
2018-09-12 18:18:44 +08:00
* `` fail_at_collect `` raises an exception if parametrize collects an empty parameter set
2018-03-13 06:33:34 +08:00
.. code-block :: ini
# content of pytest.ini
[pytest]
empty_parameter_set_mark = xfail
.. note ::
The default value of this option is planned to change to `` xfail `` in future releases
2021-11-06 17:16:11 +08:00
as this is considered less error prone, see :issue: `3155` for more details.
2018-03-08 07:45:41 +08:00
2019-06-23 06:22:43 +08:00
.. confval :: faulthandler_timeout
Dumps the tracebacks of all threads if a test takes longer than `` X `` seconds to run (including
2021-08-26 22:05:03 +08:00
fixture setup and teardown). Implemented using the :func: `faulthandler.dump_traceback_later` function,
2019-06-23 06:22:43 +08:00
so all caveats there apply.
.. code-block :: ini
# content of pytest.ini
[pytest]
faulthandler_timeout=5
For more information please refer to :ref: `faulthandler` .
2018-03-08 07:45:41 +08:00
.. confval :: filterwarnings
2019-04-28 23:37:58 +08:00
2018-03-08 07:45:41 +08:00
Sets a list of filters and actions that should be taken for matched
warnings. By default all warnings emitted during the test session
will be displayed in a summary at the end of the test session.
.. code-block :: ini
# content of pytest.ini
[pytest]
filterwarnings =
error
ignore::DeprecationWarning
This tells pytest to ignore deprecation warnings and turn all other warnings
into errors. For more information please refer to :ref: `warnings` .
2019-05-30 08:13:16 +08:00
.. confval :: junit_duration_report
.. versionadded :: 4.1
Configures how durations are recorded into the JUnit XML report:
* `` total `` (the default): duration times reported include setup, call, and teardown times.
* `` call `` : duration times reported include only call times, excluding setup and teardown.
.. code-block :: ini
[pytest]
junit_duration_report = call
2019-02-08 23:10:47 +08:00
.. confval :: junit_family
.. versionadded :: 4.2
2020-10-06 01:04:37 +08:00
.. versionchanged :: 6.1
Default changed to `` xunit2 `` .
2019-02-08 23:10:47 +08:00
Configures the format of the generated JUnit XML file. The possible options are:
2020-10-06 01:04:37 +08:00
* `` xunit1 `` (or `` legacy `` ): produces old style output, compatible with the xunit 1.0 format.
* `` xunit2 `` : produces `xunit 2.0 style output <https://github.com/jenkinsci/xunit-plugin/blob/xunit-2.3.2/src/main/resources/org/jenkinsci/plugins/xunit/types/model/xsd/junit-10.xsd> `__ , which should be more compatible with latest Jenkins versions. **This is the default** .
2019-02-08 23:10:47 +08:00
.. code-block :: ini
[pytest]
junit_family = xunit2
2018-03-08 07:45:41 +08:00
2019-05-30 08:13:16 +08:00
.. confval :: junit_logging
2019-04-28 23:37:58 +08:00
2019-05-30 08:13:16 +08:00
.. versionadded :: 3.5
2020-01-16 18:47:00 +08:00
.. versionchanged :: 5.4
`` log `` , `` all `` , `` out-err `` options added.
2019-05-30 08:13:16 +08:00
2020-01-16 18:47:00 +08:00
Configures if captured output should be written to the JUnit XML file. Valid values are:
* `` log `` : write only `` logging `` captured output.
* `` system-out `` : write captured `` stdout `` contents.
* `` system-err `` : write captured `` stderr `` contents.
* `` out-err `` : write both captured `` stdout `` and `` stderr `` contents.
* `` all `` : write captured `` logging `` , `` stdout `` and `` stderr `` contents.
* `` no `` (the default): no captured output is written.
2019-05-30 08:13:16 +08:00
.. code-block :: ini
[pytest]
junit_logging = system-out
.. confval :: junit_log_passing_tests
.. versionadded :: 4.6
If `` junit_logging != "no" `` , configures if the captured output should be written
to the JUnit XML file for **passing** tests. Default is `` True `` .
.. code-block :: ini
[pytest]
junit_log_passing_tests = False
.. confval :: junit_suite_name
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
To set the name of the root test suite xml item, you can configure the `` junit_suite_name `` option in your config file:
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
.. code-block :: ini
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
[pytest]
junit_suite_name = my_suite
2018-03-08 07:45:41 +08:00
2019-10-08 05:56:28 +08:00
.. confval :: log_auto_indent
Allow selective auto-indentation of multiline log messages.
Supports command line option `` --log-auto-indent [value] ``
and config option `` log_auto_indent = [value] `` to set the
auto-indentation behavior for all logging.
`` [value] `` can be:
* True or "On" - Dynamically auto-indent multiline log messages
* False or "Off" or 0 - Do not auto-indent multiline log messages (the default behavior)
* [positive integer] - auto-indent multiline log messages by [value] spaces
.. code-block :: ini
[pytest]
log_auto_indent = False
Supports passing kwarg `` extra={"auto_indent": [value]} `` to
calls to `` logging.log() `` to specify auto-indentation behavior for
a specific entry in the log. `` extra `` kwarg overrides the value specified
on the command line or in the config.
2019-11-25 05:33:51 +08:00
.. confval :: log_cli
Enable log display during test run (also known as :ref: `"live logging" <live_logs>` ).
The default is `` False `` .
.. code-block :: ini
[pytest]
log_cli = True
2018-03-08 07:45:41 +08:00
2018-03-13 07:09:05 +08:00
.. confval :: log_cli_date_format
2019-04-28 23:37:58 +08:00
2018-03-13 07:09:05 +08:00
Sets a :py:func: `time.strftime` -compatible string that will be used when formatting dates for live logging.
.. code-block :: ini
[pytest]
log_cli_date_format = %Y-%m-%d %H:%M:%S
For more information, see :ref: `live_logs` .
.. confval :: log_cli_format
2019-04-28 23:37:58 +08:00
2018-03-13 07:09:05 +08:00
Sets a :py:mod: `logging` -compatible string used to format live logging messages.
.. code-block :: ini
[pytest]
log_cli_format = %(asctime)s %(levelname)s %(message)s
For more information, see :ref: `live_logs` .
.. confval :: log_cli_level
2019-04-28 23:37:58 +08:00
2018-03-13 07:09:05 +08:00
Sets the minimum log message level that should be captured for live logging. The integer value or
the names of the levels can be used.
.. code-block :: ini
[pytest]
2018-03-23 00:02:30 +08:00
log_cli_level = INFO
2018-03-13 07:09:05 +08:00
For more information, see :ref: `live_logs` .
.. confval :: log_date_format
2019-04-28 23:37:58 +08:00
2018-03-13 07:09:05 +08:00
Sets a :py:func: `time.strftime` -compatible string that will be used when formatting dates for logging capture.
.. code-block :: ini
[pytest]
log_date_format = %Y-%m-%d %H:%M:%S
For more information, see :ref: `logging` .
.. confval :: log_file
2019-04-28 23:37:58 +08:00
2018-03-13 07:09:05 +08:00
2022-04-23 02:15:27 +08:00
Sets a file name relative to the current working directory where log messages should be written to, in addition
2018-03-13 07:09:05 +08:00
to the other logging facilities that are active.
.. code-block :: ini
[pytest]
log_file = logs/pytest-logs.txt
For more information, see :ref: `logging` .
.. confval :: log_file_date_format
2019-04-28 23:37:58 +08:00
2018-03-13 07:09:05 +08:00
Sets a :py:func: `time.strftime` -compatible string that will be used when formatting dates for the logging file.
.. code-block :: ini
[pytest]
log_file_date_format = %Y-%m-%d %H:%M:%S
For more information, see :ref: `logging` .
.. confval :: log_file_format
2019-04-28 23:37:58 +08:00
2018-03-13 07:09:05 +08:00
Sets a :py:mod: `logging` -compatible string used to format logging messages redirected to the logging file.
.. code-block :: ini
[pytest]
log_file_format = %(asctime)s %(levelname)s %(message)s
For more information, see :ref: `logging` .
.. confval :: log_file_level
2019-04-28 23:37:58 +08:00
2018-03-13 07:09:05 +08:00
Sets the minimum log message level that should be captured for the logging file. The integer value or
the names of the levels can be used.
.. code-block :: ini
[pytest]
log_file_level = INFO
For more information, see :ref: `logging` .
.. confval :: log_format
2019-04-28 23:37:58 +08:00
2018-03-13 07:09:05 +08:00
Sets a :py:mod: `logging` -compatible string used to format captured logging messages.
.. code-block :: ini
[pytest]
log_format = %(asctime)s %(levelname)s %(message)s
For more information, see :ref: `logging` .
.. confval :: log_level
2019-04-28 23:37:58 +08:00
2018-03-13 07:09:05 +08:00
Sets the minimum log message level that should be captured for logging capture. The integer value or
the names of the levels can be used.
.. code-block :: ini
[pytest]
log_level = INFO
For more information, see :ref: `logging` .
2018-03-13 06:43:04 +08:00
.. confval :: markers
2019-04-27 22:43:36 +08:00
When the `` --strict-markers `` or `` --strict `` command-line arguments are used,
only known markers - defined in code by core pytest or some plugin - are allowed.
2019-02-25 19:30:49 +08:00
2019-04-27 21:52:12 +08:00
You can list additional markers in this setting to add them to the whitelist,
in which case you probably want to add `` --strict-markers `` to `` addopts ``
to avoid future regressions:
2018-03-13 06:43:04 +08:00
.. code-block :: ini
[pytest]
2019-04-27 21:52:12 +08:00
addopts = --strict-markers
2018-03-13 06:43:04 +08:00
markers =
slow
serial
2020-05-22 22:33:50 +08:00
.. note ::
The use of `` --strict-markers `` is highly preferred. `` --strict `` was kept for
backward compatibility only and may be confusing for others as it only applies to
markers and not to other options.
2018-03-13 06:33:34 +08:00
.. confval :: minversion
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
Specifies a minimal pytest version required for running tests.
2018-03-08 07:45:41 +08:00
.. code-block :: ini
# content of pytest.ini
[pytest]
2018-03-13 06:33:34 +08:00
minversion = 3.0 # will fail if we run with pytest-2.8
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
.. confval :: norecursedirs
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
Set the directory basename patterns to avoid when recursing
for test discovery. The individual (fnmatch-style) patterns are
applied to the basename of a directory to decide if to recurse into it.
Pattern matching characters::
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
* matches everything
? matches any single character
[seq] matches any character in seq
[!seq] matches any char not in seq
2018-03-08 07:45:41 +08:00
2020-11-11 09:41:25 +08:00
Default patterns are `` '*.egg' `` , `` '.*' `` , `` '_darcs' `` , `` 'build' `` ,
`` 'CVS' `` , `` 'dist' `` , `` 'node_modules' `` , `` 'venv' `` , `` '{arch}' `` .
2018-03-13 06:33:34 +08:00
Setting a `` norecursedirs `` replaces the default. Here is an example of
how to avoid certain directories:
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
.. code-block :: ini
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
[pytest]
norecursedirs = .svn _build tmp*
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
This would tell `` pytest `` to not look into typical subversion or
sphinx-build directories or into any `` tmp `` prefixed directory.
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
Additionally, `` pytest `` will attempt to intelligently identify and ignore a
virtualenv by the presence of an activation script. Any directory deemed to
be the root of a virtual environment will not be considered during test
2023-08-21 20:40:03 +08:00
collection unless `` --collect-in-virtualenv `` is given. Note also that
`` norecursedirs `` takes precedence over `` --collect-in-virtualenv `` ; e.g. if
2018-03-13 06:33:34 +08:00
you intend to run tests in a virtualenv with a base directory that matches
`` '.*' `` you *must* override `` norecursedirs `` in addition to using the
2023-08-21 20:40:03 +08:00
`` --collect-in-virtualenv `` flag.
2018-03-08 07:45:41 +08:00
2018-03-13 06:33:34 +08:00
.. confval :: python_classes
2018-03-13 06:27:17 +08:00
2018-03-13 06:33:34 +08:00
One or more name prefixes or glob-style patterns determining which classes
2018-08-22 21:37:35 +08:00
are considered for test collection. Search for multiple glob patterns by
adding a space between patterns. By default, pytest will consider any
2018-03-13 06:33:34 +08:00
class prefixed with `` Test `` as a test collection. Here is an example of how
to collect tests from classes that end in `` Suite `` :
2018-03-13 06:27:17 +08:00
2018-03-13 06:33:34 +08:00
.. code-block :: ini
2018-03-13 06:27:17 +08:00
2018-03-13 06:33:34 +08:00
[pytest]
python_classes = *Suite
Note that `` unittest.TestCase `` derived classes are always collected
regardless of this option, as `` unittest `` 's own collection framework is used
to collect those tests.
.. confval :: python_files
One or more Glob-style file patterns determining which python files
2018-08-22 21:37:35 +08:00
are considered as test modules. Search for multiple glob patterns by
2018-09-15 04:20:22 +08:00
adding a space between patterns:
2018-08-22 21:37:35 +08:00
.. code-block :: ini
[pytest]
python_files = test_*.py check_* .py example_*.py
2018-09-15 04:20:22 +08:00
Or one per line:
.. code-block :: ini
[pytest]
python_files =
test_*.py
check_*.py
example_*.py
By default, files matching `` test_*.py `` and `` *_test.py `` will be considered
test modules.
2018-03-13 06:33:34 +08:00
.. confval :: python_functions
One or more name prefixes or glob-patterns determining which test functions
2018-08-22 21:37:35 +08:00
and methods are considered tests. Search for multiple glob patterns by
adding a space between patterns. By default, pytest will consider any
2018-03-13 06:33:34 +08:00
function prefixed with `` test `` as a test. Here is an example of how
to collect test functions and methods that end in `` _test `` :
.. code-block :: ini
2018-03-13 06:27:17 +08:00
[pytest]
2018-03-13 06:33:34 +08:00
python_functions = *_test
2021-11-11 04:54:21 +08:00
Note that this has no effect on methods that live on a `` unittest.TestCase ``
derived class, as `` unittest `` 's own collection framework is used
2018-03-13 06:33:34 +08:00
to collect those tests.
See :ref: `change naming conventions` for more detailed examples.
2021-10-05 14:36:38 +08:00
.. confval :: pythonpath
Sets list of directories that should be added to the python search path.
Directories will be added to the head of :data: `sys.path` .
Similar to the :envvar: `PYTHONPATH` environment variable, the directories will be
included in where Python will look for imported modules.
Paths are relative to the :ref: `rootdir <rootdir>` directory.
Directories remain in path for the duration of the test session.
.. code-block :: ini
[pytest]
pythonpath = src1 src2
2023-06-22 20:45:20 +08:00
.. note ::
`` pythonpath `` does not affect some imports that happen very early,
most notably plugins loaded using the `` -p `` command line option.
2021-10-05 14:36:38 +08:00
2020-06-10 12:44:22 +08:00
.. confval :: required_plugins
2020-06-06 23:05:32 +08:00
A space separated list of plugins that must be present for pytest to run.
2020-06-13 23:22:18 +08:00
Plugins can be listed with or without version specifiers directly following
their name. Whitespace between different version specifiers is not allowed.
2020-06-12 20:27:55 +08:00
If any one of the plugins is not found, emit an error.
2020-06-06 23:05:32 +08:00
.. code-block :: ini
[pytest]
2020-06-13 23:22:18 +08:00
required_plugins = pytest-django>=3.0.0,<4.0.0 pytest-html pytest-xdist>=1.0.0
2020-06-06 23:05:32 +08:00
2018-03-13 06:33:34 +08:00
.. confval :: testpaths
Sets list of directories that should be searched for tests when
no specific directories, files or test ids are given in the command line when
executing pytest from the :ref: `rootdir <rootdir>` directory.
2022-05-24 16:20:51 +08:00
File system paths may use shell-style wildcards, including the recursive
`` ** `` pattern.
2023-05-11 20:22:17 +08:00
2018-03-13 06:33:34 +08:00
Useful when all project tests are in a known location to speed up
test collection and to avoid picking up undesired tests by accident.
.. code-block :: ini
2018-03-13 06:27:17 +08:00
2018-03-13 06:33:34 +08:00
[pytest]
testpaths = testing doc
2018-03-13 06:27:17 +08:00
2023-05-11 20:22:17 +08:00
This configuration means that executing:
.. code-block :: console
pytest
has the same practical effects as executing:
.. code-block :: console
pytest testing doc
2018-03-08 07:45:41 +08:00
2018-03-13 06:43:04 +08:00
2022-11-15 20:11:39 +08:00
.. confval :: tmp_path_retention_count
How many sessions should we keep the `tmp_path` directories,
according to `tmp_path_retention_policy` .
.. code-block :: ini
[pytest]
tmp_path_retention_count = 3
2023-05-11 20:30:43 +08:00
Default: `` 3 ``
2022-11-15 20:11:39 +08:00
.. confval :: tmp_path_retention_policy
Controls which directories created by the `tmp_path` fixture are kept around,
based on test outcome.
* `all` : retains directories for all tests, regardless of the outcome.
* `failed` : retains directories only for tests with outcome `error` or `failed` .
* `none` : directories are always removed after each test ends, regardless of the outcome.
.. code-block :: ini
[pytest]
tmp_path_retention_policy = "all"
2023-05-11 20:30:43 +08:00
Default: `` all ``
2022-11-15 20:11:39 +08:00
2018-03-13 06:43:04 +08:00
.. confval :: usefixtures
List of fixtures that will be applied to all test functions; this is semantically the same to apply
the `` @pytest.mark.usefixtures `` marker to all test functions.
.. code-block :: ini
[pytest]
usefixtures =
clean_db
.. confval :: xfail_strict
If set to `` True `` , tests marked with `` @pytest.mark.xfail `` that actually succeed will by default fail the
test suite.
For more information, see :ref: `xfail strict tutorial` .
.. code-block :: ini
[pytest]
xfail_strict = True
2020-09-12 22:30:14 +08:00
.. _`command-line-flags`:
Command-line Flags
------------------
All the command-line flags can be obtained by running `` pytest --help `` ::
$ pytest --help
usage: pytest [options] [file_or_dir] [file_or_dir] [...]
2022-10-25 19:12:55 +08:00
positional arguments:
2020-09-12 22:30:14 +08:00
file_or_dir
2022-10-25 19:12:55 +08:00
general:
2022-06-01 03:32:51 +08:00
-k EXPRESSION Only run tests which match the given substring
2022-10-25 19:12:55 +08:00
expression. An expression is a Python evaluatable
2020-09-12 22:30:14 +08:00
expression where all names are substring-matched
against test names and their parent classes.
Example: -k 'test_method or test_other' matches all
test functions and classes whose name contains
'test_method' or 'test_other', while -k 'not
test_method' matches those that don't contain
'test_method' in their names. -k 'not test_method
and not test_other' will eliminate the matches.
Additionally keywords are matched to classes and
functions containing extra names in their
'extra_keyword_matches' set, as well as functions
which have names assigned directly to them. The
matching is case-insensitive.
2022-10-25 19:12:55 +08:00
-m MARKEXPR Only run tests matching given mark expression. For
example: -m 'mark1 and not mark2'.
--markers show markers (builtin, plugin and per-project ones).
2022-06-01 03:32:51 +08:00
-x, --exitfirst Exit instantly on first error or failed test
2020-09-12 22:30:14 +08:00
--fixtures, --funcargs
2022-06-01 03:32:51 +08:00
Show available fixtures, sorted by plugin appearance
2020-09-12 22:30:14 +08:00
(fixtures with leading '_' are only shown with '-v')
2022-06-01 03:32:51 +08:00
--fixtures-per-test Show fixtures per test
--pdb Start the interactive Python debugger on errors or
KeyboardInterrupt
2020-09-12 22:30:14 +08:00
--pdbcls=modulename:classname
2022-06-01 03:32:51 +08:00
Specify a custom interactive Python debugger for use
2022-10-25 19:12:55 +08:00
with --pdb.For example:
2020-09-12 22:30:14 +08:00
--pdbcls=IPython.terminal.debugger:TerminalPdb
2022-06-01 03:32:51 +08:00
--trace Immediately break when running each test
2022-10-25 19:12:55 +08:00
--capture=method Per-test capturing method: one of fd|sys|no|tee-sys
-s Shortcut for --capture=no
2022-06-01 03:32:51 +08:00
--runxfail Report the results of xfail tests as if they were
2020-09-12 22:30:14 +08:00
not marked
2022-06-01 03:32:51 +08:00
--lf, --last-failed Rerun only the tests that failed at the last run (or
2020-09-12 22:30:14 +08:00
all if none failed)
2022-10-25 19:12:55 +08:00
--ff, --failed-first Run all tests, but run the last failures first. This
may re-order tests and thus lead to repeated fixture
setup/teardown.
2022-06-01 03:32:51 +08:00
--nf, --new-first Run tests from new files first, then the rest of the
2020-09-12 22:30:14 +08:00
tests sorted by file mtime
--cache-show=[CACHESHOW]
2022-06-01 03:32:51 +08:00
Show cache contents, don't perform collection or
2020-09-12 22:30:14 +08:00
tests. Optional argument: glob (default: '*').
2022-06-01 03:32:51 +08:00
--cache-clear Remove all cache contents at start of test run
2020-09-12 22:30:14 +08:00
--lfnf={all,none}, --last-failed-no-failures={all,none}
2023-09-02 23:41:32 +08:00
With `` --lf `` , determines whether to execute tests
when there are no previously (known) failures or
when no cached `` lastfailed `` data was found.
`` all `` (the default) runs the full test suite
again. `` none `` just emits a message about no known
failures and exits successfully.
2022-06-01 03:32:51 +08:00
--sw, --stepwise Exit on test failure and continue from last failing
2020-09-12 22:30:14 +08:00
test next time
2020-12-13 05:21:28 +08:00
--sw-skip, --stepwise-skip
2022-06-01 03:32:51 +08:00
Ignore the first failing test but stop on the next
2022-10-25 19:12:55 +08:00
failing test. Implicitly enables --stepwise.
2020-09-12 22:30:14 +08:00
2022-06-01 03:32:51 +08:00
Reporting:
2022-10-25 19:12:55 +08:00
--durations=N Show N slowest setup/test durations (N=0 for all)
2020-09-12 22:30:14 +08:00
--durations-min=N Minimal duration in seconds for inclusion in slowest
2022-06-01 03:32:51 +08:00
list. Default: 0.005.
-v, --verbose Increase verbosity
--no-header Disable header
--no-summary Disable summary
-q, --quiet Decrease verbosity
--verbosity=VERBOSE Set verbosity. Default: 0.
-r chars Show extra test summary info as specified by chars:
2020-09-12 22:30:14 +08:00
(f)ailed, (E)rror, (s)kipped, (x)failed, (X)passed,
(p)assed, (P)assed with output, (a)ll except passed
(p/P), or (A)ll. (w)arnings are enabled by default
(see --disable-warnings), 'N' can be used to reset
the list. (default: 'fE').
--disable-warnings, --disable-pytest-warnings
2022-06-01 03:32:51 +08:00
Disable warnings summary
-l, --showlocals Show locals in tracebacks (disabled by default)
2022-10-25 19:12:55 +08:00
--no-showlocals Hide locals in tracebacks (negate --showlocals
passed through addopts)
2022-06-01 03:32:51 +08:00
--tb=style Traceback print mode
2022-10-25 19:12:55 +08:00
(auto/long/short/line/native/no)
2020-09-12 22:30:14 +08:00
--show-capture={no,stdout,stderr,log,all}
Controls how captured stdout/stderr/log is shown on
2022-06-01 03:32:51 +08:00
failed tests. Default: all.
--full-trace Don't cut any tracebacks (default is to cut)
--color=color Color terminal output (yes/no/auto)
2020-09-12 22:30:14 +08:00
--code-highlight={yes,no}
Whether code should be highlighted (only if --color
2022-06-01 03:32:51 +08:00
is also enabled). Default: yes.
--pastebin=mode Send failed|all info to bpaste.net pastebin service
--junit-xml=path Create junit-xml style report file at given path
--junit-prefix=str Prepend prefix to classnames in junit-xml output
2020-09-12 22:30:14 +08:00
pytest-warnings:
-W PYTHONWARNINGS, --pythonwarnings=PYTHONWARNINGS
2022-06-01 03:32:51 +08:00
Set which warnings to report, see -W option of
Python itself
--maxfail=num Exit after first num failures or errors
--strict-config Any warnings encountered while parsing the `pytest`
section of the configuration file raise errors
--strict-markers Markers not registered in the `markers` section of
the configuration file raise errors
--strict (Deprecated) alias to --strict-markers
2023-06-23 19:18:43 +08:00
-c FILE, --config-file=FILE
2023-05-26 18:56:18 +08:00
Load configuration from `FILE` instead of trying to
2023-06-23 19:18:43 +08:00
locate one of the implicit configuration files.
2020-09-12 22:30:14 +08:00
--continue-on-collection-errors
2022-10-25 19:12:55 +08:00
Force test execution even if collection errors occur
2020-09-12 22:30:14 +08:00
--rootdir=ROOTDIR Define root directory for tests. Can be relative
path: 'root_dir', './root_dir',
'root_dir/another_dir/'; absolute path:
'/home/user/root_dir'; path with variables:
'$HOME/root_dir'.
2022-10-25 19:12:55 +08:00
collection:
2022-06-01 03:32:51 +08:00
--collect-only, --co Only collect tests, don't execute them
--pyargs Try to interpret all arguments as Python packages
--ignore=path Ignore path during collection (multi-allowed)
--ignore-glob=path Ignore path pattern during collection (multi-
allowed)
2020-09-12 22:30:14 +08:00
--deselect=nodeid_prefix
2022-06-01 03:32:51 +08:00
Deselect item (via node id prefix) during collection
(multi-allowed)
--confcutdir=dir Only load conftest.py's relative to specified dir
--noconftest Don't load any conftest.py files
--keep-duplicates Keep duplicate tests
2020-09-12 22:30:14 +08:00
--collect-in-virtualenv
Don't ignore tests in a local virtualenv directory
--import-mode={prepend,append,importlib}
2022-06-01 03:32:51 +08:00
Prepend/append to sys.path when importing test
modules and conftest files. Default: prepend.
--doctest-modules Run doctests in all .py modules
2020-09-12 22:30:14 +08:00
--doctest-report={none,cdiff,ndiff,udiff,only_first_failure}
2022-06-01 03:32:51 +08:00
Choose another output format for diffs on doctest
2020-09-12 22:30:14 +08:00
failure
2022-06-01 03:32:51 +08:00
--doctest-glob=pat Doctests file matching pattern, default: test*.txt
2020-09-12 22:30:14 +08:00
--doctest-ignore-import-errors
2022-06-01 03:32:51 +08:00
Ignore doctest ImportErrors
2020-09-12 22:30:14 +08:00
--doctest-continue-on-failure
2022-06-01 03:32:51 +08:00
For a given doctest, continue to run after the first
2020-09-12 22:30:14 +08:00
failure
2022-10-25 19:12:55 +08:00
test session debugging and configuration:
--basetemp=dir Base temporary directory for this test run.
(Warning: this directory is removed if it exists.)
2022-06-01 03:32:51 +08:00
-V, --version Display pytest version and information about
2021-10-04 14:56:26 +08:00
plugins. When given twice, also display information
2020-09-12 22:30:14 +08:00
about plugins.
2022-06-01 03:32:51 +08:00
-h, --help Show help message and configuration info
-p name Early-load given plugin module name or entry point
2022-10-25 19:12:55 +08:00
(multi-allowed). To avoid loading of plugins, use
the `no:` prefix, e.g. `no:doctest` .
2022-06-01 03:32:51 +08:00
--trace-config Trace considerations of conftest.py files
2021-10-04 14:56:26 +08:00
--debug=[DEBUG_FILE_NAME]
2022-06-01 03:32:51 +08:00
Store internal tracing debug information in this log
2022-10-25 19:12:55 +08:00
file. This file is opened with 'w' and truncated as
a result, care advised. Default: pytestdebug.log.
2020-09-12 22:30:14 +08:00
-o OVERRIDE_INI, --override-ini=OVERRIDE_INI
2022-06-01 03:32:51 +08:00
Override ini option with "option=value" style, e.g.
2022-10-25 19:12:55 +08:00
`-o xfail_strict=True -o cache_dir=cache` .
2020-09-12 22:30:14 +08:00
--assert=MODE Control assertion debugging tools.
'plain' performs no assertion debugging.
'rewrite' (the default) rewrites assert statements
in test modules on import to provide assert
expression information.
2022-06-01 03:32:51 +08:00
--setup-only Only setup fixtures, do not execute tests
--setup-show Show setup of fixtures while executing tests
--setup-plan Show what fixtures and tests would be executed but
don't execute anything
2020-09-12 22:30:14 +08:00
2022-10-25 19:12:55 +08:00
logging:
--log-level=LEVEL Level of messages to catch/display. Not set by
default, so it depends on the root/parent log
handler's effective level, where it is "WARNING" by
default.
2020-09-12 22:30:14 +08:00
--log-format=LOG_FORMAT
2022-06-01 03:32:51 +08:00
Log format used by the logging module
2020-09-12 22:30:14 +08:00
--log-date-format=LOG_DATE_FORMAT
2022-06-01 03:32:51 +08:00
Log date format used by the logging module
2020-09-12 22:30:14 +08:00
--log-cli-level=LOG_CLI_LEVEL
2022-06-01 03:32:51 +08:00
CLI logging level
2020-09-12 22:30:14 +08:00
--log-cli-format=LOG_CLI_FORMAT
2022-06-01 03:32:51 +08:00
Log format used by the logging module
2020-09-12 22:30:14 +08:00
--log-cli-date-format=LOG_CLI_DATE_FORMAT
2022-06-01 03:32:51 +08:00
Log date format used by the logging module
--log-file=LOG_FILE Path to a file when logging will be written to
2020-09-12 22:30:14 +08:00
--log-file-level=LOG_FILE_LEVEL
2022-06-01 03:32:51 +08:00
Log file logging level
2020-09-12 22:30:14 +08:00
--log-file-format=LOG_FILE_FORMAT
2022-06-01 03:32:51 +08:00
Log format used by the logging module
2020-09-12 22:30:14 +08:00
--log-file-date-format=LOG_FILE_DATE_FORMAT
2022-06-01 03:32:51 +08:00
Log date format used by the logging module
2020-09-12 22:30:14 +08:00
--log-auto-indent=LOG_AUTO_INDENT
Auto-indent multiline messages passed to the logging
module. Accepts true|on, false|off or an integer.
2023-03-17 16:32:08 +08:00
--log-disable=LOGGER_DISABLE
2023-04-25 16:49:16 +08:00
Disable a logger by name. Can be passed multiple
2023-03-17 16:32:08 +08:00
times.
2020-09-12 22:30:14 +08:00
2023-03-11 21:59:02 +08:00
[pytest] ini-options in the first pytest.ini|tox.ini|setup.cfg|pyproject.toml file found:
2020-09-12 22:30:14 +08:00
2022-06-01 03:32:51 +08:00
markers (linelist): Markers for test functions
2020-09-12 22:30:14 +08:00
empty_parameter_set_mark (string):
2022-06-01 03:32:51 +08:00
Default marker for empty parametersets
norecursedirs (args): Directory patterns to avoid for recursion
testpaths (args): Directories to search for tests when no files or
2022-10-25 19:12:55 +08:00
directories are given on the command line
2020-09-12 22:30:14 +08:00
filterwarnings (linelist):
Each line specifies a pattern for
warnings.filterwarnings. Processed after
-W/--pythonwarnings.
2022-06-01 03:32:51 +08:00
usefixtures (args): List of default fixtures to be used with this
2020-09-12 22:30:14 +08:00
project
2022-06-01 03:32:51 +08:00
python_files (args): Glob-style file patterns for Python test module
2020-09-12 22:30:14 +08:00
discovery
python_classes (args):
2022-06-01 03:32:51 +08:00
Prefixes or glob names for Python test class
2020-09-12 22:30:14 +08:00
discovery
python_functions (args):
2022-06-01 03:32:51 +08:00
Prefixes or glob names for Python test function and
2020-09-12 22:30:14 +08:00
method discovery
disable_test_id_escaping_and_forfeit_all_rights_to_community_support (bool):
2022-06-01 03:32:51 +08:00
Disable string escape non-ASCII characters, might
2020-09-12 22:30:14 +08:00
cause unwanted side effects(use at your own risk)
console_output_style (string):
2022-06-01 03:32:51 +08:00
Console output: "classic", or with additional
2020-09-12 22:30:14 +08:00
progress information ("progress" (percentage) |
2023-03-17 16:32:08 +08:00
"count" | "progress-even-when-capture-no" (forces
progress even when capture=no)
2022-06-01 03:32:51 +08:00
xfail_strict (bool): Default for the strict parameter of xfail markers
2020-09-12 22:30:14 +08:00
when not given explicitly (default: False)
2023-03-17 16:32:08 +08:00
tmp_path_retention_count (string):
How many sessions should we keep the `tmp_path`
directories, according to
`tmp_path_retention_policy` .
tmp_path_retention_policy (string):
Controls which directories created by the `tmp_path`
fixture are kept around, based on test outcome.
(all/failed/none)
2020-09-12 22:30:14 +08:00
enable_assertion_pass_hook (bool):
2022-06-01 03:32:51 +08:00
Enables the pytest_assertion_pass hook. Make sure to
2020-09-12 22:30:14 +08:00
delete any previously generated pyc cache files.
junit_suite_name (string):
Test suite name for JUnit report
junit_logging (string):
Write captured log messages to JUnit report: one of
no|log|system-out|system-err|out-err|all
junit_log_passing_tests (bool):
Capture log information for passing tests to JUnit
report:
junit_duration_report (string):
Duration time to report: one of total|call
junit_family (string):
Emit XML for schema: one of legacy|xunit1|xunit2
doctest_optionflags (args):
2022-06-01 03:32:51 +08:00
Option flags for doctests
2020-09-12 22:30:14 +08:00
doctest_encoding (string):
2022-06-01 03:32:51 +08:00
Encoding used for doctest files
cache_dir (string): Cache directory path
log_level (string): Default value for --log-level
log_format (string): Default value for --log-format
2020-09-12 22:30:14 +08:00
log_date_format (string):
2022-06-01 03:32:51 +08:00
Default value for --log-date-format
log_cli (bool): Enable log display during test run (also known as
"live logging")
2020-09-12 22:30:14 +08:00
log_cli_level (string):
2022-06-01 03:32:51 +08:00
Default value for --log-cli-level
2020-09-12 22:30:14 +08:00
log_cli_format (string):
2022-06-01 03:32:51 +08:00
Default value for --log-cli-format
2020-09-12 22:30:14 +08:00
log_cli_date_format (string):
2022-06-01 03:32:51 +08:00
Default value for --log-cli-date-format
log_file (string): Default value for --log-file
2020-09-12 22:30:14 +08:00
log_file_level (string):
2022-06-01 03:32:51 +08:00
Default value for --log-file-level
2020-09-12 22:30:14 +08:00
log_file_format (string):
2022-06-01 03:32:51 +08:00
Default value for --log-file-format
2020-09-12 22:30:14 +08:00
log_file_date_format (string):
2022-06-01 03:32:51 +08:00
Default value for --log-file-date-format
2020-09-12 22:30:14 +08:00
log_auto_indent (string):
2022-06-01 03:32:51 +08:00
Default value for --log-auto-indent
2021-12-07 17:13:36 +08:00
pythonpath (paths): Add paths to sys.path
2020-09-12 22:30:14 +08:00
faulthandler_timeout (string):
Dump the traceback of all threads if a test takes
2022-06-01 03:32:51 +08:00
more than TIMEOUT seconds to finish
addopts (args): Extra command line options
minversion (string): Minimally required pytest version
2020-09-12 22:30:14 +08:00
required_plugins (args):
2022-06-01 03:32:51 +08:00
Plugins that must be present for pytest to run
2020-09-12 22:30:14 +08:00
2022-06-01 03:32:51 +08:00
Environment variables:
PYTEST_ADDOPTS Extra command line options
PYTEST_PLUGINS Comma-separated plugins to load during startup
PYTEST_DISABLE_PLUGIN_AUTOLOAD Set to disable plugin auto-loading
PYTEST_DEBUG Set to enable debug tracing of pytest's internals
2020-09-12 22:30:14 +08:00
to see available markers type: pytest --markers
to see available fixtures type: pytest --fixtures
(shown according to specified file_or_dir or current dir if not specified; fixtures with leading '_' are only shown with the '-v' option