From cf7cae0780a4f05f4702f7755365e6b1b26a4e86 Mon Sep 17 00:00:00 2001 From: Ronny Pfannschmidt Date: Thu, 18 Apr 2013 11:18:24 +0200 Subject: [PATCH] pdb plugin: move entering pdb into a toplevel function this prepares pdb at collect time --- _pytest/pdb.py | 32 +++++++++++++++++++------------- 1 file changed, 19 insertions(+), 13 deletions(-) diff --git a/_pytest/pdb.py b/_pytest/pdb.py index fdcd1b142..45487131a 100644 --- a/_pytest/pdb.py +++ b/_pytest/pdb.py @@ -61,20 +61,26 @@ class PdbInvoke: return rep if hasattr(rep, "wasxfail"): return rep - # we assume that the above execute() suspended capturing - # XXX we re-use the TerminalReporter's terminalwriter - # because this seems to avoid some encoding related troubles - # for not completely clear reasons. - tw = item.config.pluginmanager.getplugin("terminalreporter")._tw - tw.line() - tw.sep(">", "traceback") - rep.toterminal(tw) - tw.sep(">", "entering PDB") + return _enter_pdb(item, call.excinfo, rep) - tb = _postmortem_traceback(call.excinfo) - post_mortem(tb) - rep._pdbshown = True - return rep + + + +def _enter_pdb(item, excinfo, rep): + # we assume that the above execute() suspended capturing + # XXX we re-use the TerminalReporter's terminalwriter + # because this seems to avoid some encoding related troubles + # for not completely clear reasons. + tw = item.config.pluginmanager.getplugin("terminalreporter")._tw + tw.line() + tw.sep(">", "traceback") + rep.toterminal(tw) + tw.sep(">", "entering PDB") + + tb = _postmortem_traceback(excinfo) + post_mortem(tb) + rep._pdbshown = True + return rep def _postmortem_traceback(excinfo):