diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2013-02-02 08:31:17 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2013-02-02 08:31:17 (GMT) |
commit | d52023968afd0124b0812a4c8d5b194b19c6e979 (patch) | |
tree | b95577fa8fd54a80d7aaedb04c4c72b147d0f7fb | |
parent | 9cd864dcbf178e18d1e8370724218594757fddb0 (diff) | |
download | cpython-d52023968afd0124b0812a4c8d5b194b19c6e979.zip cpython-d52023968afd0124b0812a4c8d5b194b19c6e979.tar.gz cpython-d52023968afd0124b0812a4c8d5b194b19c6e979.tar.bz2 |
Issue #11159: Add tests for testing SAX parser support of non-ascii file names.
-rw-r--r-- | Lib/test/test_sax.py | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/Lib/test/test_sax.py b/Lib/test/test_sax.py index d6ed6db..7b989e8 100644 --- a/Lib/test/test_sax.py +++ b/Lib/test/test_sax.py @@ -14,6 +14,8 @@ from xml.sax.expatreader import create_parser from xml.sax.handler import feature_namespaces from xml.sax.xmlreader import InputSource, AttributesImpl, AttributesNSImpl from io import StringIO +import shutil +from test import support from test.support import findfile, run_unittest import unittest @@ -481,6 +483,20 @@ class ExpatReaderTest(XmlTestBase): self.assertEqual(result.getvalue(), xml_test_out) + def test_expat_file_nonascii(self): + fname = support.TESTFN_UNICODE + shutil.copyfile(TEST_XMLFILE, fname) + self.addCleanup(support.unlink, fname) + + parser = create_parser() + result = StringIO() + xmlgen = XMLGenerator(result) + + parser.setContentHandler(xmlgen) + parser.parse(open(fname)) + + self.assertEqual(result.getvalue(), xml_test_out) + # ===== DTDHandler support class TestDTDHandler: @@ -620,6 +636,20 @@ class ExpatReaderTest(XmlTestBase): self.assertEqual(result.getvalue(), xml_test_out) + def test_expat_inpsource_sysid_nonascii(self): + fname = support.TESTFN_UNICODE + shutil.copyfile(TEST_XMLFILE, fname) + self.addCleanup(support.unlink, fname) + + parser = create_parser() + result = StringIO() + xmlgen = XMLGenerator(result) + + parser.setContentHandler(xmlgen) + parser.parse(InputSource(fname)) + + self.assertEqual(result.getvalue(), xml_test_out) + def test_expat_inpsource_stream(self): parser = create_parser() result = StringIO() @@ -694,6 +724,20 @@ class ExpatReaderTest(XmlTestBase): self.assertEqual(parser.getSystemId(), TEST_XMLFILE) self.assertEqual(parser.getPublicId(), None) + def test_expat_locator_withinfo_nonascii(self): + fname = support.TESTFN_UNICODE + shutil.copyfile(TEST_XMLFILE, fname) + self.addCleanup(support.unlink, fname) + + result = StringIO() + xmlgen = XMLGenerator(result) + parser = create_parser() + parser.setContentHandler(xmlgen) + parser.parse(fname) + + self.assertEqual(parser.getSystemId(), fname) + self.assertEqual(parser.getPublicId(), None) + # =========================================================================== # |