Merge pull request #4924 from blueyed/fix-pdbpp

Fix/harden some pdb tests
This commit is contained in:
Daniel Hahler 2019-03-15 00:51:12 +01:00 committed by GitHub
commit 158432217c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 12 additions and 7 deletions

View File

@ -457,7 +457,7 @@ class TestPDB(object):
child.read() child.read()
self.flush(child) self.flush(child)
def test_pdb_interaction_doctest(self, testdir): def test_pdb_interaction_doctest(self, testdir, monkeypatch):
p1 = testdir.makepyfile( p1 = testdir.makepyfile(
""" """
import pytest import pytest
@ -468,11 +468,18 @@ class TestPDB(object):
''' '''
""" """
) )
# Prevent ~/.pdbrc etc to output anything.
monkeypatch.setenv("HOME", str(testdir))
child = testdir.spawn_pytest("--doctest-modules --pdb %s" % p1) child = testdir.spawn_pytest("--doctest-modules --pdb %s" % p1)
child.expect("Pdb") child.expect("Pdb")
child.sendline("i")
child.expect("0") assert "UNEXPECTED EXCEPTION: AssertionError()" in child.before.decode("utf8")
child.sendline("'i=%i.' % i")
child.expect("Pdb") child.expect("Pdb")
assert "\r\n'i=0.'\r\n" in child.before.decode("utf8")
child.sendeof() child.sendeof()
rest = child.read().decode("utf8") rest = child.read().decode("utf8")
assert "1 failed" in rest assert "1 failed" in rest
@ -528,15 +535,13 @@ class TestPDB(object):
import sys import sys
import types import types
newglobals = {
'Pdb': self.__class__, # NOTE: different with pdb.Pdb
'sys': sys,
}
if sys.version_info < (3, ): if sys.version_info < (3, ):
do_debug_func = pdb.Pdb.do_debug.im_func do_debug_func = pdb.Pdb.do_debug.im_func
else: else:
do_debug_func = pdb.Pdb.do_debug do_debug_func = pdb.Pdb.do_debug
newglobals = do_debug_func.__globals__.copy()
newglobals['Pdb'] = self.__class__
orig_do_debug = types.FunctionType( orig_do_debug = types.FunctionType(
do_debug_func.__code__, newglobals, do_debug_func.__code__, newglobals,
do_debug_func.__name__, do_debug_func.__defaults__, do_debug_func.__name__, do_debug_func.__defaults__,