2008-03-17 22:50:25 -03:00
|
|
|
from test import test_support
|
|
|
|
import unittest
|
2002-12-30 18:30:22 -04:00
|
|
|
import dummy_threading as _threading
|
|
|
|
import time
|
|
|
|
|
2008-03-17 22:50:25 -03:00
|
|
|
class DummyThreadingTestCase(unittest.TestCase):
|
|
|
|
|
|
|
|
class TestThread(_threading.Thread):
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
global running
|
|
|
|
global sema
|
|
|
|
global mutex
|
|
|
|
# Uncomment if testing another module, such as the real 'threading'
|
|
|
|
# module.
|
|
|
|
#delay = random.random() * 2
|
|
|
|
delay = 0
|
|
|
|
if test_support.verbose:
|
2008-08-18 15:01:43 -03:00
|
|
|
print 'task', self.name, 'will run for', delay, 'sec'
|
2008-03-17 22:50:25 -03:00
|
|
|
sema.acquire()
|
|
|
|
mutex.acquire()
|
|
|
|
running += 1
|
|
|
|
if test_support.verbose:
|
|
|
|
print running, 'tasks are running'
|
|
|
|
mutex.release()
|
|
|
|
time.sleep(delay)
|
|
|
|
if test_support.verbose:
|
2008-08-18 15:01:43 -03:00
|
|
|
print 'task', self.name, 'done'
|
2008-03-17 22:50:25 -03:00
|
|
|
mutex.acquire()
|
|
|
|
running -= 1
|
|
|
|
if test_support.verbose:
|
2008-08-18 15:01:43 -03:00
|
|
|
print self.name, 'is finished.', running, 'tasks are running'
|
2008-03-17 22:50:25 -03:00
|
|
|
mutex.release()
|
|
|
|
sema.release()
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
self.numtasks = 10
|
|
|
|
global sema
|
|
|
|
sema = _threading.BoundedSemaphore(value=3)
|
|
|
|
global mutex
|
|
|
|
mutex = _threading.RLock()
|
2002-12-30 18:30:22 -04:00
|
|
|
global running
|
2008-03-17 22:50:25 -03:00
|
|
|
running = 0
|
|
|
|
self.threads = []
|
|
|
|
|
|
|
|
def test_tasks(self):
|
|
|
|
for i in range(self.numtasks):
|
|
|
|
t = self.TestThread(name="<thread %d>"%i)
|
|
|
|
self.threads.append(t)
|
|
|
|
t.start()
|
|
|
|
|
|
|
|
if test_support.verbose:
|
|
|
|
print 'waiting for all tasks to complete'
|
|
|
|
for t in self.threads:
|
|
|
|
t.join()
|
|
|
|
if test_support.verbose:
|
|
|
|
print 'all tasks done'
|
2002-12-30 18:30:22 -04:00
|
|
|
|
|
|
|
def test_main():
|
2008-03-17 22:50:25 -03:00
|
|
|
test_support.run_unittest(DummyThreadingTestCase)
|
2002-12-30 18:30:22 -04:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
test_main()
|