2009-03-17 15:11:18 +08:00
|
|
|
import py
|
|
|
|
|
|
|
|
class TestTracebackCutting:
|
|
|
|
def test_skip_simple(self):
|
|
|
|
from py.__.test.outcome import Skipped
|
|
|
|
excinfo = py.test.raises(Skipped, 'py.test.skip("xxx")')
|
|
|
|
assert excinfo.traceback[-1].frame.code.name == "skip"
|
|
|
|
assert excinfo.traceback[-1].ishidden()
|
|
|
|
|
|
|
|
def test_traceback_argsetup(self, testdir):
|
|
|
|
testdir.makeconftest("""
|
2009-05-19 05:26:16 +08:00
|
|
|
def pytest_funcarg__hello(request):
|
|
|
|
raise ValueError("xyz")
|
2009-03-17 15:11:18 +08:00
|
|
|
""")
|
|
|
|
p = testdir.makepyfile("def test(hello): pass")
|
|
|
|
result = testdir.runpytest(p)
|
|
|
|
assert result.ret != 0
|
|
|
|
out = result.stdout.str()
|
|
|
|
assert out.find("xyz") != -1
|
2009-05-19 05:26:16 +08:00
|
|
|
assert out.find("conftest.py:2: ValueError") != -1
|
2009-03-17 15:11:18 +08:00
|
|
|
numentries = out.count("_ _ _") # separator for traceback entries
|
|
|
|
assert numentries == 0
|
|
|
|
|
|
|
|
result = testdir.runpytest("--fulltrace", p)
|
|
|
|
out = result.stdout.str()
|
2009-05-19 05:26:16 +08:00
|
|
|
assert out.find("conftest.py:2: ValueError") != -1
|
2009-03-17 15:11:18 +08:00
|
|
|
numentries = out.count("_ _ _ _") # separator for traceback entries
|
|
|
|
assert numentries >3
|