| Benjamin Peterson | 90f5ba5 | 2010-03-11 22:53:45 +0000 | [diff] [blame] | 1 | #! /usr/bin/env python3 | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 2 |  | 
| R. David Murray | 0ba81e0 | 2010-04-26 17:02:32 +0000 | [diff] [blame] | 3 | """ | 
 | 4 | Usage: | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 5 |  | 
| Georg Brandl | be41a48 | 2011-01-05 21:47:47 +0000 | [diff] [blame] | 6 | python -m test [options] [test_name1 [test_name2 ...]] | 
| R. David Murray | 0ba81e0 | 2010-04-26 17:02:32 +0000 | [diff] [blame] | 7 | python path/to/Lib/test/regrtest.py [options] [test_name1 [test_name2 ...]] | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 8 |  | 
| R. David Murray | 0ba81e0 | 2010-04-26 17:02:32 +0000 | [diff] [blame] | 9 |  | 
 | 10 | If no arguments or options are provided, finds all files matching | 
 | 11 | the pattern "test_*" in the Lib/test subdirectory and runs | 
 | 12 | them in alphabetical order (but see -M and -u, below, for exceptions). | 
 | 13 |  | 
 | 14 | For more rigorous testing, it is useful to use the following | 
 | 15 | command line: | 
 | 16 |  | 
| Georg Brandl | be41a48 | 2011-01-05 21:47:47 +0000 | [diff] [blame] | 17 | python -E -Wd -m test [options] [test_name1 ...] | 
| R. David Murray | 0ba81e0 | 2010-04-26 17:02:32 +0000 | [diff] [blame] | 18 |  | 
 | 19 |  | 
 | 20 | Options: | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 21 |  | 
| Georg Brandl | 96f7897 | 2009-10-27 21:02:11 +0000 | [diff] [blame] | 22 | -h/--help       -- print this text and exit | 
 | 23 |  | 
 | 24 | Verbosity | 
 | 25 |  | 
 | 26 | -v/--verbose    -- run tests in verbose mode with output to stdout | 
 | 27 | -w/--verbose2   -- re-run failed tests in verbose mode | 
| Victor Stinner | a7c33e5 | 2011-06-29 13:00:54 +0200 | [diff] [blame] | 28 | -W/--verbose3   -- display test output on failure | 
| Georg Brandl | 96f7897 | 2009-10-27 21:02:11 +0000 | [diff] [blame] | 29 | -d/--debug      -- print traceback for failed tests | 
| R. David Murray | 0ba81e0 | 2010-04-26 17:02:32 +0000 | [diff] [blame] | 30 | -q/--quiet      -- no output unless one or more tests fail | 
| Georg Brandl | 96f7897 | 2009-10-27 21:02:11 +0000 | [diff] [blame] | 31 | -S/--slow       -- print the slowest 10 tests | 
| Antoine Pitrou | 3c4402f | 2011-01-03 20:38:52 +0000 | [diff] [blame] | 32 |    --header     -- print header with interpreter info | 
| Georg Brandl | 96f7897 | 2009-10-27 21:02:11 +0000 | [diff] [blame] | 33 |  | 
 | 34 | Selecting tests | 
 | 35 |  | 
| R. David Murray | 0ba81e0 | 2010-04-26 17:02:32 +0000 | [diff] [blame] | 36 | -r/--random     -- randomize test execution order (see below) | 
| Antoine Pitrou | 68530ac | 2011-01-03 20:40:07 +0000 | [diff] [blame] | 37 |    --randseed   -- pass a random seed to reproduce a previous random run | 
| Georg Brandl | 96f7897 | 2009-10-27 21:02:11 +0000 | [diff] [blame] | 38 | -f/--fromfile   -- read names of tests to run from a file (see below) | 
 | 39 | -x/--exclude    -- arguments are tests to *exclude* | 
| R. David Murray | 0ba81e0 | 2010-04-26 17:02:32 +0000 | [diff] [blame] | 40 | -s/--single     -- single step through a set of tests (see below) | 
| Georg Brandl | 96f7897 | 2009-10-27 21:02:11 +0000 | [diff] [blame] | 41 | -u/--use RES1,RES2,... | 
 | 42 |                 -- specify which special resource intensive tests to run | 
 | 43 | -M/--memlimit LIMIT | 
 | 44 |                 -- run very large memory-consuming tests | 
 | 45 |  | 
 | 46 | Special runs | 
 | 47 |  | 
 | 48 | -l/--findleaks  -- if GC is available detect tests that leak memory | 
 | 49 | -L/--runleaks   -- run the leaks(1) command just before exit | 
 | 50 | -R/--huntrleaks RUNCOUNTS | 
 | 51 |                 -- search for reference leaks (needs debug build, v. slow) | 
 | 52 | -j/--multiprocess PROCESSES | 
 | 53 |                 -- run PROCESSES processes at once | 
| R. David Murray | 0ba81e0 | 2010-04-26 17:02:32 +0000 | [diff] [blame] | 54 | -T/--coverage   -- turn on code coverage tracing using the trace module | 
| Georg Brandl | 96f7897 | 2009-10-27 21:02:11 +0000 | [diff] [blame] | 55 | -D/--coverdir DIRECTORY | 
 | 56 |                 -- Directory where coverage files are put | 
 | 57 | -N/--nocoverdir -- Put coverage files alongside modules | 
 | 58 | -t/--threshold THRESHOLD | 
 | 59 |                 -- call gc.set_threshold(THRESHOLD) | 
 | 60 | -n/--nowindows  -- suppress error message boxes on Windows | 
| R. David Murray | 0ba81e0 | 2010-04-26 17:02:32 +0000 | [diff] [blame] | 61 | -F/--forever    -- run the specified tests in a loop, until an error happens | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 62 |  | 
| R. David Murray | 0ba81e0 | 2010-04-26 17:02:32 +0000 | [diff] [blame] | 63 |  | 
 | 64 | Additional Option Details: | 
| Guido van Rossum | f58ed25 | 1997-03-07 21:04:33 +0000 | [diff] [blame] | 65 |  | 
| Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 66 | -r randomizes test execution order. You can use --randseed=int to provide a | 
 | 67 | int seed value for the randomizer; this is useful for reproducing troublesome | 
 | 68 | test orders. | 
 | 69 |  | 
| R. David Murray | 0ba81e0 | 2010-04-26 17:02:32 +0000 | [diff] [blame] | 70 | -s On the first invocation of regrtest using -s, the first test file found | 
 | 71 | or the first test file given on the command line is run, and the name of | 
 | 72 | the next test is recorded in a file named pynexttest.  If run from the | 
 | 73 | Python build directory, pynexttest is located in the 'build' subdirectory, | 
 | 74 | otherwise it is located in tempfile.gettempdir().  On subsequent runs, | 
 | 75 | the test in pynexttest is run, and the next test is written to pynexttest. | 
 | 76 | When the last test has been run, pynexttest is deleted.  In this way it | 
 | 77 | is possible to single step through the test files.  This is useful when | 
 | 78 | doing memory analysis on the Python interpreter, which process tends to | 
 | 79 | consume too many resources to run the full regression test non-stop. | 
| Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 80 |  | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 81 | -S is used to continue running tests after an aborted run.  It will | 
 | 82 | maintain the order a standard run (ie, this assumes -r is not used). | 
 | 83 | This is useful after the tests have prematurely stopped for some external | 
 | 84 | reason and you want to start running from where you left off rather | 
 | 85 | than starting from the beginning. | 
 | 86 |  | 
| Guido van Rossum | 9e9d4f8 | 2002-06-07 15:17:03 +0000 | [diff] [blame] | 87 | -f reads the names of tests from the file given as f's argument, one | 
 | 88 | or more test names per line.  Whitespace is ignored.  Blank lines and | 
 | 89 | lines beginning with '#' are ignored.  This is especially useful for | 
 | 90 | whittling down failures involving interactions among tests. | 
| Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 91 |  | 
| Skip Montanaro | 0179a18 | 2004-06-06 15:53:18 +0000 | [diff] [blame] | 92 | -L causes the leaks(1) command to be run just before exit if it exists. | 
 | 93 | leaks(1) is available on Mac OS X and presumably on some other | 
 | 94 | FreeBSD-derived systems. | 
 | 95 |  | 
| Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 96 | -R runs each test several times and examines sys.gettotalrefcount() to | 
 | 97 | see if the test appears to be leaking references.  The argument should | 
 | 98 | be of the form stab:run:fname where 'stab' is the number of times the | 
 | 99 | test is run to let gettotalrefcount settle down, 'run' is the number | 
 | 100 | of times further it is run and 'fname' is the name of the file the | 
 | 101 | reports are written to.  These parameters all have defaults (5, 4 and | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 102 | "reflog.txt" respectively), and the minimal invocation is '-R :'. | 
| Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 103 |  | 
| Thomas Wouters | 477c8d5 | 2006-05-27 19:21:47 +0000 | [diff] [blame] | 104 | -M runs tests that require an exorbitant amount of memory. These tests | 
 | 105 | typically try to ascertain containers keep working when containing more than | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 106 | 2 billion objects, which only works on 64-bit systems. There are also some | 
 | 107 | tests that try to exhaust the address space of the process, which only makes | 
 | 108 | sense on 32-bit systems with at least 2Gb of memory. The passed-in memlimit, | 
| Thomas Wouters | 477c8d5 | 2006-05-27 19:21:47 +0000 | [diff] [blame] | 109 | which is a string in the form of '2.5Gb', determines howmuch memory the | 
 | 110 | tests will limit themselves to (but they may go slightly over.) The number | 
 | 111 | shouldn't be more memory than the machine has (including swap memory). You | 
 | 112 | should also keep in mind that swap memory is generally much, much slower | 
 | 113 | than RAM, and setting memlimit to all available RAM or higher will heavily | 
 | 114 | tax the machine. On the other hand, it is no use running these tests with a | 
 | 115 | limit of less than 2.5Gb, and many require more than 20Gb. Tests that expect | 
 | 116 | to use more than memlimit memory will be skipped. The big-memory tests | 
 | 117 | generally run very, very long. | 
 | 118 |  | 
| Guido van Rossum | 9e9d4f8 | 2002-06-07 15:17:03 +0000 | [diff] [blame] | 119 | -u is used to specify which special resource intensive tests to run, | 
 | 120 | such as those requiring large file support or network connectivity. | 
 | 121 | The argument is a comma-separated list of words indicating the | 
 | 122 | resources to test.  Currently only the following are defined: | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 123 |  | 
| Fred Drake | 3a15dac | 2002-04-11 16:39:16 +0000 | [diff] [blame] | 124 |     all -       Enable all special resources. | 
 | 125 |  | 
| Guido van Rossum | 315aa36 | 2003-03-11 14:46:48 +0000 | [diff] [blame] | 126 |     audio -     Tests that use the audio device.  (There are known | 
 | 127 |                 cases of broken audio drivers that can crash Python or | 
 | 128 |                 even the Linux kernel.) | 
 | 129 |  | 
| Andrew M. Kuchling | 2158df0 | 2001-10-22 15:26:09 +0000 | [diff] [blame] | 130 |     curses -    Tests that use curses and will modify the terminal's | 
 | 131 |                 state and output modes. | 
| Tim Peters | 1633a2e | 2001-10-30 05:56:40 +0000 | [diff] [blame] | 132 |  | 
| Guido van Rossum | 9e9d4f8 | 2002-06-07 15:17:03 +0000 | [diff] [blame] | 133 |     largefile - It is okay to run some test that may create huge | 
 | 134 |                 files.  These tests can take a long time and may | 
 | 135 |                 consume >2GB of disk space temporarily. | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 136 |  | 
| Guido van Rossum | 9e9d4f8 | 2002-06-07 15:17:03 +0000 | [diff] [blame] | 137 |     network -   It is okay to run tests that use external network | 
 | 138 |                 resource, e.g. testing SSL support for sockets. | 
| Martin v. Löwis | 1c6b1a2 | 2002-11-19 17:47:07 +0000 | [diff] [blame] | 139 |  | 
| Raymond Hettinger | 7c85fa4 | 2004-07-01 11:01:35 +0000 | [diff] [blame] | 140 |     decimal -   Test the decimal module against a large suite that | 
 | 141 |                 verifies compliance with standards. | 
 | 142 |  | 
| Antoine Pitrou | 5bc4fa7 | 2010-10-14 15:34:31 +0000 | [diff] [blame] | 143 |     cpu -       Used for certain CPU-heavy tests. | 
| Jeremy Hylton | 4336eda | 2004-08-07 19:25:33 +0000 | [diff] [blame] | 144 |  | 
| Tim Peters | eba28be | 2005-03-28 01:08:02 +0000 | [diff] [blame] | 145 |     subprocess  Run all tests for the subprocess module. | 
| Peter Astrand | f7f1bb7 | 2005-03-03 20:47:37 +0000 | [diff] [blame] | 146 |  | 
| Hye-Shik Chang | aaa2f1d | 2005-12-10 17:44:27 +0000 | [diff] [blame] | 147 |     urlfetch -  It is okay to download files required on testing. | 
 | 148 |  | 
| Guilherme Polo | 9de29af | 2009-01-28 20:40:48 +0000 | [diff] [blame] | 149 |     gui -       Run tests that require a running GUI. | 
 | 150 |  | 
| Fred Drake | 4dd0f7e | 2002-11-26 21:44:56 +0000 | [diff] [blame] | 151 | To enable all resources except one, use '-uall,-<resource>'.  For | 
| Georg Brandl | 1158a33 | 2009-06-04 09:30:30 +0000 | [diff] [blame] | 152 | example, to run all the tests except for the gui tests, give the | 
 | 153 | option '-uall,-gui'. | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 154 | """ | 
 | 155 |  | 
| Brett Cannon | 4507190 | 2010-06-14 22:22:54 +0000 | [diff] [blame] | 156 | import builtins | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 157 | import errno | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 158 | import getopt | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 159 | import io | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 160 | import json | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 161 | import logging | 
| Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 162 | import os | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 163 | import platform | 
| Skip Montanaro | ab1c791 | 2000-06-30 16:39:27 +0000 | [diff] [blame] | 164 | import random | 
| Thomas Wouters | 9ada3d6 | 2006-04-21 09:47:09 +0000 | [diff] [blame] | 165 | import re | 
| Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 166 | import sys | 
| Florent Xicluna | da7bfd5 | 2010-03-06 11:43:55 +0000 | [diff] [blame] | 167 | import sysconfig | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 168 | import tempfile | 
 | 169 | import time | 
 | 170 | import traceback | 
 | 171 | import unittest | 
 | 172 | import warnings | 
 | 173 | from inspect import isabstract | 
