Merge pull request #4555 from nicoddemus/remove-record-xml-pytest-main-str
Remove record_xml_property and support for strings in pytest.main()
This commit is contained in:
commit
c6d27d8224
|
@ -0,0 +1,3 @@
|
||||||
|
Removed support for passing strings to ``pytest.main``. Now, always pass a list of strings instead.
|
||||||
|
|
||||||
|
See our `docs <https://docs.pytest.org/en/latest/deprecations.html#passing-command-line-string-to-pytest-main>`__ on information on how to update your code.
|
|
@ -0,0 +1,3 @@
|
||||||
|
The deprecated ``record_xml_property`` fixture has been removed, use the more generic ``record_property`` instead.
|
||||||
|
|
||||||
|
See our `docs <https://docs.pytest.org/en/latest/deprecations.html#record-xml-property>`__ for more information.
|
|
@ -149,28 +149,6 @@ As part of a large :ref:`marker-revamp`, :meth:`_pytest.nodes.Node.get_marker` i
|
||||||
:ref:`the documentation <update marker code>` on tips on how to update your code.
|
:ref:`the documentation <update marker code>` on tips on how to update your code.
|
||||||
|
|
||||||
|
|
||||||
record_xml_property
|
|
||||||
~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
.. deprecated:: 3.5
|
|
||||||
|
|
||||||
The ``record_xml_property`` fixture is now deprecated in favor of the more generic ``record_property``, which
|
|
||||||
can be used by other consumers (for example ``pytest-html``) to obtain custom information about the test run.
|
|
||||||
|
|
||||||
This is just a matter of renaming the fixture as the API is the same:
|
|
||||||
|
|
||||||
.. code-block:: python
|
|
||||||
|
|
||||||
def test_foo(record_xml_property):
|
|
||||||
...
|
|
||||||
|
|
||||||
Change to:
|
|
||||||
|
|
||||||
.. code-block:: python
|
|
||||||
|
|
||||||
def test_foo(record_property):
|
|
||||||
...
|
|
||||||
|
|
||||||
pytest_plugins in non-top-level conftest files
|
pytest_plugins in non-top-level conftest files
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
@ -215,27 +193,6 @@ To update the code, use ``pytest.param``:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Passing command-line string to ``pytest.main()``
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
.. deprecated:: 3.0
|
|
||||||
|
|
||||||
Passing a command-line string to ``pytest.main()`` is deprecated:
|
|
||||||
|
|
||||||
.. code-block:: python
|
|
||||||
|
|
||||||
pytest.main("-v -s")
|
|
||||||
|
|
||||||
Pass a list instead:
|
|
||||||
|
|
||||||
.. code-block:: python
|
|
||||||
|
|
||||||
pytest.main(["-v", "-s"])
|
|
||||||
|
|
||||||
|
|
||||||
By passing a string, users expect that pytest will interpret that command-line using the shell rules they are working
|
|
||||||
on (for example ``bash`` or ``Powershell``), but this is very hard/impossible to do in a portable way.
|
|
||||||
|
|
||||||
|
|
||||||
[pytest] section in setup.cfg files
|
[pytest] section in setup.cfg files
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
@ -353,6 +310,52 @@ more information.
|
||||||
|
|
||||||
This has been documented as deprecated for years, but only now we are actually emitting deprecation warnings.
|
This has been documented as deprecated for years, but only now we are actually emitting deprecation warnings.
|
||||||
|
|
||||||
|
record_xml_property
|
||||||
|
~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
*Removed in version 4.0.*
|
||||||
|
|
||||||
|
The ``record_xml_property`` fixture is now deprecated in favor of the more generic ``record_property``, which
|
||||||
|
can be used by other consumers (for example ``pytest-html``) to obtain custom information about the test run.
|
||||||
|
|
||||||
|
This is just a matter of renaming the fixture as the API is the same:
|
||||||
|
|
||||||
|
.. code-block:: python
|
||||||
|
|
||||||
|
def test_foo(record_xml_property):
|
||||||
|
...
|
||||||
|
|
||||||
|
Change to:
|
||||||
|
|
||||||
|
.. code-block:: python
|
||||||
|
|
||||||
|
def test_foo(record_property):
|
||||||
|
...
|
||||||
|
|
||||||
|
|
||||||
|
Passing command-line string to ``pytest.main()``
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
*Removed in version 4.0.*
|
||||||
|
|
||||||
|
Passing a command-line string to ``pytest.main()`` is deprecated:
|
||||||
|
|
||||||
|
.. code-block:: python
|
||||||
|
|
||||||
|
pytest.main("-v -s")
|
||||||
|
|
||||||
|
Pass a list instead:
|
||||||
|
|
||||||
|
.. code-block:: python
|
||||||
|
|
||||||
|
pytest.main(["-v", "-s"])
|
||||||
|
|
||||||
|
|
||||||
|
By passing a string, users expect that pytest will interpret that command-line using the shell rules they are working
|
||||||
|
on (for example ``bash`` or ``Powershell``), but this is very hard/impossible to do in a portable way.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
``yield`` tests
|
``yield`` tests
|
||||||
~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
|
|
@ -173,12 +173,9 @@ def _prepareconfig(args=None, plugins=None):
|
||||||
elif isinstance(args, py.path.local):
|
elif isinstance(args, py.path.local):
|
||||||
args = [str(args)]
|
args = [str(args)]
|
||||||
elif not isinstance(args, (tuple, list)):
|
elif not isinstance(args, (tuple, list)):
|
||||||
if not isinstance(args, str):
|
msg = "`args` parameter expected to be a list or tuple of strings, got: {!r} (type: {})"
|
||||||
raise ValueError("not a string or argument list: %r" % (args,))
|
raise TypeError(msg.format(args, type(args)))
|
||||||
args = shlex.split(args, posix=sys.platform != "win32")
|
|
||||||
from _pytest import deprecated
|
|
||||||
|
|
||||||
warning = deprecated.MAIN_STR_ARGS
|
|
||||||
config = get_config()
|
config = get_config()
|
||||||
pluginmanager = config.pluginmanager
|
pluginmanager = config.pluginmanager
|
||||||
try:
|
try:
|
||||||
|
|
|
@ -17,11 +17,6 @@ from _pytest.warning_types import RemovedInPytest4Warning
|
||||||
from _pytest.warning_types import UnformattedWarning
|
from _pytest.warning_types import UnformattedWarning
|
||||||
|
|
||||||
|
|
||||||
MAIN_STR_ARGS = RemovedInPytest4Warning(
|
|
||||||
"passing a string to pytest.main() is deprecated, "
|
|
||||||
"pass a list of arguments instead."
|
|
||||||
)
|
|
||||||
|
|
||||||
YIELD_TESTS = "yield tests were removed in pytest 4.0 - {name} will be ignored"
|
YIELD_TESTS = "yield tests were removed in pytest 4.0 - {name} will be ignored"
|
||||||
|
|
||||||
|
|
||||||
|
@ -82,12 +77,6 @@ WARNS_EXEC = PytestDeprecationWarning(
|
||||||
"See https://docs.pytest.org/en/latest/deprecations.html#raises-warns-exec"
|
"See https://docs.pytest.org/en/latest/deprecations.html#raises-warns-exec"
|
||||||
)
|
)
|
||||||
|
|
||||||
RECORD_XML_PROPERTY = RemovedInPytest4Warning(
|
|
||||||
'Fixture renamed from "record_xml_property" to "record_property" as user '
|
|
||||||
"properties are now available to all reporters.\n"
|
|
||||||
'"record_xml_property" is now deprecated.'
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
PYTEST_PLUGINS_FROM_NON_TOP_LEVEL_CONFTEST = RemovedInPytest4Warning(
|
PYTEST_PLUGINS_FROM_NON_TOP_LEVEL_CONFTEST = RemovedInPytest4Warning(
|
||||||
"Defining pytest_plugins in a non-top-level conftest is deprecated, "
|
"Defining pytest_plugins in a non-top-level conftest is deprecated, "
|
||||||
|
|
|
@ -263,16 +263,6 @@ def record_property(request):
|
||||||
return append_property
|
return append_property
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
|
||||||
def record_xml_property(record_property, request):
|
|
||||||
"""(Deprecated) use record_property."""
|
|
||||||
from _pytest import deprecated
|
|
||||||
|
|
||||||
request.node.warn(deprecated.RECORD_XML_PROPERTY)
|
|
||||||
|
|
||||||
return record_property
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def record_xml_attribute(request):
|
def record_xml_attribute(request):
|
||||||
"""Add extra xml attributes to the tag for the calling test.
|
"""Add extra xml attributes to the tag for the calling test.
|
||||||
|
|
|
@ -559,12 +559,11 @@ class TestInvocationVariants(object):
|
||||||
def test_equivalence_pytest_pytest(self):
|
def test_equivalence_pytest_pytest(self):
|
||||||
assert pytest.main == py.test.cmdline.main
|
assert pytest.main == py.test.cmdline.main
|
||||||
|
|
||||||
def test_invoke_with_string(self, capsys):
|
def test_invoke_with_invalid_type(self, capsys):
|
||||||
retcode = pytest.main("-h")
|
with pytest.raises(
|
||||||
assert not retcode
|
TypeError, match="expected to be a list or tuple of strings, got: '-h'"
|
||||||
out, err = capsys.readouterr()
|
):
|
||||||
assert "--help" in out
|
pytest.main("-h")
|
||||||
pytest.raises(ValueError, lambda: pytest.main(0))
|
|
||||||
|
|
||||||
def test_invoke_with_path(self, tmpdir, capsys):
|
def test_invoke_with_path(self, tmpdir, capsys):
|
||||||
retcode = pytest.main(tmpdir)
|
retcode = pytest.main(tmpdir)
|
||||||
|
|
|
@ -40,25 +40,6 @@ def test_pytest_custom_cfg_deprecated(testdir):
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def test_str_args_deprecated(tmpdir):
|
|
||||||
"""Deprecate passing strings to pytest.main(). Scheduled for removal in pytest-4.0."""
|
|
||||||
from _pytest.main import EXIT_NOTESTSCOLLECTED
|
|
||||||
|
|
||||||
warnings = []
|
|
||||||
|
|
||||||
class Collect(object):
|
|
||||||
def pytest_warning_captured(self, warning_message):
|
|
||||||
warnings.append(str(warning_message.message))
|
|
||||||
|
|
||||||
ret = pytest.main("%s -x" % tmpdir, plugins=[Collect()])
|
|
||||||
msg = (
|
|
||||||
"passing a string to pytest.main() is deprecated, "
|
|
||||||
"pass a list of arguments instead."
|
|
||||||
)
|
|
||||||
assert msg in warnings
|
|
||||||
assert ret == EXIT_NOTESTSCOLLECTED
|
|
||||||
|
|
||||||
|
|
||||||
def test_getfuncargvalue_is_deprecated(request):
|
def test_getfuncargvalue_is_deprecated(request):
|
||||||
pytest.deprecated_call(request.getfuncargvalue, "tmpdir")
|
pytest.deprecated_call(request.getfuncargvalue, "tmpdir")
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue