aboutsummaryrefslogtreecommitdiff
path: root/setuptools/_distutils/tests/test_log.py
diff options
context:
space:
mode:
authorDan Willemsen <dwillemsen@google.com>2022-03-26 04:06:48 +0000
committerAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>2022-03-26 04:06:48 +0000
commite3ce094dab748df046ee1a7ab039ed6f48fafab3 (patch)
tree690b5fb2994f47324dd4298e676335d4555ee267 /setuptools/_distutils/tests/test_log.py
parentdf3578c2a35ac125ee592a3f800065e72f6e77c9 (diff)
parent5a8b6adcfa54d474a9ad1a772d65bf6716217993 (diff)
downloadsetuptools-e3ce094dab748df046ee1a7ab039ed6f48fafab3.tar.gz
Upgrade to setuptools 61.1.0 am: adad21eb06 am: 30dd327dfb am: d25f34ce2b am: 5a8b6adcfa
Original change: https://android-review.googlesource.com/c/platform/external/python/setuptools/+/2045746 Change-Id: Ia9263955741ff22662dc01ca557c179254efa6e0 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
Diffstat (limited to 'setuptools/_distutils/tests/test_log.py')
-rw-r--r--setuptools/_distutils/tests/test_log.py46
1 files changed, 46 insertions, 0 deletions
diff --git a/setuptools/_distutils/tests/test_log.py b/setuptools/_distutils/tests/test_log.py
new file mode 100644
index 0000000..ec2ae02
--- /dev/null
+++ b/setuptools/_distutils/tests/test_log.py
@@ -0,0 +1,46 @@
+"""Tests for distutils.log"""
+
+import io
+import sys
+import unittest
+from test.support import swap_attr, run_unittest
+
+from distutils import log
+
+class TestLog(unittest.TestCase):
+ def test_non_ascii(self):
+ # Issues #8663, #34421: test that non-encodable text is escaped with
+ # backslashreplace error handler and encodable non-ASCII text is
+ # output as is.
+ for errors in ('strict', 'backslashreplace', 'surrogateescape',
+ 'replace', 'ignore'):
+ with self.subTest(errors=errors):
+ stdout = io.TextIOWrapper(io.BytesIO(),
+ encoding='cp437', errors=errors)
+ stderr = io.TextIOWrapper(io.BytesIO(),
+ encoding='cp437', errors=errors)
+ old_threshold = log.set_threshold(log.DEBUG)
+ try:
+ with swap_attr(sys, 'stdout', stdout), \
+ swap_attr(sys, 'stderr', stderr):
+ log.debug('Dεbug\tMėssãge')
+ log.fatal('Fαtal\tÈrrōr')
+ finally:
+ log.set_threshold(old_threshold)
+
+ stdout.seek(0)
+ self.assertEqual(stdout.read().rstrip(),
+ 'Dεbug\tM?ss?ge' if errors == 'replace' else
+ 'Dεbug\tMssge' if errors == 'ignore' else
+ 'Dεbug\tM\\u0117ss\\xe3ge')
+ stderr.seek(0)
+ self.assertEqual(stderr.read().rstrip(),
+ 'Fαtal\t?rr?r' if errors == 'replace' else
+ 'Fαtal\trrr' if errors == 'ignore' else
+ 'Fαtal\t\\xc8rr\\u014dr')
+
+def test_suite():
+ return unittest.TestLoader().loadTestsFromTestCase(TestLog)
+
+if __name__ == "__main__":
+ run_unittest(test_suite())