summaryrefslogtreecommitdiffstats
path: root/QMTest/TestCmd.py
diff options
context:
space:
mode:
authorWilliam Deegan <bill@baddogconsulting.com>2017-05-16 17:35:36 (GMT)
committerWilliam Deegan <bill@baddogconsulting.com>2017-05-16 17:35:36 (GMT)
commit0821956ca661d728764062dd0ddc9971181116b3 (patch)
tree2edbe2df56c51c1be7e81bafdb6b607b8dcfe73d /QMTest/TestCmd.py
parent023b20eeeb87114afa2edcef6ea7af11ee51fe8d (diff)
downloadSCons-0821956ca661d728764062dd0ddc9971181116b3.zip
SCons-0821956ca661d728764062dd0ddc9971181116b3.tar.gz
SCons-0821956ca661d728764062dd0ddc9971181116b3.tar.bz2
py2/3 set os.environ['PYTHONIOENCODING'] = 'utf-8' for py3 and win32. Otherwise piped stdout/stderr default to windows system encodeing cp1252 which will throw UnicodeUnicodeEncodeError when outputting non ascii (KANJI) which was causing failure in test/install/non-ascii-name.py
Diffstat (limited to 'QMTest/TestCmd.py')
-rw-r--r--QMTest/TestCmd.py15
1 files changed, 14 insertions, 1 deletions
diff --git a/QMTest/TestCmd.py b/QMTest/TestCmd.py
index 20f1f14..4b025d6 100644
--- a/QMTest/TestCmd.py
+++ b/QMTest/TestCmd.py
@@ -1364,11 +1364,18 @@ class TestCmd(object):
if timeout:
self.timer = threading.Timer(float(timeout), self._timeout)
self.timer.start()
+
+ if sys.version_info[0] == 3 and sys.platform == 'win32':
+ # Set this otherwist stdout/stderr pipes default to
+ # windows default locall cp1252 which will throw exception
+ # if using non-ascii characters.
+ # For example test/Install/non-ascii-name.py
+ os.environ['PYTHONIOENCODING'] = 'utf-8'
p = Popen(cmd,
stdin=stdin,
stdout=subprocess.PIPE,
stderr=stderr_value,
- universal_newlines=universal_newlines)
+ universal_newlines=False)
self.process = p
return p
@@ -1424,6 +1431,7 @@ class TestCmd(object):
stdin = stdin)
if is_List(stdin):
stdin = ''.join(stdin)
+
# TODO(sgk): figure out how to re-use the logic in the .finish()
# method above. Just calling it from here causes problems with
# subclasses that redefine .finish(). We could abstract this
@@ -1524,6 +1532,11 @@ class TestCmd(object):
is an absolute path name. The target is *not* assumed to be
under the temporary working directory.
"""
+ if sys.platform == 'win32':
+ # Skip this on windows as we're not enabling it due to
+ # it requiring user permissions which aren't always present
+ # and we don't have a good way to detect those permissions yet.
+ return
link = self.canonicalize(link)
try:
os.symlink(target, link)