diff options
author | Skip Montanaro <skip@pobox.com> | 2001-08-20 20:28:48 (GMT) |
---|---|---|
committer | Skip Montanaro <skip@pobox.com> | 2001-08-20 20:28:48 (GMT) |
commit | 4533f60da5e1893440318a3c2c866266200044c4 (patch) | |
tree | 7dc8f61438fc678525f5411c9ebc18cf950d68fb /Lib/test/test_threading.py | |
parent | e428bb703010317dc6f87c9a1e709dff8e078535 (diff) | |
download | cpython-4533f60da5e1893440318a3c2c866266200044c4.zip cpython-4533f60da5e1893440318a3c2c866266200044c4.tar.gz cpython-4533f60da5e1893440318a3c2c866266200044c4.tar.bz2 |
add a few test cases for threading module.
Diffstat (limited to 'Lib/test/test_threading.py')
-rw-r--r-- | Lib/test/test_threading.py | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/Lib/test/test_threading.py b/Lib/test/test_threading.py new file mode 100644 index 0000000..87262b1 --- /dev/null +++ b/Lib/test/test_threading.py @@ -0,0 +1,52 @@ +# Very rudimentary test of threading module + +# Create a bunch of threads, let each do some work, wait until all are done + +from test_support import verbose +import random +import threading +import time + +numtasks = 10 + +# no more than 3 of the 10 can run at once +sema = threading.BoundedSemaphore(value=3) +mutex = threading.RLock() +running = 0 + +class TestThread(threading.Thread): + def run(self): + global running + delay = random.random() * numtasks + if verbose: + print 'task', self.getName(), 'will run for', round(delay, 1), 'sec' + sema.acquire() + mutex.acquire() + running = running + 1 + if verbose: + print running, 'tasks are running' + mutex.release() + time.sleep(delay) + if verbose: + print 'task', self.getName(), 'done' + mutex.acquire() + running = running - 1 + if verbose: + print self.getName(), 'is finished.', running, 'tasks are running' + mutex.release() + sema.release() + +threads = [] +def starttasks(): + for i in range(numtasks): + t = TestThread(name="<thread %d>"%i) + threads.append(t) + t.start() + +starttasks() + +print 'waiting for all tasks to complete' +for t in threads: + t.join() +print 'all tasks done' + |