summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrew Svetlov <andrew.svetlov@gmail.com>2012-12-04 19:10:20 (GMT)
committerAndrew Svetlov <andrew.svetlov@gmail.com>2012-12-04 19:10:20 (GMT)
commit1dfb5c1cf3aac0a42b157631a0e8d274e5be8c6f (patch)
tree90cdb2b13e03256b55a63a62f818c6ce6cc4f497
parent56a2ae27e3f142f5a92d43fab5296748ef8ecc98 (diff)
parent539ee5da6fb2a56869e6c6f4401300b4d5906d76 (diff)
downloadcpython-1dfb5c1cf3aac0a42b157631a0e8d274e5be8c6f.zip
cpython-1dfb5c1cf3aac0a42b157631a0e8d274e5be8c6f.tar.gz
cpython-1dfb5c1cf3aac0a42b157631a0e8d274e5be8c6f.tar.bz2
Merge issue #13120: Allow to call pdb.set_trace() from thread.
Patch by Ilya Sandler.
-rwxr-xr-xLib/pdb.py11
-rw-r--r--Lib/test/test_pdb.py27
-rw-r--r--Misc/NEWS3
3 files changed, 39 insertions, 2 deletions
diff --git a/Lib/pdb.py b/Lib/pdb.py
index 3043391..e6d7f8f 100755
--- a/Lib/pdb.py
+++ b/Lib/pdb.py
@@ -1031,8 +1031,15 @@ class Pdb(bdb.Bdb, cmd.Cmd):
Continue execution, only stop when a breakpoint is encountered.
"""
if not self.nosigint:
- self._previous_sigint_handler = \
- signal.signal(signal.SIGINT, self.sigint_handler)
+ try:
+ self._previous_sigint_handler = \
+ signal.signal(signal.SIGINT, self.sigint_handler)
+ except ValueError:
+ # ValueError happens when do_continue() is invoked from
+ # a non-main thread in which case we just continue without
+ # SIGINT set. Would printing a message here (once) make
+ # sense?
+ pass
self.set_continue()
return 1
do_c = do_cont = do_continue
diff --git a/Lib/test/test_pdb.py b/Lib/test/test_pdb.py
index 0f7a984..4e543dd 100644
--- a/Lib/test/test_pdb.py
+++ b/Lib/test/test_pdb.py
@@ -667,6 +667,33 @@ class PdbTestCase(unittest.TestCase):
any('main.py(5)foo()->None' in l for l in stdout.splitlines()),
'Fail to step into the caller after a return')
+ def test_issue13210(self):
+ # invoking "continue" on a non-main thread triggered an exception
+ # inside signal.signal
+
+ with open(support.TESTFN, 'wb') as f:
+ f.write(textwrap.dedent("""
+ import threading
+ import pdb
+
+ def start_pdb():
+ pdb.Pdb().set_trace()
+ x = 1
+ y = 1
+
+ t = threading.Thread(target=start_pdb)
+ t.start()""").encode('ascii'))
+ cmd = [sys.executable, '-u', support.TESTFN]
+ proc = subprocess.Popen(cmd,
+ stdout=subprocess.PIPE,
+ stdin=subprocess.PIPE,
+ stderr=subprocess.STDOUT,
+ )
+ self.addCleanup(proc.stdout.close)
+ stdout, stderr = proc.communicate(b'cont\n')
+ self.assertNotIn('Error', stdout.decode(),
+ "Got an error running test script under PDB")
+
def tearDown(self):
support.unlink(support.TESTFN)
diff --git a/Misc/NEWS b/Misc/NEWS
index c695be5..61270f4 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -104,6 +104,9 @@ Core and Builtins
Library
-------
+- Issue #13120: Allow to call pdb.set_trace() from thread.
+ Patch by Ilya Sandler.
+
- Issue #16585: Make CJK encoders support error handlers that return bytes per
PEP 383.