mirror of
https://github.com/python/cpython.git
synced 2025-09-27 02:39:58 +00:00
gh-123471: make itertools.batched
thread-safe (#129416)
This commit is contained in:
parent
155c44b901
commit
405a2d74cb
3 changed files with 51 additions and 2 deletions
39
Lib/test/test_free_threading/test_itertools_batched.py
Normal file
39
Lib/test/test_free_threading/test_itertools_batched.py
Normal file
|
@ -0,0 +1,39 @@
|
|||
import unittest
|
||||
import sys
|
||||
from threading import Thread, Barrier
|
||||
from itertools import batched
|
||||
from test.support import threading_helper
|
||||
|
||||
|
||||
threading_helper.requires_working_threading(module=True)
|
||||
|
||||
class EnumerateThreading(unittest.TestCase):
|
||||
|
||||
@threading_helper.reap_threads
|
||||
def test_threading(self):
|
||||
number_of_threads = 10
|
||||
number_of_iterations = 20
|
||||
barrier = Barrier(number_of_threads)
|
||||
def work(it):
|
||||
barrier.wait()
|
||||
while True:
|
||||
try:
|
||||
_ = next(it)
|
||||
except StopIteration:
|
||||
break
|
||||
|
||||
data = tuple(range(1000))
|
||||
for it in range(number_of_iterations):
|
||||
batch_iterator = batched(data, 2)
|
||||
worker_threads = []
|
||||
for ii in range(number_of_threads):
|
||||
worker_threads.append(
|
||||
Thread(target=work, args=[batch_iterator]))
|
||||
|
||||
with threading_helper.start_threads(worker_threads):
|
||||
pass
|
||||
|
||||
barrier.reset()
|
||||
|
||||
if __name__ == "__main__":
|
||||
unittest.main()
|
Loading…
Add table
Add a link
Reference in a new issue