]> granicus.if.org Git - python/commitdiff
Issue #8407: signal.sigwait() releases the GIL
authorVictor Stinner <victor.stinner@haypocalc.com>
Thu, 9 Jun 2011 23:39:53 +0000 (01:39 +0200)
committerVictor Stinner <victor.stinner@haypocalc.com>
Thu, 9 Jun 2011 23:39:53 +0000 (01:39 +0200)
Initial patch by Charles-François Natali.

Lib/test/test_signal.py
Modules/signalmodule.c

index 063139061a05e95b074dbffe0e79bcaa0bd61216..1ed4b9e731b176216056406ee027150b7eba625d 100644 (file)
@@ -607,6 +607,25 @@ class PendingSignalsTests(unittest.TestCase):
         signal.alarm(1)
         self.assertEqual(signal.sigwait([signal.SIGALRM]), signal.SIGALRM)
 
+    @unittest.skipUnless(hasattr(signal, 'sigwait'),
+                         'need signal.sigwait()')
+    @unittest.skipIf(threading is None, "test needs threading module")
+    def test_sigwait_thread(self):
+        signum = signal.SIGUSR1
+        old_handler = signal.signal(signum, self.handler)
+        self.addCleanup(signal.signal, signum, old_handler)
+
+        def kill_later():
+            time.sleep(1)
+            os.kill(os.getpid(), signum)
+
+        killer = threading.Thread(target=kill_later)
+        killer.start()
+        try:
+            self.assertEqual(signal.sigwait([signum]), signum)
+        finally:
+            killer.join()
+
     @unittest.skipUnless(hasattr(signal, 'pthread_sigmask'),
                          'need signal.pthread_sigmask()')
     def test_pthread_sigmask_arguments(self):
index 6d27ab32912ff9f351ebd990da5b875da62eff0f..94e6bcbf312a29d43d63d2063c7e5d705ff4db12 100644 (file)
@@ -662,7 +662,9 @@ signal_sigwait(PyObject *self, PyObject *args)
     if (iterable_to_sigset(signals, &set))
         return NULL;
 
+    Py_BEGIN_ALLOW_THREADS
     err = sigwait(&set, &signum);
+    Py_END_ALLOW_THREADS
     if (err) {
         errno = err;
         return PyErr_SetFromErrno(PyExc_OSError);