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