diff options
author | William Deegan <bill@baddogconsulting.com> | 2017-05-16 17:35:36 (GMT) |
---|---|---|
committer | William Deegan <bill@baddogconsulting.com> | 2017-05-16 17:35:36 (GMT) |
commit | 0821956ca661d728764062dd0ddc9971181116b3 (patch) | |
tree | 2edbe2df56c51c1be7e81bafdb6b607b8dcfe73d /QMTest/TestCmd.py | |
parent | 023b20eeeb87114afa2edcef6ea7af11ee51fe8d (diff) | |
download | SCons-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.py | 15 |
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) |