Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 1 | #! /usr/bin/env python |
| 2 | |
| 3 | """Regression test. |
| 4 | |
| 5 | This will find all modules whose name is "test_*" in the test |
| 6 | directory, and run them. Various command line options provide |
| 7 | additional facilities. |
| 8 | |
| 9 | Command line options: |
| 10 | |
Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 11 | -v: verbose -- run tests in verbose mode with output to stdout |
Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 12 | -w: verbose2 -- re-run failed tests in verbose mode |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 13 | -d: debug -- print traceback for failed tests |
Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 14 | -q: quiet -- don't print anything except if a test fails |
Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 15 | -x: exclude -- arguments are tests to *exclude* |
| 16 | -s: single -- run only a single test (see below) |
Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 17 | -S: slow -- print the slowest 10 tests |
Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 18 | -r: random -- randomize test execution order |
| 19 | -f: fromfile -- read names of tests to run from a file (see below) |
| 20 | -l: findleaks -- if GC is available detect tests that leak memory |
| 21 | -u: use -- specify which special resource intensive tests to run |
| 22 | -h: help -- print this text and exit |
| 23 | -t: threshold -- call gc.set_threshold(N) |
| 24 | -T: coverage -- turn on code coverage using the trace module |
Walter Dörwald | aee4da6 | 2004-11-12 18:51:27 +0000 | [diff] [blame] | 25 | -D: coverdir -- Directory where coverage files are put |
| 26 | -N: nocoverdir -- Put coverage files alongside modules |
Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 27 | -L: runleaks -- run the leaks(1) command just before exit |
| 28 | -R: huntrleaks -- search for reference leaks (needs debug build, v. slow) |
Thomas Wouters | 477c8d5 | 2006-05-27 19:21:47 +0000 | [diff] [blame] | 29 | -M: memlimit -- run very large memory-consuming tests |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 30 | -n: nowindows -- suppress error message boxes on Windows |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 31 | -j: multiprocess -- run several processes at once |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 32 | |
| 33 | If non-option arguments are present, they are names for tests to run, |
| 34 | unless -x is given, in which case they are names for tests not to run. |
| 35 | If no test names are given, all tests are run. |
Guido van Rossum | f58ed25 | 1997-03-07 21:04:33 +0000 | [diff] [blame] | 36 | |
Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 37 | -r randomizes test execution order. You can use --randseed=int to provide a |
| 38 | int seed value for the randomizer; this is useful for reproducing troublesome |
| 39 | test orders. |
| 40 | |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 41 | -T turns on code coverage tracing with the trace module. |
| 42 | |
Walter Dörwald | aee4da6 | 2004-11-12 18:51:27 +0000 | [diff] [blame] | 43 | -D specifies the directory where coverage files are put. |
| 44 | |
| 45 | -N Put coverage files alongside modules. |
| 46 | |
Guido van Rossum | 9e9d4f8 | 2002-06-07 15:17:03 +0000 | [diff] [blame] | 47 | -s means to run only a single test and exit. This is useful when |
| 48 | doing memory analysis on the Python interpreter (which tend to consume |
| 49 | too many resources to run the full regression test non-stop). The |
| 50 | file /tmp/pynexttest is read to find the next test to run. If this |
| 51 | file is missing, the first test_*.py file in testdir or on the command |
| 52 | line is used. (actually tempfile.gettempdir() is used instead of |
| 53 | /tmp). |
Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 54 | |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 55 | -S is used to continue running tests after an aborted run. It will |
| 56 | maintain the order a standard run (ie, this assumes -r is not used). |
| 57 | This is useful after the tests have prematurely stopped for some external |
| 58 | reason and you want to start running from where you left off rather |
| 59 | than starting from the beginning. |
| 60 | |
Guido van Rossum | 9e9d4f8 | 2002-06-07 15:17:03 +0000 | [diff] [blame] | 61 | -f reads the names of tests from the file given as f's argument, one |
| 62 | or more test names per line. Whitespace is ignored. Blank lines and |
| 63 | lines beginning with '#' are ignored. This is especially useful for |
| 64 | whittling down failures involving interactions among tests. |
Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 65 | |
Skip Montanaro | 0179a18 | 2004-06-06 15:53:18 +0000 | [diff] [blame] | 66 | -L causes the leaks(1) command to be run just before exit if it exists. |
| 67 | leaks(1) is available on Mac OS X and presumably on some other |
| 68 | FreeBSD-derived systems. |
| 69 | |
Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 70 | -R runs each test several times and examines sys.gettotalrefcount() to |
| 71 | see if the test appears to be leaking references. The argument should |
| 72 | be of the form stab:run:fname where 'stab' is the number of times the |
| 73 | test is run to let gettotalrefcount settle down, 'run' is the number |
| 74 | of times further it is run and 'fname' is the name of the file the |
| 75 | reports are written to. These parameters all have defaults (5, 4 and |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 76 | "reflog.txt" respectively), and the minimal invocation is '-R :'. |
Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 77 | |
Thomas Wouters | 477c8d5 | 2006-05-27 19:21:47 +0000 | [diff] [blame] | 78 | -M runs tests that require an exorbitant amount of memory. These tests |
| 79 | typically try to ascertain containers keep working when containing more than |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 80 | 2 billion objects, which only works on 64-bit systems. There are also some |
| 81 | tests that try to exhaust the address space of the process, which only makes |
| 82 | 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] | 83 | which is a string in the form of '2.5Gb', determines howmuch memory the |
| 84 | tests will limit themselves to (but they may go slightly over.) The number |
| 85 | shouldn't be more memory than the machine has (including swap memory). You |
| 86 | should also keep in mind that swap memory is generally much, much slower |
| 87 | than RAM, and setting memlimit to all available RAM or higher will heavily |
| 88 | tax the machine. On the other hand, it is no use running these tests with a |
| 89 | limit of less than 2.5Gb, and many require more than 20Gb. Tests that expect |
| 90 | to use more than memlimit memory will be skipped. The big-memory tests |
| 91 | generally run very, very long. |
| 92 | |
Guido van Rossum | 9e9d4f8 | 2002-06-07 15:17:03 +0000 | [diff] [blame] | 93 | -u is used to specify which special resource intensive tests to run, |
| 94 | such as those requiring large file support or network connectivity. |
| 95 | The argument is a comma-separated list of words indicating the |
| 96 | resources to test. Currently only the following are defined: |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 97 | |
Fred Drake | 3a15dac | 2002-04-11 16:39:16 +0000 | [diff] [blame] | 98 | all - Enable all special resources. |
| 99 | |
Guido van Rossum | 315aa36 | 2003-03-11 14:46:48 +0000 | [diff] [blame] | 100 | audio - Tests that use the audio device. (There are known |
| 101 | cases of broken audio drivers that can crash Python or |
| 102 | even the Linux kernel.) |
| 103 | |
Andrew M. Kuchling | 2158df0 | 2001-10-22 15:26:09 +0000 | [diff] [blame] | 104 | curses - Tests that use curses and will modify the terminal's |
| 105 | state and output modes. |
Tim Peters | 1633a2e | 2001-10-30 05:56:40 +0000 | [diff] [blame] | 106 | |
Georg Brandl | 86b2fb9 | 2008-07-16 03:43:04 +0000 | [diff] [blame] | 107 | lib2to3 - Run the tests for 2to3 (They take a while.) |
| 108 | |
Guido van Rossum | 9e9d4f8 | 2002-06-07 15:17:03 +0000 | [diff] [blame] | 109 | largefile - It is okay to run some test that may create huge |
| 110 | files. These tests can take a long time and may |
| 111 | consume >2GB of disk space temporarily. |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 112 | |
Guido van Rossum | 9e9d4f8 | 2002-06-07 15:17:03 +0000 | [diff] [blame] | 113 | network - It is okay to run tests that use external network |
| 114 | resource, e.g. testing SSL support for sockets. |
Martin v. Löwis | 1c6b1a2 | 2002-11-19 17:47:07 +0000 | [diff] [blame] | 115 | |
Raymond Hettinger | 7c85fa4 | 2004-07-01 11:01:35 +0000 | [diff] [blame] | 116 | decimal - Test the decimal module against a large suite that |
| 117 | verifies compliance with standards. |
| 118 | |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 119 | compiler - Allow test_tokenize to verify round-trip lexing on |
| 120 | every file in the test library. |
Jeremy Hylton | 4336eda | 2004-08-07 19:25:33 +0000 | [diff] [blame] | 121 | |
Tim Peters | eba28be | 2005-03-28 01:08:02 +0000 | [diff] [blame] | 122 | subprocess Run all tests for the subprocess module. |
Peter Astrand | f7f1bb7 | 2005-03-03 20:47:37 +0000 | [diff] [blame] | 123 | |
Hye-Shik Chang | aaa2f1d | 2005-12-10 17:44:27 +0000 | [diff] [blame] | 124 | urlfetch - It is okay to download files required on testing. |
| 125 | |
Guilherme Polo | 9de29af | 2009-01-28 20:40:48 +0000 | [diff] [blame] | 126 | gui - Run tests that require a running GUI. |
| 127 | |
Fred Drake | 4dd0f7e | 2002-11-26 21:44:56 +0000 | [diff] [blame] | 128 | To enable all resources except one, use '-uall,-<resource>'. For |
Georg Brandl | 1158a33 | 2009-06-04 09:30:30 +0000 | [diff] [blame] | 129 | example, to run all the tests except for the gui tests, give the |
| 130 | option '-uall,-gui'. |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 131 | """ |
| 132 | |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 133 | import getopt |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 134 | import json |
Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 135 | import os |
Skip Montanaro | ab1c791 | 2000-06-30 16:39:27 +0000 | [diff] [blame] | 136 | import random |
Thomas Wouters | 9ada3d6 | 2006-04-21 09:47:09 +0000 | [diff] [blame] | 137 | import re |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 138 | import io |
Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 139 | import sys |
| 140 | import time |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 141 | import traceback |
Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 142 | import warnings |
Benjamin Peterson | e549ead | 2009-03-28 21:42:05 +0000 | [diff] [blame] | 143 | import unittest |
Christian Heimes | be5b30b | 2008-03-03 19:18:51 +0000 | [diff] [blame] | 144 | from inspect import isabstract |
Guido van Rossum | dc15c27 | 2002-08-12 21:55:51 +0000 | [diff] [blame] | 145 | |
| 146 | # I see no other way to suppress these warnings; |
| 147 | # putting them in test_grammar.py has no effect: |
Guido van Rossum | 88b1def | 2002-08-14 17:54:48 +0000 | [diff] [blame] | 148 | warnings.filterwarnings("ignore", "hex/oct constants", FutureWarning, |
Guido van Rossum | dc15c27 | 2002-08-12 21:55:51 +0000 | [diff] [blame] | 149 | ".*test.test_grammar$") |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 150 | if sys.maxsize > 0x7fffffff: |
Guido van Rossum | c34c4fc | 2002-09-19 00:42:16 +0000 | [diff] [blame] | 151 | # Also suppress them in <string>, because for 64-bit platforms, |
| 152 | # that's where test_grammar.py hides them. |
| 153 | warnings.filterwarnings("ignore", "hex/oct constants", FutureWarning, |
| 154 | "<string>") |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 155 | |
Thomas Wouters | 477c8d5 | 2006-05-27 19:21:47 +0000 | [diff] [blame] | 156 | # Ignore ImportWarnings that only occur in the source tree, |
| 157 | # (because of modules with the same name as source-directories in Modules/) |
| 158 | for mod in ("ctypes", "gzip", "zipfile", "tarfile", "encodings.zlib_codec", |
| 159 | "test.test_zipimport", "test.test_zlib", "test.test_zipfile", |
| 160 | "test.test_codecs", "test.string_tests"): |
| 161 | warnings.filterwarnings(module=".*%s$" % (mod,), |
| 162 | action="ignore", category=ImportWarning) |
| 163 | |
Guido van Rossum | bb48465 | 2002-12-02 09:56:21 +0000 | [diff] [blame] | 164 | # MacOSX (a.k.a. Darwin) has a default stack size that is too small |
| 165 | # for deeply recursive regular expressions. We see this as crashes in |
| 166 | # the Python test suite when running test_re.py and test_sre.py. The |
| 167 | # fix is to set the stack limit to 2048. |
| 168 | # This approach may also be useful for other Unixy platforms that |
| 169 | # suffer from small default stack limits. |
| 170 | if sys.platform == 'darwin': |
| 171 | try: |
| 172 | import resource |
| 173 | except ImportError: |
| 174 | pass |
| 175 | else: |
| 176 | soft, hard = resource.getrlimit(resource.RLIMIT_STACK) |
| 177 | newsoft = min(hard, max(soft, 1024*2048)) |
| 178 | resource.setrlimit(resource.RLIMIT_STACK, (newsoft, hard)) |
| 179 | |
Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 180 | from test import support |
Fred Drake | 3a15dac | 2002-04-11 16:39:16 +0000 | [diff] [blame] | 181 | |
Georg Brandl | 1158a33 | 2009-06-04 09:30:30 +0000 | [diff] [blame] | 182 | RESOURCE_NAMES = ('audio', 'curses', 'largefile', 'network', |
Guilherme Polo | 9de29af | 2009-01-28 20:40:48 +0000 | [diff] [blame] | 183 | 'decimal', 'compiler', 'subprocess', 'urlfetch', 'gui') |
Fred Drake | 3a15dac | 2002-04-11 16:39:16 +0000 | [diff] [blame] | 184 | |
| 185 | |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 186 | def usage(msg): |
| 187 | print(msg, file=sys.stderr) |
| 188 | print("Use --help for usage", file=sys.stderr) |
| 189 | sys.exit(2) |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 190 | |
| 191 | |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 192 | def main(tests=None, testdir=None, verbose=0, quiet=False, |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 193 | exclude=False, single=False, randomize=False, fromfile=None, |
Walter Dörwald | aee4da6 | 2004-11-12 18:51:27 +0000 | [diff] [blame] | 194 | findleaks=False, use_resources=None, trace=False, coverdir='coverage', |
Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 195 | runleaks=False, huntrleaks=False, verbose2=False, print_slow=False, |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 196 | random_seed=None, use_mp=None): |
Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 197 | """Execute a test suite. |
| 198 | |
Thomas Wouters | 7e47402 | 2000-07-16 12:04:32 +0000 | [diff] [blame] | 199 | This also parses command-line options and modifies its behavior |
Fred Drake | 004d5e6 | 2000-10-23 17:22:08 +0000 | [diff] [blame] | 200 | accordingly. |
Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 201 | |
| 202 | tests -- a list of strings containing test names (optional) |
| 203 | testdir -- the directory in which to look for tests (optional) |
| 204 | |
| 205 | Users other than the Python test suite will certainly want to |
| 206 | specify testdir; if it's omitted, the directory containing the |
Fred Drake | 004d5e6 | 2000-10-23 17:22:08 +0000 | [diff] [blame] | 207 | Python test suite is searched for. |
Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 208 | |
| 209 | If the tests argument is omitted, the tests listed on the |
| 210 | command-line will be used. If that's empty, too, then all *.py |
| 211 | files beginning with test_ will be used. |
Skip Montanaro | ab1c791 | 2000-06-30 16:39:27 +0000 | [diff] [blame] | 212 | |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 213 | The other default arguments (verbose, quiet, exclude, |
Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 214 | single, randomize, findleaks, use_resources, trace, coverdir, |
| 215 | print_slow, and random_seed) allow programmers calling main() |
| 216 | directly to set the values that would normally be set by flags |
| 217 | on the command line. |
Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 218 | """ |
Fred Drake | 004d5e6 | 2000-10-23 17:22:08 +0000 | [diff] [blame] | 219 | |
Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 220 | support.record_original_stdout(sys.stdout) |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 221 | try: |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 222 | opts, args = getopt.getopt(sys.argv[1:], 'hvqxsSrf:lu:t:TD:NLR:wM:nj:', |
Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 223 | ['help', 'verbose', 'quiet', 'exclude', |
| 224 | 'single', 'slow', 'random', 'fromfile', |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 225 | 'findleaks', 'use=', 'threshold=', 'trace', |
Walter Dörwald | aee4da6 | 2004-11-12 18:51:27 +0000 | [diff] [blame] | 226 | 'coverdir=', 'nocoverdir', 'runleaks', |
Thomas Wouters | 477c8d5 | 2006-05-27 19:21:47 +0000 | [diff] [blame] | 227 | 'huntrleaks=', 'verbose2', 'memlimit=', |
Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 228 | 'debug', 'start=', 'nowindows', |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 229 | 'randseed=', 'multiprocess=', 'slaveargs=', |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 230 | ]) |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 231 | except getopt.error as msg: |
| 232 | usage(msg) |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 233 | |
| 234 | # Defaults |
Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 235 | if random_seed is None: |
| 236 | random_seed = random.randrange(10000000) |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 237 | if use_resources is None: |
| 238 | use_resources = [] |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 239 | debug = False |
| 240 | start = None |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 241 | for o, a in opts: |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 242 | if o in ('-h', '--help'): |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 243 | print(__doc__) |
| 244 | return |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 245 | elif o in ('-v', '--verbose'): |
| 246 | verbose += 1 |
Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 247 | elif o in ('-w', '--verbose2'): |
| 248 | verbose2 = True |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 249 | elif o in ('-d', '--debug'): |
| 250 | debug = True |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 251 | elif o in ('-q', '--quiet'): |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 252 | quiet = True; |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 253 | verbose = 0 |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 254 | elif o in ('-x', '--exclude'): |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 255 | exclude = True |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 256 | elif o in ('-S', '--start'): |
| 257 | start = a |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 258 | elif o in ('-s', '--single'): |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 259 | single = True |
Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 260 | elif o in ('-S', '--slow'): |
| 261 | print_slow = True |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 262 | elif o in ('-r', '--randomize'): |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 263 | randomize = True |
Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 264 | elif o == '--randseed': |
| 265 | random_seed = int(a) |
Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 266 | elif o in ('-f', '--fromfile'): |
| 267 | fromfile = a |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 268 | elif o in ('-l', '--findleaks'): |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 269 | findleaks = True |
Skip Montanaro | 0179a18 | 2004-06-06 15:53:18 +0000 | [diff] [blame] | 270 | elif o in ('-L', '--runleaks'): |
| 271 | runleaks = True |
Guido van Rossum | 9e9d4f8 | 2002-06-07 15:17:03 +0000 | [diff] [blame] | 272 | elif o in ('-t', '--threshold'): |
| 273 | import gc |
| 274 | gc.set_threshold(int(a)) |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 275 | elif o in ('-T', '--coverage'): |
| 276 | trace = True |
Walter Dörwald | aee4da6 | 2004-11-12 18:51:27 +0000 | [diff] [blame] | 277 | elif o in ('-D', '--coverdir'): |
| 278 | coverdir = os.path.join(os.getcwd(), a) |
| 279 | elif o in ('-N', '--nocoverdir'): |
| 280 | coverdir = None |
Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 281 | elif o in ('-R', '--huntrleaks'): |
| 282 | huntrleaks = a.split(':') |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 283 | if len(huntrleaks) not in (2, 3): |
| 284 | print(a, huntrleaks) |
| 285 | usage('-R takes 2 or 3 colon-separated arguments') |
| 286 | if not huntrleaks[0]: |
Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 287 | huntrleaks[0] = 5 |
| 288 | else: |
| 289 | huntrleaks[0] = int(huntrleaks[0]) |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 290 | if not huntrleaks[1]: |
Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 291 | huntrleaks[1] = 4 |
| 292 | else: |
| 293 | huntrleaks[1] = int(huntrleaks[1]) |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 294 | if len(huntrleaks) == 2 or not huntrleaks[2]: |
| 295 | huntrleaks[2:] = ["reflog.txt"] |
| 296 | # Avoid false positives due to the character cache in |
| 297 | # stringobject.c filling slowly with random data |
| 298 | warm_char_cache() |
Thomas Wouters | 477c8d5 | 2006-05-27 19:21:47 +0000 | [diff] [blame] | 299 | elif o in ('-M', '--memlimit'): |
Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 300 | support.set_memlimit(a) |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 301 | elif o in ('-u', '--use'): |
Guido van Rossum | fe3f696 | 2001-09-06 16:09:41 +0000 | [diff] [blame] | 302 | u = [x.lower() for x in a.split(',')] |
| 303 | for r in u: |
Fred Drake | 3a15dac | 2002-04-11 16:39:16 +0000 | [diff] [blame] | 304 | if r == 'all': |
Fred Drake | 4dd0f7e | 2002-11-26 21:44:56 +0000 | [diff] [blame] | 305 | use_resources[:] = RESOURCE_NAMES |
| 306 | continue |
| 307 | remove = False |
| 308 | if r[0] == '-': |
| 309 | remove = True |
| 310 | r = r[1:] |
Fred Drake | 3a15dac | 2002-04-11 16:39:16 +0000 | [diff] [blame] | 311 | if r not in RESOURCE_NAMES: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 312 | usage('Invalid -u/--use option: ' + a) |
Fred Drake | 4dd0f7e | 2002-11-26 21:44:56 +0000 | [diff] [blame] | 313 | if remove: |
| 314 | if r in use_resources: |
| 315 | use_resources.remove(r) |
| 316 | elif r not in use_resources: |
Andrew MacIntyre | e41abab | 2002-04-30 12:11:04 +0000 | [diff] [blame] | 317 | use_resources.append(r) |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 318 | elif o in ('-n', '--nowindows'): |
| 319 | import msvcrt |
| 320 | msvcrt.SetErrorMode(msvcrt.SEM_FAILCRITICALERRORS| |
| 321 | msvcrt.SEM_NOALIGNMENTFAULTEXCEPT| |
| 322 | msvcrt.SEM_NOGPFAULTERRORBOX| |
| 323 | msvcrt.SEM_NOOPENFILEERRORBOX) |
| 324 | try: |
| 325 | msvcrt.CrtSetReportMode |
| 326 | except AttributeError: |
| 327 | # release build |
| 328 | pass |
| 329 | else: |
| 330 | for m in [msvcrt.CRT_WARN, msvcrt.CRT_ERROR, msvcrt.CRT_ASSERT]: |
| 331 | msvcrt.CrtSetReportMode(m, msvcrt.CRTDBG_MODE_FILE) |
| 332 | msvcrt.CrtSetReportFile(m, msvcrt.CRTDBG_FILE_STDERR) |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 333 | elif o in ('-j', '--multiprocess'): |
| 334 | use_mp = int(a) |
| 335 | elif o == '--slaveargs': |
| 336 | args, kwargs = json.loads(a) |
| 337 | try: |
| 338 | result = runtest(*args, **kwargs) |
| 339 | except BaseException as e: |
| 340 | result = -3, e.__class__.__name__ |
| 341 | sys.stdout.flush() |
| 342 | print() # Force a newline (just in case) |
| 343 | print(json.dumps(result)) |
| 344 | sys.exit(0) |
Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 345 | if single and fromfile: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 346 | usage("-s and -f don't go together!") |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 347 | if use_mp and trace: |
| 348 | usage(2, "-T and -j don't go together!") |
| 349 | if use_mp and findleaks: |
| 350 | usage(2, "-l and -j don't go together!") |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 351 | |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 352 | good = [] |
| 353 | bad = [] |
| 354 | skipped = [] |
Fred Drake | 9a0db07 | 2003-02-03 15:19:30 +0000 | [diff] [blame] | 355 | resource_denieds = [] |
Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 356 | |
Neil Schemenauer | d569f23 | 2000-09-22 15:29:28 +0000 | [diff] [blame] | 357 | if findleaks: |
Barry Warsaw | a873b03 | 2000-08-03 15:50:37 +0000 | [diff] [blame] | 358 | try: |
| 359 | import gc |
| 360 | except ImportError: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 361 | print('No GC available, disabling findleaks.') |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 362 | findleaks = False |
Barry Warsaw | a873b03 | 2000-08-03 15:50:37 +0000 | [diff] [blame] | 363 | else: |
Neil Schemenauer | 8a00abc | 2000-10-13 01:32:42 +0000 | [diff] [blame] | 364 | # Uncomment the line below to report garbage that is not |
| 365 | # freeable by reference counting alone. By default only |
| 366 | # garbage that is not collectable by the GC is reported. |
| 367 | #gc.set_debug(gc.DEBUG_SAVEALL) |
Neil Schemenauer | d569f23 | 2000-09-22 15:29:28 +0000 | [diff] [blame] | 368 | found_garbage = [] |
Barry Warsaw | a873b03 | 2000-08-03 15:50:37 +0000 | [diff] [blame] | 369 | |
Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 370 | if single: |
| 371 | from tempfile import gettempdir |
| 372 | filename = os.path.join(gettempdir(), 'pynexttest') |
| 373 | try: |
| 374 | fp = open(filename, 'r') |
Eric S. Raymond | fc170b1 | 2001-02-09 11:51:27 +0000 | [diff] [blame] | 375 | next = fp.read().strip() |
Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 376 | tests = [next] |
| 377 | fp.close() |
| 378 | except IOError: |
| 379 | pass |
Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 380 | |
| 381 | if fromfile: |
| 382 | tests = [] |
| 383 | fp = open(fromfile) |
| 384 | for line in fp: |
| 385 | guts = line.split() # assuming no test has whitespace in its name |
| 386 | if guts and not guts[0].startswith('#'): |
| 387 | tests.extend(guts) |
| 388 | fp.close() |
| 389 | |
| 390 | # Strip .py extensions. |
| 391 | if args: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 392 | args = list(map(removepy, args)) |
Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 393 | if tests: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 394 | tests = list(map(removepy, tests)) |
Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 395 | |
Guido van Rossum | 6c74fea | 1998-08-25 12:29:08 +0000 | [diff] [blame] | 396 | stdtests = STDTESTS[:] |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 397 | nottests = NOTTESTS.copy() |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 398 | if exclude: |
Guido van Rossum | 6c74fea | 1998-08-25 12:29:08 +0000 | [diff] [blame] | 399 | for arg in args: |
| 400 | if arg in stdtests: |
| 401 | stdtests.remove(arg) |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 402 | nottests.add(arg) |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 403 | args = [] |
Guido van Rossum | 747e1ca | 1998-08-24 13:48:36 +0000 | [diff] [blame] | 404 | tests = tests or args or findtests(testdir, stdtests, nottests) |
Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 405 | if single: |
| 406 | tests = tests[:1] |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 407 | # Remove all the tests that precede start if it's set. |
| 408 | if start: |
| 409 | try: |
| 410 | del tests[:tests.index(start)] |
| 411 | except ValueError: |
| 412 | print("Couldn't find starting test (%s), using all tests" % start) |
Skip Montanaro | ab1c791 | 2000-06-30 16:39:27 +0000 | [diff] [blame] | 413 | if randomize: |
Collin Winter | fd12f49 | 2009-03-29 04:05:05 +0000 | [diff] [blame] | 414 | random.seed(random_seed) |
| 415 | print("Using random seed", random_seed) |
Skip Montanaro | ab1c791 | 2000-06-30 16:39:27 +0000 | [diff] [blame] | 416 | random.shuffle(tests) |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 417 | if trace: |
Georg Brandl | 33c2881 | 2009-04-01 23:07:29 +0000 | [diff] [blame] | 418 | import trace, tempfile |
| 419 | tracer = trace.Trace(ignoredirs=[sys.prefix, sys.exec_prefix, |
| 420 | tempfile.gettempdir()], |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 421 | trace=False, count=True) |
Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 422 | test_times = [] |
Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 423 | support.verbose = verbose # Tell tests to be moderately quiet |
| 424 | support.use_resources = use_resources |
Guido van Rossum | 5796d26 | 2000-04-21 21:35:06 +0000 | [diff] [blame] | 425 | save_modules = sys.modules.keys() |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 426 | |
| 427 | def accumulate_result(test, result): |
| 428 | ok, test_time = result |
| 429 | test_times.append((test_time, test)) |
| 430 | if ok > 0: |
| 431 | good.append(test) |
| 432 | elif ok == 0: |
| 433 | bad.append(test) |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 434 | else: |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 435 | skipped.append(test) |
| 436 | if ok == -2: |
| 437 | resource_denieds.append(test) |
| 438 | |
| 439 | if use_mp: |
| 440 | from threading import Thread, Lock |
| 441 | from queue import Queue, Empty |
| 442 | from subprocess import Popen, PIPE, STDOUT |
| 443 | from collections import deque |
| 444 | # TextIOWrapper is not entirely thread-safe now, |
| 445 | # it can produce duplicate output when printing from several threads. |
| 446 | print_lock = Lock() |
| 447 | debug_output_pat = re.compile(r"\[\d+ refs\]$") |
| 448 | pending = deque() |
| 449 | output = Queue() |
| 450 | for test in tests: |
| 451 | args_tuple = ( |
| 452 | (test, verbose, quiet, testdir), |
| 453 | dict(huntrleaks=huntrleaks, use_resources=use_resources, |
| 454 | debug=debug) |
| 455 | ) |
| 456 | pending.append((test, args_tuple)) |
| 457 | def work(): |
| 458 | # A worker thread. |
Neal Norwitz | 14ca327 | 2006-02-28 18:05:43 +0000 | [diff] [blame] | 459 | try: |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 460 | while True: |
| 461 | try: |
| 462 | test, args_tuple = pending.popleft() |
| 463 | except IndexError: |
| 464 | output.put((None, None, None)) |
| 465 | return |
| 466 | if not quiet: |
| 467 | with print_lock: |
| 468 | print(test) |
| 469 | sys.stdout.flush() |
| 470 | # -E is needed by some tests, e.g. test_import |
| 471 | popen = Popen([sys.executable, '-E', '-m', 'test.regrtest', |
| 472 | '--slaveargs', json.dumps(args_tuple)], |
| 473 | stdout=PIPE, stderr=STDOUT, |
| 474 | universal_newlines=True, close_fds=True) |
| 475 | out = popen.communicate()[0].strip() |
| 476 | out = debug_output_pat.sub("", out) |
| 477 | out, _, result = out.strip().rpartition("\n") |
| 478 | result = json.loads(result) |
| 479 | output.put((test, out.strip(), result)) |
| 480 | except BaseException: |
| 481 | output.put((None, None, None)) |
Neal Norwitz | 14ca327 | 2006-02-28 18:05:43 +0000 | [diff] [blame] | 482 | raise |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 483 | workers = [Thread(target=work) for i in range(use_mp)] |
| 484 | for worker in workers: |
| 485 | worker.start() |
| 486 | finished = 0 |
| 487 | while finished < use_mp: |
| 488 | test, out, result = output.get() |
| 489 | if out: |
| 490 | with print_lock: |
| 491 | print(out) |
| 492 | sys.stdout.flush() |
| 493 | if test is None: |
| 494 | finished += 1 |
| 495 | continue |
| 496 | if result[0] == -3: |
| 497 | assert result[1] == 'KeyboardInterrupt' |
| 498 | pending.clear() |
| 499 | raise KeyboardInterrupt # What else? |
| 500 | accumulate_result(test, result) |
| 501 | for worker in workers: |
| 502 | worker.join() |
| 503 | else: |
| 504 | for test in tests: |
| 505 | if not quiet: |
| 506 | print(test) |
| 507 | sys.stdout.flush() |
| 508 | if trace: |
| 509 | # If we're tracing code coverage, then we don't exit with status |
| 510 | # if on a false return value from main. |
| 511 | tracer.runctx('runtest(test, verbose, quiet, testdir)', |
| 512 | globals=globals(), locals=vars()) |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 513 | else: |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 514 | try: |
| 515 | result = runtest(test, verbose, quiet, |
| 516 | testdir, huntrleaks, debug) |
| 517 | accumulate_result(test, result) |
| 518 | except KeyboardInterrupt: |
| 519 | # print a newline separate from the ^C |
| 520 | print() |
| 521 | break |
| 522 | except: |
| 523 | raise |
| 524 | if findleaks: |
| 525 | gc.collect() |
| 526 | if gc.garbage: |
| 527 | print("Warning: test created", len(gc.garbage), end=' ') |
| 528 | print("uncollectable object(s).") |
| 529 | # move the uncollectable objects somewhere so we don't see |
| 530 | # them again |
| 531 | found_garbage.extend(gc.garbage) |
| 532 | del gc.garbage[:] |
| 533 | # Unload the newly imported modules (best effort finalization) |
| 534 | for module in sys.modules.keys(): |
| 535 | if module not in save_modules and module.startswith("test."): |
| 536 | support.unload(module) |
Jeremy Hylton | 7a1ea0e | 2001-10-17 13:45:28 +0000 | [diff] [blame] | 537 | |
| 538 | # The lists won't be sorted if running with -r |
| 539 | good.sort() |
| 540 | bad.sort() |
| 541 | skipped.sort() |
Tim Peters | e0c446b | 2001-10-18 21:57:37 +0000 | [diff] [blame] | 542 | |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 543 | if good and not quiet: |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 544 | if not bad and not skipped and len(good) > 1: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 545 | print("All", end=' ') |
| 546 | print(count(len(good), "test"), "OK.") |
| 547 | if verbose: |
| 548 | print("CAUTION: stdout isn't compared in verbose mode:") |
| 549 | print("a test that passes in verbose mode may fail without it.") |
Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 550 | if print_slow: |
| 551 | test_times.sort(reverse=True) |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 552 | print("10 slowest tests:") |
Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 553 | for time, test in test_times[:10]: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 554 | print("%s: %.1fs" % (test, time)) |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 555 | if bad: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 556 | print(count(len(bad), "test"), "failed:") |
Tim Peters | a45da92 | 2001-08-12 03:45:50 +0000 | [diff] [blame] | 557 | printlist(bad) |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 558 | if skipped and not quiet: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 559 | print(count(len(skipped), "test"), "skipped:") |
Tim Peters | a45da92 | 2001-08-12 03:45:50 +0000 | [diff] [blame] | 560 | printlist(skipped) |
Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 561 | |
Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 562 | e = _ExpectedSkips() |
Tim Peters | a2be2d6 | 2001-08-12 02:01:09 +0000 | [diff] [blame] | 563 | plat = sys.platform |
Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 564 | if e.isvalid(): |
Raymond Hettinger | a690a99 | 2003-11-16 16:17:49 +0000 | [diff] [blame] | 565 | surprise = set(skipped) - e.getexpected() - set(resource_denieds) |
Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 566 | if surprise: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 567 | print(count(len(surprise), "skip"), \ |
| 568 | "unexpected on", plat + ":") |
Tim Peters | a45da92 | 2001-08-12 03:45:50 +0000 | [diff] [blame] | 569 | printlist(surprise) |
Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 570 | else: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 571 | print("Those skips are all expected on", plat + ".") |
Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 572 | else: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 573 | print("Ask someone to teach regrtest.py about which tests are") |
| 574 | print("expected to get skipped on", plat + ".") |
Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 575 | |
Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 576 | if verbose2 and bad: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 577 | print("Re-running failed tests in verbose mode") |
Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 578 | for test in bad: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 579 | print("Re-running test %r in verbose mode" % test) |
Tim Peters | 922dd7d | 2006-03-10 23:37:10 +0000 | [diff] [blame] | 580 | sys.stdout.flush() |
Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 581 | try: |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 582 | verbose = True |
| 583 | ok = runtest(test, True, quiet, testdir, |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 584 | huntrleaks, debug) |
Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 585 | except KeyboardInterrupt: |
| 586 | # print a newline separate from the ^C |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 587 | print() |
Martin v. Löwis | 04824ce | 2006-03-10 21:26:16 +0000 | [diff] [blame] | 588 | break |
| 589 | except: |
| 590 | raise |
| 591 | |
Barry Warsaw | e11e3de | 1999-01-28 19:51:51 +0000 | [diff] [blame] | 592 | if single: |
| 593 | alltests = findtests(testdir, stdtests, nottests) |
| 594 | for i in range(len(alltests)): |
| 595 | if tests[0] == alltests[i]: |
| 596 | if i == len(alltests) - 1: |
| 597 | os.unlink(filename) |
| 598 | else: |
| 599 | fp = open(filename, 'w') |
| 600 | fp.write(alltests[i+1] + '\n') |
| 601 | fp.close() |
| 602 | break |
| 603 | else: |
| 604 | os.unlink(filename) |
| 605 | |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 606 | if trace: |
| 607 | r = tracer.results() |
| 608 | r.write_results(show_missing=True, summary=True, coverdir=coverdir) |
| 609 | |
Skip Montanaro | 0179a18 | 2004-06-06 15:53:18 +0000 | [diff] [blame] | 610 | if runleaks: |
| 611 | os.system("leaks %d" % os.getpid()) |
| 612 | |
Tim Peters | 5943b4a | 2003-07-23 00:30:39 +0000 | [diff] [blame] | 613 | sys.exit(len(bad) > 0) |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 614 | |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 615 | |
Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 616 | STDTESTS = [ |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 617 | 'test_grammar', |
| 618 | 'test_opcodes', |
Guido van Rossum | d8faa36 | 2007-04-27 19:54:29 +0000 | [diff] [blame] | 619 | 'test_dict', |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 620 | 'test_builtin', |
| 621 | 'test_exceptions', |
| 622 | 'test_types', |
Collin Winter | 7afaa88 | 2007-03-08 19:54:43 +0000 | [diff] [blame] | 623 | 'test_unittest', |
| 624 | 'test_doctest', |
| 625 | 'test_doctest2', |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 626 | ] |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 627 | |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 628 | NOTTESTS = { |
Jeremy Hylton | 62e2c7e | 2001-02-28 17:48:06 +0000 | [diff] [blame] | 629 | 'test_future1', |
| 630 | 'test_future2', |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 631 | } |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 632 | |
Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 633 | def findtests(testdir=None, stdtests=STDTESTS, nottests=NOTTESTS): |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 634 | """Return a list of all applicable test modules.""" |
Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 635 | if not testdir: testdir = findtestdir() |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 636 | names = os.listdir(testdir) |
| 637 | tests = [] |
| 638 | for name in names: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 639 | if name[:5] == "test_" and name[-3:] == ".py": |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 640 | modname = name[:-3] |
| 641 | if modname not in stdtests and modname not in nottests: |
| 642 | tests.append(modname) |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 643 | tests.sort() |
| 644 | return stdtests + tests |
| 645 | |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 646 | def runtest(test, verbose, quiet, |
| 647 | testdir=None, huntrleaks=False, debug=False, use_resources=None): |
Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 648 | """Run a single test. |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 649 | |
Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 650 | test -- the name of the test |
Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 651 | verbose -- if true, print more messages |
Trent Mick | f29f47b | 2000-08-11 19:02:59 +0000 | [diff] [blame] | 652 | quiet -- if true, don't print 'skipped' messages (probably redundant) |
Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 653 | test_times -- a list of (time, test_name) pairs |
Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 654 | testdir -- test directory |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 655 | huntrleaks -- run multiple times to test for leaks; requires a debug |
| 656 | build; a triple corresponding to -R's three arguments |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 657 | debug -- if true, print tracebacks for failed tests regardless of |
| 658 | verbose setting |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 659 | Return: |
| 660 | -2 test skipped because resource denied |
| 661 | -1 test skipped for some other reason |
| 662 | 0 test failed |
| 663 | 1 test passed |
Guido van Rossum | 6fd83b7 | 1998-08-01 17:04:08 +0000 | [diff] [blame] | 664 | """ |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 665 | |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 666 | support.verbose = verbose # Tell tests to be moderately quiet |
| 667 | if use_resources is not None: |
| 668 | support.use_resources = use_resources |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 669 | try: |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 670 | return runtest_inner(test, verbose, quiet, |
| 671 | testdir, huntrleaks, debug) |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 672 | finally: |
| 673 | cleanup_test_droppings(test, verbose) |
| 674 | |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 675 | def runtest_inner(test, verbose, quiet, |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 676 | testdir=None, huntrleaks=False, debug=False): |
Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 677 | support.unload(test) |
Barry Warsaw | 3b6d025 | 2004-02-07 22:43:03 +0000 | [diff] [blame] | 678 | if not testdir: |
| 679 | testdir = findtestdir() |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 680 | |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 681 | test_time = 0.0 |
Collin Winter | a5503d5 | 2009-05-15 01:20:21 +0000 | [diff] [blame] | 682 | refleak = False # True if the test leaked references. |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 683 | try: |
Tim Peters | 342ca75 | 2001-09-25 19:13:20 +0000 | [diff] [blame] | 684 | save_stdout = sys.stdout |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 685 | try: |
Barry Warsaw | 408b6d3 | 2002-07-30 23:27:12 +0000 | [diff] [blame] | 686 | if test.startswith('test.'): |
| 687 | abstest = test |
| 688 | else: |
| 689 | # Always import it from the test package |
| 690 | abstest = 'test.' + test |
Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 691 | start_time = time.time() |
Barry Warsaw | 408b6d3 | 2002-07-30 23:27:12 +0000 | [diff] [blame] | 692 | the_package = __import__(abstest, globals(), locals(), []) |
| 693 | the_module = getattr(the_package, test) |
Guido van Rossum | 58da931 | 2007-11-10 23:39:45 +0000 | [diff] [blame] | 694 | # Old tests run to completion simply as a side-effect of |
| 695 | # being imported. For tests based on unittest or doctest, |
| 696 | # explicitly invoke their test_main() function (if it exists). |
Tim Peters | d974221 | 2001-05-22 18:28:25 +0000 | [diff] [blame] | 697 | indirect_test = getattr(the_module, "test_main", None) |
| 698 | if indirect_test is not None: |
| 699 | indirect_test() |
Michael W. Hudson | 61147f6 | 2004-08-03 11:33:28 +0000 | [diff] [blame] | 700 | if huntrleaks: |
Collin Winter | a5503d5 | 2009-05-15 01:20:21 +0000 | [diff] [blame] | 701 | refleak = dash_R(the_module, test, indirect_test, huntrleaks) |
Christian Heimes | b186d00 | 2008-03-18 15:15:01 +0000 | [diff] [blame] | 702 | test_time = time.time() - start_time |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 703 | finally: |
Tim Peters | 342ca75 | 2001-09-25 19:13:20 +0000 | [diff] [blame] | 704 | sys.stdout = save_stdout |
Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 705 | except support.ResourceDenied as msg: |
Fred Drake | 9a0db07 | 2003-02-03 15:19:30 +0000 | [diff] [blame] | 706 | if not quiet: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 707 | print(test, "skipped --", msg) |
Fred Drake | 9a0db07 | 2003-02-03 15:19:30 +0000 | [diff] [blame] | 708 | sys.stdout.flush() |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 709 | return -2, test_time |
R. David Murray | a21e4ca | 2009-03-31 23:16:50 +0000 | [diff] [blame] | 710 | except unittest.SkipTest as msg: |
Trent Mick | f29f47b | 2000-08-11 19:02:59 +0000 | [diff] [blame] | 711 | if not quiet: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 712 | print(test, "skipped --", msg) |
Guido van Rossum | 3cda93e | 2002-09-13 21:28:03 +0000 | [diff] [blame] | 713 | sys.stdout.flush() |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 714 | return -1, test_time |
Fred Drake | fe5c22a | 2000-08-18 16:04:05 +0000 | [diff] [blame] | 715 | except KeyboardInterrupt: |
| 716 | raise |
Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 717 | except support.TestFailed as msg: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 718 | print("test", test, "failed --", msg) |
Guido van Rossum | 3cda93e | 2002-09-13 21:28:03 +0000 | [diff] [blame] | 719 | sys.stdout.flush() |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 720 | return 0, test_time |
Guido van Rossum | 9e48b27 | 1997-07-16 01:56:13 +0000 | [diff] [blame] | 721 | except: |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 722 | type, value = sys.exc_info()[:2] |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 723 | print("test", test, "crashed --", str(type) + ":", value) |
Guido van Rossum | 3cda93e | 2002-09-13 21:28:03 +0000 | [diff] [blame] | 724 | sys.stdout.flush() |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 725 | if verbose or debug: |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 726 | traceback.print_exc(file=sys.stdout) |
Guido van Rossum | 3cda93e | 2002-09-13 21:28:03 +0000 | [diff] [blame] | 727 | sys.stdout.flush() |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 728 | return 0, test_time |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 729 | else: |
Collin Winter | a5503d5 | 2009-05-15 01:20:21 +0000 | [diff] [blame] | 730 | if refleak: |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 731 | return 0, test_time |
| 732 | return 1, test_time |
Guido van Rossum | 0fcca4e | 2001-09-21 20:31:52 +0000 | [diff] [blame] | 733 | |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 734 | def cleanup_test_droppings(testname, verbose): |
| 735 | import shutil |
Benjamin Peterson | 25c95f1 | 2009-05-08 20:42:26 +0000 | [diff] [blame] | 736 | import stat |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 737 | |
| 738 | # Try to clean up junk commonly left behind. While tests shouldn't leave |
| 739 | # any files or directories behind, when a test fails that can be tedious |
| 740 | # for it to arrange. The consequences can be especially nasty on Windows, |
| 741 | # since if a test leaves a file open, it cannot be deleted by name (while |
| 742 | # there's nothing we can do about that here either, we can display the |
| 743 | # name of the offending test, which is a real help). |
Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 744 | for name in (support.TESTFN, |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 745 | "db_home", |
| 746 | ): |
| 747 | if not os.path.exists(name): |
| 748 | continue |
| 749 | |
| 750 | if os.path.isdir(name): |
| 751 | kind, nuker = "directory", shutil.rmtree |
| 752 | elif os.path.isfile(name): |
| 753 | kind, nuker = "file", os.unlink |
| 754 | else: |
| 755 | raise SystemError("os.path says %r exists but is neither " |
| 756 | "directory nor file" % name) |
| 757 | |
| 758 | if verbose: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 759 | print("%r left behind %s %r" % (testname, kind, name)) |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 760 | try: |
Benjamin Peterson | 25c95f1 | 2009-05-08 20:42:26 +0000 | [diff] [blame] | 761 | # if we have chmod, fix possible permissions problems |
| 762 | # that might prevent cleanup |
| 763 | if (hasattr(os, 'chmod')): |
| 764 | os.chmod(name, stat.S_IRWXU | stat.S_IRWXG | stat.S_IRWXO) |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 765 | nuker(name) |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 766 | except Exception as msg: |
| 767 | print(("%r left behind %s %r and it couldn't be " |
| 768 | "removed: %s" % (testname, kind, name, msg)), file=sys.stderr) |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 769 | |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 770 | def dash_R(the_module, test, indirect_test, huntrleaks): |
Collin Winter | a5503d5 | 2009-05-15 01:20:21 +0000 | [diff] [blame] | 771 | """Run a test multiple times, looking for reference leaks. |
| 772 | |
| 773 | Returns: |
| 774 | False if the test didn't leak references; True if we detected refleaks. |
| 775 | """ |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 776 | # 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] | 777 | import copyreg, _abcoll |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 778 | |
| 779 | if not hasattr(sys, 'gettotalrefcount'): |
| 780 | raise Exception("Tracking reference leaks requires a debug build " |
| 781 | "of Python") |
| 782 | |
| 783 | # Save current values for dash_R_cleanup() to restore. |
| 784 | fs = warnings.filters[:] |
Alexandre Vassalotti | f7fa63d | 2008-05-11 08:55:36 +0000 | [diff] [blame] | 785 | ps = copyreg.dispatch_table.copy() |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 786 | pic = sys.path_importer_cache.copy() |
Christian Heimes | 9385266 | 2007-12-01 12:22:32 +0000 | [diff] [blame] | 787 | abcs = {} |
| 788 | for abc in [getattr(_abcoll, a) for a in _abcoll.__all__]: |
Christian Heimes | be5b30b | 2008-03-03 19:18:51 +0000 | [diff] [blame] | 789 | if not isabstract(abc): |
Christian Heimes | 9385266 | 2007-12-01 12:22:32 +0000 | [diff] [blame] | 790 | continue |
| 791 | for obj in abc.__subclasses__() + [abc]: |
| 792 | abcs[obj] = obj._abc_registry.copy() |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 793 | |
| 794 | if indirect_test: |
| 795 | def run_the_test(): |
| 796 | indirect_test() |
| 797 | else: |
| 798 | def run_the_test(): |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 799 | del sys.modules[the_module.__name__] |
| 800 | exec('import ' + the_module.__name__) |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 801 | |
| 802 | deltas = [] |
| 803 | nwarmup, ntracked, fname = huntrleaks |
| 804 | repcount = nwarmup + ntracked |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 805 | print("beginning", repcount, "repetitions", file=sys.stderr) |
| 806 | print(("1234567890"*(repcount//10 + 1))[:repcount], file=sys.stderr) |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 807 | sys.stderr.flush() |
Guido van Rossum | 3de862d | 2007-08-18 00:10:33 +0000 | [diff] [blame] | 808 | dash_R_cleanup(fs, ps, pic, abcs) |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 809 | for i in range(repcount): |
| 810 | rc = sys.gettotalrefcount() |
| 811 | run_the_test() |
| 812 | sys.stderr.write('.') |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 813 | sys.stderr.flush() |
Guido van Rossum | 3de862d | 2007-08-18 00:10:33 +0000 | [diff] [blame] | 814 | dash_R_cleanup(fs, ps, pic, abcs) |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 815 | if i >= nwarmup: |
| 816 | deltas.append(sys.gettotalrefcount() - rc - 2) |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 817 | print(file=sys.stderr) |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 818 | if any(deltas): |
Guido van Rossum | 360e4b8 | 2007-05-14 22:51:27 +0000 | [diff] [blame] | 819 | msg = '%s leaked %s references, sum=%s' % (test, deltas, sum(deltas)) |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 820 | print(msg, file=sys.stderr) |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 821 | sys.stderr.flush() |
| 822 | with open(fname, "a") as refrep: |
| 823 | print(msg, file=refrep) |
| 824 | refrep.flush() |
Collin Winter | a5503d5 | 2009-05-15 01:20:21 +0000 | [diff] [blame] | 825 | return True |
| 826 | return False |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 827 | |
Guido van Rossum | 3de862d | 2007-08-18 00:10:33 +0000 | [diff] [blame] | 828 | def dash_R_cleanup(fs, ps, pic, abcs): |
Alexandre Vassalotti | f7fa63d | 2008-05-11 08:55:36 +0000 | [diff] [blame] | 829 | import gc, copyreg |
Brett Cannon | f4fd993 | 2008-05-10 21:11:46 +0000 | [diff] [blame] | 830 | import _strptime, linecache |
Jeremy Hylton | 1afc169 | 2008-06-18 20:49:58 +0000 | [diff] [blame] | 831 | import urllib.parse, urllib.request, mimetypes, doctest |
Guido van Rossum | 7eaf822 | 2007-06-18 17:58:50 +0000 | [diff] [blame] | 832 | import struct, filecmp, _abcoll |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 833 | from distutils.dir_util import _path_created |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 834 | from weakref import WeakSet |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 835 | |
Christian Heimes | dae2a89 | 2008-04-19 00:55:37 +0000 | [diff] [blame] | 836 | # Clear the warnings registry, so they can be displayed again |
| 837 | for mod in sys.modules.values(): |
| 838 | if hasattr(mod, '__warningregistry__'): |
| 839 | del mod.__warningregistry__ |
| 840 | |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 841 | # Restore some original values. |
| 842 | warnings.filters[:] = fs |
Alexandre Vassalotti | f7fa63d | 2008-05-11 08:55:36 +0000 | [diff] [blame] | 843 | copyreg.dispatch_table.clear() |
| 844 | copyreg.dispatch_table.update(ps) |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 845 | sys.path_importer_cache.clear() |
| 846 | sys.path_importer_cache.update(pic) |
| 847 | |
Christian Heimes | 2685563 | 2008-01-27 23:50:43 +0000 | [diff] [blame] | 848 | # clear type cache |
Christian Heimes | 15ebc88 | 2008-02-04 18:48:49 +0000 | [diff] [blame] | 849 | sys._clear_type_cache() |
Christian Heimes | 2685563 | 2008-01-27 23:50:43 +0000 | [diff] [blame] | 850 | |
Guido van Rossum | 3de862d | 2007-08-18 00:10:33 +0000 | [diff] [blame] | 851 | # Clear ABC registries, restoring previously saved ABC registries. |
Guido van Rossum | 7eaf822 | 2007-06-18 17:58:50 +0000 | [diff] [blame] | 852 | for abc in [getattr(_abcoll, a) for a in _abcoll.__all__]: |
Christian Heimes | be5b30b | 2008-03-03 19:18:51 +0000 | [diff] [blame] | 853 | if not isabstract(abc): |
Christian Heimes | 941973a | 2007-11-30 21:53:03 +0000 | [diff] [blame] | 854 | continue |
Guido van Rossum | 7eaf822 | 2007-06-18 17:58:50 +0000 | [diff] [blame] | 855 | for obj in abc.__subclasses__() + [abc]: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 856 | obj._abc_registry = abcs.get(obj, WeakSet()).copy() |
Guido van Rossum | c1e315d | 2007-08-20 19:29:24 +0000 | [diff] [blame] | 857 | obj._abc_cache.clear() |
| 858 | obj._abc_negative_cache.clear() |
Guido van Rossum | cd16bf6 | 2007-06-13 18:07:49 +0000 | [diff] [blame] | 859 | |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 860 | # Clear assorted module caches. |
| 861 | _path_created.clear() |
| 862 | re.purge() |
| 863 | _strptime._regex_cache.clear() |
Jeremy Hylton | 1afc169 | 2008-06-18 20:49:58 +0000 | [diff] [blame] | 864 | urllib.parse.clear_cache() |
| 865 | urllib.request.urlcleanup() |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 866 | linecache.clearcache() |
| 867 | mimetypes._default_mime_types() |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 868 | filecmp._cache.clear() |
Christian Heimes | a34706f | 2008-01-04 03:06:10 +0000 | [diff] [blame] | 869 | struct._clearcache() |
Thomas Wouters | 73e5a5b | 2006-06-08 15:35:45 +0000 | [diff] [blame] | 870 | doctest.master = None |
| 871 | |
| 872 | # Collect cyclic trash. |
| 873 | gc.collect() |
| 874 | |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 875 | def warm_char_cache(): |
| 876 | s = bytes(range(256)) |
| 877 | for i in range(256): |
| 878 | s[i:i+1] |
| 879 | |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 880 | def findtestdir(): |
| 881 | if __name__ == '__main__': |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 882 | file = sys.argv[0] |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 883 | else: |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 884 | file = __file__ |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 885 | testdir = os.path.dirname(file) or os.curdir |
| 886 | return testdir |
| 887 | |
Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 888 | def removepy(name): |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 889 | if name.endswith(".py"): |
Tim Peters | c5000df | 2002-06-02 21:42:01 +0000 | [diff] [blame] | 890 | name = name[:-3] |
| 891 | return name |
| 892 | |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 893 | def count(n, word): |
| 894 | if n == 1: |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 895 | return "%d %s" % (n, word) |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 896 | else: |
Guido van Rossum | 41360a4 | 1998-03-26 19:42:58 +0000 | [diff] [blame] | 897 | return "%d %ss" % (n, word) |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 898 | |
Tim Peters | a45da92 | 2001-08-12 03:45:50 +0000 | [diff] [blame] | 899 | def printlist(x, width=70, indent=4): |
Tim Peters | 7c7efe9 | 2002-08-23 17:55:54 +0000 | [diff] [blame] | 900 | """Print the elements of iterable x to stdout. |
Tim Peters | a45da92 | 2001-08-12 03:45:50 +0000 | [diff] [blame] | 901 | |
| 902 | Optional arg width (default 70) is the maximum line length. |
| 903 | Optional arg indent (default 4) is the number of blanks with which to |
| 904 | begin each line. |
| 905 | """ |
| 906 | |
Tim Peters | ba78bc4 | 2002-07-04 19:45:06 +0000 | [diff] [blame] | 907 | from textwrap import fill |
| 908 | blanks = ' ' * indent |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 909 | print(fill(' '.join(map(str, x)), width, |
| 910 | initial_indent=blanks, subsequent_indent=blanks)) |
Tim Peters | a45da92 | 2001-08-12 03:45:50 +0000 | [diff] [blame] | 911 | |
Tim Peters | de14a30 | 2002-04-01 05:04:46 +0000 | [diff] [blame] | 912 | # Map sys.platform to a string containing the basenames of tests |
| 913 | # expected to be skipped on that platform. |
Tim Peters | 2a182db | 2002-10-09 01:07:11 +0000 | [diff] [blame] | 914 | # |
| 915 | # Special cases: |
| 916 | # test_pep277 |
| 917 | # The _ExpectedSkips constructor adds this to the set of expected |
| 918 | # skips if not os.path.supports_unicode_filenames. |
Neal Norwitz | 55b61d2 | 2003-02-28 19:57:03 +0000 | [diff] [blame] | 919 | # test_timeout |
| 920 | # Controlled by test_timeout.skip_expected. Requires the network |
| 921 | # resource and a socket module. |
Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 922 | # |
| 923 | # Tests that are expected to be skipped everywhere except on one platform |
| 924 | # are also handled separately. |
Tim Peters | de14a30 | 2002-04-01 05:04:46 +0000 | [diff] [blame] | 925 | |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 926 | _expectations = { |
| 927 | 'win32': |
| 928 | """ |
Tim Peters | c7c516a | 2003-09-20 22:06:13 +0000 | [diff] [blame] | 929 | test__locale |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 930 | test_crypt |
Tim Peters | d703057 | 2001-10-22 22:06:08 +0000 | [diff] [blame] | 931 | test_curses |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 932 | test_dbm |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 933 | test_fcntl |
| 934 | test_fork1 |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 935 | test_epoll |
Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 936 | test_dbm_gnu |
Kristján Valur Jónsson | 42a40c5 | 2009-04-01 11:28:47 +0000 | [diff] [blame] | 937 | test_dbm_ndbm |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 938 | test_grp |
Tim Peters | fd8e6e5 | 2003-03-04 00:26:38 +0000 | [diff] [blame] | 939 | test_ioctl |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 940 | test_largefile |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 941 | test_kqueue |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 942 | test_openpty |
Tim Peters | efc4b12 | 2002-12-10 18:47:56 +0000 | [diff] [blame] | 943 | test_ossaudiodev |
Thomas Wouters | 47b49bf | 2007-08-30 22:15:33 +0000 | [diff] [blame] | 944 | test_pipes |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 945 | test_poll |
Tim Peters | 003eb30 | 2003-02-17 21:48:48 +0000 | [diff] [blame] | 946 | test_posix |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 947 | test_pty |
| 948 | test_pwd |
Tim Peters | 1e33ffa | 2002-04-23 23:09:02 +0000 | [diff] [blame] | 949 | test_resource |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 950 | test_signal |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 951 | test_syslog |
Tim Peters | cea2cc4 | 2004-08-04 02:32:03 +0000 | [diff] [blame] | 952 | test_threadsignals |
Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 953 | test_wait3 |
| 954 | test_wait4 |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 955 | """, |
| 956 | 'linux2': |
| 957 | """ |
Guido van Rossum | f66dacd | 2001-10-23 15:10:55 +0000 | [diff] [blame] | 958 | test_curses |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 959 | test_largefile |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 960 | test_kqueue |
Guido van Rossum | 4507ec7 | 2003-02-14 19:29:22 +0000 | [diff] [blame] | 961 | test_ossaudiodev |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 962 | """, |
Jack Jansen | 49a806e | 2001-08-28 14:49:00 +0000 | [diff] [blame] | 963 | 'mac': |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 964 | """ |
Jack Jansen | 6797514 | 2003-01-08 16:31:11 +0000 | [diff] [blame] | 965 | test_atexit |
Jack Jansen | 6797514 | 2003-01-08 16:31:11 +0000 | [diff] [blame] | 966 | test_bz2 |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 967 | test_crypt |
Jack Jansen | b3be216 | 2001-11-30 14:16:36 +0000 | [diff] [blame] | 968 | test_curses |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 969 | test_dbm |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 970 | test_fcntl |
| 971 | test_fork1 |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 972 | test_epoll |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 973 | test_grp |
Jack Jansen | c4d6bdd | 2003-03-07 15:38:11 +0000 | [diff] [blame] | 974 | test_ioctl |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 975 | test_largefile |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 976 | test_locale |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 977 | test_kqueue |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 978 | test_mmap |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 979 | test_openpty |
Jack Jansen | 6797514 | 2003-01-08 16:31:11 +0000 | [diff] [blame] | 980 | test_ossaudiodev |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 981 | test_poll |
Jack Jansen | 6797514 | 2003-01-08 16:31:11 +0000 | [diff] [blame] | 982 | test_popen |
Jack Jansen | 5bb97e6 | 2003-02-21 22:33:55 +0000 | [diff] [blame] | 983 | test_posix |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 984 | test_pty |
| 985 | test_pwd |
Jack Jansen | 6797514 | 2003-01-08 16:31:11 +0000 | [diff] [blame] | 986 | test_resource |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 987 | test_signal |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 988 | test_sundry |
Jack Jansen | c4d6bdd | 2003-03-07 15:38:11 +0000 | [diff] [blame] | 989 | test_tarfile |
Guido van Rossum | aa78236 | 2001-09-02 03:58:41 +0000 | [diff] [blame] | 990 | """, |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 991 | 'unixware7': |
Martin v. Löwis | 0ace326 | 2001-09-05 14:38:48 +0000 | [diff] [blame] | 992 | """ |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 993 | test_epoll |
Martin v. Löwis | 0ace326 | 2001-09-05 14:38:48 +0000 | [diff] [blame] | 994 | test_largefile |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 995 | test_kqueue |
Martin v. Löwis | 0ace326 | 2001-09-05 14:38:48 +0000 | [diff] [blame] | 996 | test_minidom |
Martin v. Löwis | 0ace326 | 2001-09-05 14:38:48 +0000 | [diff] [blame] | 997 | test_openpty |
| 998 | test_pyexpat |
| 999 | test_sax |
Martin v. Löwis | 0ace326 | 2001-09-05 14:38:48 +0000 | [diff] [blame] | 1000 | test_sundry |
Martin v. Löwis | 0ace326 | 2001-09-05 14:38:48 +0000 | [diff] [blame] | 1001 | """, |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1002 | 'openunix8': |
| 1003 | """ |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1004 | test_epoll |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1005 | test_largefile |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1006 | test_kqueue |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1007 | test_minidom |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1008 | test_openpty |
| 1009 | test_pyexpat |
| 1010 | test_sax |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1011 | test_sundry |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1012 | """, |
| 1013 | 'sco_sv3': |
| 1014 | """ |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1015 | test_asynchat |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1016 | test_fork1 |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1017 | test_epoll |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1018 | test_gettext |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1019 | test_largefile |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1020 | test_locale |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1021 | test_kqueue |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1022 | test_minidom |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1023 | test_openpty |
| 1024 | test_pyexpat |
| 1025 | test_queue |
| 1026 | test_sax |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1027 | test_sundry |
| 1028 | test_thread |
| 1029 | test_threaded_import |
| 1030 | test_threadedtempfile |
| 1031 | test_threading |
Martin v. Löwis | 21ee409 | 2002-09-30 16:19:48 +0000 | [diff] [blame] | 1032 | """, |
Jack Jansen | 8a97f4a | 2001-12-05 23:27:32 +0000 | [diff] [blame] | 1033 | 'darwin': |
Jack Jansen | 398c236 | 2001-12-02 21:41:36 +0000 | [diff] [blame] | 1034 | """ |
Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1035 | test__locale |
Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1036 | test_curses |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1037 | test_epoll |
Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1038 | test_dbm_gnu |
Jack Jansen | 398c236 | 2001-12-02 21:41:36 +0000 | [diff] [blame] | 1039 | test_largefile |
Jack Jansen | acda339 | 2002-12-30 23:03:13 +0000 | [diff] [blame] | 1040 | test_locale |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1041 | test_minidom |
Jack Jansen | acda339 | 2002-12-30 23:03:13 +0000 | [diff] [blame] | 1042 | test_ossaudiodev |
Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1043 | test_poll |
Jack Jansen | 398c236 | 2001-12-02 21:41:36 +0000 | [diff] [blame] | 1044 | """, |
Guido van Rossum | 11c3f09 | 2002-07-17 15:08:24 +0000 | [diff] [blame] | 1045 | 'sunos5': |
| 1046 | """ |
Guido van Rossum | 11c3f09 | 2002-07-17 15:08:24 +0000 | [diff] [blame] | 1047 | test_curses |
| 1048 | test_dbm |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1049 | test_epoll |
| 1050 | test_kqueue |
Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1051 | test_dbm_gnu |
Guido van Rossum | 11c3f09 | 2002-07-17 15:08:24 +0000 | [diff] [blame] | 1052 | test_gzip |
Guido van Rossum | 11c3f09 | 2002-07-17 15:08:24 +0000 | [diff] [blame] | 1053 | test_openpty |
Guido van Rossum | 11c3f09 | 2002-07-17 15:08:24 +0000 | [diff] [blame] | 1054 | test_zipfile |
| 1055 | test_zlib |
Jeremy Hylton | ed375e1 | 2002-07-17 15:56:55 +0000 | [diff] [blame] | 1056 | """, |
Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1057 | 'hp-ux11': |
| 1058 | """ |
Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1059 | test_curses |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1060 | test_epoll |
Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1061 | test_dbm_gnu |
Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1062 | test_gzip |
Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1063 | test_largefile |
Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1064 | test_locale |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1065 | test_kqueue |
Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1066 | test_minidom |
Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1067 | test_openpty |
| 1068 | test_pyexpat |
| 1069 | test_sax |
Skip Montanaro | b323021 | 2002-03-15 02:54:03 +0000 | [diff] [blame] | 1070 | test_zipfile |
| 1071 | test_zlib |
| 1072 | """, |
Martin v. Löwis | f90ae20 | 2002-06-11 06:22:31 +0000 | [diff] [blame] | 1073 | 'atheos': |
Tim Peters | c411dba | 2002-07-16 21:35:23 +0000 | [diff] [blame] | 1074 | """ |
Tim Peters | c411dba | 2002-07-16 21:35:23 +0000 | [diff] [blame] | 1075 | test_curses |
Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1076 | test_dbm_gnu |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1077 | test_epoll |
Tim Peters | c411dba | 2002-07-16 21:35:23 +0000 | [diff] [blame] | 1078 | test_largefile |
Tim Peters | c411dba | 2002-07-16 21:35:23 +0000 | [diff] [blame] | 1079 | test_locale |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1080 | test_kqueue |
Tim Peters | c411dba | 2002-07-16 21:35:23 +0000 | [diff] [blame] | 1081 | test_mhlib |
| 1082 | test_mmap |
Tim Peters | c411dba | 2002-07-16 21:35:23 +0000 | [diff] [blame] | 1083 | test_poll |
Tim Peters | c411dba | 2002-07-16 21:35:23 +0000 | [diff] [blame] | 1084 | test_resource |
Tim Peters | c411dba | 2002-07-16 21:35:23 +0000 | [diff] [blame] | 1085 | """, |
Jason Tishler | 2511594 | 2002-12-05 15:18:15 +0000 | [diff] [blame] | 1086 | 'cygwin': |
| 1087 | """ |
Jason Tishler | 2511594 | 2002-12-05 15:18:15 +0000 | [diff] [blame] | 1088 | test_curses |
| 1089 | test_dbm |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1090 | test_epoll |
Jason Tishler | c23f39c | 2003-07-22 18:35:58 +0000 | [diff] [blame] | 1091 | test_ioctl |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1092 | test_kqueue |
Jason Tishler | 2511594 | 2002-12-05 15:18:15 +0000 | [diff] [blame] | 1093 | test_largefile |
Jason Tishler | 2511594 | 2002-12-05 15:18:15 +0000 | [diff] [blame] | 1094 | test_locale |
Jason Tishler | 5c4ded2 | 2003-02-05 16:46:01 +0000 | [diff] [blame] | 1095 | test_ossaudiodev |
Jason Tishler | 2511594 | 2002-12-05 15:18:15 +0000 | [diff] [blame] | 1096 | test_socketserver |
Jason Tishler | 2511594 | 2002-12-05 15:18:15 +0000 | [diff] [blame] | 1097 | """, |
Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1098 | 'os2emx': |
| 1099 | """ |
Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1100 | test_audioop |
Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1101 | test_curses |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1102 | test_epoll |
| 1103 | test_kqueue |
Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1104 | test_largefile |
Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1105 | test_mmap |
Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1106 | test_openpty |
| 1107 | test_ossaudiodev |
| 1108 | test_pty |
| 1109 | test_resource |
| 1110 | test_signal |
Andrew MacIntyre | fd07e7d | 2002-12-31 11:26:50 +0000 | [diff] [blame] | 1111 | """, |
Guido van Rossum | 944a6c3 | 2003-11-20 22:11:29 +0000 | [diff] [blame] | 1112 | 'freebsd4': |
| 1113 | """ |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1114 | test_epoll |
Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1115 | test_dbm_gnu |
Guido van Rossum | 944a6c3 | 2003-11-20 22:11:29 +0000 | [diff] [blame] | 1116 | test_locale |
Guido van Rossum | 944a6c3 | 2003-11-20 22:11:29 +0000 | [diff] [blame] | 1117 | test_ossaudiodev |
| 1118 | test_pep277 |
Hye-Shik Chang | f64700a | 2004-08-18 15:13:41 +0000 | [diff] [blame] | 1119 | test_pty |
Guido van Rossum | 944a6c3 | 2003-11-20 22:11:29 +0000 | [diff] [blame] | 1120 | test_socketserver |
Hye-Shik Chang | f64700a | 2004-08-18 15:13:41 +0000 | [diff] [blame] | 1121 | test_tcl |
Guilherme Polo | a91790a | 2009-02-09 20:40:42 +0000 | [diff] [blame] | 1122 | test_tk |
Guilherme Polo | 9de29af | 2009-01-28 20:40:48 +0000 | [diff] [blame] | 1123 | test_ttk_guionly |
| 1124 | test_ttk_textonly |
Guido van Rossum | 944a6c3 | 2003-11-20 22:11:29 +0000 | [diff] [blame] | 1125 | test_timeout |
Guido van Rossum | 944a6c3 | 2003-11-20 22:11:29 +0000 | [diff] [blame] | 1126 | test_urllibnet |
Benjamin Peterson | e5384b0 | 2008-10-04 22:00:42 +0000 | [diff] [blame] | 1127 | test_multiprocessing |
Martin v. Löwis | 56f8811 | 2003-06-07 20:01:37 +0000 | [diff] [blame] | 1128 | """, |
Guido van Rossum | 8ee3e5a | 2005-09-14 18:09:42 +0000 | [diff] [blame] | 1129 | 'aix5': |
| 1130 | """ |
Guido van Rossum | 8ee3e5a | 2005-09-14 18:09:42 +0000 | [diff] [blame] | 1131 | test_bz2 |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1132 | test_epoll |
Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1133 | test_dbm_gnu |
Guido van Rossum | 8ee3e5a | 2005-09-14 18:09:42 +0000 | [diff] [blame] | 1134 | test_gzip |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1135 | test_kqueue |
Guido van Rossum | 8ee3e5a | 2005-09-14 18:09:42 +0000 | [diff] [blame] | 1136 | test_ossaudiodev |
Guido van Rossum | 8ee3e5a | 2005-09-14 18:09:42 +0000 | [diff] [blame] | 1137 | test_tcl |
Guilherme Polo | a91790a | 2009-02-09 20:40:42 +0000 | [diff] [blame] | 1138 | test_tk |
Guilherme Polo | 9de29af | 2009-01-28 20:40:48 +0000 | [diff] [blame] | 1139 | test_ttk_guionly |
| 1140 | test_ttk_textonly |
Guido van Rossum | 8ee3e5a | 2005-09-14 18:09:42 +0000 | [diff] [blame] | 1141 | test_zipimport |
| 1142 | test_zlib |
| 1143 | """, |
Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1144 | 'openbsd3': |
| 1145 | """ |
Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1146 | test_ctypes |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1147 | test_epoll |
Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1148 | test_dbm_gnu |
Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1149 | test_locale |
Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1150 | test_normalization |
| 1151 | test_ossaudiodev |
| 1152 | test_pep277 |
Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1153 | test_tcl |
Guilherme Polo | a91790a | 2009-02-09 20:40:42 +0000 | [diff] [blame] | 1154 | test_tk |
Guilherme Polo | 9de29af | 2009-01-28 20:40:48 +0000 | [diff] [blame] | 1155 | test_ttk_guionly |
| 1156 | test_ttk_textonly |
Benjamin Peterson | e5384b0 | 2008-10-04 22:00:42 +0000 | [diff] [blame] | 1157 | test_multiprocessing |
Thomas Wouters | 49fd7fa | 2006-04-21 10:40:58 +0000 | [diff] [blame] | 1158 | """, |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1159 | 'netbsd3': |
| 1160 | """ |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1161 | test_ctypes |
| 1162 | test_curses |
Christian Heimes | 4fbc72b | 2008-03-22 00:47:35 +0000 | [diff] [blame] | 1163 | test_epoll |
Benjamin Peterson | 4d48053 | 2008-05-26 19:08:31 +0000 | [diff] [blame] | 1164 | test_dbm_gnu |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1165 | test_locale |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1166 | test_ossaudiodev |
| 1167 | test_pep277 |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1168 | test_tcl |
Guilherme Polo | a91790a | 2009-02-09 20:40:42 +0000 | [diff] [blame] | 1169 | test_tk |
Guilherme Polo | 9de29af | 2009-01-28 20:40:48 +0000 | [diff] [blame] | 1170 | test_ttk_guionly |
| 1171 | test_ttk_textonly |
Benjamin Peterson | e5384b0 | 2008-10-04 22:00:42 +0000 | [diff] [blame] | 1172 | test_multiprocessing |
Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 1173 | """, |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1174 | } |
Martin v. Löwis | 32d0c1b | 2004-07-26 12:09:13 +0000 | [diff] [blame] | 1175 | _expectations['freebsd5'] = _expectations['freebsd4'] |
Hye-Shik Chang | f64700a | 2004-08-18 15:13:41 +0000 | [diff] [blame] | 1176 | _expectations['freebsd6'] = _expectations['freebsd4'] |
Hye-Shik Chang | 4e42281 | 2005-07-17 02:36:59 +0000 | [diff] [blame] | 1177 | _expectations['freebsd7'] = _expectations['freebsd4'] |
Guido van Rossum | 8ce8a78 | 2007-11-01 19:42:39 +0000 | [diff] [blame] | 1178 | _expectations['freebsd8'] = _expectations['freebsd4'] |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1179 | |
Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 1180 | class _ExpectedSkips: |
| 1181 | def __init__(self): |
Tim Peters | 2a182db | 2002-10-09 01:07:11 +0000 | [diff] [blame] | 1182 | import os.path |
Neal Norwitz | 55b61d2 | 2003-02-28 19:57:03 +0000 | [diff] [blame] | 1183 | from test import test_timeout |
Tim Peters | 1b445d3 | 2002-11-24 18:53:11 +0000 | [diff] [blame] | 1184 | |
Tim Peters | 7c7efe9 | 2002-08-23 17:55:54 +0000 | [diff] [blame] | 1185 | self.valid = False |
Tim Peters | de14a30 | 2002-04-01 05:04:46 +0000 | [diff] [blame] | 1186 | if sys.platform in _expectations: |
Guido van Rossum | f73e30c | 2001-08-12 02:22:19 +0000 | [diff] [blame] | 1187 | s = _expectations[sys.platform] |
Raymond Hettinger | a690a99 | 2003-11-16 16:17:49 +0000 | [diff] [blame] | 1188 | self.expected = set(s.split()) |
Tim Peters | 1b445d3 | 2002-11-24 18:53:11 +0000 | [diff] [blame] | 1189 | |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1190 | # These are broken tests, for now skipped on every platform. |
| 1191 | # XXX Fix these! |
Benjamin Peterson | e9ea19e | 2008-08-19 23:02:38 +0000 | [diff] [blame] | 1192 | self.expected.add('test_nis') |
Benjamin Peterson | 4fde0c4 | 2008-03-31 02:36:22 +0000 | [diff] [blame] | 1193 | |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1194 | # expected to be skipped on every platform, even Linux |
Tim Peters | 2a182db | 2002-10-09 01:07:11 +0000 | [diff] [blame] | 1195 | if not os.path.supports_unicode_filenames: |
| 1196 | self.expected.add('test_pep277') |
Tim Peters | 1b445d3 | 2002-11-24 18:53:11 +0000 | [diff] [blame] | 1197 | |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1198 | # doctest, profile and cProfile tests fail when the codec for the |
| 1199 | # fs encoding isn't built in because PyUnicode_Decode() adds two |
| 1200 | # calls into Python. |
| 1201 | encs = ("utf-8", "latin-1", "ascii", "mbcs", "utf-16", "utf-32") |
| 1202 | if sys.getfilesystemencoding().lower() not in encs: |
| 1203 | self.expected.add('test_profile') |
| 1204 | self.expected.add('test_cProfile') |
| 1205 | self.expected.add('test_doctest') |
Guido van Rossum | daa251c | 2007-10-25 23:47:33 +0000 | [diff] [blame] | 1206 | |
Neal Norwitz | 55b61d2 | 2003-02-28 19:57:03 +0000 | [diff] [blame] | 1207 | if test_timeout.skip_expected: |
| 1208 | self.expected.add('test_timeout') |
| 1209 | |
Tim Peters | ecd79eb | 2003-01-29 00:35:32 +0000 | [diff] [blame] | 1210 | if sys.platform != "win32": |
Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1211 | # test_sqlite is only reliable on Windows where the library |
| 1212 | # is distributed with Python |
Neal Norwitz | 7035c98 | 2003-03-29 22:01:17 +0000 | [diff] [blame] | 1213 | WIN_ONLY = ["test_unicode_file", "test_winreg", |
Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1214 | "test_winsound", "test_startfile", |
| 1215 | "test_sqlite"] |
Neal Norwitz | 7035c98 | 2003-03-29 22:01:17 +0000 | [diff] [blame] | 1216 | for skip in WIN_ONLY: |
| 1217 | self.expected.add(skip) |
Tim Peters | f2715e0 | 2003-02-19 02:35:07 +0000 | [diff] [blame] | 1218 | |
Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1219 | if sys.platform != 'sunos5': |
Guido van Rossum | b5a755e | 2007-07-18 18:15:48 +0000 | [diff] [blame] | 1220 | self.expected.add('test_nis') |
Guido van Rossum | d59da4b | 2007-05-22 18:11:13 +0000 | [diff] [blame] | 1221 | |
Tim Peters | 7c7efe9 | 2002-08-23 17:55:54 +0000 | [diff] [blame] | 1222 | self.valid = True |
Tim Peters | b5b7b78 | 2001-08-12 01:20:39 +0000 | [diff] [blame] | 1223 | |
| 1224 | def isvalid(self): |
| 1225 | "Return true iff _ExpectedSkips knows about the current platform." |
| 1226 | return self.valid |
| 1227 | |
| 1228 | def getexpected(self): |
| 1229 | """Return set of test names we expect to skip on current platform. |
| 1230 | |
| 1231 | self.isvalid() must be true. |
| 1232 | """ |
| 1233 | |
| 1234 | assert self.isvalid() |
| 1235 | return self.expected |
| 1236 | |
Guido van Rossum | 152494a | 1996-12-20 03:12:20 +0000 | [diff] [blame] | 1237 | if __name__ == '__main__': |
Barry Warsaw | 408b6d3 | 2002-07-30 23:27:12 +0000 | [diff] [blame] | 1238 | # Remove regrtest.py's own directory from the module search path. This |
| 1239 | # prevents relative imports from working, and relative imports will screw |
Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 1240 | # up the testing framework. E.g. if both test.support and |
| 1241 | # support are imported, they will not contain the same globals, and |
Barry Warsaw | 408b6d3 | 2002-07-30 23:27:12 +0000 | [diff] [blame] | 1242 | # much of the testing framework relies on the globals in the |
Benjamin Peterson | ee8712c | 2008-05-20 21:35:26 +0000 | [diff] [blame] | 1243 | # test.support module. |
Barry Warsaw | 408b6d3 | 2002-07-30 23:27:12 +0000 | [diff] [blame] | 1244 | mydir = os.path.abspath(os.path.normpath(os.path.dirname(sys.argv[0]))) |
| 1245 | i = pathlen = len(sys.path) |
| 1246 | while i >= 0: |
| 1247 | i -= 1 |
| 1248 | if os.path.abspath(os.path.normpath(sys.path[i])) == mydir: |
| 1249 | del sys.path[i] |
Antoine Pitrou | 8890954 | 2009-06-29 13:54:42 +0000 | [diff] [blame] | 1250 | if '--slaveargs' not in sys.argv and len(sys.path) == pathlen: |
Neal Norwitz | 94fa2ee | 2008-03-31 02:55:15 +0000 | [diff] [blame] | 1251 | print('Could not find %r in sys.path to remove it' % mydir) |
Barry Warsaw | 08fca52 | 2001-08-20 22:33:46 +0000 | [diff] [blame] | 1252 | main() |