test_ok2/py/thread/testing/test_pool.py

95 lines
2.3 KiB
Python

import py
import sys
from py.__.thread.pool import queue
WorkerPool = py._thread.WorkerPool
ThreadOut = py._thread.ThreadOut
def test_some():
pool = WorkerPool()
q = queue.Queue()
num = 4
def f(i):
q.put(i)
while q.qsize():
py.std.time.sleep(0.01)
for i in range(num):
pool.dispatch(f, i)
for i in range(num):
q.get()
assert len(pool._alive) == 4
pool.shutdown()
# XXX I replaced the following join() with a time.sleep(1), which seems
# to fix the test on Windows, and doesn't break it on Linux... Completely
# unsure what the idea is, though, so it would be nice if someone with some
# more understanding of what happens here would either fix this better, or
# remove this comment...
# pool.join(timeout=1.0)
py.std.time.sleep(1)
assert len(pool._alive) == 0
assert len(pool._ready) == 0
def test_get():
pool = WorkerPool()
def f():
return 42
reply = pool.dispatch(f)
result = reply.get()
assert result == 42
def test_get_timeout():
pool = WorkerPool()
def f():
py.std.time.sleep(0.2)
return 42
reply = pool.dispatch(f)
py.test.raises(IOError, "reply.get(timeout=0.01)")
def test_get_excinfo():
pool = WorkerPool()
def f():
raise ValueError("42")
reply = pool.dispatch(f)
excinfo = py.test.raises(ValueError, "reply.get(1.0)")
py.test.raises(EOFError, "reply.get(1.0)")
def test_maxthreads():
pool = WorkerPool(maxthreads=1)
def f():
py.std.time.sleep(0.5)
try:
pool.dispatch(f)
py.test.raises(IOError, pool.dispatch, f)
finally:
pool.shutdown()
def test_join_timeout():
pool = WorkerPool()
q = queue.Queue()
def f():
q.get()
reply = pool.dispatch(f)
pool.shutdown()
py.test.raises(IOError, pool.join, 0.01)
q.put(None)
reply.get(timeout=1.0)
pool.join(timeout=0.1)
def test_pool_clean_shutdown():
capture = py.io.StdCaptureFD()
pool = WorkerPool()
def f():
pass
pool.dispatch(f)
pool.dispatch(f)
pool.shutdown()
pool.join(timeout=1.0)
assert not pool._alive
assert not pool._ready
out, err = capture.reset()
print(out)
sys.stderr.write(err + "\n")
assert err == ''