mirror of
https://github.com/python/cpython.git
synced 2025-10-17 04:08:28 +00:00
Merged revisions 81359-81361 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k ........ r81359 | victor.stinner | 2010-05-19 19:00:07 +0200 (mer., 19 mai 2010) | 4 lines Issue #8663: distutils.log emulates backslashreplace error handler. Fix compilation in a non-ASCII directory if stdout encoding is ASCII (eg. if stdout is not a TTY). ........ r81360 | victor.stinner | 2010-05-19 19:11:19 +0200 (mer., 19 mai 2010) | 5 lines regrtest.py: call replace_stdout() before the first call to print() print("== ", os.getcwd()) fails if the current working directory is not ASCII whereas sys.stdout encoding is ASCII. ........ r81361 | victor.stinner | 2010-05-19 19:15:50 +0200 (mer., 19 mai 2010) | 2 lines Oops, add the new test_log.py for distutils test suite (missing part of r81359) ........
This commit is contained in:
parent
20c043b40c
commit
db19fb6bb1
4 changed files with 46 additions and 1 deletions
|
@ -27,6 +27,10 @@ class Log:
|
||||||
stream = sys.stderr
|
stream = sys.stderr
|
||||||
else:
|
else:
|
||||||
stream = sys.stdout
|
stream = sys.stdout
|
||||||
|
if stream.errors == 'strict':
|
||||||
|
# emulate backslashreplace error handler
|
||||||
|
encoding = stream.encoding
|
||||||
|
msg = msg.encode(encoding, "backslashreplace").decode(encoding)
|
||||||
stream.write('%s\n' % msg)
|
stream.write('%s\n' % msg)
|
||||||
stream.flush()
|
stream.flush()
|
||||||
|
|
||||||
|
|
36
Lib/distutils/tests/test_log.py
Normal file
36
Lib/distutils/tests/test_log.py
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
"""Tests for distutils.log"""
|
||||||
|
|
||||||
|
import sys
|
||||||
|
import unittest
|
||||||
|
from tempfile import NamedTemporaryFile
|
||||||
|
|
||||||
|
from distutils import log
|
||||||
|
|
||||||
|
class TestLog(unittest.TestCase):
|
||||||
|
def test_non_ascii(self):
|
||||||
|
# Issue #8663: test that non-ASCII text is escaped with
|
||||||
|
# backslashreplace error handler (stream use ASCII encoding and strict
|
||||||
|
# error handler)
|
||||||
|
old_stdout = sys.stdout
|
||||||
|
old_stderr = sys.stderr
|
||||||
|
try:
|
||||||
|
log.set_threshold(log.DEBUG)
|
||||||
|
with NamedTemporaryFile(mode="w+", encoding='ascii') as stdout, \
|
||||||
|
NamedTemporaryFile(mode="w+", encoding='ascii') as stderr:
|
||||||
|
sys.stdout = stdout
|
||||||
|
sys.stderr = stderr
|
||||||
|
log.debug("debug:\xe9")
|
||||||
|
log.fatal("fatal:\xe9")
|
||||||
|
stdout.seek(0)
|
||||||
|
self.assertEquals(stdout.read().rstrip(), "debug:\\xe9")
|
||||||
|
stderr.seek(0)
|
||||||
|
self.assertEquals(stderr.read().rstrip(), "fatal:\\xe9")
|
||||||
|
finally:
|
||||||
|
sys.stdout = old_stdout
|
||||||
|
sys.stderr = old_stderr
|
||||||
|
|
||||||
|
def test_suite():
|
||||||
|
return unittest.makeSuite(TestLog)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
unittest.main(defaultTest="test_suite")
|
|
@ -215,6 +215,8 @@ def main(tests=None, testdir=None, verbose=0, quiet=False, generate=False,
|
||||||
on the command line.
|
on the command line.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
replace_stdout()
|
||||||
|
|
||||||
support.record_original_stdout(sys.stdout)
|
support.record_original_stdout(sys.stdout)
|
||||||
try:
|
try:
|
||||||
opts, args = getopt.getopt(sys.argv[1:], 'hvgqxsSrf:lu:t:TD:NLR:wM:n',
|
opts, args = getopt.getopt(sys.argv[1:], 'hvgqxsSrf:lu:t:TD:NLR:wM:n',
|
||||||
|
@ -411,7 +413,6 @@ def main(tests=None, testdir=None, verbose=0, quiet=False, generate=False,
|
||||||
support.verbose = verbose # Tell tests to be moderately quiet
|
support.verbose = verbose # Tell tests to be moderately quiet
|
||||||
support.use_resources = use_resources
|
support.use_resources = use_resources
|
||||||
save_modules = sys.modules.keys()
|
save_modules = sys.modules.keys()
|
||||||
replace_stdout()
|
|
||||||
for test in tests:
|
for test in tests:
|
||||||
if not quiet:
|
if not quiet:
|
||||||
print(test)
|
print(test)
|
||||||
|
|
|
@ -43,6 +43,10 @@ Core and Builtins
|
||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #8663: distutils.log emulates backslashreplace error handler. Fix
|
||||||
|
compilation in a non-ASCII directory if stdout encoding is ASCII (eg. if
|
||||||
|
stdout is not a TTY).
|
||||||
|
|
||||||
- Issue #8688: Distutils now recalculates MANIFEST everytime.
|
- Issue #8688: Distutils now recalculates MANIFEST everytime.
|
||||||
|
|
||||||
- Issue #5099: subprocess.Popen.__del__ no longer references global objects
|
- Issue #5099: subprocess.Popen.__del__ no longer references global objects
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue