test_dummy_threading.py 1.76 KB
Newer Older
1
from test import support
Christian Heimes's avatar
Christian Heimes committed
2
import unittest
3 4 5
import dummy_threading as _threading
import time

Christian Heimes's avatar
Christian Heimes committed
6
class DummyThreadingTestCase(unittest.TestCase):
7

Christian Heimes's avatar
Christian Heimes committed
8
    class TestThread(_threading.Thread):
Tim Peters's avatar
Tim Peters committed
9

Christian Heimes's avatar
Christian Heimes committed
10 11 12 13 14 15 16 17
        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
18
            if support.verbose:
19
                print('task', self.name, 'will run for', delay, 'sec')
Christian Heimes's avatar
Christian Heimes committed
20 21 22
            sema.acquire()
            mutex.acquire()
            running += 1
23
            if support.verbose:
Christian Heimes's avatar
Christian Heimes committed
24 25 26
                print(running, 'tasks are running')
            mutex.release()
            time.sleep(delay)
27
            if support.verbose:
28
                print('task', self.name, 'done')
Christian Heimes's avatar
Christian Heimes committed
29 30
            mutex.acquire()
            running -= 1
31
            if support.verbose:
32
                print(self.name, 'is finished.', running, 'tasks are running')
Christian Heimes's avatar
Christian Heimes committed
33 34 35 36 37 38 39 40 41
            mutex.release()
            sema.release()

    def setUp(self):
        self.numtasks = 10
        global sema
        sema = _threading.BoundedSemaphore(value=3)
        global mutex
        mutex = _threading.RLock()
42
        global running
Christian Heimes's avatar
Christian Heimes committed
43 44
        running = 0
        self.threads = []
45

Christian Heimes's avatar
Christian Heimes committed
46 47 48 49 50
    def test_tasks(self):
        for i in range(self.numtasks):
            t = self.TestThread(name="<thread %d>"%i)
            self.threads.append(t)
            t.start()
51

52
        if support.verbose:
Christian Heimes's avatar
Christian Heimes committed
53 54 55
            print('waiting for all tasks to complete')
        for t in self.threads:
            t.join()
56
        if support.verbose:
Christian Heimes's avatar
Christian Heimes committed
57
            print('all tasks done')
58 59

def test_main():
60
    support.run_unittest(DummyThreadingTestCase)
61 62 63 64


if __name__ == '__main__':
    test_main()