mirror of
https://github.com/python/cpython.git
synced 2025-10-09 16:34:44 +00:00
bpo-31479: Always reset the signal alarm in tests (#3588)
* bpo-31479: Always reset the signal alarm in tests Use "try: ... finally: signal.signal(0)" pattern to make sure that tests don't "leak" a pending fatal signal alarm. * Move two more alarm() calls into the try block Fix also typo: replace signal.signal(0) with signal.alarm(0) * Move another signal.alarm() into the try block
This commit is contained in:
parent
a92941ff12
commit
9abee722d4
6 changed files with 56 additions and 40 deletions
|
@ -56,9 +56,11 @@ class ThreadSignals(unittest.TestCase):
|
|||
# wait for it return.
|
||||
if signal_blackboard[signal.SIGUSR1]['tripped'] == 0 \
|
||||
or signal_blackboard[signal.SIGUSR2]['tripped'] == 0:
|
||||
signal.alarm(1)
|
||||
signal.pause()
|
||||
signal.alarm(0)
|
||||
try:
|
||||
signal.alarm(1)
|
||||
signal.pause()
|
||||
finally:
|
||||
signal.alarm(0)
|
||||
|
||||
self.assertEqual( signal_blackboard[signal.SIGUSR1]['tripped'], 1)
|
||||
self.assertEqual( signal_blackboard[signal.SIGUSR1]['tripped_by'],
|
||||
|
@ -98,6 +100,7 @@ class ThreadSignals(unittest.TestCase):
|
|||
# after timeout return of lock.acquire() (which can fool assertRaises).
|
||||
self.assertLess(dt, 3.0)
|
||||
finally:
|
||||
signal.alarm(0)
|
||||
signal.signal(signal.SIGALRM, oldalrm)
|
||||
|
||||
@unittest.skipIf(USING_PTHREAD_COND,
|
||||
|
@ -131,6 +134,7 @@ class ThreadSignals(unittest.TestCase):
|
|||
# See rationale above in test_lock_acquire_interruption
|
||||
self.assertLess(dt, 3.0)
|
||||
finally:
|
||||
signal.alarm(0)
|
||||
signal.signal(signal.SIGALRM, oldalrm)
|
||||
|
||||
def acquire_retries_on_intr(self, lock):
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue