Commit 35ce42f2 authored by Antoine Pitrou's avatar Antoine Pitrou

Merged revisions 85444 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/branches/py3k

........
  r85444 | antoine.pitrou | 2010-10-14 01:48:39 +0200 (jeu., 14 oct. 2010) | 6 lines

  Fix (hopefully) occasional failures in test_threaded_import.
  `done` could be released multiple times because of concurrent
  execution.  We convert it to an Event, where calling set()
  multiple times is not a problem.
........
parent 2693d087
...@@ -33,7 +33,7 @@ def task(N, done, done_tasks, errors): ...@@ -33,7 +33,7 @@ def task(N, done, done_tasks, errors):
done_tasks.append(thread.get_ident()) done_tasks.append(thread.get_ident())
finished = len(done_tasks) == N finished = len(done_tasks) == N
if finished: if finished:
done.release() done.set()
# Create a circular import structure: A -> C -> B -> D -> A # Create a circular import structure: A -> C -> B -> D -> A
# NOTE: `time` is already loaded and therefore doesn't threaten to deadlock. # NOTE: `time` is already loaded and therefore doesn't threaten to deadlock.
...@@ -99,8 +99,7 @@ class ThreadedImportTests(unittest.TestCase): ...@@ -99,8 +99,7 @@ class ThreadedImportTests(unittest.TestCase):
# This triggers on, e.g., from test import autotest. # This triggers on, e.g., from test import autotest.
raise unittest.SkipTest("can't run when import lock is held") raise unittest.SkipTest("can't run when import lock is held")
done = thread.allocate_lock() done = threading.Event()
done.acquire()
for N in (20, 50) * 3: for N in (20, 50) * 3:
if verbose: if verbose:
print("Trying", N, "threads ...", end=' ') print("Trying", N, "threads ...", end=' ')
...@@ -112,13 +111,13 @@ class ThreadedImportTests(unittest.TestCase): ...@@ -112,13 +111,13 @@ class ThreadedImportTests(unittest.TestCase):
pass pass
errors = [] errors = []
done_tasks = [] done_tasks = []
done.clear()
for i in range(N): for i in range(N):
thread.start_new_thread(task, (N, done, done_tasks, errors,)) thread.start_new_thread(task, (N, done, done_tasks, errors,))
done.acquire() done.wait(60)
self.assertFalse(errors) self.assertFalse(errors)
if verbose: if verbose:
print("OK.") print("OK.")
done.release()
def test_parallel_module_init(self): def test_parallel_module_init(self):
self.check_parallel_module_init() self.check_parallel_module_init()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment