[Python-checkins] cpython (merge 3.2 -> 3.3): Fix tests for issue #11159.

serhiy.storchaka python-checkins at python.org
Sat Feb 2 11:20:02 CET 2013


http://hg.python.org/cpython/rev/2bf01f03ff40
changeset:   81921:2bf01f03ff40
branch:      3.3
parent:      81917:f0135def8eac
parent:      81920:a7c074d9cbfb
user:        Serhiy Storchaka <storchaka at gmail.com>
date:        Sat Feb 02 12:17:30 2013 +0200
summary:
  Fix tests for issue #11159.

files:
  Lib/test/test_sax.py |  16 ++++++++++++++++
  1 files changed, 16 insertions(+), 0 deletions(-)


diff --git a/Lib/test/test_sax.py b/Lib/test/test_sax.py
--- a/Lib/test/test_sax.py
+++ b/Lib/test/test_sax.py
@@ -14,6 +14,7 @@
 from xml.sax.handler import feature_namespaces
 from xml.sax.xmlreader import InputSource, AttributesImpl, AttributesNSImpl
 from io import StringIO
+import os.path
 import shutil
 from test import support
 from test.support import findfile, run_unittest
@@ -27,6 +28,18 @@
 except UnicodeEncodeError:
     raise unittest.SkipTest("filename is not encodable to utf8")
 
+supports_nonascii_filenames = True
+if not os.path.supports_unicode_filenames:
+    try:
+        support.TESTFN_UNICODE.encode(support.TESTFN_ENCODING)
+    except (UnicodeError, TypeError):
+        # Either the file system encoding is None, or the file name
+        # cannot be encoded in the file system encoding.
+        supports_nonascii_filenames = False
+requires_nonascii_filenames = unittest.skipUnless(
+        supports_nonascii_filenames,
+        'Requires non-ascii filenames support')
+
 ns_uri = "http://www.python.org/xml-ns/saxtest/"
 
 class XmlTestBase(unittest.TestCase):
@@ -483,6 +496,7 @@
 
         self.assertEqual(result.getvalue(), xml_test_out)
 
+    @requires_nonascii_filenames
     def test_expat_file_nonascii(self):
         fname = support.TESTFN_UNICODE
         shutil.copyfile(TEST_XMLFILE, fname)
@@ -636,6 +650,7 @@
 
         self.assertEqual(result.getvalue(), xml_test_out)
 
+    @requires_nonascii_filenames
     def test_expat_inpsource_sysid_nonascii(self):
         fname = support.TESTFN_UNICODE
         shutil.copyfile(TEST_XMLFILE, fname)
@@ -724,6 +739,7 @@
         self.assertEqual(parser.getSystemId(), TEST_XMLFILE)
         self.assertEqual(parser.getPublicId(), None)
 
+    @requires_nonascii_filenames
     def test_expat_locator_withinfo_nonascii(self):
         fname = support.TESTFN_UNICODE
         shutil.copyfile(TEST_XMLFILE, fname)

-- 
Repository URL: http://hg.python.org/cpython


More information about the Python-checkins mailing list