From 7e8044f9b819e1b137518f5a5051f983cd1fd824 Mon Sep 17 00:00:00 2001 From: Bruno Oliveira Date: Tue, 14 May 2019 20:49:47 -0300 Subject: [PATCH] Revamp the mark section in the docs Add an introductory section about how to register marks, including doing so programatically (#5255). --- doc/en/mark.rst | 51 +++++++++++++++++++++++++++++--------------- doc/en/reference.rst | 2 ++ 2 files changed, 36 insertions(+), 17 deletions(-) diff --git a/doc/en/mark.rst b/doc/en/mark.rst index 05ffdb36c..2f96ee3ae 100644 --- a/doc/en/mark.rst +++ b/doc/en/mark.rst @@ -24,40 +24,57 @@ which also serve as documentation. :ref:`fixtures `. -.. _unknown-marks: +Registering marks +----------------- -Raising errors on unknown marks -------------------------------- - -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: +You can register custom marks in your ``pytest.ini`` file like this: .. code-block:: ini [pytest] markers = - slow + slow: marks tests as slow (deselect with '-m "not slow"') serial +Note that everything after the ``:`` is an optional description. + +Alternatively, you can register new markers programatically in a +:ref:`pytest_configure ` 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 `. + +.. _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 -with the ``@pytest.mark.name_of_the_mark`` decorator will trigger an error. -Marks added by pytest or by a plugin instead of the decorator will not trigger -this error. To enforce validation of markers, add ``--strict-markers`` to ``addopts``: +with the ``@pytest.mark.name_of_the_mark`` decorator will trigger an error. You can +enforce this validation in your project by adding ``--strict-markers`` to ``addopts``: .. code-block:: ini [pytest] addopts = --strict-markers markers = - slow + slow: marks tests as slow (deselect with '-m "not slow"') serial -Third-party plugins should always :ref:`register their markers ` -so that they appear in pytest's help text and do not emit warnings. - - .. _marker-revamp: Marker revamp and iteration diff --git a/doc/en/reference.rst b/doc/en/reference.rst index 61f8034ed..f76fc7765 100644 --- a/doc/en/reference.rst +++ b/doc/en/reference.rst @@ -581,6 +581,8 @@ Bootstrapping hooks called for plugins registered early enough (internal and set .. autofunction:: pytest_cmdline_parse .. autofunction:: pytest_cmdline_main +.. _`initialization-hooks`: + Initialization hooks ~~~~~~~~~~~~~~~~~~~~