blob: bdc61645adbddd44021605474c395e4cd8f5cfff [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
8import socket
Fred Drakecd1b1dd2001-03-21 18:26:33 +00009import sys
Guido van Rossumd8faa362007-04-27 19:54:29 +000010import os
Benjamin Petersone549ead2009-03-28 21:42:05 +000011import platform
Christian Heimes23daade02008-02-25 12:39:23 +000012import shutil
Thomas Wouters902d6eb2007-01-09 23:18:33 +000013import warnings
Guido van Rossumd8faa362007-04-27 19:54:29 +000014import unittest
R. David Murraya21e4ca2009-03-31 23:16:50 +000015import importlib
Fred Drakecd1b1dd2001-03-21 18:26:33 +000016
Benjamin Petersone549ead2009-03-28 21:42:05 +000017__all__ = ["Error", "TestFailed", "ResourceDenied", "import_module",
Benjamin Peterson744c2cd2008-05-26 16:26:37 +000018 "verbose", "use_resources", "max_memuse", "record_original_stdout",
19 "get_original_stdout", "unload", "unlink", "rmtree", "forget",
20 "is_resource_enabled", "requires", "find_unused_port", "bind_port",
Benjamin Peterson79e48032008-05-26 17:44:33 +000021 "fcmp", "is_jython", "TESTFN", "HOST", "FUZZ", "findfile", "verify",
22 "vereq", "sortdict", "check_syntax_error", "open_urlresource",
Benjamin Petersonfcf5d632008-10-16 23:24:44 +000023 "check_warnings", "CleanImport", "EnvironmentVarGuard",
Benjamin Peterson79e48032008-05-26 17:44:33 +000024 "TransientResource", "captured_output", "captured_stdout",
25 "TransientResource", "transient_internet", "run_with_locale",
26 "set_memlimit", "bigmemtest", "bigaddrspacetest", "BasicTestRunner",
27 "run_unittest", "run_doctest", "threading_setup", "threading_cleanup",
R. David Murraya21e4ca2009-03-31 23:16:50 +000028 "reap_children", "cpython_only", "check_impl_detail", "get_attribute"]
Benjamin Peterson744c2cd2008-05-26 16:26:37 +000029
Fred Drake1790dd42000-07-24 06:55:00 +000030class Error(Exception):
Fred Drake004d5e62000-10-23 17:22:08 +000031 """Base class for regression test exceptions."""
Fred Drake1790dd42000-07-24 06:55:00 +000032
33class TestFailed(Error):
Fred Drake004d5e62000-10-23 17:22:08 +000034 """Test failed."""
Fred Drake1790dd42000-07-24 06:55:00 +000035
Benjamin Petersone549ead2009-03-28 21:42:05 +000036class ResourceDenied(unittest.SkipTest):
Fred Drake9a0db072003-02-03 15:19:30 +000037 """Test skipped because it requested a disallowed resource.
38
39 This is raised when a test calls requires() for a resource that
40 has not be enabled. It is used to distinguish between expected
41 and unexpected skips.
42 """
43
Nick Coghlanfce769e2009-04-11 14:30:59 +000044@contextlib.contextmanager
45def _ignore_deprecated_imports(ignore=True):
46 """Context manager to suppress package and module deprecation
47 warnings when importing them.
48
49 If ignore is False, this context manager has no effect."""
50 if ignore:
51 with warnings.catch_warnings():
52 warnings.filterwarnings("ignore", ".+ (module|package)",
53 DeprecationWarning)
54 yield
55 else:
56 yield
57
58
Benjamin Peterson699adb92008-05-08 22:27:58 +000059def import_module(name, deprecated=False):
R. David Murraya21e4ca2009-03-31 23:16:50 +000060 """Import and return the module to be tested, raising SkipTest if
61 it is not available.
62
63 If deprecated is True, any module or package deprecation messages
64 will be suppressed."""
Nick Coghlanfce769e2009-04-11 14:30:59 +000065 with _ignore_deprecated_imports(deprecated):
Benjamin Peterson699adb92008-05-08 22:27:58 +000066 try:
Nick Coghlanfce769e2009-04-11 14:30:59 +000067 return importlib.import_module(name)
R. David Murraya21e4ca2009-03-31 23:16:50 +000068 except ImportError as msg:
69 raise unittest.SkipTest(str(msg))
Nick Coghlanfce769e2009-04-11 14:30:59 +000070
71
Nick Coghlan47384702009-04-22 16:13:36 +000072def _save_and_remove_module(name, orig_modules):
73 """Helper function to save and remove a module from sys.modules
74
75 Return value is True if the module was in sys.modules and
76 False otherwise."""
77 saved = True
78 try:
79 orig_modules[name] = sys.modules[name]
80 except KeyError:
81 saved = False
82 else:
83 del sys.modules[name]
84 return saved
85
86
87def _save_and_block_module(name, orig_modules):
88 """Helper function to save and block a module in sys.modules
89
90 Return value is True if the module was in sys.modules and
91 False otherwise."""
92 saved = True
93 try:
94 orig_modules[name] = sys.modules[name]
95 except KeyError:
96 saved = False
97 sys.modules[name] = 0
98 return saved
99
100
101def import_fresh_module(name, fresh=(), blocked=(), deprecated=False):
Nick Coghlanfce769e2009-04-11 14:30:59 +0000102 """Imports and returns a module, deliberately bypassing the sys.modules cache
103 and importing a fresh copy of the module. Once the import is complete,
104 the sys.modules cache is restored to its original state.
105
Nick Coghlan47384702009-04-22 16:13:36 +0000106 Modules named in fresh are also imported anew if needed by the import.
107
108 Importing of modules named in blocked is prevented while the fresh import
Nick Coghlanfce769e2009-04-11 14:30:59 +0000109 takes place.
110
111 If deprecated is True, any module or package deprecation messages
112 will be suppressed."""
113 # NOTE: test_heapq and test_warnings include extra sanity checks to make
114 # sure that this utility function is working as expected
115 with _ignore_deprecated_imports(deprecated):
Nick Coghlan47384702009-04-22 16:13:36 +0000116 # Keep track of modules saved for later restoration as well
117 # as those which just need a blocking entry removed
Nick Coghlanfce769e2009-04-11 14:30:59 +0000118 orig_modules = {}
Nick Coghlan47384702009-04-22 16:13:36 +0000119 names_to_remove = []
120 _save_and_remove_module(name, orig_modules)
Nick Coghlanfce769e2009-04-11 14:30:59 +0000121 try:
Nick Coghlan47384702009-04-22 16:13:36 +0000122 for fresh_name in fresh:
123 _save_and_remove_module(fresh_name, orig_modules)
124 for blocked_name in blocked:
125 if not _save_and_block_module(blocked_name, orig_modules):
126 names_to_remove.append(blocked_name)
127 fresh_module = importlib.import_module(name)
Nick Coghlanfce769e2009-04-11 14:30:59 +0000128 finally:
Nick Coghlan47384702009-04-22 16:13:36 +0000129 for orig_name, module in orig_modules.items():
130 sys.modules[orig_name] = module
131 for name_to_remove in names_to_remove:
132 del sys.modules[name_to_remove]
133 return fresh_module
Nick Coghlanfce769e2009-04-11 14:30:59 +0000134
Benjamin Peterson699adb92008-05-08 22:27:58 +0000135
R. David Murraya21e4ca2009-03-31 23:16:50 +0000136def get_attribute(obj, name):
137 """Get an attribute, raising SkipTest if AttributeError is raised."""
138 try:
139 attribute = getattr(obj, name)
140 except AttributeError:
141 raise unittest.SkipTest("module %s has no attribute %s" % (
142 obj.__name__, name))
143 else:
144 return attribute
145
Barry Warsawc0fb6052001-08-20 22:29:23 +0000146verbose = 1 # Flag set to 0 by regrtest.py
Thomas Wouters477c8d52006-05-27 19:21:47 +0000147use_resources = None # Flag set to [] by regrtest.py
148max_memuse = 0 # Disable bigmem tests (they will still be run with
149 # small sizes, to make sure they work.)
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000150real_max_memuse = 0
Guido van Rossum531661c1996-12-20 02:58:22 +0000151
Tim Peters8dee8092001-09-25 20:05:11 +0000152# _original_stdout is meant to hold stdout at the time regrtest began.
153# This may be "the real" stdout, or IDLE's emulation of stdout, or whatever.
154# The point is to have some flavor of stdout the user can actually see.
155_original_stdout = None
156def record_original_stdout(stdout):
157 global _original_stdout
158 _original_stdout = stdout
159
160def get_original_stdout():
161 return _original_stdout or sys.stdout
162
Guido van Rossum3bead091992-01-27 17:00:37 +0000163def unload(name):
Fred Drake004d5e62000-10-23 17:22:08 +0000164 try:
165 del sys.modules[name]
166 except KeyError:
167 pass
Guido van Rossum3bead091992-01-27 17:00:37 +0000168
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000169def unlink(filename):
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000170 try:
171 os.unlink(filename)
172 except OSError:
173 pass
174
Christian Heimes23daade02008-02-25 12:39:23 +0000175def rmtree(path):
176 try:
177 shutil.rmtree(path)
178 except OSError as e:
179 # Unix returns ENOENT, Windows returns ESRCH.
180 if e.errno not in (errno.ENOENT, errno.ESRCH):
181 raise
182
Guido van Rossum3bead091992-01-27 17:00:37 +0000183def forget(modname):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000184 '''"Forget" a module was ever imported by removing it from sys.modules and
185 deleting any .pyc and .pyo files.'''
Fred Drake004d5e62000-10-23 17:22:08 +0000186 unload(modname)
Fred Drake004d5e62000-10-23 17:22:08 +0000187 for dirname in sys.path:
Skip Montanaro7a98be22007-08-16 14:35:24 +0000188 unlink(os.path.join(dirname, modname + '.pyc'))
Brett Cannonf1cfb622003-05-04 21:15:27 +0000189 # Deleting the .pyo file cannot be within the 'try' for the .pyc since
190 # the chance exists that there is no .pyc (and thus the 'try' statement
191 # is exited) but there is a .pyo file.
Skip Montanaro7a98be22007-08-16 14:35:24 +0000192 unlink(os.path.join(dirname, modname + '.pyo'))
Guido van Rossum3bead091992-01-27 17:00:37 +0000193
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000194def is_resource_enabled(resource):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000195 """Test whether a resource is enabled. Known resources are set by
196 regrtest.py."""
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000197 return use_resources is not None and resource in use_resources
198
Barry Warsawc0fb6052001-08-20 22:29:23 +0000199def requires(resource, msg=None):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000200 """Raise ResourceDenied if the specified resource is not available.
201
202 If the caller's module is __main__ then automatically return True. The
203 possibility of False being returned occurs when regrtest.py is executing."""
Skip Montanarod839ecd2003-04-24 19:06:57 +0000204 # see if the caller's module is __main__ - if so, treat as if
205 # the resource was set
Benjamin Petersone549ead2009-03-28 21:42:05 +0000206 if sys._getframe(1).f_globals.get("__name__") == "__main__":
Skip Montanarod839ecd2003-04-24 19:06:57 +0000207 return
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000208 if not is_resource_enabled(resource):
Barry Warsawc0fb6052001-08-20 22:29:23 +0000209 if msg is None:
210 msg = "Use of the `%s' resource not enabled" % resource
Fred Drake9a0db072003-02-03 15:19:30 +0000211 raise ResourceDenied(msg)
Barry Warsawc0fb6052001-08-20 22:29:23 +0000212
Christian Heimes5e696852008-04-09 08:37:03 +0000213HOST = 'localhost'
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000214
Christian Heimes5e696852008-04-09 08:37:03 +0000215def find_unused_port(family=socket.AF_INET, socktype=socket.SOCK_STREAM):
216 """Returns an unused port that should be suitable for binding. This is
217 achieved by creating a temporary socket with the same family and type as
218 the 'sock' parameter (default is AF_INET, SOCK_STREAM), and binding it to
219 the specified host address (defaults to 0.0.0.0) with the port set to 0,
220 eliciting an unused ephemeral port from the OS. The temporary socket is
221 then closed and deleted, and the ephemeral port is returned.
222
223 Either this method or bind_port() should be used for any tests where a
224 server socket needs to be bound to a particular port for the duration of
225 the test. Which one to use depends on whether the calling code is creating
226 a python socket, or if an unused port needs to be provided in a constructor
227 or passed to an external program (i.e. the -accept argument to openssl's
228 s_server mode). Always prefer bind_port() over find_unused_port() where
229 possible. Hard coded ports should *NEVER* be used. As soon as a server
230 socket is bound to a hard coded port, the ability to run multiple instances
231 of the test simultaneously on the same host is compromised, which makes the
232 test a ticking time bomb in a buildbot environment. On Unix buildbots, this
233 may simply manifest as a failed test, which can be recovered from without
234 intervention in most cases, but on Windows, the entire python process can
235 completely and utterly wedge, requiring someone to log in to the buildbot
236 and manually kill the affected process.
237
238 (This is easy to reproduce on Windows, unfortunately, and can be traced to
239 the SO_REUSEADDR socket option having different semantics on Windows versus
240 Unix/Linux. On Unix, you can't have two AF_INET SOCK_STREAM sockets bind,
241 listen and then accept connections on identical host/ports. An EADDRINUSE
242 socket.error will be raised at some point (depending on the platform and
243 the order bind and listen were called on each socket).
244
245 However, on Windows, if SO_REUSEADDR is set on the sockets, no EADDRINUSE
246 will ever be raised when attempting to bind two identical host/ports. When
247 accept() is called on each socket, the second caller's process will steal
248 the port from the first caller, leaving them both in an awkwardly wedged
249 state where they'll no longer respond to any signals or graceful kills, and
250 must be forcibly killed via OpenProcess()/TerminateProcess().
251
252 The solution on Windows is to use the SO_EXCLUSIVEADDRUSE socket option
253 instead of SO_REUSEADDR, which effectively affords the same semantics as
254 SO_REUSEADDR on Unix. Given the propensity of Unix developers in the Open
255 Source world compared to Windows ones, this is a common mistake. A quick
256 look over OpenSSL's 0.9.8g source shows that they use SO_REUSEADDR when
257 openssl.exe is called with the 's_server' option, for example. See
258 http://bugs.python.org/issue2550 for more info. The following site also
259 has a very thorough description about the implications of both REUSEADDR
260 and EXCLUSIVEADDRUSE on Windows:
261 http://msdn2.microsoft.com/en-us/library/ms740621(VS.85).aspx)
262
263 XXX: although this approach is a vast improvement on previous attempts to
264 elicit unused ports, it rests heavily on the assumption that the ephemeral
265 port returned to us by the OS won't immediately be dished back out to some
266 other process when we close and delete our temporary socket but before our
267 calling code has a chance to bind the returned port. We can deal with this
268 issue if/when we come across it.
269 """
270
271 tempsock = socket.socket(family, socktype)
272 port = bind_port(tempsock)
273 tempsock.close()
274 del tempsock
275 return port
276
277def bind_port(sock, host=HOST):
278 """Bind the socket to a free port and return the port number. Relies on
279 ephemeral ports in order to ensure we are using an unbound port. This is
280 important as many tests may be running simultaneously, especially in a
281 buildbot environment. This method raises an exception if the sock.family
282 is AF_INET and sock.type is SOCK_STREAM, *and* the socket has SO_REUSEADDR
283 or SO_REUSEPORT set on it. Tests should *never* set these socket options
284 for TCP/IP sockets. The only case for setting these options is testing
285 multicasting via multiple UDP sockets.
286
287 Additionally, if the SO_EXCLUSIVEADDRUSE socket option is available (i.e.
288 on Windows), it will be set on the socket. This will prevent anyone else
289 from bind()'ing to our host/port for the duration of the test.
290 """
291
292 if sock.family == socket.AF_INET and sock.type == socket.SOCK_STREAM:
293 if hasattr(socket, 'SO_REUSEADDR'):
294 if sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR) == 1:
295 raise TestFailed("tests should never set the SO_REUSEADDR " \
296 "socket option on TCP/IP sockets!")
297 if hasattr(socket, 'SO_REUSEPORT'):
298 if sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEPORT) == 1:
299 raise TestFailed("tests should never set the SO_REUSEPORT " \
300 "socket option on TCP/IP sockets!")
301 if hasattr(socket, 'SO_EXCLUSIVEADDRUSE'):
302 sock.setsockopt(socket.SOL_SOCKET, socket.SO_EXCLUSIVEADDRUSE, 1)
303
304 sock.bind((host, 0))
305 port = sock.getsockname()[1]
306 return port
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000307
Guido van Rossum35fb82a1993-01-26 13:04:43 +0000308FUZZ = 1e-6
309
310def fcmp(x, y): # fuzzy comparison function
Neal Norwitz79212992006-08-21 16:27:31 +0000311 if isinstance(x, float) or isinstance(y, float):
Fred Drake004d5e62000-10-23 17:22:08 +0000312 try:
Fred Drake004d5e62000-10-23 17:22:08 +0000313 fuzz = (abs(x) + abs(y)) * FUZZ
314 if abs(x-y) <= fuzz:
315 return 0
316 except:
317 pass
Neal Norwitz79212992006-08-21 16:27:31 +0000318 elif type(x) == type(y) and isinstance(x, (tuple, list)):
Fred Drake004d5e62000-10-23 17:22:08 +0000319 for i in range(min(len(x), len(y))):
320 outcome = fcmp(x[i], y[i])
Fred Drake132dce22000-12-12 23:11:42 +0000321 if outcome != 0:
Fred Drake004d5e62000-10-23 17:22:08 +0000322 return outcome
Guido van Rossum47b9ff62006-08-24 00:41:19 +0000323 return (len(x) > len(y)) - (len(x) < len(y))
324 return (x > y) - (x < y)
Guido van Rossum35fb82a1993-01-26 13:04:43 +0000325
Finn Bock57bc5fa2002-11-01 18:02:03 +0000326is_jython = sys.platform.startswith('java')
327
Barry Warsaw559f6682001-03-23 18:04:02 +0000328# Filename used for testing
329if os.name == 'java':
330 # Jython disallows @ in module names
331 TESTFN = '$test'
Martin v. Löwisa94568a2003-05-10 07:36:56 +0000332else:
Barry Warsaw559f6682001-03-23 18:04:02 +0000333 TESTFN = '@test'
Walter Dörwald9b775532007-06-08 14:30:53 +0000334
335 # Assuming sys.getfilesystemencoding()!=sys.getdefaultencoding()
336 # TESTFN_UNICODE is a filename that can be encoded using the
337 # file system encoding, but *not* with the default (ascii) encoding
338 TESTFN_UNICODE = "@test-\xe0\xf2"
339 TESTFN_ENCODING = sys.getfilesystemencoding()
340 # TESTFN_UNICODE_UNENCODEABLE is a filename that should *not* be
341 # able to be encoded by *either* the default or filesystem encoding.
342 # This test really only makes sense on Windows NT platforms
343 # which have special Unicode support in posixmodule.
344 if (not hasattr(sys, "getwindowsversion") or
345 sys.getwindowsversion()[3] < 2): # 0=win32s or 1=9x/ME
346 TESTFN_UNICODE_UNENCODEABLE = None
347 else:
348 # Japanese characters (I think - from bug 846133)
349 TESTFN_UNICODE_UNENCODEABLE = "@test-\u5171\u6709\u3055\u308c\u308b"
350 try:
351 # XXX - Note - should be using TESTFN_ENCODING here - but for
352 # Windows, "mbcs" currently always operates as if in
353 # errors=ignore' mode - hence we get '?' characters rather than
354 # the exception. 'Latin1' operates as we expect - ie, fails.
355 # See [ 850997 ] mbcs encoding ignores errors
356 TESTFN_UNICODE_UNENCODEABLE.encode("Latin1")
357 except UnicodeEncodeError:
358 pass
Martin v. Löwis2411a2d2002-11-09 19:57:26 +0000359 else:
Georg Brandldb028442008-02-05 20:48:58 +0000360 print('WARNING: The filename %r CAN be encoded by the filesystem. '
361 'Unicode filename tests may not be effective'
362 % TESTFN_UNICODE_UNENCODEABLE)
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000363
364# Make sure we can write to TESTFN, try in /tmp if we can't
365fp = None
366try:
367 fp = open(TESTFN, 'w+')
368except IOError:
369 TMP_TESTFN = os.path.join('/tmp', TESTFN)
370 try:
371 fp = open(TMP_TESTFN, 'w+')
372 TESTFN = TMP_TESTFN
373 del TMP_TESTFN
374 except IOError:
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000375 print(('WARNING: tests will fail, unable to write to: %s or %s' %
376 (TESTFN, TMP_TESTFN)))
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000377if fp is not None:
378 fp.close()
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000379 unlink(TESTFN)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000380del fp
Guido van Rossuma8f7e592001-03-13 09:31:07 +0000381
Guido van Rossume26132c1998-04-23 20:13:30 +0000382def findfile(file, here=__file__):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000383 """Try to find a file on sys.path and the working directory. If it is not
384 found the argument passed to the function is returned (this does not
385 necessarily signal failure; could still be the legitimate path)."""
Fred Drake004d5e62000-10-23 17:22:08 +0000386 if os.path.isabs(file):
387 return file
Fred Drake004d5e62000-10-23 17:22:08 +0000388 path = sys.path
389 path = [os.path.dirname(here)] + path
390 for dn in path:
391 fn = os.path.join(dn, file)
392 if os.path.exists(fn): return fn
393 return file
Marc-André Lemburg36619082001-01-17 19:11:13 +0000394
395def verify(condition, reason='test failed'):
Guido van Rossuma1374e42001-01-19 19:01:56 +0000396 """Verify that condition is true. If not, raise TestFailed.
Marc-André Lemburg36619082001-01-17 19:11:13 +0000397
Skip Montanaroc955f892001-01-20 19:12:54 +0000398 The optional argument reason can be given to provide
Tim Peters983874d2001-01-19 05:59:21 +0000399 a better error text.
Tim Petersd2bf3b72001-01-18 02:22:22 +0000400 """
Tim Peters983874d2001-01-19 05:59:21 +0000401
Tim Petersd2bf3b72001-01-18 02:22:22 +0000402 if not condition:
Guido van Rossuma1374e42001-01-19 19:01:56 +0000403 raise TestFailed(reason)
Jeremy Hylton47793992001-02-19 15:35:26 +0000404
Tim Petersc2fe6182001-10-30 23:20:46 +0000405def vereq(a, b):
Tim Peters77902972001-12-29 17:34:57 +0000406 """Raise TestFailed if a == b is false.
407
408 This is better than verify(a == b) because, in case of failure, the
409 error message incorporates repr(a) and repr(b) so you can see the
410 inputs.
411
412 Note that "not (a == b)" isn't necessarily the same as "a != b"; the
413 former is tested.
414 """
415
Tim Petersc2fe6182001-10-30 23:20:46 +0000416 if not (a == b):
Guido van Rossumd8faa362007-04-27 19:54:29 +0000417 raise TestFailed("%r == %r" % (a, b))
Tim Petersc2fe6182001-10-30 23:20:46 +0000418
Tim Peters2f228e72001-05-13 00:19:31 +0000419def sortdict(dict):
420 "Like repr(dict), but in sorted order."
Guido van Rossumcc2b0162007-02-11 06:12:03 +0000421 items = sorted(dict.items())
Tim Peters2f228e72001-05-13 00:19:31 +0000422 reprpairs = ["%r: %r" % pair for pair in items]
423 withcommas = ", ".join(reprpairs)
424 return "{%s}" % withcommas
425
Benjamin Peterson7522c742009-01-19 21:00:09 +0000426def make_bad_fd():
427 """
428 Create an invalid file descriptor by opening and closing a file and return
429 its fd.
430 """
431 file = open(TESTFN, "wb")
432 try:
433 return file.fileno()
434 finally:
435 file.close()
436 unlink(TESTFN)
437
Thomas Wouters89f507f2006-12-13 04:49:30 +0000438def check_syntax_error(testcase, statement):
Benjamin Petersone549ead2009-03-28 21:42:05 +0000439 testcase.assertRaises(SyntaxError, compile, statement,
440 '<test string>', 'exec')
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000441
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000442def open_urlresource(url, *args, **kw):
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000443 import urllib.request, urllib.parse
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000444
Guido van Rossum360e4b82007-05-14 22:51:27 +0000445 requires('urlfetch')
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000446 filename = urllib.parse.urlparse(url)[2].split('/')[-1] # '/': it's URL!
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000447
448 for path in [os.path.curdir, os.path.pardir]:
449 fn = os.path.join(path, filename)
450 if os.path.exists(fn):
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000451 return open(fn, *args, **kw)
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000452
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000453 print('\tfetching %s ...' % url, file=get_original_stdout())
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000454 fn, _ = urllib.request.urlretrieve(url, filename)
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000455 return open(fn, *args, **kw)
Thomas Wouters9fe394c2007-02-05 01:24:16 +0000456
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000457
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000458class WarningsRecorder(object):
459 """Convenience wrapper for the warnings list returned on
460 entry to the warnings.catch_warnings() context manager.
Guido van Rossumd8faa362007-04-27 19:54:29 +0000461 """
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000462 def __init__(self, warnings_list):
463 self.warnings = warnings_list
464
465 def __getattr__(self, attr):
466 if self.warnings:
467 return getattr(self.warnings[-1], attr)
468 elif attr in warnings.WarningMessage._WARNING_DETAILS:
469 return None
470 raise AttributeError("%r has no attribute %r" % (self, attr))
471
472 def reset(self):
473 del self.warnings[:]
474
475@contextlib.contextmanager
476def check_warnings():
477 with warnings.catch_warnings(record=True) as w:
478 yield WarningsRecorder(w)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000479
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000480
481class CleanImport(object):
482 """Context manager to force import to return a new module reference.
483
484 This is useful for testing module-level behaviours, such as
Nick Coghlanb1304932008-07-13 12:25:08 +0000485 the emission of a DeprecationWarning on import.
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000486
487 Use like this:
488
489 with CleanImport("foo"):
490 __import__("foo") # new reference
491 """
492
493 def __init__(self, *module_names):
494 self.original_modules = sys.modules.copy()
495 for module_name in module_names:
496 if module_name in sys.modules:
497 module = sys.modules[module_name]
498 # It is possible that module_name is just an alias for
499 # another module (e.g. stub for modules renamed in 3.x).
500 # In that case, we also need delete the real module to clear
501 # the import cache.
502 if module.__name__ != module_name:
503 del sys.modules[module.__name__]
504 del sys.modules[module_name]
505
506 def __enter__(self):
507 return self
508
509 def __exit__(self, *ignore_exc):
510 sys.modules.update(self.original_modules)
511
512
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000513class EnvironmentVarGuard(object):
514
515 """Class to help protect the environment variable properly. Can be used as
516 a context manager."""
517
518 def __init__(self):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000519 self._changed = {}
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000520
521 def set(self, envvar, value):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000522 # Remember the initial value on the first access
523 if envvar not in self._changed:
524 self._changed[envvar] = os.environ.get(envvar)
525 os.environ[envvar] = value
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000526
527 def unset(self, envvar):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000528 # Remember the initial value on the first access
529 if envvar not in self._changed:
530 self._changed[envvar] = os.environ.get(envvar)
531 if envvar in os.environ:
532 del os.environ[envvar]
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000533
534 def __enter__(self):
535 return self
536
537 def __exit__(self, *ignore_exc):
Walter Dörwald4ba80132009-04-25 12:48:43 +0000538 for (k, v) in self._changed.items():
539 if v is None:
540 if k in os.environ:
541 del os.environ[k]
542 else:
543 os.environ[k] = v
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000544
Guido van Rossumd8faa362007-04-27 19:54:29 +0000545class TransientResource(object):
546
547 """Raise ResourceDenied if an exception is raised while the context manager
548 is in effect that matches the specified exception and attributes."""
549
550 def __init__(self, exc, **kwargs):
551 self.exc = exc
552 self.attrs = kwargs
553
554 def __enter__(self):
555 return self
556
557 def __exit__(self, type_=None, value=None, traceback=None):
558 """If type_ is a subclass of self.exc and value has attributes matching
559 self.attrs, raise ResourceDenied. Otherwise let the exception
560 propagate (if any)."""
561 if type_ is not None and issubclass(self.exc, type_):
562 for attr, attr_value in self.attrs.items():
563 if not hasattr(value, attr):
564 break
565 if getattr(value, attr) != attr_value:
566 break
567 else:
568 raise ResourceDenied("an optional resource is not available")
569
570
571def transient_internet():
572 """Return a context manager that raises ResourceDenied when various issues
573 with the Internet connection manifest themselves as exceptions."""
574 time_out = TransientResource(IOError, errno=errno.ETIMEDOUT)
575 socket_peer_reset = TransientResource(socket.error, errno=errno.ECONNRESET)
576 ioerror_peer_reset = TransientResource(IOError, errno=errno.ECONNRESET)
577 return contextlib.nested(time_out, socket_peer_reset, ioerror_peer_reset)
578
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000579
Thomas Woutersed03b412007-08-28 21:37:11 +0000580@contextlib.contextmanager
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000581def captured_output(stream_name):
582 """Run the 'with' statement body using a StringIO object in place of a
583 specific attribute on the sys module.
584 Example use (with 'stream_name=stdout')::
Thomas Woutersed03b412007-08-28 21:37:11 +0000585
586 with captured_stdout() as s:
Neal Norwitz752abd02008-05-13 04:55:24 +0000587 print("hello")
Thomas Woutersed03b412007-08-28 21:37:11 +0000588 assert s.getvalue() == "hello"
589 """
590 import io
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000591 orig_stdout = getattr(sys, stream_name)
592 setattr(sys, stream_name, io.StringIO())
Christian Heimes81ee3ef2008-05-04 22:42:01 +0000593 try:
594 yield getattr(sys, stream_name)
595 finally:
596 setattr(sys, stream_name, orig_stdout)
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000597
598def captured_stdout():
599 return captured_output("stdout")
Thomas Woutersed03b412007-08-28 21:37:11 +0000600
Benjamin Petersone549ead2009-03-28 21:42:05 +0000601def gc_collect():
602 """Force as many objects as possible to be collected.
603
604 In non-CPython implementations of Python, this is needed because timely
605 deallocation is not guaranteed by the garbage collector. (Even in CPython
606 this can be the case in case of reference cycles.) This means that __del__
607 methods may be called later than expected and weakrefs may remain alive for
608 longer than expected. This function tries its best to force all garbage
609 objects to disappear.
610 """
611 import gc
612 gc.collect()
613 gc.collect()
614 gc.collect()
615
Thomas Woutersed03b412007-08-28 21:37:11 +0000616
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000617#=======================================================================
Thomas Wouters477c8d52006-05-27 19:21:47 +0000618# Decorator for running a function in a different locale, correctly resetting
619# it afterwards.
620
621def run_with_locale(catstr, *locales):
622 def decorator(func):
623 def inner(*args, **kwds):
624 try:
625 import locale
626 category = getattr(locale, catstr)
627 orig_locale = locale.setlocale(category)
628 except AttributeError:
629 # if the test author gives us an invalid category string
630 raise
631 except:
632 # cannot retrieve original locale, so do nothing
633 locale = orig_locale = None
634 else:
635 for loc in locales:
636 try:
637 locale.setlocale(category, loc)
638 break
639 except:
640 pass
641
642 # now run the function, resetting the locale on exceptions
643 try:
644 return func(*args, **kwds)
645 finally:
646 if locale and orig_locale:
647 locale.setlocale(category, orig_locale)
Neal Norwitz221085d2007-02-25 20:55:47 +0000648 inner.__name__ = func.__name__
Thomas Wouters477c8d52006-05-27 19:21:47 +0000649 inner.__doc__ = func.__doc__
650 return inner
651 return decorator
652
653#=======================================================================
Georg Brandldb028442008-02-05 20:48:58 +0000654# Big-memory-test support. Separate from 'resources' because memory use
655# should be configurable.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000656
657# Some handy shorthands. Note that these are used for byte-limits as well
658# as size-limits, in the various bigmem tests
659_1M = 1024*1024
660_1G = 1024 * _1M
661_2G = 2 * _1G
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000662_4G = 4 * _1G
Thomas Wouters477c8d52006-05-27 19:21:47 +0000663
Thomas Woutersd2cf20e2007-08-30 22:57:53 +0000664MAX_Py_ssize_t = sys.maxsize
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000665
Thomas Wouters477c8d52006-05-27 19:21:47 +0000666def set_memlimit(limit):
667 import re
668 global max_memuse
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000669 global real_max_memuse
Thomas Wouters477c8d52006-05-27 19:21:47 +0000670 sizes = {
671 'k': 1024,
672 'm': _1M,
673 'g': _1G,
674 't': 1024*_1G,
675 }
676 m = re.match(r'(\d+(\.\d+)?) (K|M|G|T)b?$', limit,
677 re.IGNORECASE | re.VERBOSE)
678 if m is None:
679 raise ValueError('Invalid memory limit %r' % (limit,))
680 memlimit = int(float(m.group(1)) * sizes[m.group(3).lower()])
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000681 real_max_memuse = memlimit
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000682 if memlimit > MAX_Py_ssize_t:
683 memlimit = MAX_Py_ssize_t
684 if memlimit < _2G - 1:
Thomas Wouters477c8d52006-05-27 19:21:47 +0000685 raise ValueError('Memory limit %r too low to be useful' % (limit,))
686 max_memuse = memlimit
687
688def bigmemtest(minsize, memuse, overhead=5*_1M):
689 """Decorator for bigmem tests.
690
691 'minsize' is the minimum useful size for the test (in arbitrary,
692 test-interpreted units.) 'memuse' is the number of 'bytes per size' for
693 the test, or a good estimate of it. 'overhead' specifies fixed overhead,
Christian Heimes33fe8092008-04-13 13:53:33 +0000694 independent of the testsize, and defaults to 5Mb.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000695
696 The decorator tries to guess a good value for 'size' and passes it to
697 the decorated test function. If minsize * memuse is more than the
698 allowed memory use (as defined by max_memuse), the test is skipped.
699 Otherwise, minsize is adjusted upward to use up to max_memuse.
700 """
701 def decorator(f):
702 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000703 # Retrieve values in case someone decided to adjust them
704 minsize = wrapper.minsize
705 memuse = wrapper.memuse
706 overhead = wrapper.overhead
Thomas Wouters477c8d52006-05-27 19:21:47 +0000707 if not max_memuse:
708 # If max_memuse is 0 (the default),
709 # we still want to run the tests with size set to a few kb,
710 # to make sure they work. We still want to avoid using
711 # too much memory, though, but we do that noisily.
712 maxsize = 5147
713 self.failIf(maxsize * memuse + overhead > 20 * _1M)
714 else:
715 maxsize = int((max_memuse - overhead) / memuse)
716 if maxsize < minsize:
717 # Really ought to print 'test skipped' or something
718 if verbose:
719 sys.stderr.write("Skipping %s because of memory "
720 "constraint\n" % (f.__name__,))
721 return
722 # Try to keep some breathing room in memory use
723 maxsize = max(maxsize - 50 * _1M, minsize)
724 return f(self, maxsize)
725 wrapper.minsize = minsize
726 wrapper.memuse = memuse
727 wrapper.overhead = overhead
728 return wrapper
729 return decorator
730
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000731def precisionbigmemtest(size, memuse, overhead=5*_1M):
732 def decorator(f):
733 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000734 size = wrapper.size
735 memuse = wrapper.memuse
736 overhead = wrapper.overhead
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000737 if not real_max_memuse:
738 maxsize = 5147
739 else:
740 maxsize = size
741
742 if real_max_memuse and real_max_memuse < maxsize * memuse:
743 if verbose:
744 sys.stderr.write("Skipping %s because of memory "
745 "constraint\n" % (f.__name__,))
746 return
747
748 return f(self, maxsize)
749 wrapper.size = size
750 wrapper.memuse = memuse
751 wrapper.overhead = overhead
752 return wrapper
753 return decorator
754
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000755def bigaddrspacetest(f):
756 """Decorator for tests that fill the address space."""
757 def wrapper(self):
758 if max_memuse < MAX_Py_ssize_t:
759 if verbose:
760 sys.stderr.write("Skipping %s because of memory "
761 "constraint\n" % (f.__name__,))
762 else:
763 return f(self)
764 return wrapper
765
Thomas Wouters477c8d52006-05-27 19:21:47 +0000766#=======================================================================
Guido van Rossumd8faa362007-04-27 19:54:29 +0000767# unittest integration.
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000768
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000769class BasicTestRunner:
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000770 def run(self, test):
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000771 result = unittest.TestResult()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000772 test(result)
773 return result
774
Benjamin Petersone549ead2009-03-28 21:42:05 +0000775def _id(obj):
776 return obj
777
778def requires_resource(resource):
779 if resource_is_enabled(resource):
780 return _id
781 else:
782 return unittest.skip("resource {0!r} is not enabled".format(resource))
783
784def cpython_only(test):
785 """
786 Decorator for tests only applicable on CPython.
787 """
788 return impl_detail(cpython=True)(test)
789
790def impl_detail(msg=None, **guards):
791 if check_impl_detail(**guards):
792 return _id
793 if msg is None:
794 guardnames, default = _parse_guards(guards)
795 if default:
796 msg = "implementation detail not available on {0}"
797 else:
798 msg = "implementation detail specific to {0}"
799 guardnames = sorted(guardnames.keys())
800 msg = msg.format(' or '.join(guardnames))
801 return unittest.skip(msg)
802
803def _parse_guards(guards):
804 # Returns a tuple ({platform_name: run_me}, default_value)
805 if not guards:
806 return ({'cpython': True}, False)
Eric Smith886b40a2009-04-26 21:26:45 +0000807 is_true = list(guards.values())[0]
808 assert list(guards.values()) == [is_true] * len(guards) # all True or all False
Benjamin Petersone549ead2009-03-28 21:42:05 +0000809 return (guards, not is_true)
810
811# Use the following check to guard CPython's implementation-specific tests --
812# or to run them only on the implementation(s) guarded by the arguments.
813def check_impl_detail(**guards):
814 """This function returns True or False depending on the host platform.
815 Examples:
816 if check_impl_detail(): # only on CPython (default)
817 if check_impl_detail(jython=True): # only on Jython
818 if check_impl_detail(cpython=False): # everywhere except on CPython
819 """
820 guards, default = _parse_guards(guards)
821 return guards.get(platform.python_implementation().lower(), default)
822
823
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000824
Guido van Rossumd8faa362007-04-27 19:54:29 +0000825def _run_suite(suite):
Barry Warsawc88425e2001-09-20 06:31:22 +0000826 """Run tests from a unittest.TestSuite-derived class."""
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000827 if verbose:
Fred Drake84a59342001-03-23 04:21:17 +0000828 runner = unittest.TextTestRunner(sys.stdout, verbosity=2)
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000829 else:
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000830 runner = BasicTestRunner()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000831
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000832 result = runner.run(suite)
833 if not result.wasSuccessful():
Fred Drake14f6c182001-07-16 18:51:32 +0000834 if len(result.errors) == 1 and not result.failures:
835 err = result.errors[0][1]
836 elif len(result.failures) == 1 and not result.errors:
837 err = result.failures[0][1]
838 else:
Guido van Rossum8ce8a782007-11-01 19:42:39 +0000839 err = "errors occurred; run in verbose mode for details"
Tim Peters2d84f2c2001-09-08 03:37:56 +0000840 raise TestFailed(err)
Tim Petersa0a62222001-09-09 06:12:01 +0000841
Barry Warsawc10d6902001-09-20 06:30:41 +0000842
Walter Dörwald21d3a322003-05-01 17:45:56 +0000843def run_unittest(*classes):
844 """Run tests from unittest.TestCase-derived classes."""
Guido van Rossumd8faa362007-04-27 19:54:29 +0000845 valid_types = (unittest.TestSuite, unittest.TestCase)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000846 suite = unittest.TestSuite()
Walter Dörwald21d3a322003-05-01 17:45:56 +0000847 for cls in classes:
Guido van Rossum3172c5d2007-10-16 18:12:55 +0000848 if isinstance(cls, str):
Guido van Rossumd8faa362007-04-27 19:54:29 +0000849 if cls in sys.modules:
850 suite.addTest(unittest.findTestCases(sys.modules[cls]))
851 else:
852 raise ValueError("str arguments must be keys in sys.modules")
853 elif isinstance(cls, valid_types):
Raymond Hettinger21d99872003-07-16 02:59:32 +0000854 suite.addTest(cls)
855 else:
856 suite.addTest(unittest.makeSuite(cls))
Guido van Rossumd8faa362007-04-27 19:54:29 +0000857 _run_suite(suite)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000858
Barry Warsawc10d6902001-09-20 06:30:41 +0000859
Tim Petersa0a62222001-09-09 06:12:01 +0000860#=======================================================================
861# doctest driver.
862
863def run_doctest(module, verbosity=None):
Tim Peters17111f32001-10-03 04:08:26 +0000864 """Run doctest on the given module. Return (#failures, #tests).
Tim Petersa0a62222001-09-09 06:12:01 +0000865
866 If optional argument verbosity is not specified (or is None), pass
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000867 support's belief about verbosity on to doctest. Else doctest's
Tim Petersbea3fb82001-09-10 01:39:21 +0000868 usual behavior is used (it searches sys.argv for -v).
Tim Petersa0a62222001-09-09 06:12:01 +0000869 """
870
871 import doctest
872
873 if verbosity is None:
874 verbosity = verbose
875 else:
876 verbosity = None
877
Tim Peters342ca752001-09-25 19:13:20 +0000878 # Direct doctest output (normally just errors) to real stdout; doctest
879 # output shouldn't be compared by regrtest.
880 save_stdout = sys.stdout
Tim Peters8dee8092001-09-25 20:05:11 +0000881 sys.stdout = get_original_stdout()
Tim Peters342ca752001-09-25 19:13:20 +0000882 try:
883 f, t = doctest.testmod(module, verbose=verbosity)
884 if f:
885 raise TestFailed("%d of %d doctests failed" % (f, t))
886 finally:
887 sys.stdout = save_stdout
Raymond Hettinger35b34bd2003-05-17 00:58:33 +0000888 if verbose:
Georg Brandldb028442008-02-05 20:48:58 +0000889 print('doctest (%s) ... %d tests with zero failures' %
890 (module.__name__, t))
Raymond Hettinger35b34bd2003-05-17 00:58:33 +0000891 return f, t
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000892
893#=======================================================================
894# Threading support to prevent reporting refleaks when running regrtest.py -R
895
896def threading_setup():
897 import threading
898 return len(threading._active), len(threading._limbo)
899
900def threading_cleanup(num_active, num_limbo):
901 import threading
902 import time
903
904 _MAX_COUNT = 10
905 count = 0
906 while len(threading._active) != num_active and count < _MAX_COUNT:
907 count += 1
908 time.sleep(0.1)
909
910 count = 0
911 while len(threading._limbo) != num_limbo and count < _MAX_COUNT:
912 count += 1
913 time.sleep(0.1)
914
915def reap_children():
916 """Use this function at the end of test_main() whenever sub-processes
917 are started. This will help ensure that no extra children (zombies)
918 stick around to hog resources and create problems when looking
919 for refleaks.
920 """
921
922 # Reap all our dead child processes so we don't leave zombies around.
923 # These hog resources and might be causing some of the buildbots to die.
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000924 if hasattr(os, 'waitpid'):
925 any_process = -1
926 while True:
927 try:
928 # This will raise an exception on Windows. That's ok.
929 pid, status = os.waitpid(any_process, os.WNOHANG)
930 if pid == 0:
931 break
932 except:
933 break