Add section on how to update marks and add ref to the deprecation notice
This commit is contained in:
parent
718ba83600
commit
2cd159e8c5
|
@ -32,8 +32,9 @@ RESULT_LOG = (
|
||||||
)
|
)
|
||||||
|
|
||||||
MARK_INFO_ATTRIBUTE = RemovedInPytest4Warning(
|
MARK_INFO_ATTRIBUTE = RemovedInPytest4Warning(
|
||||||
"MarkInfo objects are deprecated as they contain the merged marks.\n"
|
"MarkInfo objects are deprecated as they contain merged marks which are hard to deal with correctly.\n"
|
||||||
"Please use node.iter_markers to iterate over markers correctly"
|
"Please use node.get_closest_marker(name) or node.iter_markers(name).\n"
|
||||||
|
"Docs: https://docs.pytest.org/en/latest/mark.html#updating-code"
|
||||||
)
|
)
|
||||||
|
|
||||||
MARK_PARAMETERSET_UNPACKING = RemovedInPytest4Warning(
|
MARK_PARAMETERSET_UNPACKING = RemovedInPytest4Warning(
|
||||||
|
|
|
@ -51,8 +51,57 @@ in fact, markers where only accessible in functions, even if they where declared
|
||||||
|
|
||||||
A new API to access markers has been introduced in pytest 3.6 in order to solve the problems with the initial design, providing :func:`_pytest.nodes.Node.iter_markers` method to iterate over markers in a consistent manner and reworking the internals, which solved great deal of problems with the initial design.
|
A new API to access markers has been introduced in pytest 3.6 in order to solve the problems with the initial design, providing :func:`_pytest.nodes.Node.iter_markers` method to iterate over markers in a consistent manner and reworking the internals, which solved great deal of problems with the initial design.
|
||||||
|
|
||||||
Here is a non-exhaustive list of issues fixed by the new implementation:
|
Updating code
|
||||||
|
~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
The old ``Node.get_marker(name)`` function is considered deprecated because it returns an internal ``MarkerInfo`` object
|
||||||
|
which contains the merged name, ``*args`` and ``**kwargs**`` of all the markers which apply to that node.
|
||||||
|
|
||||||
|
In general there are two scenarios on how markers should be handled:
|
||||||
|
|
||||||
|
1. Marks overwrite each other. Order matters but you only want to think of your mark as a single item. E.g.
|
||||||
|
``log_level('info')`` at a module level can be overwritten by ``log_level('debug')`` for a specific test.
|
||||||
|
|
||||||
|
In this case replace use ``Node.get_closest_marker(name)``:
|
||||||
|
|
||||||
|
.. code-block:: python
|
||||||
|
|
||||||
|
# replace this:
|
||||||
|
marker = item.get_marker('log_level')
|
||||||
|
if marker:
|
||||||
|
level = marker.args[0]
|
||||||
|
|
||||||
|
# by this:
|
||||||
|
marker = item.get_closest_marker('log_level')
|
||||||
|
if marker:
|
||||||
|
level = marker.args[0]
|
||||||
|
|
||||||
|
2. Marks compose additive. E.g. ``skipif(condition)`` marks means you just want to evaluate all of them,
|
||||||
|
order doesn't even matter. You probably want to think of your marks as a set here.
|
||||||
|
|
||||||
|
In this case iterate over each mark and handle their ``*args`` and ``**kwargs`` individually.
|
||||||
|
|
||||||
|
.. code-block:: python
|
||||||
|
|
||||||
|
# replace this
|
||||||
|
skipif = item.get_marker('skipif')
|
||||||
|
if skipif:
|
||||||
|
for condition in skipif.args:
|
||||||
|
# eval condition
|
||||||
|
|
||||||
|
# by this:
|
||||||
|
for skipif in item.iter_markers('skipif):
|
||||||
|
condition = skipif.args[0]
|
||||||
|
# eval condition
|
||||||
|
|
||||||
|
|
||||||
|
If you are unsure or have any questions, please consider opening
|
||||||
|
`an issue <https://github.com/pytest-dev/pytest/issues>`_.
|
||||||
|
|
||||||
|
Related issues
|
||||||
|
~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Here is a non-exhaustive list of issues fixed by the new implementation:
|
||||||
|
|
||||||
* Marks don't pick up nested classes (`#199 <https://github.com/pytest-dev/pytest/issues/199>`_).
|
* Marks don't pick up nested classes (`#199 <https://github.com/pytest-dev/pytest/issues/199>`_).
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue