blob: 5dd8017a54d16a5dcd3b453c190bdef34d7c0e15 [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
Antoine Pitrouf50a6b62011-01-03 18:36:36 +000013import re
Benjamin Petersone549ead2009-03-28 21:42:05 +000014import platform
Christian Heimes23daade02008-02-25 12:39:23 +000015import shutil
Thomas Wouters902d6eb2007-01-09 23:18:33 +000016import warnings
Guido van Rossumd8faa362007-04-27 19:54:29 +000017import unittest
R. David Murraya21e4ca2009-03-31 23:16:50 +000018import importlib
Walter Dörwald155374d2009-05-01 19:58:58 +000019import collections
Fred Drakecd1b1dd2001-03-21 18:26:33 +000020
Antoine Pitrou4d7979b2010-09-07 21:22:56 +000021__all__ = [
22 "Error", "TestFailed", "ResourceDenied", "import_module",
23 "verbose", "use_resources", "max_memuse", "record_original_stdout",
24 "get_original_stdout", "unload", "unlink", "rmtree", "forget",
25 "is_resource_enabled", "requires", "find_unused_port", "bind_port",
26 "fcmp", "is_jython", "TESTFN", "HOST", "FUZZ", "findfile", "verify",
27 "vereq", "sortdict", "check_syntax_error", "open_urlresource",
28 "check_warnings", "CleanImport", "EnvironmentVarGuard",
29 "TransientResource", "captured_output", "captured_stdout",
30 "time_out", "socket_peer_reset", "ioerror_peer_reset",
31 "run_with_locale", "transient_internet",
32 "set_memlimit", "bigmemtest", "bigaddrspacetest", "BasicTestRunner",
33 "run_unittest", "run_doctest", "threading_setup", "threading_cleanup",
34 "reap_children", "cpython_only", "check_impl_detail", "get_attribute",
35 ]
Benjamin Peterson744c2cd2008-05-26 16:26:37 +000036
Fred Drake1790dd42000-07-24 06:55:00 +000037class Error(Exception):
Fred Drake004d5e62000-10-23 17:22:08 +000038 """Base class for regression test exceptions."""
Fred Drake1790dd42000-07-24 06:55:00 +000039
40class TestFailed(Error):
Fred Drake004d5e62000-10-23 17:22:08 +000041 """Test failed."""
Fred Drake1790dd42000-07-24 06:55:00 +000042
Benjamin Petersone549ead2009-03-28 21:42:05 +000043class ResourceDenied(unittest.SkipTest):
Fred Drake9a0db072003-02-03 15:19:30 +000044 """Test skipped because it requested a disallowed resource.
45
46 This is raised when a test calls requires() for a resource that
47 has not be enabled. It is used to distinguish between expected
48 and unexpected skips.
49 """
50
Nick Coghlanfce769e2009-04-11 14:30:59 +000051@contextlib.contextmanager
52def _ignore_deprecated_imports(ignore=True):
53 """Context manager to suppress package and module deprecation
54 warnings when importing them.
55
56 If ignore is False, this context manager has no effect."""
57 if ignore:
58 with warnings.catch_warnings():
59 warnings.filterwarnings("ignore", ".+ (module|package)",
60 DeprecationWarning)
61 yield
62 else:
63 yield
64
65
Benjamin Peterson699adb92008-05-08 22:27:58 +000066def import_module(name, deprecated=False):
R. David Murraya21e4ca2009-03-31 23:16:50 +000067 """Import and return the module to be tested, raising SkipTest if
68 it is not available.
69
70 If deprecated is True, any module or package deprecation messages
71 will be suppressed."""
Nick Coghlanfce769e2009-04-11 14:30:59 +000072 with _ignore_deprecated_imports(deprecated):
Benjamin Peterson699adb92008-05-08 22:27:58 +000073 try:
Nick Coghlanfce769e2009-04-11 14:30:59 +000074 return importlib.import_module(name)
R. David Murraya21e4ca2009-03-31 23:16:50 +000075 except ImportError as msg:
76 raise unittest.SkipTest(str(msg))
Nick Coghlanfce769e2009-04-11 14:30:59 +000077
78
Nick Coghlan47384702009-04-22 16:13:36 +000079def _save_and_remove_module(name, orig_modules):
80 """Helper function to save and remove a module from sys.modules
81
82 Return value is True if the module was in sys.modules and
83 False otherwise."""
84 saved = True
85 try:
86 orig_modules[name] = sys.modules[name]
87 except KeyError:
88 saved = False
89 else:
90 del sys.modules[name]
91 return saved
92
93
94def _save_and_block_module(name, orig_modules):
95 """Helper function to save and block a module in sys.modules
96
97 Return value is True if the module was in sys.modules and
98 False otherwise."""
99 saved = True
100 try:
101 orig_modules[name] = sys.modules[name]
102 except KeyError:
103 saved = False
Alexander Belopolsky0a5d9a22010-07-13 14:55:04 +0000104 sys.modules[name] = None
Nick Coghlan47384702009-04-22 16:13:36 +0000105 return saved
106
107
108def import_fresh_module(name, fresh=(), blocked=(), deprecated=False):
Nick Coghlanfce769e2009-04-11 14:30:59 +0000109 """Imports and returns a module, deliberately bypassing the sys.modules cache
110 and importing a fresh copy of the module. Once the import is complete,
111 the sys.modules cache is restored to its original state.
112
Nick Coghlan47384702009-04-22 16:13:36 +0000113 Modules named in fresh are also imported anew if needed by the import.
114
115 Importing of modules named in blocked is prevented while the fresh import
Nick Coghlanfce769e2009-04-11 14:30:59 +0000116 takes place.
117
118 If deprecated is True, any module or package deprecation messages
119 will be suppressed."""
120 # NOTE: test_heapq and test_warnings include extra sanity checks to make
121 # sure that this utility function is working as expected
122 with _ignore_deprecated_imports(deprecated):
Nick Coghlan47384702009-04-22 16:13:36 +0000123 # Keep track of modules saved for later restoration as well
124 # as those which just need a blocking entry removed
Nick Coghlanfce769e2009-04-11 14:30:59 +0000125 orig_modules = {}
Nick Coghlan47384702009-04-22 16:13:36 +0000126 names_to_remove = []
127 _save_and_remove_module(name, orig_modules)
Nick Coghlanfce769e2009-04-11 14:30:59 +0000128 try:
Nick Coghlan47384702009-04-22 16:13:36 +0000129 for fresh_name in fresh:
130 _save_and_remove_module(fresh_name, orig_modules)
131 for blocked_name in blocked:
132 if not _save_and_block_module(blocked_name, orig_modules):
133 names_to_remove.append(blocked_name)
134 fresh_module = importlib.import_module(name)
Nick Coghlanfce769e2009-04-11 14:30:59 +0000135 finally:
Nick Coghlan47384702009-04-22 16:13:36 +0000136 for orig_name, module in orig_modules.items():
137 sys.modules[orig_name] = module
138 for name_to_remove in names_to_remove:
139 del sys.modules[name_to_remove]
140 return fresh_module
Nick Coghlanfce769e2009-04-11 14:30:59 +0000141
Benjamin Peterson699adb92008-05-08 22:27:58 +0000142
R. David Murraya21e4ca2009-03-31 23:16:50 +0000143def get_attribute(obj, name):
144 """Get an attribute, raising SkipTest if AttributeError is raised."""
145 try:
146 attribute = getattr(obj, name)
147 except AttributeError:
148 raise unittest.SkipTest("module %s has no attribute %s" % (
149 obj.__name__, name))
150 else:
151 return attribute
152
Barry Warsawc0fb6052001-08-20 22:29:23 +0000153verbose = 1 # Flag set to 0 by regrtest.py
Thomas Wouters477c8d52006-05-27 19:21:47 +0000154use_resources = None # Flag set to [] by regrtest.py
155max_memuse = 0 # Disable bigmem tests (they will still be run with
156 # small sizes, to make sure they work.)
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000157real_max_memuse = 0
Guido van Rossum531661c1996-12-20 02:58:22 +0000158
Tim Peters8dee8092001-09-25 20:05:11 +0000159# _original_stdout is meant to hold stdout at the time regrtest began.
160# This may be "the real" stdout, or IDLE's emulation of stdout, or whatever.
161# The point is to have some flavor of stdout the user can actually see.
162_original_stdout = None
163def record_original_stdout(stdout):
164 global _original_stdout
165 _original_stdout = stdout
166
167def get_original_stdout():
168 return _original_stdout or sys.stdout
169
Guido van Rossum3bead091992-01-27 17:00:37 +0000170def unload(name):
Fred Drake004d5e62000-10-23 17:22:08 +0000171 try:
172 del sys.modules[name]
173 except KeyError:
174 pass
Guido van Rossum3bead091992-01-27 17:00:37 +0000175
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000176def unlink(filename):
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000177 try:
178 os.unlink(filename)
179 except OSError:
180 pass
181
Christian Heimes23daade02008-02-25 12:39:23 +0000182def rmtree(path):
183 try:
184 shutil.rmtree(path)
185 except OSError as e:
186 # Unix returns ENOENT, Windows returns ESRCH.
187 if e.errno not in (errno.ENOENT, errno.ESRCH):
188 raise
189
Guido van Rossum3bead091992-01-27 17:00:37 +0000190def forget(modname):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000191 '''"Forget" a module was ever imported by removing it from sys.modules and
192 deleting any .pyc and .pyo files.'''
Fred Drake004d5e62000-10-23 17:22:08 +0000193 unload(modname)
Fred Drake004d5e62000-10-23 17:22:08 +0000194 for dirname in sys.path:
Skip Montanaro7a98be22007-08-16 14:35:24 +0000195 unlink(os.path.join(dirname, modname + '.pyc'))
Brett Cannonf1cfb622003-05-04 21:15:27 +0000196 # Deleting the .pyo file cannot be within the 'try' for the .pyc since
197 # the chance exists that there is no .pyc (and thus the 'try' statement
198 # is exited) but there is a .pyo file.
Skip Montanaro7a98be22007-08-16 14:35:24 +0000199 unlink(os.path.join(dirname, modname + '.pyo'))
Guido van Rossum3bead091992-01-27 17:00:37 +0000200
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000201def is_resource_enabled(resource):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000202 """Test whether a resource is enabled. Known resources are set by
203 regrtest.py."""
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000204 return use_resources is not None and resource in use_resources
205
Barry Warsawc0fb6052001-08-20 22:29:23 +0000206def requires(resource, msg=None):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000207 """Raise ResourceDenied if the specified resource is not available.
208
209 If the caller's module is __main__ then automatically return True. The
210 possibility of False being returned occurs when regrtest.py is executing."""
Skip Montanarod839ecd2003-04-24 19:06:57 +0000211 # see if the caller's module is __main__ - if so, treat as if
212 # the resource was set
Benjamin Petersone549ead2009-03-28 21:42:05 +0000213 if sys._getframe(1).f_globals.get("__name__") == "__main__":
Skip Montanarod839ecd2003-04-24 19:06:57 +0000214 return
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000215 if not is_resource_enabled(resource):
Barry Warsawc0fb6052001-08-20 22:29:23 +0000216 if msg is None:
217 msg = "Use of the `%s' resource not enabled" % resource
Fred Drake9a0db072003-02-03 15:19:30 +0000218 raise ResourceDenied(msg)
Barry Warsawc0fb6052001-08-20 22:29:23 +0000219
Christian Heimes5e696852008-04-09 08:37:03 +0000220HOST = 'localhost'
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000221
Christian Heimes5e696852008-04-09 08:37:03 +0000222def find_unused_port(family=socket.AF_INET, socktype=socket.SOCK_STREAM):
223 """Returns an unused port that should be suitable for binding. This is
224 achieved by creating a temporary socket with the same family and type as
225 the 'sock' parameter (default is AF_INET, SOCK_STREAM), and binding it to
226 the specified host address (defaults to 0.0.0.0) with the port set to 0,
227 eliciting an unused ephemeral port from the OS. The temporary socket is
228 then closed and deleted, and the ephemeral port is returned.
229
230 Either this method or bind_port() should be used for any tests where a
231 server socket needs to be bound to a particular port for the duration of
232 the test. Which one to use depends on whether the calling code is creating
233 a python socket, or if an unused port needs to be provided in a constructor
234 or passed to an external program (i.e. the -accept argument to openssl's
235 s_server mode). Always prefer bind_port() over find_unused_port() where
236 possible. Hard coded ports should *NEVER* be used. As soon as a server
237 socket is bound to a hard coded port, the ability to run multiple instances
238 of the test simultaneously on the same host is compromised, which makes the
239 test a ticking time bomb in a buildbot environment. On Unix buildbots, this
240 may simply manifest as a failed test, which can be recovered from without
241 intervention in most cases, but on Windows, the entire python process can
242 completely and utterly wedge, requiring someone to log in to the buildbot
243 and manually kill the affected process.
244
245 (This is easy to reproduce on Windows, unfortunately, and can be traced to
246 the SO_REUSEADDR socket option having different semantics on Windows versus
247 Unix/Linux. On Unix, you can't have two AF_INET SOCK_STREAM sockets bind,
248 listen and then accept connections on identical host/ports. An EADDRINUSE
249 socket.error will be raised at some point (depending on the platform and
250 the order bind and listen were called on each socket).
251
252 However, on Windows, if SO_REUSEADDR is set on the sockets, no EADDRINUSE
253 will ever be raised when attempting to bind two identical host/ports. When
254 accept() is called on each socket, the second caller's process will steal
255 the port from the first caller, leaving them both in an awkwardly wedged
256 state where they'll no longer respond to any signals or graceful kills, and
257 must be forcibly killed via OpenProcess()/TerminateProcess().
258
259 The solution on Windows is to use the SO_EXCLUSIVEADDRUSE socket option
260 instead of SO_REUSEADDR, which effectively affords the same semantics as
261 SO_REUSEADDR on Unix. Given the propensity of Unix developers in the Open
262 Source world compared to Windows ones, this is a common mistake. A quick
263 look over OpenSSL's 0.9.8g source shows that they use SO_REUSEADDR when
264 openssl.exe is called with the 's_server' option, for example. See
265 http://bugs.python.org/issue2550 for more info. The following site also
266 has a very thorough description about the implications of both REUSEADDR
267 and EXCLUSIVEADDRUSE on Windows:
268 http://msdn2.microsoft.com/en-us/library/ms740621(VS.85).aspx)
269
270 XXX: although this approach is a vast improvement on previous attempts to
271 elicit unused ports, it rests heavily on the assumption that the ephemeral
272 port returned to us by the OS won't immediately be dished back out to some
273 other process when we close and delete our temporary socket but before our
274 calling code has a chance to bind the returned port. We can deal with this
275 issue if/when we come across it.
276 """
277
278 tempsock = socket.socket(family, socktype)
279 port = bind_port(tempsock)
280 tempsock.close()
281 del tempsock
282 return port
283
284def bind_port(sock, host=HOST):
285 """Bind the socket to a free port and return the port number. Relies on
286 ephemeral ports in order to ensure we are using an unbound port. This is
287 important as many tests may be running simultaneously, especially in a
288 buildbot environment. This method raises an exception if the sock.family
289 is AF_INET and sock.type is SOCK_STREAM, *and* the socket has SO_REUSEADDR
290 or SO_REUSEPORT set on it. Tests should *never* set these socket options
291 for TCP/IP sockets. The only case for setting these options is testing
292 multicasting via multiple UDP sockets.
293
294 Additionally, if the SO_EXCLUSIVEADDRUSE socket option is available (i.e.
295 on Windows), it will be set on the socket. This will prevent anyone else
296 from bind()'ing to our host/port for the duration of the test.
297 """
298
299 if sock.family == socket.AF_INET and sock.type == socket.SOCK_STREAM:
300 if hasattr(socket, 'SO_REUSEADDR'):
301 if sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR) == 1:
302 raise TestFailed("tests should never set the SO_REUSEADDR " \
303 "socket option on TCP/IP sockets!")
304 if hasattr(socket, 'SO_REUSEPORT'):
305 if sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEPORT) == 1:
306 raise TestFailed("tests should never set the SO_REUSEPORT " \
307 "socket option on TCP/IP sockets!")
308 if hasattr(socket, 'SO_EXCLUSIVEADDRUSE'):
309 sock.setsockopt(socket.SOL_SOCKET, socket.SO_EXCLUSIVEADDRUSE, 1)
310
311 sock.bind((host, 0))
312 port = sock.getsockname()[1]
313 return port
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000314
Guido van Rossum35fb82a1993-01-26 13:04:43 +0000315FUZZ = 1e-6
316
317def fcmp(x, y): # fuzzy comparison function
Neal Norwitz79212992006-08-21 16:27:31 +0000318 if isinstance(x, float) or isinstance(y, float):
Fred Drake004d5e62000-10-23 17:22:08 +0000319 try:
Fred Drake004d5e62000-10-23 17:22:08 +0000320 fuzz = (abs(x) + abs(y)) * FUZZ
321 if abs(x-y) <= fuzz:
322 return 0
323 except:
324 pass
Neal Norwitz79212992006-08-21 16:27:31 +0000325 elif type(x) == type(y) and isinstance(x, (tuple, list)):
Fred Drake004d5e62000-10-23 17:22:08 +0000326 for i in range(min(len(x), len(y))):
327 outcome = fcmp(x[i], y[i])
Fred Drake132dce22000-12-12 23:11:42 +0000328 if outcome != 0:
Fred Drake004d5e62000-10-23 17:22:08 +0000329 return outcome
Guido van Rossum47b9ff62006-08-24 00:41:19 +0000330 return (len(x) > len(y)) - (len(x) < len(y))
331 return (x > y) - (x < y)
Guido van Rossum35fb82a1993-01-26 13:04:43 +0000332
Finn Bock57bc5fa2002-11-01 18:02:03 +0000333is_jython = sys.platform.startswith('java')
334
Barry Warsaw559f6682001-03-23 18:04:02 +0000335# Filename used for testing
336if os.name == 'java':
337 # Jython disallows @ in module names
338 TESTFN = '$test'
Martin v. Löwisa94568a2003-05-10 07:36:56 +0000339else:
Barry Warsaw559f6682001-03-23 18:04:02 +0000340 TESTFN = '@test'
Walter Dörwald9b775532007-06-08 14:30:53 +0000341
342 # Assuming sys.getfilesystemencoding()!=sys.getdefaultencoding()
343 # TESTFN_UNICODE is a filename that can be encoded using the
344 # file system encoding, but *not* with the default (ascii) encoding
345 TESTFN_UNICODE = "@test-\xe0\xf2"
346 TESTFN_ENCODING = sys.getfilesystemencoding()
Victor Stinner0ea31a92010-09-10 12:32:58 +0000347 # TESTFN_UNENCODABLE is a filename that should *not* be
Walter Dörwald9b775532007-06-08 14:30:53 +0000348 # able to be encoded by *either* the default or filesystem encoding.
349 # This test really only makes sense on Windows NT platforms
350 # which have special Unicode support in posixmodule.
351 if (not hasattr(sys, "getwindowsversion") or
352 sys.getwindowsversion()[3] < 2): # 0=win32s or 1=9x/ME
Victor Stinner0ea31a92010-09-10 12:32:58 +0000353 TESTFN_UNENCODABLE = None
Walter Dörwald9b775532007-06-08 14:30:53 +0000354 else:
Victor Stinner0d823ed2010-09-10 12:19:37 +0000355 # Different kinds of characters from various languages to minimize the
356 # probability that the whole name is encodable to MBCS (issue #9819)
357 TESTFN_UNENCODABLE = TESTFN + "-\u5171\u0141\u2661\u0363\uDC80"
Walter Dörwald9b775532007-06-08 14:30:53 +0000358 try:
359 # XXX - Note - should be using TESTFN_ENCODING here - but for
360 # Windows, "mbcs" currently always operates as if in
361 # errors=ignore' mode - hence we get '?' characters rather than
362 # the exception. 'Latin1' operates as we expect - ie, fails.
363 # See [ 850997 ] mbcs encoding ignores errors
Victor Stinner0ea31a92010-09-10 12:32:58 +0000364 TESTFN_UNENCODABLE.encode("Latin1")
Walter Dörwald9b775532007-06-08 14:30:53 +0000365 except UnicodeEncodeError:
366 pass
Martin v. Löwis2411a2d2002-11-09 19:57:26 +0000367 else:
Georg Brandldb028442008-02-05 20:48:58 +0000368 print('WARNING: The filename %r CAN be encoded by the filesystem. '
369 'Unicode filename tests may not be effective'
Victor Stinner0ea31a92010-09-10 12:32:58 +0000370 % TESTFN_UNENCODABLE)
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000371
Victor Stinner7f6423a2010-05-14 20:08:55 +0000372if os.path.isdir(TESTFN):
373 # a test failed (eg. test_os) without removing TESTFN directory
374 shutil.rmtree(TESTFN)
375
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000376# Make sure we can write to TESTFN, try in /tmp if we can't
377fp = None
378try:
379 fp = open(TESTFN, 'w+')
380except IOError:
381 TMP_TESTFN = os.path.join('/tmp', TESTFN)
382 try:
383 fp = open(TMP_TESTFN, 'w+')
384 TESTFN = TMP_TESTFN
385 del TMP_TESTFN
386 except IOError:
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000387 print(('WARNING: tests will fail, unable to write to: %s or %s' %
388 (TESTFN, TMP_TESTFN)))
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000389if fp is not None:
390 fp.close()
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000391 unlink(TESTFN)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000392del fp
Guido van Rossuma8f7e592001-03-13 09:31:07 +0000393
Victor Stinner3f682ad2010-07-13 23:14:46 +0000394def findfile(file, here=__file__, subdir=None):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000395 """Try to find a file on sys.path and the working directory. If it is not
396 found the argument passed to the function is returned (this does not
397 necessarily signal failure; could still be the legitimate path)."""
Fred Drake004d5e62000-10-23 17:22:08 +0000398 if os.path.isabs(file):
399 return file
Victor Stinner3f682ad2010-07-13 23:14:46 +0000400 if subdir is not None:
401 file = os.path.join(subdir, file)
Fred Drake004d5e62000-10-23 17:22:08 +0000402 path = sys.path
403 path = [os.path.dirname(here)] + path
404 for dn in path:
405 fn = os.path.join(dn, file)
406 if os.path.exists(fn): return fn
407 return file
Marc-André Lemburg36619082001-01-17 19:11:13 +0000408
Ezio Melotti2aef4b82010-01-25 12:20:04 +0000409def verify(condition, reason='test failed'):
410 """Verify that condition is true. If not, raise TestFailed.
411
412 The optional argument reason can be given to provide
413 a better error text.
414 """
415
416 if not condition:
417 raise TestFailed(reason)
418
419def vereq(a, b):
420 """Raise TestFailed if a == b is false.
421
422 This is better than verify(a == b) because, in case of failure, the
423 error message incorporates repr(a) and repr(b) so you can see the
424 inputs.
425
426 Note that "not (a == b)" isn't necessarily the same as "a != b"; the
427 former is tested.
428 """
429
430 if not (a == b):
431 raise TestFailed("%r == %r" % (a, b))
432
Tim Peters2f228e72001-05-13 00:19:31 +0000433def sortdict(dict):
434 "Like repr(dict), but in sorted order."
Guido van Rossumcc2b0162007-02-11 06:12:03 +0000435 items = sorted(dict.items())
Tim Peters2f228e72001-05-13 00:19:31 +0000436 reprpairs = ["%r: %r" % pair for pair in items]
437 withcommas = ", ".join(reprpairs)
438 return "{%s}" % withcommas
439
Benjamin Peterson7522c742009-01-19 21:00:09 +0000440def make_bad_fd():
441 """
442 Create an invalid file descriptor by opening and closing a file and return
443 its fd.
444 """
445 file = open(TESTFN, "wb")
446 try:
447 return file.fileno()
448 finally:
449 file.close()
450 unlink(TESTFN)
451
Thomas Wouters89f507f2006-12-13 04:49:30 +0000452def check_syntax_error(testcase, statement):
Benjamin Petersone549ead2009-03-28 21:42:05 +0000453 testcase.assertRaises(SyntaxError, compile, statement,
454 '<test string>', 'exec')
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000455
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000456def open_urlresource(url, *args, **kw):
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000457 import urllib.request, urllib.parse
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000458
Guido van Rossum360e4b82007-05-14 22:51:27 +0000459 requires('urlfetch')
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000460 filename = urllib.parse.urlparse(url)[2].split('/')[-1] # '/': it's URL!
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000461
462 for path in [os.path.curdir, os.path.pardir]:
463 fn = os.path.join(path, filename)
464 if os.path.exists(fn):
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000465 return open(fn, *args, **kw)
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000466
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000467 print('\tfetching %s ...' % url, file=get_original_stdout())
Antoine Pitrouec416612009-11-01 22:28:14 +0000468 f = urllib.request.urlopen(url, timeout=15)
469 try:
470 with open(filename, "wb") as out:
471 s = f.read()
472 while s:
473 out.write(s)
474 s = f.read()
475 finally:
476 f.close()
477 return open(filename, *args, **kw)
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000478
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000479class WarningsRecorder(object):
480 """Convenience wrapper for the warnings list returned on
481 entry to the warnings.catch_warnings() context manager.
Guido van Rossumd8faa362007-04-27 19:54:29 +0000482 """
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000483 def __init__(self, warnings_list):
484 self.warnings = warnings_list
485
486 def __getattr__(self, attr):
487 if self.warnings:
488 return getattr(self.warnings[-1], attr)
489 elif attr in warnings.WarningMessage._WARNING_DETAILS:
490 return None
491 raise AttributeError("%r has no attribute %r" % (self, attr))
492
493 def reset(self):
494 del self.warnings[:]
495
496@contextlib.contextmanager
497def check_warnings():
498 with warnings.catch_warnings(record=True) as w:
499 yield WarningsRecorder(w)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000500
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000501
502class CleanImport(object):
503 """Context manager to force import to return a new module reference.
504
505 This is useful for testing module-level behaviours, such as
Nick Coghlanb1304932008-07-13 12:25:08 +0000506 the emission of a DeprecationWarning on import.
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000507
508 Use like this:
509
510 with CleanImport("foo"):
511 __import__("foo") # new reference
512 """
513
514 def __init__(self, *module_names):
515 self.original_modules = sys.modules.copy()
516 for module_name in module_names:
517 if module_name in sys.modules:
518 module = sys.modules[module_name]
519 # It is possible that module_name is just an alias for
520 # another module (e.g. stub for modules renamed in 3.x).
521 # In that case, we also need delete the real module to clear
522 # the import cache.
523 if module.__name__ != module_name:
524 del sys.modules[module.__name__]
525 del sys.modules[module_name]
526
527 def __enter__(self):
528 return self
529
530 def __exit__(self, *ignore_exc):
531 sys.modules.update(self.original_modules)
532
533
Walter Dörwald155374d2009-05-01 19:58:58 +0000534class EnvironmentVarGuard(collections.MutableMapping):
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000535
536 """Class to help protect the environment variable properly. Can be used as
537 a context manager."""
538
539 def __init__(self):
Walter Dörwald155374d2009-05-01 19:58:58 +0000540 self._environ = os.environ
Walter Dörwald4ba80132009-04-25 12:48:43 +0000541 self._changed = {}
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000542
Walter Dörwald155374d2009-05-01 19:58:58 +0000543 def __getitem__(self, envvar):
544 return self._environ[envvar]
545
546 def __setitem__(self, envvar, value):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000547 # Remember the initial value on the first access
548 if envvar not in self._changed:
Walter Dörwald155374d2009-05-01 19:58:58 +0000549 self._changed[envvar] = self._environ.get(envvar)
550 self._environ[envvar] = value
551
552 def __delitem__(self, envvar):
553 # Remember the initial value on the first access
554 if envvar not in self._changed:
555 self._changed[envvar] = self._environ.get(envvar)
556 if envvar in self._environ:
557 del self._environ[envvar]
558
559 def keys(self):
560 return self._environ.keys()
561
562 def __iter__(self):
563 return iter(self._environ)
564
565 def __len__(self):
566 return len(self._environ)
567
568 def set(self, envvar, value):
569 self[envvar] = value
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000570
571 def unset(self, envvar):
Walter Dörwald155374d2009-05-01 19:58:58 +0000572 del self[envvar]
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000573
574 def __enter__(self):
575 return self
576
577 def __exit__(self, *ignore_exc):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000578 for (k, v) in self._changed.items():
579 if v is None:
Walter Dörwald155374d2009-05-01 19:58:58 +0000580 if k in self._environ:
581 del self._environ[k]
Walter Dörwald4ba80132009-04-25 12:48:43 +0000582 else:
Walter Dörwald155374d2009-05-01 19:58:58 +0000583 self._environ[k] = v
584
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000585
Guido van Rossumd8faa362007-04-27 19:54:29 +0000586class TransientResource(object):
587
588 """Raise ResourceDenied if an exception is raised while the context manager
589 is in effect that matches the specified exception and attributes."""
590
591 def __init__(self, exc, **kwargs):
592 self.exc = exc
593 self.attrs = kwargs
594
595 def __enter__(self):
596 return self
597
598 def __exit__(self, type_=None, value=None, traceback=None):
599 """If type_ is a subclass of self.exc and value has attributes matching
600 self.attrs, raise ResourceDenied. Otherwise let the exception
601 propagate (if any)."""
602 if type_ is not None and issubclass(self.exc, type_):
603 for attr, attr_value in self.attrs.items():
604 if not hasattr(value, attr):
605 break
606 if getattr(value, attr) != attr_value:
607 break
608 else:
609 raise ResourceDenied("an optional resource is not available")
610
Raymond Hettinger686057b2009-06-04 00:11:54 +0000611# Context managers that raise ResourceDenied when various issues
612# with the Internet connection manifest themselves as exceptions.
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000613# XXX deprecate these and use transient_internet() instead
Raymond Hettinger686057b2009-06-04 00:11:54 +0000614time_out = TransientResource(IOError, errno=errno.ETIMEDOUT)
615socket_peer_reset = TransientResource(socket.error, errno=errno.ECONNRESET)
616ioerror_peer_reset = TransientResource(IOError, errno=errno.ECONNRESET)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000617
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000618
Thomas Woutersed03b412007-08-28 21:37:11 +0000619@contextlib.contextmanager
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000620def transient_internet(resource_name, *, timeout=30.0, errnos=()):
Antoine Pitrouda6902c2010-04-21 19:52:52 +0000621 """Return a context manager that raises ResourceDenied when various issues
622 with the Internet connection manifest themselves as exceptions."""
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000623 default_errnos = [
624 ('ECONNREFUSED', 111),
625 ('ECONNRESET', 104),
Antoine Pitrou50778ab2011-01-08 10:31:09 +0000626 ('EHOSTUNREACH', 113),
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000627 ('ENETUNREACH', 101),
628 ('ETIMEDOUT', 110),
629 ]
Antoine Pitroudae0c632010-09-07 21:44:17 +0000630 default_gai_errnos = [
631 ('EAI_NONAME', -2),
632 ('EAI_NODATA', -5),
633 ]
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000634
635 denied = ResourceDenied("Resource '%s' is not available" % resource_name)
636 captured_errnos = errnos
Antoine Pitroudae0c632010-09-07 21:44:17 +0000637 gai_errnos = []
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000638 if not captured_errnos:
639 captured_errnos = [getattr(errno, name, num)
640 for (name, num) in default_errnos]
Antoine Pitroudae0c632010-09-07 21:44:17 +0000641 gai_errnos = [getattr(socket, name, num)
642 for (name, num) in default_gai_errnos]
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000643
644 def filter_error(err):
Antoine Pitroudae0c632010-09-07 21:44:17 +0000645 n = getattr(err, 'errno', None)
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000646 if (isinstance(err, socket.timeout) or
Antoine Pitroudae0c632010-09-07 21:44:17 +0000647 (isinstance(err, socket.gaierror) and n in gai_errnos) or
648 n in captured_errnos):
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000649 if not verbose:
650 sys.stderr.write(denied.args[0] + "\n")
651 raise denied from err
652
653 old_timeout = socket.getdefaulttimeout()
654 try:
655 if timeout is not None:
656 socket.setdefaulttimeout(timeout)
Antoine Pitrouda6902c2010-04-21 19:52:52 +0000657 yield
Antoine Pitrou4d7979b2010-09-07 21:22:56 +0000658 except IOError as err:
659 # urllib can wrap original socket errors multiple times (!), we must
660 # unwrap to get at the original error.
661 while True:
662 a = err.args
663 if len(a) >= 1 and isinstance(a[0], IOError):
664 err = a[0]
665 # The error can also be wrapped as args[1]:
666 # except socket.error as msg:
667 # raise IOError('socket error', msg).with_traceback(sys.exc_info()[2])
668 elif len(a) >= 2 and isinstance(a[1], IOError):
669 err = a[1]
670 else:
671 break
672 filter_error(err)
673 raise
674 # XXX should we catch generic exceptions and look for their
675 # __cause__ or __context__?
676 finally:
677 socket.setdefaulttimeout(old_timeout)
Antoine Pitrouda6902c2010-04-21 19:52:52 +0000678
679
680@contextlib.contextmanager
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000681def captured_output(stream_name):
682 """Run the 'with' statement body using a StringIO object in place of a
683 specific attribute on the sys module.
684 Example use (with 'stream_name=stdout')::
Thomas Woutersed03b412007-08-28 21:37:11 +0000685
686 with captured_stdout() as s:
Neal Norwitz752abd02008-05-13 04:55:24 +0000687 print("hello")
Thomas Woutersed03b412007-08-28 21:37:11 +0000688 assert s.getvalue() == "hello"
689 """
690 import io
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000691 orig_stdout = getattr(sys, stream_name)
692 setattr(sys, stream_name, io.StringIO())
Christian Heimes81ee3ef2008-05-04 22:42:01 +0000693 try:
694 yield getattr(sys, stream_name)
695 finally:
696 setattr(sys, stream_name, orig_stdout)
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000697
698def captured_stdout():
699 return captured_output("stdout")
Thomas Woutersed03b412007-08-28 21:37:11 +0000700
Benjamin Petersone549ead2009-03-28 21:42:05 +0000701def gc_collect():
702 """Force as many objects as possible to be collected.
703
704 In non-CPython implementations of Python, this is needed because timely
705 deallocation is not guaranteed by the garbage collector. (Even in CPython
706 this can be the case in case of reference cycles.) This means that __del__
707 methods may be called later than expected and weakrefs may remain alive for
708 longer than expected. This function tries its best to force all garbage
709 objects to disappear.
710 """
Benjamin Petersone549ead2009-03-28 21:42:05 +0000711 gc.collect()
712 gc.collect()
713 gc.collect()
714
Thomas Woutersed03b412007-08-28 21:37:11 +0000715
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000716#=======================================================================
Thomas Wouters477c8d52006-05-27 19:21:47 +0000717# Decorator for running a function in a different locale, correctly resetting
718# it afterwards.
719
720def run_with_locale(catstr, *locales):
721 def decorator(func):
722 def inner(*args, **kwds):
723 try:
724 import locale
725 category = getattr(locale, catstr)
726 orig_locale = locale.setlocale(category)
727 except AttributeError:
728 # if the test author gives us an invalid category string
729 raise
730 except:
731 # cannot retrieve original locale, so do nothing
732 locale = orig_locale = None
733 else:
734 for loc in locales:
735 try:
736 locale.setlocale(category, loc)
737 break
738 except:
739 pass
740
741 # now run the function, resetting the locale on exceptions
742 try:
743 return func(*args, **kwds)
744 finally:
745 if locale and orig_locale:
746 locale.setlocale(category, orig_locale)
Neal Norwitz221085d2007-02-25 20:55:47 +0000747 inner.__name__ = func.__name__
Thomas Wouters477c8d52006-05-27 19:21:47 +0000748 inner.__doc__ = func.__doc__
749 return inner
750 return decorator
751
752#=======================================================================
Georg Brandldb028442008-02-05 20:48:58 +0000753# Big-memory-test support. Separate from 'resources' because memory use
754# should be configurable.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000755
756# Some handy shorthands. Note that these are used for byte-limits as well
757# as size-limits, in the various bigmem tests
758_1M = 1024*1024
759_1G = 1024 * _1M
760_2G = 2 * _1G
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000761_4G = 4 * _1G
Thomas Wouters477c8d52006-05-27 19:21:47 +0000762
Thomas Woutersd2cf20e2007-08-30 22:57:53 +0000763MAX_Py_ssize_t = sys.maxsize
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000764
Thomas Wouters477c8d52006-05-27 19:21:47 +0000765def set_memlimit(limit):
766 import re
767 global max_memuse
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000768 global real_max_memuse
Thomas Wouters477c8d52006-05-27 19:21:47 +0000769 sizes = {
770 'k': 1024,
771 'm': _1M,
772 'g': _1G,
773 't': 1024*_1G,
774 }
775 m = re.match(r'(\d+(\.\d+)?) (K|M|G|T)b?$', limit,
776 re.IGNORECASE | re.VERBOSE)
777 if m is None:
778 raise ValueError('Invalid memory limit %r' % (limit,))
779 memlimit = int(float(m.group(1)) * sizes[m.group(3).lower()])
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000780 real_max_memuse = memlimit
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000781 if memlimit > MAX_Py_ssize_t:
782 memlimit = MAX_Py_ssize_t
783 if memlimit < _2G - 1:
Thomas Wouters477c8d52006-05-27 19:21:47 +0000784 raise ValueError('Memory limit %r too low to be useful' % (limit,))
785 max_memuse = memlimit
786
787def bigmemtest(minsize, memuse, overhead=5*_1M):
788 """Decorator for bigmem tests.
789
790 'minsize' is the minimum useful size for the test (in arbitrary,
791 test-interpreted units.) 'memuse' is the number of 'bytes per size' for
792 the test, or a good estimate of it. 'overhead' specifies fixed overhead,
Christian Heimes33fe8092008-04-13 13:53:33 +0000793 independent of the testsize, and defaults to 5Mb.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000794
795 The decorator tries to guess a good value for 'size' and passes it to
796 the decorated test function. If minsize * memuse is more than the
797 allowed memory use (as defined by max_memuse), the test is skipped.
798 Otherwise, minsize is adjusted upward to use up to max_memuse.
799 """
800 def decorator(f):
801 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000802 # Retrieve values in case someone decided to adjust them
803 minsize = wrapper.minsize
804 memuse = wrapper.memuse
805 overhead = wrapper.overhead
Thomas Wouters477c8d52006-05-27 19:21:47 +0000806 if not max_memuse:
807 # If max_memuse is 0 (the default),
808 # we still want to run the tests with size set to a few kb,
809 # to make sure they work. We still want to avoid using
810 # too much memory, though, but we do that noisily.
811 maxsize = 5147
Georg Brandlfe5f11c2009-08-13 08:52:53 +0000812 self.assertFalse(maxsize * memuse + overhead > 20 * _1M)
Thomas Wouters477c8d52006-05-27 19:21:47 +0000813 else:
814 maxsize = int((max_memuse - overhead) / memuse)
815 if maxsize < minsize:
816 # Really ought to print 'test skipped' or something
817 if verbose:
818 sys.stderr.write("Skipping %s because of memory "
819 "constraint\n" % (f.__name__,))
820 return
821 # Try to keep some breathing room in memory use
822 maxsize = max(maxsize - 50 * _1M, minsize)
823 return f(self, maxsize)
824 wrapper.minsize = minsize
825 wrapper.memuse = memuse
826 wrapper.overhead = overhead
827 return wrapper
828 return decorator
829
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000830def precisionbigmemtest(size, memuse, overhead=5*_1M):
831 def decorator(f):
832 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000833 size = wrapper.size
834 memuse = wrapper.memuse
835 overhead = wrapper.overhead
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000836 if not real_max_memuse:
837 maxsize = 5147
838 else:
839 maxsize = size
840
841 if real_max_memuse and real_max_memuse < maxsize * memuse:
842 if verbose:
843 sys.stderr.write("Skipping %s because of memory "
844 "constraint\n" % (f.__name__,))
845 return
846
847 return f(self, maxsize)
848 wrapper.size = size
849 wrapper.memuse = memuse
850 wrapper.overhead = overhead
851 return wrapper
852 return decorator
853
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000854def bigaddrspacetest(f):
855 """Decorator for tests that fill the address space."""
856 def wrapper(self):
857 if max_memuse < MAX_Py_ssize_t:
858 if verbose:
859 sys.stderr.write("Skipping %s because of memory "
860 "constraint\n" % (f.__name__,))
861 else:
862 return f(self)
863 return wrapper
864
Thomas Wouters477c8d52006-05-27 19:21:47 +0000865#=======================================================================
Guido van Rossumd8faa362007-04-27 19:54:29 +0000866# unittest integration.
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000867
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000868class BasicTestRunner:
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000869 def run(self, test):
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000870 result = unittest.TestResult()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000871 test(result)
872 return result
873
Benjamin Petersone549ead2009-03-28 21:42:05 +0000874def _id(obj):
875 return obj
876
877def requires_resource(resource):
Antoine Pitrou27314942010-10-14 15:41:23 +0000878 if is_resource_enabled(resource):
Benjamin Petersone549ead2009-03-28 21:42:05 +0000879 return _id
880 else:
881 return unittest.skip("resource {0!r} is not enabled".format(resource))
882
883def cpython_only(test):
884 """
885 Decorator for tests only applicable on CPython.
886 """
887 return impl_detail(cpython=True)(test)
888
889def impl_detail(msg=None, **guards):
890 if check_impl_detail(**guards):
891 return _id
892 if msg is None:
893 guardnames, default = _parse_guards(guards)
894 if default:
895 msg = "implementation detail not available on {0}"
896 else:
897 msg = "implementation detail specific to {0}"
898 guardnames = sorted(guardnames.keys())
899 msg = msg.format(' or '.join(guardnames))
900 return unittest.skip(msg)
901
902def _parse_guards(guards):
903 # Returns a tuple ({platform_name: run_me}, default_value)
904 if not guards:
905 return ({'cpython': True}, False)
Eric Smith886b40a2009-04-26 21:26:45 +0000906 is_true = list(guards.values())[0]
907 assert list(guards.values()) == [is_true] * len(guards) # all True or all False
Benjamin Petersone549ead2009-03-28 21:42:05 +0000908 return (guards, not is_true)
909
910# Use the following check to guard CPython's implementation-specific tests --
911# or to run them only on the implementation(s) guarded by the arguments.
912def check_impl_detail(**guards):
913 """This function returns True or False depending on the host platform.
914 Examples:
915 if check_impl_detail(): # only on CPython (default)
916 if check_impl_detail(jython=True): # only on Jython
917 if check_impl_detail(cpython=False): # everywhere except on CPython
918 """
919 guards, default = _parse_guards(guards)
920 return guards.get(platform.python_implementation().lower(), default)
921
922
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000923
Guido van Rossumd8faa362007-04-27 19:54:29 +0000924def _run_suite(suite):
Barry Warsawc88425e2001-09-20 06:31:22 +0000925 """Run tests from a unittest.TestSuite-derived class."""
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000926 if verbose:
Fred Drake84a59342001-03-23 04:21:17 +0000927 runner = unittest.TextTestRunner(sys.stdout, verbosity=2)
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000928 else:
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000929 runner = BasicTestRunner()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000930
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000931 result = runner.run(suite)
932 if not result.wasSuccessful():
Fred Drake14f6c182001-07-16 18:51:32 +0000933 if len(result.errors) == 1 and not result.failures:
934 err = result.errors[0][1]
935 elif len(result.failures) == 1 and not result.errors:
936 err = result.failures[0][1]
937 else:
R. David Murrayb3438b82009-10-28 14:47:15 +0000938 err = "multiple errors occurred"
939 if not verbose: err += "; run in verbose mode for details"
Tim Peters2d84f2c2001-09-08 03:37:56 +0000940 raise TestFailed(err)
Tim Petersa0a62222001-09-09 06:12:01 +0000941
Barry Warsawc10d6902001-09-20 06:30:41 +0000942
Walter Dörwald21d3a322003-05-01 17:45:56 +0000943def run_unittest(*classes):
944 """Run tests from unittest.TestCase-derived classes."""
Guido van Rossumd8faa362007-04-27 19:54:29 +0000945 valid_types = (unittest.TestSuite, unittest.TestCase)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000946 suite = unittest.TestSuite()
Walter Dörwald21d3a322003-05-01 17:45:56 +0000947 for cls in classes:
Guido van Rossum3172c5d2007-10-16 18:12:55 +0000948 if isinstance(cls, str):
Guido van Rossumd8faa362007-04-27 19:54:29 +0000949 if cls in sys.modules:
950 suite.addTest(unittest.findTestCases(sys.modules[cls]))
951 else:
952 raise ValueError("str arguments must be keys in sys.modules")
953 elif isinstance(cls, valid_types):
Raymond Hettinger21d99872003-07-16 02:59:32 +0000954 suite.addTest(cls)
955 else:
956 suite.addTest(unittest.makeSuite(cls))
Guido van Rossumd8faa362007-04-27 19:54:29 +0000957 _run_suite(suite)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000958
Barry Warsawc10d6902001-09-20 06:30:41 +0000959
Tim Petersa0a62222001-09-09 06:12:01 +0000960#=======================================================================
961# doctest driver.
962
963def run_doctest(module, verbosity=None):
Tim Peters17111f32001-10-03 04:08:26 +0000964 """Run doctest on the given module. Return (#failures, #tests).
Tim Petersa0a62222001-09-09 06:12:01 +0000965
966 If optional argument verbosity is not specified (or is None), pass
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000967 support's belief about verbosity on to doctest. Else doctest's
Tim Petersbea3fb82001-09-10 01:39:21 +0000968 usual behavior is used (it searches sys.argv for -v).
Tim Petersa0a62222001-09-09 06:12:01 +0000969 """
970
971 import doctest
972
973 if verbosity is None:
974 verbosity = verbose
975 else:
976 verbosity = None
977
Tim Peters342ca752001-09-25 19:13:20 +0000978 # Direct doctest output (normally just errors) to real stdout; doctest
979 # output shouldn't be compared by regrtest.
980 save_stdout = sys.stdout
Tim Peters8dee8092001-09-25 20:05:11 +0000981 sys.stdout = get_original_stdout()
Tim Peters342ca752001-09-25 19:13:20 +0000982 try:
983 f, t = doctest.testmod(module, verbose=verbosity)
984 if f:
985 raise TestFailed("%d of %d doctests failed" % (f, t))
986 finally:
987 sys.stdout = save_stdout
Raymond Hettinger35b34bd2003-05-17 00:58:33 +0000988 if verbose:
Georg Brandldb028442008-02-05 20:48:58 +0000989 print('doctest (%s) ... %d tests with zero failures' %
990 (module.__name__, t))
Raymond Hettinger35b34bd2003-05-17 00:58:33 +0000991 return f, t
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000992
Antoine Pitrouca154092009-11-13 16:31:51 +0000993
994#=======================================================================
995# Support for saving and restoring the imported modules.
996
997def modules_setup():
998 return sys.modules.copy(),
999
1000def modules_cleanup(oldmodules):
1001 # Encoders/decoders are registered permanently within the internal
1002 # codec cache. If we destroy the corresponding modules their
1003 # globals will be set to None which will trip up the cached functions.
1004 encodings = [(k, v) for k, v in sys.modules.items()
1005 if k.startswith('encodings.')]
1006 sys.modules.clear()
1007 sys.modules.update(encodings)
1008 sys.modules.update(oldmodules)
1009
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001010#=======================================================================
1011# Threading support to prevent reporting refleaks when running regrtest.py -R
1012
1013def threading_setup():
1014 import threading
1015 return len(threading._active), len(threading._limbo)
1016
1017def threading_cleanup(num_active, num_limbo):
1018 import threading
1019 import time
1020
1021 _MAX_COUNT = 10
1022 count = 0
1023 while len(threading._active) != num_active and count < _MAX_COUNT:
1024 count += 1
1025 time.sleep(0.1)
1026
1027 count = 0
1028 while len(threading._limbo) != num_limbo and count < _MAX_COUNT:
1029 count += 1
1030 time.sleep(0.1)
1031
Benjamin Petersonfa0d7032009-06-01 22:42:33 +00001032def reap_threads(func):
1033 @functools.wraps(func)
1034 def decorator(*args):
1035 key = threading_setup()
1036 try:
1037 return func(*args)
1038 finally:
1039 threading_cleanup(*key)
1040 return decorator
1041
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001042def reap_children():
1043 """Use this function at the end of test_main() whenever sub-processes
1044 are started. This will help ensure that no extra children (zombies)
1045 stick around to hog resources and create problems when looking
1046 for refleaks.
1047 """
1048
1049 # Reap all our dead child processes so we don't leave zombies around.
1050 # These hog resources and might be causing some of the buildbots to die.
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001051 if hasattr(os, 'waitpid'):
1052 any_process = -1
1053 while True:
1054 try:
1055 # This will raise an exception on Windows. That's ok.
1056 pid, status = os.waitpid(any_process, os.WNOHANG)
1057 if pid == 0:
1058 break
1059 except:
1060 break
Antoine Pitrouf50a6b62011-01-03 18:36:36 +00001061
1062def strip_python_stderr(stderr):
1063 """Strip the stderr of a Python process from potential debug output
1064 emitted by the interpreter.
1065
1066 This will typically be run on the result of the communicate() method
1067 of a subprocess.Popen object.
1068 """
1069 stderr = re.sub(br"\[\d+ refs\]\r?\n?$", b"", stderr).strip()
1070 return stderr