blob: 7b0241aacc5fe33084d4338662e6909f94a04392 [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",
Raymond Hettingerd76b9f12009-06-04 00:35:30 +000028 "time_out", "socket_peer_reset", "ioerror_peer_reset",
29 "run_with_locale",
Benjamin Peterson79e48032008-05-26 17:44:33 +000030 "set_memlimit", "bigmemtest", "bigaddrspacetest", "BasicTestRunner",
31 "run_unittest", "run_doctest", "threading_setup", "threading_cleanup",
R. David Murraya21e4ca2009-03-31 23:16:50 +000032 "reap_children", "cpython_only", "check_impl_detail", "get_attribute"]
Benjamin Peterson744c2cd2008-05-26 16:26:37 +000033
Fred Drake1790dd42000-07-24 06:55:00 +000034class Error(Exception):
Fred Drake004d5e62000-10-23 17:22:08 +000035 """Base class for regression test exceptions."""
Fred Drake1790dd42000-07-24 06:55:00 +000036
37class TestFailed(Error):
Fred Drake004d5e62000-10-23 17:22:08 +000038 """Test failed."""
Fred Drake1790dd42000-07-24 06:55:00 +000039
Benjamin Petersone549ead2009-03-28 21:42:05 +000040class ResourceDenied(unittest.SkipTest):
Fred Drake9a0db072003-02-03 15:19:30 +000041 """Test skipped because it requested a disallowed resource.
42
43 This is raised when a test calls requires() for a resource that
44 has not be enabled. It is used to distinguish between expected
45 and unexpected skips.
46 """
47
Nick Coghlanfce769e2009-04-11 14:30:59 +000048@contextlib.contextmanager
49def _ignore_deprecated_imports(ignore=True):
50 """Context manager to suppress package and module deprecation
51 warnings when importing them.
52
53 If ignore is False, this context manager has no effect."""
54 if ignore:
55 with warnings.catch_warnings():
56 warnings.filterwarnings("ignore", ".+ (module|package)",
57 DeprecationWarning)
58 yield
59 else:
60 yield
61
62
Benjamin Peterson699adb92008-05-08 22:27:58 +000063def import_module(name, deprecated=False):
R. David Murraya21e4ca2009-03-31 23:16:50 +000064 """Import and return the module to be tested, raising SkipTest if
65 it is not available.
66
67 If deprecated is True, any module or package deprecation messages
68 will be suppressed."""
Nick Coghlanfce769e2009-04-11 14:30:59 +000069 with _ignore_deprecated_imports(deprecated):
Benjamin Peterson699adb92008-05-08 22:27:58 +000070 try:
Nick Coghlanfce769e2009-04-11 14:30:59 +000071 return importlib.import_module(name)
R. David Murraya21e4ca2009-03-31 23:16:50 +000072 except ImportError as msg:
73 raise unittest.SkipTest(str(msg))
Nick Coghlanfce769e2009-04-11 14:30:59 +000074
75
Nick Coghlan47384702009-04-22 16:13:36 +000076def _save_and_remove_module(name, orig_modules):
77 """Helper function to save and remove a module from sys.modules
78
79 Return value is True if the module was in sys.modules and
80 False otherwise."""
81 saved = True
82 try:
83 orig_modules[name] = sys.modules[name]
84 except KeyError:
85 saved = False
86 else:
87 del sys.modules[name]
88 return saved
89
90
91def _save_and_block_module(name, orig_modules):
92 """Helper function to save and block a module in sys.modules
93
94 Return value is True if the module was in sys.modules and
95 False otherwise."""
96 saved = True
97 try:
98 orig_modules[name] = sys.modules[name]
99 except KeyError:
100 saved = False
101 sys.modules[name] = 0
102 return saved
103
104
105def import_fresh_module(name, fresh=(), blocked=(), deprecated=False):
Nick Coghlanfce769e2009-04-11 14:30:59 +0000106 """Imports and returns a module, deliberately bypassing the sys.modules cache
107 and importing a fresh copy of the module. Once the import is complete,
108 the sys.modules cache is restored to its original state.
109
Nick Coghlan47384702009-04-22 16:13:36 +0000110 Modules named in fresh are also imported anew if needed by the import.
111
112 Importing of modules named in blocked is prevented while the fresh import
Nick Coghlanfce769e2009-04-11 14:30:59 +0000113 takes place.
114
115 If deprecated is True, any module or package deprecation messages
116 will be suppressed."""
117 # NOTE: test_heapq and test_warnings include extra sanity checks to make
118 # sure that this utility function is working as expected
119 with _ignore_deprecated_imports(deprecated):
Nick Coghlan47384702009-04-22 16:13:36 +0000120 # Keep track of modules saved for later restoration as well
121 # as those which just need a blocking entry removed
Nick Coghlanfce769e2009-04-11 14:30:59 +0000122 orig_modules = {}
Nick Coghlan47384702009-04-22 16:13:36 +0000123 names_to_remove = []
124 _save_and_remove_module(name, orig_modules)
Nick Coghlanfce769e2009-04-11 14:30:59 +0000125 try:
Nick Coghlan47384702009-04-22 16:13:36 +0000126 for fresh_name in fresh:
127 _save_and_remove_module(fresh_name, orig_modules)
128 for blocked_name in blocked:
129 if not _save_and_block_module(blocked_name, orig_modules):
130 names_to_remove.append(blocked_name)
131 fresh_module = importlib.import_module(name)
Nick Coghlanfce769e2009-04-11 14:30:59 +0000132 finally:
Nick Coghlan47384702009-04-22 16:13:36 +0000133 for orig_name, module in orig_modules.items():
134 sys.modules[orig_name] = module
135 for name_to_remove in names_to_remove:
136 del sys.modules[name_to_remove]
137 return fresh_module
Nick Coghlanfce769e2009-04-11 14:30:59 +0000138
Benjamin Peterson699adb92008-05-08 22:27:58 +0000139
R. David Murraya21e4ca2009-03-31 23:16:50 +0000140def get_attribute(obj, name):
141 """Get an attribute, raising SkipTest if AttributeError is raised."""
142 try:
143 attribute = getattr(obj, name)
144 except AttributeError:
145 raise unittest.SkipTest("module %s has no attribute %s" % (
146 obj.__name__, name))
147 else:
148 return attribute
149
Barry Warsawc0fb6052001-08-20 22:29:23 +0000150verbose = 1 # Flag set to 0 by regrtest.py
Thomas Wouters477c8d52006-05-27 19:21:47 +0000151use_resources = None # Flag set to [] by regrtest.py
152max_memuse = 0 # Disable bigmem tests (they will still be run with
153 # small sizes, to make sure they work.)
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000154real_max_memuse = 0
Guido van Rossum531661c1996-12-20 02:58:22 +0000155
Tim Peters8dee8092001-09-25 20:05:11 +0000156# _original_stdout is meant to hold stdout at the time regrtest began.
157# This may be "the real" stdout, or IDLE's emulation of stdout, or whatever.
158# The point is to have some flavor of stdout the user can actually see.
159_original_stdout = None
160def record_original_stdout(stdout):
161 global _original_stdout
162 _original_stdout = stdout
163
164def get_original_stdout():
165 return _original_stdout or sys.stdout
166
Guido van Rossum3bead091992-01-27 17:00:37 +0000167def unload(name):
Fred Drake004d5e62000-10-23 17:22:08 +0000168 try:
169 del sys.modules[name]
170 except KeyError:
171 pass
Guido van Rossum3bead091992-01-27 17:00:37 +0000172
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000173def unlink(filename):
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000174 try:
175 os.unlink(filename)
176 except OSError:
177 pass
178
Christian Heimes23daade02008-02-25 12:39:23 +0000179def rmtree(path):
180 try:
181 shutil.rmtree(path)
182 except OSError as e:
183 # Unix returns ENOENT, Windows returns ESRCH.
184 if e.errno not in (errno.ENOENT, errno.ESRCH):
185 raise
186
Guido van Rossum3bead091992-01-27 17:00:37 +0000187def forget(modname):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000188 '''"Forget" a module was ever imported by removing it from sys.modules and
189 deleting any .pyc and .pyo files.'''
Fred Drake004d5e62000-10-23 17:22:08 +0000190 unload(modname)
Fred Drake004d5e62000-10-23 17:22:08 +0000191 for dirname in sys.path:
Skip Montanaro7a98be22007-08-16 14:35:24 +0000192 unlink(os.path.join(dirname, modname + '.pyc'))
Brett Cannonf1cfb622003-05-04 21:15:27 +0000193 # Deleting the .pyo file cannot be within the 'try' for the .pyc since
194 # the chance exists that there is no .pyc (and thus the 'try' statement
195 # is exited) but there is a .pyo file.
Skip Montanaro7a98be22007-08-16 14:35:24 +0000196 unlink(os.path.join(dirname, modname + '.pyo'))
Guido van Rossum3bead091992-01-27 17:00:37 +0000197
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000198def is_resource_enabled(resource):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000199 """Test whether a resource is enabled. Known resources are set by
200 regrtest.py."""
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000201 return use_resources is not None and resource in use_resources
202
Barry Warsawc0fb6052001-08-20 22:29:23 +0000203def requires(resource, msg=None):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000204 """Raise ResourceDenied if the specified resource is not available.
205
206 If the caller's module is __main__ then automatically return True. The
207 possibility of False being returned occurs when regrtest.py is executing."""
Skip Montanarod839ecd2003-04-24 19:06:57 +0000208 # see if the caller's module is __main__ - if so, treat as if
209 # the resource was set
Benjamin Petersone549ead2009-03-28 21:42:05 +0000210 if sys._getframe(1).f_globals.get("__name__") == "__main__":
Skip Montanarod839ecd2003-04-24 19:06:57 +0000211 return
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000212 if not is_resource_enabled(resource):
Barry Warsawc0fb6052001-08-20 22:29:23 +0000213 if msg is None:
214 msg = "Use of the `%s' resource not enabled" % resource
Fred Drake9a0db072003-02-03 15:19:30 +0000215 raise ResourceDenied(msg)
Barry Warsawc0fb6052001-08-20 22:29:23 +0000216
Christian Heimes5e696852008-04-09 08:37:03 +0000217HOST = 'localhost'
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000218
Christian Heimes5e696852008-04-09 08:37:03 +0000219def find_unused_port(family=socket.AF_INET, socktype=socket.SOCK_STREAM):
220 """Returns an unused port that should be suitable for binding. This is
221 achieved by creating a temporary socket with the same family and type as
222 the 'sock' parameter (default is AF_INET, SOCK_STREAM), and binding it to
223 the specified host address (defaults to 0.0.0.0) with the port set to 0,
224 eliciting an unused ephemeral port from the OS. The temporary socket is
225 then closed and deleted, and the ephemeral port is returned.
226
227 Either this method or bind_port() should be used for any tests where a
228 server socket needs to be bound to a particular port for the duration of
229 the test. Which one to use depends on whether the calling code is creating
230 a python socket, or if an unused port needs to be provided in a constructor
231 or passed to an external program (i.e. the -accept argument to openssl's
232 s_server mode). Always prefer bind_port() over find_unused_port() where
233 possible. Hard coded ports should *NEVER* be used. As soon as a server
234 socket is bound to a hard coded port, the ability to run multiple instances
235 of the test simultaneously on the same host is compromised, which makes the
236 test a ticking time bomb in a buildbot environment. On Unix buildbots, this
237 may simply manifest as a failed test, which can be recovered from without
238 intervention in most cases, but on Windows, the entire python process can
239 completely and utterly wedge, requiring someone to log in to the buildbot
240 and manually kill the affected process.
241
242 (This is easy to reproduce on Windows, unfortunately, and can be traced to
243 the SO_REUSEADDR socket option having different semantics on Windows versus
244 Unix/Linux. On Unix, you can't have two AF_INET SOCK_STREAM sockets bind,
245 listen and then accept connections on identical host/ports. An EADDRINUSE
246 socket.error will be raised at some point (depending on the platform and
247 the order bind and listen were called on each socket).
248
249 However, on Windows, if SO_REUSEADDR is set on the sockets, no EADDRINUSE
250 will ever be raised when attempting to bind two identical host/ports. When
251 accept() is called on each socket, the second caller's process will steal
252 the port from the first caller, leaving them both in an awkwardly wedged
253 state where they'll no longer respond to any signals or graceful kills, and
254 must be forcibly killed via OpenProcess()/TerminateProcess().
255
256 The solution on Windows is to use the SO_EXCLUSIVEADDRUSE socket option
257 instead of SO_REUSEADDR, which effectively affords the same semantics as
258 SO_REUSEADDR on Unix. Given the propensity of Unix developers in the Open
259 Source world compared to Windows ones, this is a common mistake. A quick
260 look over OpenSSL's 0.9.8g source shows that they use SO_REUSEADDR when
261 openssl.exe is called with the 's_server' option, for example. See
262 http://bugs.python.org/issue2550 for more info. The following site also
263 has a very thorough description about the implications of both REUSEADDR
264 and EXCLUSIVEADDRUSE on Windows:
265 http://msdn2.microsoft.com/en-us/library/ms740621(VS.85).aspx)
266
267 XXX: although this approach is a vast improvement on previous attempts to
268 elicit unused ports, it rests heavily on the assumption that the ephemeral
269 port returned to us by the OS won't immediately be dished back out to some
270 other process when we close and delete our temporary socket but before our
271 calling code has a chance to bind the returned port. We can deal with this
272 issue if/when we come across it.
273 """
274
275 tempsock = socket.socket(family, socktype)
276 port = bind_port(tempsock)
277 tempsock.close()
278 del tempsock
279 return port
280
281def bind_port(sock, host=HOST):
282 """Bind the socket to a free port and return the port number. Relies on
283 ephemeral ports in order to ensure we are using an unbound port. This is
284 important as many tests may be running simultaneously, especially in a
285 buildbot environment. This method raises an exception if the sock.family
286 is AF_INET and sock.type is SOCK_STREAM, *and* the socket has SO_REUSEADDR
287 or SO_REUSEPORT set on it. Tests should *never* set these socket options
288 for TCP/IP sockets. The only case for setting these options is testing
289 multicasting via multiple UDP sockets.
290
291 Additionally, if the SO_EXCLUSIVEADDRUSE socket option is available (i.e.
292 on Windows), it will be set on the socket. This will prevent anyone else
293 from bind()'ing to our host/port for the duration of the test.
294 """
295
296 if sock.family == socket.AF_INET and sock.type == socket.SOCK_STREAM:
297 if hasattr(socket, 'SO_REUSEADDR'):
298 if sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR) == 1:
299 raise TestFailed("tests should never set the SO_REUSEADDR " \
300 "socket option on TCP/IP sockets!")
301 if hasattr(socket, 'SO_REUSEPORT'):
302 if sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEPORT) == 1:
303 raise TestFailed("tests should never set the SO_REUSEPORT " \
304 "socket option on TCP/IP sockets!")
305 if hasattr(socket, 'SO_EXCLUSIVEADDRUSE'):
306 sock.setsockopt(socket.SOL_SOCKET, socket.SO_EXCLUSIVEADDRUSE, 1)
307
308 sock.bind((host, 0))
309 port = sock.getsockname()[1]
310 return port
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000311
Guido van Rossum35fb82a1993-01-26 13:04:43 +0000312FUZZ = 1e-6
313
314def fcmp(x, y): # fuzzy comparison function
Neal Norwitz79212992006-08-21 16:27:31 +0000315 if isinstance(x, float) or isinstance(y, float):
Fred Drake004d5e62000-10-23 17:22:08 +0000316 try:
Fred Drake004d5e62000-10-23 17:22:08 +0000317 fuzz = (abs(x) + abs(y)) * FUZZ
318 if abs(x-y) <= fuzz:
319 return 0
320 except:
321 pass
Neal Norwitz79212992006-08-21 16:27:31 +0000322 elif type(x) == type(y) and isinstance(x, (tuple, list)):
Fred Drake004d5e62000-10-23 17:22:08 +0000323 for i in range(min(len(x), len(y))):
324 outcome = fcmp(x[i], y[i])
Fred Drake132dce22000-12-12 23:11:42 +0000325 if outcome != 0:
Fred Drake004d5e62000-10-23 17:22:08 +0000326 return outcome
Guido van Rossum47b9ff62006-08-24 00:41:19 +0000327 return (len(x) > len(y)) - (len(x) < len(y))
328 return (x > y) - (x < y)
Guido van Rossum35fb82a1993-01-26 13:04:43 +0000329
Finn Bock57bc5fa2002-11-01 18:02:03 +0000330is_jython = sys.platform.startswith('java')
331
Barry Warsaw559f6682001-03-23 18:04:02 +0000332# Filename used for testing
333if os.name == 'java':
334 # Jython disallows @ in module names
335 TESTFN = '$test'
Martin v. Löwisa94568a2003-05-10 07:36:56 +0000336else:
Barry Warsaw559f6682001-03-23 18:04:02 +0000337 TESTFN = '@test'
Walter Dörwald9b775532007-06-08 14:30:53 +0000338
Antoine Pitrou88909542009-06-29 13:54:42 +0000339# Disambiguate TESTFN for parallel testing, while letting it remain a valid
340# module name.
341TESTFN = "{0}_{1}_tmp".format(TESTFN, os.getpid())
342
343# Assuming sys.getfilesystemencoding()!=sys.getdefaultencoding()
344# TESTFN_UNICODE is a filename that can be encoded using the
345# file system encoding, but *not* with the default (ascii) encoding
346TESTFN_UNICODE = TESTFN + "-\xe0\xf2"
347TESTFN_ENCODING = sys.getfilesystemencoding()
348# TESTFN_UNICODE_UNENCODEABLE is a filename that should *not* be
349# able to be encoded by *either* the default or filesystem encoding.
350# This test really only makes sense on Windows NT platforms
351# which have special Unicode support in posixmodule.
352if (not hasattr(sys, "getwindowsversion") or
353 sys.getwindowsversion()[3] < 2): # 0=win32s or 1=9x/ME
354 TESTFN_UNICODE_UNENCODEABLE = None
355else:
356 # Japanese characters (I think - from bug 846133)
357 TESTFN_UNICODE_UNENCODEABLE = TESTFN + "-\u5171\u6709\u3055\u308c\u308b"
358 try:
359 # XXX - Note - should be using TESTFN_ENCODING here - but for
360 # Windows, "mbcs" currently always operates as if in
361 # errors=ignore' mode - hence we get '?' characters rather than
362 # the exception. 'Latin1' operates as we expect - ie, fails.
363 # See [ 850997 ] mbcs encoding ignores errors
364 TESTFN_UNICODE_UNENCODEABLE.encode("Latin1")
365 except UnicodeEncodeError:
366 pass
Walter Dörwald9b775532007-06-08 14:30:53 +0000367 else:
Antoine Pitrou88909542009-06-29 13:54:42 +0000368 print('WARNING: The filename %r CAN be encoded by the filesystem. '
369 'Unicode filename tests may not be effective'
370 % TESTFN_UNICODE_UNENCODEABLE)
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000371
372# Make sure we can write to TESTFN, try in /tmp if we can't
373fp = None
374try:
375 fp = open(TESTFN, 'w+')
376except IOError:
377 TMP_TESTFN = os.path.join('/tmp', TESTFN)
378 try:
379 fp = open(TMP_TESTFN, 'w+')
380 TESTFN = TMP_TESTFN
381 del TMP_TESTFN
382 except IOError:
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000383 print(('WARNING: tests will fail, unable to write to: %s or %s' %
384 (TESTFN, TMP_TESTFN)))
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000385if fp is not None:
386 fp.close()
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000387 unlink(TESTFN)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000388del fp
Guido van Rossuma8f7e592001-03-13 09:31:07 +0000389
Guido van Rossume26132c1998-04-23 20:13:30 +0000390def findfile(file, here=__file__):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000391 """Try to find a file on sys.path and the working directory. If it is not
392 found the argument passed to the function is returned (this does not
393 necessarily signal failure; could still be the legitimate path)."""
Fred Drake004d5e62000-10-23 17:22:08 +0000394 if os.path.isabs(file):
395 return file
Fred Drake004d5e62000-10-23 17:22:08 +0000396 path = sys.path
397 path = [os.path.dirname(here)] + path
398 for dn in path:
399 fn = os.path.join(dn, file)
400 if os.path.exists(fn): return fn
401 return file
Marc-André Lemburg36619082001-01-17 19:11:13 +0000402
403def verify(condition, reason='test failed'):
Guido van Rossuma1374e42001-01-19 19:01:56 +0000404 """Verify that condition is true. If not, raise TestFailed.
Marc-André Lemburg36619082001-01-17 19:11:13 +0000405
Skip Montanaroc955f892001-01-20 19:12:54 +0000406 The optional argument reason can be given to provide
Tim Peters983874d2001-01-19 05:59:21 +0000407 a better error text.
Tim Petersd2bf3b72001-01-18 02:22:22 +0000408 """
Tim Peters983874d2001-01-19 05:59:21 +0000409
Tim Petersd2bf3b72001-01-18 02:22:22 +0000410 if not condition:
Guido van Rossuma1374e42001-01-19 19:01:56 +0000411 raise TestFailed(reason)
Jeremy Hylton47793992001-02-19 15:35:26 +0000412
Tim Petersc2fe6182001-10-30 23:20:46 +0000413def vereq(a, b):
Tim Peters77902972001-12-29 17:34:57 +0000414 """Raise TestFailed if a == b is false.
415
416 This is better than verify(a == b) because, in case of failure, the
417 error message incorporates repr(a) and repr(b) so you can see the
418 inputs.
419
420 Note that "not (a == b)" isn't necessarily the same as "a != b"; the
421 former is tested.
422 """
423
Tim Petersc2fe6182001-10-30 23:20:46 +0000424 if not (a == b):
Guido van Rossumd8faa362007-04-27 19:54:29 +0000425 raise TestFailed("%r == %r" % (a, b))
Tim Petersc2fe6182001-10-30 23:20:46 +0000426
Tim Peters2f228e72001-05-13 00:19:31 +0000427def sortdict(dict):
428 "Like repr(dict), but in sorted order."
Guido van Rossumcc2b0162007-02-11 06:12:03 +0000429 items = sorted(dict.items())
Tim Peters2f228e72001-05-13 00:19:31 +0000430 reprpairs = ["%r: %r" % pair for pair in items]
431 withcommas = ", ".join(reprpairs)
432 return "{%s}" % withcommas
433
Benjamin Peterson7522c742009-01-19 21:00:09 +0000434def make_bad_fd():
435 """
436 Create an invalid file descriptor by opening and closing a file and return
437 its fd.
438 """
439 file = open(TESTFN, "wb")
440 try:
441 return file.fileno()
442 finally:
443 file.close()
444 unlink(TESTFN)
445
Thomas Wouters89f507f2006-12-13 04:49:30 +0000446def check_syntax_error(testcase, statement):
Benjamin Petersone549ead2009-03-28 21:42:05 +0000447 testcase.assertRaises(SyntaxError, compile, statement,
448 '<test string>', 'exec')
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000449
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000450def open_urlresource(url, *args, **kw):
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000451 import urllib.request, urllib.parse
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000452
Guido van Rossum360e4b82007-05-14 22:51:27 +0000453 requires('urlfetch')
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000454 filename = urllib.parse.urlparse(url)[2].split('/')[-1] # '/': it's URL!
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000455
Alexandre Vassalotti711ed4a2009-07-17 10:42:05 +0000456 fn = os.path.join(os.path.dirname(__file__), "data", filename)
457 if os.path.exists(fn):
Alexandre Vassalottidf4ff082009-07-22 00:19:57 +0000458 return open(fn, *args, **kw)
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000459
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000460 print('\tfetching %s ...' % url, file=get_original_stdout())
Antoine Pitroufd0680b2009-11-01 22:13:48 +0000461 f = urllib.request.urlopen(url, timeout=15)
462 try:
463 with open(fn, "wb") as out:
464 s = f.read()
465 while s:
466 out.write(s)
467 s = f.read()
468 finally:
469 f.close()
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000470 return open(fn, *args, **kw)
Thomas Wouters9fe394c2007-02-05 01:24:16 +0000471
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000472class WarningsRecorder(object):
473 """Convenience wrapper for the warnings list returned on
474 entry to the warnings.catch_warnings() context manager.
Guido van Rossumd8faa362007-04-27 19:54:29 +0000475 """
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000476 def __init__(self, warnings_list):
477 self.warnings = warnings_list
478
479 def __getattr__(self, attr):
480 if self.warnings:
481 return getattr(self.warnings[-1], attr)
482 elif attr in warnings.WarningMessage._WARNING_DETAILS:
483 return None
484 raise AttributeError("%r has no attribute %r" % (self, attr))
485
486 def reset(self):
487 del self.warnings[:]
488
489@contextlib.contextmanager
490def check_warnings():
491 with warnings.catch_warnings(record=True) as w:
492 yield WarningsRecorder(w)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000493
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000494
495class CleanImport(object):
496 """Context manager to force import to return a new module reference.
497
498 This is useful for testing module-level behaviours, such as
Nick Coghlanb1304932008-07-13 12:25:08 +0000499 the emission of a DeprecationWarning on import.
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000500
501 Use like this:
502
503 with CleanImport("foo"):
504 __import__("foo") # new reference
505 """
506
507 def __init__(self, *module_names):
508 self.original_modules = sys.modules.copy()
509 for module_name in module_names:
510 if module_name in sys.modules:
511 module = sys.modules[module_name]
512 # It is possible that module_name is just an alias for
513 # another module (e.g. stub for modules renamed in 3.x).
514 # In that case, we also need delete the real module to clear
515 # the import cache.
516 if module.__name__ != module_name:
517 del sys.modules[module.__name__]
518 del sys.modules[module_name]
519
520 def __enter__(self):
521 return self
522
523 def __exit__(self, *ignore_exc):
524 sys.modules.update(self.original_modules)
525
526
Walter Dörwald155374d2009-05-01 19:58:58 +0000527class EnvironmentVarGuard(collections.MutableMapping):
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000528
529 """Class to help protect the environment variable properly. Can be used as
530 a context manager."""
531
532 def __init__(self):
Walter Dörwald155374d2009-05-01 19:58:58 +0000533 self._environ = os.environ
Walter Dörwald4ba80132009-04-25 12:48:43 +0000534 self._changed = {}
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000535
Walter Dörwald155374d2009-05-01 19:58:58 +0000536 def __getitem__(self, envvar):
537 return self._environ[envvar]
538
539 def __setitem__(self, envvar, value):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000540 # Remember the initial value on the first access
541 if envvar not in self._changed:
Walter Dörwald155374d2009-05-01 19:58:58 +0000542 self._changed[envvar] = self._environ.get(envvar)
543 self._environ[envvar] = value
544
545 def __delitem__(self, envvar):
546 # Remember the initial value on the first access
547 if envvar not in self._changed:
548 self._changed[envvar] = self._environ.get(envvar)
549 if envvar in self._environ:
550 del self._environ[envvar]
551
552 def keys(self):
553 return self._environ.keys()
554
555 def __iter__(self):
556 return iter(self._environ)
557
558 def __len__(self):
559 return len(self._environ)
560
561 def set(self, envvar, value):
562 self[envvar] = value
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000563
564 def unset(self, envvar):
Walter Dörwald155374d2009-05-01 19:58:58 +0000565 del self[envvar]
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000566
567 def __enter__(self):
568 return self
569
570 def __exit__(self, *ignore_exc):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000571 for (k, v) in self._changed.items():
572 if v is None:
Walter Dörwald155374d2009-05-01 19:58:58 +0000573 if k in self._environ:
574 del self._environ[k]
Walter Dörwald4ba80132009-04-25 12:48:43 +0000575 else:
Walter Dörwald155374d2009-05-01 19:58:58 +0000576 self._environ[k] = v
Nick Coghlan6ead5522009-10-18 13:19:33 +0000577 os.environ = self._environ
578
579
580class DirsOnSysPath(object):
581 """Context manager to temporarily add directories to sys.path.
582
583 This makes a copy of sys.path, appends any directories given
584 as positional arguments, then reverts sys.path to the copied
585 settings when the context ends.
586
587 Note that *all* sys.path modifications in the body of the
588 context manager, including replacement of the object,
589 will be reverted at the end of the block.
590 """
591
592 def __init__(self, *paths):
593 self.original_value = sys.path[:]
594 self.original_object = sys.path
595 sys.path.extend(paths)
596
597 def __enter__(self):
598 return self
599
600 def __exit__(self, *ignore_exc):
601 sys.path = self.original_object
602 sys.path[:] = self.original_value
Walter Dörwald155374d2009-05-01 19:58:58 +0000603
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000604
Guido van Rossumd8faa362007-04-27 19:54:29 +0000605class TransientResource(object):
606
607 """Raise ResourceDenied if an exception is raised while the context manager
608 is in effect that matches the specified exception and attributes."""
609
610 def __init__(self, exc, **kwargs):
611 self.exc = exc
612 self.attrs = kwargs
613
614 def __enter__(self):
615 return self
616
617 def __exit__(self, type_=None, value=None, traceback=None):
618 """If type_ is a subclass of self.exc and value has attributes matching
619 self.attrs, raise ResourceDenied. Otherwise let the exception
620 propagate (if any)."""
621 if type_ is not None and issubclass(self.exc, type_):
622 for attr, attr_value in self.attrs.items():
623 if not hasattr(value, attr):
624 break
625 if getattr(value, attr) != attr_value:
626 break
627 else:
628 raise ResourceDenied("an optional resource is not available")
629
630
Raymond Hettinger686057b2009-06-04 00:11:54 +0000631# Context managers that raise ResourceDenied when various issues
632# with the Internet connection manifest themselves as exceptions.
633time_out = TransientResource(IOError, errno=errno.ETIMEDOUT)
634socket_peer_reset = TransientResource(socket.error, errno=errno.ECONNRESET)
635ioerror_peer_reset = TransientResource(IOError, errno=errno.ECONNRESET)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000636
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000637
Thomas Woutersed03b412007-08-28 21:37:11 +0000638@contextlib.contextmanager
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000639def captured_output(stream_name):
640 """Run the 'with' statement body using a StringIO object in place of a
641 specific attribute on the sys module.
642 Example use (with 'stream_name=stdout')::
Thomas Woutersed03b412007-08-28 21:37:11 +0000643
644 with captured_stdout() as s:
Neal Norwitz752abd02008-05-13 04:55:24 +0000645 print("hello")
Thomas Woutersed03b412007-08-28 21:37:11 +0000646 assert s.getvalue() == "hello"
647 """
648 import io
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000649 orig_stdout = getattr(sys, stream_name)
650 setattr(sys, stream_name, io.StringIO())
Christian Heimes81ee3ef2008-05-04 22:42:01 +0000651 try:
652 yield getattr(sys, stream_name)
653 finally:
654 setattr(sys, stream_name, orig_stdout)
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000655
656def captured_stdout():
657 return captured_output("stdout")
Thomas Woutersed03b412007-08-28 21:37:11 +0000658
Nick Coghlan6ead5522009-10-18 13:19:33 +0000659def captured_stdin():
660 return captured_output("stdin")
661
Benjamin Petersone549ead2009-03-28 21:42:05 +0000662def gc_collect():
663 """Force as many objects as possible to be collected.
664
665 In non-CPython implementations of Python, this is needed because timely
666 deallocation is not guaranteed by the garbage collector. (Even in CPython
667 this can be the case in case of reference cycles.) This means that __del__
668 methods may be called later than expected and weakrefs may remain alive for
669 longer than expected. This function tries its best to force all garbage
670 objects to disappear.
671 """
Benjamin Petersone549ead2009-03-28 21:42:05 +0000672 gc.collect()
673 gc.collect()
674 gc.collect()
675
Thomas Woutersed03b412007-08-28 21:37:11 +0000676
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000677#=======================================================================
Thomas Wouters477c8d52006-05-27 19:21:47 +0000678# Decorator for running a function in a different locale, correctly resetting
679# it afterwards.
680
681def run_with_locale(catstr, *locales):
682 def decorator(func):
683 def inner(*args, **kwds):
684 try:
685 import locale
686 category = getattr(locale, catstr)
687 orig_locale = locale.setlocale(category)
688 except AttributeError:
689 # if the test author gives us an invalid category string
690 raise
691 except:
692 # cannot retrieve original locale, so do nothing
693 locale = orig_locale = None
694 else:
695 for loc in locales:
696 try:
697 locale.setlocale(category, loc)
698 break
699 except:
700 pass
701
702 # now run the function, resetting the locale on exceptions
703 try:
704 return func(*args, **kwds)
705 finally:
706 if locale and orig_locale:
707 locale.setlocale(category, orig_locale)
Neal Norwitz221085d2007-02-25 20:55:47 +0000708 inner.__name__ = func.__name__
Thomas Wouters477c8d52006-05-27 19:21:47 +0000709 inner.__doc__ = func.__doc__
710 return inner
711 return decorator
712
713#=======================================================================
Georg Brandldb028442008-02-05 20:48:58 +0000714# Big-memory-test support. Separate from 'resources' because memory use
715# should be configurable.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000716
717# Some handy shorthands. Note that these are used for byte-limits as well
718# as size-limits, in the various bigmem tests
719_1M = 1024*1024
720_1G = 1024 * _1M
721_2G = 2 * _1G
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000722_4G = 4 * _1G
Thomas Wouters477c8d52006-05-27 19:21:47 +0000723
Thomas Woutersd2cf20e2007-08-30 22:57:53 +0000724MAX_Py_ssize_t = sys.maxsize
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000725
Thomas Wouters477c8d52006-05-27 19:21:47 +0000726def set_memlimit(limit):
727 import re
728 global max_memuse
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000729 global real_max_memuse
Thomas Wouters477c8d52006-05-27 19:21:47 +0000730 sizes = {
731 'k': 1024,
732 'm': _1M,
733 'g': _1G,
734 't': 1024*_1G,
735 }
736 m = re.match(r'(\d+(\.\d+)?) (K|M|G|T)b?$', limit,
737 re.IGNORECASE | re.VERBOSE)
738 if m is None:
739 raise ValueError('Invalid memory limit %r' % (limit,))
740 memlimit = int(float(m.group(1)) * sizes[m.group(3).lower()])
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000741 real_max_memuse = memlimit
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000742 if memlimit > MAX_Py_ssize_t:
743 memlimit = MAX_Py_ssize_t
744 if memlimit < _2G - 1:
Thomas Wouters477c8d52006-05-27 19:21:47 +0000745 raise ValueError('Memory limit %r too low to be useful' % (limit,))
746 max_memuse = memlimit
747
748def bigmemtest(minsize, memuse, overhead=5*_1M):
749 """Decorator for bigmem tests.
750
751 'minsize' is the minimum useful size for the test (in arbitrary,
752 test-interpreted units.) 'memuse' is the number of 'bytes per size' for
753 the test, or a good estimate of it. 'overhead' specifies fixed overhead,
Christian Heimes33fe8092008-04-13 13:53:33 +0000754 independent of the testsize, and defaults to 5Mb.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000755
756 The decorator tries to guess a good value for 'size' and passes it to
757 the decorated test function. If minsize * memuse is more than the
758 allowed memory use (as defined by max_memuse), the test is skipped.
759 Otherwise, minsize is adjusted upward to use up to max_memuse.
760 """
761 def decorator(f):
762 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000763 # Retrieve values in case someone decided to adjust them
764 minsize = wrapper.minsize
765 memuse = wrapper.memuse
766 overhead = wrapper.overhead
Thomas Wouters477c8d52006-05-27 19:21:47 +0000767 if not max_memuse:
768 # If max_memuse is 0 (the default),
769 # we still want to run the tests with size set to a few kb,
770 # to make sure they work. We still want to avoid using
771 # too much memory, though, but we do that noisily.
772 maxsize = 5147
Benjamin Peterson46d44402009-07-01 00:45:43 +0000773 self.assertFalse(maxsize * memuse + overhead > 20 * _1M)
Thomas Wouters477c8d52006-05-27 19:21:47 +0000774 else:
775 maxsize = int((max_memuse - overhead) / memuse)
776 if maxsize < minsize:
777 # Really ought to print 'test skipped' or something
778 if verbose:
779 sys.stderr.write("Skipping %s because of memory "
780 "constraint\n" % (f.__name__,))
781 return
782 # Try to keep some breathing room in memory use
783 maxsize = max(maxsize - 50 * _1M, minsize)
784 return f(self, maxsize)
785 wrapper.minsize = minsize
786 wrapper.memuse = memuse
787 wrapper.overhead = overhead
788 return wrapper
789 return decorator
790
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000791def precisionbigmemtest(size, memuse, overhead=5*_1M):
792 def decorator(f):
793 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000794 size = wrapper.size
795 memuse = wrapper.memuse
796 overhead = wrapper.overhead
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000797 if not real_max_memuse:
798 maxsize = 5147
799 else:
800 maxsize = size
801
802 if real_max_memuse and real_max_memuse < maxsize * memuse:
803 if verbose:
804 sys.stderr.write("Skipping %s because of memory "
805 "constraint\n" % (f.__name__,))
806 return
807
808 return f(self, maxsize)
809 wrapper.size = size
810 wrapper.memuse = memuse
811 wrapper.overhead = overhead
812 return wrapper
813 return decorator
814
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000815def bigaddrspacetest(f):
816 """Decorator for tests that fill the address space."""
817 def wrapper(self):
818 if max_memuse < MAX_Py_ssize_t:
819 if verbose:
820 sys.stderr.write("Skipping %s because of memory "
821 "constraint\n" % (f.__name__,))
822 else:
823 return f(self)
824 return wrapper
825
Thomas Wouters477c8d52006-05-27 19:21:47 +0000826#=======================================================================
Guido van Rossumd8faa362007-04-27 19:54:29 +0000827# unittest integration.
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000828
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000829class BasicTestRunner:
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000830 def run(self, test):
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000831 result = unittest.TestResult()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000832 test(result)
833 return result
834
Benjamin Petersone549ead2009-03-28 21:42:05 +0000835def _id(obj):
836 return obj
837
838def requires_resource(resource):
839 if resource_is_enabled(resource):
840 return _id
841 else:
842 return unittest.skip("resource {0!r} is not enabled".format(resource))
843
844def cpython_only(test):
845 """
846 Decorator for tests only applicable on CPython.
847 """
848 return impl_detail(cpython=True)(test)
849
850def impl_detail(msg=None, **guards):
851 if check_impl_detail(**guards):
852 return _id
853 if msg is None:
854 guardnames, default = _parse_guards(guards)
855 if default:
856 msg = "implementation detail not available on {0}"
857 else:
858 msg = "implementation detail specific to {0}"
859 guardnames = sorted(guardnames.keys())
860 msg = msg.format(' or '.join(guardnames))
861 return unittest.skip(msg)
862
863def _parse_guards(guards):
864 # Returns a tuple ({platform_name: run_me}, default_value)
865 if not guards:
866 return ({'cpython': True}, False)
Eric Smith886b40a2009-04-26 21:26:45 +0000867 is_true = list(guards.values())[0]
868 assert list(guards.values()) == [is_true] * len(guards) # all True or all False
Benjamin Petersone549ead2009-03-28 21:42:05 +0000869 return (guards, not is_true)
870
871# Use the following check to guard CPython's implementation-specific tests --
872# or to run them only on the implementation(s) guarded by the arguments.
873def check_impl_detail(**guards):
874 """This function returns True or False depending on the host platform.
875 Examples:
876 if check_impl_detail(): # only on CPython (default)
877 if check_impl_detail(jython=True): # only on Jython
878 if check_impl_detail(cpython=False): # everywhere except on CPython
879 """
880 guards, default = _parse_guards(guards)
881 return guards.get(platform.python_implementation().lower(), default)
882
883
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000884
Guido van Rossumd8faa362007-04-27 19:54:29 +0000885def _run_suite(suite):
Barry Warsawc88425e2001-09-20 06:31:22 +0000886 """Run tests from a unittest.TestSuite-derived class."""
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000887 if verbose:
Fred Drake84a59342001-03-23 04:21:17 +0000888 runner = unittest.TextTestRunner(sys.stdout, verbosity=2)
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000889 else:
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000890 runner = BasicTestRunner()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000891
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000892 result = runner.run(suite)
893 if not result.wasSuccessful():
Fred Drake14f6c182001-07-16 18:51:32 +0000894 if len(result.errors) == 1 and not result.failures:
895 err = result.errors[0][1]
896 elif len(result.failures) == 1 and not result.errors:
897 err = result.failures[0][1]
898 else:
R. David Murray723357e2009-10-19 18:06:17 +0000899 err = "multiple errors occurred"
900 if not verbose: err += "; run in verbose mode for details"
Tim Peters2d84f2c2001-09-08 03:37:56 +0000901 raise TestFailed(err)
Tim Petersa0a62222001-09-09 06:12:01 +0000902
Barry Warsawc10d6902001-09-20 06:30:41 +0000903
Walter Dörwald21d3a322003-05-01 17:45:56 +0000904def run_unittest(*classes):
905 """Run tests from unittest.TestCase-derived classes."""
Guido van Rossumd8faa362007-04-27 19:54:29 +0000906 valid_types = (unittest.TestSuite, unittest.TestCase)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000907 suite = unittest.TestSuite()
Walter Dörwald21d3a322003-05-01 17:45:56 +0000908 for cls in classes:
Guido van Rossum3172c5d2007-10-16 18:12:55 +0000909 if isinstance(cls, str):
Guido van Rossumd8faa362007-04-27 19:54:29 +0000910 if cls in sys.modules:
911 suite.addTest(unittest.findTestCases(sys.modules[cls]))
912 else:
913 raise ValueError("str arguments must be keys in sys.modules")
914 elif isinstance(cls, valid_types):
Raymond Hettinger21d99872003-07-16 02:59:32 +0000915 suite.addTest(cls)
916 else:
917 suite.addTest(unittest.makeSuite(cls))
Guido van Rossumd8faa362007-04-27 19:54:29 +0000918 _run_suite(suite)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000919
Barry Warsawc10d6902001-09-20 06:30:41 +0000920
Tim Petersa0a62222001-09-09 06:12:01 +0000921#=======================================================================
922# doctest driver.
923
924def run_doctest(module, verbosity=None):
Tim Peters17111f32001-10-03 04:08:26 +0000925 """Run doctest on the given module. Return (#failures, #tests).
Tim Petersa0a62222001-09-09 06:12:01 +0000926
927 If optional argument verbosity is not specified (or is None), pass
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000928 support's belief about verbosity on to doctest. Else doctest's
Tim Petersbea3fb82001-09-10 01:39:21 +0000929 usual behavior is used (it searches sys.argv for -v).
Tim Petersa0a62222001-09-09 06:12:01 +0000930 """
931
932 import doctest
933
934 if verbosity is None:
935 verbosity = verbose
936 else:
937 verbosity = None
938
Tim Peters342ca752001-09-25 19:13:20 +0000939 # Direct doctest output (normally just errors) to real stdout; doctest
940 # output shouldn't be compared by regrtest.
941 save_stdout = sys.stdout
Tim Peters8dee8092001-09-25 20:05:11 +0000942 sys.stdout = get_original_stdout()
Tim Peters342ca752001-09-25 19:13:20 +0000943 try:
944 f, t = doctest.testmod(module, verbose=verbosity)
945 if f:
946 raise TestFailed("%d of %d doctests failed" % (f, t))
947 finally:
948 sys.stdout = save_stdout
Raymond Hettinger35b34bd2003-05-17 00:58:33 +0000949 if verbose:
Georg Brandldb028442008-02-05 20:48:58 +0000950 print('doctest (%s) ... %d tests with zero failures' %
951 (module.__name__, t))
Raymond Hettinger35b34bd2003-05-17 00:58:33 +0000952 return f, t
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000953
Antoine Pitrou060cee22009-11-13 16:29:04 +0000954
955#=======================================================================
956# Support for saving and restoring the imported modules.
957
958def modules_setup():
959 return sys.modules.copy(),
960
961def modules_cleanup(oldmodules):
962 # Encoders/decoders are registered permanently within the internal
963 # codec cache. If we destroy the corresponding modules their
964 # globals will be set to None which will trip up the cached functions.
965 encodings = [(k, v) for k, v in sys.modules.items()
966 if k.startswith('encodings.')]
967 sys.modules.clear()
968 sys.modules.update(encodings)
969 sys.modules.update(oldmodules)
970
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000971#=======================================================================
972# Threading support to prevent reporting refleaks when running regrtest.py -R
973
Antoine Pitrou65c9c642009-10-30 17:25:12 +0000974# NOTE: we use thread._count() rather than threading.enumerate() (or the
975# moral equivalent thereof) because a threading.Thread object is still alive
976# until its __bootstrap() method has returned, even after it has been
977# unregistered from the threading module.
978# thread._count(), on the other hand, only gets decremented *after* the
979# __bootstrap() method has returned, which gives us reliable reference counts
980# at the end of a test run.
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000981
Antoine Pitrou65c9c642009-10-30 17:25:12 +0000982def threading_setup():
983 import _thread
984 return _thread._count(),
985
986def threading_cleanup(nb_threads):
987 import _thread
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000988 import time
989
990 _MAX_COUNT = 10
Antoine Pitrou65c9c642009-10-30 17:25:12 +0000991 for count in range(_MAX_COUNT):
992 n = _thread._count()
993 if n == nb_threads:
994 break
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000995 time.sleep(0.1)
Antoine Pitrou65c9c642009-10-30 17:25:12 +0000996 # XXX print a warning in case of failure?
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000997
Benjamin Petersonfa0d7032009-06-01 22:42:33 +0000998def reap_threads(func):
999 @functools.wraps(func)
1000 def decorator(*args):
1001 key = threading_setup()
1002 try:
1003 return func(*args)
1004 finally:
1005 threading_cleanup(*key)
1006 return decorator
1007
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001008def reap_children():
1009 """Use this function at the end of test_main() whenever sub-processes
1010 are started. This will help ensure that no extra children (zombies)
1011 stick around to hog resources and create problems when looking
1012 for refleaks.
1013 """
1014
1015 # Reap all our dead child processes so we don't leave zombies around.
1016 # These hog resources and might be causing some of the buildbots to die.
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001017 if hasattr(os, 'waitpid'):
1018 any_process = -1
1019 while True:
1020 try:
1021 # This will raise an exception on Windows. That's ok.
1022 pid, status = os.waitpid(any_process, os.WNOHANG)
1023 if pid == 0:
1024 break
1025 except:
1026 break