Merge pull request #1952 from davidszotten/pdbcls_without_pdb_on_fail
Pdbcls without pdb on fail
This commit is contained in:
commit
5e96edd435
|
@ -20,15 +20,15 @@ def pytest_namespace():
|
||||||
return {'set_trace': pytestPDB().set_trace}
|
return {'set_trace': pytestPDB().set_trace}
|
||||||
|
|
||||||
def pytest_configure(config):
|
def pytest_configure(config):
|
||||||
if config.getvalue("usepdb") or config.getvalue("usepdb_cls"):
|
if config.getvalue("usepdb_cls"):
|
||||||
|
modname, classname = config.getvalue("usepdb_cls").split(":")
|
||||||
|
__import__(modname)
|
||||||
|
pdb_cls = getattr(sys.modules[modname], classname)
|
||||||
|
else:
|
||||||
|
pdb_cls = pdb.Pdb
|
||||||
|
|
||||||
|
if config.getvalue("usepdb"):
|
||||||
config.pluginmanager.register(PdbInvoke(), 'pdbinvoke')
|
config.pluginmanager.register(PdbInvoke(), 'pdbinvoke')
|
||||||
if config.getvalue("usepdb_cls"):
|
|
||||||
modname, classname = config.getvalue("usepdb_cls").split(":")
|
|
||||||
__import__(modname)
|
|
||||||
pdb_cls = getattr(sys.modules[modname], classname)
|
|
||||||
else:
|
|
||||||
pdb_cls = pdb.Pdb
|
|
||||||
pytestPDB._pdb_cls = pdb_cls
|
|
||||||
|
|
||||||
old = (pdb.set_trace, pytestPDB._pluginmanager)
|
old = (pdb.set_trace, pytestPDB._pluginmanager)
|
||||||
def fin():
|
def fin():
|
||||||
|
@ -38,6 +38,7 @@ def pytest_configure(config):
|
||||||
pdb.set_trace = pytest.set_trace
|
pdb.set_trace = pytest.set_trace
|
||||||
pytestPDB._pluginmanager = config.pluginmanager
|
pytestPDB._pluginmanager = config.pluginmanager
|
||||||
pytestPDB._config = config
|
pytestPDB._config = config
|
||||||
|
pytestPDB._pdb_cls = pdb_cls
|
||||||
config._cleanup.append(fin)
|
config._cleanup.append(fin)
|
||||||
|
|
||||||
class pytestPDB:
|
class pytestPDB:
|
||||||
|
|
|
@ -12,6 +12,26 @@ def runpdb_and_get_report(testdir, source):
|
||||||
return reports[1]
|
return reports[1]
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def custom_pdb_calls():
|
||||||
|
called = []
|
||||||
|
|
||||||
|
# install dummy debugger class and track which methods were called on it
|
||||||
|
class _CustomPdb:
|
||||||
|
def __init__(self, *args, **kwargs):
|
||||||
|
called.append("init")
|
||||||
|
|
||||||
|
def reset(self):
|
||||||
|
called.append("reset")
|
||||||
|
|
||||||
|
def interaction(self, *args):
|
||||||
|
called.append("interaction")
|
||||||
|
|
||||||
|
_pytest._CustomPdb = _CustomPdb
|
||||||
|
return called
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class TestPDB:
|
class TestPDB:
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
|
@ -334,22 +354,18 @@ class TestPDB:
|
||||||
if child.isalive():
|
if child.isalive():
|
||||||
child.wait()
|
child.wait()
|
||||||
|
|
||||||
def test_pdb_custom_cls(self, testdir):
|
def test_pdb_custom_cls(self, testdir, custom_pdb_calls):
|
||||||
called = []
|
p1 = testdir.makepyfile("""xxx """)
|
||||||
|
result = testdir.runpytest_inprocess(
|
||||||
|
"--pdb", "--pdbcls=_pytest:_CustomPdb", p1)
|
||||||
|
result.stdout.fnmatch_lines([
|
||||||
|
"*NameError*xxx*",
|
||||||
|
"*1 error*",
|
||||||
|
])
|
||||||
|
assert custom_pdb_calls == ["init", "reset", "interaction"]
|
||||||
|
|
||||||
# install dummy debugger class and track which methods were called on it
|
|
||||||
class _CustomPdb:
|
|
||||||
def __init__(self, *args, **kwargs):
|
|
||||||
called.append("init")
|
|
||||||
|
|
||||||
def reset(self):
|
|
||||||
called.append("reset")
|
|
||||||
|
|
||||||
def interaction(self, *args):
|
|
||||||
called.append("interaction")
|
|
||||||
|
|
||||||
_pytest._CustomPdb = _CustomPdb
|
|
||||||
|
|
||||||
|
def test_pdb_custom_cls_without_pdb(self, testdir, custom_pdb_calls):
|
||||||
p1 = testdir.makepyfile("""xxx """)
|
p1 = testdir.makepyfile("""xxx """)
|
||||||
result = testdir.runpytest_inprocess(
|
result = testdir.runpytest_inprocess(
|
||||||
"--pdbcls=_pytest:_CustomPdb", p1)
|
"--pdbcls=_pytest:_CustomPdb", p1)
|
||||||
|
@ -357,4 +373,23 @@ class TestPDB:
|
||||||
"*NameError*xxx*",
|
"*NameError*xxx*",
|
||||||
"*1 error*",
|
"*1 error*",
|
||||||
])
|
])
|
||||||
assert called == ["init", "reset", "interaction"]
|
assert custom_pdb_calls == []
|
||||||
|
|
||||||
|
def test_pdb_custom_cls_with_settrace(self, testdir, monkeypatch):
|
||||||
|
testdir.makepyfile(custom_pdb="""
|
||||||
|
class CustomPdb:
|
||||||
|
def set_trace(*args, **kwargs):
|
||||||
|
print 'custom set_trace>'
|
||||||
|
""")
|
||||||
|
p1 = testdir.makepyfile("""
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
def test_foo():
|
||||||
|
pytest.set_trace()
|
||||||
|
""")
|
||||||
|
monkeypatch.setenv('PYTHONPATH', str(testdir.tmpdir))
|
||||||
|
child = testdir.spawn_pytest("--pdbcls=custom_pdb:CustomPdb %s" % str(p1))
|
||||||
|
|
||||||
|
child.expect('custom set_trace>')
|
||||||
|
if child.isalive():
|
||||||
|
child.wait()
|
||||||
|
|
Loading…
Reference in New Issue