mirror of
https://github.com/python/cpython.git
synced 2025-08-04 08:59:19 +00:00
Issue #13502: threading: Fix a race condition in Event.wait() that made it
return False when the event was set and cleared right after.
This commit is contained in:
commit
61d28d6a74
4 changed files with 27 additions and 5 deletions
|
@ -804,8 +804,10 @@ An event object manages an internal flag that can be set to true with the
|
|||
floating point number specifying a timeout for the operation in seconds
|
||||
(or fractions thereof).
|
||||
|
||||
This method returns the internal flag on exit, so it will always return
|
||||
``True`` except if a timeout is given and the operation times out.
|
||||
This method returns true if and only if the internal flag has been set to
|
||||
true, either before the wait call or after the wait starts, so it will
|
||||
always return ``True`` except if a timeout is given and the operation
|
||||
times out.
|
||||
|
||||
.. versionchanged:: 3.1
|
||||
Previously, the method always returned ``None``.
|
||||
|
|
|
@ -353,6 +353,22 @@ class EventTests(BaseTestCase):
|
|||
for r, dt in results2:
|
||||
self.assertTrue(r)
|
||||
|
||||
def test_set_and_clear(self):
|
||||
# Issue #13502: check that wait() returns true even when the event is
|
||||
# cleared before the waiting thread is woken up.
|
||||
evt = self.eventtype()
|
||||
results = []
|
||||
N = 5
|
||||
def f():
|
||||
results.append(evt.wait(1))
|
||||
b = Bunch(f, N)
|
||||
b.wait_for_started()
|
||||
time.sleep(0.5)
|
||||
evt.set()
|
||||
evt.clear()
|
||||
b.wait_for_finished()
|
||||
self.assertEqual(results, [True] * N)
|
||||
|
||||
|
||||
class ConditionTests(BaseTestCase):
|
||||
"""
|
||||
|
|
|
@ -408,9 +408,10 @@ class Event(_Verbose):
|
|||
def wait(self, timeout=None):
|
||||
self._cond.acquire()
|
||||
try:
|
||||
if not self._flag:
|
||||
self._cond.wait(timeout)
|
||||
return self._flag
|
||||
signaled = self._flag
|
||||
if not signaled:
|
||||
signaled = self._cond.wait(timeout)
|
||||
return signaled
|
||||
finally:
|
||||
self._cond.release()
|
||||
|
||||
|
|
|
@ -422,6 +422,9 @@ Core and Builtins
|
|||
Library
|
||||
-------
|
||||
|
||||
- Issue #13502: threading: Fix a race condition in Event.wait() that made it
|
||||
return False when the event was set and cleared right after.
|
||||
|
||||
- Issue #9993: When the source and destination are on different filesystems,
|
||||
and the source is a symlink, shutil.move() now recreates a symlink on the
|
||||
destination instead of copying the file contents. Patch by Jonathan Niehof
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue