summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorSkip Montanaro <skip@pobox.com>2001-08-20 20:28:48 (GMT)
committerSkip Montanaro <skip@pobox.com>2001-08-20 20:28:48 (GMT)
commit4533f60da5e1893440318a3c2c866266200044c4 (patch)
tree7dc8f61438fc678525f5411c9ebc18cf950d68fb /Lib
parente428bb703010317dc6f87c9a1e709dff8e078535 (diff)
downloadcpython-4533f60da5e1893440318a3c2c866266200044c4.zip
cpython-4533f60da5e1893440318a3c2c866266200044c4.tar.gz
cpython-4533f60da5e1893440318a3c2c866266200044c4.tar.bz2
add a few test cases for threading module.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/test/test_threading.py52
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'
+