| Ezio Melotti | 184bdfb | 2010-02-18 09:37:05 +0000 | [diff] [blame] | 174 |  | 
| Florent Xicluna | 64fb18e | 2010-03-06 14:43:34 +0000 | [diff] [blame] | 175 |  | 
| Ezio Melotti | 184bdfb | 2010-02-18 09:37:05 +0000 | [diff] [blame] | 176 | # Some times __path__ and __file__ are not absolute (e.g. while running from | 
 | 177 | # Lib/) and, if we change the CWD to run the tests in a temporary dir, some | 
 | 178 | # imports might fail.  This affects only the modules imported before os.chdir(). | 
 | 179 | # These modules are searched first in sys.path[0] (so '' -- the CWD) and if | 
 | 180 | # they are found in the CWD their __file__ and __path__ will be relative (this | 
 | 181 | # happens before the chdir).  All the modules imported after the chdir, are | 
 | 182 | # not found in the CWD, and since the other paths in sys.path[1:] are absolute | 
 | 183 | # (site.py absolutize them), the __file__ and __path__ will be absolute too. | 
 | 184 | # Therefore it is necessary to absolutize manually the __file__ and __path__ of | 
 | 185 | # the packages to prevent later imports to fail when the CWD is different. | 
 | 186 | for module in sys.modules.values(): | 
 | 187 |     if hasattr(module, '__path__'): | 
 | 188 |         module.__path__ = [os.path.abspath(path) for path in module.__path__] | 
 | 189 |     if hasattr(module, '__file__'): | 
 | 190 |         module.__file__ = os.path.abspath(module.__file__) | 
 | 191 |  | 
| Guido van Rossum | dc15c27 | 2002-08-12 21:55:51 +0000 | [diff] [blame] | 192 |  | 
| Guido van Rossum | bb48465 | 2002-12-02 09:56:21 +0000 | [diff] [blame] | 193 | # MacOSX (a.k.a. Darwin) has a default stack size that is too small | 
 | 194 | # for deeply recursive regular expressions.  We see this as crashes in | 
 | 195 | # the Python test suite when running test_re.py and test_sre.py.  The | 
 | 196 | # fix is to set the stack limit to 2048. | 
 | 197 | # This approach may also be useful for other Unixy platforms that | 
 | 198 | # suffer from small default stack limits. | 
 | 199 | if sys.platform == 'darwin': | 
 | 200 |     try: | 
 | 201 |         import resource | 
 | 202 |     except ImportError: | 
 | 203 |         pass | 
 | 204 |     else: | 
 | 205 |         soft, hard = resource.getrlimit(resource.RLIMIT_STACK) | 
 | 206 |         newsoft = min(hard, max(soft, 1024*2048)) | 
 | 207 |         resource.setrlimit(resource.RLIMIT_STACK, (newsoft, hard)) | 
 | 208 |  | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 209 | # Test result constants. | 
 | 210 | PASSED = 1 | 
 | 211 | FAILED = 0 | 
 | 212 | ENV_CHANGED = -1 | 
 | 213 | SKIPPED = -2 | 
 | 214 | RESOURCE_DENIED = -3 | 
 | 215 | INTERRUPTED = -4 | 
 | 216 |  | 
| Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 217 | from test import support | 
| Fred Drake | 3a15dac | 2002-04-11 16:39:16 +0000 | [diff] [blame] | 218 |  | 
| Georg Brandl | 1158a33 | 2009-06-04 09:30:30 +0000 | [diff] [blame] | 219 | RESOURCE_NAMES = ('audio', 'curses', 'largefile', 'network', | 
| Antoine Pitrou | 5bc4fa7 | 2010-10-14 15:34:31 +0000 | [diff] [blame] | 220 |                   'decimal', 'cpu', 'subprocess', 'urlfetch', 'gui') | 
| Fred Drake | 3a15dac | 2002-04-11 16:39:16 +0000 | [diff] [blame] | 221 |  | 
| Florent Xicluna | ec88221 | 2010-08-09 16:56:43 +0000 | [diff] [blame] | 222 | TEMPDIR = os.path.abspath(tempfile.gettempdir()) | 
| Fred Drake | 3a15dac | 2002-04-11 16:39:16 +0000 | [diff] [blame] | 223 |  | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 224 | def usage(msg): | 
 | 225 |     print(msg, file=sys.stderr) | 
 | 226 |     print("Use --help for usage", file=sys.stderr) | 
 | 227 |     sys.exit(2) | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 228 |  | 
 | 229 |  | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 230 | def main(tests=None, testdir=None, verbose=0, quiet=False, | 
| Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 231 |          exclude=False, single=False, randomize=False, fromfile=None, | 
| Walter Dörwald | aee4da6 | 2004-11-12 18:51:27 +0000 | [diff] [blame] | 232 |          findleaks=False, use_resources=None, trace=False, coverdir='coverage', | 
| Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 233 |          runleaks=False, huntrleaks=False, verbose2=False, print_slow=False, | 
| Antoine Pitrou | 3c4402f | 2011-01-03 20:38:52 +0000 | [diff] [blame] | 234 |          random_seed=None, use_mp=None, verbose3=False, forever=False, | 
 | 235 |          header=False): | 
| Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 236 |     """Execute a test suite. | 
 | 237 |  | 
| Thomas Wouters | 7e47402 | 2000-07-16 12:04:32 +0000 | [diff] [blame] | 238 |     This also parses command-line options and modifies its behavior | 
| Fred Drake | 004d5e6 | 2000-10-23 17:22:08 +0000 | [diff] [blame] | 239 |     accordingly. | 
| Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 240 |  | 
 | 241 |     tests -- a list of strings containing test names (optional) | 
 | 242 |     testdir -- the directory in which to look for tests (optional) | 
 | 243 |  | 
 | 244 |     Users other than the Python test suite will certainly want to | 
 | 245 |     specify testdir; if it's omitted, the directory containing the | 
| Fred Drake | 004d5e6 | 2000-10-23 17:22:08 +0000 | [diff] [blame] | 246 |     Python test suite is searched for. | 
| Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 247 |  | 
 | 248 |     If the tests argument is omitted, the tests listed on the | 
 | 249 |     command-line will be used.  If that's empty, too, then all *.py | 
 | 250 |     files beginning with test_ will be used. | 
| Skip Montanaro | ab1c791 | 2000-06-30 16:39:27 +0000 | [diff] [blame] | 251 |  | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 252 |     The other default arguments (verbose, quiet, exclude, | 
| Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 253 |     single, randomize, findleaks, use_resources, trace, coverdir, | 
 | 254 |     print_slow, and random_seed) allow programmers calling main() | 
 | 255 |     directly to set the values that would normally be set by flags | 
 | 256 |     on the command line. | 
| Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 257 |     """ | 
| Fred Drake | 004d5e6 | 2000-10-23 17:22:08 +0000 | [diff] [blame] | 258 |  | 
| Victor Stinner | 1802d3f | 2010-05-19 17:11:19 +0000 | [diff] [blame] | 259 |     replace_stdout() | 
 | 260 |  | 
| Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 261 |     support.record_original_stdout(sys.stdout) | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 262 |     try: | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 263 |         opts, args = getopt.getopt(sys.argv[1:], 'hvqxsSrf:lu:t:TD:NLR:FwWM:nj:', | 
| Georg Brandl | 96f7897 | 2009-10-27 21:02:11 +0000 | [diff] [blame] | 264 |             ['help', 'verbose', 'verbose2', 'verbose3', 'quiet', | 
 | 265 |              'exclude', 'single', 'slow', 'random', 'fromfile', 'findleaks', | 
 | 266 |              'use=', 'threshold=', 'trace', 'coverdir=', 'nocoverdir', | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 267 |              'runleaks', 'huntrleaks=', 'memlimit=', 'randseed=', | 
| Brett Cannon | 63eef1e | 2011-01-06 22:32:41 +0000 | [diff] [blame] | 268 |              'multiprocess=', 'coverage', 'slaveargs=', 'forever', 'debug', | 
 | 269 |              'start=', 'nowindows', 'header']) | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 270 |     except getopt.error as msg: | 
 | 271 |         usage(msg) | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 272 |  | 
 | 273 |     # Defaults | 
| Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 274 |     if random_seed is None: | 
 | 275 |         random_seed = random.randrange(10000000) | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 276 |     if use_resources is None: | 
 | 277 |         use_resources = [] | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 278 |     debug = False | 
 | 279 |     start = None | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 280 |     for o, a in opts: | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 281 |         if o in ('-h', '--help'): | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 282 |             print(__doc__) | 
 | 283 |             return | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 284 |         elif o in ('-v', '--verbose'): | 
 | 285 |             verbose += 1 | 
| Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 286 |         elif o in ('-w', '--verbose2'): | 
 | 287 |             verbose2 = True | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 288 |         elif o in ('-d', '--debug'): | 
 | 289 |             debug = True | 
| Georg Brandl | 96f7897 | 2009-10-27 21:02:11 +0000 | [diff] [blame] | 290 |         elif o in ('-W', '--verbose3'): | 
 | 291 |             verbose3 = True | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 292 |         elif o in ('-q', '--quiet'): | 
| Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 293 |             quiet = True; | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 294 |             verbose = 0 | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 295 |         elif o in ('-x', '--exclude'): | 
| Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 296 |             exclude = True | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 297 |         elif o in ('-S', '--start'): | 
 | 298 |             start = a | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 299 |         elif o in ('-s', '--single'): | 
| Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 300 |             single = True | 
| Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 301 |         elif o in ('-S', '--slow'): | 
 | 302 |             print_slow = True | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 303 |         elif o in ('-r', '--randomize'): | 
| Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 304 |             randomize = True | 
| Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 305 |         elif o == '--randseed': | 
 | 306 |             random_seed = int(a) | 
| Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 307 |         elif o in ('-f', '--fromfile'): | 
 | 308 |             fromfile = a | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 309 |         elif o in ('-l', '--findleaks'): | 
| Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 310 |             findleaks = True | 
| Skip Montanaro | 0179a18 | 2004-06-06 15:53:18 +0000 | [diff] [blame] | 311 |         elif o in ('-L', '--runleaks'): | 
 | 312 |             runleaks = True | 
| Guido van Rossum | 9e9d4f8 | 2002-06-07 15:17:03 +0000 | [diff] [blame] | 313 |         elif o in ('-t', '--threshold'): | 
 | 314 |             import gc | 
 | 315 |             gc.set_threshold(int(a)) | 
| Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 316 |         elif o in ('-T', '--coverage'): | 
 | 317 |             trace = True | 
| Walter Dörwald | aee4da6 | 2004-11-12 18:51:27 +0000 | [diff] [blame] | 318 |         elif o in ('-D', '--coverdir'): | 
 | 319 |             coverdir = os.path.join(os.getcwd(), a) | 
 | 320 |         elif o in ('-N', '--nocoverdir'): | 
 | 321 |             coverdir = None | 
| Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 322 |         elif o in ('-R', '--huntrleaks'): | 
 | 323 |             huntrleaks = a.split(':') | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 324 |             if len(huntrleaks) not in (2, 3): | 
 | 325 |                 print(a, huntrleaks) | 
 | 326 |                 usage('-R takes 2 or 3 colon-separated arguments') | 
 | 327 |             if not huntrleaks[0]: | 
| Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 328 |                 huntrleaks[0] = 5 | 
 | 329 |             else: | 
 | 330 |                 huntrleaks[0] = int(huntrleaks[0]) | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 331 |             if not huntrleaks[1]: | 
| Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 332 |                 huntrleaks[1] = 4 | 
 | 333 |             else: | 
 | 334 |                 huntrleaks[1] = int(huntrleaks[1]) | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 335 |             if len(huntrleaks) == 2 or not huntrleaks[2]: | 
 | 336 |                 huntrleaks[2:] = ["reflog.txt"] | 
 | 337 |             # Avoid false positives due to the character cache in | 
 | 338 |             # stringobject.c filling slowly with random data | 
 | 339 |             warm_char_cache() | 
| Thomas Wouters | 477c8d5 | 2006-05-27 19:21:47 +0000 | [diff] [blame] | 340 |         elif o in ('-M', '--memlimit'): | 
| Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 341 |             support.set_memlimit(a) | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 342 |         elif o in ('-u', '--use'): | 
| Guido van Rossum | fe3f696 | 2001-09-06 16:09:41 +0000 | [diff] [blame] | 343 |             u = [x.lower() for x in a.split(',')] | 
 | 344 |             for r in u: | 
| Fred Drake | 3a15dac | 2002-04-11 16:39:16 +0000 | [diff] [blame] | 345 |                 if r == 'all': | 
| Fred Drake | 4dd0f7e | 2002-11-26 21:44:56 +0000 | [diff] [blame] | 346 |                     use_resources[:] = RESOURCE_NAMES | 
 | 347 |                     continue | 
 | 348 |                 remove = False | 
 | 349 |                 if r[0] == '-': | 
 | 350 |                     remove = True | 
 | 351 |                     r = r[1:] | 
| Fred Drake | 3a15dac | 2002-04-11 16:39:16 +0000 | [diff] [blame] | 352 |                 if r not in RESOURCE_NAMES: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 353 |                     usage('Invalid -u/--use option: ' + a) | 
| Fred Drake | 4dd0f7e | 2002-11-26 21:44:56 +0000 | [diff] [blame] | 354 |                 if remove: | 
 | 355 |                     if r in use_resources: | 
 | 356 |                         use_resources.remove(r) | 
 | 357 |                 elif r not in use_resources: | 
| Andrew MacIntyre | e41abab | 2002-04-30 12:11:04 +0000 | [diff] [blame] | 358 |                     use_resources.append(r) | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 359 |         elif o in ('-n', '--nowindows'): | 
 | 360 |             import msvcrt | 
 | 361 |             msvcrt.SetErrorMode(msvcrt.SEM_FAILCRITICALERRORS| | 
 | 362 |                     msvcrt.SEM_NOALIGNMENTFAULTEXCEPT| | 
 | 363 |                     msvcrt.SEM_NOGPFAULTERRORBOX| | 
 | 364 |                     msvcrt.SEM_NOOPENFILEERRORBOX) | 
 | 365 |             try: | 
 | 366 |                 msvcrt.CrtSetReportMode | 
 | 367 |             except AttributeError: | 
 | 368 |                 # release build | 
 | 369 |                 pass | 
 | 370 |             else: | 
 | 371 |                 for m in [msvcrt.CRT_WARN, msvcrt.CRT_ERROR, msvcrt.CRT_ASSERT]: | 
 | 372 |                     msvcrt.CrtSetReportMode(m, msvcrt.CRTDBG_MODE_FILE) | 
 | 373 |                     msvcrt.CrtSetReportFile(m, msvcrt.CRTDBG_FILE_STDERR) | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 374 |         elif o in ('-F', '--forever'): | 
 | 375 |             forever = True | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 376 |         elif o in ('-j', '--multiprocess'): | 
 | 377 |             use_mp = int(a) | 
| Antoine Pitrou | 3c4402f | 2011-01-03 20:38:52 +0000 | [diff] [blame] | 378 |         elif o == '--header': | 
 | 379 |             header = True | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 380 |         elif o == '--slaveargs': | 
 | 381 |             args, kwargs = json.loads(a) | 
 | 382 |             try: | 
 | 383 |                 result = runtest(*args, **kwargs) | 
 | 384 |             except BaseException as e: | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 385 |                 result = INTERRUPTED, e.__class__.__name__ | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 386 |             sys.stdout.flush() | 
 | 387 |             print()   # Force a newline (just in case) | 
 | 388 |             print(json.dumps(result)) | 
 | 389 |             sys.exit(0) | 
| R. David Murray | 35768ad | 2009-11-15 00:23:21 +0000 | [diff] [blame] | 390 |         else: | 
 | 391 |             print(("No handler for option {}.  Please report this as a bug " | 
| Georg Brandl | dee7b85 | 2010-08-02 18:59:52 +0000 | [diff] [blame] | 392 |                    "at http://bugs.python.org.").format(o), file=sys.stderr) | 
| R. David Murray | 35768ad | 2009-11-15 00:23:21 +0000 | [diff] [blame] | 393 |             sys.exit(1) | 
| Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 394 |     if single and fromfile: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 395 |         usage("-s and -f don't go together!") | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 396 |     if use_mp and trace: | 
| Florent Xicluna | 64fb18e | 2010-03-06 14:43:34 +0000 | [diff] [blame] | 397 |         usage("-T and -j don't go together!") | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 398 |     if use_mp and findleaks: | 
| Florent Xicluna | 64fb18e | 2010-03-06 14:43:34 +0000 | [diff] [blame] | 399 |         usage("-l and -j don't go together!") | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 400 |  | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 401 |     good = [] | 
 | 402 |     bad = [] | 
 | 403 |     skipped = [] | 
| Fred Drake | 9a0db07 | 2003-02-03 15:19:30 +0000 | [diff] [blame] | 404 |     resource_denieds = [] | 
| Nick Coghlan | 6ead552 | 2009-10-18 13:19:33 +0000 | [diff] [blame] | 405 |     environment_changed = [] | 
| Florent Xicluna | d6995eb | 2010-03-30 19:43:09 +0000 | [diff] [blame] | 406 |     interrupted = False | 
| Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 407 |  | 
| Neil Schemenauer | d569f23 | 2000-09-22 15:29:28 +0000 | [diff] [blame] | 408 |     if findleaks: | 
| Barry Warsaw | a873b03 | 2000-08-03 15:50:37 +0000 | [diff] [blame] | 409 |         try: | 
 | 410 |             import gc | 
 | 411 |         except ImportError: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 412 |             print('No GC available, disabling findleaks.') | 
| Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 413 |             findleaks = False | 
| Barry Warsaw | a873b03 | 2000-08-03 15:50:37 +0000 | [diff] [blame] | 414 |         else: | 
| Neil Schemenauer | 8a00abc | 2000-10-13 01:32:42 +0000 | [diff] [blame] | 415 |             # Uncomment the line below to report garbage that is not | 
 | 416 |             # freeable by reference counting alone.  By default only | 
 | 417 |             # garbage that is not collectable by the GC is reported. | 
 | 418 |             #gc.set_debug(gc.DEBUG_SAVEALL) | 
| Neil Schemenauer | d569f23 | 2000-09-22 15:29:28 +0000 | [diff] [blame] | 419 |             found_garbage = [] | 
| Barry Warsaw | a873b03 | 2000-08-03 15:50:37 +0000 | [diff] [blame] | 420 |  | 
| Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 421 |     if single: | 
| Florent Xicluna | ec88221 | 2010-08-09 16:56:43 +0000 | [diff] [blame] | 422 |         filename = os.path.join(TEMPDIR, 'pynexttest') | 
| Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 423 |         try: | 
 | 424 |             fp = open(filename, 'r') | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 425 |             next_test = fp.read().strip() | 
 | 426 |             tests = [next_test] | 
| Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 427 |             fp.close() | 
 | 428 |         except IOError: | 
 | 429 |             pass | 
| Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 430 |  | 
 | 431 |     if fromfile: | 
 | 432 |         tests = [] | 
| Ezio Melotti | 184bdfb | 2010-02-18 09:37:05 +0000 | [diff] [blame] | 433 |         fp = open(os.path.join(support.SAVEDCWD, fromfile)) | 
| Antoine Pitrou | d95c7b5 | 2010-11-07 20:50:51 +0000 | [diff] [blame] | 434 |         count_pat = re.compile(r'\[\s*\d+/\s*\d+\]') | 
| Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 435 |         for line in fp: | 
| Antoine Pitrou | d95c7b5 | 2010-11-07 20:50:51 +0000 | [diff] [blame] | 436 |             line = count_pat.sub('', line) | 
| Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 437 |             guts = line.split() # assuming no test has whitespace in its name | 
 | 438 |             if guts and not guts[0].startswith('#'): | 
 | 439 |                 tests.extend(guts) | 
 | 440 |         fp.close() | 
 | 441 |  | 
 | 442 |     # Strip .py extensions. | 
| Florent Xicluna | da7bfd5 | 2010-03-06 11:43:55 +0000 | [diff] [blame] | 443 |     removepy(args) | 
 | 444 |     removepy(tests) | 
| Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 445 |  | 
| Guido van Rossum | 6c74fea | 1998-08-25 12:29:08 +0000 | [diff] [blame] | 446 |     stdtests = STDTESTS[:] | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 447 |     nottests = NOTTESTS.copy() | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 448 |     if exclude: | 
| Guido van Rossum | 6c74fea | 1998-08-25 12:29:08 +0000 | [diff] [blame] | 449 |         for arg in args: | 
 | 450 |             if arg in stdtests: | 
 | 451 |                 stdtests.remove(arg) | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 452 |             nottests.add(arg) | 
| Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 453 |         args = [] | 
| Florent Xicluna | 0e62a14 | 2010-03-06 17:34:48 +0000 | [diff] [blame] | 454 |  | 
 | 455 |     # For a partial run, we do not need to clutter the output. | 
| Antoine Pitrou | 3c4402f | 2011-01-03 20:38:52 +0000 | [diff] [blame] | 456 |     if verbose or header or not (quiet or single or tests or args): | 
| Florent Xicluna | 0e62a14 | 2010-03-06 17:34:48 +0000 | [diff] [blame] | 457 |         # Print basic platform information | 
 | 458 |         print("==", platform.python_implementation(), *sys.version.split()) | 
| Florent Xicluna | ec88221 | 2010-08-09 16:56:43 +0000 | [diff] [blame] | 459 |         print("==  ", platform.platform(aliased=True), | 
 | 460 |                       "%s-endian" % sys.byteorder) | 
| Florent Xicluna | 0e62a14 | 2010-03-06 17:34:48 +0000 | [diff] [blame] | 461 |         print("==  ", os.getcwd()) | 
| Antoine Pitrou | 3c4402f | 2011-01-03 20:38:52 +0000 | [diff] [blame] | 462 |         print("Testing with flags:", sys.flags) | 
| Florent Xicluna | 0e62a14 | 2010-03-06 17:34:48 +0000 | [diff] [blame] | 463 |  | 
| R. David Murray | ef1992b | 2009-12-16 15:19:27 +0000 | [diff] [blame] | 464 |     alltests = findtests(testdir, stdtests, nottests) | 
| Florent Xicluna | d6995eb | 2010-03-30 19:43:09 +0000 | [diff] [blame] | 465 |     selected = tests or args or alltests | 
| Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 466 |     if single: | 
| Florent Xicluna | d6995eb | 2010-03-30 19:43:09 +0000 | [diff] [blame] | 467 |         selected = selected[:1] | 
| R. David Murray | ef1992b | 2009-12-16 15:19:27 +0000 | [diff] [blame] | 468 |         try: | 
| Florent Xicluna | d6995eb | 2010-03-30 19:43:09 +0000 | [diff] [blame] | 469 |             next_single_test = alltests[alltests.index(selected[0])+1] | 
| R. David Murray | ef1992b | 2009-12-16 15:19:27 +0000 | [diff] [blame] | 470 |         except IndexError: | 
 | 471 |             next_single_test = None | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 472 |     # Remove all the tests that precede start if it's set. | 
 | 473 |     if start: | 
 | 474 |         try: | 
 | 475 |             del tests[:tests.index(start)] | 
 | 476 |         except ValueError: | 
 | 477 |             print("Couldn't find starting test (%s), using all tests" % start) | 
| Skip Montanaro | ab1c791 | 2000-06-30 16:39:27 +0000 | [diff] [blame] | 478 |     if randomize: | 
| Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 479 |         random.seed(random_seed) | 
 | 480 |         print("Using random seed", random_seed) | 
| Florent Xicluna | d6995eb | 2010-03-30 19:43:09 +0000 | [diff] [blame] | 481 |         random.shuffle(selected) | 
| Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 482 |     if trace: | 
| Georg Brandl | 33c2881 | 2009-04-01 23:07:29 +0000 | [diff] [blame] | 483 |         import trace, tempfile | 
 | 484 |         tracer = trace.Trace(ignoredirs=[sys.prefix, sys.exec_prefix, | 
 | 485 |                                          tempfile.gettempdir()], | 
| Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 486 |                              trace=False, count=True) | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 487 |  | 
| Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 488 |     test_times = [] | 
| Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 489 |     support.verbose = verbose      # Tell tests to be moderately quiet | 
 | 490 |     support.use_resources = use_resources | 
| Guido van Rossum | 5796d26 | 2000-04-21 21:35:06 +0000 | [diff] [blame] | 491 |     save_modules = sys.modules.keys() | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 492 |  | 
 | 493 |     def accumulate_result(test, result): | 
 | 494 |         ok, test_time = result | 
 | 495 |         test_times.append((test_time, test)) | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 496 |         if ok == PASSED: | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 497 |             good.append(test) | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 498 |         elif ok == FAILED: | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 499 |             bad.append(test) | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 500 |         elif ok == ENV_CHANGED: | 
 | 501 |             bad.append(test) | 
 | 502 |             environment_changed.append(test) | 
 | 503 |         elif ok == SKIPPED: | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 504 |             skipped.append(test) | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 505 |         elif ok == RESOURCE_DENIED: | 
 | 506 |             skipped.append(test) | 
 | 507 |             resource_denieds.append(test) | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 508 |  | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 509 |     if forever: | 
| Florent Xicluna | d6995eb | 2010-03-30 19:43:09 +0000 | [diff] [blame] | 510 |         def test_forever(tests=list(selected)): | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 511 |             while True: | 
 | 512 |                 for test in tests: | 
 | 513 |                     yield test | 
 | 514 |                     if bad: | 
 | 515 |                         return | 
 | 516 |         tests = test_forever() | 
| Georg Brandl | e8e02e3 | 2010-08-03 07:56:50 +0000 | [diff] [blame] | 517 |         test_count = '' | 
 | 518 |         test_count_width = 3 | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 519 |     else: | 
| Florent Xicluna | d6995eb | 2010-03-30 19:43:09 +0000 | [diff] [blame] | 520 |         tests = iter(selected) | 
| Georg Brandl | e8e02e3 | 2010-08-03 07:56:50 +0000 | [diff] [blame] | 521 |         test_count = '/{}'.format(len(selected)) | 
 | 522 |         test_count_width = len(test_count) - 1 | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 523 |  | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 524 |     if use_mp: | 
| Victor Stinner | 45df820 | 2010-04-28 22:31:17 +0000 | [diff] [blame] | 525 |         try: | 
 | 526 |             from threading import Thread | 
 | 527 |         except ImportError: | 
 | 528 |             print("Multiprocess option requires thread support") | 
 | 529 |             sys.exit(2) | 
| Georg Brandl | 1b37e87 | 2010-03-14 10:45:50 +0000 | [diff] [blame] | 530 |         from queue import Queue | 
 | 531 |         from subprocess import Popen, PIPE | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 532 |         debug_output_pat = re.compile(r"\[\d+ refs\]$") | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 533 |         output = Queue() | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 534 |         def tests_and_args(): | 
 | 535 |             for test in tests: | 
 | 536 |                 args_tuple = ( | 
| R. David Murray | 8e286c4 | 2010-12-27 20:09:32 +0000 | [diff] [blame] | 537 |                     (test, verbose, quiet), | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 538 |                     dict(huntrleaks=huntrleaks, use_resources=use_resources, | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 539 |                          debug=debug, output_on_failure=verbose3) | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 540 |                 ) | 
 | 541 |                 yield (test, args_tuple) | 
 | 542 |         pending = tests_and_args() | 
| Antoine Pitrou | 1b03f2c | 2010-10-14 11:12:00 +0000 | [diff] [blame] | 543 |         opt_args = support.args_from_interpreter_flags() | 
 | 544 |         base_cmd = [sys.executable] + opt_args + ['-m', 'test.regrtest'] | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 545 |         def work(): | 
 | 546 |             # A worker thread. | 
| Neal Norwitz | 14ca327 | 2006-02-28 18:05:43 +0000 | [diff] [blame] | 547 |             try: | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 548 |                 while True: | 
 | 549 |                     try: | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 550 |                         test, args_tuple = next(pending) | 
 | 551 |                     except StopIteration: | 
| R. David Murray | 2714460 | 2009-10-19 15:26:16 +0000 | [diff] [blame] | 552 |                         output.put((None, None, None, None)) | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 553 |                         return | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 554 |                     # -E is needed by some tests, e.g. test_import | 
| Antoine Pitrou | 1b03f2c | 2010-10-14 11:12:00 +0000 | [diff] [blame] | 555 |                     popen = Popen(base_cmd + ['--slaveargs', json.dumps(args_tuple)], | 
| R. David Murray | 2714460 | 2009-10-19 15:26:16 +0000 | [diff] [blame] | 556 |                                    stdout=PIPE, stderr=PIPE, | 
| Antoine Pitrou | 36e778e | 2010-08-18 20:44:14 +0000 | [diff] [blame] | 557 |                                    universal_newlines=True, | 
 | 558 |                                    close_fds=(os.name != 'nt')) | 
| R. David Murray | 2714460 | 2009-10-19 15:26:16 +0000 | [diff] [blame] | 559 |                     stdout, stderr = popen.communicate() | 
 | 560 |                     # Strip last refcount output line if it exists, since it | 
 | 561 |                     # comes from the shutdown of the interpreter in the subcommand. | 
 | 562 |                     stderr = debug_output_pat.sub("", stderr) | 
 | 563 |                     stdout, _, result = stdout.strip().rpartition("\n") | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 564 |                     if not result: | 
 | 565 |                         output.put((None, None, None, None)) | 
 | 566 |                         return | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 567 |                     result = json.loads(result) | 
| R. David Murray | 2714460 | 2009-10-19 15:26:16 +0000 | [diff] [blame] | 568 |                     output.put((test, stdout.rstrip(), stderr.rstrip(), result)) | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 569 |             except BaseException: | 
| R. David Murray | 2714460 | 2009-10-19 15:26:16 +0000 | [diff] [blame] | 570 |                 output.put((None, None, None, None)) | 
| Neal Norwitz | 14ca327 | 2006-02-28 18:05:43 +0000 | [diff] [blame] | 571 |                 raise | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 572 |         workers = [Thread(target=work) for i in range(use_mp)] | 
 | 573 |         for worker in workers: | 
 | 574 |             worker.start() | 
 | 575 |         finished = 0 | 
| Georg Brandl | dee7b85 | 2010-08-02 18:59:52 +0000 | [diff] [blame] | 576 |         test_index = 1 | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 577 |         try: | 
 | 578 |             while finished < use_mp: | 
 | 579 |                 test, stdout, stderr, result = output.get() | 
 | 580 |                 if test is None: | 
 | 581 |                     finished += 1 | 
 | 582 |                     continue | 
| Victor Stinner | a2a895c | 2011-05-23 23:14:05 +0200 | [diff] [blame] | 583 |                 accumulate_result(test, result) | 
| Georg Brandl | dee7b85 | 2010-08-02 18:59:52 +0000 | [diff] [blame] | 584 |                 if not quiet: | 
| Ezio Melotti | 84f75c6 | 2011-05-24 01:00:10 +0300 | [diff] [blame] | 585 |                     fmt = "[{1:{0}}{2}/{3}] {4}" if bad else "[{1:{0}}{2}] {4}" | 
 | 586 |                     print(fmt.format( | 
| Victor Stinner | a2a895c | 2011-05-23 23:14:05 +0200 | [diff] [blame] | 587 |                         test_count_width, test_index, test_count, | 
 | 588 |                         len(bad), test)) | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 589 |                 if stdout: | 
 | 590 |                     print(stdout) | 
 | 591 |                 if stderr: | 
 | 592 |                     print(stderr, file=sys.stderr) | 
 | 593 |                 if result[0] == INTERRUPTED: | 
 | 594 |                     assert result[1] == 'KeyboardInterrupt' | 
 | 595 |                     raise KeyboardInterrupt   # What else? | 
| Georg Brandl | dee7b85 | 2010-08-02 18:59:52 +0000 | [diff] [blame] | 596 |                 test_index += 1 | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 597 |         except KeyboardInterrupt: | 
| Florent Xicluna | d6995eb | 2010-03-30 19:43:09 +0000 | [diff] [blame] | 598 |             interrupted = True | 
| R. David Murray | 7dc72cc | 2009-11-14 16:13:02 +0000 | [diff] [blame] | 599 |             pending.close() | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 600 |         for worker in workers: | 
 | 601 |             worker.join() | 
 | 602 |     else: | 
| Georg Brandl | dee7b85 | 2010-08-02 18:59:52 +0000 | [diff] [blame] | 603 |         for test_index, test in enumerate(tests, 1): | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 604 |             if not quiet: | 
| Ezio Melotti | 84f75c6 | 2011-05-24 01:00:10 +0300 | [diff] [blame] | 605 |                 fmt = "[{1:{0}}{2}/{3}] {4}" if bad else "[{1:{0}}{2}] {4}" | 
 | 606 |                 print(fmt.format( | 
| Victor Stinner | a2a895c | 2011-05-23 23:14:05 +0200 | [diff] [blame] | 607 |                     test_count_width, test_index, test_count, len(bad), test)) | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 608 |                 sys.stdout.flush() | 
 | 609 |             if trace: | 
 | 610 |                 # If we're tracing code coverage, then we don't exit with status | 
 | 611 |                 # if on a false return value from main. | 
| R. David Murray | 8e286c4 | 2010-12-27 20:09:32 +0000 | [diff] [blame] | 612 |                 tracer.runctx('runtest(test, verbose, quiet)', | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 613 |                               globals=globals(), locals=vars()) | 
| Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 614 |             else: | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 615 |                 try: | 
| Antoine Pitrou | 293954d | 2011-03-23 23:01:49 +0100 | [diff] [blame] | 616 |                     result = runtest(test, verbose, quiet, huntrleaks, debug, | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 617 |                                      output_on_failure=verbose3) | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 618 |                     accumulate_result(test, result) | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 619 |                 except KeyboardInterrupt: | 
| Florent Xicluna | d6995eb | 2010-03-30 19:43:09 +0000 | [diff] [blame] | 620 |                     interrupted = True | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 621 |                     break | 
 | 622 |                 except: | 
 | 623 |                     raise | 
 | 624 |             if findleaks: | 
 | 625 |                 gc.collect() | 
 | 626 |                 if gc.garbage: | 
 | 627 |                     print("Warning: test created", len(gc.garbage), end=' ') | 
 | 628 |                     print("uncollectable object(s).") | 
 | 629 |                     # move the uncollectable objects somewhere so we don't see | 
 | 630 |                     # them again | 
 | 631 |                     found_garbage.extend(gc.garbage) | 
 | 632 |                     del gc.garbage[:] | 
 | 633 |             # Unload the newly imported modules (best effort finalization) | 
 | 634 |             for module in sys.modules.keys(): | 
 | 635 |                 if module not in save_modules and module.startswith("test."): | 
 | 636 |                     support.unload(module) | 
| Jeremy Hylton | 7a1ea0e | 2001-10-17 13:45:28 +0000 | [diff] [blame] | 637 |  | 
| Florent Xicluna | d6995eb | 2010-03-30 19:43:09 +0000 | [diff] [blame] | 638 |     if interrupted: | 
 | 639 |         # print a newline after ^C | 
 | 640 |         print() | 
 | 641 |         print("Test suite interrupted by signal SIGINT.") | 
 | 642 |         omitted = set(selected) - set(good) - set(bad) - set(skipped) | 
 | 643 |         print(count(len(omitted), "test"), "omitted:") | 
 | 644 |         printlist(omitted) | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 645 |     if good and not quiet: | 
| Florent Xicluna | d6995eb | 2010-03-30 19:43:09 +0000 | [diff] [blame] | 646 |         if not bad and not skipped and not interrupted and len(good) > 1: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 647 |             print("All", end=' ') | 
 | 648 |         print(count(len(good), "test"), "OK.") | 
| Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 649 |     if print_slow: | 
 | 650 |         test_times.sort(reverse=True) | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 651 |         print("10 slowest tests:") | 
| Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 652 |         for time, test in test_times[:10]: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 653 |             print("%s: %.1fs" % (test, time)) | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 654 |     if bad: | 
| Nick Coghlan | 6ead552 | 2009-10-18 13:19:33 +0000 | [diff] [blame] | 655 |         bad = sorted(set(bad) - set(environment_changed)) | 
 | 656 |         if bad: | 
 | 657 |             print(count(len(bad), "test"), "failed:") | 
 | 658 |             printlist(bad) | 
 | 659 |         if environment_changed: | 
 | 660 |             print("{} altered the execution environment:".format( | 
 | 661 |                      count(len(environment_changed), "test"))) | 
 | 662 |             printlist(environment_changed) | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 663 |     if skipped and not quiet: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 664 |         print(count(len(skipped), "test"), "skipped:") | 
| Tim Peters | a45da92 | 2001-08-12 03:45:50 +0000 | [diff] [blame] | 665 |         printlist(skipped) | 
| Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 666 |  | 
| Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 667 |         e = _ExpectedSkips() | 
| Tim Peters | a2be2d6 | 2001-08-12 02:01:09 +0000 | [diff] [blame] | 668 |         plat = sys.platform | 
| Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 669 |         if e.isvalid(): | 
| Raymond Hettinger | a690a99 | 2003-11-16 16:17:49 +0000 | [diff] [blame] | 670 |             surprise = set(skipped) - e.getexpected() - set(resource_denieds) | 
| Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 671 |             if surprise: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 672 |                 print(count(len(surprise), "skip"), \ | 
 | 673 |                       "unexpected on", plat + ":") | 
| Tim Peters | a45da92 | 2001-08-12 03:45:50 +0000 | [diff] [blame] | 674 |                 printlist(surprise) | 
| Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 675 |             else: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 676 |                 print("Those skips are all expected on", plat + ".") | 
| Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 677 |         else: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 678 |             print("Ask someone to teach regrtest.py about which tests are") | 
 | 679 |             print("expected to get skipped on", plat + ".") | 
| Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 680 |  | 
| Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 681 |     if verbose2 and bad: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 682 |         print("Re-running failed tests in verbose mode") | 
| Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 683 |         for test in bad: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 684 |             print("Re-running test %r in verbose mode" % test) | 
| Tim Peters | 922dd7d | 2006-03-10 23:37:10 +0000 | [diff] [blame] | 685 |             sys.stdout.flush() | 
| Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 686 |             try: | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 687 |                 verbose = True | 
| R. David Murray | 8e286c4 | 2010-12-27 20:09:32 +0000 | [diff] [blame] | 688 |                 ok = runtest(test, True, quiet, huntrleaks, debug) | 
| Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 689 |             except KeyboardInterrupt: | 
 | 690 |                 # print a newline separate from the ^C | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 691 |                 print() | 
| Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 692 |                 break | 
 | 693 |             except: | 
 | 694 |                 raise | 
 | 695 |  | 
| Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 696 |     if single: | 
| R. David Murray | ef1992b | 2009-12-16 15:19:27 +0000 | [diff] [blame] | 697 |         if next_single_test: | 
 | 698 |             with open(filename, 'w') as fp: | 
 | 699 |                 fp.write(next_single_test + '\n') | 
| Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 700 |         else: | 
 | 701 |             os.unlink(filename) | 
 | 702 |  | 
| Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 703 |     if trace: | 
 | 704 |         r = tracer.results() | 
 | 705 |         r.write_results(show_missing=True, summary=True, coverdir=coverdir) | 
 | 706 |  | 
| Skip Montanaro | 0179a18 | 2004-06-06 15:53:18 +0000 | [diff] [blame] | 707 |     if runleaks: | 
 | 708 |         os.system("leaks %d" % os.getpid()) | 
 | 709 |  | 
| Florent Xicluna | d6995eb | 2010-03-30 19:43:09 +0000 | [diff] [blame] | 710 |     sys.exit(len(bad) > 0 or interrupted) | 
| Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 711 |  | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 712 |  | 
| Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 713 | STDTESTS = [ | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 714 |     'test_grammar', | 
 | 715 |     'test_opcodes', | 
| Guido van Rossum | d8faa36 | 2007-04-27 19:54:29 +0000 | [diff] [blame] | 716 |     'test_dict', | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 717 |     'test_builtin', | 
 | 718 |     'test_exceptions', | 
 | 719 |     'test_types', | 
| Collin Winter | 7afaa88 | 2007-03-08 19:54:43 +0000 | [diff] [blame] | 720 |     'test_unittest', | 
 | 721 |     'test_doctest', | 
 | 722 |     'test_doctest2', | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 723 | ] | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 724 |  | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 725 | NOTTESTS = { | 
| Jeremy Hylton | 62e2c7e | 2001-02-28 17:48:06 +0000 | [diff] [blame] | 726 |     'test_future1', | 
 | 727 |     'test_future2', | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 728 | } | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 729 |  | 
| Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 730 | def findtests(testdir=None, stdtests=STDTESTS, nottests=NOTTESTS): | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 731 |     """Return a list of all applicable test modules.""" | 
| Florent Xicluna | da7bfd5 | 2010-03-06 11:43:55 +0000 | [diff] [blame] | 732 |     testdir = findtestdir(testdir) | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 733 |     names = os.listdir(testdir) | 
 | 734 |     tests = [] | 
| Florent Xicluna | da7bfd5 | 2010-03-06 11:43:55 +0000 | [diff] [blame] | 735 |     others = set(stdtests) | nottests | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 736 |     for name in names: | 
| Florent Xicluna | da7bfd5 | 2010-03-06 11:43:55 +0000 | [diff] [blame] | 737 |         modname, ext = os.path.splitext(name) | 
 | 738 |         if modname[:5] == "test_" and ext == ".py" and modname not in others: | 
 | 739 |             tests.append(modname) | 
 | 740 |     return stdtests + sorted(tests) | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 741 |  | 
| Victor Stinner | f58087b | 2010-05-02 17:24:51 +0000 | [diff] [blame] | 742 | def replace_stdout(): | 
 | 743 |     """Set stdout encoder error handler to backslashreplace (as stderr error | 
 | 744 |     handler) to avoid UnicodeEncodeError when printing a traceback""" | 
| Victor Stinner | a303280 | 2010-05-07 00:57:12 +0000 | [diff] [blame] | 745 |     if os.name == "nt": | 
 | 746 |         # Replace sys.stdout breaks the stdout newlines on Windows: issue #8533 | 
 | 747 |         return | 
| Victor Stinner | 4b2b43d | 2011-01-05 03:54:26 +0000 | [diff] [blame] | 748 |  | 
 | 749 |     import atexit | 
 | 750 |  | 
| Victor Stinner | f58087b | 2010-05-02 17:24:51 +0000 | [diff] [blame] | 751 |     stdout = sys.stdout | 
 | 752 |     sys.stdout = open(stdout.fileno(), 'w', | 
 | 753 |         encoding=stdout.encoding, | 
| Victor Stinner | 4b2b43d | 2011-01-05 03:54:26 +0000 | [diff] [blame] | 754 |         errors="backslashreplace", | 
 | 755 |         closefd=False) | 
 | 756 |  | 
 | 757 |     def restore_stdout(): | 
 | 758 |         sys.stdout.close() | 
 | 759 |         sys.stdout = stdout | 
 | 760 |     atexit.register(restore_stdout) | 
| Victor Stinner | f58087b | 2010-05-02 17:24:51 +0000 | [diff] [blame] | 761 |  | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 762 | def runtest(test, verbose, quiet, | 
| Antoine Pitrou | 293954d | 2011-03-23 23:01:49 +0100 | [diff] [blame] | 763 |             huntrleaks=False, debug=False, use_resources=None, | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 764 |             output_on_failure=False): | 
| Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 765 |     """Run a single test. | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 766 |  | 
| Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 767 |     test -- the name of the test | 
| Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 768 |     verbose -- if true, print more messages | 
| Trent Mick | f29f47b | 2000-08-11 19:02:59 +0000 | [diff] [blame] | 769 |     quiet -- if true, don't print 'skipped' messages (probably redundant) | 
| Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 770 |     test_times -- a list of (time, test_name) pairs | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 771 |     huntrleaks -- run multiple times to test for leaks; requires a debug | 
 | 772 |                   build; a triple corresponding to -R's three arguments | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 773 |     output_on_failure -- if true, display test output on failure | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 774 |  | 
 | 775 |     Returns one of the test result constants: | 
 | 776 |         INTERRUPTED      KeyboardInterrupt when run under -j | 
 | 777 |         RESOURCE_DENIED  test skipped because resource denied | 
 | 778 |         SKIPPED          test skipped for some other reason | 
 | 779 |         ENV_CHANGED      test failed because it changed the execution environment | 
 | 780 |         FAILED           test failed | 
 | 781 |         PASSED           test passed | 
| Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 782 |     """ | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 783 |  | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 784 |     if use_resources is not None: | 
 | 785 |         support.use_resources = use_resources | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 786 |     try: | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 787 |         if output_on_failure: | 
| Victor Stinner | ea95de7 | 2011-06-29 15:34:48 +0200 | [diff] [blame^] | 788 |             support.verbose = True | 
 | 789 |  | 
 | 790 |             # Reuse the same instance to all calls to runtest(). Some | 
 | 791 |             # tests keep a reference to sys.stdout or sys.stderr | 
 | 792 |             # (eg. test_argparse). | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 793 |             if runtest.stringio is None: | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 794 |                 runtest.stringio = io.StringIO() | 
| Victor Stinner | ea95de7 | 2011-06-29 15:34:48 +0200 | [diff] [blame^] | 795 |             stream = runtest.stringio | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 796 |  | 
 | 797 |             orig_stdout = sys.stdout | 
| Victor Stinner | a7c33e5 | 2011-06-29 13:00:54 +0200 | [diff] [blame] | 798 |             orig_stderr = sys.stderr | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 799 |             try: | 
| Victor Stinner | ea95de7 | 2011-06-29 15:34:48 +0200 | [diff] [blame^] | 800 |                 sys.stdout = stream | 
 | 801 |                 sys.stderr = stream | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 802 |                 result = runtest_inner(test, verbose, quiet, huntrleaks, | 
 | 803 |                                        debug, display_failure=False) | 
 | 804 |                 if result[0] == FAILED: | 
| Victor Stinner | ea95de7 | 2011-06-29 15:34:48 +0200 | [diff] [blame^] | 805 |                     output = stream.getvalue() | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 806 |                     orig_stderr.write(output) | 
 | 807 |                     orig_stderr.flush() | 
 | 808 |             finally: | 
 | 809 |                 sys.stdout = orig_stdout | 
 | 810 |                 sys.stderr = orig_stderr | 
| Victor Stinner | a7c33e5 | 2011-06-29 13:00:54 +0200 | [diff] [blame] | 811 |         else: | 
| Victor Stinner | ea95de7 | 2011-06-29 15:34:48 +0200 | [diff] [blame^] | 812 |             support.verbose = verbose  # Tell tests to be moderately quiet | 
| Victor Stinner | a7c33e5 | 2011-06-29 13:00:54 +0200 | [diff] [blame] | 813 |             result = runtest_inner(test, verbose, quiet, huntrleaks, debug, | 
 | 814 |                                    display_failure=not verbose) | 
| Antoine Pitrou | 293954d | 2011-03-23 23:01:49 +0100 | [diff] [blame] | 815 |         return result | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 816 |     finally: | 
 | 817 |         cleanup_test_droppings(test, verbose) | 
| Victor Stinner | 8313d6a | 2011-06-29 15:22:26 +0200 | [diff] [blame] | 818 | runtest.stringio = None | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 819 |  | 
| Nick Coghlan | 6ead552 | 2009-10-18 13:19:33 +0000 | [diff] [blame] | 820 | # Unit tests are supposed to leave the execution environment unchanged | 
 | 821 | # once they complete.  But sometimes tests have bugs, especially when | 
 | 822 | # tests fail, and the changes to environment go on to mess up other | 
 | 823 | # tests.  This can cause issues with buildbot stability, since tests | 
 | 824 | # are run in random order and so problems may appear to come and go. | 
 | 825 | # There are a few things we can save and restore to mitigate this, and | 
 | 826 | # the following context manager handles this task. | 
 | 827 |  | 
 | 828 | class saved_test_environment: | 
 | 829 |     """Save bits of the test environment and restore them at block exit. | 
 | 830 |  | 
 | 831 |         with saved_test_environment(testname, verbose, quiet): | 
 | 832 |             #stuff | 
 | 833 |  | 
 | 834 |     Unless quiet is True, a warning is printed to stderr if any of | 
 | 835 |     the saved items was changed by the test.  The attribute 'changed' | 
 | 836 |     is initially False, but is set to True if a change is detected. | 
 | 837 |  | 
 | 838 |     If verbose is more than 1, the before and after state of changed | 
 | 839 |     items is also printed. | 
 | 840 |     """ | 
 | 841 |  | 
 | 842 |     changed = False | 
 | 843 |  | 
 | 844 |     def __init__(self, testname, verbose=0, quiet=False): | 
 | 845 |         self.testname = testname | 
 | 846 |         self.verbose = verbose | 
 | 847 |         self.quiet = quiet | 
 | 848 |  | 
 | 849 |     # To add things to save and restore, add a name XXX to the resources list | 
 | 850 |     # and add corresponding get_XXX/restore_XXX functions.  get_XXX should | 
 | 851 |     # return the value to be saved and compared against a second call to the | 
 | 852 |     # get function when test execution completes.  restore_XXX should accept | 
 | 853 |     # the saved value and restore the resource using it.  It will be called if | 
 | 854 |     # and only if a change in the value is detected. | 
 | 855 |     # | 
 | 856 |     # Note: XXX will have any '.' replaced with '_' characters when determining | 
 | 857 |     # the corresponding method names. | 
 | 858 |  | 
 | 859 |     resources = ('sys.argv', 'cwd', 'sys.stdin', 'sys.stdout', 'sys.stderr', | 
| Brett Cannon | 29c0e4f | 2010-03-20 22:22:57 +0000 | [diff] [blame] | 860 |                  'os.environ', 'sys.path', 'sys.path_hooks', '__import__', | 
| Nick Coghlan | 7bd5dbe | 2010-12-05 07:17:25 +0000 | [diff] [blame] | 861 |                  'warnings.filters', 'asyncore.socket_map', | 
| Ezio Melotti | 0123e05 | 2011-03-20 15:09:26 +0200 | [diff] [blame] | 862 |                  'logging._handlers', 'logging._handlerList', | 
 | 863 |                  'sys.warnoptions') | 
| Nick Coghlan | 6ead552 | 2009-10-18 13:19:33 +0000 | [diff] [blame] | 864 |  | 
 | 865 |     def get_sys_argv(self): | 
 | 866 |         return id(sys.argv), sys.argv, sys.argv[:] | 
 | 867 |     def restore_sys_argv(self, saved_argv): | 
 | 868 |         sys.argv = saved_argv[1] | 
 | 869 |         sys.argv[:] = saved_argv[2] | 
 | 870 |  | 
 | 871 |     def get_cwd(self): | 
 | 872 |         return os.getcwd() | 
 | 873 |     def restore_cwd(self, saved_cwd): | 
 | 874 |         os.chdir(saved_cwd) | 
 | 875 |  | 
 | 876 |     def get_sys_stdout(self): | 
 | 877 |         return sys.stdout | 
 | 878 |     def restore_sys_stdout(self, saved_stdout): | 
 | 879 |         sys.stdout = saved_stdout | 
 | 880 |  | 
 | 881 |     def get_sys_stderr(self): | 
 | 882 |         return sys.stderr | 
 | 883 |     def restore_sys_stderr(self, saved_stderr): | 
 | 884 |         sys.stderr = saved_stderr | 
 | 885 |  | 
 | 886 |     def get_sys_stdin(self): | 
 | 887 |         return sys.stdin | 
 | 888 |     def restore_sys_stdin(self, saved_stdin): | 
 | 889 |         sys.stdin = saved_stdin | 
 | 890 |  | 
 | 891 |     def get_os_environ(self): | 
 | 892 |         return id(os.environ), os.environ, dict(os.environ) | 
 | 893 |     def restore_os_environ(self, saved_environ): | 
 | 894 |         os.environ = saved_environ[1] | 
 | 895 |         os.environ.clear() | 
 | 896 |         os.environ.update(saved_environ[2]) | 
 | 897 |  | 
 | 898 |     def get_sys_path(self): | 
 | 899 |         return id(sys.path), sys.path, sys.path[:] | 
 | 900 |     def restore_sys_path(self, saved_path): | 
 | 901 |         sys.path = saved_path[1] | 
 | 902 |         sys.path[:] = saved_path[2] | 
 | 903 |  | 
| Brett Cannon | 055470a | 2010-02-19 15:57:10 +0000 | [diff] [blame] | 904 |     def get_sys_path_hooks(self): | 
 | 905 |         return id(sys.path_hooks), sys.path_hooks, sys.path_hooks[:] | 
 | 906 |     def restore_sys_path_hooks(self, saved_hooks): | 
 | 907 |         sys.path_hooks = saved_hooks[1] | 
 | 908 |         sys.path_hooks[:] = saved_hooks[2] | 
 | 909 |  | 
 | 910 |     def get___import__(self): | 
| Brett Cannon | 4507190 | 2010-06-14 22:22:54 +0000 | [diff] [blame] | 911 |         return builtins.__import__ | 
| Brett Cannon | 055470a | 2010-02-19 15:57:10 +0000 | [diff] [blame] | 912 |     def restore___import__(self, import_): | 
| Brett Cannon | 4507190 | 2010-06-14 22:22:54 +0000 | [diff] [blame] | 913 |         builtins.__import__ = import_ | 
| Brett Cannon | 055470a | 2010-02-19 15:57:10 +0000 | [diff] [blame] | 914 |  | 
| Brett Cannon | 29c0e4f | 2010-03-20 22:22:57 +0000 | [diff] [blame] | 915 |     def get_warnings_filters(self): | 
 | 916 |         return id(warnings.filters), warnings.filters, warnings.filters[:] | 
 | 917 |     def restore_warnings_filters(self, saved_filters): | 
 | 918 |         warnings.filters = saved_filters[1] | 
 | 919 |         warnings.filters[:] = saved_filters[2] | 
 | 920 |  | 
| Antoine Pitrou | b14ac8c | 2010-08-16 00:28:05 +0000 | [diff] [blame] | 921 |     def get_asyncore_socket_map(self): | 
 | 922 |         asyncore = sys.modules.get('asyncore') | 
| Antoine Pitrou | aa87965 | 2010-10-29 11:54:38 +0000 | [diff] [blame] | 923 |         # XXX Making a copy keeps objects alive until __exit__ gets called. | 
 | 924 |         return asyncore and asyncore.socket_map.copy() or {} | 
| Antoine Pitrou | b14ac8c | 2010-08-16 00:28:05 +0000 | [diff] [blame] | 925 |     def restore_asyncore_socket_map(self, saved_map): | 
 | 926 |         asyncore = sys.modules.get('asyncore') | 
 | 927 |         if asyncore is not None: | 
| Antoine Pitrou | aa87965 | 2010-10-29 11:54:38 +0000 | [diff] [blame] | 928 |             asyncore.close_all(ignore_all=True) | 
| Antoine Pitrou | b14ac8c | 2010-08-16 00:28:05 +0000 | [diff] [blame] | 929 |             asyncore.socket_map.update(saved_map) | 
 | 930 |  | 
| Nick Coghlan | 7d81975 | 2010-12-05 06:45:03 +0000 | [diff] [blame] | 931 |     def get_logging__handlers(self): | 
 | 932 |         # _handlers is a WeakValueDictionary | 
| Nick Coghlan | 7bd5dbe | 2010-12-05 07:17:25 +0000 | [diff] [blame] | 933 |         return id(logging._handlers), logging._handlers, logging._handlers.copy() | 
| Nick Coghlan | 7d81975 | 2010-12-05 06:45:03 +0000 | [diff] [blame] | 934 |     def restore_logging__handlers(self, saved_handlers): | 
 | 935 |         # Can't easily revert the logging state | 
 | 936 |         pass | 
 | 937 |  | 
| Nick Coghlan | 7bd5dbe | 2010-12-05 07:17:25 +0000 | [diff] [blame] | 938 |     def get_logging__handlerList(self): | 
 | 939 |         # _handlerList is a list of weakrefs to handlers | 
 | 940 |         return id(logging._handlerList), logging._handlerList, logging._handlerList[:] | 
 | 941 |     def restore_logging__handlerList(self, saved_handlerList): | 
 | 942 |         # Can't easily revert the logging state | 
 | 943 |         pass | 
 | 944 |  | 
| Ezio Melotti | 0123e05 | 2011-03-20 15:09:26 +0200 | [diff] [blame] | 945 |     def get_sys_warnoptions(self): | 
 | 946 |         return id(sys.warnoptions), sys.warnoptions, sys.warnoptions[:] | 
 | 947 |     def restore_sys_warnoptions(self, saved_options): | 
 | 948 |         sys.warnoptions = saved_options[1] | 
 | 949 |         sys.warnoptions[:] = saved_options[2] | 
 | 950 |  | 
| Nick Coghlan | 6ead552 | 2009-10-18 13:19:33 +0000 | [diff] [blame] | 951 |     def resource_info(self): | 
 | 952 |         for name in self.resources: | 
 | 953 |             method_suffix = name.replace('.', '_') | 
 | 954 |             get_name = 'get_' + method_suffix | 
 | 955 |             restore_name = 'restore_' + method_suffix | 
 | 956 |             yield name, getattr(self, get_name), getattr(self, restore_name) | 
 | 957 |  | 
 | 958 |     def __enter__(self): | 
 | 959 |         self.saved_values = dict((name, get()) for name, get, restore | 
 | 960 |                                                    in self.resource_info()) | 
 | 961 |         return self | 
 | 962 |  | 
 | 963 |     def __exit__(self, exc_type, exc_val, exc_tb): | 
| Antoine Pitrou | aa87965 | 2010-10-29 11:54:38 +0000 | [diff] [blame] | 964 |         saved_values = self.saved_values | 
 | 965 |         del self.saved_values | 
| Nick Coghlan | 6ead552 | 2009-10-18 13:19:33 +0000 | [diff] [blame] | 966 |         for name, get, restore in self.resource_info(): | 
 | 967 |             current = get() | 
| Antoine Pitrou | aa87965 | 2010-10-29 11:54:38 +0000 | [diff] [blame] | 968 |             original = saved_values.pop(name) | 
| Nick Coghlan | 6ead552 | 2009-10-18 13:19:33 +0000 | [diff] [blame] | 969 |             # Check for changes to the resource's value | 
 | 970 |             if current != original: | 
 | 971 |                 self.changed = True | 
 | 972 |                 restore(original) | 
 | 973 |                 if not self.quiet: | 
 | 974 |                     print("Warning -- {} was modified by {}".format( | 
 | 975 |                                                  name, self.testname), | 
 | 976 |                                                  file=sys.stderr) | 
 | 977 |                     if self.verbose > 1: | 
 | 978 |                         print("  Before: {}\n  After:  {} ".format( | 
 | 979 |                                                   original, current), | 
 | 980 |                                                   file=sys.stderr) | 
 | 981 |         return False | 
 | 982 |  | 
 | 983 |  | 
| Victor Stinner | a7c33e5 | 2011-06-29 13:00:54 +0200 | [diff] [blame] | 984 | def runtest_inner(test, verbose, quiet, | 
 | 985 |                   huntrleaks=False, debug=False, display_failure=True): | 
| Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 986 |     support.unload(test) | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 987 |  | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 988 |     test_time = 0.0 | 
| Collin Winter | a5503d5 | 2009-05-15 01:20:21 +0000 | [diff] [blame] | 989 |     refleak = False  # True if the test leaked references. | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 990 |     try: | 
| R. David Murray | 0bc11ae | 2009-10-18 22:18:17 +0000 | [diff] [blame] | 991 |         if test.startswith('test.'): | 
 | 992 |             abstest = test | 
 | 993 |         else: | 
 | 994 |             # Always import it from the test package | 
 | 995 |             abstest = 'test.' + test | 
 | 996 |         with saved_test_environment(test, verbose, quiet) as environment: | 
 | 997 |             start_time = time.time() | 
 | 998 |             the_package = __import__(abstest, globals(), locals(), []) | 
 | 999 |             the_module = getattr(the_package, test) | 
 | 1000 |             # Old tests run to completion simply as a side-effect of | 
 | 1001 |             # being imported.  For tests based on unittest or doctest, | 
 | 1002 |             # explicitly invoke their test_main() function (if it exists). | 
 | 1003 |             indirect_test = getattr(the_module, "test_main", None) | 
 | 1004 |             if indirect_test is not None: | 
 | 1005 |                 indirect_test() | 
 | 1006 |             if huntrleaks: | 
 | 1007 |                 refleak = dash_R(the_module, test, indirect_test, | 
 | 1008 |                     huntrleaks) | 
 | 1009 |             test_time = time.time() - start_time | 
| Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 1010 |     except support.ResourceDenied as msg: | 
| Fred Drake | 9a0db07 | 2003-02-03 15:19:30 +0000 | [diff] [blame] | 1011 |         if not quiet: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1012 |             print(test, "skipped --", msg) | 
| Fred Drake | 9a0db07 | 2003-02-03 15:19:30 +0000 | [diff] [blame] | 1013 |             sys.stdout.flush() | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 1014 |         return RESOURCE_DENIED, test_time | 
| R. David Murray | a21e4ca | 2009-03-31 23:16:50 +0000 | [diff] [blame] | 1015 |     except unittest.SkipTest as msg: | 
| Trent Mick | f29f47b | 2000-08-11 19:02:59 +0000 | [diff] [blame] | 1016 |         if not quiet: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1017 |             print(test, "skipped --", msg) | 
| Guido van Rossum | 3cda93e | 2002-09-13 21:28:03 +0000 | [diff] [blame] | 1018 |             sys.stdout.flush() | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 1019 |         return SKIPPED, test_time | 
| Fred Drake | fe5c22a | 2000-08-18 16:04:05 +0000 | [diff] [blame] | 1020 |     except KeyboardInterrupt: | 
 | 1021 |         raise | 
| Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 1022 |     except support.TestFailed as msg: | 
| Victor Stinner | a7c33e5 | 2011-06-29 13:00:54 +0200 | [diff] [blame] | 1023 |         if display_failure: | 
 | 1024 |             print("test", test, "failed --", msg, file=sys.stderr) | 
 | 1025 |         else: | 
 | 1026 |             print("test", test, "failed", file=sys.stderr) | 
| R. David Murray | 11cabcf | 2010-09-29 01:08:05 +0000 | [diff] [blame] | 1027 |         sys.stderr.flush() | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 1028 |         return FAILED, test_time | 
| Guido van Rossum | 9e48b27 | 1997-07-16 01:56:13 +0000 | [diff] [blame] | 1029 |     except: | 
| Antoine Pitrou | 779a5b0 | 2011-03-21 19:55:16 +0100 | [diff] [blame] | 1030 |         msg = traceback.format_exc() | 
 | 1031 |         print("test", test, "crashed --", msg, file=sys.stderr) | 
| R. David Murray | 11cabcf | 2010-09-29 01:08:05 +0000 | [diff] [blame] | 1032 |         sys.stderr.flush() | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 1033 |         return FAILED, test_time | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 1034 |     else: | 
| Collin Winter | a5503d5 | 2009-05-15 01:20:21 +0000 | [diff] [blame] | 1035 |         if refleak: | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 1036 |             return FAILED, test_time | 
| Nick Coghlan | 6ead552 | 2009-10-18 13:19:33 +0000 | [diff] [blame] | 1037 |         if environment.changed: | 
| Benjamin Peterson | a0dfa82 | 2009-11-13 02:25:08 +0000 | [diff] [blame] | 1038 |             return ENV_CHANGED, test_time | 
 | 1039 |         return PASSED, test_time | 
| Guido van Rossum | 0fcca4e | 2001-09-21 20:31:52 +0000 | [diff] [blame] | 1040 |  | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1041 | def cleanup_test_droppings(testname, verbose): | 
 | 1042 |     import shutil | 
| Benjamin Peterson | 25c95f1 | 2009-05-08 20:42:26 +0000 | [diff] [blame] | 1043 |     import stat | 
| Antoine Pitrou | c14efc4 | 2010-10-29 19:34:45 +0000 | [diff] [blame] | 1044 |     import gc | 
 | 1045 |  | 
 | 1046 |     # First kill any dangling references to open files etc. | 
 | 1047 |     # This can also issue some ResourceWarnings which would otherwise get | 
| Antoine Pitrou | 2b40efd | 2010-10-29 19:36:37 +0000 | [diff] [blame] | 1048 |     # triggered during the following test run, and possibly produce failures. | 
| Antoine Pitrou | c14efc4 | 2010-10-29 19:34:45 +0000 | [diff] [blame] | 1049 |     gc.collect() | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1050 |  | 
 | 1051 |     # Try to clean up junk commonly left behind.  While tests shouldn't leave | 
 | 1052 |     # any files or directories behind, when a test fails that can be tedious | 
 | 1053 |     # for it to arrange.  The consequences can be especially nasty on Windows, | 
 | 1054 |     # since if a test leaves a file open, it cannot be deleted by name (while | 
 | 1055 |     # there's nothing we can do about that here either, we can display the | 
 | 1056 |     # name of the offending test, which is a real help). | 
| Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 1057 |     for name in (support.TESTFN, | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1058 |                  "db_home", | 
 | 1059 |                 ): | 
 | 1060 |         if not os.path.exists(name): | 
 | 1061 |             continue | 
 | 1062 |  | 
 | 1063 |         if os.path.isdir(name): | 
 | 1064 |             kind, nuker = "directory", shutil.rmtree | 
 | 1065 |         elif os.path.isfile(name): | 
 | 1066 |             kind, nuker = "file", os.unlink | 
 | 1067 |         else: | 
 | 1068 |             raise SystemError("os.path says %r exists but is neither " | 
 | 1069 |                               "directory nor file" % name) | 
 | 1070 |  | 
 | 1071 |         if verbose: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1072 |             print("%r left behind %s %r" % (testname, kind, name)) | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1073 |         try: | 
| Benjamin Peterson | 25c95f1 | 2009-05-08 20:42:26 +0000 | [diff] [blame] | 1074 |             # if we have chmod, fix possible permissions problems | 
 | 1075 |             # that might prevent cleanup | 
 | 1076 |             if (hasattr(os, 'chmod')): | 
 | 1077 |                 os.chmod(name, stat.S_IRWXU | stat.S_IRWXG | stat.S_IRWXO) | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1078 |             nuker(name) | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1079 |         except Exception as msg: | 
 | 1080 |             print(("%r left behind %s %r and it couldn't be " | 
 | 1081 |                 "removed: %s" % (testname, kind, name, msg)), file=sys.stderr) | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1082 |  | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1083 | def dash_R(the_module, test, indirect_test, huntrleaks): | 
| Collin Winter | a5503d5 | 2009-05-15 01:20:21 +0000 | [diff] [blame] | 1084 |     """Run a test multiple times, looking for reference leaks. | 
 | 1085 |  | 
 | 1086 |     Returns: | 
 | 1087 |         False if the test didn't leak references; True if we detected refleaks. | 
 | 1088 |     """ | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1089 |     # This code is hackish and inelegant, but it seems to do the job. | 
| Alexandre Vassalotti | f7fa63d | 2008-05-11 08:55:36 +0000 | [diff] [blame] | 1090 |     import copyreg, _abcoll | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1091 |  | 
 | 1092 |     if not hasattr(sys, 'gettotalrefcount'): | 
 | 1093 |         raise Exception("Tracking reference leaks requires a debug build " | 
 | 1094 |                         "of Python") | 
 | 1095 |  | 
 | 1096 |     # Save current values for dash_R_cleanup() to restore. | 
 | 1097 |     fs = warnings.filters[:] | 
| Alexandre Vassalotti | f7fa63d | 2008-05-11 08:55:36 +0000 | [diff] [blame] | 1098 |     ps = copyreg.dispatch_table.copy() | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1099 |     pic = sys.path_importer_cache.copy() | 
| Nick Coghlan | 260bd3e | 2009-11-16 06:49:25 +0000 | [diff] [blame] | 1100 |     try: | 
 | 1101 |         import zipimport | 
 | 1102 |     except ImportError: | 
 | 1103 |         zdc = None # Run unmodified on platforms without zipimport support | 
 | 1104 |     else: | 
 | 1105 |         zdc = zipimport._zip_directory_cache.copy() | 
| Christian Heimes | 9385266 | 2007-12-01 12:22:32 +0000 | [diff] [blame] | 1106 |     abcs = {} | 
 | 1107 |     for abc in [getattr(_abcoll, a) for a in _abcoll.__all__]: | 
| Christian Heimes | be5b30b | 2008-03-03 19:18:51 +0000 | [diff] [blame] | 1108 |         if not isabstract(abc): | 
| Christian Heimes | 9385266 | 2007-12-01 12:22:32 +0000 | [diff] [blame] | 1109 |             continue | 
 | 1110 |         for obj in abc.__subclasses__() + [abc]: | 
 | 1111 |             abcs[obj] = obj._abc_registry.copy() | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1112 |  | 
 | 1113 |     if indirect_test: | 
 | 1114 |         def run_the_test(): | 
 | 1115 |             indirect_test() | 
 | 1116 |     else: | 
 | 1117 |         def run_the_test(): | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1118 |             del sys.modules[the_module.__name__] | 
 | 1119 |             exec('import ' + the_module.__name__) | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1120 |  | 
 | 1121 |     deltas = [] | 
 | 1122 |     nwarmup, ntracked, fname = huntrleaks | 
| Ezio Melotti | 184bdfb | 2010-02-18 09:37:05 +0000 | [diff] [blame] | 1123 |     fname = os.path.join(support.SAVEDCWD, fname) | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1124 |     repcount = nwarmup + ntracked | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1125 |     print("beginning", repcount, "repetitions", file=sys.stderr) | 
 | 1126 |     print(("1234567890"*(repcount//10 + 1))[:repcount], file=sys.stderr) | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 1127 |     sys.stderr.flush() | 
| Nick Coghlan | 260bd3e | 2009-11-16 06:49:25 +0000 | [diff] [blame] | 1128 |     dash_R_cleanup(fs, ps, pic, zdc, abcs) | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1129 |     for i in range(repcount): | 
| Collin Winter | 58bee59 | 2010-03-17 02:08:57 +0000 | [diff] [blame] | 1130 |         rc_before = sys.gettotalrefcount() | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1131 |         run_the_test() | 
 | 1132 |         sys.stderr.write('.') | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1133 |         sys.stderr.flush() | 
| Nick Coghlan | 260bd3e | 2009-11-16 06:49:25 +0000 | [diff] [blame] | 1134 |         dash_R_cleanup(fs, ps, pic, zdc, abcs) | 
| Collin Winter | 58bee59 | 2010-03-17 02:08:57 +0000 | [diff] [blame] | 1135 |         rc_after = sys.gettotalrefcount() | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1136 |         if i >= nwarmup: | 
| Collin Winter | 58bee59 | 2010-03-17 02:08:57 +0000 | [diff] [blame] | 1137 |             deltas.append(rc_after - rc_before) | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1138 |     print(file=sys.stderr) | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1139 |     if any(deltas): | 
| Guido van Rossum | 360e4b8 | 2007-05-14 22:51:27 +0000 | [diff] [blame] | 1140 |         msg = '%s leaked %s references, sum=%s' % (test, deltas, sum(deltas)) | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1141 |         print(msg, file=sys.stderr) | 
| Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 1142 |         sys.stderr.flush() | 
 | 1143 |         with open(fname, "a") as refrep: | 
 | 1144 |             print(msg, file=refrep) | 
 | 1145 |             refrep.flush() | 
| Collin Winter | a5503d5 | 2009-05-15 01:20:21 +0000 | [diff] [blame] | 1146 |         return True | 
 | 1147 |     return False | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1148 |  | 
| Nick Coghlan | 260bd3e | 2009-11-16 06:49:25 +0000 | [diff] [blame] | 1149 | def dash_R_cleanup(fs, ps, pic, zdc, abcs): | 
| Alexandre Vassalotti | f7fa63d | 2008-05-11 08:55:36 +0000 | [diff] [blame] | 1150 |     import gc, copyreg | 
| Brett Cannon | f4fd993 | 2008-05-10 21:11:46 +0000 | [diff] [blame] | 1151 |     import _strptime, linecache | 
| Jeremy Hylton | 1afc169 | 2008-06-18 20:49:58 +0000 | [diff] [blame] | 1152 |     import urllib.parse, urllib.request, mimetypes, doctest | 
| Guido van Rossum | 7eaf822 | 2007-06-18 17:58:50 +0000 | [diff] [blame] | 1153 |     import struct, filecmp, _abcoll | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1154 |     from distutils.dir_util import _path_created | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1155 |     from weakref import WeakSet | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1156 |  | 
| Christian Heimes | dae2a89 | 2008-04-19 00:55:37 +0000 | [diff] [blame] | 1157 |     # Clear the warnings registry, so they can be displayed again | 
 | 1158 |     for mod in sys.modules.values(): | 
 | 1159 |         if hasattr(mod, '__warningregistry__'): | 
 | 1160 |             del mod.__warningregistry__ | 
 | 1161 |  | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1162 |     # Restore some original values. | 
 | 1163 |     warnings.filters[:] = fs | 
| Alexandre Vassalotti | f7fa63d | 2008-05-11 08:55:36 +0000 | [diff] [blame] | 1164 |     copyreg.dispatch_table.clear() | 
 | 1165 |     copyreg.dispatch_table.update(ps) | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1166 |     sys.path_importer_cache.clear() | 
 | 1167 |     sys.path_importer_cache.update(pic) | 
| Nick Coghlan | 260bd3e | 2009-11-16 06:49:25 +0000 | [diff] [blame] | 1168 |     try: | 
 | 1169 |         import zipimport | 
 | 1170 |     except ImportError: | 
 | 1171 |         pass # Run unmodified on platforms without zipimport support | 
 | 1172 |     else: | 
 | 1173 |         zipimport._zip_directory_cache.clear() | 
 | 1174 |         zipimport._zip_directory_cache.update(zdc) | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1175 |  | 
| Christian Heimes | 2685563 | 2008-01-27 23:50:43 +0000 | [diff] [blame] | 1176 |     # clear type cache | 
| Christian Heimes | 15ebc88 | 2008-02-04 18:48:49 +0000 | [diff] [blame] | 1177 |     sys._clear_type_cache() | 
| Christian Heimes | 2685563 | 2008-01-27 23:50:43 +0000 | [diff] [blame] | 1178 |  | 
| Guido van Rossum | 3de862d | 2007-08-18 00:10:33 +0000 | [diff] [blame] | 1179 |     # Clear ABC registries, restoring previously saved ABC registries. | 
| Guido van Rossum | 7eaf822 | 2007-06-18 17:58:50 +0000 | [diff] [blame] | 1180 |     for abc in [getattr(_abcoll, a) for a in _abcoll.__all__]: | 
| Christian Heimes | be5b30b | 2008-03-03 19:18:51 +0000 | [diff] [blame] | 1181 |         if not isabstract(abc): | 
| Christian Heimes | 941973a | 2007-11-30 21:53:03 +0000 | [diff] [blame] | 1182 |             continue | 
| Guido van Rossum | 7eaf822 | 2007-06-18 17:58:50 +0000 | [diff] [blame] | 1183 |         for obj in abc.__subclasses__() + [abc]: | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1184 |             obj._abc_registry = abcs.get(obj, WeakSet()).copy() | 
| Guido van Rossum | c1e315d | 2007-08-20 19:29:24 +0000 | [diff] [blame] | 1185 |             obj._abc_cache.clear() | 
 | 1186 |             obj._abc_negative_cache.clear() | 
| Guido van Rossum | cd16bf6 | 2007-06-13 18:07:49 +0000 | [diff] [blame] | 1187 |  | 
| Antoine Pitrou | 046467c | 2009-10-30 18:30:35 +0000 | [diff] [blame] | 1188 |     # Flush standard output, so that buffered data is sent to the OS and | 
 | 1189 |     # associated Python objects are reclaimed. | 
 | 1190 |     for stream in (sys.stdout, sys.stderr, sys.__stdout__, sys.__stderr__): | 
 | 1191 |         if stream is not None: | 
 | 1192 |             stream.flush() | 
 | 1193 |  | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1194 |     # Clear assorted module caches. | 
 | 1195 |     _path_created.clear() | 
 | 1196 |     re.purge() | 
 | 1197 |     _strptime._regex_cache.clear() | 
| Jeremy Hylton | 1afc169 | 2008-06-18 20:49:58 +0000 | [diff] [blame] | 1198 |     urllib.parse.clear_cache() | 
 | 1199 |     urllib.request.urlcleanup() | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1200 |     linecache.clearcache() | 
 | 1201 |     mimetypes._default_mime_types() | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1202 |     filecmp._cache.clear() | 
| Christian Heimes | a34706f | 2008-01-04 03:06:10 +0000 | [diff] [blame] | 1203 |     struct._clearcache() | 
| Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 1204 |     doctest.master = None | 
 | 1205 |  | 
 | 1206 |     # Collect cyclic trash. | 
 | 1207 |     gc.collect() | 
 | 1208 |  | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1209 | def warm_char_cache(): | 
 | 1210 |     s = bytes(range(256)) | 
 | 1211 |     for i in range(256): | 
 | 1212 |         s[i:i+1] | 
 | 1213 |  | 
| Florent Xicluna | da7bfd5 | 2010-03-06 11:43:55 +0000 | [diff] [blame] | 1214 | def findtestdir(path=None): | 
 | 1215 |     return path or os.path.dirname(__file__) or os.curdir | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 1216 |  | 
| Florent Xicluna | da7bfd5 | 2010-03-06 11:43:55 +0000 | [diff] [blame] | 1217 | def removepy(names): | 
 | 1218 |     if not names: | 
 | 1219 |         return | 
 | 1220 |     for idx, name in enumerate(names): | 
 | 1221 |         basename, ext = os.path.splitext(name) | 
 | 1222 |         if ext == '.py': | 
 | 1223 |             names[idx] = basename | 
| Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 1224 |  | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 1225 | def count(n, word): | 
 | 1226 |     if n == 1: | 
| Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 1227 |         return "%d %s" % (n, word) | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 1228 |     else: | 
| Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 1229 |         return "%d %ss" % (n, word) | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 1230 |  | 
| Tim Peters | a45da92 | 2001-08-12 03:45:50 +0000 | [diff] [blame] | 1231 | def printlist(x, width=70, indent=4): | 
| Tim Peters | 7c7efe9 | 2002-08-23 17:55:54 +0000 | [diff] [blame] | 1232 |     """Print the elements of iterable x to stdout. | 
| Tim Peters | a45da92 | 2001-08-12 03:45:50 +0000 | [diff] [blame] | 1233 |  | 
 | 1234 |     Optional arg width (default 70) is the maximum line length. | 
 | 1235 |     Optional arg indent (default 4) is the number of blanks with which to | 
 | 1236 |     begin each line. | 
 | 1237 |     """ | 
 | 1238 |  | 
| Tim Peters | ba78bc4 | 2002-07-04 19:45:06 +0000 | [diff] [blame] | 1239 |     from textwrap import fill | 
 | 1240 |     blanks = ' ' * indent | 
| Florent Xicluna | fd1b093 | 2010-03-28 00:25:02 +0000 | [diff] [blame] | 1241 |     # Print the sorted list: 'x' may be a '--random' list or a set() | 
 | 1242 |     print(fill(' '.join(str(elt) for elt in sorted(x)), width, | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1243 |                initial_indent=blanks, subsequent_indent=blanks)) | 
| Tim Peters | a45da92 | 2001-08-12 03:45:50 +0000 | [diff] [blame] | 1244 |  | 
| Tim Peters | de14a30 | 2002-04-01 05:04:46 +0000 | [diff] [blame] | 1245 | # Map sys.platform to a string containing the basenames of tests | 
 | 1246 | # expected to be skipped on that platform. | 
| Tim Peters | 2a182db | 2002-10-09 01:07:11 +0000 | [diff] [blame] | 1247 | # | 
 | 1248 | # Special cases: | 
 | 1249 | #     test_pep277 | 
 | 1250 | #         The _ExpectedSkips constructor adds this to the set of expected | 
 | 1251 | #         skips if not os.path.supports_unicode_filenames. | 
| Neal Norwitz | 55b61d2 | 2003-02-28 19:57:03 +0000 | [diff] [blame] | 1252 | #     test_timeout | 
 | 1253 | #         Controlled by test_timeout.skip_expected.  Requires the network | 
 | 1254 | #         resource and a socket module. | 
| Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1255 | # | 
 | 1256 | # Tests that are expected to be skipped everywhere except on one platform | 
 | 1257 | # are also handled separately. | 
| Tim Peters | de14a30 | 2002-04-01 05:04:46 +0000 | [diff] [blame] | 1258 |  | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1259 | _expectations = { | 
 | 1260 |     'win32': | 
 | 1261 |         """ | 
| Tim Peters | c7c516a | 2003-09-20 22:06:13 +0000 | [diff] [blame] | 1262 |         test__locale | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1263 |         test_crypt | 
| Tim Peters | d703057 | 2001-10-22 22:06:08 +0000 | [diff] [blame] | 1264 |         test_curses | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1265 |         test_dbm | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1266 |         test_fcntl | 
 | 1267 |         test_fork1 | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1268 |         test_epoll | 
| Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1269 |         test_dbm_gnu | 
| Kristján Valur Jónsson | 42a40c5 | 2009-04-01 11:28:47 +0000 | [diff] [blame] | 1270 |         test_dbm_ndbm | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1271 |         test_grp | 
| Tim Peters | fd8e6e5 | 2003-03-04 00:26:38 +0000 | [diff] [blame] | 1272 |         test_ioctl | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1273 |         test_largefile | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1274 |         test_kqueue | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1275 |         test_openpty | 
| Tim Peters | efc4b12 | 2002-12-10 18:47:56 +0000 | [diff] [blame] | 1276 |         test_ossaudiodev | 
| Thomas Wouters | 47b49bf | 2007-08-30 22:15:33 +0000 | [diff] [blame] | 1277 |         test_pipes | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1278 |         test_poll | 
| Tim Peters | 003eb30 | 2003-02-17 21:48:48 +0000 | [diff] [blame] | 1279 |         test_posix | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1280 |         test_pty | 
 | 1281 |         test_pwd | 
| Tim Peters | 1e33ffa | 2002-04-23 23:09:02 +0000 | [diff] [blame] | 1282 |         test_resource | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1283 |         test_signal | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1284 |         test_syslog | 
| Tim Peters | cea2cc4 | 2004-08-04 02:32:03 +0000 | [diff] [blame] | 1285 |         test_threadsignals | 
| Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1286 |         test_wait3 | 
 | 1287 |         test_wait4 | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1288 |         """, | 
 | 1289 |     'linux2': | 
 | 1290 |         """ | 
| Guido van Rossum | f66dacd | 2001-10-23 15:10:55 +0000 | [diff] [blame] | 1291 |         test_curses | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1292 |         test_largefile | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1293 |         test_kqueue | 
| Guido van Rossum | 4507ec7 | 2003-02-14 19:29:22 +0000 | [diff] [blame] | 1294 |         test_ossaudiodev | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1295 |         """, | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1296 |     'unixware7': | 
| Martin v. Löwis | 0ace326 | 2001-09-05 14:38:48 +0000 | [diff] [blame] | 1297 |         """ | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1298 |         test_epoll | 
| Martin v. Löwis | 0ace326 | 2001-09-05 14:38:48 +0000 | [diff] [blame] | 1299 |         test_largefile | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1300 |         test_kqueue | 
| Martin v. Löwis | 0ace326 | 2001-09-05 14:38:48 +0000 | [diff] [blame] | 1301 |         test_minidom | 
| Martin v. Löwis | 0ace326 | 2001-09-05 14:38:48 +0000 | [diff] [blame] | 1302 |         test_openpty | 
 | 1303 |         test_pyexpat | 
 | 1304 |         test_sax | 
| Martin v. Löwis | 0ace326 | 2001-09-05 14:38:48 +0000 | [diff] [blame] | 1305 |         test_sundry | 
| Martin v. Löwis | 0ace326 | 2001-09-05 14:38:48 +0000 | [diff] [blame] | 1306 |         """, | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1307 |     'openunix8': | 
 | 1308 |         """ | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1309 |         test_epoll | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1310 |         test_largefile | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1311 |         test_kqueue | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1312 |         test_minidom | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1313 |         test_openpty | 
 | 1314 |         test_pyexpat | 
 | 1315 |         test_sax | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1316 |         test_sundry | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1317 |         """, | 
 | 1318 |     'sco_sv3': | 
 | 1319 |         """ | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1320 |         test_asynchat | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1321 |         test_fork1 | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1322 |         test_epoll | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1323 |         test_gettext | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1324 |         test_largefile | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1325 |         test_locale | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1326 |         test_kqueue | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1327 |         test_minidom | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1328 |         test_openpty | 
 | 1329 |         test_pyexpat | 
 | 1330 |         test_queue | 
 | 1331 |         test_sax | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1332 |         test_sundry | 
 | 1333 |         test_thread | 
 | 1334 |         test_threaded_import | 
 | 1335 |         test_threadedtempfile | 
 | 1336 |         test_threading | 
| Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1337 |         """, | 
| Jack Jansen | 8a97f4a | 2001-12-05 23:27:32 +0000 | [diff] [blame] | 1338 |     'darwin': | 
| Jack Jansen | 398c236 | 2001-12-02 21:41:36 +0000 | [diff] [blame] | 1339 |         """ | 
| Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1340 |         test__locale | 
| Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1341 |         test_curses | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1342 |         test_epoll | 
| Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1343 |         test_dbm_gnu | 
| Skip Montanaro | 97019ff | 2010-10-25 01:35:48 +0000 | [diff] [blame] | 1344 |         test_gdb | 
| Jack Jansen | 398c236 | 2001-12-02 21:41:36 +0000 | [diff] [blame] | 1345 |         test_largefile | 
| Jack Jansen | acda339 | 2002-12-30 23:03:13 +0000 | [diff] [blame] | 1346 |         test_locale | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1347 |         test_minidom | 
| Jack Jansen | acda339 | 2002-12-30 23:03:13 +0000 | [diff] [blame] | 1348 |         test_ossaudiodev | 
| Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1349 |         test_poll | 
| Jack Jansen | 398c236 | 2001-12-02 21:41:36 +0000 | [diff] [blame] | 1350 |         """, | 
| Guido van Rossum | 11c3f09 | 2002-07-17 15:08:24 +0000 | [diff] [blame] | 1351 |     'sunos5': | 
 | 1352 |         """ | 
| Guido van Rossum | 11c3f09 | 2002-07-17 15:08:24 +0000 | [diff] [blame] | 1353 |         test_curses | 
 | 1354 |         test_dbm | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1355 |         test_epoll | 
 | 1356 |         test_kqueue | 
| Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1357 |         test_dbm_gnu | 
| Guido van Rossum | 11c3f09 | 2002-07-17 15:08:24 +0000 | [diff] [blame] | 1358 |         test_gzip | 
| Guido van Rossum | 11c3f09 | 2002-07-17 15:08:24 +0000 | [diff] [blame] | 1359 |         test_openpty | 
| Guido van Rossum | 11c3f09 | 2002-07-17 15:08:24 +0000 | [diff] [blame] | 1360 |         test_zipfile | 
 | 1361 |         test_zlib | 
| Jeremy Hylton | ed375e1 | 2002-07-17 15:56:55 +0000 | [diff] [blame] | 1362 |         """, | 
| Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1363 |     'hp-ux11': | 
 | 1364 |         """ | 
| Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1365 |         test_curses | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1366 |         test_epoll | 
| Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1367 |         test_dbm_gnu | 
| Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1368 |         test_gzip | 
| Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1369 |         test_largefile | 
| Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1370 |         test_locale | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1371 |         test_kqueue | 
| Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1372 |         test_minidom | 
| Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1373 |         test_openpty | 
 | 1374 |         test_pyexpat | 
 | 1375 |         test_sax | 
| Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1376 |         test_zipfile | 
 | 1377 |         test_zlib | 
 | 1378 |         """, | 
| Jason Tishler | 2511594 | 2002-12-05 15:18:15 +0000 | [diff] [blame] | 1379 |     'cygwin': | 
 | 1380 |         """ | 
| Jason Tishler | 2511594 | 2002-12-05 15:18:15 +0000 | [diff] [blame] | 1381 |         test_curses | 
 | 1382 |         test_dbm | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1383 |         test_epoll | 
| Jason Tishler | c23f39c | 2003-07-22 18:35:58 +0000 | [diff] [blame] | 1384 |         test_ioctl | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1385 |         test_kqueue | 
| Jason Tishler | 2511594 | 2002-12-05 15:18:15 +0000 | [diff] [blame] | 1386 |         test_largefile | 
| Jason Tishler | 2511594 | 2002-12-05 15:18:15 +0000 | [diff] [blame] | 1387 |         test_locale | 
| Jason Tishler | 5c4ded2 | 2003-02-05 16:46:01 +0000 | [diff] [blame] | 1388 |         test_ossaudiodev | 
| Jason Tishler | 2511594 | 2002-12-05 15:18:15 +0000 | [diff] [blame] | 1389 |         test_socketserver | 
| Jason Tishler | 2511594 | 2002-12-05 15:18:15 +0000 | [diff] [blame] | 1390 |         """, | 
| Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1391 |     'os2emx': | 
 | 1392 |         """ | 
| Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1393 |         test_audioop | 
| Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1394 |         test_curses | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1395 |         test_epoll | 
 | 1396 |         test_kqueue | 
| Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1397 |         test_largefile | 
| Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1398 |         test_mmap | 
| Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1399 |         test_openpty | 
 | 1400 |         test_ossaudiodev | 
 | 1401 |         test_pty | 
 | 1402 |         test_resource | 
 | 1403 |         test_signal | 
| Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1404 |         """, | 
| Guido van Rossum | 944a6c3 | 2003-11-20 22:11:29 +0000 | [diff] [blame] | 1405 |     'freebsd4': | 
 | 1406 |         """ | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1407 |         test_epoll | 
| Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1408 |         test_dbm_gnu | 
| Guido van Rossum | 944a6c3 | 2003-11-20 22:11:29 +0000 | [diff] [blame] | 1409 |         test_locale | 
| Guido van Rossum | 944a6c3 | 2003-11-20 22:11:29 +0000 | [diff] [blame] | 1410 |         test_ossaudiodev | 
 | 1411 |         test_pep277 | 
| Hye-Shik Chang | f64700a | 2004-08-18 15:13:41 +0000 | [diff] [blame] | 1412 |         test_pty | 
| Guido van Rossum | 944a6c3 | 2003-11-20 22:11:29 +0000 | [diff] [blame] | 1413 |         test_socketserver | 
| Hye-Shik Chang | f64700a | 2004-08-18 15:13:41 +0000 | [diff] [blame] | 1414 |         test_tcl | 
| Guilherme Polo | a91790a | 2009-02-09 20:40:42 +0000 | [diff] [blame] | 1415 |         test_tk | 
| Guilherme Polo | 9de29af | 2009-01-28 20:40:48 +0000 | [diff] [blame] | 1416 |         test_ttk_guionly | 
 | 1417 |         test_ttk_textonly | 
| Guido van Rossum | 944a6c3 | 2003-11-20 22:11:29 +0000 | [diff] [blame] | 1418 |         test_timeout | 
| Guido van Rossum | 944a6c3 | 2003-11-20 22:11:29 +0000 | [diff] [blame] | 1419 |         test_urllibnet | 
| Benjamin Peterson | e5384b0 | 2008-10-04 22:00:42 +0000 | [diff] [blame] | 1420 |         test_multiprocessing | 
| Martin v. Löwis | 56f8811 | 2003-06-07 20:01:37 +0000 | [diff] [blame] | 1421 |         """, | 
| Guido van Rossum | 8ee3e5a | 2005-09-14 18:09:42 +0000 | [diff] [blame] | 1422 |     'aix5': | 
 | 1423 |         """ | 
| Guido van Rossum | 8ee3e5a | 2005-09-14 18:09:42 +0000 | [diff] [blame] | 1424 |         test_bz2 | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1425 |         test_epoll | 
| Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1426 |         test_dbm_gnu | 
| Guido van Rossum | 8ee3e5a | 2005-09-14 18:09:42 +0000 | [diff] [blame] | 1427 |         test_gzip | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1428 |         test_kqueue | 
| Guido van Rossum | 8ee3e5a | 2005-09-14 18:09:42 +0000 | [diff] [blame] | 1429 |         test_ossaudiodev | 
| Guido van Rossum | 8ee3e5a | 2005-09-14 18:09:42 +0000 | [diff] [blame] | 1430 |         test_tcl | 
| Guilherme Polo | a91790a | 2009-02-09 20:40:42 +0000 | [diff] [blame] | 1431 |         test_tk | 
| Guilherme Polo | 9de29af | 2009-01-28 20:40:48 +0000 | [diff] [blame] | 1432 |         test_ttk_guionly | 
 | 1433 |         test_ttk_textonly | 
| Guido van Rossum | 8ee3e5a | 2005-09-14 18:09:42 +0000 | [diff] [blame] | 1434 |         test_zipimport | 
 | 1435 |         test_zlib | 
 | 1436 |         """, | 
| Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1437 |     'openbsd3': | 
 | 1438 |         """ | 
| Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1439 |         test_ctypes | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1440 |         test_epoll | 
| Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1441 |         test_dbm_gnu | 
| Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1442 |         test_locale | 
| Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1443 |         test_normalization | 
 | 1444 |         test_ossaudiodev | 
 | 1445 |         test_pep277 | 
| Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1446 |         test_tcl | 
| Guilherme Polo | a91790a | 2009-02-09 20:40:42 +0000 | [diff] [blame] | 1447 |         test_tk | 
| Guilherme Polo | 9de29af | 2009-01-28 20:40:48 +0000 | [diff] [blame] | 1448 |         test_ttk_guionly | 
 | 1449 |         test_ttk_textonly | 
| Benjamin Peterson | e5384b0 | 2008-10-04 22:00:42 +0000 | [diff] [blame] | 1450 |         test_multiprocessing | 
| Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1451 |         """, | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1452 |     'netbsd3': | 
 | 1453 |         """ | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1454 |         test_ctypes | 
 | 1455 |         test_curses | 
| Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1456 |         test_epoll | 
| Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1457 |         test_dbm_gnu | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1458 |         test_locale | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1459 |         test_ossaudiodev | 
 | 1460 |         test_pep277 | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1461 |         test_tcl | 
| Guilherme Polo | a91790a | 2009-02-09 20:40:42 +0000 | [diff] [blame] | 1462 |         test_tk | 
| Guilherme Polo | 9de29af | 2009-01-28 20:40:48 +0000 | [diff] [blame] | 1463 |         test_ttk_guionly | 
 | 1464 |         test_ttk_textonly | 
| Benjamin Peterson | e5384b0 | 2008-10-04 22:00:42 +0000 | [diff] [blame] | 1465 |         test_multiprocessing | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1466 |         """, | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1467 | } | 
| Martin v. Löwis | 32d0c1b | 2004-07-26 12:09:13 +0000 | [diff] [blame] | 1468 | _expectations['freebsd5'] = _expectations['freebsd4'] | 
| Hye-Shik Chang | f64700a | 2004-08-18 15:13:41 +0000 | [diff] [blame] | 1469 | _expectations['freebsd6'] = _expectations['freebsd4'] | 
| Hye-Shik Chang | 4e42281 | 2005-07-17 02:36:59 +0000 | [diff] [blame] | 1470 | _expectations['freebsd7'] = _expectations['freebsd4'] | 
| Guido van Rossum | 8ce8a78 | 2007-11-01 19:42:39 +0000 | [diff] [blame] | 1471 | _expectations['freebsd8'] = _expectations['freebsd4'] | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1472 |  | 
| Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 1473 | class _ExpectedSkips: | 
 | 1474 |     def __init__(self): | 
| Tim Peters | 2a182db | 2002-10-09 01:07:11 +0000 | [diff] [blame] | 1475 |         import os.path | 
| Neal Norwitz | 55b61d2 | 2003-02-28 19:57:03 +0000 | [diff] [blame] | 1476 |         from test import test_timeout | 
| Tim Peters | 1b445d3 | 2002-11-24 18:53:11 +0000 | [diff] [blame] | 1477 |  | 
| Tim Peters | 7c7efe9 | 2002-08-23 17:55:54 +0000 | [diff] [blame] | 1478 |         self.valid = False | 
| Tim Peters | de14a30 | 2002-04-01 05:04:46 +0000 | [diff] [blame] | 1479 |         if sys.platform in _expectations: | 
| Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1480 |             s = _expectations[sys.platform] | 
| Raymond Hettinger | a690a99 | 2003-11-16 16:17:49 +0000 | [diff] [blame] | 1481 |             self.expected = set(s.split()) | 
| Tim Peters | 1b445d3 | 2002-11-24 18:53:11 +0000 | [diff] [blame] | 1482 |  | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1483 |             # These are broken tests, for now skipped on every platform. | 
 | 1484 |             # XXX Fix these! | 
| Benjamin Peterson | e9ea19e | 2008-08-19 23:02:38 +0000 | [diff] [blame] | 1485 |             self.expected.add('test_nis') | 
| Benjamin Peterson | 4fde0c4 | 2008-03-31 02:36:22 +0000 | [diff] [blame] | 1486 |  | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1487 |             # expected to be skipped on every platform, even Linux | 
| Tim Peters | 2a182db | 2002-10-09 01:07:11 +0000 | [diff] [blame] | 1488 |             if not os.path.supports_unicode_filenames: | 
 | 1489 |                 self.expected.add('test_pep277') | 
| Tim Peters | 1b445d3 | 2002-11-24 18:53:11 +0000 | [diff] [blame] | 1490 |  | 
| Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1491 |             # doctest, profile and cProfile tests fail when the codec for the | 
 | 1492 |             # fs encoding isn't built in because PyUnicode_Decode() adds two | 
 | 1493 |             # calls into Python. | 
 | 1494 |             encs = ("utf-8", "latin-1", "ascii", "mbcs", "utf-16", "utf-32") | 
 | 1495 |             if sys.getfilesystemencoding().lower() not in encs: | 
 | 1496 |                 self.expected.add('test_profile') | 
 | 1497 |                 self.expected.add('test_cProfile') | 
 | 1498 |                 self.expected.add('test_doctest') | 
| Guido van Rossum | daa251c | 2007-10-25 23:47:33 +0000 | [diff] [blame] | 1499 |  | 
| Neal Norwitz | 55b61d2 | 2003-02-28 19:57:03 +0000 | [diff] [blame] | 1500 |             if test_timeout.skip_expected: | 
 | 1501 |                 self.expected.add('test_timeout') | 
 | 1502 |  | 
| Tim Peters | ecd79eb | 2003-01-29 00:35:32 +0000 | [diff] [blame] | 1503 |             if sys.platform != "win32": | 
| Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1504 |                 # test_sqlite is only reliable on Windows where the library | 
 | 1505 |                 # is distributed with Python | 
| Benjamin Peterson | 54ad0be | 2010-10-29 21:33:10 +0000 | [diff] [blame] | 1506 |                 WIN_ONLY = {"test_unicode_file", "test_winreg", | 
| Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1507 |                             "test_winsound", "test_startfile", | 
| Ross Lagerwall | 226580e | 2011-04-09 20:05:04 +0200 | [diff] [blame] | 1508 |                             "test_sqlite", "test_msilib"} | 
| Benjamin Peterson | 54ad0be | 2010-10-29 21:33:10 +0000 | [diff] [blame] | 1509 |                 self.expected |= WIN_ONLY | 
| Tim Peters | f2715e0 | 2003-02-19 02:35:07 +0000 | [diff] [blame] | 1510 |  | 
| Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1511 |             if sys.platform != 'sunos5': | 
| Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1512 |                 self.expected.add('test_nis') | 
| Guido van Rossum | d59da4b | 2007-05-22 18:11:13 +0000 | [diff] [blame] | 1513 |  | 
| Benjamin Peterson | 65c66ab | 2010-10-29 21:31:35 +0000 | [diff] [blame] | 1514 |             if support.python_is_optimized(): | 
 | 1515 |                 self.expected.add("test_gdb") | 
 | 1516 |  | 
| Tim Peters | 7c7efe9 | 2002-08-23 17:55:54 +0000 | [diff] [blame] | 1517 |             self.valid = True | 
| Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 1518 |  | 
 | 1519 |     def isvalid(self): | 
 | 1520 |         "Return true iff _ExpectedSkips knows about the current platform." | 
 | 1521 |         return self.valid | 
 | 1522 |  | 
 | 1523 |     def getexpected(self): | 
 | 1524 |         """Return set of test names we expect to skip on current platform. | 
 | 1525 |  | 
 | 1526 |         self.isvalid() must be true. | 
 | 1527 |         """ | 
 | 1528 |  | 
 | 1529 |         assert self.isvalid() | 
 | 1530 |         return self.expected | 
 | 1531 |  | 
| Michael Foord | 3ab34cc | 2010-12-03 12:27:40 +0000 | [diff] [blame] | 1532 | def _make_temp_dir_for_build(TEMPDIR): | 
 | 1533 |     # When tests are run from the Python build directory, it is best practice | 
 | 1534 |     # to keep the test files in a subfolder.  It eases the cleanup of leftover | 
 | 1535 |     # files using command "make distclean". | 
 | 1536 |     if sysconfig.is_python_build(): | 
 | 1537 |         TEMPDIR = os.path.join(sysconfig.get_config_var('srcdir'), 'build') | 
 | 1538 |         TEMPDIR = os.path.abspath(TEMPDIR) | 
| Antoine Pitrou | ee42934 | 2011-04-16 18:53:59 +0200 | [diff] [blame] | 1539 |         try: | 
| Michael Foord | 3ab34cc | 2010-12-03 12:27:40 +0000 | [diff] [blame] | 1540 |             os.mkdir(TEMPDIR) | 
| Antoine Pitrou | ee42934 | 2011-04-16 18:53:59 +0200 | [diff] [blame] | 1541 |         except OSError as e: | 
 | 1542 |             if e.errno != errno.EEXIST: | 
 | 1543 |                 raise | 
| Michael Foord | 3ab34cc | 2010-12-03 12:27:40 +0000 | [diff] [blame] | 1544 |  | 
 | 1545 |     # Define a writable temp dir that will be used as cwd while running | 
 | 1546 |     # the tests. The name of the dir includes the pid to allow parallel | 
 | 1547 |     # testing (see the -j option). | 
 | 1548 |     TESTCWD = 'test_python_{}'.format(os.getpid()) | 
 | 1549 |  | 
 | 1550 |     TESTCWD = os.path.join(TEMPDIR, TESTCWD) | 
 | 1551 |     return TEMPDIR, TESTCWD | 
| Nick Coghlan | 4c4c0f2 | 2010-12-03 07:44:33 +0000 | [diff] [blame] | 1552 |  | 
| Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 1553 | if __name__ == '__main__': | 
| Nick Coghlan | 4c4c0f2 | 2010-12-03 07:44:33 +0000 | [diff] [blame] | 1554 |     # Remove regrtest.py's own directory from the module search path. Despite | 
 | 1555 |     # the elimination of implicit relative imports, this is still needed to | 
 | 1556 |     # ensure that submodules of the test package do not inappropriately appear | 
 | 1557 |     # as top-level modules even when people (or buildbots!) invoke regrtest.py | 
 | 1558 |     # directly instead of using the -m switch | 
 | 1559 |     mydir = os.path.abspath(os.path.normpath(os.path.dirname(sys.argv[0]))) | 
 | 1560 |     i = len(sys.path) | 
 | 1561 |     while i >= 0: | 
 | 1562 |         i -= 1 | 
 | 1563 |         if os.path.abspath(os.path.normpath(sys.path[i])) == mydir: | 
 | 1564 |             del sys.path[i] | 
 | 1565 |  | 
| Florent Xicluna | dc69e72 | 2010-09-13 16:35:02 +0000 | [diff] [blame] | 1566 |     # findtestdir() gets the dirname out of __file__, so we have to make it | 
 | 1567 |     # absolute before changing the working directory. | 
 | 1568 |     # For example __file__ may be relative when running trace or profile. | 
 | 1569 |     # See issue #9323. | 
 | 1570 |     __file__ = os.path.abspath(__file__) | 
 | 1571 |  | 
 | 1572 |     # sanity check | 
| Florent Xicluna | da7bfd5 | 2010-03-06 11:43:55 +0000 | [diff] [blame] | 1573 |     assert __file__ == os.path.abspath(sys.argv[0]) | 
| Ezio Melotti | 184bdfb | 2010-02-18 09:37:05 +0000 | [diff] [blame] | 1574 |  | 
| Michael Foord | 3ab34cc | 2010-12-03 12:27:40 +0000 | [diff] [blame] | 1575 |     TEMPDIR, TESTCWD = _make_temp_dir_for_build(TEMPDIR) | 
| Ezio Melotti | 184bdfb | 2010-02-18 09:37:05 +0000 | [diff] [blame] | 1576 |  | 
 | 1577 |     # Run the tests in a context manager that temporary changes the CWD to a | 
 | 1578 |     # temporary and writable directory. If it's not possible to create or | 
 | 1579 |     # change the CWD, the original CWD will be used. The original CWD is | 
 | 1580 |     # available from support.SAVEDCWD. | 
 | 1581 |     with support.temp_cwd(TESTCWD, quiet=True): | 
 | 1582 |         main() |