summaryrefslogtreecommitdiffstats
path: root/Lib/test/__main__.py
diff options
context:
space:
mode:
authorMichael Foord <fuzzyman@voidspace.org.uk>2010-12-03 01:34:01 (GMT)
committerMichael Foord <fuzzyman@voidspace.org.uk>2010-12-03 01:34:01 (GMT)
commite2befc11dbb0ca97662fd6d1567ceb3b180d267d (patch)
treef7aff841c413e50945b693ea5839998fa10f0459 /Lib/test/__main__.py
parent5074df623b70cf196965af332092a6f98a035c3d (diff)
downloadcpython-e2befc11dbb0ca97662fd6d1567ceb3b180d267d.zip
cpython-e2befc11dbb0ca97662fd6d1567ceb3b180d267d.tar.gz
cpython-e2befc11dbb0ca97662fd6d1567ceb3b180d267d.tar.bz2
Initial implementation of Lib/test/__main__.py so we can run tests with 'python -m test'
Diffstat (limited to 'Lib/test/__main__.py')
-rw-r--r--Lib/test/__main__.py38
1 files changed, 38 insertions, 0 deletions
diff --git a/Lib/test/__main__.py b/Lib/test/__main__.py
new file mode 100644
index 0000000..8f12fed
--- /dev/null
+++ b/Lib/test/__main__.py
@@ -0,0 +1,38 @@
+import os
+import sys
+import sysconfig
+
+from test import support
+from test.regrtest import main
+
+# findtestdir() gets the dirname out of __file__, so we have to make it
+# absolute before changing the working directory.
+# For example __file__ may be relative when running trace or profile.
+# See issue #9323.
+__file__ = os.path.abspath(__file__)
+
+# sanity check
+assert __file__ == os.path.abspath(sys.argv[0])
+
+# When tests are run from the Python build directory, it is best practice
+# to keep the test files in a subfolder. It eases the cleanup of leftover
+# files using command "make distclean".
+if sysconfig.is_python_build():
+ TEMPDIR = os.path.join(sysconfig.get_config_var('srcdir'), 'build')
+ TEMPDIR = os.path.abspath(TEMPDIR)
+ if not os.path.exists(TEMPDIR):
+ os.mkdir(TEMPDIR)
+
+# Define a writable temp dir that will be used as cwd while running
+# the tests. The name of the dir includes the pid to allow parallel
+# testing (see the -j option).
+TESTCWD = 'test_python_{}'.format(os.getpid())
+
+TESTCWD = os.path.join(TEMPDIR, TESTCWD)
+
+# Run the tests in a context manager that temporary changes the CWD to a
+# temporary and writable directory. If it's not possible to create or
+# change the CWD, the original CWD will be used. The original CWD is
+# available from support.SAVEDCWD.
+with support.temp_cwd(TESTCWD, quiet=True):
+ main()