- make API between runpytest() and inline_run() more similar

- shift a number of tests to become inline_run() tests

--HG--
branch : testrefactor
This commit is contained in:
holger krekel 2015-04-28 11:54:45 +02:00
parent 424e5d1394
commit d3e363b97a
9 changed files with 169 additions and 153 deletions

View File

@ -29,17 +29,21 @@ def main(args=None, plugins=None):
initialization. initialization.
""" """
try: try:
config = _prepareconfig(args, plugins) try:
except ConftestImportFailure: config = _prepareconfig(args, plugins)
e = sys.exc_info()[1] except ConftestImportFailure as e:
tw = py.io.TerminalWriter(sys.stderr) tw = py.io.TerminalWriter(sys.stderr)
for line in traceback.format_exception(*e.excinfo): for line in traceback.format_exception(*e.excinfo):
tw.line(line.rstrip(), red=True) tw.line(line.rstrip(), red=True)
tw.line("ERROR: could not load %s\n" % (e.path), red=True) tw.line("ERROR: could not load %s\n" % (e.path), red=True)
return 4
else:
config.pluginmanager.check_pending()
return config.hook.pytest_cmdline_main(config=config)
except UsageError as e:
for msg in e.args:
sys.stderr.write("ERROR: %s\n" %(msg,))
return 4 return 4
else:
config.pluginmanager.check_pending()
return config.hook.pytest_cmdline_main(config=config)
class cmdline: # compatibility namespace class cmdline: # compatibility namespace
main = staticmethod(main) main = staticmethod(main)

View File

@ -83,10 +83,7 @@ def wrap_session(config, doit):
initstate = 2 initstate = 2
doit(config, session) doit(config, session)
except pytest.UsageError: except pytest.UsageError:
args = sys.exc_info()[1].args raise
for msg in args:
sys.stderr.write("ERROR: %s\n" %(msg,))
session.exitstatus = EXIT_USAGEERROR
except KeyboardInterrupt: except KeyboardInterrupt:
excinfo = py.code.ExceptionInfo() excinfo = py.code.ExceptionInfo()
config.hook.pytest_keyboard_interrupt(excinfo=excinfo) config.hook.pytest_keyboard_interrupt(excinfo=excinfo)

View File

@ -204,6 +204,8 @@ def pytest_funcarg__testdir(request):
tmptestdir = TmpTestdir(request) tmptestdir = TmpTestdir(request)
return tmptestdir return tmptestdir
rex_outcome = re.compile("(\d+) (\w+)") rex_outcome = re.compile("(\d+) (\w+)")
class RunResult: class RunResult:
"""The result of running a command. """The result of running a command.
@ -229,6 +231,8 @@ class RunResult:
self.duration = duration self.duration = duration
def parseoutcomes(self): def parseoutcomes(self):
""" Return a dictionary of outcomestring->num from parsing
the terminal output that the test process produced."""
for line in reversed(self.outlines): for line in reversed(self.outlines):
if 'seconds' in line: if 'seconds' in line:
outcomes = rex_outcome.findall(line) outcomes = rex_outcome.findall(line)
@ -238,13 +242,16 @@ class RunResult:
d[cat] = int(num) d[cat] = int(num)
return d return d
def assertoutcome(self, passed=0, skipped=0, failed=0): def assert_outcomes(self, passed=0, skipped=0, failed=0):
""" assert that the specified outcomes appear with the respective
numbers (0 means it didn't occur) in the text output from a test run."""
d = self.parseoutcomes() d = self.parseoutcomes()
assert passed == d.get("passed", 0) assert passed == d.get("passed", 0)
assert skipped == d.get("skipped", 0) assert skipped == d.get("skipped", 0)
assert failed == d.get("failed", 0) assert failed == d.get("failed", 0)
class TmpTestdir: class TmpTestdir:
"""Temporary test directory with tools to test/run py.test itself. """Temporary test directory with tools to test/run py.test itself.
@ -568,12 +575,32 @@ class TmpTestdir:
plugins = kwargs.get("plugins") or [] plugins = kwargs.get("plugins") or []
plugins.append(Collect()) plugins.append(Collect())
ret = pytest.main(list(args), plugins=plugins) ret = pytest.main(list(args), plugins=plugins)
assert len(rec) == 1
reprec = rec[0]
reprec.ret = ret
self.delete_loaded_modules() self.delete_loaded_modules()
if len(rec) == 1:
reprec = rec.pop()
else:
class reprec:
pass
reprec.ret = ret
return reprec return reprec
def inline_runpytest(self, *args):
""" Return result of running pytest in-process, providing a similar
interface to what self.runpytest() provides. """
now = time.time()
capture = py.io.StdCaptureFD()
try:
reprec = self.inline_run(*args)
finally:
out, err = capture.reset()
assert out or err
res = RunResult(reprec.ret,
out.split("\n"), err.split("\n"),
time.time()-now)
res.reprec = reprec
return res
def parseconfig(self, *args): def parseconfig(self, *args):
"""Return a new py.test Config instance from given commandline args. """Return a new py.test Config instance from given commandline args.

View File

@ -15,7 +15,7 @@ class TestModule:
p.pyimport() p.pyimport()
del py.std.sys.modules['test_whatever'] del py.std.sys.modules['test_whatever']
b.ensure("test_whatever.py") b.ensure("test_whatever.py")
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*import*mismatch*", "*import*mismatch*",
"*imported*test_whatever*", "*imported*test_whatever*",
@ -59,7 +59,7 @@ class TestClass:
def __init__(self): def __init__(self):
pass pass
""") """)
result = testdir.runpytest("-rw") result = testdir.inline_runpytest("-rw")
result.stdout.fnmatch_lines_random(""" result.stdout.fnmatch_lines_random("""
WC1*test_class_with_init_warning.py*__init__* WC1*test_class_with_init_warning.py*__init__*
""") """)
@ -69,7 +69,7 @@ class TestClass:
class test(object): class test(object):
pass pass
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*collected 0*", "*collected 0*",
]) ])
@ -86,7 +86,7 @@ class TestClass:
def teardown_class(cls): def teardown_class(cls):
pass pass
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*1 passed*", "*1 passed*",
]) ])
@ -534,7 +534,7 @@ class TestConftestCustomization:
""") """)
testdir.makepyfile("def test_some(): pass") testdir.makepyfile("def test_some(): pass")
testdir.makepyfile(test_xyz="def test_func(): pass") testdir.makepyfile(test_xyz="def test_func(): pass")
result = testdir.runpytest("--collect-only") result = testdir.inline_runpytest("--collect-only")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*<Module*test_pytest*", "*<Module*test_pytest*",
"*<MyModule*xyz*", "*<MyModule*xyz*",
@ -590,7 +590,7 @@ class TestConftestCustomization:
return MyFunction(name, collector) return MyFunction(name, collector)
""") """)
testdir.makepyfile("def some(): pass") testdir.makepyfile("def some(): pass")
result = testdir.runpytest("--collect-only") result = testdir.inline_runpytest("--collect-only")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*MyFunction*some*", "*MyFunction*some*",
]) ])
@ -626,7 +626,7 @@ def test_setup_only_available_in_subdir(testdir):
""")) """))
sub1.join("test_in_sub1.py").write("def test_1(): pass") sub1.join("test_in_sub1.py").write("def test_1(): pass")
sub2.join("test_in_sub2.py").write("def test_2(): pass") sub2.join("test_in_sub2.py").write("def test_2(): pass")
result = testdir.runpytest("-v", "-s") result = testdir.inline_runpytest("-v", "-s")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*2 passed*" "*2 passed*"
]) ])
@ -650,7 +650,7 @@ class TestTracebackCutting:
raise ValueError("xyz") raise ValueError("xyz")
""") """)
p = testdir.makepyfile("def test(hello): pass") p = testdir.makepyfile("def test(hello): pass")
result = testdir.runpytest(p) result = testdir.inline_runpytest(p)
assert result.ret != 0 assert result.ret != 0
out = result.stdout.str() out = result.stdout.str()
assert out.find("xyz") != -1 assert out.find("xyz") != -1
@ -658,7 +658,7 @@ class TestTracebackCutting:
numentries = out.count("_ _ _") # separator for traceback entries numentries = out.count("_ _ _") # separator for traceback entries
assert numentries == 0 assert numentries == 0
result = testdir.runpytest("--fulltrace", p) result = testdir.inline_runpytest("--fulltrace", p)
out = result.stdout.str() out = result.stdout.str()
assert out.find("conftest.py:2: ValueError") != -1 assert out.find("conftest.py:2: ValueError") != -1
numentries = out.count("_ _ _ _") # separator for traceback entries numentries = out.count("_ _ _ _") # separator for traceback entries
@ -671,7 +671,7 @@ class TestTracebackCutting:
x = 17 x = 17
asd asd
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.ret != 0 assert result.ret != 0
out = result.stdout.str() out = result.stdout.str()
assert "x = 1" not in out assert "x = 1" not in out
@ -680,7 +680,7 @@ class TestTracebackCutting:
" *asd*", " *asd*",
"E*NameError*", "E*NameError*",
]) ])
result = testdir.runpytest("--fulltrace") result = testdir.inline_runpytest("--fulltrace")
out = result.stdout.str() out = result.stdout.str()
assert "x = 1" in out assert "x = 1" in out
assert "x = 2" in out assert "x = 2" in out
@ -771,7 +771,7 @@ def test_customized_python_discovery(testdir):
""") """)
p2 = p.new(basename=p.basename.replace("test", "check")) p2 = p.new(basename=p.basename.replace("test", "check"))
p.move(p2) p.move(p2)
result = testdir.runpytest("--collect-only", "-s") result = testdir.inline_runpytest("--collect-only", "-s")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*check_customized*", "*check_customized*",
"*check_simple*", "*check_simple*",
@ -779,7 +779,7 @@ def test_customized_python_discovery(testdir):
"*check_meth*", "*check_meth*",
]) ])
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.ret == 0 assert result.ret == 0
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*2 passed*", "*2 passed*",
@ -795,12 +795,12 @@ def test_customized_python_discovery_functions(testdir):
def _test_underscore(): def _test_underscore():
pass pass
""") """)
result = testdir.runpytest("--collect-only", "-s") result = testdir.inline_runpytest("--collect-only", "-s")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*_test_underscore*", "*_test_underscore*",
]) ])
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.ret == 0 assert result.ret == 0
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*1 passed*", "*1 passed*",
@ -820,7 +820,7 @@ def test_collector_attributes(testdir):
def test_hello(): def test_hello():
pass pass
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*1 passed*", "*1 passed*",
]) ])
@ -844,7 +844,7 @@ def test_customize_through_attributes(testdir):
def test_hello(self): def test_hello(self):
pass pass
""") """)
result = testdir.runpytest("--collect-only") result = testdir.inline_runpytest("--collect-only")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*MyClass*", "*MyClass*",
"*MyInstance*", "*MyInstance*",
@ -864,6 +864,6 @@ def test_unorderable_types(testdir):
return Test return Test
TestFoo = make_test() TestFoo = make_test()
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert "TypeError" not in result.stdout.str() assert "TypeError" not in result.stdout.str()
assert result.ret == 0 assert result.ret == 0

View File

