From 1e0611b208d4efec016fcfd621accddb40f3af6a Mon Sep 17 00:00:00 2001 From: Fred Drake Date: Sat, 23 Dec 2000 22:12:07 +0000 Subject: [PATCH] The "context" parameter to the ExternalEntityRefParameter exposes internal information from the Expat library that is not part of its public API. Do not print this information as the format of the string may (and will) change as Expat evolves. Add additional tests to make sure the ParserCreate() function raises the right exceptions on illegal parameters. --- Lib/test/output/test_pyexpat | 15 ++++++++++++--- Lib/test/test_pyexpat.py | 33 ++++++++++++++++++++++++++++++++- 2 files changed, 44 insertions(+), 4 deletions(-) diff --git a/Lib/test/output/test_pyexpat b/Lib/test/output/test_pyexpat index 6aed69d41e3..4d9981cbbeb 100644 --- a/Lib/test/output/test_pyexpat +++ b/Lib/test/output/test_pyexpat @@ -30,7 +30,7 @@ Character data: End of CDATA section End element: 'sub2' -External entity ref: ('http://www.python.org/namespace=http://www.w3.org/XML/1998/namespace\014external_entity', None, 'entity.file', None) +External entity ref: (None, 'entity.file', None) End element: 'root' PI: @@ -60,7 +60,7 @@ Character data: End of CDATA section End element: u'sub2' -External entity ref: (u'http://www.python.org/namespace=http://www.w3.org/XML/1998/namespace\014external_entity', None, u'entity.file', None) +External entity ref: (None, u'entity.file', None) End element: u'root' PI: @@ -90,6 +90,15 @@ Character data: End of CDATA section End element: u'sub2' -External entity ref: (u'http://www.python.org/namespace=http://www.w3.org/XML/1998/namespace\014external_entity', None, u'entity.file', None) +External entity ref: (None, u'entity.file', None) End element: u'root' + +Testing constructor for proper handling of namespace_separator values: +Legal values tested o.k. +Caught expected TypeError: +ParserCreate, argument 2: expected string or None, int found +Caught expected ValueError: +namespace_separator must be one character, omitted, or None +Caught expected ValueError: +namespace_separator must be one character, omitted, or None diff --git a/Lib/test/test_pyexpat.py b/Lib/test/test_pyexpat.py index fae1849f923..0c400b4d6d1 100644 --- a/Lib/test/test_pyexpat.py +++ b/Lib/test/test_pyexpat.py @@ -50,7 +50,7 @@ class Outputter: def ExternalEntityRefHandler(self, *args): context, base, sysId, pubId = args - print 'External entity ref:', args + print 'External entity ref:', args[1:] return 1 def DefaultHandler(self, userData): @@ -150,3 +150,34 @@ except expat.error: print '** Line', parser.ErrorLineNumber print '** Column', parser.ErrorColumnNumber print '** Byte', parser.ErrorByteIndex + + +# Tests that make sure we get errors when the namespace_separator value +# is illegal, and that we don't for good values: +print +print "Testing constructor for proper handling of namespace_separator values:" +expat.ParserCreate() +expat.ParserCreate(namespace_separator=None) +expat.ParserCreate(namespace_separator=' ') +print "Legal values tested o.k." +try: + expat.ParserCreate(namespace_separator=42) +except TypeError, e: + print "Caught expected TypeError:" + print e +else: + print "Failed to catch expected TypeError." +try: + expat.ParserCreate(namespace_separator='too long') +except ValueError, e: + print "Caught expected ValueError:" + print e +else: + print "Failed to catch expected ValueError." +try: + expat.ParserCreate(namespace_separator='') # too short +except ValueError, e: + print "Caught expected ValueError:" + print e +else: + print "Failed to catch expected ValueError."