File: test_worker_thread.py

package info (click to toggle)
enthought-traits-ui 2.0.5-1
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 15,204 kB
  • ctags: 9,623
  • sloc: python: 45,547; sh: 32; makefile: 19
file content (86 lines) | stat: -rw-r--r-- 2,659 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#------------------------------------------------------------------------------
# Copyright (c) 2005, Enthought, Inc.
# All rights reserved.
# 
# This software is provided without warranty under the terms of the BSD
# license included in enthought/LICENSE.txt and may be redistributed only
# under the conditions described in the aforementioned license.  The license
# is also available online at http://www.enthought.com/licenses/BSD.txt
# Thanks for using Enthought open source!
# 
# Author: Enthought, Inc.
# Description: <Enthought util package component>
#------------------------------------------------------------------------------
from enthought.util.Worker import Worker
import threading
import time
import unittest 
  
snooze = 1

class test_worker_thread(unittest.TestCase):
    
    
    
    def check_cancel(self):
        start = time.time()
        worker = Worker(name = "First EnVisage worker thread")
        worker.perform_work(slow_eval, snooze)
        worker.start()   
        time.sleep(3 * snooze)
        worker.cancel()
    
        worker = Worker(name = "Second EnVisage worker thread")
        worker.perform_work(slow_eval, snooze)
        worker.start()
        time.sleep(2 * snooze)
        worker.cancel()

        duration = time.time() - start
        self.assert_(duration > 5 * snooze)
        self.assert_(duration < 10 * snooze)
        
    def check_concurrent(self):
        start = time.time()
        
        worker = Worker(name = "First EnVisage worker thread")
        worker.perform_work(slow_eval, snooze)
        worker.start()   
    
        worker = Worker(name = "Second EnVisage worker thread")
        worker.perform_work(slow_eval, snooze)
        worker.start()

        duration = time.time() - start
        print duration
        
        # !! todo block on completion and check it is less than twice
        # the time for a single thread

def slow_eval(worker, sleep_time):   
    for i in range(10):
        if worker.abort():
            return
        else:
            # pretend to do some intensive computation 
            time.sleep(sleep_time)
            print worker.getName(),' sleeping for: ', sleep_time
    return sleep_time

def test_suite(level=1):
    suites = []
    if level > 0:
        suites.append( unittest.makeSuite(test_worker_thread,'check_') )
    if level > 5:
        pass
    total_suite = unittest.TestSuite(suites)
    return total_suite

def test(level=10,verbosity=1):
    all_tests = test_suite(level=level)
    runner = unittest.TextTestRunner(verbosity=verbosity)
    runner.run(all_tests)
    return runner

if __name__ == "__main__":
    test()