blob: 34005e857ebf19ec0fabda6e0ea159e2ce089e00 [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
Antoine Pitrou4d7979b2010-09-07 21:22:56 +000020__all__ = [
21 "Error", "TestFailed", "ResourceDenied", "import_module",
22 "verbose", "use_resources", "max_memuse", "record_original_stdout",
23 "get_original_stdout", "unload", "unlink", "rmtree", "forget",
24 "is_resource_enabled", "requires", "find_unused_port", "bind_port",
25 "fcmp", "is_jython", "TESTFN", "HOST", "FUZZ", "findfile", "verify",
26 "vereq", "sortdict", "check_syntax_error", "open_urlresource",
27 "check_warnings", "CleanImport", "EnvironmentVarGuard",
28 "TransientResource", "captured_output", "captured_stdout",
29 "time_out", "socket_peer_reset", "ioerror_peer_reset",
30 "run_with_locale", "transient_internet",
31 "set_memlimit", "bigmemtest", "bigaddrspacetest", "BasicTestRunner",
32 "run_unittest", "run_doctest", "threading_setup", "threading_cleanup",
33 "reap_children", "cpython_only", "check_impl_detail", "get_attribute",
34 ]
Benjamin Peterson744c2cd2008-05-26 16:26:37 +000035
Fred Drake1790dd42000-07-24 06:55:00 +000036class Error(Exception):
Fred Drake004d5e62000-10-23 17:22:08 +000037 """Base class for regression test exceptions."""
Fred Drake1790dd42000-07-24 06:55:00 +000038
39class TestFailed(Error):
Fred Drake004d5e62000-10-23 17:22:08 +000040 """Test failed."""
Fred Drake1790dd42000-07-24 06:55:00 +000041
Benjamin Petersone549ead2009-03-28 21:42:05 +000042class ResourceDenied(unittest.SkipTest):
Fred Drake9a0db072003-02-03 15:19:30 +000043 """Test skipped because it requested a disallowed resource.
44
45 This is raised when a test calls requires() for a resource that
46 has not be enabled. It is used to distinguish between expected
47 and unexpected skips.
48 """
49
Nick Coghlanfce769e2009-04-11 14:30:59 +000050@contextlib.contextmanager
51def _ignore_deprecated_imports(ignore=True):
52 """Context manager to suppress package and module deprecation
53 warnings when importing them.
54
55 If ignore is False, this context manager has no effect."""
56 if ignore:
57 with warnings.catch_warnings():
58 warnings.filterwarnings("ignore", ".+ (module|package)",
59 DeprecationWarning)
60 yield
61 else:
62 yield
63
64
Benjamin Peterson699adb92008-05-08 22:27:58 +000065def import_module(name, deprecated=False):
R. David Murraya21e4ca2009-03-31 23:16:50 +000066 """Import and return the module to be tested, raising SkipTest if
67 it is not available.
68
69 If deprecated is True, any module or package deprecation messages
70 will be suppressed."""
Nick Coghlanfce769e2009-04-11 14:30:59 +000071 with _ignore_deprecated_imports(deprecated):
Benjamin Peterson699adb92008-05-08 22:27:58 +000072 try:
Nick Coghlanfce769e2009-04-11 14:30:59 +000073 return importlib.import_module(name)
R. David Murraya21e4ca2009-03-31 23:16:50 +000074 except ImportError as msg:
75 raise unittest.SkipTest(str(msg))
Nick Coghlanfce769e2009-04-11 14:30:59 +000076
77
Nick Coghlan47384702009-04-22 16:13:36 +000078def _save_and_remove_module(name, orig_modules):
79 """Helper function to save and remove a module from sys.modules
80
81 Return value is True if the module was in sys.modules and
82 False otherwise."""
83 saved = True
84 try:
85 orig_modules[name] = sys.modules[name]
86 except KeyError:
87 saved = False
88 else:
89 del sys.modules[name]
90 return saved
91
92
93def _save_and_block_module(name, orig_modules):
94 """Helper function to save and block a module in sys.modules
95
96 Return value is True if the module was in sys.modules and
97 False otherwise."""
98 saved = True
99 try:
100 orig_modules[name] = sys.modules[name]
101 except KeyError:
102 saved = False
Alexander Belopolsky0a5d9a22010-07-13 14:55:04 +0000103 sys.modules[name] = None
Nick Coghlan47384702009-04-22 16:13:36 +0000104 return saved
105
106
107def import_fresh_module(name, fresh=(), blocked=(), deprecated=False):
Nick Coghlanfce769e2009-04-11 14:30:59 +0000108 """Imports and returns a module, deliberately bypassing the sys.modules cache
109 and importing a fresh copy of the module. Once the import is complete,
110 the sys.modules cache is restored to its original state.
111
Nick Coghlan47384702009-04-22 16:13:36 +0000112 Modules named in fresh are also imported anew if needed by the import.
113
114 Importing of modules named in blocked is prevented while the fresh import
Nick Coghlanfce769e2009-04-11 14:30:59 +0000115 takes place.
116
117 If deprecated is True, any module or package deprecation messages
118 will be suppressed."""
119 # NOTE: test_heapq and test_warnings include extra sanity checks to make
120 # sure that this utility function is working as expected
121 with _ignore_deprecated_imports(deprecated):
Nick Coghlan47384702009-04-22 16:13:36 +0000122 # Keep track of modules saved for later restoration as well
123 # as those which just need a blocking entry removed
Nick Coghlanfce769e2009-04-11 14:30:59 +0000124 orig_modules = {}
Nick Coghlan47384702009-04-22 16:13:36 +0000125 names_to_remove = []
126 _save_and_remove_module(name, orig_modules)
Nick Coghlanfce769e2009-04-11 14:30:59 +0000127 try:
Nick Coghlan47384702009-04-22 16:13:36 +0000128 for fresh_name in fresh:
129 _save_and_remove_module(fresh_name, orig_modules)
130 for blocked_name in blocked:
131 if not _save_and_block_module(blocked_name, orig_modules):
132 names_to_remove.append(blocked_name)
133 fresh_module = importlib.import_module(name)
Nick Coghlanfce769e2009-04-11 14:30:59 +0000134 finally:
Nick Coghlan47384702009-04-22 16:13:36 +0000135 for orig_name, module in orig_modules.items():
136 sys.modules[orig_name] = module
137 for name_to_remove in names_to_remove:
138 del sys.modules[name_to_remove]
139 return fresh_module
Nick Coghlanfce769e2009-04-11 14:30:59 +0000140
Benjamin Peterson699adb92008-05-08 22:27:58 +0000141
R. David Murraya21e4ca2009-03-31 23:16:50 +0000142def get_attribute(obj, name):
143 """Get an attribute, raising SkipTest if AttributeError is raised."""
144 try:
145 attribute = getattr(obj, name)
146 except AttributeError:
147 raise unittest.SkipTest("module %s has no attribute %s" % (
148 obj.__name__, name))
149 else:
150 return attribute
151
Barry Warsawc0fb6052001-08-20 22:29:23 +0000152verbose = 1 # Flag set to 0 by regrtest.py
Thomas Wouters477c8d52006-05-27 19:21:47 +0000153use_resources = None # Flag set to [] by regrtest.py
154max_memuse = 0 # Disable bigmem tests (they will still be run with
155 # small sizes, to make sure they work.)
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000156real_max_memuse = 0
Guido van Rossum531661c1996-12-20 02:58:22 +0000157
Tim Peters8dee8092001-09-25 20:05:11 +0000158# _original_stdout is meant to hold stdout at the time regrtest began.
159# This may be "the real" stdout, or IDLE's emulation of stdout, or whatever.
160# The point is to have some flavor of stdout the user can actually see.
161_original_stdout = None
162def record_original_stdout(stdout):
163 global _original_stdout
164 _original_stdout = stdout
165
166def get_original_stdout():
167 return _original_stdout or sys.stdout
168
Guido van Rossum3bead091992-01-27 17:00:37 +0000169def unload(name):
Fred Drake004d5e62000-10-23 17:22:08 +0000170 try:
171 del sys.modules[name]
172 except KeyError:
173 pass
Guido van Rossum3bead091992-01-27 17:00:37 +0000174
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000175def unlink(filename):
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000176 try:
177 os.unlink(filename)
178 except OSError:
179 pass
180
Christian Heimes23daade02008-02-25 12:39:23 +0000181def rmtree(path):
182 try:
183 shutil.rmtree(path)
184 except OSError as e:
185 # Unix returns ENOENT, Windows returns ESRCH.
186 if e.errno not in (errno.ENOENT, errno.ESRCH):
187 raise
188
Guido van Rossum3bead091992-01-27 17:00:37 +0000189def forget(modname):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000190 '''"Forget" a module was ever imported by removing it from sys.modules and
191 deleting any .pyc and .pyo files.'''
Fred Drake004d5e62000-10-23 17:22:08 +0000192 unload(modname)
Fred Drake004d5e62000-10-23 17:22:08 +0000193 for dirname in sys.path:
Skip Montanaro7a98be22007-08-16 14:35:24 +0000194 unlink(os.path.join(dirname, modname + '.pyc'))
Brett Cannonf1cfb622003-05-04 21:15:27 +0000195 # Deleting the .pyo file cannot be within the 'try' for the .pyc since
196 # the chance exists that there is no .pyc (and thus the 'try' statement
197 # is exited) but there is a .pyo file.
Skip Montanaro7a98be22007-08-16 14:35:24 +0000198 unlink(os.path.join(dirname, modname + '.pyo'))
Guido van Rossum3bead091992-01-27 17:00:37 +0000199
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000200def is_resource_enabled(resource):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000201 """Test whether a resource is enabled. Known resources are set by
202 regrtest.py."""
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000203 return use_resources is not None and resource in use_resources
204
Barry Warsawc0fb6052001-08-20 22:29:23 +0000205def requires(resource, msg=None):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000206 """Raise ResourceDenied if the specified resource is not available.
207
208 If the caller's module is __main__ then automatically return True. The
209 possibility of False being returned occurs when regrtest.py is executing."""
Skip Montanarod839ecd2003-04-24 19:06:57 +0000210 # see if the caller's module is __main__ - if so, treat as if
211 # the resource was set
Benjamin Petersone549ead2009-03-28 21:42:05 +0000212 if sys._getframe(1).f_globals.get("__name__") == "__main__":
Skip Montanarod839ecd2003-04-24 19:06:57 +0000213 return
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000214 if not is_resource_enabled(resource):
Barry Warsawc0fb6052001-08-20 22:29:23 +0000215 if msg is None:
216 msg = "Use of the `%s' resource not enabled" % resource
Fred Drake9a0db072003-02-03 15:19:30 +0000217 raise ResourceDenied(msg)
Barry Warsawc0fb6052001-08-20 22:29:23 +0000218
Christian Heimes5e696852008-04-09 08:37:03 +0000219HOST = 'localhost'
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000220
Christian Heimes5e696852008-04-09 08:37:03 +0000221def find_unused_port(family=socket.AF_INET, socktype=socket.SOCK_STREAM):
222 """Returns an unused port that should be suitable for binding. This is
223 achieved by creating a temporary socket with the same family and type as
224 the 'sock' parameter (default is AF_INET, SOCK_STREAM), and binding it to
225 the specified host address (defaults to 0.0.0.0) with the port set to 0,
226 eliciting an unused ephemeral port from the OS. The temporary socket is
227 then closed and deleted, and the ephemeral port is returned.
228
229 Either this method or bind_port() should be used for any tests where a
230 server socket needs to be bound to a particular port for the duration of
231 the test. Which one to use depends on whether the calling code is creating
232 a python socket, or if an unused port needs to be provided in a constructor
233 or passed to an external program (i.e. the -accept argument to openssl's
234 s_server mode). Always prefer bind_port() over find_unused_port() where
235 possible. Hard coded ports should *NEVER* be used. As soon as a server
236 socket is bound to a hard coded port, the ability to run multiple instances
237 of the test simultaneously on the same host is compromised, which makes the
238 test a ticking time bomb in a buildbot environment. On Unix buildbots, this
239 may simply manifest as a failed test, which can be recovered from without
240 intervention in most cases, but on Windows, the entire python process can
241 completely and utterly wedge, requiring someone to log in to the buildbot
242 and manually kill the affected process.
243
244 (This is easy to reproduce on Windows, unfortunately, and can be traced to
245 the SO_REUSEADDR socket option having different semantics on Windows versus
246 Unix/Linux. On Unix, you can't have two AF_INET SOCK_STREAM sockets bind,
247 listen and then accept connections on identical host/ports. An EADDRINUSE
248 socket.error will be raised at some point (depending on the platform and
249 the order bind and listen were called on each socket).
250
251 However, on Windows, if SO_REUSEADDR is set on the sockets, no EADDRINUSE
252 will ever be raised when attempting to bind two identical host/ports. When
253 accept() is called on each socket, the second caller's process will steal
254 the port from the first caller, leaving them both in an awkwardly wedged
255 state where they'll no longer respond to any signals or graceful kills, and
256 must be forcibly killed via OpenProcess()/TerminateProcess().
257
258 The solution on Windows is to use the SO_EXCLUSIVEADDRUSE socket option
259 instead of SO_REUSEADDR, which effectively affords the same semantics as
260 SO_REUSEADDR on Unix. Given the propensity of Unix developers in the Open
261 Source world compared to Windows ones, this is a common mistake. A quick
262 look over OpenSSL's 0.9.8g source shows that they use SO_REUSEADDR when
263 openssl.exe is called with the 's_server' option, for example. See
264 http://bugs.python.org/issue2550 for more info. The following site also
265 has a very thorough description about the implications of both REUSEADDR
266 and EXCLUSIVEADDRUSE on Windows:
267 http://msdn2.microsoft.com/en-us/library/ms740621(VS.85).aspx)
268
269 XXX: although this approach is a vast improvement on previous attempts to
270 elicit unused ports, it rests heavily on the assumption that the ephemeral
271 port returned to us by the OS won't immediately be dished back out to some
272 other process when we close and delete our temporary socket but before our
273 calling code has a chance to bind the returned port. We can deal with this
274 issue if/when we come across it.
275 """
276
277 tempsock = socket.socket(family, socktype)
278 port = bind_port(tempsock)
279 tempsock.close()
280 del tempsock
281 return port
282
283def bind_port(sock, host=HOST):
284 """Bind the socket to a free port and return the port number. Relies on
285 ephemeral ports in order to ensure we are using an unbound port. This is
286 important as many tests may be running simultaneously, especially in a
287 buildbot environment. This method raises an exception if the sock.family
288 is AF_INET and sock.type is SOCK_STREAM, *and* the socket has SO_REUSEADDR
289 or SO_REUSEPORT set on it. Tests should *never* set these socket options
290 for TCP/IP sockets. The only case for setting these options is testing
291 multicasting via multiple UDP sockets.
292
293 Additionally, if the SO_EXCLUSIVEADDRUSE socket option is available (i.e.
294 on Windows), it will be set on the socket. This will prevent anyone else
295 from bind()'ing to our host/port for the duration of the test.
296 """
297
298 if sock.family == socket.AF_INET and sock.type == socket.SOCK_STREAM:
299 if hasattr(socket, 'SO_REUSEADDR'):
300 if sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR) == 1:
301 raise TestFailed("tests should never set the SO_REUSEADDR " \
302 "socket option on TCP/IP sockets!")
303 if hasattr(socket, 'SO_REUSEPORT'):
304 if sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEPORT) == 1:
305 raise TestFailed("tests should never set the SO_REUSEPORT " \
306 "socket option on TCP/IP sockets!")
307 if hasattr(socket, 'SO_EXCLUSIVEADDRUSE'):
308 sock.setsockopt(socket.SOL_SOCKET, socket.SO_EXCLUSIVEADDRUSE, 1)
309
310 sock.bind((host, 0))
311 port = sock.getsockname()[1]
312 return port
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000313
Guido van Rossum35fb82a1993-01-26 13:04:43 +0000314FUZZ = 1e-6
315
316def fcmp(x, y): # fuzzy comparison function
Neal Norwitz79212992006-08-21 16:27:31 +0000317 if isinstance(x, float) or isinstance(y, float):
Fred Drake004d5e62000-10-23 17:22:08 +0000318 try:
Fred Drake004d5e62000-10-23 17:22:08 +0000319 fuzz = (abs(x) + abs(y)) * FUZZ
320 if abs(x-y) <= fuzz:
321 return 0
322 except:
323 pass
Neal Norwitz79212992006-08-21 16:27:31 +0000324 elif type(x) == type(y) and isinstance(x, (tuple, list)):
Fred Drake004d5e62000-10-23 17:22:08 +0000325 for i in range(min(len(x), len(y))):
326 outcome = fcmp(x[i], y[i])
Fred Drake132dce22000-12-12 23:11:42 +0000327 if outcome != 0:
Fred Drake004d5e62000-10-23 17:22:08 +0000328 return outcome
Guido van Rossum47b9ff62006-08-24 00:41:19 +0000329 return (len(x) > len(y)) - (len(x) < len(y))
330 return (x > y) - (x < y)
Guido van Rossum35fb82a1993-01-26 13:04:43 +0000331
Finn Bock57bc5fa2002-11-01 18:02:03 +0000332is_jython = sys.platform.startswith('java')
333
Barry Warsaw559f6682001-03-23 18:04:02 +0000334# Filename used for testing
335if os.name == 'java':
336 # Jython disallows @ in module names
337 TESTFN = '$test'
Martin v. Löwisa94568a2003-05-10 07:36:56 +0000338else:
Barry Warsaw559f6682001-03-23 18:04:02 +0000339 TESTFN = '@test'
Walter Dörwald9b775532007-06-08 14:30:53 +0000340
341 # Assuming sys.getfilesystemencoding()!=sys.getdefaultencoding()
342 # TESTFN_UNICODE is a filename that can be encoded using the
343 # file system encoding, but *not* with the default (ascii) encoding
344 TESTFN_UNICODE = "@test-\xe0\xf2"
345 TESTFN_ENCODING = sys.getfilesystemencoding()
Victor Stinner0ea31a92010-09-10 12:32:58 +0000346 # TESTFN_UNENCODABLE is a filename that should *not* be
Walter Dörwald9b775532007-06-08 14:30:53 +0000347 # able to be encoded by *either* the default or filesystem encoding.
348 # This test really only makes sense on Windows NT platforms
349 # which have special Unicode support in posixmodule.
350 if (not hasattr(sys, "getwindowsversion") or
351 sys.getwindowsversion()[3] < 2): # 0=win32s or 1=9x/ME
Victor Stinner0ea31a92010-09-10 12:32:58 +0000352 TESTFN_UNENCODABLE = None
Walter Dörwald9b775532007-06-08 14:30:53 +0000353 else:
Victor Stinner0d823ed2010-09-10 12:19:37 +0000354 # Different kinds of characters from various languages to minimize the
355 # probability that the whole name is encodable to MBCS (issue #9819)
356 TESTFN_UNENCODABLE = TESTFN + "-\u5171\u0141\u2661\u0363\uDC80"
Walter Dörwald9b775532007-06-08 14:30:53 +0000357 try:
358 # XXX - Note - should be using TESTFN_ENCODING here - but for
359 # Windows, "mbcs" currently always operates as if in
360 # errors=ignore' mode - hence we get '?' characters rather than
361 # the exception. 'Latin1' operates as we expect - ie, fails.
362 # See [ 850997 ] mbcs encoding ignores errors
Victor Stinner0ea31a92010-09-10 12:32:58 +0000363 TESTFN_UNENCODABLE.encode("Latin1")
Walter Dörwald9b775532007-06-08 14:30:53 +0000364 except UnicodeEncodeError:
365 pass
Martin v. Löwis2411a2d2002-11-09 19:57:26 +0000366 else:
Georg Brandldb028442008-02-05 20:48:58 +0000367 print('WARNING: The filename %r CAN be encoded by the filesystem. '
368 'Unicode filename tests may not be effective'
Victor Stinner0ea31a92010-09-10 12:32:58 +0000369 % TESTFN_UNENCODABLE)
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000370
Victor Stinner7f6423a2010-05-14 20:08:55 +0000371if os.path.isdir(TESTFN):
372 # a test failed (eg. test_os) without removing TESTFN directory
373 shutil.rmtree(TESTFN)
374
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000375# Make sure we can write to TESTFN, try in /tmp if we can't
376fp = None
377try:
378 fp = open(TESTFN, 'w+')
379except IOError:
380 TMP_TESTFN = os.path.join('/tmp', TESTFN)
381 try:
382 fp = open(TMP_TESTFN, 'w+')
383 TESTFN = TMP_TESTFN
384 del TMP_TESTFN
385 except IOError:
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000386 print(('WARNING: tests will fail, unable to write to: %s or %s' %
387 (TESTFN, TMP_TESTFN)))
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000388if fp is not None:
389 fp.close()
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000390 unlink(TESTFN)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000391del fp
Guido van Rossuma8f7e592001-03-13 09:31:07 +0000392
Victor Stinner3f682ad2010-07-13 23:14:46 +0000393def findfile(file, here=__file__, subdir=None):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000394 """Try to find a file on sys.path and the working directory. If it is not
395 found the argument passed to the function is returned (this does not
396 necessarily signal failure; could still be the legitimate path)."""
Fred Drake004d5e62000-10-23 17:22:08 +0000397 if os.path.isabs(file):
398 return file
Victor Stinner3f682ad2010-07-13 23:14:46 +0000399 if subdir is not None:
400 file = os.path.join(subdir, file)
Fred Drake004d5e62000-10-23 17:22:08 +0000401 path = sys.path
402 path = [os.path.dirname(here)] + path
403 for dn in path:
404 fn = os.path.join(dn, file)
405 if os.path.exists(fn): return fn
406 return file
Marc-André Lemburg36619082001-01-17 19:11:13 +0000407
Ezio Melotti2aef4b82010-01-25 12:20:04 +0000408def verify(condition, reason='test failed'):
409 """Verify that condition is true. If not, raise TestFailed.
410
411 The optional argument reason can be given to provide
412 a better error text.
413 """
414
415 if not condition:
416 raise TestFailed(reason)
417
418def vereq(a, b):
419 """Raise TestFailed if a == b is false.
420
421 This is better than verify(a == b) because, in case of failure, the
422 error message incorporates repr(a) and repr(b) so you can see the
423 inputs.
424
425 Note that "not (a == b)" isn't necessarily the same as "a != b"; the
426 former is tested.
427 """
428
429 if not (a == b):
430 raise TestFailed("%r == %r" % (a, b))
431
Tim Peters2f228e72001-05-13 00:19:31 +0000432def sortdict(dict):
433 "Like repr(dict), but in sorted order."
Guido van Rossumcc2b0162007-02-11 06:12:03 +0000434 items = sorted(dict.items())
Tim Peters2f228e72001-05-13 00:19:31 +0000435 reprpairs = ["%r: %r" % pair for pair in items]
436 withcommas = ", ".join(reprpairs)
437 return "{%s}" % withcommas
438
Benjamin Peterson7522c742009-01-19 21:00:09 +0000439def make_bad_fd():
440 """
441 Create an invalid file descriptor by opening and closing a file and return
442 its fd.
443 """
444 file = open(TESTFN, "wb")
445 try:
446 return file.fileno()
447 finally:
448 file.close()
449 unlink(TESTFN)
450
Thomas Wouters89f507f2006-12-13 04:49:30 +0000451def check_syntax_error(testcase, statement):
Benjamin Petersone549ead2009-03-28 21:42:05 +0000452 testcase.assertRaises(SyntaxError, compile, statement,
453 '<test string>', 'exec')
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000454
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000455def open_urlresource(url, *args, **kw):
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000456 import urllib.request, urllib.parse
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000457
Guido van Rossum360e4b82007-05-14 22:51:27 +0000458 requires('urlfetch')
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000459 filename = urllib.parse.urlparse(url)[2].split('/')[-1] # '/': it's URL!
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000460
461 for path in [os.path.curdir, os.path.pardir]:
462 fn = os.path.join(path, filename)
463 if os.path.exists(fn):
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000464 return open(fn, *args, **kw)
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000465
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000466 print('\tfetching %s ...' % url, file=get_original_stdout())
Antoine Pitrouec416612009-11-01 22:28:14 +0000467 f = urllib.request.urlopen(url, timeout=15)
468 try:
469 with open(filename, "wb") as out:
470 s = f.read()
471 while s:
472 out.write(s)
473 s = f.read()
474 finally:
475 f.close()
476 return open(filename, *args, **kw)
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000477
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000478class WarningsRecorder(object):
479 """Convenience wrapper for the warnings list returned on
480 entry to the warnings.catch_warnings() context manager.
Guido van Rossumd8faa362007-04-27 19:54:29 +0000481 """
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000482 def __init__(self, warnings_list):
483 self.warnings = warnings_list
484
485 def __getattr__(self, attr):
486 if self.warnings:
487 return getattr(self.warnings[-1], attr)
488 elif attr in warnings.WarningMessage._WARNING_DETAILS:
489 return None
490 raise AttributeError("%r has no attribute %r" % (self, attr))
491
492 def reset(self):
493 del self.warnings[:]
494
495@contextlib.contextmanager
496def check_warnings():
497 with warnings.catch_warnings(record=True) as w:
498 yield WarningsRecorder(w)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000499
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000500
501class CleanImport(object):
502 """Context manager to force import to return a new module reference.
503
504 This is useful for testing module-level behaviours, such as
Nick Coghlanb1304932008-07-13 12:25:08 +0000505 the emission of a DeprecationWarning on import.
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000506
507 Use like this:
508
509 with CleanImport("foo"):
510 __import__("foo") # new reference
511 """
512
513 def __init__(self, *module_names):
514 self.original_modules = sys.modules.copy()
515 for module_name in module_names:
516 if module_name in sys.modules:
517 module = sys.modules[module_name]
518 # It is possible that module_name is just an alias for
519 # another module (e.g. stub for modules renamed in 3.x).
520 # In that case, we also need delete the real module to clear
521 # the import cache.
522 if module.__name__ != module_name:
523 del sys.modules[module.__name__]
524 del sys.modules[module_name]
525
526 def __enter__(self):
527 return self
528
529 def __exit__(self, *ignore_exc):
530 sys.modules.update(self.original_modules)
531
532
Walter Dörwald155374d2009-05-01 19:58:58 +0000533class EnvironmentVarGuard(collections.MutableMapping):
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000534
535 """Class to help protect the environment variable properly. Can be used as
536 a context manager."""
537
538 def __init__(self):
Walter Dörwald155374d2009-05-01 19:58:58 +0000539 self._environ = os.environ
Walter Dörwald4ba80132009-04-25 12:48:43 +0000540 self._changed = {}
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000541
Walter Dörwald155374d2009-05-01 19:58:58 +0000542 def __getitem__(self, envvar):
543 return self._environ[envvar]
544
545 def __setitem__(self, envvar, value):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000546 # Remember the initial value on the first access
547 if envvar not in self._changed:
Walter Dörwald155374d2009-05-01 19:58:58 +0000548 self._changed[envvar] = self._environ.get(envvar)
549 self._environ[envvar] = value
550
551 def __delitem__(self, envvar):
552 # Remember the initial value on the first access
553 if envvar not in self._changed:
554 self._changed[envvar] = self._environ.get(envvar)
555 if envvar in self._environ:
556 del self._environ[envvar]
557
558 def keys(self):
559 return self._environ.keys()
560
561 def __iter__(self):
562 return iter(self._environ)
563
564 def __len__(self):
565 return len(self._environ)
566
567 def set(self, envvar, value):
568 self[envvar] = value
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000569
570 def unset(self, envvar):
Walter Dörwald155374d2009-05-01 19:58:58 +0000571 del self[envvar]
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000572
573 def __enter__(self):
574 return self
575
576 def __exit__(self, *ignore_exc):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000577 for (k, v) in self._changed.items():
578 if v is None:
Walter Dörwald155374d2009-05-01 19:58:58 +0000579 if k in self._environ:
580 del self._environ[k]
Walter Dörwald4ba80132009-04-25 12:48:43 +0000581 else:
Walter Dörwald155374d2009-05-01 19:58:58 +0000582 self._environ[k] = v
583
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000584
Guido van Rossumd8faa362007-04-27 19:54:29 +0000585class TransientResource(object):
586
587 """Raise ResourceDenied if an exception is raised while the context manager
588 is in effect that matches the specified exception and attributes."""
589
590 def __init__(self, exc, **kwargs):
591 self.exc = exc
592 self.attrs = kwargs
593
594 def __enter__(self):
595 return self
596
597 def __exit__(self, type_=None, value=None, traceback=None):
598 """If type_ is a subclass of self.exc and value has attributes matching
599 self.attrs, raise ResourceDenied. Otherwise let the exception
600 propagate (if any)."""
601 if type_ is not None and issubclass(self.exc, type_):
602 for attr, attr_value in self.attrs.items():
603 if not hasattr(value, attr):
604 break
605 if getattr(value, attr) != attr_value:
606 break
607 else:
608 raise ResourceDenied("an optional resource is not available")
609
Raymond Hettinger686057b2009-06-04 00:11:54 +0000610# Context managers that raise ResourceDenied when various issues
611# with the Internet connection manifest themselves as exceptions.
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000612# XXX deprecate these and use transient_internet() instead
Raymond Hettinger686057b2009-06-04 00:11:54 +0000613time_out = TransientResource(IOError, errno=errno.ETIMEDOUT)
614socket_peer_reset = TransientResource(socket.error, errno=errno.ECONNRESET)
615ioerror_peer_reset = TransientResource(IOError, errno=errno.ECONNRESET)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000616
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000617
Thomas Woutersed03b412007-08-28 21:37:11 +0000618@contextlib.contextmanager
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000619def transient_internet(resource_name, *, timeout=30.0, errnos=()):
Antoine Pitrouda6902c2010-04-21 19:52:52 +0000620 """Return a context manager that raises ResourceDenied when various issues
621 with the Internet connection manifest themselves as exceptions."""
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000622 default_errnos = [
623 ('ECONNREFUSED', 111),
624 ('ECONNRESET', 104),
625 ('ENETUNREACH', 101),
626 ('ETIMEDOUT', 110),
627 ]
Antoine Pitroudae0c632010-09-07 21:44:17 +0000628 default_gai_errnos = [
629 ('EAI_NONAME', -2),
630 ('EAI_NODATA', -5),
631 ]
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000632
633 denied = ResourceDenied("Resource '%s' is not available" % resource_name)
634 captured_errnos = errnos
Antoine Pitroudae0c632010-09-07 21:44:17 +0000635 gai_errnos = []
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000636 if not captured_errnos:
637 captured_errnos = [getattr(errno, name, num)
638 for (name, num) in default_errnos]
Antoine Pitroudae0c632010-09-07 21:44:17 +0000639 gai_errnos = [getattr(socket, name, num)
640 for (name, num) in default_gai_errnos]
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000641
642 def filter_error(err):
Antoine Pitroudae0c632010-09-07 21:44:17 +0000643 n = getattr(err, 'errno', None)
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000644 if (isinstance(err, socket.timeout) or
Antoine Pitroudae0c632010-09-07 21:44:17 +0000645 (isinstance(err, socket.gaierror) and n in gai_errnos) or
646 n in captured_errnos):
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000647 if not verbose:
648 sys.stderr.write(denied.args[0] + "\n")
649 raise denied from err
650
651 old_timeout = socket.getdefaulttimeout()
652 try:
653 if timeout is not None:
654 socket.setdefaulttimeout(timeout)
Antoine Pitrouda6902c2010-04-21 19:52:52 +0000655 yield
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000656 except IOError as err:
657 # urllib can wrap original socket errors multiple times (!), we must
658 # unwrap to get at the original error.
659 while True:
660 a = err.args
661 if len(a) >= 1 and isinstance(a[0], IOError):
662 err = a[0]
663 # The error can also be wrapped as args[1]:
664 # except socket.error as msg:
665 # raise IOError('socket error', msg).with_traceback(sys.exc_info()[2])
666 elif len(a) >= 2 and isinstance(a[1], IOError):
667 err = a[1]
668 else:
669 break
670 filter_error(err)
671 raise
672 # XXX should we catch generic exceptions and look for their
673 # __cause__ or __context__?
674 finally:
675 socket.setdefaulttimeout(old_timeout)
Antoine Pitrouda6902c2010-04-21 19:52:52 +0000676
677
678@contextlib.contextmanager
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000679def captured_output(stream_name):
680 """Run the 'with' statement body using a StringIO object in place of a
681 specific attribute on the sys module.
682 Example use (with 'stream_name=stdout')::
Thomas Woutersed03b412007-08-28 21:37:11 +0000683
684 with captured_stdout() as s:
Neal Norwitz752abd02008-05-13 04:55:24 +0000685 print("hello")
Thomas Woutersed03b412007-08-28 21:37:11 +0000686 assert s.getvalue() == "hello"
687 """
688 import io
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000689 orig_stdout = getattr(sys, stream_name)
690 setattr(sys, stream_name, io.StringIO())
Christian Heimes81ee3ef2008-05-04 22:42:01 +0000691 try:
692 yield getattr(sys, stream_name)
693 finally:
694 setattr(sys, stream_name, orig_stdout)
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000695
696def captured_stdout():
697 return captured_output("stdout")
Thomas Woutersed03b412007-08-28 21:37:11 +0000698
Benjamin Petersone549ead2009-03-28 21:42:05 +0000699def gc_collect():
700 """Force as many objects as possible to be collected.
701
702 In non-CPython implementations of Python, this is needed because timely
703 deallocation is not guaranteed by the garbage collector. (Even in CPython
704 this can be the case in case of reference cycles.) This means that __del__
705 methods may be called later than expected and weakrefs may remain alive for
706 longer than expected. This function tries its best to force all garbage
707 objects to disappear.
708 """
Benjamin Petersone549ead2009-03-28 21:42:05 +0000709 gc.collect()
710 gc.collect()
711 gc.collect()
712
Thomas Woutersed03b412007-08-28 21:37:11 +0000713
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000714#=======================================================================
Thomas Wouters477c8d52006-05-27 19:21:47 +0000715# Decorator for running a function in a different locale, correctly resetting
716# it afterwards.
717
718def run_with_locale(catstr, *locales):
719 def decorator(func):
720 def inner(*args, **kwds):
721 try:
722 import locale
723 category = getattr(locale, catstr)
724 orig_locale = locale.setlocale(category)
725 except AttributeError:
726 # if the test author gives us an invalid category string
727 raise
728 except:
729 # cannot retrieve original locale, so do nothing
730 locale = orig_locale = None
731 else:
732 for loc in locales:
733 try:
734 locale.setlocale(category, loc)
735 break
736 except:
737 pass
738
739 # now run the function, resetting the locale on exceptions
740 try:
741 return func(*args, **kwds)
742 finally:
743 if locale and orig_locale:
744 locale.setlocale(category, orig_locale)
Neal Norwitz221085d2007-02-25 20:55:47 +0000745 inner.__name__ = func.__name__
Thomas Wouters477c8d52006-05-27 19:21:47 +0000746 inner.__doc__ = func.__doc__
747 return inner
748 return decorator
749
750#=======================================================================
Georg Brandldb028442008-02-05 20:48:58 +0000751# Big-memory-test support. Separate from 'resources' because memory use
752# should be configurable.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000753
754# Some handy shorthands. Note that these are used for byte-limits as well
755# as size-limits, in the various bigmem tests
756_1M = 1024*1024
757_1G = 1024 * _1M
758_2G = 2 * _1G
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000759_4G = 4 * _1G
Thomas Wouters477c8d52006-05-27 19:21:47 +0000760
Thomas Woutersd2cf20e2007-08-30 22:57:53 +0000761MAX_Py_ssize_t = sys.maxsize
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000762
Thomas Wouters477c8d52006-05-27 19:21:47 +0000763def set_memlimit(limit):
764 import re
765 global max_memuse
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000766 global real_max_memuse
Thomas Wouters477c8d52006-05-27 19:21:47 +0000767 sizes = {
768 'k': 1024,
769 'm': _1M,
770 'g': _1G,
771 't': 1024*_1G,
772 }
773 m = re.match(r'(\d+(\.\d+)?) (K|M|G|T)b?$', limit,
774 re.IGNORECASE | re.VERBOSE)
775 if m is None:
776 raise ValueError('Invalid memory limit %r' % (limit,))
777 memlimit = int(float(m.group(1)) * sizes[m.group(3).lower()])
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000778 real_max_memuse = memlimit
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000779 if memlimit > MAX_Py_ssize_t:
780 memlimit = MAX_Py_ssize_t
781 if memlimit < _2G - 1:
Thomas Wouters477c8d52006-05-27 19:21:47 +0000782 raise ValueError('Memory limit %r too low to be useful' % (limit,))
783 max_memuse = memlimit
784
785def bigmemtest(minsize, memuse, overhead=5*_1M):
786 """Decorator for bigmem tests.
787
788 'minsize' is the minimum useful size for the test (in arbitrary,
789 test-interpreted units.) 'memuse' is the number of 'bytes per size' for
790 the test, or a good estimate of it. 'overhead' specifies fixed overhead,
Christian Heimes33fe8092008-04-13 13:53:33 +0000791 independent of the testsize, and defaults to 5Mb.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000792
793 The decorator tries to guess a good value for 'size' and passes it to
794 the decorated test function. If minsize * memuse is more than the
795 allowed memory use (as defined by max_memuse), the test is skipped.
796 Otherwise, minsize is adjusted upward to use up to max_memuse.
797 """
798 def decorator(f):
799 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000800 # Retrieve values in case someone decided to adjust them
801 minsize = wrapper.minsize
802 memuse = wrapper.memuse
803 overhead = wrapper.overhead
Thomas Wouters477c8d52006-05-27 19:21:47 +0000804 if not max_memuse:
805 # If max_memuse is 0 (the default),
806 # we still want to run the tests with size set to a few kb,
807 # to make sure they work. We still want to avoid using
808 # too much memory, though, but we do that noisily.
809 maxsize = 5147
Georg Brandlfe5f11c2009-08-13 08:52:53 +0000810 self.assertFalse(maxsize * memuse + overhead > 20 * _1M)
Thomas Wouters477c8d52006-05-27 19:21:47 +0000811 else:
812 maxsize = int((max_memuse - overhead) / memuse)
813 if maxsize < minsize:
814 # Really ought to print 'test skipped' or something
815 if verbose:
816 sys.stderr.write("Skipping %s because of memory "
817 "constraint\n" % (f.__name__,))
818 return
819 # Try to keep some breathing room in memory use
820 maxsize = max(maxsize - 50 * _1M, minsize)
821 return f(self, maxsize)
822 wrapper.minsize = minsize
823 wrapper.memuse = memuse
824 wrapper.overhead = overhead
825 return wrapper
826 return decorator
827
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000828def precisionbigmemtest(size, memuse, overhead=5*_1M):
829 def decorator(f):
830 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000831 size = wrapper.size
832 memuse = wrapper.memuse
833 overhead = wrapper.overhead
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000834 if not real_max_memuse:
835 maxsize = 5147
836 else:
837 maxsize = size
838
839 if real_max_memuse and real_max_memuse < maxsize * memuse:
840 if verbose:
841 sys.stderr.write("Skipping %s because of memory "
842 "constraint\n" % (f.__name__,))
843 return
844
845 return f(self, maxsize)
846 wrapper.size = size
847 wrapper.memuse = memuse
848 wrapper.overhead = overhead
849 return wrapper
850 return decorator
851
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000852def bigaddrspacetest(f):
853 """Decorator for tests that fill the address space."""
854 def wrapper(self):
855 if max_memuse < MAX_Py_ssize_t:
856 if verbose:
857 sys.stderr.write("Skipping %s because of memory "
858 "constraint\n" % (f.__name__,))
859 else:
860 return f(self)
861 return wrapper
862
Thomas Wouters477c8d52006-05-27 19:21:47 +0000863#=======================================================================
Guido van Rossumd8faa362007-04-27 19:54:29 +0000864# unittest integration.
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000865
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000866class BasicTestRunner:
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000867 def run(self, test):
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000868 result = unittest.TestResult()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000869 test(result)
870 return result
871
Benjamin Petersone549ead2009-03-28 21:42:05 +0000872def _id(obj):
873 return obj
874
875def requires_resource(resource):
876 if resource_is_enabled(resource):
877 return _id
878 else:
879 return unittest.skip("resource {0!r} is not enabled".format(resource))
880
881def cpython_only(test):
882 """
883 Decorator for tests only applicable on CPython.
884 """
885 return impl_detail(cpython=True)(test)
886
887def impl_detail(msg=None, **guards):
888 if check_impl_detail(**guards):
889 return _id
890 if msg is None:
891 guardnames, default = _parse_guards(guards)
892 if default:
893 msg = "implementation detail not available on {0}"
894 else:
895 msg = "implementation detail specific to {0}"
896 guardnames = sorted(guardnames.keys())
897 msg = msg.format(' or '.join(guardnames))
898 return unittest.skip(msg)
899
900def _parse_guards(guards):
901 # Returns a tuple ({platform_name: run_me}, default_value)
902 if not guards:
903 return ({'cpython': True}, False)
Eric Smith886b40a2009-04-26 21:26:45 +0000904 is_true = list(guards.values())[0]
905 assert list(guards.values()) == [is_true] * len(guards) # all True or all False
Benjamin Petersone549ead2009-03-28 21:42:05 +0000906 return (guards, not is_true)
907
908# Use the following check to guard CPython's implementation-specific tests --
909# or to run them only on the implementation(s) guarded by the arguments.
910def check_impl_detail(**guards):
911 """This function returns True or False depending on the host platform.
912 Examples:
913 if check_impl_detail(): # only on CPython (default)
914 if check_impl_detail(jython=True): # only on Jython
915 if check_impl_detail(cpython=False): # everywhere except on CPython
916 """
917 guards, default = _parse_guards(guards)
918 return guards.get(platform.python_implementation().lower(), default)
919
920
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000921
Guido van Rossumd8faa362007-04-27 19:54:29 +0000922def _run_suite(suite):
Barry Warsawc88425e2001-09-20 06:31:22 +0000923 """Run tests from a unittest.TestSuite-derived class."""
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000924 if verbose:
Fred Drake84a59342001-03-23 04:21:17 +0000925 runner = unittest.TextTestRunner(sys.stdout, verbosity=2)
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000926 else:
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000927 runner = BasicTestRunner()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000928
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000929 result = runner.run(suite)
930 if not result.wasSuccessful():
Fred Drake14f6c182001-07-16 18:51:32 +0000931 if len(result.errors) == 1 and not result.failures:
932 err = result.errors[0][1]
933 elif len(result.failures) == 1 and not result.errors:
934 err = result.failures[0][1]
935 else:
R. David Murrayb3438b82009-10-28 14:47:15 +0000936 err = "multiple errors occurred"
937 if not verbose: err += "; run in verbose mode for details"
Tim Peters2d84f2c2001-09-08 03:37:56 +0000938 raise TestFailed(err)
Tim Petersa0a62222001-09-09 06:12:01 +0000939
Barry Warsawc10d6902001-09-20 06:30:41 +0000940
Walter Dörwald21d3a322003-05-01 17:45:56 +0000941def run_unittest(*classes):
942 """Run tests from unittest.TestCase-derived classes."""
Guido van Rossumd8faa362007-04-27 19:54:29 +0000943 valid_types = (unittest.TestSuite, unittest.TestCase)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000944 suite = unittest.TestSuite()
Walter Dörwald21d3a322003-05-01 17:45:56 +0000945 for cls in classes:
Guido van Rossum3172c5d2007-10-16 18:12:55 +0000946 if isinstance(cls, str):
Guido van Rossumd8faa362007-04-27 19:54:29 +0000947 if cls in sys.modules:
948 suite.addTest(unittest.findTestCases(sys.modules[cls]))
949 else:
950 raise ValueError("str arguments must be keys in sys.modules")
951 elif isinstance(cls, valid_types):
Raymond Hettinger21d99872003-07-16 02:59:32 +0000952 suite.addTest(cls)
953 else:
954 suite.addTest(unittest.makeSuite(cls))
Guido van Rossumd8faa362007-04-27 19:54:29 +0000955 _run_suite(suite)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000956
Barry Warsawc10d6902001-09-20 06:30:41 +0000957
Tim Petersa0a62222001-09-09 06:12:01 +0000958#=======================================================================
959# doctest driver.
960
961def run_doctest(module, verbosity=None):
Tim Peters17111f32001-10-03 04:08:26 +0000962 """Run doctest on the given module. Return (#failures, #tests).
Tim Petersa0a62222001-09-09 06:12:01 +0000963
964 If optional argument verbosity is not specified (or is None), pass
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000965 support's belief about verbosity on to doctest. Else doctest's
Tim Petersbea3fb82001-09-10 01:39:21 +0000966 usual behavior is used (it searches sys.argv for -v).
Tim Petersa0a62222001-09-09 06:12:01 +0000967 """
968
969 import doctest
970
971 if verbosity is None:
972 verbosity = verbose
973 else:
974 verbosity = None
975
Tim Peters342ca752001-09-25 19:13:20 +0000976 # Direct doctest output (normally just errors) to real stdout; doctest
977 # output shouldn't be compared by regrtest.
978 save_stdout = sys.stdout
Tim Peters8dee8092001-09-25 20:05:11 +0000979 sys.stdout = get_original_stdout()
Tim Peters342ca752001-09-25 19:13:20 +0000980 try:
981 f, t = doctest.testmod(module, verbose=verbosity)
982 if f:
983 raise TestFailed("%d of %d doctests failed" % (f, t))
984 finally:
985 sys.stdout = save_stdout
Raymond Hettinger35b34bd2003-05-17 00:58:33 +0000986 if verbose:
Georg Brandldb028442008-02-05 20:48:58 +0000987 print('doctest (%s) ... %d tests with zero failures' %
988 (module.__name__, t))
Raymond Hettinger35b34bd2003-05-17 00:58:33 +0000989 return f, t
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000990
Antoine Pitrouca154092009-11-13 16:31:51 +0000991
992#=======================================================================
993# Support for saving and restoring the imported modules.
994
995def modules_setup():
996 return sys.modules.copy(),
997
998def modules_cleanup(oldmodules):
999 # Encoders/decoders are registered permanently within the internal
1000 # codec cache. If we destroy the corresponding modules their
1001 # globals will be set to None which will trip up the cached functions.
1002 encodings = [(k, v) for k, v in sys.modules.items()
1003 if k.startswith('encodings.')]
1004 sys.modules.clear()
1005 sys.modules.update(encodings)
1006 sys.modules.update(oldmodules)
1007
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001008#=======================================================================
1009# Threading support to prevent reporting refleaks when running regrtest.py -R
1010
1011def threading_setup():
1012 import threading
1013 return len(threading._active), len(threading._limbo)
1014
1015def threading_cleanup(num_active, num_limbo):
1016 import threading
1017 import time
1018
1019 _MAX_COUNT = 10
1020 count = 0
1021 while len(threading._active) != num_active and count < _MAX_COUNT:
1022 count += 1
1023 time.sleep(0.1)
1024
1025 count = 0
1026 while len(threading._limbo) != num_limbo and count < _MAX_COUNT:
1027 count += 1
1028 time.sleep(0.1)
1029
Benjamin Petersonfa0d7032009-06-01 22:42:33 +00001030def reap_threads(func):
1031 @functools.wraps(func)
1032 def decorator(*args):
1033 key = threading_setup()
1034 try:
1035 return func(*args)
1036 finally:
1037 threading_cleanup(*key)
1038 return decorator
1039
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001040def reap_children():
1041 """Use this function at the end of test_main() whenever sub-processes
1042 are started. This will help ensure that no extra children (zombies)
1043 stick around to hog resources and create problems when looking
1044 for refleaks.
1045 """
1046
1047 # Reap all our dead child processes so we don't leave zombies around.
1048 # These hog resources and might be causing some of the buildbots to die.
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001049 if hasattr(os, 'waitpid'):
1050 any_process = -1
1051 while True:
1052 try:
1053 # This will raise an exception on Windows. That's ok.
1054 pid, status = os.waitpid(any_process, os.WNOHANG)
1055 if pid == 0:
1056 break
1057 except:
1058 break