Merge pull request #3859 from asottile/pyupgrade_1_4
Some pyupgrade 1.4.x changes
This commit is contained in:
commit
f2e35c8c4f
|
@ -10,4 +10,4 @@ def pytest_runtest_setup(item):
|
||||||
return
|
return
|
||||||
mod = item.getparent(pytest.Module).obj
|
mod = item.getparent(pytest.Module).obj
|
||||||
if hasattr(mod, "hello"):
|
if hasattr(mod, "hello"):
|
||||||
print("mod.hello %r" % (mod.hello,))
|
print("mod.hello {!r}".format(mod.hello))
|
||||||
|
|
|
@ -2,9 +2,10 @@
|
||||||
module containing a parametrized tests testing cross-python
|
module containing a parametrized tests testing cross-python
|
||||||
serialization via the pickle module.
|
serialization via the pickle module.
|
||||||
"""
|
"""
|
||||||
|
import textwrap
|
||||||
|
|
||||||
import py
|
import py
|
||||||
import pytest
|
import pytest
|
||||||
import _pytest._code
|
|
||||||
|
|
||||||
pythonlist = ["python2.7", "python3.4", "python3.5"]
|
pythonlist = ["python2.7", "python3.4", "python3.5"]
|
||||||
|
|
||||||
|
@ -24,42 +25,44 @@ class Python(object):
|
||||||
def __init__(self, version, picklefile):
|
def __init__(self, version, picklefile):
|
||||||
self.pythonpath = py.path.local.sysfind(version)
|
self.pythonpath = py.path.local.sysfind(version)
|
||||||
if not self.pythonpath:
|
if not self.pythonpath:
|
||||||
pytest.skip("%r not found" % (version,))
|
pytest.skip("{!r} not found".format(version))
|
||||||
self.picklefile = picklefile
|
self.picklefile = picklefile
|
||||||
|
|
||||||
def dumps(self, obj):
|
def dumps(self, obj):
|
||||||
dumpfile = self.picklefile.dirpath("dump.py")
|
dumpfile = self.picklefile.dirpath("dump.py")
|
||||||
dumpfile.write(
|
dumpfile.write(
|
||||||
_pytest._code.Source(
|
textwrap.dedent(
|
||||||
"""
|
"""\
|
||||||
import pickle
|
import pickle
|
||||||
f = open(%r, 'wb')
|
f = open({!r}, 'wb')
|
||||||
s = pickle.dump(%r, f, protocol=2)
|
s = pickle.dump({!r}, f, protocol=2)
|
||||||
f.close()
|
f.close()
|
||||||
"""
|
""".format(
|
||||||
% (str(self.picklefile), obj)
|
str(self.picklefile), obj
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
py.process.cmdexec("%s %s" % (self.pythonpath, dumpfile))
|
)
|
||||||
|
py.process.cmdexec("{} {}".format(self.pythonpath, dumpfile))
|
||||||
|
|
||||||
def load_and_is_true(self, expression):
|
def load_and_is_true(self, expression):
|
||||||
loadfile = self.picklefile.dirpath("load.py")
|
loadfile = self.picklefile.dirpath("load.py")
|
||||||
loadfile.write(
|
loadfile.write(
|
||||||
_pytest._code.Source(
|
textwrap.dedent(
|
||||||
"""
|
"""\
|
||||||
import pickle
|
import pickle
|
||||||
f = open(%r, 'rb')
|
f = open({!r}, 'rb')
|
||||||
obj = pickle.load(f)
|
obj = pickle.load(f)
|
||||||
f.close()
|
f.close()
|
||||||
res = eval(%r)
|
res = eval({!r})
|
||||||
if not res:
|
if not res:
|
||||||
raise SystemExit(1)
|
raise SystemExit(1)
|
||||||
"""
|
""".format(
|
||||||
% (str(self.picklefile), expression)
|
str(self.picklefile), expression
|
||||||
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
print(loadfile)
|
print(loadfile)
|
||||||
py.process.cmdexec("%s %s" % (self.pythonpath, loadfile))
|
py.process.cmdexec("{} {}".format(self.pythonpath, loadfile))
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize("obj", [42, {}, {1: 3}])
|
@pytest.mark.parametrize("obj", [42, {}, {1: 3}])
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
# CHANGES:
|
# CHANGES:
|
||||||
# - some_str is replaced, trying to create unicode strings
|
# - some_str is replaced, trying to create unicode strings
|
||||||
#
|
#
|
||||||
from __future__ import absolute_import, division, print_function
|
from __future__ import absolute_import, division, print_function, unicode_literals
|
||||||
import types
|
import types
|
||||||
from six import text_type
|
from six import text_type
|
||||||
|
|
||||||
|
@ -51,17 +51,17 @@ def format_exception_only(etype, value):
|
||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
filename = filename or "<string>"
|
filename = filename or "<string>"
|
||||||
lines.append(' File "%s", line %d\n' % (filename, lineno))
|
lines.append(' File "{}", line {}\n'.format(filename, lineno))
|
||||||
if badline is not None:
|
if badline is not None:
|
||||||
if isinstance(badline, bytes): # python 2 only
|
if isinstance(badline, bytes): # python 2 only
|
||||||
badline = badline.decode("utf-8", "replace")
|
badline = badline.decode("utf-8", "replace")
|
||||||
lines.append(u" %s\n" % badline.strip())
|
lines.append(" {}\n".format(badline.strip()))
|
||||||
if offset is not None:
|
if offset is not None:
|
||||||
caretspace = badline.rstrip("\n")[:offset].lstrip()
|
caretspace = badline.rstrip("\n")[:offset].lstrip()
|
||||||
# non-space whitespace (likes tabs) must be kept for alignment
|
# non-space whitespace (likes tabs) must be kept for alignment
|
||||||
caretspace = ((c.isspace() and c or " ") for c in caretspace)
|
caretspace = ((c.isspace() and c or " ") for c in caretspace)
|
||||||
# only three spaces to account for offset1 == pos 0
|
# only three spaces to account for offset1 == pos 0
|
||||||
lines.append(" %s^\n" % "".join(caretspace))
|
lines.append(" {}^\n".format("".join(caretspace)))
|
||||||
value = msg
|
value = msg
|
||||||
|
|
||||||
lines.append(_format_final_exc_line(stype, value))
|
lines.append(_format_final_exc_line(stype, value))
|
||||||
|
@ -72,9 +72,9 @@ def _format_final_exc_line(etype, value):
|
||||||
"""Return a list of a single line -- normal case for format_exception_only"""
|
"""Return a list of a single line -- normal case for format_exception_only"""
|
||||||
valuestr = _some_str(value)
|
valuestr = _some_str(value)
|
||||||
if value is None or not valuestr:
|
if value is None or not valuestr:
|
||||||
line = "%s\n" % etype
|
line = "{}\n".format(etype)
|
||||||
else:
|
else:
|
||||||
line = "%s: %s\n" % (etype, valuestr)
|
line = "{}: {}\n".format(etype, valuestr)
|
||||||
return line
|
return line
|
||||||
|
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@ def _some_str(value):
|
||||||
return text_type(value)
|
return text_type(value)
|
||||||
except Exception:
|
except Exception:
|
||||||
try:
|
try:
|
||||||
return str(value)
|
return bytes(value).decode("UTF-8", "replace")
|
||||||
except Exception:
|
except Exception:
|
||||||
pass
|
pass
|
||||||
return "<unprintable %s object>" % type(value).__name__
|
return "<unprintable {} object>".format(type(value).__name__)
|
||||||
|
|
|
@ -131,7 +131,7 @@ class TestGeneralUsage(object):
|
||||||
p2 = testdir.makefile(".pyc", "123")
|
p2 = testdir.makefile(".pyc", "123")
|
||||||
result = testdir.runpytest(p1, p2)
|
result = testdir.runpytest(p1, p2)
|
||||||
assert result.ret
|
assert result.ret
|
||||||
result.stderr.fnmatch_lines(["*ERROR: not found:*%s" % (p2.basename,)])
|
result.stderr.fnmatch_lines(["*ERROR: not found:*{}".format(p2.basename)])
|
||||||
|
|
||||||
def test_issue486_better_reporting_on_conftest_load_failure(self, testdir):
|
def test_issue486_better_reporting_on_conftest_load_failure(self, testdir):
|
||||||
testdir.makepyfile("")
|
testdir.makepyfile("")
|
||||||
|
@ -453,7 +453,7 @@ class TestInvocationVariants(object):
|
||||||
@pytest.mark.xfail("sys.platform.startswith('java')")
|
@pytest.mark.xfail("sys.platform.startswith('java')")
|
||||||
def test_pydoc(self, testdir):
|
def test_pydoc(self, testdir):
|
||||||
for name in ("py.test", "pytest"):
|
for name in ("py.test", "pytest"):
|
||||||
result = testdir.runpython_c("import %s;help(%s)" % (name, name))
|
result = testdir.runpython_c("import {};help({})".format(name, name))
|
||||||
assert result.ret == 0
|
assert result.ret == 0
|
||||||
s = result.stdout.str()
|
s = result.stdout.str()
|
||||||
assert "MarkGenerator" in s
|
assert "MarkGenerator" in s
|
||||||
|
@ -836,7 +836,7 @@ class TestDurations(object):
|
||||||
if ("test_%s" % x) in line and y in line:
|
if ("test_%s" % x) in line and y in line:
|
||||||
break
|
break
|
||||||
else:
|
else:
|
||||||
raise AssertionError("not found %s %s" % (x, y))
|
raise AssertionError("not found {} {}".format(x, y))
|
||||||
|
|
||||||
def test_with_deselected(self, testdir):
|
def test_with_deselected(self, testdir):
|
||||||
testdir.makepyfile(self.source)
|
testdir.makepyfile(self.source)
|
||||||
|
|
|
@ -270,7 +270,7 @@ class TestTraceback_f_g_h(object):
|
||||||
decorator = pytest.importorskip("decorator").decorator
|
decorator = pytest.importorskip("decorator").decorator
|
||||||
|
|
||||||
def log(f, *k, **kw):
|
def log(f, *k, **kw):
|
||||||
print("%s %s" % (k, kw))
|
print("{} {}".format(k, kw))
|
||||||
f(*k, **kw)
|
f(*k, **kw)
|
||||||
|
|
||||||
log = decorator(log)
|
log = decorator(log)
|
||||||
|
|
|
@ -11,7 +11,7 @@ def equal_with_bash(prefix, ffc, fc, out=None):
|
||||||
res_bash = set(fc(prefix))
|
res_bash = set(fc(prefix))
|
||||||
retval = set(res) == res_bash
|
retval = set(res) == res_bash
|
||||||
if out:
|
if out:
|
||||||
out.write("equal_with_bash %s %s\n" % (retval, res))
|
out.write("equal_with_bash {} {}\n".format(retval, res))
|
||||||
if not retval:
|
if not retval:
|
||||||
out.write(" python - bash: %s\n" % (set(res) - res_bash))
|
out.write(" python - bash: %s\n" % (set(res) - res_bash))
|
||||||
out.write(" bash - python: %s\n" % (res_bash - set(res)))
|
out.write(" bash - python: %s\n" % (res_bash - set(res)))
|
||||||
|
|
|
@ -561,7 +561,7 @@ class TestAssertionRewrite(object):
|
||||||
assert getmsg(f) == "assert 42"
|
assert getmsg(f) == "assert 42"
|
||||||
|
|
||||||
def my_reprcompare(op, left, right):
|
def my_reprcompare(op, left, right):
|
||||||
return "%s %s %s" % (left, op, right)
|
return "{} {} {}".format(left, op, right)
|
||||||
|
|
||||||
monkeypatch.setattr(util, "_reprcompare", my_reprcompare)
|
monkeypatch.setattr(util, "_reprcompare", my_reprcompare)
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,9 @@ def test_version(testdir, pytestconfig):
|
||||||
result = testdir.runpytest("--version")
|
result = testdir.runpytest("--version")
|
||||||
assert result.ret == 0
|
assert result.ret == 0
|
||||||
# p = py.path.local(py.__file__).dirpath()
|
# p = py.path.local(py.__file__).dirpath()
|
||||||
result.stderr.fnmatch_lines(["*pytest*%s*imported from*" % (pytest.__version__,)])
|
result.stderr.fnmatch_lines(
|
||||||
|
["*pytest*{}*imported from*".format(pytest.__version__)]
|
||||||
|
)
|
||||||
if pytestconfig.pluginmanager.list_plugin_distinfo():
|
if pytestconfig.pluginmanager.list_plugin_distinfo():
|
||||||
result.stderr.fnmatch_lines(["*setuptools registered plugins:", "*at*"])
|
result.stderr.fnmatch_lines(["*setuptools registered plugins:", "*at*"])
|
||||||
|
|
||||||
|
|
|
@ -294,7 +294,7 @@ def test_argcomplete(testdir, monkeypatch):
|
||||||
script = str(testdir.tmpdir.join("test_argcomplete"))
|
script = str(testdir.tmpdir.join("test_argcomplete"))
|
||||||
pytest_bin = sys.argv[0]
|
pytest_bin = sys.argv[0]
|
||||||
if "pytest" not in os.path.basename(pytest_bin):
|
if "pytest" not in os.path.basename(pytest_bin):
|
||||||
pytest.skip("need to be run with pytest executable, not %s" % (pytest_bin,))
|
pytest.skip("need to be run with pytest executable, not {}".format(pytest_bin))
|
||||||
|
|
||||||
with open(str(script), "w") as fp:
|
with open(str(script), "w") as fp:
|
||||||
# redirect output from argcomplete to stdin and stderr is not trivial
|
# redirect output from argcomplete to stdin and stderr is not trivial
|
||||||
|
|
|
@ -260,7 +260,9 @@ class TestPDB(object):
|
||||||
assert False
|
assert False
|
||||||
"""
|
"""
|
||||||
)
|
)
|
||||||
child = testdir.spawn_pytest("--show-capture=%s --pdb %s" % (showcapture, p1))
|
child = testdir.spawn_pytest(
|
||||||
|
"--show-capture={} --pdb {}".format(showcapture, p1)
|
||||||
|
)
|
||||||
if showcapture in ("all", "log"):
|
if showcapture in ("all", "log"):
|
||||||
child.expect("captured log")
|
child.expect("captured log")
|
||||||
child.expect("get rekt")
|
child.expect("get rekt")
|
||||||
|
@ -473,7 +475,7 @@ class TestPDB(object):
|
||||||
x = 5
|
x = 5
|
||||||
"""
|
"""
|
||||||
)
|
)
|
||||||
child = testdir.spawn("%s %s" % (sys.executable, p1))
|
child = testdir.spawn("{} {}".format(sys.executable, p1))
|
||||||
child.expect("x = 5")
|
child.expect("x = 5")
|
||||||
child.sendeof()
|
child.sendeof()
|
||||||
self.flush(child)
|
self.flush(child)
|
||||||
|
|
|
@ -1118,9 +1118,9 @@ def test_terminal_summary_warnings_are_displayed(testdir):
|
||||||
)
|
)
|
||||||
def test_summary_stats(exp_line, exp_color, stats_arg):
|
def test_summary_stats(exp_line, exp_color, stats_arg):
|
||||||
print("Based on stats: %s" % stats_arg)
|
print("Based on stats: %s" % stats_arg)
|
||||||
print('Expect summary: "%s"; with color "%s"' % (exp_line, exp_color))
|
print('Expect summary: "{}"; with color "{}"'.format(exp_line, exp_color))
|
||||||
(line, color) = build_summary_stats_line(stats_arg)
|
(line, color) = build_summary_stats_line(stats_arg)
|
||||||
print('Actually got: "%s"; with color "%s"' % (line, color))
|
print('Actually got: "{}"; with color "{}"'.format(line, color))
|
||||||
assert line == exp_line
|
assert line == exp_line
|
||||||
assert color == exp_color
|
assert color == exp_color
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue