mirror of
https://github.com/python/cpython.git
synced 2025-07-15 15:25:29 +00:00

svn+ssh://pythondev@svn.python.org/python/trunk ........ r78018 | georg.brandl | 2010-02-06 11:08:21 +0100 (Sa, 06 Feb 2010) | 1 line #7864: make deprecation notices a bit clearer. ........ r78035 | georg.brandl | 2010-02-06 23:44:17 +0100 (Sa, 06 Feb 2010) | 1 line Fix duplicate import. ........ r78036 | georg.brandl | 2010-02-06 23:49:47 +0100 (Sa, 06 Feb 2010) | 1 line Remove unused import. ........ r78037 | georg.brandl | 2010-02-06 23:59:15 +0100 (Sa, 06 Feb 2010) | 1 line No need to assign the results of expressions used only for side effects. ........ r78038 | georg.brandl | 2010-02-07 00:02:29 +0100 (So, 07 Feb 2010) | 1 line Add a missing import. ........ r78039 | georg.brandl | 2010-02-07 00:06:24 +0100 (So, 07 Feb 2010) | 1 line Add missing imports. ........ r78040 | georg.brandl | 2010-02-07 00:08:00 +0100 (So, 07 Feb 2010) | 1 line Fix a few UnboundLocalErrors in test_long. ........ r78042 | georg.brandl | 2010-02-07 00:12:12 +0100 (So, 07 Feb 2010) | 1 line Add missing import. ........ r78043 | georg.brandl | 2010-02-07 00:12:19 +0100 (So, 07 Feb 2010) | 1 line Remove duplicate test method. ........ r78046 | georg.brandl | 2010-02-07 00:18:00 +0100 (So, 07 Feb 2010) | 1 line Fix various missing import/unbound name errors. ........ r78048 | georg.brandl | 2010-02-07 00:23:45 +0100 (So, 07 Feb 2010) | 1 line We heard you like test failures so we put unbound locals in your test so that you can fail while you fail. ........ r78049 | georg.brandl | 2010-02-07 00:33:33 +0100 (So, 07 Feb 2010) | 1 line Fix import/access for some identifiers. _TestSharedCTypes does not seem to be executed? ........ r78050 | georg.brandl | 2010-02-07 00:34:10 +0100 (So, 07 Feb 2010) | 1 line Fix more unbound locals in code paths that do not seem to be used. ........ r78051 | georg.brandl | 2010-02-07 00:53:52 +0100 (So, 07 Feb 2010) | 1 line Add missing import when running these tests standalone. ........ r78052 | georg.brandl | 2010-02-07 00:54:04 +0100 (So, 07 Feb 2010) | 1 line Add missing import when running these tests standalone. ........ r78054 | georg.brandl | 2010-02-07 00:58:25 +0100 (So, 07 Feb 2010) | 1 line Add missing import. ........ r78059 | georg.brandl | 2010-02-07 12:34:15 +0100 (So, 07 Feb 2010) | 1 line Use "regexp" consistently. ........ r78075 | georg.brandl | 2010-02-07 13:16:12 +0100 (So, 07 Feb 2010) | 1 line Fix another duplicated test method. ........ r78076 | georg.brandl | 2010-02-07 13:19:43 +0100 (So, 07 Feb 2010) | 1 line Fix wrong usage of "except X, Y:". ........ r78077 | georg.brandl | 2010-02-07 13:25:50 +0100 (So, 07 Feb 2010) | 1 line Fix two redefined test methods. ........ r78078 | georg.brandl | 2010-02-07 13:27:06 +0100 (So, 07 Feb 2010) | 1 line Fix a redefined test method. ........ r78079 | georg.brandl | 2010-02-07 13:34:26 +0100 (So, 07 Feb 2010) | 1 line Add a minimal test for fnmatchcase(). ........ r78080 | georg.brandl | 2010-02-07 13:55:12 +0100 (So, 07 Feb 2010) | 1 line Remove duplicate test method. ........
76 lines
2.5 KiB
Python
76 lines
2.5 KiB
Python
# This is a variant of the very old (early 90's) file
|
|
# Demo/threads/bug.py. It simply provokes a number of threads into
|
|
# trying to import the same module "at the same time".
|
|
# There are no pleasant failure modes -- most likely is that Python
|
|
# complains several times about module random having no attribute
|
|
# randrange, and then Python hangs.
|
|
|
|
import _thread as thread
|
|
import unittest
|
|
from test.support import verbose, TestFailed
|
|
|
|
critical_section = thread.allocate_lock()
|
|
done = thread.allocate_lock()
|
|
|
|
def task():
|
|
global N, critical_section, done
|
|
import random
|
|
x = random.randrange(1, 3)
|
|
critical_section.acquire()
|
|
N -= 1
|
|
# Must release critical_section before releasing done, else the main
|
|
# thread can exit and set critical_section to None as part of global
|
|
# teardown; then critical_section.release() raises AttributeError.
|
|
finished = N == 0
|
|
critical_section.release()
|
|
if finished:
|
|
done.release()
|
|
|
|
def test_import_hangers():
|
|
import sys
|
|
if verbose:
|
|
print("testing import hangers ...", end=' ')
|
|
|
|
import test.threaded_import_hangers
|
|
try:
|
|
if test.threaded_import_hangers.errors:
|
|
raise TestFailed(test.threaded_import_hangers.errors)
|
|
elif verbose:
|
|
print("OK.")
|
|
finally:
|
|
# In case this test is run again, make sure the helper module
|
|
# gets loaded from scratch again.
|
|
del sys.modules['test.threaded_import_hangers']
|
|
|
|
# Tricky: When regrtest imports this module, the thread running regrtest
|
|
# grabs the import lock and won't let go of it until this module returns.
|
|
# All other threads attempting an import hang for the duration. Since
|
|
# this test spawns threads that do little *but* import, we can't do that
|
|
# successfully until after this module finishes importing and regrtest
|
|
# regains control. To make this work, a special case was added to
|
|
# regrtest to invoke a module's "test_main" function (if any) after
|
|
# importing it.
|
|
|
|
def test_main(): # magic name! see above
|
|
global N, done
|
|
|
|
import imp
|
|
if imp.lock_held():
|
|
# This triggers on, e.g., from test import autotest.
|
|
raise unittest.SkipTest("can't run when import lock is held")
|
|
|
|
done.acquire()
|
|
for N in (20, 50) * 3:
|
|
if verbose:
|
|
print("Trying", N, "threads ...", end=' ')
|
|
for i in range(N):
|
|
thread.start_new_thread(task, ())
|
|
done.acquire()
|
|
if verbose:
|
|
print("OK.")
|
|
done.release()
|
|
|
|
test_import_hangers()
|
|
|
|
if __name__ == "__main__":
|
|
test_main()
|