blob: da814228c033b62dd7009a933c3319c2e8279602 [file] [log] [blame]
Brett Cannonf1cfb622003-05-04 21:15:27 +00001"""Supporting definitions for the Python regression tests."""
Guido van Rossum3bead091992-01-27 17:00:37 +00002
Benjamin Petersonee8712c2008-05-20 21:35:26 +00003if __name__ != 'test.support':
4 raise ImportError('support must be imported from the test package')
Barry Warsaw408b6d32002-07-30 23:27:12 +00005
Guido van Rossumd8faa362007-04-27 19:54:29 +00006import contextlib
7import errno
Benjamin Petersonfa0d7032009-06-01 22:42:33 +00008import functools
Benjamin Peterson8cc7d882009-06-01 23:14:51 +00009import gc
Guido van Rossumd8faa362007-04-27 19:54:29 +000010import socket
Fred Drakecd1b1dd2001-03-21 18:26:33 +000011import sys
Guido van Rossumd8faa362007-04-27 19:54:29 +000012import os
Benjamin Petersone549ead2009-03-28 21:42:05 +000013import platform
Christian Heimes23daade02008-02-25 12:39:23 +000014import shutil
Thomas Wouters902d6eb2007-01-09 23:18:33 +000015import warnings
Guido van Rossumd8faa362007-04-27 19:54:29 +000016import unittest
R. David Murraya21e4ca2009-03-31 23:16:50 +000017import importlib
Walter Dörwald155374d2009-05-01 19:58:58 +000018import collections
Fred Drakecd1b1dd2001-03-21 18:26:33 +000019
Benjamin Petersone549ead2009-03-28 21:42:05 +000020__all__ = ["Error", "TestFailed", "ResourceDenied", "import_module",
Benjamin Peterson744c2cd2008-05-26 16:26:37 +000021 "verbose", "use_resources", "max_memuse", "record_original_stdout",
22 "get_original_stdout", "unload", "unlink", "rmtree", "forget",
23 "is_resource_enabled", "requires", "find_unused_port", "bind_port",
Benjamin Peterson79e48032008-05-26 17:44:33 +000024 "fcmp", "is_jython", "TESTFN", "HOST", "FUZZ", "findfile", "verify",
25 "vereq", "sortdict", "check_syntax_error", "open_urlresource",
Benjamin Petersonfcf5d632008-10-16 23:24:44 +000026 "check_warnings", "CleanImport", "EnvironmentVarGuard",
Benjamin Peterson79e48032008-05-26 17:44:33 +000027 "TransientResource", "captured_output", "captured_stdout",
28 "TransientResource", "transient_internet", "run_with_locale",
29 "set_memlimit", "bigmemtest", "bigaddrspacetest", "BasicTestRunner",
30 "run_unittest", "run_doctest", "threading_setup", "threading_cleanup",
R. David Murraya21e4ca2009-03-31 23:16:50 +000031 "reap_children", "cpython_only", "check_impl_detail", "get_attribute"]
Benjamin Peterson744c2cd2008-05-26 16:26:37 +000032
Fred Drake1790dd42000-07-24 06:55:00 +000033class Error(Exception):
Fred Drake004d5e62000-10-23 17:22:08 +000034 """Base class for regression test exceptions."""
Fred Drake1790dd42000-07-24 06:55:00 +000035
36class TestFailed(Error):
Fred Drake004d5e62000-10-23 17:22:08 +000037 """Test failed."""
Fred Drake1790dd42000-07-24 06:55:00 +000038
Benjamin Petersone549ead2009-03-28 21:42:05 +000039class ResourceDenied(unittest.SkipTest):
Fred Drake9a0db072003-02-03 15:19:30 +000040 """Test skipped because it requested a disallowed resource.
41
42 This is raised when a test calls requires() for a resource that
43 has not be enabled. It is used to distinguish between expected
44 and unexpected skips.
45 """
46
Nick Coghlanfce769e2009-04-11 14:30:59 +000047@contextlib.contextmanager
48def _ignore_deprecated_imports(ignore=True):
49 """Context manager to suppress package and module deprecation
50 warnings when importing them.
51
52 If ignore is False, this context manager has no effect."""
53 if ignore:
54 with warnings.catch_warnings():
55 warnings.filterwarnings("ignore", ".+ (module|package)",
56 DeprecationWarning)
57 yield
58 else:
59 yield
60
61
Benjamin Peterson699adb92008-05-08 22:27:58 +000062def import_module(name, deprecated=False):
R. David Murraya21e4ca2009-03-31 23:16:50 +000063 """Import and return the module to be tested, raising SkipTest if
64 it is not available.
65
66 If deprecated is True, any module or package deprecation messages
67 will be suppressed."""
Nick Coghlanfce769e2009-04-11 14:30:59 +000068 with _ignore_deprecated_imports(deprecated):
Benjamin Peterson699adb92008-05-08 22:27:58 +000069 try:
Nick Coghlanfce769e2009-04-11 14:30:59 +000070 return importlib.import_module(name)
R. David Murraya21e4ca2009-03-31 23:16:50 +000071 except ImportError as msg:
72 raise unittest.SkipTest(str(msg))
Nick Coghlanfce769e2009-04-11 14:30:59 +000073
74
Nick Coghlan47384702009-04-22 16:13:36 +000075def _save_and_remove_module(name, orig_modules):
76 """Helper function to save and remove a module from sys.modules
77
78 Return value is True if the module was in sys.modules and
79 False otherwise."""
80 saved = True
81 try:
82 orig_modules[name] = sys.modules[name]
83 except KeyError:
84 saved = False
85 else:
86 del sys.modules[name]
87 return saved
88
89
90def _save_and_block_module(name, orig_modules):
91 """Helper function to save and block a module in sys.modules
92
93 Return value is True if the module was in sys.modules and
94 False otherwise."""
95 saved = True
96 try:
97 orig_modules[name] = sys.modules[name]
98 except KeyError:
99 saved = False
100 sys.modules[name] = 0
101 return saved
102
103
104def import_fresh_module(name, fresh=(), blocked=(), deprecated=False):
Nick Coghlanfce769e2009-04-11 14:30:59 +0000105 """Imports and returns a module, deliberately bypassing the sys.modules cache
106 and importing a fresh copy of the module. Once the import is complete,
107 the sys.modules cache is restored to its original state.
108
Nick Coghlan47384702009-04-22 16:13:36 +0000109 Modules named in fresh are also imported anew if needed by the import.
110
111 Importing of modules named in blocked is prevented while the fresh import
Nick Coghlanfce769e2009-04-11 14:30:59 +0000112 takes place.
113
114 If deprecated is True, any module or package deprecation messages
115 will be suppressed."""
116 # NOTE: test_heapq and test_warnings include extra sanity checks to make
117 # sure that this utility function is working as expected
118 with _ignore_deprecated_imports(deprecated):
Nick Coghlan47384702009-04-22 16:13:36 +0000119 # Keep track of modules saved for later restoration as well
120 # as those which just need a blocking entry removed
Nick Coghlanfce769e2009-04-11 14:30:59 +0000121 orig_modules = {}
Nick Coghlan47384702009-04-22 16:13:36 +0000122 names_to_remove = []
123 _save_and_remove_module(name, orig_modules)
Nick Coghlanfce769e2009-04-11 14:30:59 +0000124 try:
Nick Coghlan47384702009-04-22 16:13:36 +0000125 for fresh_name in fresh:
126 _save_and_remove_module(fresh_name, orig_modules)
127 for blocked_name in blocked:
128 if not _save_and_block_module(blocked_name, orig_modules):
129 names_to_remove.append(blocked_name)
130 fresh_module = importlib.import_module(name)
Nick Coghlanfce769e2009-04-11 14:30:59 +0000131 finally:
Nick Coghlan47384702009-04-22 16:13:36 +0000132 for orig_name, module in orig_modules.items():
133 sys.modules[orig_name] = module
134 for name_to_remove in names_to_remove:
135 del sys.modules[name_to_remove]
136 return fresh_module
Nick Coghlanfce769e2009-04-11 14:30:59 +0000137
Benjamin Peterson699adb92008-05-08 22:27:58 +0000138
R. David Murraya21e4ca2009-03-31 23:16:50 +0000139def get_attribute(obj, name):
140 """Get an attribute, raising SkipTest if AttributeError is raised."""
141 try:
142 attribute = getattr(obj, name)
143 except AttributeError:
144 raise unittest.SkipTest("module %s has no attribute %s" % (
145 obj.__name__, name))
146 else:
147 return attribute
148
Barry Warsawc0fb6052001-08-20 22:29:23 +0000149verbose = 1 # Flag set to 0 by regrtest.py
Thomas Wouters477c8d52006-05-27 19:21:47 +0000150use_resources = None # Flag set to [] by regrtest.py
151max_memuse = 0 # Disable bigmem tests (they will still be run with
152 # small sizes, to make sure they work.)
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000153real_max_memuse = 0
Guido van Rossum531661c1996-12-20 02:58:22 +0000154
Tim Peters8dee8092001-09-25 20:05:11 +0000155# _original_stdout is meant to hold stdout at the time regrtest began.
156# This may be "the real" stdout, or IDLE's emulation of stdout, or whatever.
157# The point is to have some flavor of stdout the user can actually see.
158_original_stdout = None
159def record_original_stdout(stdout):
160 global _original_stdout
161 _original_stdout = stdout
162
163def get_original_stdout():
164 return _original_stdout or sys.stdout
165
Guido van Rossum3bead091992-01-27 17:00:37 +0000166def unload(name):
Fred Drake004d5e62000-10-23 17:22:08 +0000167 try:
168 del sys.modules[name]
169 except KeyError:
170 pass
Guido van Rossum3bead091992-01-27 17:00:37 +0000171
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000172def unlink(filename):
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000173 try:
174 os.unlink(filename)
175 except OSError:
176 pass
177
Christian Heimes23daade02008-02-25 12:39:23 +0000178def rmtree(path):
179 try:
180 shutil.rmtree(path)
181 except OSError as e:
182 # Unix returns ENOENT, Windows returns ESRCH.
183 if e.errno not in (errno.ENOENT, errno.ESRCH):
184 raise
185
Guido van Rossum3bead091992-01-27 17:00:37 +0000186def forget(modname):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000187 '''"Forget" a module was ever imported by removing it from sys.modules and
188 deleting any .pyc and .pyo files.'''
Fred Drake004d5e62000-10-23 17:22:08 +0000189 unload(modname)
Fred Drake004d5e62000-10-23 17:22:08 +0000190 for dirname in sys.path:
Skip Montanaro7a98be22007-08-16 14:35:24 +0000191 unlink(os.path.join(dirname, modname + '.pyc'))
Brett Cannonf1cfb622003-05-04 21:15:27 +0000192 # Deleting the .pyo file cannot be within the 'try' for the .pyc since
193 # the chance exists that there is no .pyc (and thus the 'try' statement
194 # is exited) but there is a .pyo file.
Skip Montanaro7a98be22007-08-16 14:35:24 +0000195 unlink(os.path.join(dirname, modname + '.pyo'))
Guido van Rossum3bead091992-01-27 17:00:37 +0000196
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000197def is_resource_enabled(resource):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000198 """Test whether a resource is enabled. Known resources are set by
199 regrtest.py."""
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000200 return use_resources is not None and resource in use_resources
201
Barry Warsawc0fb6052001-08-20 22:29:23 +0000202def requires(resource, msg=None):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000203 """Raise ResourceDenied if the specified resource is not available.
204
205 If the caller's module is __main__ then automatically return True. The
206 possibility of False being returned occurs when regrtest.py is executing."""
Skip Montanarod839ecd2003-04-24 19:06:57 +0000207 # see if the caller's module is __main__ - if so, treat as if
208 # the resource was set
Benjamin Petersone549ead2009-03-28 21:42:05 +0000209 if sys._getframe(1).f_globals.get("__name__") == "__main__":
Skip Montanarod839ecd2003-04-24 19:06:57 +0000210 return
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000211 if not is_resource_enabled(resource):
Barry Warsawc0fb6052001-08-20 22:29:23 +0000212 if msg is None:
213 msg = "Use of the `%s' resource not enabled" % resource
Fred Drake9a0db072003-02-03 15:19:30 +0000214 raise ResourceDenied(msg)
Barry Warsawc0fb6052001-08-20 22:29:23 +0000215
Christian Heimes5e696852008-04-09 08:37:03 +0000216HOST = 'localhost'
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000217
Christian Heimes5e696852008-04-09 08:37:03 +0000218def find_unused_port(family=socket.AF_INET, socktype=socket.SOCK_STREAM):
219 """Returns an unused port that should be suitable for binding. This is
220 achieved by creating a temporary socket with the same family and type as
221 the 'sock' parameter (default is AF_INET, SOCK_STREAM), and binding it to
222 the specified host address (defaults to 0.0.0.0) with the port set to 0,
223 eliciting an unused ephemeral port from the OS. The temporary socket is
224 then closed and deleted, and the ephemeral port is returned.
225
226 Either this method or bind_port() should be used for any tests where a
227 server socket needs to be bound to a particular port for the duration of
228 the test. Which one to use depends on whether the calling code is creating
229 a python socket, or if an unused port needs to be provided in a constructor
230 or passed to an external program (i.e. the -accept argument to openssl's
231 s_server mode). Always prefer bind_port() over find_unused_port() where
232 possible. Hard coded ports should *NEVER* be used. As soon as a server
233 socket is bound to a hard coded port, the ability to run multiple instances
234 of the test simultaneously on the same host is compromised, which makes the
235 test a ticking time bomb in a buildbot environment. On Unix buildbots, this
236 may simply manifest as a failed test, which can be recovered from without
237 intervention in most cases, but on Windows, the entire python process can
238 completely and utterly wedge, requiring someone to log in to the buildbot
239 and manually kill the affected process.
240
241 (This is easy to reproduce on Windows, unfortunately, and can be traced to
242 the SO_REUSEADDR socket option having different semantics on Windows versus
243 Unix/Linux. On Unix, you can't have two AF_INET SOCK_STREAM sockets bind,
244 listen and then accept connections on identical host/ports. An EADDRINUSE
245 socket.error will be raised at some point (depending on the platform and
246 the order bind and listen were called on each socket).
247
248 However, on Windows, if SO_REUSEADDR is set on the sockets, no EADDRINUSE
249 will ever be raised when attempting to bind two identical host/ports. When
250 accept() is called on each socket, the second caller's process will steal
251 the port from the first caller, leaving them both in an awkwardly wedged
252 state where they'll no longer respond to any signals or graceful kills, and
253 must be forcibly killed via OpenProcess()/TerminateProcess().
254
255 The solution on Windows is to use the SO_EXCLUSIVEADDRUSE socket option
256 instead of SO_REUSEADDR, which effectively affords the same semantics as
257 SO_REUSEADDR on Unix. Given the propensity of Unix developers in the Open
258 Source world compared to Windows ones, this is a common mistake. A quick
259 look over OpenSSL's 0.9.8g source shows that they use SO_REUSEADDR when
260 openssl.exe is called with the 's_server' option, for example. See
261 http://bugs.python.org/issue2550 for more info. The following site also
262 has a very thorough description about the implications of both REUSEADDR
263 and EXCLUSIVEADDRUSE on Windows:
264 http://msdn2.microsoft.com/en-us/library/ms740621(VS.85).aspx)
265
266 XXX: although this approach is a vast improvement on previous attempts to
267 elicit unused ports, it rests heavily on the assumption that the ephemeral
268 port returned to us by the OS won't immediately be dished back out to some
269 other process when we close and delete our temporary socket but before our
270 calling code has a chance to bind the returned port. We can deal with this
271 issue if/when we come across it.
272 """
273
274 tempsock = socket.socket(family, socktype)
275 port = bind_port(tempsock)
276 tempsock.close()
277 del tempsock
278 return port
279
280def bind_port(sock, host=HOST):
281 """Bind the socket to a free port and return the port number. Relies on
282 ephemeral ports in order to ensure we are using an unbound port. This is
283 important as many tests may be running simultaneously, especially in a
284 buildbot environment. This method raises an exception if the sock.family
285 is AF_INET and sock.type is SOCK_STREAM, *and* the socket has SO_REUSEADDR
286 or SO_REUSEPORT set on it. Tests should *never* set these socket options
287 for TCP/IP sockets. The only case for setting these options is testing
288 multicasting via multiple UDP sockets.
289
290 Additionally, if the SO_EXCLUSIVEADDRUSE socket option is available (i.e.
291 on Windows), it will be set on the socket. This will prevent anyone else
292 from bind()'ing to our host/port for the duration of the test.
293 """
294
295 if sock.family == socket.AF_INET and sock.type == socket.SOCK_STREAM:
296 if hasattr(socket, 'SO_REUSEADDR'):
297 if sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR) == 1:
298 raise TestFailed("tests should never set the SO_REUSEADDR " \
299 "socket option on TCP/IP sockets!")
300 if hasattr(socket, 'SO_REUSEPORT'):
301 if sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEPORT) == 1:
302 raise TestFailed("tests should never set the SO_REUSEPORT " \
303 "socket option on TCP/IP sockets!")
304 if hasattr(socket, 'SO_EXCLUSIVEADDRUSE'):
305 sock.setsockopt(socket.SOL_SOCKET, socket.SO_EXCLUSIVEADDRUSE, 1)
306
307 sock.bind((host, 0))
308 port = sock.getsockname()[1]
309 return port
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000310
Guido van Rossum35fb82a1993-01-26 13:04:43 +0000311FUZZ = 1e-6
312
313def fcmp(x, y): # fuzzy comparison function
Neal Norwitz79212992006-08-21 16:27:31 +0000314 if isinstance(x, float) or isinstance(y, float):
Fred Drake004d5e62000-10-23 17:22:08 +0000315 try:
Fred Drake004d5e62000-10-23 17:22:08 +0000316 fuzz = (abs(x) + abs(y)) * FUZZ
317 if abs(x-y) <= fuzz:
318 return 0
319 except:
320 pass
Neal Norwitz79212992006-08-21 16:27:31 +0000321 elif type(x) == type(y) and isinstance(x, (tuple, list)):
Fred Drake004d5e62000-10-23 17:22:08 +0000322 for i in range(min(len(x), len(y))):
323 outcome = fcmp(x[i], y[i])
Fred Drake132dce22000-12-12 23:11:42 +0000324 if outcome != 0:
Fred Drake004d5e62000-10-23 17:22:08 +0000325 return outcome
Guido van Rossum47b9ff62006-08-24 00:41:19 +0000326 return (len(x) > len(y)) - (len(x) < len(y))
327 return (x > y) - (x < y)
Guido van Rossum35fb82a1993-01-26 13:04:43 +0000328
Finn Bock57bc5fa2002-11-01 18:02:03 +0000329is_jython = sys.platform.startswith('java')
330
Barry Warsaw559f6682001-03-23 18:04:02 +0000331# Filename used for testing
332if os.name == 'java':
333 # Jython disallows @ in module names
334 TESTFN = '$test'
Martin v. Löwisa94568a2003-05-10 07:36:56 +0000335else:
Barry Warsaw559f6682001-03-23 18:04:02 +0000336 TESTFN = '@test'
Walter Dörwald9b775532007-06-08 14:30:53 +0000337
338 # Assuming sys.getfilesystemencoding()!=sys.getdefaultencoding()
339 # TESTFN_UNICODE is a filename that can be encoded using the
340 # file system encoding, but *not* with the default (ascii) encoding
341 TESTFN_UNICODE = "@test-\xe0\xf2"
342 TESTFN_ENCODING = sys.getfilesystemencoding()
343 # TESTFN_UNICODE_UNENCODEABLE is a filename that should *not* be
344 # able to be encoded by *either* the default or filesystem encoding.
345 # This test really only makes sense on Windows NT platforms
346 # which have special Unicode support in posixmodule.
347 if (not hasattr(sys, "getwindowsversion") or
348 sys.getwindowsversion()[3] < 2): # 0=win32s or 1=9x/ME
349 TESTFN_UNICODE_UNENCODEABLE = None
350 else:
351 # Japanese characters (I think - from bug 846133)
352 TESTFN_UNICODE_UNENCODEABLE = "@test-\u5171\u6709\u3055\u308c\u308b"
353 try:
354 # XXX - Note - should be using TESTFN_ENCODING here - but for
355 # Windows, "mbcs" currently always operates as if in
356 # errors=ignore' mode - hence we get '?' characters rather than
357 # the exception. 'Latin1' operates as we expect - ie, fails.
358 # See [ 850997 ] mbcs encoding ignores errors
359 TESTFN_UNICODE_UNENCODEABLE.encode("Latin1")
360 except UnicodeEncodeError:
361 pass
Martin v. Löwis2411a2d2002-11-09 19:57:26 +0000362 else:
Georg Brandldb028442008-02-05 20:48:58 +0000363 print('WARNING: The filename %r CAN be encoded by the filesystem. '
364 'Unicode filename tests may not be effective'
365 % TESTFN_UNICODE_UNENCODEABLE)
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000366
367# Make sure we can write to TESTFN, try in /tmp if we can't
368fp = None
369try:
370 fp = open(TESTFN, 'w+')
371except IOError:
372 TMP_TESTFN = os.path.join('/tmp', TESTFN)
373 try:
374 fp = open(TMP_TESTFN, 'w+')
375 TESTFN = TMP_TESTFN
376 del TMP_TESTFN
377 except IOError:
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000378 print(('WARNING: tests will fail, unable to write to: %s or %s' %
379 (TESTFN, TMP_TESTFN)))
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000380if fp is not None:
381 fp.close()
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000382 unlink(TESTFN)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000383del fp
Guido van Rossuma8f7e592001-03-13 09:31:07 +0000384
Guido van Rossume26132c1998-04-23 20:13:30 +0000385def findfile(file, here=__file__):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000386 """Try to find a file on sys.path and the working directory. If it is not
387 found the argument passed to the function is returned (this does not
388 necessarily signal failure; could still be the legitimate path)."""
Fred Drake004d5e62000-10-23 17:22:08 +0000389 if os.path.isabs(file):
390 return file
Fred Drake004d5e62000-10-23 17:22:08 +0000391 path = sys.path
392 path = [os.path.dirname(here)] + path
393 for dn in path:
394 fn = os.path.join(dn, file)
395 if os.path.exists(fn): return fn
396 return file
Marc-André Lemburg36619082001-01-17 19:11:13 +0000397
398def verify(condition, reason='test failed'):
Guido van Rossuma1374e42001-01-19 19:01:56 +0000399 """Verify that condition is true. If not, raise TestFailed.
Marc-André Lemburg36619082001-01-17 19:11:13 +0000400
Skip Montanaroc955f892001-01-20 19:12:54 +0000401 The optional argument reason can be given to provide
Tim Peters983874d2001-01-19 05:59:21 +0000402 a better error text.
Tim Petersd2bf3b72001-01-18 02:22:22 +0000403 """
Tim Peters983874d2001-01-19 05:59:21 +0000404
Tim Petersd2bf3b72001-01-18 02:22:22 +0000405 if not condition:
Guido van Rossuma1374e42001-01-19 19:01:56 +0000406 raise TestFailed(reason)
Jeremy Hylton47793992001-02-19 15:35:26 +0000407
Tim Petersc2fe6182001-10-30 23:20:46 +0000408def vereq(a, b):
Tim Peters77902972001-12-29 17:34:57 +0000409 """Raise TestFailed if a == b is false.
410
411 This is better than verify(a == b) because, in case of failure, the
412 error message incorporates repr(a) and repr(b) so you can see the
413 inputs.
414
415 Note that "not (a == b)" isn't necessarily the same as "a != b"; the
416 former is tested.
417 """
418
Tim Petersc2fe6182001-10-30 23:20:46 +0000419 if not (a == b):
Guido van Rossumd8faa362007-04-27 19:54:29 +0000420 raise TestFailed("%r == %r" % (a, b))
Tim Petersc2fe6182001-10-30 23:20:46 +0000421
Tim Peters2f228e72001-05-13 00:19:31 +0000422def sortdict(dict):
423 "Like repr(dict), but in sorted order."
Guido van Rossumcc2b0162007-02-11 06:12:03 +0000424 items = sorted(dict.items())
Tim Peters2f228e72001-05-13 00:19:31 +0000425 reprpairs = ["%r: %r" % pair for pair in items]
426 withcommas = ", ".join(reprpairs)
427 return "{%s}" % withcommas
428
Benjamin Peterson7522c742009-01-19 21:00:09 +0000429def make_bad_fd():
430 """
431 Create an invalid file descriptor by opening and closing a file and return
432 its fd.
433 """
434 file = open(TESTFN, "wb")
435 try:
436 return file.fileno()
437 finally:
438 file.close()
439 unlink(TESTFN)
440
Thomas Wouters89f507f2006-12-13 04:49:30 +0000441def check_syntax_error(testcase, statement):
Benjamin Petersone549ead2009-03-28 21:42:05 +0000442 testcase.assertRaises(SyntaxError, compile, statement,
443 '<test string>', 'exec')
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000444
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000445def open_urlresource(url, *args, **kw):
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000446 import urllib.request, urllib.parse
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000447
Guido van Rossum360e4b82007-05-14 22:51:27 +0000448 requires('urlfetch')
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000449 filename = urllib.parse.urlparse(url)[2].split('/')[-1] # '/': it's URL!
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000450
451 for path in [os.path.curdir, os.path.pardir]:
452 fn = os.path.join(path, filename)
453 if os.path.exists(fn):
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000454 return open(fn, *args, **kw)
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000455
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000456 print('\tfetching %s ...' % url, file=get_original_stdout())
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000457 fn, _ = urllib.request.urlretrieve(url, filename)
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000458 return open(fn, *args, **kw)
Thomas Wouters9fe394c2007-02-05 01:24:16 +0000459
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000460
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000461class WarningsRecorder(object):
462 """Convenience wrapper for the warnings list returned on
463 entry to the warnings.catch_warnings() context manager.
Guido van Rossumd8faa362007-04-27 19:54:29 +0000464 """
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000465 def __init__(self, warnings_list):
466 self.warnings = warnings_list
467
468 def __getattr__(self, attr):
469 if self.warnings:
470 return getattr(self.warnings[-1], attr)
471 elif attr in warnings.WarningMessage._WARNING_DETAILS:
472 return None
473 raise AttributeError("%r has no attribute %r" % (self, attr))
474
475 def reset(self):
476 del self.warnings[:]
477
478@contextlib.contextmanager
479def check_warnings():
480 with warnings.catch_warnings(record=True) as w:
481 yield WarningsRecorder(w)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000482
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000483
484class CleanImport(object):
485 """Context manager to force import to return a new module reference.
486
487 This is useful for testing module-level behaviours, such as
Nick Coghlanb1304932008-07-13 12:25:08 +0000488 the emission of a DeprecationWarning on import.
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000489
490 Use like this:
491
492 with CleanImport("foo"):
493 __import__("foo") # new reference
494 """
495
496 def __init__(self, *module_names):
497 self.original_modules = sys.modules.copy()
498 for module_name in module_names:
499 if module_name in sys.modules:
500 module = sys.modules[module_name]
501 # It is possible that module_name is just an alias for
502 # another module (e.g. stub for modules renamed in 3.x).
503 # In that case, we also need delete the real module to clear
504 # the import cache.
505 if module.__name__ != module_name:
506 del sys.modules[module.__name__]
507 del sys.modules[module_name]
508
509 def __enter__(self):
510 return self
511
512 def __exit__(self, *ignore_exc):
513 sys.modules.update(self.original_modules)
514
515
Walter Dörwald155374d2009-05-01 19:58:58 +0000516class EnvironmentVarGuard(collections.MutableMapping):
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000517
518 """Class to help protect the environment variable properly. Can be used as
519 a context manager."""
520
521 def __init__(self):
Walter Dörwald155374d2009-05-01 19:58:58 +0000522 self._environ = os.environ
Walter Dörwald4ba80132009-04-25 12:48:43 +0000523 self._changed = {}
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000524
Walter Dörwald155374d2009-05-01 19:58:58 +0000525 def __getitem__(self, envvar):
526 return self._environ[envvar]
527
528 def __setitem__(self, envvar, value):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000529 # Remember the initial value on the first access
530 if envvar not in self._changed:
Walter Dörwald155374d2009-05-01 19:58:58 +0000531 self._changed[envvar] = self._environ.get(envvar)
532 self._environ[envvar] = value
533
534 def __delitem__(self, envvar):
535 # Remember the initial value on the first access
536 if envvar not in self._changed:
537 self._changed[envvar] = self._environ.get(envvar)
538 if envvar in self._environ:
539 del self._environ[envvar]
540
541 def keys(self):
542 return self._environ.keys()
543
544 def __iter__(self):
545 return iter(self._environ)
546
547 def __len__(self):
548 return len(self._environ)
549
550 def set(self, envvar, value):
551 self[envvar] = value
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000552
553 def unset(self, envvar):
Walter Dörwald155374d2009-05-01 19:58:58 +0000554 del self[envvar]
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000555
556 def __enter__(self):
557 return self
558
559 def __exit__(self, *ignore_exc):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000560 for (k, v) in self._changed.items():
561 if v is None:
Walter Dörwald155374d2009-05-01 19:58:58 +0000562 if k in self._environ:
563 del self._environ[k]
Walter Dörwald4ba80132009-04-25 12:48:43 +0000564 else:
Walter Dörwald155374d2009-05-01 19:58:58 +0000565 self._environ[k] = v
566
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000567
Guido van Rossumd8faa362007-04-27 19:54:29 +0000568class TransientResource(object):
569
570 """Raise ResourceDenied if an exception is raised while the context manager
571 is in effect that matches the specified exception and attributes."""
572
573 def __init__(self, exc, **kwargs):
574 self.exc = exc
575 self.attrs = kwargs
576
577 def __enter__(self):
578 return self
579
580 def __exit__(self, type_=None, value=None, traceback=None):
581 """If type_ is a subclass of self.exc and value has attributes matching
582 self.attrs, raise ResourceDenied. Otherwise let the exception
583 propagate (if any)."""
584 if type_ is not None and issubclass(self.exc, type_):
585 for attr, attr_value in self.attrs.items():
586 if not hasattr(value, attr):
587 break
588 if getattr(value, attr) != attr_value:
589 break
590 else:
591 raise ResourceDenied("an optional resource is not available")
592
593
Raymond Hettinger686057b2009-06-04 00:11:54 +0000594# Context managers that raise ResourceDenied when various issues
595# with the Internet connection manifest themselves as exceptions.
596time_out = TransientResource(IOError, errno=errno.ETIMEDOUT)
597socket_peer_reset = TransientResource(socket.error, errno=errno.ECONNRESET)
598ioerror_peer_reset = TransientResource(IOError, errno=errno.ECONNRESET)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000599
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000600
Thomas Woutersed03b412007-08-28 21:37:11 +0000601@contextlib.contextmanager
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000602def captured_output(stream_name):
603 """Run the 'with' statement body using a StringIO object in place of a
604 specific attribute on the sys module.
605 Example use (with 'stream_name=stdout')::
Thomas Woutersed03b412007-08-28 21:37:11 +0000606
607 with captured_stdout() as s:
Neal Norwitz752abd02008-05-13 04:55:24 +0000608 print("hello")
Thomas Woutersed03b412007-08-28 21:37:11 +0000609 assert s.getvalue() == "hello"
610 """
611 import io
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000612 orig_stdout = getattr(sys, stream_name)
613 setattr(sys, stream_name, io.StringIO())
Christian Heimes81ee3ef2008-05-04 22:42:01 +0000614 try:
615 yield getattr(sys, stream_name)
616 finally:
617 setattr(sys, stream_name, orig_stdout)
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000618
619def captured_stdout():
620 return captured_output("stdout")
Thomas Woutersed03b412007-08-28 21:37:11 +0000621
Benjamin Petersone549ead2009-03-28 21:42:05 +0000622def gc_collect():
623 """Force as many objects as possible to be collected.
624
625 In non-CPython implementations of Python, this is needed because timely
626 deallocation is not guaranteed by the garbage collector. (Even in CPython
627 this can be the case in case of reference cycles.) This means that __del__
628 methods may be called later than expected and weakrefs may remain alive for
629 longer than expected. This function tries its best to force all garbage
630 objects to disappear.
631 """
Benjamin Petersone549ead2009-03-28 21:42:05 +0000632 gc.collect()
633 gc.collect()
634 gc.collect()
635
Thomas Woutersed03b412007-08-28 21:37:11 +0000636
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000637#=======================================================================
Thomas Wouters477c8d52006-05-27 19:21:47 +0000638# Decorator for running a function in a different locale, correctly resetting
639# it afterwards.
640
641def run_with_locale(catstr, *locales):
642 def decorator(func):
643 def inner(*args, **kwds):
644 try:
645 import locale
646 category = getattr(locale, catstr)
647 orig_locale = locale.setlocale(category)
648 except AttributeError:
649 # if the test author gives us an invalid category string
650 raise
651 except:
652 # cannot retrieve original locale, so do nothing
653 locale = orig_locale = None
654 else:
655 for loc in locales:
656 try:
657 locale.setlocale(category, loc)
658 break
659 except:
660 pass
661
662 # now run the function, resetting the locale on exceptions
663 try:
664 return func(*args, **kwds)
665 finally:
666 if locale and orig_locale:
667 locale.setlocale(category, orig_locale)
Neal Norwitz221085d2007-02-25 20:55:47 +0000668 inner.__name__ = func.__name__
Thomas Wouters477c8d52006-05-27 19:21:47 +0000669 inner.__doc__ = func.__doc__
670 return inner
671 return decorator
672
673#=======================================================================
Georg Brandldb028442008-02-05 20:48:58 +0000674# Big-memory-test support. Separate from 'resources' because memory use
675# should be configurable.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000676
677# Some handy shorthands. Note that these are used for byte-limits as well
678# as size-limits, in the various bigmem tests
679_1M = 1024*1024
680_1G = 1024 * _1M
681_2G = 2 * _1G
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000682_4G = 4 * _1G
Thomas Wouters477c8d52006-05-27 19:21:47 +0000683
Thomas Woutersd2cf20e2007-08-30 22:57:53 +0000684MAX_Py_ssize_t = sys.maxsize
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000685
Thomas Wouters477c8d52006-05-27 19:21:47 +0000686def set_memlimit(limit):
687 import re
688 global max_memuse
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000689 global real_max_memuse
Thomas Wouters477c8d52006-05-27 19:21:47 +0000690 sizes = {
691 'k': 1024,
692 'm': _1M,
693 'g': _1G,
694 't': 1024*_1G,
695 }
696 m = re.match(r'(\d+(\.\d+)?) (K|M|G|T)b?$', limit,
697 re.IGNORECASE | re.VERBOSE)
698 if m is None:
699 raise ValueError('Invalid memory limit %r' % (limit,))
700 memlimit = int(float(m.group(1)) * sizes[m.group(3).lower()])
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000701 real_max_memuse = memlimit
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000702 if memlimit > MAX_Py_ssize_t:
703 memlimit = MAX_Py_ssize_t
704 if memlimit < _2G - 1:
Thomas Wouters477c8d52006-05-27 19:21:47 +0000705 raise ValueError('Memory limit %r too low to be useful' % (limit,))
706 max_memuse = memlimit
707
708def bigmemtest(minsize, memuse, overhead=5*_1M):
709 """Decorator for bigmem tests.
710
711 'minsize' is the minimum useful size for the test (in arbitrary,
712 test-interpreted units.) 'memuse' is the number of 'bytes per size' for
713 the test, or a good estimate of it. 'overhead' specifies fixed overhead,
Christian Heimes33fe8092008-04-13 13:53:33 +0000714 independent of the testsize, and defaults to 5Mb.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000715
716 The decorator tries to guess a good value for 'size' and passes it to
717 the decorated test function. If minsize * memuse is more than the
718 allowed memory use (as defined by max_memuse), the test is skipped.
719 Otherwise, minsize is adjusted upward to use up to max_memuse.
720 """
721 def decorator(f):
722 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000723 # Retrieve values in case someone decided to adjust them
724 minsize = wrapper.minsize
725 memuse = wrapper.memuse
726 overhead = wrapper.overhead
Thomas Wouters477c8d52006-05-27 19:21:47 +0000727 if not max_memuse:
728 # If max_memuse is 0 (the default),
729 # we still want to run the tests with size set to a few kb,
730 # to make sure they work. We still want to avoid using
731 # too much memory, though, but we do that noisily.
732 maxsize = 5147
733 self.failIf(maxsize * memuse + overhead > 20 * _1M)
734 else:
735 maxsize = int((max_memuse - overhead) / memuse)
736 if maxsize < minsize:
737 # Really ought to print 'test skipped' or something
738 if verbose:
739 sys.stderr.write("Skipping %s because of memory "
740 "constraint\n" % (f.__name__,))
741 return
742 # Try to keep some breathing room in memory use
743 maxsize = max(maxsize - 50 * _1M, minsize)
744 return f(self, maxsize)
745 wrapper.minsize = minsize
746 wrapper.memuse = memuse
747 wrapper.overhead = overhead
748 return wrapper
749 return decorator
750
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000751def precisionbigmemtest(size, memuse, overhead=5*_1M):
752 def decorator(f):
753 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000754 size = wrapper.size
755 memuse = wrapper.memuse
756 overhead = wrapper.overhead
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000757 if not real_max_memuse:
758 maxsize = 5147
759 else:
760 maxsize = size
761
762 if real_max_memuse and real_max_memuse < maxsize * memuse:
763 if verbose:
764 sys.stderr.write("Skipping %s because of memory "
765 "constraint\n" % (f.__name__,))
766 return
767
768 return f(self, maxsize)
769 wrapper.size = size
770 wrapper.memuse = memuse
771 wrapper.overhead = overhead
772 return wrapper
773 return decorator
774
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000775def bigaddrspacetest(f):
776 """Decorator for tests that fill the address space."""
777 def wrapper(self):
778 if max_memuse < MAX_Py_ssize_t:
779 if verbose:
780 sys.stderr.write("Skipping %s because of memory "
781 "constraint\n" % (f.__name__,))
782 else:
783 return f(self)
784 return wrapper
785
Thomas Wouters477c8d52006-05-27 19:21:47 +0000786#=======================================================================
Guido van Rossumd8faa362007-04-27 19:54:29 +0000787# unittest integration.
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000788
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000789class BasicTestRunner:
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000790 def run(self, test):
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000791 result = unittest.TestResult()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000792 test(result)
793 return result
794
Benjamin Petersone549ead2009-03-28 21:42:05 +0000795def _id(obj):
796 return obj
797
798def requires_resource(resource):
799 if resource_is_enabled(resource):
800 return _id
801 else:
802 return unittest.skip("resource {0!r} is not enabled".format(resource))
803
804def cpython_only(test):
805 """
806 Decorator for tests only applicable on CPython.
807 """
808 return impl_detail(cpython=True)(test)
809
810def impl_detail(msg=None, **guards):
811 if check_impl_detail(**guards):
812 return _id
813 if msg is None:
814 guardnames, default = _parse_guards(guards)
815 if default:
816 msg = "implementation detail not available on {0}"
817 else:
818 msg = "implementation detail specific to {0}"
819 guardnames = sorted(guardnames.keys())
820 msg = msg.format(' or '.join(guardnames))
821 return unittest.skip(msg)
822
823def _parse_guards(guards):
824 # Returns a tuple ({platform_name: run_me}, default_value)
825 if not guards:
826 return ({'cpython': True}, False)
Eric Smith886b40a2009-04-26 21:26:45 +0000827 is_true = list(guards.values())[0]
828 assert list(guards.values()) == [is_true] * len(guards) # all True or all False
Benjamin Petersone549ead2009-03-28 21:42:05 +0000829 return (guards, not is_true)
830
831# Use the following check to guard CPython's implementation-specific tests --
832# or to run them only on the implementation(s) guarded by the arguments.
833def check_impl_detail(**guards):
834 """This function returns True or False depending on the host platform.
835 Examples:
836 if check_impl_detail(): # only on CPython (default)
837 if check_impl_detail(jython=True): # only on Jython
838 if check_impl_detail(cpython=False): # everywhere except on CPython
839 """
840 guards, default = _parse_guards(guards)
841 return guards.get(platform.python_implementation().lower(), default)
842
843
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000844
Guido van Rossumd8faa362007-04-27 19:54:29 +0000845def _run_suite(suite):
Barry Warsawc88425e2001-09-20 06:31:22 +0000846 """Run tests from a unittest.TestSuite-derived class."""
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000847 if verbose:
Fred Drake84a59342001-03-23 04:21:17 +0000848 runner = unittest.TextTestRunner(sys.stdout, verbosity=2)
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000849 else:
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000850 runner = BasicTestRunner()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000851
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000852 result = runner.run(suite)
853 if not result.wasSuccessful():
Fred Drake14f6c182001-07-16 18:51:32 +0000854 if len(result.errors) == 1 and not result.failures:
855 err = result.errors[0][1]
856 elif len(result.failures) == 1 and not result.errors:
857 err = result.failures[0][1]
858 else:
Guido van Rossum8ce8a782007-11-01 19:42:39 +0000859 err = "errors occurred; run in verbose mode for details"
Tim Peters2d84f2c2001-09-08 03:37:56 +0000860 raise TestFailed(err)
Tim Petersa0a62222001-09-09 06:12:01 +0000861
Barry Warsawc10d6902001-09-20 06:30:41 +0000862
Walter Dörwald21d3a322003-05-01 17:45:56 +0000863def run_unittest(*classes):
864 """Run tests from unittest.TestCase-derived classes."""
Guido van Rossumd8faa362007-04-27 19:54:29 +0000865 valid_types = (unittest.TestSuite, unittest.TestCase)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000866 suite = unittest.TestSuite()
Walter Dörwald21d3a322003-05-01 17:45:56 +0000867 for cls in classes:
Guido van Rossum3172c5d2007-10-16 18:12:55 +0000868 if isinstance(cls, str):
Guido van Rossumd8faa362007-04-27 19:54:29 +0000869 if cls in sys.modules:
870 suite.addTest(unittest.findTestCases(sys.modules[cls]))
871 else:
872 raise ValueError("str arguments must be keys in sys.modules")
873 elif isinstance(cls, valid_types):
Raymond Hettinger21d99872003-07-16 02:59:32 +0000874 suite.addTest(cls)
875 else:
876 suite.addTest(unittest.makeSuite(cls))
Guido van Rossumd8faa362007-04-27 19:54:29 +0000877 _run_suite(suite)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000878
Barry Warsawc10d6902001-09-20 06:30:41 +0000879
Tim Petersa0a62222001-09-09 06:12:01 +0000880#=======================================================================
881# doctest driver.
882
883def run_doctest(module, verbosity=None):
Tim Peters17111f32001-10-03 04:08:26 +0000884 """Run doctest on the given module. Return (#failures, #tests).
Tim Petersa0a62222001-09-09 06:12:01 +0000885
886 If optional argument verbosity is not specified (or is None), pass
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000887 support's belief about verbosity on to doctest. Else doctest's
Tim Petersbea3fb82001-09-10 01:39:21 +0000888 usual behavior is used (it searches sys.argv for -v).
Tim Petersa0a62222001-09-09 06:12:01 +0000889 """
890
891 import doctest
892
893 if verbosity is None:
894 verbosity = verbose
895 else:
896 verbosity = None
897
Tim Peters342ca752001-09-25 19:13:20 +0000898 # Direct doctest output (normally just errors) to real stdout; doctest
899 # output shouldn't be compared by regrtest.
900 save_stdout = sys.stdout
Tim Peters8dee8092001-09-25 20:05:11 +0000901 sys.stdout = get_original_stdout()
Tim Peters342ca752001-09-25 19:13:20 +0000902 try:
903 f, t = doctest.testmod(module, verbose=verbosity)
904 if f:
905 raise TestFailed("%d of %d doctests failed" % (f, t))
906 finally:
907 sys.stdout = save_stdout
Raymond Hettinger35b34bd2003-05-17 00:58:33 +0000908 if verbose:
Georg Brandldb028442008-02-05 20:48:58 +0000909 print('doctest (%s) ... %d tests with zero failures' %
910 (module.__name__, t))
Raymond Hettinger35b34bd2003-05-17 00:58:33 +0000911 return f, t
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000912
913#=======================================================================
914# Threading support to prevent reporting refleaks when running regrtest.py -R
915
916def threading_setup():
917 import threading
918 return len(threading._active), len(threading._limbo)
919
920def threading_cleanup(num_active, num_limbo):
921 import threading
922 import time
923
924 _MAX_COUNT = 10
925 count = 0
926 while len(threading._active) != num_active and count < _MAX_COUNT:
927 count += 1
928 time.sleep(0.1)
929
930 count = 0
931 while len(threading._limbo) != num_limbo and count < _MAX_COUNT:
932 count += 1
933 time.sleep(0.1)
934
Benjamin Petersonfa0d7032009-06-01 22:42:33 +0000935def reap_threads(func):
936 @functools.wraps(func)
937 def decorator(*args):
938 key = threading_setup()
939 try:
940 return func(*args)
941 finally:
942 threading_cleanup(*key)
943 return decorator
944
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000945def reap_children():
946 """Use this function at the end of test_main() whenever sub-processes
947 are started. This will help ensure that no extra children (zombies)
948 stick around to hog resources and create problems when looking
949 for refleaks.
950 """
951
952 # Reap all our dead child processes so we don't leave zombies around.
953 # These hog resources and might be causing some of the buildbots to die.
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000954 if hasattr(os, 'waitpid'):
955 any_process = -1
956 while True:
957 try:
958 # This will raise an exception on Windows. That's ok.
959 pid, status = os.waitpid(any_process, os.WNOHANG)
960 if pid == 0:
961 break
962 except:
963 break