@ -33,7 +33,7 @@ class TestFillFixtures:
def test_func(some): def test_func(some):
pass pass
""") """)
result = testdir.runpytest() # "--collect-only") result = testdir.inline_runpytest() # "--collect-only")
assert result.ret != 0 assert result.ret != 0
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*def test_func(some)*", "*def test_func(some)*",
@ -78,7 +78,7 @@ class TestFillFixtures:
def test_method(self, something): def test_method(self, something):
assert something is self assert something is self
""") """)
result = testdir.runpytest(p) result = testdir.inline_runpytest(p)
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*1 passed*" "*1 passed*"
]) ])
@ -99,7 +99,7 @@ class TestFillFixtures:
sub1.join("test_in_sub1.py").write("def test_1(arg1): pass") sub1.join("test_in_sub1.py").write("def test_1(arg1): pass")
sub2.join("test_in_sub2.py").write("def test_2(arg2): pass") sub2.join("test_in_sub2.py").write("def test_2(arg2): pass")
result = testdir.runpytest("-v") result = testdir.inline_runpytest("-v")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*2 passed*" "*2 passed*"
]) ])
@ -121,9 +121,9 @@ class TestFillFixtures:
def test_spam(self, spam): def test_spam(self, spam):
assert spam == 'spamspam' assert spam == 'spamspam'
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines(["*1 passed*"]) result.stdout.fnmatch_lines(["*1 passed*"])
result = testdir.runpytest(testfile) result = testdir.inline_runpytest(testfile)
result.stdout.fnmatch_lines(["*1 passed*"]) result.stdout.fnmatch_lines(["*1 passed*"])
def test_extend_fixture_conftest_module(self, testdir): def test_extend_fixture_conftest_module(self, testdir):
@ -144,9 +144,9 @@ class TestFillFixtures:
def test_spam(spam): def test_spam(spam):
assert spam == 'spamspam' assert spam == 'spamspam'
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines(["*1 passed*"]) result.stdout.fnmatch_lines(["*1 passed*"])
result = testdir.runpytest(testfile) result = testdir.inline_runpytest(testfile)
result.stdout.fnmatch_lines(["*1 passed*"]) result.stdout.fnmatch_lines(["*1 passed*"])
def test_extend_fixture_conftest_conftest(self, testdir): def test_extend_fixture_conftest_conftest(self, testdir):
@ -170,9 +170,9 @@ class TestFillFixtures:
def test_spam(spam): def test_spam(spam):
assert spam == "spamspam" assert spam == "spamspam"
""")) """))
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines(["*1 passed*"]) result.stdout.fnmatch_lines(["*1 passed*"])
result = testdir.runpytest(testfile) result = testdir.inline_runpytest(testfile)
result.stdout.fnmatch_lines(["*1 passed*"]) result.stdout.fnmatch_lines(["*1 passed*"])
def test_extend_fixture_conftest_plugin(self, testdir): def test_extend_fixture_conftest_plugin(self, testdir):
@ -197,7 +197,7 @@ class TestFillFixtures:
def test_foo(foo): def test_foo(foo):
assert foo == 14 assert foo == 14
""") """)
result = testdir.runpytest('-s') result = testdir.inline_runpytest('-s')
assert result.ret == 0 assert result.ret == 0
def test_extend_fixture_plugin_plugin(self, testdir): def test_extend_fixture_plugin_plugin(self, testdir):
@ -223,7 +223,7 @@ class TestFillFixtures:
def test_foo(foo): def test_foo(foo):
assert foo == 14 assert foo == 14
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.ret == 0 assert result.ret == 0
def test_override_parametrized_fixture_conftest_module(self, testdir): def test_override_parametrized_fixture_conftest_module(self, testdir):
@ -245,9 +245,9 @@ class TestFillFixtures:
def test_spam(spam): def test_spam(spam):
assert spam == 'spam' assert spam == 'spam'
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines(["*1 passed*"]) result.stdout.fnmatch_lines(["*1 passed*"])
result = testdir.runpytest(testfile) result = testdir.inline_runpytest(testfile)
result.stdout.fnmatch_lines(["*1 passed*"]) result.stdout.fnmatch_lines(["*1 passed*"])
def test_override_parametrized_fixture_conftest_conftest(self, testdir): def test_override_parametrized_fixture_conftest_conftest(self, testdir):
@ -272,9 +272,9 @@ class TestFillFixtures:
def test_spam(spam): def test_spam(spam):
assert spam == "spam" assert spam == "spam"
""")) """))
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines(["*1 passed*"]) result.stdout.fnmatch_lines(["*1 passed*"])
result = testdir.runpytest(testfile) result = testdir.inline_runpytest(testfile)
result.stdout.fnmatch_lines(["*1 passed*"]) result.stdout.fnmatch_lines(["*1 passed*"])
def test_override_non_parametrized_fixture_conftest_module(self, testdir): def test_override_non_parametrized_fixture_conftest_module(self, testdir):
@ -299,9 +299,9 @@ class TestFillFixtures:
assert spam == params['spam'] assert spam == params['spam']
params['spam'] += 1 params['spam'] += 1
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines(["*3 passed*"]) result.stdout.fnmatch_lines(["*3 passed*"])
result = testdir.runpytest(testfile) result = testdir.inline_runpytest(testfile)
result.stdout.fnmatch_lines(["*3 passed*"]) result.stdout.fnmatch_lines(["*3 passed*"])
def test_override_non_parametrized_fixture_conftest_conftest(self, testdir): def test_override_non_parametrized_fixture_conftest_conftest(self, testdir):
@ -329,9 +329,9 @@ class TestFillFixtures:
assert spam == params['spam'] assert spam == params['spam']
params['spam'] += 1 params['spam'] += 1
""")) """))
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines(["*3 passed*"]) result.stdout.fnmatch_lines(["*3 passed*"])
result = testdir.runpytest(testfile) result = testdir.inline_runpytest(testfile)
result.stdout.fnmatch_lines(["*3 passed*"]) result.stdout.fnmatch_lines(["*3 passed*"])
def test_autouse_fixture_plugin(self, testdir): def test_autouse_fixture_plugin(self, testdir):
@ -351,7 +351,7 @@ class TestFillFixtures:
def test_foo(request): def test_foo(request):
assert request.function.foo == 7 assert request.function.foo == 7
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.ret == 0 assert result.ret == 0
def test_funcarg_lookup_error(self, testdir): def test_funcarg_lookup_error(self, testdir):
@ -359,7 +359,7 @@ class TestFillFixtures:
def test_lookup_error(unknown): def test_lookup_error(unknown):
pass pass
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*ERROR*test_lookup_error*", "*ERROR*test_lookup_error*",
"*def test_lookup_error(unknown):*", "*def test_lookup_error(unknown):*",
@ -388,7 +388,7 @@ class TestFillFixtures:
traceback.print_exc() traceback.print_exc()
assert sys.exc_info() == (None, None, None) assert sys.exc_info() == (None, None, None)
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.ret == 0 assert result.ret == 0
@ -531,7 +531,7 @@ class TestRequestBasic:
def test_second(): def test_second():
assert len(l) == 1 assert len(l) == 1
""") """)
result = testdir.runpytest(p) result = testdir.inline_runpytest(p)
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*1 error*" # XXX the whole module collection fails "*1 error*" # XXX the whole module collection fails
]) ])
@ -616,7 +616,7 @@ class TestRequestBasic:
""")) """))
p = b.join("test_module.py") p = b.join("test_module.py")
p.write("def test_func(arg1): pass") p.write("def test_func(arg1): pass")
result = testdir.runpytest(p, "--fixtures") result = testdir.inline_runpytest(p, "--fixtures")
assert result.ret == 0 assert result.ret == 0
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*fixtures defined*conftest* *fixtures defined*conftest*
@ -785,7 +785,7 @@ class TestRequestCachedSetup:
def test_two_different_setups(arg1, arg2): def test_two_different_setups(arg1, arg2):
assert arg1 != arg2 assert arg1 != arg2
""") """)
result = testdir.runpytest("-v") result = testdir.inline_runpytest("-v")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*1 passed*" "*1 passed*"
]) ])
@ -800,7 +800,7 @@ class TestRequestCachedSetup:
def test_two_funcarg(arg1): def test_two_funcarg(arg1):
assert arg1 == 11 assert arg1 == 11
""") """)
result = testdir.runpytest("-v") result = testdir.inline_runpytest("-v")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*1 passed*" "*1 passed*"
]) ])
@ -827,7 +827,7 @@ class TestRequestCachedSetup:
def test_check_test0_has_teardown_correct(): def test_check_test0_has_teardown_correct():
assert test_0.l == [2] assert test_0.l == [2]
""") """)
result = testdir.runpytest("-v") result = testdir.inline_runpytest("-v")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*3 passed*" "*3 passed*"
]) ])
@ -843,7 +843,7 @@ class TestRequestCachedSetup:
def test_func(app): def test_func(app):
pass pass
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.ret != 0 assert result.ret != 0
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*3/x*", "*3/x*",
@ -898,7 +898,7 @@ class TestFixtureUsages:
def test_add(arg2): def test_add(arg2):
assert arg2 == 2 assert arg2 == 2
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*ScopeMismatch*involved factories*", "*ScopeMismatch*involved factories*",
"* def arg2*", "* def arg2*",
@ -920,7 +920,7 @@ class TestFixtureUsages:
def test_add(arg1, arg2): def test_add(arg1, arg2):
assert arg2 == 2 assert arg2 == 2
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*ScopeMismatch*involved factories*", "*ScopeMismatch*involved factories*",
"* def arg2*", "* def arg2*",
@ -944,7 +944,7 @@ class TestFixtureUsages:
assert arg2 == arg1 + 1 assert arg2 == arg1 + 1
assert len(l) == arg1 assert len(l) == arg1
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*2 passed*" "*2 passed*"
]) ])
@ -964,7 +964,7 @@ class TestFixtureUsages:
def test_missing(call_fail): def test_missing(call_fail):
pass pass
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*pytest.fixture()* *pytest.fixture()*
*def call_fail(fail)* *def call_fail(fail)*
@ -1046,7 +1046,7 @@ class TestFixtureUsages:
reprec.assertoutcome(passed=2) reprec.assertoutcome(passed=2)
def test_usefixtures_seen_in_showmarkers(self, testdir): def test_usefixtures_seen_in_showmarkers(self, testdir):
result = testdir.runpytest("--markers") result = testdir.inline_runpytest("--markers")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*usefixtures(fixturename1*mark tests*fixtures* *usefixtures(fixturename1*mark tests*fixtures*
""") """)
@ -1313,7 +1313,7 @@ class TestAutouseDiscovery:
conftest.move(a.join(conftest.basename)) conftest.move(a.join(conftest.basename))
a.join("test_something.py").write("def test_func(): pass") a.join("test_something.py").write("def test_func(): pass")
b.join("test_otherthing.py").write("def test_func(): pass") b.join("test_otherthing.py").write("def test_func(): pass")
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*1 passed*1 error* *1 passed*1 error*
""") """)
@ -1767,7 +1767,7 @@ class TestFixtureMarker:
def test_1(arg): def test_1(arg):
pass pass
""" % method) """ % method)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.ret != 0 assert result.ret != 0
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*ScopeMismatch*You tried*function*session*request*", "*ScopeMismatch*You tried*function*session*request*",
@ -1825,7 +1825,7 @@ class TestFixtureMarker:
def test_mismatch(arg): def test_mismatch(arg):
pass pass
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*ScopeMismatch*", "*ScopeMismatch*",
"*1 error*", "*1 error*",
@ -1876,7 +1876,7 @@ class TestFixtureMarker:
def test_func4(marg): def test_func4(marg):
pass pass
""") """)
result = testdir.runpytest("-v") result = testdir.inline_runpytest("-v")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
test_mod1.py::test_func[s1] PASSED test_mod1.py::test_func[s1] PASSED
test_mod2.py::test_func2[s1] PASSED test_mod2.py::test_func2[s1] PASSED
@ -1928,7 +1928,7 @@ class TestFixtureMarker:
def test_3(self): def test_3(self):
pass pass
""") """)
result = testdir.runpytest("-vs") result = testdir.inline_runpytest("-vs")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
test_class_ordering.py::TestClass2::test_1[1-a] PASSED test_class_ordering.py::TestClass2::test_1[1-a] PASSED
test_class_ordering.py::TestClass2::test_1[2-a] PASSED test_class_ordering.py::TestClass2::test_1[2-a] PASSED
@ -2019,7 +2019,7 @@ class TestFixtureMarker:
def test_finish(): def test_finish():
assert not l assert not l
""") """)
result = testdir.runpytest("-v") result = testdir.inline_runpytest("-v")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*3 passed* *3 passed*
""") """)
@ -2049,7 +2049,7 @@ class TestFixtureMarker:
def test_browser(browser): def test_browser(browser):
assert browser['visited'] is True assert browser['visited'] is True
""")) """))
reprec = testdir.runpytest("-s") reprec = testdir.inline_runpytest("-s")
for test in ['test_browser']: for test in ['test_browser']:
reprec.stdout.fnmatch_lines('*Finalized*') reprec.stdout.fnmatch_lines('*Finalized*')
@ -2260,7 +2260,7 @@ class TestFixtureMarker:
def test_foo(fix): def test_foo(fix):
assert 1 assert 1
""") """)
res = testdir.runpytest('-v') res = testdir.inline_runpytest('-v')
res.stdout.fnmatch_lines([ res.stdout.fnmatch_lines([
'*test_foo*alpha*', '*test_foo*alpha*',
'*test_foo*beta*']) '*test_foo*beta*'])
@ -2277,7 +2277,7 @@ class TestFixtureMarker:
def test_foo(fix): def test_foo(fix):
assert 1 assert 1
""") """)
res = testdir.runpytest('-v') res = testdir.inline_runpytest('-v')
res.stdout.fnmatch_lines([ res.stdout.fnmatch_lines([
'*test_foo*alpha*', '*test_foo*alpha*',
'*test_foo*beta*']) '*test_foo*beta*'])
@ -2337,7 +2337,7 @@ class TestErrors:
def test_something(gen): def test_something(gen):
pass pass
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.ret != 0 assert result.ret != 0
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*def gen(qwe123):*", "*def gen(qwe123):*",
@ -2363,7 +2363,7 @@ class TestErrors:
def test_3(): def test_3():
assert l[0] != l[1] assert l[0] != l[1]
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*ERROR*teardown*test_1* *ERROR*teardown*test_1*
*KeyError* *KeyError*
@ -2383,7 +2383,7 @@ class TestErrors:
def test_something(): def test_something():
pass pass
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.ret != 0 assert result.ret != 0
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*def gen(qwe123):*", "*def gen(qwe123):*",
@ -2397,7 +2397,7 @@ class TestShowFixtures:
assert config.option.showfixtures assert config.option.showfixtures
def test_show_fixtures(self, testdir): def test_show_fixtures(self, testdir):
result = testdir.runpytest("--fixtures") result = testdir.inline_runpytest("--fixtures")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*tmpdir*", "*tmpdir*",
"*temporary directory*", "*temporary directory*",
@ -2405,7 +2405,7 @@ class TestShowFixtures:
) )
def test_show_fixtures_verbose(self, testdir): def test_show_fixtures_verbose(self, testdir):
result = testdir.runpytest("--fixtures", "-v") result = testdir.inline_runpytest("--fixtures", "-v")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*tmpdir*--*tmpdir.py*", "*tmpdir*--*tmpdir.py*",
"*temporary directory*", "*temporary directory*",
@ -2422,7 +2422,7 @@ class TestShowFixtures:
def arg1(): def arg1():
""" hello world """ """ hello world """
''') ''')
result = testdir.runpytest("--fixtures", p) result = testdir.inline_runpytest("--fixtures", p)
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*tmpdir *tmpdir
*fixtures defined from* *fixtures defined from*
@ -2444,7 +2444,7 @@ class TestShowFixtures:
def test_hello(): def test_hello():
pass pass
""") """)
result = testdir.runpytest("--fixtures") result = testdir.inline_runpytest("--fixtures")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*tmpdir* *tmpdir*
*fixtures defined from*conftest* *fixtures defined from*conftest*
@ -2470,7 +2470,7 @@ class TestShowFixtures:
""" """
''') ''')
result = testdir.runpytest("--fixtures", p) result = testdir.inline_runpytest("--fixtures", p)
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
* fixtures defined from test_show_fixtures_trimmed_doc * * fixtures defined from test_show_fixtures_trimmed_doc *
arg2 arg2
@ -2498,7 +2498,7 @@ class TestContextManagerFixtureFuncs:
print ("test2 %s" % arg1) print ("test2 %s" % arg1)
assert 0 assert 0
""") """)
result = testdir.runpytest("-s") result = testdir.inline_runpytest("-s")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*setup* *setup*
*test1 1* *test1 1*
@ -2521,7 +2521,7 @@ class TestContextManagerFixtureFuncs:
def test_2(arg1): def test_2(arg1):
print ("test2 %s" % arg1) print ("test2 %s" % arg1)
""") """)
result = testdir.runpytest("-s") result = testdir.inline_runpytest("-s")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*setup* *setup*
*test1 1* *test1 1*
@ -2539,7 +2539,7 @@ class TestContextManagerFixtureFuncs:
def test_1(arg1): def test_1(arg1):
pass pass
""") """)
result = testdir.runpytest("-s") result = testdir.inline_runpytest("-s")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*pytest.fail*setup* *pytest.fail*setup*
*1 error* *1 error*
@ -2555,7 +2555,7 @@ class TestContextManagerFixtureFuncs:
def test_1(arg1): def test_1(arg1):
pass pass
""") """)
result = testdir.runpytest("-s") result = testdir.inline_runpytest("-s")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*pytest.fail*teardown* *pytest.fail*teardown*
*1 passed*1 error* *1 passed*1 error*
@ -2571,7 +2571,7 @@ class TestContextManagerFixtureFuncs:
def test_1(arg1): def test_1(arg1):
pass pass
""") """)
result = testdir.runpytest("-s") result = testdir.inline_runpytest("-s")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*fixture function* *fixture function*
*test_yields*:2* *test_yields*:2*
@ -2587,7 +2587,7 @@ class TestContextManagerFixtureFuncs:
def test_1(arg1): def test_1(arg1):
pass pass
""") """)
result = testdir.runpytest("-s") result = testdir.inline_runpytest("-s")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*yield_fixture*requires*yield* *yield_fixture*requires*yield*
*yield_fixture* *yield_fixture*
@ -2603,7 +2603,7 @@ class TestContextManagerFixtureFuncs:
def test_1(arg1): def test_1(arg1):
pass pass
""") """)
result = testdir.runpytest("-s") result = testdir.inline_runpytest("-s")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*fixture*cannot use*yield* *fixture*cannot use*yield*
*def arg1* *def arg1*

View File

@ -246,7 +246,7 @@ class TestMetafunc:
assert x in (10,20) assert x in (10,20)
assert y == 2 assert y == 2
""") """)
result = testdir.runpytest("-v") result = testdir.inline_runpytest("-v")
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*test_simple*1-2*", "*test_simple*1-2*",
"*test_simple*2-2*", "*test_simple*2-2*",
@ -290,11 +290,9 @@ class TestMetafunc:
def test_meth(self, x, y): def test_meth(self, x, y):
assert 0, x assert 0, x
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.ret == 1 assert result.ret == 1
result.stdout.fnmatch_lines([ result.assert_outcomes(failed=6)
"*6 fail*",
])
def test_parametrize_CSV(self, testdir): def test_parametrize_CSV(self, testdir):
testdir.makepyfile(""" testdir.makepyfile("""
@ -332,7 +330,7 @@ class TestMetafunc:
def test_3(self, arg, arg2): def test_3(self, arg, arg2):
pass pass
""") """)
result = testdir.runpytest("-v") result = testdir.inline_runpytest("-v")
assert result.ret == 0 assert result.ret == 0
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*test_1*1* *test_1*1*
@ -374,8 +372,8 @@ class TestMetafuncFunctional:
assert metafunc.function == unbound assert metafunc.function == unbound
assert metafunc.cls == TestClass assert metafunc.cls == TestClass
""") """)
result = testdir.runpytest(p, "-v") result = testdir.inline_runpytest(p, "-v")
result.assertoutcome(passed=2) result.assert_outcomes(passed=2)
def test_addcall_with_two_funcargs_generators(self, testdir): def test_addcall_with_two_funcargs_generators(self, testdir):
testdir.makeconftest(""" testdir.makeconftest("""
@ -391,7 +389,7 @@ class TestMetafuncFunctional:
def test_myfunc(self, arg1, arg2): def test_myfunc(self, arg1, arg2):
assert arg1 == arg2 assert arg1 == arg2
""") """)
result = testdir.runpytest("-v", p) result = testdir.inline_runpytest("-v", p)
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*test_myfunc*0*PASS*", "*test_myfunc*0*PASS*",
"*test_myfunc*1*FAIL*", "*test_myfunc*1*FAIL*",
@ -412,7 +410,7 @@ class TestMetafuncFunctional:
def test_func2(arg1): def test_func2(arg1):
assert arg1 in (10, 20) assert arg1 in (10, 20)
""") """)
result = testdir.runpytest("-v", p) result = testdir.inline_runpytest("-v", p)
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*test_func1*0*PASS*", "*test_func1*0*PASS*",
"*test_func1*1*FAIL*", "*test_func1*1*FAIL*",
@ -429,10 +427,8 @@ class TestMetafuncFunctional:
def test_hello(xyz): def test_hello(xyz):
pass pass
""") """)
result = testdir.runpytest(p) result = testdir.inline_runpytest(p)
result.stdout.fnmatch_lines([ result.assert_outcomes(passed=1)
"*1 pass*",
])
def test_generate_plugin_and_module(self, testdir): def test_generate_plugin_and_module(self, testdir):
@ -454,7 +450,7 @@ class TestMetafuncFunctional:
def test_myfunc(self, arg1, arg2): def test_myfunc(self, arg1, arg2):
assert arg1 == arg2 assert arg1 == arg2
""") """)
result = testdir.runpytest("-v", p) result = testdir.inline_runpytest("-v", p)
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*test_myfunc*hello*PASS*", "*test_myfunc*hello*PASS*",
"*test_myfunc*world*FAIL*", "*test_myfunc*world*FAIL*",
@ -470,7 +466,7 @@ class TestMetafuncFunctional:
def test_myfunc(self, hello): def test_myfunc(self, hello):
assert hello == "world" assert hello == "world"
""") """)
result = testdir.runpytest("-v", p) result = testdir.inline_runpytest("-v", p)
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*test_myfunc*hello*PASS*", "*test_myfunc*hello*PASS*",
"*1 passed*" "*1 passed*"
@ -487,7 +483,7 @@ class TestMetafuncFunctional:
assert not hasattr(self, 'x') assert not hasattr(self, 'x')
self.x = 1 self.x = 1
""") """)
result = testdir.runpytest("-v", p) result = testdir.inline_runpytest("-v", p)
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*test_func*0*PASS*", "*test_func*0*PASS*",
"*test_func*1*PASS*", "*test_func*1*PASS*",
@ -505,10 +501,8 @@ class TestMetafuncFunctional:
def setup_method(self, func): def setup_method(self, func):
self.val = 1 self.val = 1
""") """)
result = testdir.runpytest(p) result = testdir.inline_runpytest(p)
result.stdout.fnmatch_lines([ result.assert_outcomes(passed=1)
"*1 pass*",
])
def test_parametrize_functional2(self, testdir): def test_parametrize_functional2(self, testdir):
testdir.makepyfile(""" testdir.makepyfile("""
@ -518,7 +512,7 @@ class TestMetafuncFunctional:
def test_hello(arg1, arg2): def test_hello(arg1, arg2):
assert 0, (arg1, arg2) assert 0, (arg1, arg2)
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*(1, 4)*", "*(1, 4)*",
"*(1, 5)*", "*(1, 5)*",
@ -543,7 +537,7 @@ class TestMetafuncFunctional:
def test_func1(arg1, arg2): def test_func1(arg1, arg2):
assert arg1 == 11 assert arg1 == 11
""") """)
result = testdir.runpytest("-v", p) result = testdir.inline_runpytest("-v", p)
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*test_func1*1*PASS*", "*test_func1*1*PASS*",
"*1 passed*" "*1 passed*"
@ -564,7 +558,7 @@ class TestMetafuncFunctional:
def test_func(arg2): def test_func(arg2):
assert arg2 == 10 assert arg2 == 10
""") """)
result = testdir.runpytest("-v", p) result = testdir.inline_runpytest("-v", p)
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*test_func*1*PASS*", "*test_func*1*PASS*",
"*1 passed*" "*1 passed*"
@ -580,7 +574,7 @@ class TestMetafuncFunctional:
def test_function(a, b): def test_function(a, b):
assert a == b assert a == b
""") """)
result = testdir.runpytest("-v") result = testdir.inline_runpytest("-v")
assert result.ret == 1 assert result.ret == 1
result.stdout.fnmatch_lines_random([ result.stdout.fnmatch_lines_random([
"*test_function*basic*PASSED", "*test_function*basic*PASSED",
@ -597,7 +591,7 @@ class TestMetafuncFunctional:
def test_function(a, b): def test_function(a, b):
assert 1 assert 1
""") """)
result = testdir.runpytest("-v") result = testdir.inline_runpytest("-v")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
*test_function*1-b0* *test_function*1-b0*
*test_function*1.3-b1* *test_function*1.3-b1*
@ -653,8 +647,8 @@ class TestMetafuncFunctional:
def test_function(): def test_function():
pass pass
""") """)
reprec = testdir.inline_run() reprec = testdir.inline_runpytest()
reprec.assertoutcome(passed=1) reprec.assert_outcomes(passed=1)
def test_generate_tests_only_done_in_subdir(self, testdir): def test_generate_tests_only_done_in_subdir(self, testdir):
sub1 = testdir.mkpydir("sub1") sub1 = testdir.mkpydir("sub1")
@ -669,10 +663,8 @@ class TestMetafuncFunctional:
""")) """))
sub1.join("test_in_sub1.py").write("def test_1(): pass") sub1.join("test_in_sub1.py").write("def test_1(): pass")
sub2.join("test_in_sub2.py").write("def test_2(): pass") sub2.join("test_in_sub2.py").write("def test_2(): pass")
result = testdir.runpytest("-v", "-s", sub1, sub2, sub1) result = testdir.inline_runpytest("-v", "-s", sub1, sub2, sub1)
result.stdout.fnmatch_lines([ result.assert_outcomes(passed=3)
"*3 passed*"
])
def test_generate_same_function_names_issue403(self, testdir): def test_generate_same_function_names_issue403(self, testdir):
testdir.makepyfile(""" testdir.makepyfile("""
@ -687,8 +679,8 @@ class TestMetafuncFunctional:
test_x = make_tests() test_x = make_tests()
test_y = make_tests() test_y = make_tests()
""") """)
reprec = testdir.inline_run() reprec = testdir.inline_runpytest()
reprec.assertoutcome(passed=4) reprec.assert_outcomes(passed=4)
@pytest.mark.issue463 @pytest.mark.issue463
def test_parameterize_misspelling(self, testdir): def test_parameterize_misspelling(self, testdir):

