Commit d879e664 authored by Denis Bilenko's avatar Denis Bilenko

add a test case for pool.imap

parent 8fe8a9b6
...@@ -3,6 +3,7 @@ import gevent ...@@ -3,6 +3,7 @@ import gevent
from gevent import pool from gevent import pool
from gevent.event import Event from gevent.event import Event
import greentest import greentest
import random
class TestCoroutinePool(greentest.TestCase): class TestCoroutinePool(greentest.TestCase):
...@@ -182,6 +183,12 @@ def sqr(x, wait=0.0): ...@@ -182,6 +183,12 @@ def sqr(x, wait=0.0):
gevent.sleep(wait) gevent.sleep(wait)
return x * x return x * x
def sqr_random_sleep(x):
gevent.sleep(random.random() * 0.1)
return x * x
TIMEOUT1, TIMEOUT2, TIMEOUT3 = 0.082, 0.035, 0.14 TIMEOUT1, TIMEOUT2, TIMEOUT3 = 0.082, 0.035, 0.14
...@@ -242,6 +249,10 @@ class TestPool(greentest.TestCase): ...@@ -242,6 +249,10 @@ class TestPool(greentest.TestCase):
self.assertEqual(it.next(), i * i) self.assertEqual(it.next(), i * i)
self.assertRaises(StopIteration, it.next) self.assertRaises(StopIteration, it.next)
def test_imap_random(self):
it = self.pool.imap(sqr_random_sleep, range(10))
self.assertEqual(list(it), map(sqr, range(10)))
def test_imap_unordered(self): def test_imap_unordered(self):
it = self.pool.imap_unordered(sqr, range(1000)) it = self.pool.imap_unordered(sqr, range(1000))
self.assertEqual(sorted(it), map(sqr, range(1000))) self.assertEqual(sorted(it), map(sqr, range(1000)))
...@@ -249,6 +260,10 @@ class TestPool(greentest.TestCase): ...@@ -249,6 +260,10 @@ class TestPool(greentest.TestCase):
it = self.pool.imap_unordered(sqr, range(1000)) it = self.pool.imap_unordered(sqr, range(1000))
self.assertEqual(sorted(it), map(sqr, range(1000))) self.assertEqual(sorted(it), map(sqr, range(1000)))
def test_imap_unordered_random(self):
it = self.pool.imap_unordered(sqr_random_sleep, range(10))
self.assertEqual(sorted(it), map(sqr, range(10)))
def test_terminate(self): def test_terminate(self):
result = self.pool.map_async(gevent.sleep, [0.1] * ((self.size or 10) * 2)) result = self.pool.map_async(gevent.sleep, [0.1] * ((self.size or 10) * 2))
gevent.sleep(0.1) gevent.sleep(0.1)
......
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