Commit d0eab622 authored by Antoine Pitrou's avatar Antoine Pitrou

Issue #20006: Fix sporadic failures in test_weakset.

parent c28bd7ff
...@@ -60,6 +60,8 @@ class WeakSet: ...@@ -60,6 +60,8 @@ class WeakSet:
for itemref in self.data: for itemref in self.data:
item = itemref() item = itemref()
if item is not None: if item is not None:
# Caveat: the iterator will keep a strong reference to
# `item` until it is resumed or closed.
yield item yield item
def __len__(self): def __len__(self):
......
...@@ -370,9 +370,14 @@ class TestWeakSet(unittest.TestCase): ...@@ -370,9 +370,14 @@ class TestWeakSet(unittest.TestCase):
def testcontext(): def testcontext():
try: try:
it = iter(s) it = iter(s)
next(it) # Start iterator
yielded = ustr(str(next(it)))
# Schedule an item for removal and recreate it # Schedule an item for removal and recreate it
u = ustr(str(items.pop())) u = ustr(str(items.pop()))
if yielded == u:
# The iterator still has a reference to the removed item,
# advance it (issue #20006).
next(it)
gc.collect() # just in case gc.collect() # just in case
yield u yield u
finally: finally:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment