mirror of
https://github.com/python/cpython.git
synced 2025-07-08 03:45:36 +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()
|