mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 03:44:55 +00:00 
			
		
		
		
	svn+ssh://pythondev@svn.python.org/python/trunk ........ r60990 | eric.smith | 2008-02-23 17:05:26 +0100 (Sat, 23 Feb 2008) | 1 line Removed duplicate Py_CHARMASK define. It's already defined in Python.h. ........ r60991 | andrew.kuchling | 2008-02-23 17:23:05 +0100 (Sat, 23 Feb 2008) | 4 lines #1330538: Improve comparison of xmlrpclib.DateTime and datetime instances. Remove automatic handling of datetime.date and datetime.time. This breaks backward compatibility, but python-dev discussion was strongly against this automatic conversion; see the bug for a link. ........ r60994 | andrew.kuchling | 2008-02-23 17:39:43 +0100 (Sat, 23 Feb 2008) | 1 line #835521: Add index entries for various pickle-protocol methods and attributes ........ r60995 | andrew.kuchling | 2008-02-23 18:10:46 +0100 (Sat, 23 Feb 2008) | 2 lines #1433694: minidom's .normalize() failed to set .nextSibling for last element. Fix by Malte Helmert ........ r61000 | christian.heimes | 2008-02-23 18:40:11 +0100 (Sat, 23 Feb 2008) | 1 line Patch #2167 from calvin: Remove unused imports ........ r61001 | christian.heimes | 2008-02-23 18:42:31 +0100 (Sat, 23 Feb 2008) | 1 line Patch #1957: syslogmodule: Release GIL when calling syslog(3) ........ r61002 | christian.heimes | 2008-02-23 18:52:07 +0100 (Sat, 23 Feb 2008) | 2 lines Issue #2051 and patch from Alexander Belopolsky: Permission for pyc and pyo files are inherited from the py file. ........
		
			
				
	
	
		
			72 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# Very rudimentary test of threading module
 | 
						|
 | 
						|
# Create a bunch of threads, let each do some work, wait until all are done
 | 
						|
 | 
						|
from test.test_support import verbose
 | 
						|
import dummy_threading as _threading
 | 
						|
import time
 | 
						|
 | 
						|
 | 
						|
class TestThread(_threading.Thread):
 | 
						|
 | 
						|
    def run(self):
 | 
						|
        global running
 | 
						|
        # Uncomment if testing another module, such as the real 'threading'
 | 
						|
        # module.
 | 
						|
        #delay = random.random() * 2
 | 
						|
        delay = 0
 | 
						|
        if verbose:
 | 
						|
            print('task', self.getName(), 'will run for', delay, '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()
 | 
						|
 | 
						|
def starttasks():
 | 
						|
    for i in range(numtasks):
 | 
						|
        t = TestThread(name="<thread %d>"%i)
 | 
						|
        threads.append(t)
 | 
						|
        t.start()
 | 
						|
 | 
						|
 | 
						|
def test_main():
 | 
						|
    # This takes about n/3 seconds to run (about n/3 clumps of tasks, times
 | 
						|
    # about 1 second per clump).
 | 
						|
    global numtasks
 | 
						|
    numtasks = 10
 | 
						|
 | 
						|
    # no more than 3 of the 10 can run at once
 | 
						|
    global sema
 | 
						|
    sema = _threading.BoundedSemaphore(value=3)
 | 
						|
    global mutex
 | 
						|
    mutex = _threading.RLock()
 | 
						|
    global running
 | 
						|
    running = 0
 | 
						|
 | 
						|
    global threads
 | 
						|
    threads = []
 | 
						|
 | 
						|
    starttasks()
 | 
						|
 | 
						|
    if verbose:
 | 
						|
        print('waiting for all tasks to complete')
 | 
						|
    for t in threads:
 | 
						|
        t.join()
 | 
						|
    if verbose:
 | 
						|
        print('all tasks done')
 | 
						|
 | 
						|
 | 
						|
 | 
						|
if __name__ == '__main__':
 | 
						|
    test_main()
 |