Merge pull request #5008 from blueyed/setup-cfg-tool-pytest
setup.cfg: use existing [tool:pytest] (ignoring [pytest])
This commit is contained in:
commit
dee520e310
|
@ -0,0 +1,3 @@
|
||||||
|
If a ``setup.cfg`` file contains ``[tool:pytest]`` and also the no longer supported ``[pytest]`` section, pytest will use ``[tool:pytest]`` ignoring ``[pytest]``. Previously it would unconditionally error out.
|
||||||
|
|
||||||
|
This makes it simpler for plugins to support old pytest versions.
|
|
@ -33,7 +33,12 @@ def getcfg(args, config=None):
|
||||||
p = base.join(inibasename)
|
p = base.join(inibasename)
|
||||||
if exists(p):
|
if exists(p):
|
||||||
iniconfig = py.iniconfig.IniConfig(p)
|
iniconfig = py.iniconfig.IniConfig(p)
|
||||||
if "pytest" in iniconfig.sections:
|
if (
|
||||||
|
inibasename == "setup.cfg"
|
||||||
|
and "tool:pytest" in iniconfig.sections
|
||||||
|
):
|
||||||
|
return base, p, iniconfig["tool:pytest"]
|
||||||
|
elif "pytest" in iniconfig.sections:
|
||||||
if inibasename == "setup.cfg" and config is not None:
|
if inibasename == "setup.cfg" and config is not None:
|
||||||
|
|
||||||
fail(
|
fail(
|
||||||
|
@ -41,11 +46,6 @@ def getcfg(args, config=None):
|
||||||
pytrace=False,
|
pytrace=False,
|
||||||
)
|
)
|
||||||
return base, p, iniconfig["pytest"]
|
return base, p, iniconfig["pytest"]
|
||||||
if (
|
|
||||||
inibasename == "setup.cfg"
|
|
||||||
and "tool:pytest" in iniconfig.sections
|
|
||||||
):
|
|
||||||
return base, p, iniconfig["tool:pytest"]
|
|
||||||
elif inibasename == "pytest.ini":
|
elif inibasename == "pytest.ini":
|
||||||
# allowed to be empty
|
# allowed to be empty
|
||||||
return base, p, {}
|
return base, p, {}
|
||||||
|
|
|
@ -46,6 +46,22 @@ class TestParseIni(object):
|
||||||
"""correctly handle zero length arguments (a la pytest '')"""
|
"""correctly handle zero length arguments (a la pytest '')"""
|
||||||
getcfg([""])
|
getcfg([""])
|
||||||
|
|
||||||
|
def test_setupcfg_uses_toolpytest_with_pytest(self, testdir):
|
||||||
|
p1 = testdir.makepyfile("def test(): pass")
|
||||||
|
testdir.makefile(
|
||||||
|
".cfg",
|
||||||
|
setup="""
|
||||||
|
[tool:pytest]
|
||||||
|
testpaths=%s
|
||||||
|
[pytest]
|
||||||
|
testpaths=ignored
|
||||||
|
"""
|
||||||
|
% p1.basename,
|
||||||
|
)
|
||||||
|
result = testdir.runpytest()
|
||||||
|
result.stdout.fnmatch_lines(["*, inifile: setup.cfg, *", "* 1 passed in *"])
|
||||||
|
assert result.ret == 0
|
||||||
|
|
||||||
def test_append_parse_args(self, testdir, tmpdir, monkeypatch):
|
def test_append_parse_args(self, testdir, tmpdir, monkeypatch):
|
||||||
monkeypatch.setenv("PYTEST_ADDOPTS", '--color no -rs --tb="short"')
|
monkeypatch.setenv("PYTEST_ADDOPTS", '--color no -rs --tb="short"')
|
||||||
tmpdir.join("pytest.ini").write(
|
tmpdir.join("pytest.ini").write(
|
||||||
|
|
Loading…
Reference in New Issue