blob: 28823aebff7d0f0fad4a2053f55f4d2aef79a9ae [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
72def import_fresh_module(name, blocked_names=None, deprecated=False):
73 """Imports and returns a module, deliberately bypassing the sys.modules cache
74 and importing a fresh copy of the module. Once the import is complete,
75 the sys.modules cache is restored to its original state.
76
77 Importing of modules named in blocked_names is prevented while the fresh import
78 takes place.
79
80 If deprecated is True, any module or package deprecation messages
81 will be suppressed."""
82 # NOTE: test_heapq and test_warnings include extra sanity checks to make
83 # sure that this utility function is working as expected
84 with _ignore_deprecated_imports(deprecated):
85 if blocked_names is None:
86 blocked_names = ()
87 orig_modules = {}
88 if name in sys.modules:
89 orig_modules[name] = sys.modules[name]
90 del sys.modules[name]
91 try:
92 for blocked in blocked_names:
93 orig_modules[blocked] = sys.modules[blocked]
94 sys.modules[blocked] = 0
95 py_module = importlib.import_module(name)
96 finally:
97 for blocked, module in orig_modules.items():
98 sys.modules[blocked] = module
99 return py_module
100
Benjamin Peterson699adb92008-05-08 22:27:58 +0000101
R. David Murraya21e4ca2009-03-31 23:16:50 +0000102def get_attribute(obj, name):
103 """Get an attribute, raising SkipTest if AttributeError is raised."""
104 try:
105 attribute = getattr(obj, name)
106 except AttributeError:
107 raise unittest.SkipTest("module %s has no attribute %s" % (
108 obj.__name__, name))
109 else:
110 return attribute
111
Barry Warsawc0fb6052001-08-20 22:29:23 +0000112verbose = 1 # Flag set to 0 by regrtest.py
Thomas Wouters477c8d52006-05-27 19:21:47 +0000113use_resources = None # Flag set to [] by regrtest.py
114max_memuse = 0 # Disable bigmem tests (they will still be run with
115 # small sizes, to make sure they work.)
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000116real_max_memuse = 0
Guido van Rossum531661c1996-12-20 02:58:22 +0000117
Tim Peters8dee8092001-09-25 20:05:11 +0000118# _original_stdout is meant to hold stdout at the time regrtest began.
119# This may be "the real" stdout, or IDLE's emulation of stdout, or whatever.
120# The point is to have some flavor of stdout the user can actually see.
121_original_stdout = None
122def record_original_stdout(stdout):
123 global _original_stdout
124 _original_stdout = stdout
125
126def get_original_stdout():
127 return _original_stdout or sys.stdout
128
Guido van Rossum3bead091992-01-27 17:00:37 +0000129def unload(name):
Fred Drake004d5e62000-10-23 17:22:08 +0000130 try:
131 del sys.modules[name]
132 except KeyError:
133 pass
Guido van Rossum3bead091992-01-27 17:00:37 +0000134
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000135def unlink(filename):
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000136 try:
137 os.unlink(filename)
138 except OSError:
139 pass
140
Christian Heimes23daade02008-02-25 12:39:23 +0000141def rmtree(path):
142 try:
143 shutil.rmtree(path)
144 except OSError as e:
145 # Unix returns ENOENT, Windows returns ESRCH.
146 if e.errno not in (errno.ENOENT, errno.ESRCH):
147 raise
148
Guido van Rossum3bead091992-01-27 17:00:37 +0000149def forget(modname):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000150 '''"Forget" a module was ever imported by removing it from sys.modules and
151 deleting any .pyc and .pyo files.'''
Fred Drake004d5e62000-10-23 17:22:08 +0000152 unload(modname)
Fred Drake004d5e62000-10-23 17:22:08 +0000153 for dirname in sys.path:
Skip Montanaro7a98be22007-08-16 14:35:24 +0000154 unlink(os.path.join(dirname, modname + '.pyc'))
Brett Cannonf1cfb622003-05-04 21:15:27 +0000155 # Deleting the .pyo file cannot be within the 'try' for the .pyc since
156 # the chance exists that there is no .pyc (and thus the 'try' statement
157 # is exited) but there is a .pyo file.
Skip Montanaro7a98be22007-08-16 14:35:24 +0000158 unlink(os.path.join(dirname, modname + '.pyo'))
Guido van Rossum3bead091992-01-27 17:00:37 +0000159
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000160def is_resource_enabled(resource):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000161 """Test whether a resource is enabled. Known resources are set by
162 regrtest.py."""
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000163 return use_resources is not None and resource in use_resources
164
Barry Warsawc0fb6052001-08-20 22:29:23 +0000165def requires(resource, msg=None):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000166 """Raise ResourceDenied if the specified resource is not available.
167
168 If the caller's module is __main__ then automatically return True. The
169 possibility of False being returned occurs when regrtest.py is executing."""
Skip Montanarod839ecd2003-04-24 19:06:57 +0000170 # see if the caller's module is __main__ - if so, treat as if
171 # the resource was set
Benjamin Petersone549ead2009-03-28 21:42:05 +0000172 if sys._getframe(1).f_globals.get("__name__") == "__main__":
Skip Montanarod839ecd2003-04-24 19:06:57 +0000173 return
Tim Petersb4ee4eb2002-12-04 03:26:57 +0000174 if not is_resource_enabled(resource):
Barry Warsawc0fb6052001-08-20 22:29:23 +0000175 if msg is None:
176 msg = "Use of the `%s' resource not enabled" % resource
Fred Drake9a0db072003-02-03 15:19:30 +0000177 raise ResourceDenied(msg)
Barry Warsawc0fb6052001-08-20 22:29:23 +0000178
Christian Heimes5e696852008-04-09 08:37:03 +0000179HOST = 'localhost'
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000180
Christian Heimes5e696852008-04-09 08:37:03 +0000181def find_unused_port(family=socket.AF_INET, socktype=socket.SOCK_STREAM):
182 """Returns an unused port that should be suitable for binding. This is
183 achieved by creating a temporary socket with the same family and type as
184 the 'sock' parameter (default is AF_INET, SOCK_STREAM), and binding it to
185 the specified host address (defaults to 0.0.0.0) with the port set to 0,
186 eliciting an unused ephemeral port from the OS. The temporary socket is
187 then closed and deleted, and the ephemeral port is returned.
188
189 Either this method or bind_port() should be used for any tests where a
190 server socket needs to be bound to a particular port for the duration of
191 the test. Which one to use depends on whether the calling code is creating
192 a python socket, or if an unused port needs to be provided in a constructor
193 or passed to an external program (i.e. the -accept argument to openssl's
194 s_server mode). Always prefer bind_port() over find_unused_port() where
195 possible. Hard coded ports should *NEVER* be used. As soon as a server
196 socket is bound to a hard coded port, the ability to run multiple instances
197 of the test simultaneously on the same host is compromised, which makes the
198 test a ticking time bomb in a buildbot environment. On Unix buildbots, this
199 may simply manifest as a failed test, which can be recovered from without
200 intervention in most cases, but on Windows, the entire python process can
201 completely and utterly wedge, requiring someone to log in to the buildbot
202 and manually kill the affected process.
203
204 (This is easy to reproduce on Windows, unfortunately, and can be traced to
205 the SO_REUSEADDR socket option having different semantics on Windows versus
206 Unix/Linux. On Unix, you can't have two AF_INET SOCK_STREAM sockets bind,
207 listen and then accept connections on identical host/ports. An EADDRINUSE
208 socket.error will be raised at some point (depending on the platform and
209 the order bind and listen were called on each socket).
210
211 However, on Windows, if SO_REUSEADDR is set on the sockets, no EADDRINUSE
212 will ever be raised when attempting to bind two identical host/ports. When
213 accept() is called on each socket, the second caller's process will steal
214 the port from the first caller, leaving them both in an awkwardly wedged
215 state where they'll no longer respond to any signals or graceful kills, and
216 must be forcibly killed via OpenProcess()/TerminateProcess().
217
218 The solution on Windows is to use the SO_EXCLUSIVEADDRUSE socket option
219 instead of SO_REUSEADDR, which effectively affords the same semantics as
220 SO_REUSEADDR on Unix. Given the propensity of Unix developers in the Open
221 Source world compared to Windows ones, this is a common mistake. A quick
222 look over OpenSSL's 0.9.8g source shows that they use SO_REUSEADDR when
223 openssl.exe is called with the 's_server' option, for example. See
224 http://bugs.python.org/issue2550 for more info. The following site also
225 has a very thorough description about the implications of both REUSEADDR
226 and EXCLUSIVEADDRUSE on Windows:
227 http://msdn2.microsoft.com/en-us/library/ms740621(VS.85).aspx)
228
229 XXX: although this approach is a vast improvement on previous attempts to
230 elicit unused ports, it rests heavily on the assumption that the ephemeral
231 port returned to us by the OS won't immediately be dished back out to some
232 other process when we close and delete our temporary socket but before our
233 calling code has a chance to bind the returned port. We can deal with this
234 issue if/when we come across it.
235 """
236
237 tempsock = socket.socket(family, socktype)
238 port = bind_port(tempsock)
239 tempsock.close()
240 del tempsock
241 return port
242
243def bind_port(sock, host=HOST):
244 """Bind the socket to a free port and return the port number. Relies on
245 ephemeral ports in order to ensure we are using an unbound port. This is
246 important as many tests may be running simultaneously, especially in a
247 buildbot environment. This method raises an exception if the sock.family
248 is AF_INET and sock.type is SOCK_STREAM, *and* the socket has SO_REUSEADDR
249 or SO_REUSEPORT set on it. Tests should *never* set these socket options
250 for TCP/IP sockets. The only case for setting these options is testing
251 multicasting via multiple UDP sockets.
252
253 Additionally, if the SO_EXCLUSIVEADDRUSE socket option is available (i.e.
254 on Windows), it will be set on the socket. This will prevent anyone else
255 from bind()'ing to our host/port for the duration of the test.
256 """
257
258 if sock.family == socket.AF_INET and sock.type == socket.SOCK_STREAM:
259 if hasattr(socket, 'SO_REUSEADDR'):
260 if sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR) == 1:
261 raise TestFailed("tests should never set the SO_REUSEADDR " \
262 "socket option on TCP/IP sockets!")
263 if hasattr(socket, 'SO_REUSEPORT'):
264 if sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEPORT) == 1:
265 raise TestFailed("tests should never set the SO_REUSEPORT " \
266 "socket option on TCP/IP sockets!")
267 if hasattr(socket, 'SO_EXCLUSIVEADDRUSE'):
268 sock.setsockopt(socket.SOL_SOCKET, socket.SO_EXCLUSIVEADDRUSE, 1)
269
270 sock.bind((host, 0))
271 port = sock.getsockname()[1]
272 return port
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000273
Guido van Rossum35fb82a1993-01-26 13:04:43 +0000274FUZZ = 1e-6
275
276def fcmp(x, y): # fuzzy comparison function
Neal Norwitz79212992006-08-21 16:27:31 +0000277 if isinstance(x, float) or isinstance(y, float):
Fred Drake004d5e62000-10-23 17:22:08 +0000278 try:
Fred Drake004d5e62000-10-23 17:22:08 +0000279 fuzz = (abs(x) + abs(y)) * FUZZ
280 if abs(x-y) <= fuzz:
281 return 0
282 except:
283 pass
Neal Norwitz79212992006-08-21 16:27:31 +0000284 elif type(x) == type(y) and isinstance(x, (tuple, list)):
Fred Drake004d5e62000-10-23 17:22:08 +0000285 for i in range(min(len(x), len(y))):
286 outcome = fcmp(x[i], y[i])
Fred Drake132dce22000-12-12 23:11:42 +0000287 if outcome != 0:
Fred Drake004d5e62000-10-23 17:22:08 +0000288 return outcome
Guido van Rossum47b9ff62006-08-24 00:41:19 +0000289 return (len(x) > len(y)) - (len(x) < len(y))
290 return (x > y) - (x < y)
Guido van Rossum35fb82a1993-01-26 13:04:43 +0000291
Finn Bock57bc5fa2002-11-01 18:02:03 +0000292is_jython = sys.platform.startswith('java')
293
Barry Warsaw559f6682001-03-23 18:04:02 +0000294# Filename used for testing
295if os.name == 'java':
296 # Jython disallows @ in module names
297 TESTFN = '$test'
Martin v. Löwisa94568a2003-05-10 07:36:56 +0000298else:
Barry Warsaw559f6682001-03-23 18:04:02 +0000299 TESTFN = '@test'
Walter Dörwald9b775532007-06-08 14:30:53 +0000300
301 # Assuming sys.getfilesystemencoding()!=sys.getdefaultencoding()
302 # TESTFN_UNICODE is a filename that can be encoded using the
303 # file system encoding, but *not* with the default (ascii) encoding
304 TESTFN_UNICODE = "@test-\xe0\xf2"
305 TESTFN_ENCODING = sys.getfilesystemencoding()
306 # TESTFN_UNICODE_UNENCODEABLE is a filename that should *not* be
307 # able to be encoded by *either* the default or filesystem encoding.
308 # This test really only makes sense on Windows NT platforms
309 # which have special Unicode support in posixmodule.
310 if (not hasattr(sys, "getwindowsversion") or
311 sys.getwindowsversion()[3] < 2): # 0=win32s or 1=9x/ME
312 TESTFN_UNICODE_UNENCODEABLE = None
313 else:
314 # Japanese characters (I think - from bug 846133)
315 TESTFN_UNICODE_UNENCODEABLE = "@test-\u5171\u6709\u3055\u308c\u308b"
316 try:
317 # XXX - Note - should be using TESTFN_ENCODING here - but for
318 # Windows, "mbcs" currently always operates as if in
319 # errors=ignore' mode - hence we get '?' characters rather than
320 # the exception. 'Latin1' operates as we expect - ie, fails.
321 # See [ 850997 ] mbcs encoding ignores errors
322 TESTFN_UNICODE_UNENCODEABLE.encode("Latin1")
323 except UnicodeEncodeError:
324 pass
Martin v. Löwis2411a2d2002-11-09 19:57:26 +0000325 else:
Georg Brandldb028442008-02-05 20:48:58 +0000326 print('WARNING: The filename %r CAN be encoded by the filesystem. '
327 'Unicode filename tests may not be effective'
328 % TESTFN_UNICODE_UNENCODEABLE)
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000329
330# Make sure we can write to TESTFN, try in /tmp if we can't
331fp = None
332try:
333 fp = open(TESTFN, 'w+')
334except IOError:
335 TMP_TESTFN = os.path.join('/tmp', TESTFN)
336 try:
337 fp = open(TMP_TESTFN, 'w+')
338 TESTFN = TMP_TESTFN
339 del TMP_TESTFN
340 except IOError:
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000341 print(('WARNING: tests will fail, unable to write to: %s or %s' %
342 (TESTFN, TMP_TESTFN)))
Neal Norwitz26a1eef2002-11-03 00:35:53 +0000343if fp is not None:
344 fp.close()
Neal Norwitz0e17f8c2006-01-23 07:51:27 +0000345 unlink(TESTFN)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000346del fp
Guido van Rossuma8f7e592001-03-13 09:31:07 +0000347
Guido van Rossume26132c1998-04-23 20:13:30 +0000348def findfile(file, here=__file__):
Brett Cannonf1cfb622003-05-04 21:15:27 +0000349 """Try to find a file on sys.path and the working directory. If it is not
350 found the argument passed to the function is returned (this does not
351 necessarily signal failure; could still be the legitimate path)."""
Fred Drake004d5e62000-10-23 17:22:08 +0000352 if os.path.isabs(file):
353 return file
Fred Drake004d5e62000-10-23 17:22:08 +0000354 path = sys.path
355 path = [os.path.dirname(here)] + path
356 for dn in path:
357 fn = os.path.join(dn, file)
358 if os.path.exists(fn): return fn
359 return file
Marc-André Lemburg36619082001-01-17 19:11:13 +0000360
361def verify(condition, reason='test failed'):
Guido van Rossuma1374e42001-01-19 19:01:56 +0000362 """Verify that condition is true. If not, raise TestFailed.
Marc-André Lemburg36619082001-01-17 19:11:13 +0000363
Skip Montanaroc955f892001-01-20 19:12:54 +0000364 The optional argument reason can be given to provide
Tim Peters983874d2001-01-19 05:59:21 +0000365 a better error text.
Tim Petersd2bf3b72001-01-18 02:22:22 +0000366 """
Tim Peters983874d2001-01-19 05:59:21 +0000367
Tim Petersd2bf3b72001-01-18 02:22:22 +0000368 if not condition:
Guido van Rossuma1374e42001-01-19 19:01:56 +0000369 raise TestFailed(reason)
Jeremy Hylton47793992001-02-19 15:35:26 +0000370
Tim Petersc2fe6182001-10-30 23:20:46 +0000371def vereq(a, b):
Tim Peters77902972001-12-29 17:34:57 +0000372 """Raise TestFailed if a == b is false.
373
374 This is better than verify(a == b) because, in case of failure, the
375 error message incorporates repr(a) and repr(b) so you can see the
376 inputs.
377
378 Note that "not (a == b)" isn't necessarily the same as "a != b"; the
379 former is tested.
380 """
381
Tim Petersc2fe6182001-10-30 23:20:46 +0000382 if not (a == b):
Guido van Rossumd8faa362007-04-27 19:54:29 +0000383 raise TestFailed("%r == %r" % (a, b))
Tim Petersc2fe6182001-10-30 23:20:46 +0000384
Tim Peters2f228e72001-05-13 00:19:31 +0000385def sortdict(dict):
386 "Like repr(dict), but in sorted order."
Guido van Rossumcc2b0162007-02-11 06:12:03 +0000387 items = sorted(dict.items())
Tim Peters2f228e72001-05-13 00:19:31 +0000388 reprpairs = ["%r: %r" % pair for pair in items]
389 withcommas = ", ".join(reprpairs)
390 return "{%s}" % withcommas
391
Benjamin Peterson7522c742009-01-19 21:00:09 +0000392def make_bad_fd():
393 """
394 Create an invalid file descriptor by opening and closing a file and return
395 its fd.
396 """
397 file = open(TESTFN, "wb")
398 try:
399 return file.fileno()
400 finally:
401 file.close()
402 unlink(TESTFN)
403
Thomas Wouters89f507f2006-12-13 04:49:30 +0000404def check_syntax_error(testcase, statement):
Benjamin Petersone549ead2009-03-28 21:42:05 +0000405 testcase.assertRaises(SyntaxError, compile, statement,
406 '<test string>', 'exec')
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000407
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000408def open_urlresource(url, *args, **kw):
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000409 import urllib.request, urllib.parse
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000410
Guido van Rossum360e4b82007-05-14 22:51:27 +0000411 requires('urlfetch')
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000412 filename = urllib.parse.urlparse(url)[2].split('/')[-1] # '/': it's URL!
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000413
414 for path in [os.path.curdir, os.path.pardir]:
415 fn = os.path.join(path, filename)
416 if os.path.exists(fn):
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000417 return open(fn, *args, **kw)
Hye-Shik Changaaa2f1d2005-12-10 17:44:27 +0000418
Guido van Rossumbe19ed72007-02-09 05:37:30 +0000419 print('\tfetching %s ...' % url, file=get_original_stdout())
Jeremy Hylton1afc1692008-06-18 20:49:58 +0000420 fn, _ = urllib.request.urlretrieve(url, filename)
Martin v. Löwis234a34a2007-08-30 20:58:02 +0000421 return open(fn, *args, **kw)
Thomas Wouters9fe394c2007-02-05 01:24:16 +0000422
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000423
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000424class WarningsRecorder(object):
425 """Convenience wrapper for the warnings list returned on
426 entry to the warnings.catch_warnings() context manager.
Guido van Rossumd8faa362007-04-27 19:54:29 +0000427 """
Benjamin Petersonfcf5d632008-10-16 23:24:44 +0000428 def __init__(self, warnings_list):
429 self.warnings = warnings_list
430
431 def __getattr__(self, attr):
432 if self.warnings:
433 return getattr(self.warnings[-1], attr)
434 elif attr in warnings.WarningMessage._WARNING_DETAILS:
435 return None
436 raise AttributeError("%r has no attribute %r" % (self, attr))
437
438 def reset(self):
439 del self.warnings[:]
440
441@contextlib.contextmanager
442def check_warnings():
443 with warnings.catch_warnings(record=True) as w:
444 yield WarningsRecorder(w)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000445
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000446
447class CleanImport(object):
448 """Context manager to force import to return a new module reference.
449
450 This is useful for testing module-level behaviours, such as
Nick Coghlanb1304932008-07-13 12:25:08 +0000451 the emission of a DeprecationWarning on import.
Alexandre Vassalotti5f8ced22008-05-16 00:03:33 +0000452
453 Use like this:
454
455 with CleanImport("foo"):
456 __import__("foo") # new reference
457 """
458
459 def __init__(self, *module_names):
460 self.original_modules = sys.modules.copy()
461 for module_name in module_names:
462 if module_name in sys.modules:
463 module = sys.modules[module_name]
464 # It is possible that module_name is just an alias for
465 # another module (e.g. stub for modules renamed in 3.x).
466 # In that case, we also need delete the real module to clear
467 # the import cache.
468 if module.__name__ != module_name:
469 del sys.modules[module.__name__]
470 del sys.modules[module_name]
471
472 def __enter__(self):
473 return self
474
475 def __exit__(self, *ignore_exc):
476 sys.modules.update(self.original_modules)
477
478
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000479class EnvironmentVarGuard(object):
480
481 """Class to help protect the environment variable properly. Can be used as
482 a context manager."""
483
484 def __init__(self):
Guido van Rossumd8faa362007-04-27 19:54:29 +0000485 self._environ = os.environ
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000486 self._unset = set()
487 self._reset = dict()
488
489 def set(self, envvar, value):
490 if envvar not in self._environ:
491 self._unset.add(envvar)
492 else:
493 self._reset[envvar] = self._environ[envvar]
494 self._environ[envvar] = value
495
496 def unset(self, envvar):
497 if envvar in self._environ:
498 self._reset[envvar] = self._environ[envvar]
499 del self._environ[envvar]
500
501 def __enter__(self):
502 return self
503
504 def __exit__(self, *ignore_exc):
Guido van Rossumcc2b0162007-02-11 06:12:03 +0000505 for envvar, value in self._reset.items():
Thomas Wouters902d6eb2007-01-09 23:18:33 +0000506 self._environ[envvar] = value
507 for unset in self._unset:
508 del self._environ[unset]
509
Guido van Rossumd8faa362007-04-27 19:54:29 +0000510class TransientResource(object):
511
512 """Raise ResourceDenied if an exception is raised while the context manager
513 is in effect that matches the specified exception and attributes."""
514
515 def __init__(self, exc, **kwargs):
516 self.exc = exc
517 self.attrs = kwargs
518
519 def __enter__(self):
520 return self
521
522 def __exit__(self, type_=None, value=None, traceback=None):
523 """If type_ is a subclass of self.exc and value has attributes matching
524 self.attrs, raise ResourceDenied. Otherwise let the exception
525 propagate (if any)."""
526 if type_ is not None and issubclass(self.exc, type_):
527 for attr, attr_value in self.attrs.items():
528 if not hasattr(value, attr):
529 break
530 if getattr(value, attr) != attr_value:
531 break
532 else:
533 raise ResourceDenied("an optional resource is not available")
534
535
536def transient_internet():
537 """Return a context manager that raises ResourceDenied when various issues
538 with the Internet connection manifest themselves as exceptions."""
539 time_out = TransientResource(IOError, errno=errno.ETIMEDOUT)
540 socket_peer_reset = TransientResource(socket.error, errno=errno.ECONNRESET)
541 ioerror_peer_reset = TransientResource(IOError, errno=errno.ECONNRESET)
542 return contextlib.nested(time_out, socket_peer_reset, ioerror_peer_reset)
543
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000544
Thomas Woutersed03b412007-08-28 21:37:11 +0000545@contextlib.contextmanager
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000546def captured_output(stream_name):
547 """Run the 'with' statement body using a StringIO object in place of a
548 specific attribute on the sys module.
549 Example use (with 'stream_name=stdout')::
Thomas Woutersed03b412007-08-28 21:37:11 +0000550
551 with captured_stdout() as s:
Neal Norwitz752abd02008-05-13 04:55:24 +0000552 print("hello")
Thomas Woutersed03b412007-08-28 21:37:11 +0000553 assert s.getvalue() == "hello"
554 """
555 import io
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000556 orig_stdout = getattr(sys, stream_name)
557 setattr(sys, stream_name, io.StringIO())
Christian Heimes81ee3ef2008-05-04 22:42:01 +0000558 try:
559 yield getattr(sys, stream_name)
560 finally:
561 setattr(sys, stream_name, orig_stdout)
Benjamin Petersonad9d48d2008-04-02 21:49:44 +0000562
563def captured_stdout():
564 return captured_output("stdout")
Thomas Woutersed03b412007-08-28 21:37:11 +0000565
Benjamin Petersone549ead2009-03-28 21:42:05 +0000566def gc_collect():
567 """Force as many objects as possible to be collected.
568
569 In non-CPython implementations of Python, this is needed because timely
570 deallocation is not guaranteed by the garbage collector. (Even in CPython
571 this can be the case in case of reference cycles.) This means that __del__
572 methods may be called later than expected and weakrefs may remain alive for
573 longer than expected. This function tries its best to force all garbage
574 objects to disappear.
575 """
576 import gc
577 gc.collect()
578 gc.collect()
579 gc.collect()
580
Thomas Woutersed03b412007-08-28 21:37:11 +0000581
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000582#=======================================================================
Thomas Wouters477c8d52006-05-27 19:21:47 +0000583# Decorator for running a function in a different locale, correctly resetting
584# it afterwards.
585
586def run_with_locale(catstr, *locales):
587 def decorator(func):
588 def inner(*args, **kwds):
589 try:
590 import locale
591 category = getattr(locale, catstr)
592 orig_locale = locale.setlocale(category)
593 except AttributeError:
594 # if the test author gives us an invalid category string
595 raise
596 except:
597 # cannot retrieve original locale, so do nothing
598 locale = orig_locale = None
599 else:
600 for loc in locales:
601 try:
602 locale.setlocale(category, loc)
603 break
604 except:
605 pass
606
607 # now run the function, resetting the locale on exceptions
608 try:
609 return func(*args, **kwds)
610 finally:
611 if locale and orig_locale:
612 locale.setlocale(category, orig_locale)
Neal Norwitz221085d2007-02-25 20:55:47 +0000613 inner.__name__ = func.__name__
Thomas Wouters477c8d52006-05-27 19:21:47 +0000614 inner.__doc__ = func.__doc__
615 return inner
616 return decorator
617
618#=======================================================================
Georg Brandldb028442008-02-05 20:48:58 +0000619# Big-memory-test support. Separate from 'resources' because memory use
620# should be configurable.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000621
622# Some handy shorthands. Note that these are used for byte-limits as well
623# as size-limits, in the various bigmem tests
624_1M = 1024*1024
625_1G = 1024 * _1M
626_2G = 2 * _1G
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000627_4G = 4 * _1G
Thomas Wouters477c8d52006-05-27 19:21:47 +0000628
Thomas Woutersd2cf20e2007-08-30 22:57:53 +0000629MAX_Py_ssize_t = sys.maxsize
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000630
Thomas Wouters477c8d52006-05-27 19:21:47 +0000631def set_memlimit(limit):
632 import re
633 global max_memuse
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000634 global real_max_memuse
Thomas Wouters477c8d52006-05-27 19:21:47 +0000635 sizes = {
636 'k': 1024,
637 'm': _1M,
638 'g': _1G,
639 't': 1024*_1G,
640 }
641 m = re.match(r'(\d+(\.\d+)?) (K|M|G|T)b?$', limit,
642 re.IGNORECASE | re.VERBOSE)
643 if m is None:
644 raise ValueError('Invalid memory limit %r' % (limit,))
645 memlimit = int(float(m.group(1)) * sizes[m.group(3).lower()])
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000646 real_max_memuse = memlimit
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000647 if memlimit > MAX_Py_ssize_t:
648 memlimit = MAX_Py_ssize_t
649 if memlimit < _2G - 1:
Thomas Wouters477c8d52006-05-27 19:21:47 +0000650 raise ValueError('Memory limit %r too low to be useful' % (limit,))
651 max_memuse = memlimit
652
653def bigmemtest(minsize, memuse, overhead=5*_1M):
654 """Decorator for bigmem tests.
655
656 'minsize' is the minimum useful size for the test (in arbitrary,
657 test-interpreted units.) 'memuse' is the number of 'bytes per size' for
658 the test, or a good estimate of it. 'overhead' specifies fixed overhead,
Christian Heimes33fe8092008-04-13 13:53:33 +0000659 independent of the testsize, and defaults to 5Mb.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000660
661 The decorator tries to guess a good value for 'size' and passes it to
662 the decorated test function. If minsize * memuse is more than the
663 allowed memory use (as defined by max_memuse), the test is skipped.
664 Otherwise, minsize is adjusted upward to use up to max_memuse.
665 """
666 def decorator(f):
667 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000668 # Retrieve values in case someone decided to adjust them
669 minsize = wrapper.minsize
670 memuse = wrapper.memuse
671 overhead = wrapper.overhead
Thomas Wouters477c8d52006-05-27 19:21:47 +0000672 if not max_memuse:
673 # If max_memuse is 0 (the default),
674 # we still want to run the tests with size set to a few kb,
675 # to make sure they work. We still want to avoid using
676 # too much memory, though, but we do that noisily.
677 maxsize = 5147
678 self.failIf(maxsize * memuse + overhead > 20 * _1M)
679 else:
680 maxsize = int((max_memuse - overhead) / memuse)
681 if maxsize < minsize:
682 # Really ought to print 'test skipped' or something
683 if verbose:
684 sys.stderr.write("Skipping %s because of memory "
685 "constraint\n" % (f.__name__,))
686 return
687 # Try to keep some breathing room in memory use
688 maxsize = max(maxsize - 50 * _1M, minsize)
689 return f(self, maxsize)
690 wrapper.minsize = minsize
691 wrapper.memuse = memuse
692 wrapper.overhead = overhead
693 return wrapper
694 return decorator
695
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000696def precisionbigmemtest(size, memuse, overhead=5*_1M):
697 def decorator(f):
698 def wrapper(self):
Antoine Pitrou7cdb4952009-03-07 23:40:49 +0000699 size = wrapper.size
700 memuse = wrapper.memuse
701 overhead = wrapper.overhead
Neal Norwitz3ce5d922008-08-24 07:08:55 +0000702 if not real_max_memuse:
703 maxsize = 5147
704 else:
705 maxsize = size
706
707 if real_max_memuse and real_max_memuse < maxsize * memuse:
708 if verbose:
709 sys.stderr.write("Skipping %s because of memory "
710 "constraint\n" % (f.__name__,))
711 return
712
713 return f(self, maxsize)
714 wrapper.size = size
715 wrapper.memuse = memuse
716 wrapper.overhead = overhead
717 return wrapper
718 return decorator
719
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000720def bigaddrspacetest(f):
721 """Decorator for tests that fill the address space."""
722 def wrapper(self):
723 if max_memuse < MAX_Py_ssize_t:
724 if verbose:
725 sys.stderr.write("Skipping %s because of memory "
726 "constraint\n" % (f.__name__,))
727 else:
728 return f(self)
729 return wrapper
730
Thomas Wouters477c8d52006-05-27 19:21:47 +0000731#=======================================================================
Guido van Rossumd8faa362007-04-27 19:54:29 +0000732# unittest integration.
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000733
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000734class BasicTestRunner:
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000735 def run(self, test):
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000736 result = unittest.TestResult()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000737 test(result)
738 return result
739
Benjamin Petersone549ead2009-03-28 21:42:05 +0000740def _id(obj):
741 return obj
742
743def requires_resource(resource):
744 if resource_is_enabled(resource):
745 return _id
746 else:
747 return unittest.skip("resource {0!r} is not enabled".format(resource))
748
749def cpython_only(test):
750 """
751 Decorator for tests only applicable on CPython.
752 """
753 return impl_detail(cpython=True)(test)
754
755def impl_detail(msg=None, **guards):
756 if check_impl_detail(**guards):
757 return _id
758 if msg is None:
759 guardnames, default = _parse_guards(guards)
760 if default:
761 msg = "implementation detail not available on {0}"
762 else:
763 msg = "implementation detail specific to {0}"
764 guardnames = sorted(guardnames.keys())
765 msg = msg.format(' or '.join(guardnames))
766 return unittest.skip(msg)
767
768def _parse_guards(guards):
769 # Returns a tuple ({platform_name: run_me}, default_value)
770 if not guards:
771 return ({'cpython': True}, False)
772 is_true = guards.values()[0]
773 assert guards.values() == [is_true] * len(guards) # all True or all False
774 return (guards, not is_true)
775
776# Use the following check to guard CPython's implementation-specific tests --
777# or to run them only on the implementation(s) guarded by the arguments.
778def check_impl_detail(**guards):
779 """This function returns True or False depending on the host platform.
780 Examples:
781 if check_impl_detail(): # only on CPython (default)
782 if check_impl_detail(jython=True): # only on Jython
783 if check_impl_detail(cpython=False): # everywhere except on CPython
784 """
785 guards, default = _parse_guards(guards)
786 return guards.get(platform.python_implementation().lower(), default)
787
788
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000789
Guido van Rossumd8faa362007-04-27 19:54:29 +0000790def _run_suite(suite):
Barry Warsawc88425e2001-09-20 06:31:22 +0000791 """Run tests from a unittest.TestSuite-derived class."""
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000792 if verbose:
Fred Drake84a59342001-03-23 04:21:17 +0000793 runner = unittest.TextTestRunner(sys.stdout, verbosity=2)
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000794 else:
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000795 runner = BasicTestRunner()
Fred Drakecd1b1dd2001-03-21 18:26:33 +0000796
Steve Purcell5ddd1a82001-03-22 08:45:36 +0000797 result = runner.run(suite)
798 if not result.wasSuccessful():
Fred Drake14f6c182001-07-16 18:51:32 +0000799 if len(result.errors) == 1 and not result.failures:
800 err = result.errors[0][1]
801 elif len(result.failures) == 1 and not result.errors:
802 err = result.failures[0][1]
803 else:
Guido van Rossum8ce8a782007-11-01 19:42:39 +0000804 err = "errors occurred; run in verbose mode for details"
Tim Peters2d84f2c2001-09-08 03:37:56 +0000805 raise TestFailed(err)
Tim Petersa0a62222001-09-09 06:12:01 +0000806
Barry Warsawc10d6902001-09-20 06:30:41 +0000807
Walter Dörwald21d3a322003-05-01 17:45:56 +0000808def run_unittest(*classes):
809 """Run tests from unittest.TestCase-derived classes."""
Guido van Rossumd8faa362007-04-27 19:54:29 +0000810 valid_types = (unittest.TestSuite, unittest.TestCase)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000811 suite = unittest.TestSuite()
Walter Dörwald21d3a322003-05-01 17:45:56 +0000812 for cls in classes:
Guido van Rossum3172c5d2007-10-16 18:12:55 +0000813 if isinstance(cls, str):
Guido van Rossumd8faa362007-04-27 19:54:29 +0000814 if cls in sys.modules:
815 suite.addTest(unittest.findTestCases(sys.modules[cls]))
816 else:
817 raise ValueError("str arguments must be keys in sys.modules")
818 elif isinstance(cls, valid_types):
Raymond Hettinger21d99872003-07-16 02:59:32 +0000819 suite.addTest(cls)
820 else:
821 suite.addTest(unittest.makeSuite(cls))
Guido van Rossumd8faa362007-04-27 19:54:29 +0000822 _run_suite(suite)
Raymond Hettinger9dcbbea2003-04-27 07:54:23 +0000823
Barry Warsawc10d6902001-09-20 06:30:41 +0000824
Tim Petersa0a62222001-09-09 06:12:01 +0000825#=======================================================================
826# doctest driver.
827
828def run_doctest(module, verbosity=None):
Tim Peters17111f32001-10-03 04:08:26 +0000829 """Run doctest on the given module. Return (#failures, #tests).
Tim Petersa0a62222001-09-09 06:12:01 +0000830
831 If optional argument verbosity is not specified (or is None), pass
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000832 support's belief about verbosity on to doctest. Else doctest's
Tim Petersbea3fb82001-09-10 01:39:21 +0000833 usual behavior is used (it searches sys.argv for -v).
Tim Petersa0a62222001-09-09 06:12:01 +0000834 """
835
836 import doctest
837
838 if verbosity is None:
839 verbosity = verbose
840 else:
841 verbosity = None
842
Tim Peters342ca752001-09-25 19:13:20 +0000843 # Direct doctest output (normally just errors) to real stdout; doctest
844 # output shouldn't be compared by regrtest.
845 save_stdout = sys.stdout
Tim Peters8dee8092001-09-25 20:05:11 +0000846 sys.stdout = get_original_stdout()
Tim Peters342ca752001-09-25 19:13:20 +0000847 try:
848 f, t = doctest.testmod(module, verbose=verbosity)
849 if f:
850 raise TestFailed("%d of %d doctests failed" % (f, t))
851 finally:
852 sys.stdout = save_stdout
Raymond Hettinger35b34bd2003-05-17 00:58:33 +0000853 if verbose:
Georg Brandldb028442008-02-05 20:48:58 +0000854 print('doctest (%s) ... %d tests with zero failures' %
855 (module.__name__, t))
Raymond Hettinger35b34bd2003-05-17 00:58:33 +0000856 return f, t
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000857
858#=======================================================================
859# Threading support to prevent reporting refleaks when running regrtest.py -R
860
861def threading_setup():
862 import threading
863 return len(threading._active), len(threading._limbo)
864
865def threading_cleanup(num_active, num_limbo):
866 import threading
867 import time
868
869 _MAX_COUNT = 10
870 count = 0
871 while len(threading._active) != num_active and count < _MAX_COUNT:
872 count += 1
873 time.sleep(0.1)
874
875 count = 0
876 while len(threading._limbo) != num_limbo and count < _MAX_COUNT:
877 count += 1
878 time.sleep(0.1)
879
880def reap_children():
881 """Use this function at the end of test_main() whenever sub-processes
882 are started. This will help ensure that no extra children (zombies)
883 stick around to hog resources and create problems when looking
884 for refleaks.
885 """
886
887 # Reap all our dead child processes so we don't leave zombies around.
888 # These hog resources and might be causing some of the buildbots to die.
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000889 if hasattr(os, 'waitpid'):
890 any_process = -1
891 while True:
892 try:
893 # This will raise an exception on Windows. That's ok.
894 pid, status = os.waitpid(any_process, os.WNOHANG)
895 if pid == 0:
896 break
897 except:
898 break