2009-05-05 05:54:11 -03:00
|
|
|
# A test suite for pdb; at the moment, this only validates skipping of
|
|
|
|
# specified test modules (RFE #5142).
|
|
|
|
|
|
|
|
import imp
|
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
import doctest
|
|
|
|
import tempfile
|
|
|
|
|
|
|
|
from test import test_support
|
|
|
|
# This little helper class is essential for testing pdb under doctest.
|
|
|
|
from test_doctest import _FakeInput
|
|
|
|
|
|
|
|
|
2009-09-16 13:22:12 -03:00
|
|
|
class PdbTestInput(object):
|
|
|
|
"""Context manager that makes testing Pdb in doctests easier."""
|
|
|
|
|
|
|
|
def __init__(self, input):
|
|
|
|
self.input = input
|
|
|
|
|
|
|
|
def __enter__(self):
|
|
|
|
self.real_stdin = sys.stdin
|
|
|
|
sys.stdin = _FakeInput(self.input)
|
|
|
|
|
|
|
|
def __exit__(self, *exc):
|
|
|
|
sys.stdin = self.real_stdin
|
|
|
|
|
|
|
|
|
2009-09-16 13:36:39 -03:00
|
|
|
def write(x):
|
|
|
|
print x
|
|
|
|
|
|
|
|
def test_pdb_displayhook():
|
|
|
|
"""This tests the custom displayhook for pdb.
|
|
|
|
|
|
|
|
>>> def test_function(foo, bar):
|
|
|
|
... import pdb; pdb.Pdb().set_trace()
|
|
|
|
... pass
|
|
|
|
|
|
|
|
>>> with PdbTestInput([
|
|
|
|
... 'foo',
|
|
|
|
... 'bar',
|
|
|
|
... 'for i in range(5): write(i)',
|
|
|
|
... 'continue',
|
|
|
|
... ]):
|
|
|
|
... test_function(1, None)
|
|
|
|
> <doctest test.test_pdb.test_pdb_displayhook[0]>(3)test_function()
|
|
|
|
-> pass
|
|
|
|
(Pdb) foo
|
|
|
|
1
|
|
|
|
(Pdb) bar
|
|
|
|
(Pdb) for i in range(5): write(i)
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
(Pdb) continue
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
2009-05-05 05:54:11 -03:00
|
|
|
def test_pdb_skip_modules():
|
|
|
|
"""This illustrates the simple case of module skipping.
|
|
|
|
|
|
|
|
>>> def skip_module():
|
|
|
|
... import string
|
2009-09-16 13:22:12 -03:00
|
|
|
... import pdb; pdb.Pdb(skip=['string*']).set_trace()
|
2009-05-05 05:54:11 -03:00
|
|
|
... string.lower('FOO')
|
|
|
|
|
2009-09-16 13:22:12 -03:00
|
|
|
>>> with PdbTestInput([
|
|
|
|
... 'step',
|
2009-09-16 13:36:39 -03:00
|
|
|
... 'continue',
|
2009-09-16 13:22:12 -03:00
|
|
|
... ]):
|
2009-05-05 05:54:11 -03:00
|
|
|
... skip_module()
|
|
|
|
> <doctest test.test_pdb.test_pdb_skip_modules[0]>(4)skip_module()
|
|
|
|
-> string.lower('FOO')
|
|
|
|
(Pdb) step
|
|
|
|
--Return--
|
|
|
|
> <doctest test.test_pdb.test_pdb_skip_modules[0]>(4)skip_module()->None
|
|
|
|
-> string.lower('FOO')
|
|
|
|
(Pdb) continue
|
2009-09-16 13:22:12 -03:00
|
|
|
"""
|
2009-05-05 05:54:11 -03:00
|
|
|
|
|
|
|
|
|
|
|
# Module for testing skipping of module that makes a callback
|
|
|
|
mod = imp.new_module('module_to_skip')
|
|
|
|
exec 'def foo_pony(callback): x = 1; callback(); return None' in mod.__dict__
|
|
|
|
|
|
|
|
|
|
|
|
def test_pdb_skip_modules_with_callback():
|
|
|
|
"""This illustrates skipping of modules that call into other code.
|
|
|
|
|
|
|
|
>>> def skip_module():
|
|
|
|
... def callback():
|
|
|
|
... return None
|
2009-09-16 13:22:12 -03:00
|
|
|
... import pdb; pdb.Pdb(skip=['module_to_skip*']).set_trace()
|
2009-05-05 05:54:11 -03:00
|
|
|
... mod.foo_pony(callback)
|
2009-09-16 13:22:12 -03:00
|
|
|
|
|
|
|
>>> with PdbTestInput([
|
|
|
|
... 'step',
|
|
|
|
... 'step',
|
|
|
|
... 'step',
|
|
|
|
... 'step',
|
|
|
|
... 'step',
|
|
|
|
... 'continue',
|
|
|
|
... ]):
|
2009-05-05 05:54:11 -03:00
|
|
|
... skip_module()
|
2009-09-16 13:22:12 -03:00
|
|
|
... pass # provides something to "step" to
|
2009-05-05 05:54:11 -03:00
|
|
|
> <doctest test.test_pdb.test_pdb_skip_modules_with_callback[0]>(5)skip_module()
|
|
|
|
-> mod.foo_pony(callback)
|
|
|
|
(Pdb) step
|
|
|
|
--Call--
|
|
|
|
> <doctest test.test_pdb.test_pdb_skip_modules_with_callback[0]>(2)callback()
|
|
|
|
-> def callback():
|
|
|
|
(Pdb) step
|
|
|
|
> <doctest test.test_pdb.test_pdb_skip_modules_with_callback[0]>(3)callback()
|
|
|
|
-> return None
|
|
|
|
(Pdb) step
|
|
|
|
--Return--
|
|
|
|
> <doctest test.test_pdb.test_pdb_skip_modules_with_callback[0]>(3)callback()->None
|
|
|
|
-> return None
|
|
|
|
(Pdb) step
|
|
|
|
--Return--
|
|
|
|
> <doctest test.test_pdb.test_pdb_skip_modules_with_callback[0]>(5)skip_module()->None
|
|
|
|
-> mod.foo_pony(callback)
|
|
|
|
(Pdb) step
|
2009-09-16 13:22:12 -03:00
|
|
|
> <doctest test.test_pdb.test_pdb_skip_modules_with_callback[1]>(10)<module>()
|
|
|
|
-> pass # provides something to "step" to
|
2009-05-05 05:54:11 -03:00
|
|
|
(Pdb) continue
|
2009-09-16 13:22:12 -03:00
|
|
|
"""
|
2009-05-05 05:54:11 -03:00
|
|
|
|
|
|
|
|
|
|
|
def test_main():
|
|
|
|
from test import test_pdb
|
|
|
|
test_support.run_doctest(test_pdb, verbosity=True)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
test_main()
|