blob: 73c42288049cc3adbaae8b79d3a3ed32da5770be [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
Florent Xiclunab14930c2010-03-13 15:26:44 +000019import re
Fred Drakecd1b1dd2001-03-21 18:26:33 +000020
Benjamin Petersone549ead2009-03-28 21:42:05 +000021__all__ = ["Error", "TestFailed", "ResourceDenied", "import_module",
Benjamin Peterson744c2cd2008-05-26 16:26:37 +000022 "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",
Ezio Melotti184bdfb2010-02-18 09:37:05 +000025 "fcmp", "is_jython", "TESTFN", "HOST", "FUZZ", "SAVEDCWD", "temp_cwd",
26 "findfile", "sortdict", "check_syntax_error", "open_urlresource",
Benjamin Petersonfcf5d632008-10-16 23:24:44 +000027 "check_warnings", "CleanImport", "EnvironmentVarGuard",
Benjamin Peterson79e48032008-05-26 17:44:33 +000028 "TransientResource", "captured_output", "captured_stdout",
Raymond Hettingerd76b9f12009-06-04 00:35:30 +000029 "time_out", "socket_peer_reset", "ioerror_peer_reset",
30 "run_with_locale",
Benjamin Peterson79e48032008-05-26 17:44:33 +000031 "set_memlimit", "bigmemtest", "bigaddrspacetest", "BasicTestRunner",
32 "run_unittest", "run_doctest", "threading_setup", "threading_cleanup",
Collin Winterf2bf2b32010-03-17 00:41:56 +000033 "reap_children", "cpython_only", "check_impl_detail", "get_attribute",
34 "swap_item", "swap_attr"]
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
103 sys.modules[name] = 0
104 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
Antoine Pitrou88909542009-06-29 13:54:42 +0000341# Disambiguate TESTFN for parallel testing, while letting it remain a valid
342# module name.
Ezio Melotti184bdfb2010-02-18 09:37:05 +0000343TESTFN = "{}_{}_tmp".format(TESTFN, os.getpid())
Antoine Pitrou88909542009-06-29 13:54:42 +0000344
345# Assuming sys.getfilesystemencoding()!=sys.getdefaultencoding()
346# TESTFN_UNICODE is a filename that can be encoded using the
347# file system encoding, but *not* with the default (ascii) encoding
348TESTFN_UNICODE = TESTFN + "-\xe0\xf2"
349TESTFN_ENCODING = sys.getfilesystemencoding()
350# TESTFN_UNICODE_UNENCODEABLE is a filename that should *not* be
351# able to be encoded by *either* the default or filesystem encoding.
352# This test really only makes sense on Windows NT platforms
353# which have special Unicode support in posixmodule.
354if (not hasattr(sys, "getwindowsversion") or
355 sys.getwindowsversion()[3] < 2): # 0=win32s or 1=9x/ME
356 TESTFN_UNICODE_UNENCODEABLE = None
357else:
358 # Japanese characters (I think - from bug 846133)
359 TESTFN_UNICODE_UNENCODEABLE = TESTFN + "-\u5171\u6709\u3055\u308c\u308b"
360 try:
361 # XXX - Note - should be using TESTFN_ENCODING here - but for
362 # Windows, "mbcs" currently always operates as if in
363 # errors=ignore' mode - hence we get '?' characters rather than
364 # the exception. 'Latin1' operates as we expect - ie, fails.
365 # See [ 850997 ] mbcs encoding ignores errors
366 TESTFN_UNICODE_UNENCODEABLE.encode("Latin1")
367 except UnicodeEncodeError:
368 pass
Walter Dörwald9b775532007-06-08 14:30:53 +0000369 else:
Antoine Pitrou88909542009-06-29 13:54:42 +0000370 print('WARNING: The filename %r CAN be encoded by the filesystem. '
371 'Unicode filename tests may not be effective'
372 % TESTFN_UNICODE_UNENCODEABLE)
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000373
Ezio Melotti184bdfb2010-02-18 09:37:05 +0000374# Save the initial cwd
375SAVEDCWD = os.getcwd()
376
377@contextlib.contextmanager
378def temp_cwd(name='tempcwd', quiet=False):
379 """
380 Context manager that creates a temporary directory and set it as CWD.
381
382 The new CWD is created in the current directory and it's named *name*.
383 If *quiet* is False (default) and it's not possible to create or change
384 the CWD, an error is raised. If it's True, only a warning is raised
385 and the original CWD is used.
386 """
387 saved_dir = os.getcwd()
388 is_temporary = False
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000389 try:
Ezio Melotti184bdfb2010-02-18 09:37:05 +0000390 os.mkdir(name)
391 os.chdir(name)
392 is_temporary = True
393 except OSError:
394 if not quiet:
395 raise
396 warnings.warn('tests may fail, unable to change the CWD to ' + name,
397 RuntimeWarning, stacklevel=3)
398 try:
399 yield os.getcwd()
400 finally:
401 os.chdir(saved_dir)
402 if is_temporary:
403 rmtree(name)
404
Guido van Rossuma8f7e592001-03-13 09:31:07 +0000405
Florent Xiclunaf15351d2010-03-13 23:24:31 +0000406def findfile(file, here=__file__, subdir=None):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000407 """Try to find a file on sys.path and the working directory. If it is not
408 found the argument passed to the function is returned (this does not
409 necessarily signal failure; could still be the legitimate path)."""
Fred Drake004d5e62000-10-23 17:22:08 +0000410 if os.path.isabs(file):
411 return file
Florent Xiclunaf15351d2010-03-13 23:24:31 +0000412 if subdir is not None:
413 file = os.path.join(subdir, file)
Fred Drake004d5e62000-10-23 17:22:08 +0000414 path = sys.path
415 path = [os.path.dirname(here)] + path
416 for dn in path:
417 fn = os.path.join(dn, file)
418 if os.path.exists(fn): return fn
419 return file
Marc-André Lemburg36619082001-01-17 19:11:13 +0000420
Tim Peters2f228e72001-05-13 00:19:31 +0000421def sortdict(dict):
422 "Like repr(dict), but in sorted order."
Guido van Rossumcc2b0162007-02-11 06:12:03 +0000423 items = sorted(dict.items())
Tim Peters2f228e72001-05-13 00:19:31 +0000424 reprpairs = ["%r: %r" % pair for pair in items]
425 withcommas = ", ".join(reprpairs)
426 return "{%s}" % withcommas
427
Benjamin Peterson7522c742009-01-19 21:00:09 +0000428def make_bad_fd():
429 """
430 Create an invalid file descriptor by opening and closing a file and return
431 its fd.
432 """
433 file = open(TESTFN, "wb")
434 try:
435 return file.fileno()
436 finally:
437 file.close()
438 unlink(TESTFN)
439
Thomas Wouters89f507f2006-12-13 04:49:30 +0000440def check_syntax_error(testcase, statement):
Benjamin Petersone549ead2009-03-28 21:42:05 +0000441 testcase.assertRaises(SyntaxError, compile, statement,
442 '<test string>', 'exec')
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000443
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000444def open_urlresource(url, *args, **kw):
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000445 import urllib.request, urllib.parse
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000446
Guido van Rossum360e4b82007-05-14 22:51:27 +0000447 requires('urlfetch')
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000448 filename = urllib.parse.urlparse(url)[2].split('/')[-1] # '/': it's URL!
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000449
Alexandre Vassalotti711ed4a2009-07-17 10:42:05 +0000450 fn = os.path.join(os.path.dirname(__file__), "data", filename)
451 if os.path.exists(fn):
Alexandre Vassalottidf4ff082009-07-22 00:19:57 +0000452 return open(fn, *args, **kw)
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000453
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000454 print('\tfetching %s ...' % url, file=get_original_stdout())
Antoine Pitroufd0680b2009-11-01 22:13:48 +0000455 f = urllib.request.urlopen(url, timeout=15)
456 try:
457 with open(fn, "wb") as out:
458 s = f.read()
459 while s:
460 out.write(s)
461 s = f.read()
462 finally:
463 f.close()
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000464 return open(fn, *args, **kw)
Thomas Wouters9fe394c2007-02-05 01:24:16 +0000465
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000466class WarningsRecorder(object):
467 """Convenience wrapper for the warnings list returned on
468 entry to the warnings.catch_warnings() context manager.
Guido van Rossumd8faa362007-04-27 19:54:29 +0000469 """
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000470 def __init__(self, warnings_list):
Florent Xiclunab14930c2010-03-13 15:26:44 +0000471 self._warnings = warnings_list
472 self._last = 0
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000473
474 def __getattr__(self, attr):
Florent Xiclunab14930c2010-03-13 15:26:44 +0000475 if len(self._warnings) > self._last:
476 return getattr(self._warnings[-1], attr)
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000477 elif attr in warnings.WarningMessage._WARNING_DETAILS:
478 return None
479 raise AttributeError("%r has no attribute %r" % (self, attr))
480
Florent Xiclunab14930c2010-03-13 15:26:44 +0000481 @property
482 def warnings(self):
483 return self._warnings[self._last:]
484
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000485 def reset(self):
Florent Xiclunab14930c2010-03-13 15:26:44 +0000486 self._last = len(self._warnings)
487
488
489def _filterwarnings(filters, quiet=False):
490 """Catch the warnings, then check if all the expected
491 warnings have been raised and re-raise unexpected warnings.
492 If 'quiet' is True, only re-raise the unexpected warnings.
493 """
494 # Clear the warning registry of the calling module
495 # in order to re-raise the warnings.
496 frame = sys._getframe(2)
497 registry = frame.f_globals.get('__warningregistry__')
498 if registry:
499 registry.clear()
500 with warnings.catch_warnings(record=True) as w:
501 # Set filter "always" to record all warnings. Because
502 # test_warnings swap the module, we need to look up in
503 # the sys.modules dictionary.
504 sys.modules['warnings'].simplefilter("always")
505 yield WarningsRecorder(w)
506 # Filter the recorded warnings
507 reraise = [warning.message for warning in w]
508 missing = []
509 for msg, cat in filters:
510 seen = False
511 for exc in reraise[:]:
512 message = str(exc)
513 # Filter out the matching messages
514 if (re.match(msg, message, re.I) and
515 issubclass(exc.__class__, cat)):
516 seen = True
517 reraise.remove(exc)
518 if not seen and not quiet:
519 # This filter caught nothing
520 missing.append((msg, cat.__name__))
521 if reraise:
522 raise AssertionError("unhandled warning %r" % reraise[0])
523 if missing:
524 raise AssertionError("filter (%r, %s) did not catch any warning" %
525 missing[0])
526
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000527
528@contextlib.contextmanager
Florent Xiclunab14930c2010-03-13 15:26:44 +0000529def check_warnings(*filters, **kwargs):
530 """Context manager to silence warnings.
531
532 Accept 2-tuples as positional arguments:
533 ("message regexp", WarningCategory)
534
535 Optional argument:
536 - if 'quiet' is True, it does not fail if a filter catches nothing
Florent Xicluna53b506be2010-03-18 20:00:57 +0000537 (default True without argument,
538 default False if some filters are defined)
Florent Xiclunab14930c2010-03-13 15:26:44 +0000539
540 Without argument, it defaults to:
Florent Xicluna53b506be2010-03-18 20:00:57 +0000541 check_warnings(("", Warning), quiet=True)
Florent Xiclunab14930c2010-03-13 15:26:44 +0000542 """
Florent Xicluna53b506be2010-03-18 20:00:57 +0000543 quiet = kwargs.get('quiet')
Florent Xiclunab14930c2010-03-13 15:26:44 +0000544 if not filters:
545 filters = (("", Warning),)
Florent Xicluna53b506be2010-03-18 20:00:57 +0000546 # Preserve backward compatibility
547 if quiet is None:
548 quiet = True
549 return _filterwarnings(filters, quiet)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000550
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000551
552class CleanImport(object):
553 """Context manager to force import to return a new module reference.
554
555 This is useful for testing module-level behaviours, such as
Nick Coghlanb1304932008-07-13 12:25:08 +0000556 the emission of a DeprecationWarning on import.
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000557
558 Use like this:
559
560 with CleanImport("foo"):
Brett Cannonddb5e702010-02-03 22:16:11 +0000561 importlib.import_module("foo") # new reference
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000562 """
563
564 def __init__(self, *module_names):
565 self.original_modules = sys.modules.copy()
566 for module_name in module_names:
567 if module_name in sys.modules:
568 module = sys.modules[module_name]
569 # It is possible that module_name is just an alias for
570 # another module (e.g. stub for modules renamed in 3.x).
571 # In that case, we also need delete the real module to clear
572 # the import cache.
573 if module.__name__ != module_name:
574 del sys.modules[module.__name__]
575 del sys.modules[module_name]
576
577 def __enter__(self):
578 return self
579
580 def __exit__(self, *ignore_exc):
581 sys.modules.update(self.original_modules)
582
583
Walter Dörwald155374d2009-05-01 19:58:58 +0000584class EnvironmentVarGuard(collections.MutableMapping):
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000585
586 """Class to help protect the environment variable properly. Can be used as
587 a context manager."""
588
589 def __init__(self):
Walter Dörwald155374d2009-05-01 19:58:58 +0000590 self._environ = os.environ
Walter Dörwald4ba80132009-04-25 12:48:43 +0000591 self._changed = {}
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000592
Walter Dörwald155374d2009-05-01 19:58:58 +0000593 def __getitem__(self, envvar):
594 return self._environ[envvar]
595
596 def __setitem__(self, envvar, value):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000597 # Remember the initial value on the first access
598 if envvar not in self._changed:
Walter Dörwald155374d2009-05-01 19:58:58 +0000599 self._changed[envvar] = self._environ.get(envvar)
600 self._environ[envvar] = value
601
602 def __delitem__(self, envvar):
603 # Remember the initial value on the first access
604 if envvar not in self._changed:
605 self._changed[envvar] = self._environ.get(envvar)
606 if envvar in self._environ:
607 del self._environ[envvar]
608
609 def keys(self):
610 return self._environ.keys()
611
612 def __iter__(self):
613 return iter(self._environ)
614
615 def __len__(self):
616 return len(self._environ)
617
618 def set(self, envvar, value):
619 self[envvar] = value
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000620
621 def unset(self, envvar):
Walter Dörwald155374d2009-05-01 19:58:58 +0000622 del self[envvar]
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000623
624 def __enter__(self):
625 return self
626
627 def __exit__(self, *ignore_exc):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000628 for (k, v) in self._changed.items():
629 if v is None:
Walter Dörwald155374d2009-05-01 19:58:58 +0000630 if k in self._environ:
631 del self._environ[k]
Walter Dörwald4ba80132009-04-25 12:48:43 +0000632 else:
Walter Dörwald155374d2009-05-01 19:58:58 +0000633 self._environ[k] = v
Nick Coghlan6ead5522009-10-18 13:19:33 +0000634 os.environ = self._environ
635
636
637class DirsOnSysPath(object):
638 """Context manager to temporarily add directories to sys.path.
639
640 This makes a copy of sys.path, appends any directories given
641 as positional arguments, then reverts sys.path to the copied
642 settings when the context ends.
643
644 Note that *all* sys.path modifications in the body of the
645 context manager, including replacement of the object,
646 will be reverted at the end of the block.
647 """
648
649 def __init__(self, *paths):
650 self.original_value = sys.path[:]
651 self.original_object = sys.path
652 sys.path.extend(paths)
653
654 def __enter__(self):
655 return self
656
657 def __exit__(self, *ignore_exc):
658 sys.path = self.original_object
659 sys.path[:] = self.original_value
Walter Dörwald155374d2009-05-01 19:58:58 +0000660
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000661
Guido van Rossumd8faa362007-04-27 19:54:29 +0000662class TransientResource(object):
663
664 """Raise ResourceDenied if an exception is raised while the context manager
665 is in effect that matches the specified exception and attributes."""
666
667 def __init__(self, exc, **kwargs):
668 self.exc = exc
669 self.attrs = kwargs
670
671 def __enter__(self):
672 return self
673
674 def __exit__(self, type_=None, value=None, traceback=None):
675 """If type_ is a subclass of self.exc and value has attributes matching
676 self.attrs, raise ResourceDenied. Otherwise let the exception
677 propagate (if any)."""
678 if type_ is not None and issubclass(self.exc, type_):
679 for attr, attr_value in self.attrs.items():
680 if not hasattr(value, attr):
681 break
682 if getattr(value, attr) != attr_value:
683 break
684 else:
685 raise ResourceDenied("an optional resource is not available")
686
687
Raymond Hettinger686057b2009-06-04 00:11:54 +0000688# Context managers that raise ResourceDenied when various issues
689# with the Internet connection manifest themselves as exceptions.
690time_out = TransientResource(IOError, errno=errno.ETIMEDOUT)
691socket_peer_reset = TransientResource(socket.error, errno=errno.ECONNRESET)
692ioerror_peer_reset = TransientResource(IOError, errno=errno.ECONNRESET)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000693
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000694
Thomas Woutersed03b412007-08-28 21:37:11 +0000695@contextlib.contextmanager
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000696def captured_output(stream_name):
697 """Run the 'with' statement body using a StringIO object in place of a
698 specific attribute on the sys module.
699 Example use (with 'stream_name=stdout')::
Thomas Woutersed03b412007-08-28 21:37:11 +0000700
701 with captured_stdout() as s:
Neal Norwitz752abd02008-05-13 04:55:24 +0000702 print("hello")
Thomas Woutersed03b412007-08-28 21:37:11 +0000703 assert s.getvalue() == "hello"
704 """
705 import io
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000706 orig_stdout = getattr(sys, stream_name)
707 setattr(sys, stream_name, io.StringIO())
Christian Heimes81ee3ef2008-05-04 22:42:01 +0000708 try:
709 yield getattr(sys, stream_name)
710 finally:
711 setattr(sys, stream_name, orig_stdout)
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000712
713def captured_stdout():
714 return captured_output("stdout")
Thomas Woutersed03b412007-08-28 21:37:11 +0000715
Nick Coghlan6ead5522009-10-18 13:19:33 +0000716def captured_stdin():
717 return captured_output("stdin")
718
Benjamin Petersone549ead2009-03-28 21:42:05 +0000719def gc_collect():
720 """Force as many objects as possible to be collected.
721
722 In non-CPython implementations of Python, this is needed because timely
723 deallocation is not guaranteed by the garbage collector. (Even in CPython
724 this can be the case in case of reference cycles.) This means that __del__
725 methods may be called later than expected and weakrefs may remain alive for
726 longer than expected. This function tries its best to force all garbage
727 objects to disappear.
728 """
Benjamin Petersone549ead2009-03-28 21:42:05 +0000729 gc.collect()
730 gc.collect()
731 gc.collect()
732
Thomas Woutersed03b412007-08-28 21:37:11 +0000733
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000734#=======================================================================
Thomas Wouters477c8d52006-05-27 19:21:47 +0000735# Decorator for running a function in a different locale, correctly resetting
736# it afterwards.
737
738def run_with_locale(catstr, *locales):
739 def decorator(func):
740 def inner(*args, **kwds):
741 try:
742 import locale
743 category = getattr(locale, catstr)
744 orig_locale = locale.setlocale(category)
745 except AttributeError:
746 # if the test author gives us an invalid category string
747 raise
748 except:
749 # cannot retrieve original locale, so do nothing
750 locale = orig_locale = None
751 else:
752 for loc in locales:
753 try:
754 locale.setlocale(category, loc)
755 break
756 except:
757 pass
758
759 # now run the function, resetting the locale on exceptions
760 try:
761 return func(*args, **kwds)
762 finally:
763 if locale and orig_locale:
764 locale.setlocale(category, orig_locale)
Neal Norwitz221085d2007-02-25 20:55:47 +0000765 inner.__name__ = func.__name__
Thomas Wouters477c8d52006-05-27 19:21:47 +0000766 inner.__doc__ = func.__doc__
767 return inner
768 return decorator
769
770#=======================================================================
Georg Brandldb028442008-02-05 20:48:58 +0000771# Big-memory-test support. Separate from 'resources' because memory use
772# should be configurable.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000773
774# Some handy shorthands. Note that these are used for byte-limits as well
775# as size-limits, in the various bigmem tests
776_1M = 1024*1024
777_1G = 1024 * _1M
778_2G = 2 * _1G
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000779_4G = 4 * _1G
Thomas Wouters477c8d52006-05-27 19:21:47 +0000780
Thomas Woutersd2cf20e2007-08-30 22:57:53 +0000781MAX_Py_ssize_t = sys.maxsize
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000782
Thomas Wouters477c8d52006-05-27 19:21:47 +0000783def set_memlimit(limit):
Thomas Wouters477c8d52006-05-27 19:21:47 +0000784 global max_memuse
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000785 global real_max_memuse
Thomas Wouters477c8d52006-05-27 19:21:47 +0000786 sizes = {
787 'k': 1024,
788 'm': _1M,
789 'g': _1G,
790 't': 1024*_1G,
791 }
792 m = re.match(r'(\d+(\.\d+)?) (K|M|G|T)b?$', limit,
793 re.IGNORECASE | re.VERBOSE)
794 if m is None:
795 raise ValueError('Invalid memory limit %r' % (limit,))
796 memlimit = int(float(m.group(1)) * sizes[m.group(3).lower()])
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000797 real_max_memuse = memlimit
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000798 if memlimit > MAX_Py_ssize_t:
799 memlimit = MAX_Py_ssize_t
800 if memlimit < _2G - 1:
Thomas Wouters477c8d52006-05-27 19:21:47 +0000801 raise ValueError('Memory limit %r too low to be useful' % (limit,))
802 max_memuse = memlimit
803
804def bigmemtest(minsize, memuse, overhead=5*_1M):
805 """Decorator for bigmem tests.
806
807 'minsize' is the minimum useful size for the test (in arbitrary,
808 test-interpreted units.) 'memuse' is the number of 'bytes per size' for
809 the test, or a good estimate of it. 'overhead' specifies fixed overhead,
Christian Heimes33fe8092008-04-13 13:53:33 +0000810 independent of the testsize, and defaults to 5Mb.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000811
812 The decorator tries to guess a good value for 'size' and passes it to
813 the decorated test function. If minsize * memuse is more than the
814 allowed memory use (as defined by max_memuse), the test is skipped.
815 Otherwise, minsize is adjusted upward to use up to max_memuse.
816 """
817 def decorator(f):
818 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000819 # Retrieve values in case someone decided to adjust them
820 minsize = wrapper.minsize
821 memuse = wrapper.memuse
822 overhead = wrapper.overhead
Thomas Wouters477c8d52006-05-27 19:21:47 +0000823 if not max_memuse:
824 # If max_memuse is 0 (the default),
825 # we still want to run the tests with size set to a few kb,
826 # to make sure they work. We still want to avoid using
827 # too much memory, though, but we do that noisily.
828 maxsize = 5147
Benjamin Peterson46d44402009-07-01 00:45:43 +0000829 self.assertFalse(maxsize * memuse + overhead > 20 * _1M)
Thomas Wouters477c8d52006-05-27 19:21:47 +0000830 else:
831 maxsize = int((max_memuse - overhead) / memuse)
832 if maxsize < minsize:
833 # Really ought to print 'test skipped' or something
834 if verbose:
835 sys.stderr.write("Skipping %s because of memory "
836 "constraint\n" % (f.__name__,))
837 return
838 # Try to keep some breathing room in memory use
839 maxsize = max(maxsize - 50 * _1M, minsize)
840 return f(self, maxsize)
841 wrapper.minsize = minsize
842 wrapper.memuse = memuse
843 wrapper.overhead = overhead
844 return wrapper
845 return decorator
846
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000847def precisionbigmemtest(size, memuse, overhead=5*_1M):
848 def decorator(f):
849 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000850 size = wrapper.size
851 memuse = wrapper.memuse
852 overhead = wrapper.overhead
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000853 if not real_max_memuse:
854 maxsize = 5147
855 else:
856 maxsize = size
857
858 if real_max_memuse and real_max_memuse < maxsize * memuse:
859 if verbose:
860 sys.stderr.write("Skipping %s because of memory "
861 "constraint\n" % (f.__name__,))
862 return
863
864 return f(self, maxsize)
865 wrapper.size = size
866 wrapper.memuse = memuse
867 wrapper.overhead = overhead
868 return wrapper
869 return decorator
870
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000871def bigaddrspacetest(f):
872 """Decorator for tests that fill the address space."""
873 def wrapper(self):
874 if max_memuse < MAX_Py_ssize_t:
875 if verbose:
876 sys.stderr.write("Skipping %s because of memory "
877 "constraint\n" % (f.__name__,))
878 else:
879 return f(self)
880 return wrapper
881
Thomas Wouters477c8d52006-05-27 19:21:47 +0000882#=======================================================================
Guido van Rossumd8faa362007-04-27 19:54:29 +0000883# unittest integration.
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000884
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000885class BasicTestRunner:
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000886 def run(self, test):
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000887 result = unittest.TestResult()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000888 test(result)
889 return result
890
Benjamin Petersone549ead2009-03-28 21:42:05 +0000891def _id(obj):
892 return obj
893
894def requires_resource(resource):
895 if resource_is_enabled(resource):
896 return _id
897 else:
898 return unittest.skip("resource {0!r} is not enabled".format(resource))
899
900def cpython_only(test):
901 """
902 Decorator for tests only applicable on CPython.
903 """
904 return impl_detail(cpython=True)(test)
905
906def impl_detail(msg=None, **guards):
907 if check_impl_detail(**guards):
908 return _id
909 if msg is None:
910 guardnames, default = _parse_guards(guards)
911 if default:
912 msg = "implementation detail not available on {0}"
913 else:
914 msg = "implementation detail specific to {0}"
915 guardnames = sorted(guardnames.keys())
916 msg = msg.format(' or '.join(guardnames))
917 return unittest.skip(msg)
918
919def _parse_guards(guards):
920 # Returns a tuple ({platform_name: run_me}, default_value)
921 if not guards:
922 return ({'cpython': True}, False)
Eric Smith886b40a2009-04-26 21:26:45 +0000923 is_true = list(guards.values())[0]
924 assert list(guards.values()) == [is_true] * len(guards) # all True or all False
Benjamin Petersone549ead2009-03-28 21:42:05 +0000925 return (guards, not is_true)
926
927# Use the following check to guard CPython's implementation-specific tests --
928# or to run them only on the implementation(s) guarded by the arguments.
929def check_impl_detail(**guards):
930 """This function returns True or False depending on the host platform.
931 Examples:
932 if check_impl_detail(): # only on CPython (default)
933 if check_impl_detail(jython=True): # only on Jython
934 if check_impl_detail(cpython=False): # everywhere except on CPython
935 """
936 guards, default = _parse_guards(guards)
937 return guards.get(platform.python_implementation().lower(), default)
938
939
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000940
Guido van Rossumd8faa362007-04-27 19:54:29 +0000941def _run_suite(suite):
Barry Warsawc88425e2001-09-20 06:31:22 +0000942 """Run tests from a unittest.TestSuite-derived class."""
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000943 if verbose:
Fred Drake84a59342001-03-23 04:21:17 +0000944 runner = unittest.TextTestRunner(sys.stdout, verbosity=2)
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000945 else:
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000946 runner = BasicTestRunner()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000947
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000948 result = runner.run(suite)
949 if not result.wasSuccessful():
Fred Drake14f6c182001-07-16 18:51:32 +0000950 if len(result.errors) == 1 and not result.failures:
951 err = result.errors[0][1]
952 elif len(result.failures) == 1 and not result.errors:
953 err = result.failures[0][1]
954 else:
R. David Murray723357e2009-10-19 18:06:17 +0000955 err = "multiple errors occurred"
956 if not verbose: err += "; run in verbose mode for details"
Tim Peters2d84f2c2001-09-08 03:37:56 +0000957 raise TestFailed(err)
Tim Petersa0a62222001-09-09 06:12:01 +0000958
Barry Warsawc10d6902001-09-20 06:30:41 +0000959
Walter Dörwald21d3a322003-05-01 17:45:56 +0000960def run_unittest(*classes):
961 """Run tests from unittest.TestCase-derived classes."""
Guido van Rossumd8faa362007-04-27 19:54:29 +0000962 valid_types = (unittest.TestSuite, unittest.TestCase)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000963 suite = unittest.TestSuite()
Walter Dörwald21d3a322003-05-01 17:45:56 +0000964 for cls in classes:
Guido van Rossum3172c5d2007-10-16 18:12:55 +0000965 if isinstance(cls, str):
Guido van Rossumd8faa362007-04-27 19:54:29 +0000966 if cls in sys.modules:
967 suite.addTest(unittest.findTestCases(sys.modules[cls]))
968 else:
969 raise ValueError("str arguments must be keys in sys.modules")
970 elif isinstance(cls, valid_types):
Raymond Hettinger21d99872003-07-16 02:59:32 +0000971 suite.addTest(cls)
972 else:
973 suite.addTest(unittest.makeSuite(cls))
Guido van Rossumd8faa362007-04-27 19:54:29 +0000974 _run_suite(suite)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000975
Barry Warsawc10d6902001-09-20 06:30:41 +0000976
Tim Petersa0a62222001-09-09 06:12:01 +0000977#=======================================================================
978# doctest driver.
979
980def run_doctest(module, verbosity=None):
Tim Peters17111f32001-10-03 04:08:26 +0000981 """Run doctest on the given module. Return (#failures, #tests).
Tim Petersa0a62222001-09-09 06:12:01 +0000982
983 If optional argument verbosity is not specified (or is None), pass
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000984 support's belief about verbosity on to doctest. Else doctest's
Tim Petersbea3fb82001-09-10 01:39:21 +0000985 usual behavior is used (it searches sys.argv for -v).
Tim Petersa0a62222001-09-09 06:12:01 +0000986 """
987
988 import doctest
989
990 if verbosity is None:
991 verbosity = verbose
992 else:
993 verbosity = None
994
Tim Peters342ca752001-09-25 19:13:20 +0000995 # Direct doctest output (normally just errors) to real stdout; doctest
996 # output shouldn't be compared by regrtest.
997 save_stdout = sys.stdout
Tim Peters8dee8092001-09-25 20:05:11 +0000998 sys.stdout = get_original_stdout()
Tim Peters342ca752001-09-25 19:13:20 +0000999 try:
1000 f, t = doctest.testmod(module, verbose=verbosity)
1001 if f:
1002 raise TestFailed("%d of %d doctests failed" % (f, t))
1003 finally:
1004 sys.stdout = save_stdout
Raymond Hettinger35b34bd2003-05-17 00:58:33 +00001005 if verbose:
Georg Brandldb028442008-02-05 20:48:58 +00001006 print('doctest (%s) ... %d tests with zero failures' %
1007 (module.__name__, t))
Raymond Hettinger35b34bd2003-05-17 00:58:33 +00001008 return f, t
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001009
Antoine Pitrou060cee22009-11-13 16:29:04 +00001010
1011#=======================================================================
1012# Support for saving and restoring the imported modules.
1013
1014def modules_setup():
1015 return sys.modules.copy(),
1016
1017def modules_cleanup(oldmodules):
1018 # Encoders/decoders are registered permanently within the internal
1019 # codec cache. If we destroy the corresponding modules their
1020 # globals will be set to None which will trip up the cached functions.
1021 encodings = [(k, v) for k, v in sys.modules.items()
1022 if k.startswith('encodings.')]
1023 sys.modules.clear()
1024 sys.modules.update(encodings)
1025 sys.modules.update(oldmodules)
1026
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001027#=======================================================================
1028# Threading support to prevent reporting refleaks when running regrtest.py -R
1029
Antoine Pitrou65c9c642009-10-30 17:25:12 +00001030# NOTE: we use thread._count() rather than threading.enumerate() (or the
1031# moral equivalent thereof) because a threading.Thread object is still alive
1032# until its __bootstrap() method has returned, even after it has been
1033# unregistered from the threading module.
1034# thread._count(), on the other hand, only gets decremented *after* the
1035# __bootstrap() method has returned, which gives us reliable reference counts
1036# at the end of a test run.
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001037
Antoine Pitrou65c9c642009-10-30 17:25:12 +00001038def threading_setup():
1039 import _thread
1040 return _thread._count(),
1041
1042def threading_cleanup(nb_threads):
1043 import _thread
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001044 import time
1045
1046 _MAX_COUNT = 10
Antoine Pitrou65c9c642009-10-30 17:25:12 +00001047 for count in range(_MAX_COUNT):
1048 n = _thread._count()
1049 if n == nb_threads:
1050 break
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001051 time.sleep(0.1)
Antoine Pitrou65c9c642009-10-30 17:25:12 +00001052 # XXX print a warning in case of failure?
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001053
Benjamin Petersonfa0d7032009-06-01 22:42:33 +00001054def reap_threads(func):
1055 @functools.wraps(func)
1056 def decorator(*args):
1057 key = threading_setup()
1058 try:
1059 return func(*args)
1060 finally:
1061 threading_cleanup(*key)
1062 return decorator
1063
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001064def reap_children():
1065 """Use this function at the end of test_main() whenever sub-processes
1066 are started. This will help ensure that no extra children (zombies)
1067 stick around to hog resources and create problems when looking
1068 for refleaks.
1069 """
1070
1071 # Reap all our dead child processes so we don't leave zombies around.
1072 # These hog resources and might be causing some of the buildbots to die.
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001073 if hasattr(os, 'waitpid'):
1074 any_process = -1
1075 while True:
1076 try:
1077 # This will raise an exception on Windows. That's ok.
1078 pid, status = os.waitpid(any_process, os.WNOHANG)
1079 if pid == 0:
1080 break
1081 except:
1082 break
Collin Winterf2bf2b32010-03-17 00:41:56 +00001083
1084@contextlib.contextmanager
1085def swap_attr(obj, attr, new_val):
1086 """Temporary swap out an attribute with a new object.
1087
1088 Usage:
1089 with swap_attr(obj, "attr", 5):
1090 ...
1091
1092 This will set obj.attr to 5 for the duration of the with: block,
1093 restoring the old value at the end of the block. If `attr` doesn't
1094 exist on `obj`, it will be created and then deleted at the end of the
1095 block.
1096 """
1097 if hasattr(obj, attr):
1098 real_val = getattr(obj, attr)
1099 setattr(obj, attr, new_val)
1100 try:
1101 yield
1102 finally:
1103 setattr(obj, attr, real_val)
1104 else:
1105 setattr(obj, attr, new_val)
1106 try:
1107 yield
1108 finally:
1109 delattr(obj, attr)
1110
1111@contextlib.contextmanager
1112def swap_item(obj, item, new_val):
1113 """Temporary swap out an item with a new object.
1114
1115 Usage:
1116 with swap_item(obj, "item", 5):
1117 ...
1118
1119 This will set obj["item"] to 5 for the duration of the with: block,
1120 restoring the old value at the end of the block. If `item` doesn't
1121 exist on `obj`, it will be created and then deleted at the end of the
1122 block.
1123 """
1124 if item in obj:
1125 real_val = obj[item]
1126 obj[item] = new_val
1127 try:
1128 yield
1129 finally:
1130 obj[item] = real_val
1131 else:
1132 obj[item] = new_val
1133 try:
1134 yield
1135 finally:
1136 del obj[item]