Revamp the mark section in the docs

Add an introductory section about how to register marks,
including doing so programatically (#5255).
This commit is contained in:
Bruno Oliveira 2019-05-14 20:49:47 -03:00
parent c8f7e50c47
commit 7e8044f9b8
2 changed files with 36 additions and 17 deletions

View File

@ -24,40 +24,57 @@ which also serve as documentation.
:ref:`fixtures <fixtures>`. :ref:`fixtures <fixtures>`.
.. _unknown-marks: Registering marks
-----------------
Raising errors on unknown marks You can register custom marks in your ``pytest.ini`` file like this:
-------------------------------
Unknown marks applied with the ``@pytest.mark.name_of_the_mark`` decorator
will always emit a warning, in order to avoid silently doing something
surprising due to mis-typed names. You can disable the warning for custom
marks by registering them in ``pytest.ini`` like this:
.. code-block:: ini .. code-block:: ini
[pytest] [pytest]
markers = markers =
slow slow: marks tests as slow (deselect with '-m "not slow"')
serial serial
Note that everything after the ``:`` is an optional description.
Alternatively, you can register new markers programatically in a
:ref:`pytest_configure <initialization-hooks>` hook:
.. code-block:: python
def pytest_configure(config):
config.addinivalue_line(
"markers", "env(name): mark test to run only on named environment"
)
Registered marks appear in pytest's help text and do not emit warnings (see the next section). It
is recommended that third-party plugins always :ref:`register their markers <registering-markers>`.
.. _unknown-marks:
Raising errors on unknown marks
-------------------------------
Unregistered marks applied with the ``@pytest.mark.name_of_the_mark`` decorator
will always emit a warning in order to avoid silently doing something
surprising due to mis-typed names. As described in the previous section, you can disable
the warning for custom marks by registering them in your ``pytest.ini`` file or
using a custom ``pytest_configure`` hook.
When the ``--strict-markers`` command-line flag is passed, any unknown marks applied When the ``--strict-markers`` command-line flag is passed, any unknown marks applied
with the ``@pytest.mark.name_of_the_mark`` decorator will trigger an error. with the ``@pytest.mark.name_of_the_mark`` decorator will trigger an error. You can
Marks added by pytest or by a plugin instead of the decorator will not trigger enforce this validation in your project by adding ``--strict-markers`` to ``addopts``:
this error. To enforce validation of markers, add ``--strict-markers`` to ``addopts``:
.. code-block:: ini .. code-block:: ini
[pytest] [pytest]
addopts = --strict-markers addopts = --strict-markers
markers = markers =
slow slow: marks tests as slow (deselect with '-m "not slow"')
serial serial
Third-party plugins should always :ref:`register their markers <registering-markers>`
so that they appear in pytest's help text and do not emit warnings.
.. _marker-revamp: .. _marker-revamp:
Marker revamp and iteration Marker revamp and iteration

View File

@ -581,6 +581,8 @@ Bootstrapping hooks called for plugins registered early enough (internal and set
.. autofunction:: pytest_cmdline_parse .. autofunction:: pytest_cmdline_parse
.. autofunction:: pytest_cmdline_main .. autofunction:: pytest_cmdline_main
.. _`initialization-hooks`:
Initialization hooks Initialization hooks
~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~