2009-11-15 03:30:34 -04:00
|
|
|
# Common utility functions used by various script execution tests
|
|
|
|
# e.g. test_cmd_line, test_cmd_line_script and test_runpy
|
|
|
|
|
|
|
|
import sys
|
|
|
|
import os
|
Merged revisions 86542,87136,87216,87221,87228,87256,87337-87338,87372,87516,87571,88164 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k
........
r86542 | r.david.murray | 2010-11-19 22:48:58 -0500 (Fri, 19 Nov 2010) | 2 lines
Make test class name unique so that both test classes run.
........
r87136 | r.david.murray | 2010-12-08 17:53:00 -0500 (Wed, 08 Dec 2010) | 6 lines
Have script_helper._assert_python strip refcount strings from stderr.
This makes the output of the function and those that depend on it
independent of whether or not they are being run under a debug
build.
........
r87216 | r.david.murray | 2010-12-13 17:50:30 -0500 (Mon, 13 Dec 2010) | 2 lines
#10698: fix typo in example.
........
r87221 | r.david.murray | 2010-12-13 19:55:46 -0500 (Mon, 13 Dec 2010) | 4 lines
#10699: fix docstring for tzset: it does not take a parameter
Thanks to Garrett Cooper for the fix.
........
r87228 | r.david.murray | 2010-12-13 21:25:43 -0500 (Mon, 13 Dec 2010) | 2 lines
Turn on regrtest -W (rerun immediately) option for Windows, too.
........
r87256 | r.david.murray | 2010-12-14 21:19:14 -0500 (Tue, 14 Dec 2010) | 2 lines
#10705: document what the values of debuglevel are and mean.
........
r87337 | r.david.murray | 2010-12-17 11:11:40 -0500 (Fri, 17 Dec 2010) | 2 lines
#10559: provide instructions for accessing sys.argv when first mentioned.
........
r87338 | r.david.murray | 2010-12-17 11:29:07 -0500 (Fri, 17 Dec 2010) | 2 lines
#10454: clarify the compileall docs and help messages.
[changes to compileall.py were not backported, only the doc changes]
........
r87372 | r.david.murray | 2010-12-18 11:39:06 -0500 (Sat, 18 Dec 2010) | 2 lines
#10728: the default for printing help is sys.stdout, not stderr.
........
r87516 | r.david.murray | 2010-12-27 15:09:32 -0500 (Mon, 27 Dec 2010) | 5 lines
#7056: runtest and runtest_inner don't use testdir, so drop it from their sigs
I've only tested regular runs and -j runs. If I've broken anything
else I'm sure I'll hear about it sooner or later.
........
r87571 | r.david.murray | 2010-12-29 14:06:48 -0500 (Wed, 29 Dec 2010) | 2 lines
Fix same typo in docs.
........
r88164 | r.david.murray | 2011-01-24 14:34:58 -0500 (Mon, 24 Jan 2011) | 12 lines
#10960: fix 'stat' links, link to lstat from stat, general tidy of stat doc.
Original patch by Michal Nowikowski, with some additions and wording
fixes by me.
I changed the wording from 'Performs a stat system call' to 'Performs
the equivalent of a stat system call', since on Windows there are no
stat/lstat system calls involved. I also extended Michal's breakout
of the attributes into a list to the other paragraphs, and rearranged
the order of the paragraphs in the 'stat' docs to make it flow
better and put it in what I think is a more logical/useful order.
........
2011-02-11 13:25:54 -04:00
|
|
|
import re
|
2009-11-15 03:30:34 -04:00
|
|
|
import os.path
|
|
|
|
import tempfile
|
|
|
|
import subprocess
|
|
|
|
import py_compile
|
|
|
|
import contextlib
|
|
|
|
import shutil
|
|
|
|
import zipfile
|
|
|
|
|
Merged revisions 86542,87136,87216,87221,87228,87256,87337-87338,87372,87516,87571,88164 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k
........
r86542 | r.david.murray | 2010-11-19 22:48:58 -0500 (Fri, 19 Nov 2010) | 2 lines
Make test class name unique so that both test classes run.
........
r87136 | r.david.murray | 2010-12-08 17:53:00 -0500 (Wed, 08 Dec 2010) | 6 lines
Have script_helper._assert_python strip refcount strings from stderr.
This makes the output of the function and those that depend on it
independent of whether or not they are being run under a debug
build.
........
r87216 | r.david.murray | 2010-12-13 17:50:30 -0500 (Mon, 13 Dec 2010) | 2 lines
#10698: fix typo in example.
........
r87221 | r.david.murray | 2010-12-13 19:55:46 -0500 (Mon, 13 Dec 2010) | 4 lines
#10699: fix docstring for tzset: it does not take a parameter
Thanks to Garrett Cooper for the fix.
........
r87228 | r.david.murray | 2010-12-13 21:25:43 -0500 (Mon, 13 Dec 2010) | 2 lines
Turn on regrtest -W (rerun immediately) option for Windows, too.
........
r87256 | r.david.murray | 2010-12-14 21:19:14 -0500 (Tue, 14 Dec 2010) | 2 lines
#10705: document what the values of debuglevel are and mean.
........
r87337 | r.david.murray | 2010-12-17 11:11:40 -0500 (Fri, 17 Dec 2010) | 2 lines
#10559: provide instructions for accessing sys.argv when first mentioned.
........
r87338 | r.david.murray | 2010-12-17 11:29:07 -0500 (Fri, 17 Dec 2010) | 2 lines
#10454: clarify the compileall docs and help messages.
[changes to compileall.py were not backported, only the doc changes]
........
r87372 | r.david.murray | 2010-12-18 11:39:06 -0500 (Sat, 18 Dec 2010) | 2 lines
#10728: the default for printing help is sys.stdout, not stderr.
........
r87516 | r.david.murray | 2010-12-27 15:09:32 -0500 (Mon, 27 Dec 2010) | 5 lines
#7056: runtest and runtest_inner don't use testdir, so drop it from their sigs
I've only tested regular runs and -j runs. If I've broken anything
else I'm sure I'll hear about it sooner or later.
........
r87571 | r.david.murray | 2010-12-29 14:06:48 -0500 (Wed, 29 Dec 2010) | 2 lines
Fix same typo in docs.
........
r88164 | r.david.murray | 2011-01-24 14:34:58 -0500 (Mon, 24 Jan 2011) | 12 lines
#10960: fix 'stat' links, link to lstat from stat, general tidy of stat doc.
Original patch by Michal Nowikowski, with some additions and wording
fixes by me.
I changed the wording from 'Performs a stat system call' to 'Performs
the equivalent of a stat system call', since on Windows there are no
stat/lstat system calls involved. I also extended Michal's breakout
of the attributes into a list to the other paragraphs, and rearranged
the order of the paragraphs in the 'stat' docs to make it flow
better and put it in what I think is a more logical/useful order.
........
2011-02-11 13:25:54 -04:00
|
|
|
from test.test_support import strip_python_stderr
|
|
|
|
|
2009-11-15 03:30:34 -04:00
|
|
|
# Executing the interpreter in a subprocess
|
2010-11-10 10:03:31 -04:00
|
|
|
def _assert_python(expected_success, *args, **env_vars):
|
|
|
|
cmd_line = [sys.executable]
|
|
|
|
if not env_vars:
|
|
|
|
cmd_line.append('-E')
|
|
|
|
cmd_line.extend(args)
|
|
|
|
# Need to preserve the original environment, for in-place testing of
|
|
|
|
# shared library builds.
|
|
|
|
env = os.environ.copy()
|
|
|
|
env.update(env_vars)
|
|
|
|
p = subprocess.Popen(cmd_line, stdin=subprocess.PIPE,
|
|
|
|
stdout=subprocess.PIPE, stderr=subprocess.PIPE,
|
|
|
|
env=env)
|
|
|
|
try:
|
|
|
|
out, err = p.communicate()
|
|
|
|
finally:
|
|
|
|
subprocess._cleanup()
|
|
|
|
p.stdout.close()
|
|
|
|
p.stderr.close()
|
|
|
|
rc = p.returncode
|
Merged revisions 86542,87136,87216,87221,87228,87256,87337-87338,87372,87516,87571,88164 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k
........
r86542 | r.david.murray | 2010-11-19 22:48:58 -0500 (Fri, 19 Nov 2010) | 2 lines
Make test class name unique so that both test classes run.
........
r87136 | r.david.murray | 2010-12-08 17:53:00 -0500 (Wed, 08 Dec 2010) | 6 lines
Have script_helper._assert_python strip refcount strings from stderr.
This makes the output of the function and those that depend on it
independent of whether or not they are being run under a debug
build.
........
r87216 | r.david.murray | 2010-12-13 17:50:30 -0500 (Mon, 13 Dec 2010) | 2 lines
#10698: fix typo in example.
........
r87221 | r.david.murray | 2010-12-13 19:55:46 -0500 (Mon, 13 Dec 2010) | 4 lines
#10699: fix docstring for tzset: it does not take a parameter
Thanks to Garrett Cooper for the fix.
........
r87228 | r.david.murray | 2010-12-13 21:25:43 -0500 (Mon, 13 Dec 2010) | 2 lines
Turn on regrtest -W (rerun immediately) option for Windows, too.
........
r87256 | r.david.murray | 2010-12-14 21:19:14 -0500 (Tue, 14 Dec 2010) | 2 lines
#10705: document what the values of debuglevel are and mean.
........
r87337 | r.david.murray | 2010-12-17 11:11:40 -0500 (Fri, 17 Dec 2010) | 2 lines
#10559: provide instructions for accessing sys.argv when first mentioned.
........
r87338 | r.david.murray | 2010-12-17 11:29:07 -0500 (Fri, 17 Dec 2010) | 2 lines
#10454: clarify the compileall docs and help messages.
[changes to compileall.py were not backported, only the doc changes]
........
r87372 | r.david.murray | 2010-12-18 11:39:06 -0500 (Sat, 18 Dec 2010) | 2 lines
#10728: the default for printing help is sys.stdout, not stderr.
........
r87516 | r.david.murray | 2010-12-27 15:09:32 -0500 (Mon, 27 Dec 2010) | 5 lines
#7056: runtest and runtest_inner don't use testdir, so drop it from their sigs
I've only tested regular runs and -j runs. If I've broken anything
else I'm sure I'll hear about it sooner or later.
........
r87571 | r.david.murray | 2010-12-29 14:06:48 -0500 (Wed, 29 Dec 2010) | 2 lines
Fix same typo in docs.
........
r88164 | r.david.murray | 2011-01-24 14:34:58 -0500 (Mon, 24 Jan 2011) | 12 lines
#10960: fix 'stat' links, link to lstat from stat, general tidy of stat doc.
Original patch by Michal Nowikowski, with some additions and wording
fixes by me.
I changed the wording from 'Performs a stat system call' to 'Performs
the equivalent of a stat system call', since on Windows there are no
stat/lstat system calls involved. I also extended Michal's breakout
of the attributes into a list to the other paragraphs, and rearranged
the order of the paragraphs in the 'stat' docs to make it flow
better and put it in what I think is a more logical/useful order.
........
2011-02-11 13:25:54 -04:00
|
|
|
err = strip_python_stderr(err)
|
2010-11-10 10:03:31 -04:00
|
|
|
if (rc and expected_success) or (not rc and not expected_success):
|
|
|
|
raise AssertionError(
|
|
|
|
"Process return code is %d, "
|
|
|
|
"stderr follows:\n%s" % (rc, err.decode('ascii', 'ignore')))
|
|
|
|
return rc, out, err
|
|
|
|
|
|
|
|
def assert_python_ok(*args, **env_vars):
|
|
|
|
"""
|
|
|
|
Assert that running the interpreter with `args` and optional environment
|
|
|
|
variables `env_vars` is ok and return a (return code, stdout, stderr) tuple.
|
|
|
|
"""
|
|
|
|
return _assert_python(True, *args, **env_vars)
|
|
|
|
|
|
|
|
def assert_python_failure(*args, **env_vars):
|
|
|
|
"""
|
|
|
|
Assert that running the interpreter with `args` and optional environment
|
|
|
|
variables `env_vars` fails and return a (return code, stdout, stderr) tuple.
|
|
|
|
"""
|
|
|
|
return _assert_python(False, *args, **env_vars)
|
|
|
|
|
2009-11-15 03:30:34 -04:00
|
|
|
def python_exit_code(*args):
|
|
|
|
cmd_line = [sys.executable, '-E']
|
|
|
|
cmd_line.extend(args)
|
|
|
|
with open(os.devnull, 'w') as devnull:
|
|
|
|
return subprocess.call(cmd_line, stdout=devnull,
|
|
|
|
stderr=subprocess.STDOUT)
|
|
|
|
|
2010-04-19 15:52:43 -03:00
|
|
|
def spawn_python(*args, **kwargs):
|
2009-11-15 03:30:34 -04:00
|
|
|
cmd_line = [sys.executable, '-E']
|
|
|
|
cmd_line.extend(args)
|
|
|
|
return subprocess.Popen(cmd_line, stdin=subprocess.PIPE,
|
2010-04-19 15:52:43 -03:00
|
|
|
stdout=subprocess.PIPE, stderr=subprocess.STDOUT,
|
|
|
|
**kwargs)
|
2009-11-15 03:30:34 -04:00
|
|
|
|
|
|
|
def kill_python(p):
|
|
|
|
p.stdin.close()
|
|
|
|
data = p.stdout.read()
|
|
|
|
p.stdout.close()
|
|
|
|
# try to cleanup the child so we don't appear to leak when running
|
2009-12-08 15:25:51 -04:00
|
|
|
# with regrtest -R.
|
|
|
|
p.wait()
|
2009-11-15 03:30:34 -04:00
|
|
|
subprocess._cleanup()
|
|
|
|
return data
|
|
|
|
|
2010-04-19 15:52:43 -03:00
|
|
|
def run_python(*args, **kwargs):
|
2009-11-15 03:30:34 -04:00
|
|
|
if __debug__:
|
2010-04-19 15:52:43 -03:00
|
|
|
p = spawn_python(*args, **kwargs)
|
2009-11-15 03:30:34 -04:00
|
|
|
else:
|
2010-04-19 15:52:43 -03:00
|
|
|
p = spawn_python('-O', *args, **kwargs)
|
2009-11-15 03:30:34 -04:00
|
|
|
stdout_data = kill_python(p)
|
|
|
|
return p.wait(), stdout_data
|
|
|
|
|
|
|
|
# Script creation utilities
|
|
|
|
@contextlib.contextmanager
|
|
|
|
def temp_dir():
|
|
|
|
dirname = tempfile.mkdtemp()
|
|
|
|
dirname = os.path.realpath(dirname)
|
|
|
|
try:
|
|
|
|
yield dirname
|
|
|
|
finally:
|
|
|
|
shutil.rmtree(dirname)
|
|
|
|
|
|
|
|
def make_script(script_dir, script_basename, source):
|
|
|
|
script_filename = script_basename+os.extsep+'py'
|
|
|
|
script_name = os.path.join(script_dir, script_filename)
|
|
|
|
script_file = open(script_name, 'w')
|
|
|
|
script_file.write(source)
|
|
|
|
script_file.close()
|
|
|
|
return script_name
|
|
|
|
|
|
|
|
def compile_script(script_name):
|
|
|
|
py_compile.compile(script_name, doraise=True)
|
|
|
|
if __debug__:
|
|
|
|
compiled_name = script_name + 'c'
|
|
|
|
else:
|
|
|
|
compiled_name = script_name + 'o'
|
|
|
|
return compiled_name
|
|
|
|
|
|
|
|
def make_zip_script(zip_dir, zip_basename, script_name, name_in_zip=None):
|
|
|
|
zip_filename = zip_basename+os.extsep+'zip'
|
|
|
|
zip_name = os.path.join(zip_dir, zip_filename)
|
|
|
|
zip_file = zipfile.ZipFile(zip_name, 'w')
|
|
|
|
if name_in_zip is None:
|
|
|
|
name_in_zip = os.path.basename(script_name)
|
|
|
|
zip_file.write(script_name, name_in_zip)
|
|
|
|
zip_file.close()
|
|
|
|
#if test.test_support.verbose:
|
|
|
|
# zip_file = zipfile.ZipFile(zip_name, 'r')
|
|
|
|
# print 'Contents of %r:' % zip_name
|
|
|
|
# zip_file.printdir()
|
|
|
|
# zip_file.close()
|
|
|
|
return zip_name, os.path.join(zip_name, name_in_zip)
|
|
|
|
|
|
|
|
def make_pkg(pkg_dir):
|
|
|
|
os.mkdir(pkg_dir)
|
|
|
|
make_script(pkg_dir, '__init__', '')
|
|
|
|
|
|
|
|
def make_zip_pkg(zip_dir, zip_basename, pkg_name, script_basename,
|
|
|
|
source, depth=1, compiled=False):
|
|
|
|
unlink = []
|
|
|
|
init_name = make_script(zip_dir, '__init__', '')
|
|
|
|
unlink.append(init_name)
|
|
|
|
init_basename = os.path.basename(init_name)
|
|
|
|
script_name = make_script(zip_dir, script_basename, source)
|
|
|
|
unlink.append(script_name)
|
|
|
|
if compiled:
|
|
|
|
init_name = compile_script(init_name)
|
|
|
|
script_name = compile_script(script_name)
|
|
|
|
unlink.extend((init_name, script_name))
|
|
|
|
pkg_names = [os.sep.join([pkg_name]*i) for i in range(1, depth+1)]
|
|
|
|
script_name_in_zip = os.path.join(pkg_names[-1], os.path.basename(script_name))
|
|
|
|
zip_filename = zip_basename+os.extsep+'zip'
|
|
|
|
zip_name = os.path.join(zip_dir, zip_filename)
|
|
|
|
zip_file = zipfile.ZipFile(zip_name, 'w')
|
|
|
|
for name in pkg_names:
|
|
|
|
init_name_in_zip = os.path.join(name, init_basename)
|
|
|
|
zip_file.write(init_name, init_name_in_zip)
|
|
|
|
zip_file.write(script_name, script_name_in_zip)
|
|
|
|
zip_file.close()
|
|
|
|
for name in unlink:
|
|
|
|
os.unlink(name)
|
|
|
|
#if test.test_support.verbose:
|
|
|
|
# zip_file = zipfile.ZipFile(zip_name, 'r')
|
|
|
|
# print 'Contents of %r:' % zip_name
|
|
|
|
# zip_file.printdir()
|
|
|
|
# zip_file.close()
|
|
|
|
return zip_name, os.path.join(zip_name, script_name_in_zip)
|