View File

@ -451,7 +451,7 @@ def test_assertion_options(testdir):
x = 3 x = 3
assert x == 4 assert x == 4
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert "3 == 4" in result.stdout.str() assert "3 == 4" in result.stdout.str()
off_options = (("--no-assert",), off_options = (("--no-assert",),
("--nomagic",), ("--nomagic",),

View File

@ -39,7 +39,7 @@ class TestParseIni:
[pytest] [pytest]
minversion=9.0 minversion=9.0
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.ret != 0 assert result.ret != 0
result.stderr.fnmatch_lines([ result.stderr.fnmatch_lines([
"*tox.ini:2*requires*9.0*actual*" "*tox.ini:2*requires*9.0*actual*"
@ -75,7 +75,7 @@ class TestParseIni:
[pytest] [pytest]
addopts = --qwe addopts = --qwe
""") """)
result = testdir.runpytest("--confcutdir=.") result = testdir.inline_run("--confcutdir=.")
assert result.ret == 0 assert result.ret == 0
class TestConfigCmdlineParsing: class TestConfigCmdlineParsing:
@ -320,7 +320,7 @@ def test_cmdline_processargs_simple(testdir):
def pytest_cmdline_preparse(args): def pytest_cmdline_preparse(args):
args.append("-h") args.append("-h")
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*pytest*", "*pytest*",
"*-h*", "*-h*",
@ -389,11 +389,11 @@ class TestWarning:
def test_hello(fix): def test_hello(fix):
pass pass
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
assert result.parseoutcomes()["warnings"] > 0 assert result.parseoutcomes()["warnings"] > 0
assert "hello" not in result.stdout.str() assert "hello" not in result.stdout.str()
result = testdir.runpytest("-rw") result = testdir.inline_runpytest("-rw")
result.stdout.fnmatch_lines(""" result.stdout.fnmatch_lines("""
===*warning summary*=== ===*warning summary*===
*WT1*test_warn_on_test_item*:5*hello* *WT1*test_warn_on_test_item*:5*hello*

View File

@ -18,10 +18,8 @@ def test_nose_setup(testdir):
test_hello.setup = lambda: l.append(1) test_hello.setup = lambda: l.append(1)
test_hello.teardown = lambda: l.append(2) test_hello.teardown = lambda: l.append(2)
""") """)
result = testdir.runpytest(p, '-p', 'nose') result = testdir.inline_runpytest(p, '-p', 'nose')
result.stdout.fnmatch_lines([ result.assert_outcomes(passed=2)
"*2 passed*"
])
def test_setup_func_with_setup_decorator(): def test_setup_func_with_setup_decorator():
@ -65,10 +63,8 @@ def test_nose_setup_func(testdir):
assert l == [1,2] assert l == [1,2]
""") """)
result = testdir.runpytest(p, '-p', 'nose') result = testdir.inline_runpytest(p, '-p', 'nose')
result.stdout.fnmatch_lines([ result.assert_outcomes(passed=2)
"*2 passed*"
])
def test_nose_setup_func_failure(testdir): def test_nose_setup_func_failure(testdir):
@ -89,7 +85,7 @@ def test_nose_setup_func_failure(testdir):
assert l == [1,2] assert l == [1,2]
""") """)
result = testdir.runpytest(p, '-p', 'nose') result = testdir.inline_runpytest(p, '-p', 'nose')
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*TypeError: <lambda>()*" "*TypeError: <lambda>()*"
]) ])
@ -140,7 +136,7 @@ def test_nose_setup_partial(testdir):
test_hello.setup = my_setup_partial test_hello.setup = my_setup_partial
test_hello.teardown = my_teardown_partial test_hello.teardown = my_teardown_partial
""") """)
result = testdir.runpytest(p, '-p', 'nose') result = testdir.inline_runpytest(p, '-p', 'nose')
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*2 passed*" "*2 passed*"
]) ])
@ -207,7 +203,7 @@ def test_nose_test_generator_fixtures(testdir):
#expect.append('setup') #expect.append('setup')
eq_(self.called, expect) eq_(self.called, expect)
""") """)
result = testdir.runpytest(p, '-p', 'nose') result = testdir.inline_runpytest(p, '-p', 'nose')
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*10 passed*" "*10 passed*"
]) ])
@ -238,7 +234,7 @@ def test_module_level_setup(testdir):
assert items[2] == 2 assert items[2] == 2
assert 1 not in items assert 1 not in items
""") """)
result = testdir.runpytest('-p', 'nose') result = testdir.inline_runpytest('-p', 'nose')
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*2 passed*", "*2 passed*",
]) ])
@ -260,7 +256,7 @@ def test_nose_style_setup_teardown(testdir):
def test_world(): def test_world():
assert l == [1] assert l == [1]
""") """)
result = testdir.runpytest('-p', 'nose') result = testdir.inline_runpytest('-p', 'nose')
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*2 passed*", "*2 passed*",
]) ])
@ -276,7 +272,7 @@ def test_nose_setup_ordering(testdir):
def test_first(self): def test_first(self):
pass pass
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines([ result.stdout.fnmatch_lines([
"*1 passed*", "*1 passed*",
]) ])
@ -301,8 +297,8 @@ def test_apiwrapper_problem_issue260(testdir):
def test_fun(self): def test_fun(self):
pass pass
""") """)
result = testdir.runpytest() result = testdir.inline_runpytest()
result.stdout.fnmatch_lines("*1 passed*") result.assert_outcomes(passed=1)
@pytest.mark.skipif("sys.version_info < (2,6)") @pytest.mark.skipif("sys.version_info < (2,6)")
def test_setup_teardown_linking_issue265(testdir): def test_setup_teardown_linking_issue265(testdir):
@ -327,8 +323,8 @@ def test_setup_teardown_linking_issue265(testdir):
"""Undoes the setup.""" """Undoes the setup."""
raise Exception("should not call teardown for skipped tests") raise Exception("should not call teardown for skipped tests")
''') ''')
reprec = testdir.inline_run() reprec = testdir.inline_runpytest()
reprec.assertoutcome(passed=1, skipped=1) reprec.assert_outcomes(passed=1, skipped=1)
def test_SkipTest_during_collection(testdir): def test_SkipTest_during_collection(testdir):
@ -338,8 +334,8 @@ def test_SkipTest_during_collection(testdir):
def test_failing(): def test_failing():
assert False assert False
""") """)
result = testdir.runpytest(p) result = testdir.inline_runpytest(p)
result.assertoutcome(skipped=1) result.assert_outcomes(skipped=1)
def test_SkipTest_in_test(testdir): def test_SkipTest_in_test(testdir):