diff options
author | Guido van Rossum <guido@python.org> | 1994-05-23 12:17:36 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1994-05-23 12:17:36 (GMT) |
commit | d3b6842d9fe08e25869908a60a2068db2a5737a7 (patch) | |
tree | dcdd74c5ca38ba2876b6697fd9832516731c566c /Lib/test/test_thread.py | |
parent | f3b4903a9f24ba2a9af3f26b8f402ef7bce52a2f (diff) | |
download | cpython-d3b6842d9fe08e25869908a60a2068db2a5737a7.zip cpython-d3b6842d9fe08e25869908a60a2068db2a5737a7.tar.gz cpython-d3b6842d9fe08e25869908a60a2068db2a5737a7.tar.bz2 |
added barrier test (by Tim Peters)
Diffstat (limited to 'Lib/test/test_thread.py')
-rw-r--r-- | Lib/test/test_thread.py | 69 |
1 files changed, 67 insertions, 2 deletions
diff --git a/Lib/test/test_thread.py b/Lib/test/test_thread.py index 5bc3076..4e0eb70 100644 --- a/Lib/test/test_thread.py +++ b/Lib/test/test_thread.py @@ -7,13 +7,18 @@ import thread import time mutex = thread.allocate_lock() +whmutex = thread.allocate_lock() # for calls to whrandom running = 0 done = thread.allocate_lock() done.acquire() +numtasks = 10 + def task(ident): global running - delay = whrandom.random() * 10 + whmutex.acquire() + delay = whrandom.random() * numtasks + whmutex.release() print 'task', ident, 'will run for', delay, 'sec' time.sleep(delay) print 'task', ident, 'done' @@ -33,9 +38,69 @@ def newtask(): running = running + 1 mutex.release() -for i in range(10): +for i in range(numtasks): newtask() print 'waiting for all tasks to complete' done.acquire() print 'all tasks done' + +class barrier: + def __init__(self, n): + self.n = n + self.waiting = 0 + self.checkin = thread.allocate_lock() + self.checkout = thread.allocate_lock() + self.checkout.acquire() + + def enter(self): + checkin, checkout = self.checkin, self.checkout + + checkin.acquire() + self.waiting = self.waiting + 1 + if self.waiting == self.n: + self.waiting = self.n - 1 + checkout.release() + return + checkin.release() + + checkout.acquire() + self.waiting = self.waiting - 1 + if self.waiting == 0: + checkin.release() + return + checkout.release() + +numtrips = 3 +def task2(ident): + global running + for i in range(numtrips): + if ident == 0: + # give it a good chance to enter the next + # barrier before the others are all out + # of the current one + delay = 0.001 + else: + whmutex.acquire() + delay = whrandom.random() * numtasks + whmutex.release() + print 'task', ident, 'will run for', delay, 'sec' + time.sleep(delay) + print 'task', ident, 'entering barrier', i + bar.enter() + print 'task', ident, 'leaving barrier', i + mutex.acquire() + running = running - 1 + if running == 0: + done.release() + mutex.release() + +print '\n*** Barrier Test ***' +if done.acquire(0): + raise ValueError, "'done' should have remained acquired" +bar = barrier(numtasks) +running = numtasks +for i in range(numtasks): + thread.start_new_thread(task2, (i,)) +done.acquire() +print 'all tasks done' |