mirror of
				https://gitlab.gnome.org/GNOME/libxml2.git
				synced 2025-10-24 13:33:01 +03:00 
			
		
		
		
	update all tests for Python3 and Python2
This commit is contained in:
		| @@ -20,7 +20,7 @@ doc = libxml2.parseDoc( | |||||||
| elem = doc.getRootElement() | elem = doc.getRootElement() | ||||||
| attr = elem.hasNsProp('attr', 'http://abc.org') | attr = elem.hasNsProp('attr', 'http://abc.org') | ||||||
| if attr == None or attr.serialize()[:-1] != """<!ATTLIST test abc:attr CDATA #FIXED "def">""": | if attr == None or attr.serialize()[:-1] != """<!ATTLIST test abc:attr CDATA #FIXED "def">""": | ||||||
|     print "Failed to find defaulted attribute abc:attr" |     print("Failed to find defaulted attribute abc:attr") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| @@ -28,7 +28,7 @@ doc.freeDoc() | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -23,29 +23,29 @@ doc = libxml2.parseFile("tmp.xml") | |||||||
| comment = doc.children | comment = doc.children | ||||||
| if comment.type != "comment" or \ | if comment.type != "comment" or \ | ||||||
|    comment.content != "This is a generated document": |    comment.content != "This is a generated document": | ||||||
|    print "error rereading comment" |    print("error rereading comment") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| pi = comment.next | pi = comment.next | ||||||
| if pi.type != "pi" or pi.name != "test" or pi.content != "PI content": | if pi.type != "pi" or pi.name != "test" or pi.content != "PI content": | ||||||
|    print "error rereading PI" |    print("error rereading PI") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| root = pi.next | root = pi.next | ||||||
| if root.name != "doc": | if root.name != "doc": | ||||||
|    print "error rereading root" |    print("error rereading root") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| ns = root.ns() | ns = root.ns() | ||||||
| if ns.name != "my" or ns.content != "http://example.com/doc": | if ns.name != "my" or ns.content != "http://example.com/doc": | ||||||
|    print "error rereading namespace" |    print("error rereading namespace") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| elem = root.children | elem = root.children | ||||||
| if elem.name != "foo": | if elem.name != "foo": | ||||||
|    print "error rereading elem" |    print("error rereading elem") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| if elem.getBase(None) != "http://example.com/imgs": | if elem.getBase(None) != "http://example.com/imgs": | ||||||
|    print "error rereading base" |    print("error rereading base") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| if elem.prop("img") != "image.gif": | if elem.prop("img") != "image.gif": | ||||||
|    print "error rereading property" |    print("error rereading property") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
|  |  | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| @@ -53,7 +53,7 @@ doc.freeDoc() | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -17,25 +17,25 @@ foonode2 = root.children | |||||||
|  |  | ||||||
| # Now check that [in]equality tests work ok | # Now check that [in]equality tests work ok | ||||||
| if not ( foonode1 == foonode2 ): | if not ( foonode1 == foonode2 ): | ||||||
|     print "Error comparing nodes with ==, nodes should be equal but are unequal" |     print("Error comparing nodes with ==, nodes should be equal but are unequal") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if not ( foonode1 != root ): | if not ( foonode1 != root ): | ||||||
|     print "Error comparing nodes with ==, nodes should not be equal but are equal" |     print("Error comparing nodes with ==, nodes should not be equal but are equal") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if not ( foonode1 != root ): | if not ( foonode1 != root ): | ||||||
|     print "Error comparing nodes with !=, nodes should not be equal but are equal" |     print("Error comparing nodes with !=, nodes should not be equal but are equal") | ||||||
| if ( foonode1 != foonode2 ): | if ( foonode1 != foonode2 ): | ||||||
|     print "Error comparing nodes with !=, nodes should be equal but are unequal" |     print("Error comparing nodes with !=, nodes should be equal but are unequal") | ||||||
|  |  | ||||||
| # Next check that the hash function for the objects also works ok | # Next check that the hash function for the objects also works ok | ||||||
| if not (hash(foonode1) == hash(foonode2)): | if not (hash(foonode1) == hash(foonode2)): | ||||||
|     print "Error hash values for two equal nodes are different" |     print("Error hash values for two equal nodes are different") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if not (hash(foonode1) != hash(root)): | if not (hash(foonode1) != hash(root)): | ||||||
|     print "Error hash values for two unequal nodes are not different" |     print("Error hash values for two unequal nodes are not different") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if hash(foonode1) == hash(root): | if hash(foonode1) == hash(root): | ||||||
|     print "Error hash values for two unequal nodes are equal" |     print("Error hash values for two unequal nodes are equal") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # Basic tests successful | # Basic tests successful | ||||||
| @@ -44,7 +44,7 @@ doc.freeDoc() | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -23,7 +23,7 @@ s = """<x xmlns="foo"></y>""" | |||||||
| parserCtxt = libxml2.createPushParser(None,"",0,"test.xml") | parserCtxt = libxml2.createPushParser(None,"",0,"test.xml") | ||||||
| parserCtxt.setErrorHandler(callback, "-->") | parserCtxt.setErrorHandler(callback, "-->") | ||||||
| if parserCtxt.getErrorHandler() != (callback,"-->"): | if parserCtxt.getErrorHandler() != (callback,"-->"): | ||||||
|     print "getErrorHandler failed" |     print("getErrorHandler failed") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| parserCtxt.parseChunk(s,len(s),1) | parserCtxt.parseChunk(s,len(s),1) | ||||||
| doc = parserCtxt.doc() | doc = parserCtxt.doc() | ||||||
| @@ -31,9 +31,9 @@ doc.freeDoc() | |||||||
| parserCtxt = None | parserCtxt = None | ||||||
|  |  | ||||||
| if err != expect: | if err != expect: | ||||||
|     print "error" |     print("error") | ||||||
|     print "received %s" %(err) |     print("received %s" %(err)) | ||||||
|     print "expected %s" %(expect) |     print("expected %s" %(expect)) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| i = 10000 | i = 10000 | ||||||
| @@ -50,7 +50,7 @@ while i > 0: | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -35,14 +35,14 @@ source.freeDoc() | |||||||
| # check the resulting tree | # check the resulting tree | ||||||
| str = dest.serialize() | str = dest.serialize() | ||||||
| if str != """<root xmlns:foobar="http://example.org/bar" xmlns:default="http://example.org/include" xmlns:foo="http://example.org/foo"><default:fragment><foo:elem bar="tricky"/></default:fragment></root>""": | if str != """<root xmlns:foobar="http://example.org/bar" xmlns:default="http://example.org/include" xmlns:foo="http://example.org/foo"><default:fragment><foo:elem bar="tricky"/></default:fragment></root>""": | ||||||
|     print "reconciliateNs() failed" |     print("reconciliateNs() failed") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| target.freeDoc() | target.freeDoc() | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ ctxt = libxml2.newValidCtxt() | |||||||
| doc = libxml2.parseDoc(instance) | doc = libxml2.parseDoc(instance) | ||||||
| ret = doc.validateDtd(ctxt, dtd) | ret = doc.validateDtd(ctxt, dtd) | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "error doing DTD validation" |     print("error doing DTD validation") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| @@ -25,8 +25,8 @@ del ctxt | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|  |  | ||||||
|   | |||||||
| @@ -24,13 +24,13 @@ except libxml2.parserError: | |||||||
|     got_exc = 1 |     got_exc = 1 | ||||||
|  |  | ||||||
| if got_exc == 0: | if got_exc == 0: | ||||||
|     print "Failed to get a parser exception" |     print("Failed to get a parser exception") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| if err != expect: | if err != expect: | ||||||
|     print "error" |     print("error") | ||||||
|     print "received %s" %(err) |     print("received %s" %(err)) | ||||||
|     print "expected %s" %(expect) |     print("expected %s" %(expect)) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| i = 10000 | i = 10000 | ||||||
| @@ -45,7 +45,7 @@ while i > 0: | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -1,14 +1,19 @@ | |||||||
| #!/usr/bin/python -u | #!/usr/bin/python -u | ||||||
| import sys | import sys | ||||||
| import libxml2 | import libxml2 | ||||||
| import StringIO | try: | ||||||
|  |     import StringIO | ||||||
|  |     str_io = StringIO.StringIO | ||||||
|  | except: | ||||||
|  |     import io | ||||||
|  |     str_io = io.StringIO | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.debugMemory(1) | libxml2.debugMemory(1) | ||||||
|  |  | ||||||
| i = 0 | i = 0 | ||||||
| while i < 5000: | while i < 5000: | ||||||
|     f = StringIO.StringIO("foobar") |     f = str_io("foobar") | ||||||
|     buf = libxml2.inputBuffer(f) |     buf = libxml2.inputBuffer(f) | ||||||
|     i = i + 1 |     i = i + 1 | ||||||
|  |  | ||||||
| @@ -18,8 +23,8 @@ del buf | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|  |  | ||||||
|   | |||||||
| @@ -20,16 +20,16 @@ class callback: | |||||||
|     def startDocument(self): |     def startDocument(self): | ||||||
|         global ctxt |         global ctxt | ||||||
|         if ctxt.byteConsumed() != self.startd: |         if ctxt.byteConsumed() != self.startd: | ||||||
|             print "document start at wrong index: %d expecting %d\n" % ( |             print("document start at wrong index: %d expecting %d\n" % ( | ||||||
|                   ctxt.byteConsumed(), self.startd) |                   ctxt.byteConsumed(), self.startd)) | ||||||
|             sys.exit(1) |             sys.exit(1) | ||||||
|  |  | ||||||
|     def endDocument(self): |     def endDocument(self): | ||||||
|         global ctxt |         global ctxt | ||||||
|         expect = self.ende + self.delta * (self.count - 1) + self.endd |         expect = self.ende + self.delta * (self.count - 1) + self.endd | ||||||
|         if ctxt.byteConsumed() != expect: |         if ctxt.byteConsumed() != expect: | ||||||
|             print "document end at wrong index: %d expecting %d\n" % ( |             print("document end at wrong index: %d expecting %d\n" % ( | ||||||
|                   ctxt.byteConsumed(), expect) |                   ctxt.byteConsumed(), expect)) | ||||||
|             sys.exit(1) |             sys.exit(1) | ||||||
|  |  | ||||||
|     def startElement(self, tag, attrs): |     def startElement(self, tag, attrs): | ||||||
| @@ -37,8 +37,8 @@ class callback: | |||||||
|         if tag == "bar1": |         if tag == "bar1": | ||||||
|             expect = self.starte + self.delta * self.count |             expect = self.starte + self.delta * self.count | ||||||
|             if ctxt.byteConsumed() != expect: |             if ctxt.byteConsumed() != expect: | ||||||
|                 print "element start at wrong index: %d expecting %d\n" % ( |                 print("element start at wrong index: %d expecting %d\n" % ( | ||||||
|                    ctxt.byteConsumed(), expect) |                    ctxt.byteConsumed(), expect)) | ||||||
|                 sys.exit(1) |                 sys.exit(1) | ||||||
|              |              | ||||||
|  |  | ||||||
| @@ -47,8 +47,8 @@ class callback: | |||||||
|         if tag == "bar1": |         if tag == "bar1": | ||||||
|             expect = self.ende + self.delta * self.count |             expect = self.ende + self.delta * self.count | ||||||
|             if ctxt.byteConsumed() != expect: |             if ctxt.byteConsumed() != expect: | ||||||
|                 print "element end at wrong index: %d expecting %d\n" % ( |                 print("element end at wrong index: %d expecting %d\n" % ( | ||||||
|                       ctxt.byteConsumed(), expect) |                       ctxt.byteConsumed(), expect)) | ||||||
|                 sys.exit(1) |                 sys.exit(1) | ||||||
|             self.count = self.count + 1 |             self.count = self.count + 1 | ||||||
|  |  | ||||||
| @@ -107,7 +107,7 @@ ctxt=None | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -3,8 +3,13 @@ | |||||||
| # This tests custom input callbacks | # This tests custom input callbacks | ||||||
| # | # | ||||||
| import sys | import sys | ||||||
| import StringIO |  | ||||||
| import libxml2 | import libxml2 | ||||||
|  | try: | ||||||
|  |     import StringIO | ||||||
|  |     str_io = StringIO.StringIO | ||||||
|  | except: | ||||||
|  |     import io | ||||||
|  |     str_io = io.StringIO | ||||||
|  |  | ||||||
| # We implement a new scheme, py://strings/ that will reference this dictionary | # We implement a new scheme, py://strings/ that will reference this dictionary | ||||||
| pystrings = { | pystrings = { | ||||||
| @@ -36,7 +41,7 @@ def my_input_cb(URI): | |||||||
|     path = URI[len(prefix):] |     path = URI[len(prefix):] | ||||||
|     if path not in pystrings: |     if path not in pystrings: | ||||||
|         return None |         return None | ||||||
|     return StringIO.StringIO(pystrings[path]) |     return str_io(pystrings[path]) | ||||||
|  |  | ||||||
|  |  | ||||||
| def run_test(desc, docpath, catalog, exp_status="verified", exp_err=[], test_callback=None, | def run_test(desc, docpath, catalog, exp_status="verified", exp_err=[], test_callback=None, | ||||||
| @@ -68,14 +73,14 @@ def run_test(desc, docpath, catalog, exp_status="verified", exp_err=[], test_cal | |||||||
|         actual_status = "not loaded" |         actual_status = "not loaded" | ||||||
|  |  | ||||||
|     if actual_status != exp_status: |     if actual_status != exp_status: | ||||||
|         print "Test '%s' failed: expect status '%s', actual '%s'" % (desc, exp_status, actual_status) |         print("Test '%s' failed: expect status '%s', actual '%s'" % (desc, exp_status, actual_status)) | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|     elif actual_err != exp_err: |     elif actual_err != exp_err: | ||||||
|         print "Test '%s' failed" % desc |         print("Test '%s' failed" % desc) | ||||||
|         print "Expect errors:" |         print("Expect errors:") | ||||||
|         for s,m in exp_err: print "  [%2d] '%s'" % (s,m) |         for s,m in exp_err: print("  [%2d] '%s'" % (s,m)) | ||||||
|         print "Actual errors:" |         print("Actual errors:") | ||||||
|         for s,m in actual_err: print "  [%2d] '%s'" % (s,m) |         for s,m in actual_err: print("  [%2d] '%s'" % (s,m)) | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -128,7 +133,7 @@ run_test(desc="Loading using standard i/o after unregistering callback", | |||||||
| try: | try: | ||||||
|     while True: |     while True: | ||||||
|         libxml2.popInputCallbacks() |         libxml2.popInputCallbacks() | ||||||
| except IndexError, e: | except IndexError as e: | ||||||
|     pass |     pass | ||||||
|  |  | ||||||
| run_test(desc="Loading using standard i/o after unregistering all callbacks", | run_test(desc="Loading using standard i/o after unregistering all callbacks", | ||||||
| @@ -139,5 +144,5 @@ run_test(desc="Loading using standard i/o after unregistering all callbacks", | |||||||
|             (-1, "failed to load external entity \"tst.xml\"\n") |             (-1, "failed to load external entity \"tst.xml\"\n") | ||||||
|             ]) |             ]) | ||||||
|  |  | ||||||
| print "OK" | print("OK") | ||||||
| sys.exit(0); | sys.exit(0); | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ def checkNamespaceDefs(node, count): | |||||||
|     nsList = list(namespaceDefs(node)) |     nsList = list(namespaceDefs(node)) | ||||||
|     #print nsList |     #print nsList | ||||||
|     if len(nsList) != count : |     if len(nsList) != count : | ||||||
|         raise Exception, "Error: saw %d namespace declarations.  Expected %d" % (len(nsList), count) |         raise Exception("Error: saw %d namespace declarations.  Expected %d" % (len(nsList), count)) | ||||||
|      |      | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.debugMemory(1) | libxml2.debugMemory(1) | ||||||
| @@ -56,7 +56,7 @@ doc.freeDoc() | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -1,17 +1,22 @@ | |||||||
| #!/usr/bin/python -u | #!/usr/bin/python -u | ||||||
| import sys | import sys | ||||||
| import libxml2 | import libxml2 | ||||||
| import StringIO | try: | ||||||
|  |     import StringIO | ||||||
|  |     str_io = StringIO.StringIO | ||||||
|  | except: | ||||||
|  |     import io | ||||||
|  |     str_io = io.StringIO | ||||||
|  |  | ||||||
| def testSimpleBufferWrites(): | def testSimpleBufferWrites(): | ||||||
|     f = StringIO.StringIO() |     f = str_io() | ||||||
|     buf = libxml2.createOutputBuffer(f, "ISO-8859-1") |     buf = libxml2.createOutputBuffer(f, "ISO-8859-1") | ||||||
|     buf.write(3, "foo") |     buf.write(3, "foo") | ||||||
|     buf.writeString("bar") |     buf.writeString("bar") | ||||||
|     buf.close() |     buf.close() | ||||||
|  |  | ||||||
|     if f.getvalue() != "foobar": |     if f.getvalue() != "foobar": | ||||||
|         print "Failed to save to StringIO" |         print("Failed to save to StringIO") | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|  |  | ||||||
| def testSaveDocToBuffer(): | def testSaveDocToBuffer(): | ||||||
| @@ -23,15 +28,15 @@ def testSaveDocToBuffer(): | |||||||
| <?xml version="1.0" encoding="UTF-8"?> | <?xml version="1.0" encoding="UTF-8"?> | ||||||
| <foo>Hello</foo> | <foo>Hello</foo> | ||||||
| ''' | ''' | ||||||
|     f = StringIO.StringIO() |     f = str_io() | ||||||
|     buf = libxml2.createOutputBuffer(f, 'UTF-8') |     buf = libxml2.createOutputBuffer(f, 'UTF-8') | ||||||
|     doc = libxml2.parseDoc(input) |     doc = libxml2.parseDoc(input) | ||||||
|     doc.saveFileTo(buf, 'UTF-8') |     doc.saveFileTo(buf, 'UTF-8') | ||||||
|     doc.freeDoc() |     doc.freeDoc() | ||||||
|     if f.getvalue() != expected: |     if f.getvalue() != expected: | ||||||
|         print 'xmlDoc.saveFileTo() call failed.' |         print('xmlDoc.saveFileTo() call failed.') | ||||||
|         print '     got: %s' % repr(f.getvalue()) |         print('     got: %s' % repr(f.getvalue())) | ||||||
|         print 'expected: %s' % repr(expected) |         print('expected: %s' % repr(expected)) | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|  |  | ||||||
| def testSaveFormattedDocToBuffer(): | def testSaveFormattedDocToBuffer(): | ||||||
| @@ -49,13 +54,13 @@ def testSaveFormattedDocToBuffer(): | |||||||
| ''') | ''') | ||||||
|     doc = libxml2.parseDoc(input) |     doc = libxml2.parseDoc(input) | ||||||
|     for i in (0, 1): |     for i in (0, 1): | ||||||
|         f = StringIO.StringIO() |         f = str_io() | ||||||
|         buf = libxml2.createOutputBuffer(f, 'UTF-8') |         buf = libxml2.createOutputBuffer(f, 'UTF-8') | ||||||
|         doc.saveFormatFileTo(buf, 'UTF-8', i) |         doc.saveFormatFileTo(buf, 'UTF-8', i) | ||||||
|         if f.getvalue() != expected[i]: |         if f.getvalue() != expected[i]: | ||||||
|             print 'xmlDoc.saveFormatFileTo() call failed.' |             print('xmlDoc.saveFormatFileTo() call failed.') | ||||||
|             print '     got: %s' % repr(f.getvalue()) |             print('     got: %s' % repr(f.getvalue())) | ||||||
|             print 'expected: %s' % repr(expected[i]) |             print('expected: %s' % repr(expected[i])) | ||||||
|             sys.exit(1) |             sys.exit(1) | ||||||
|     doc.freeDoc() |     doc.freeDoc() | ||||||
|  |  | ||||||
| @@ -69,22 +74,22 @@ def testSaveIntoOutputBuffer(): | |||||||
| <?xml version="1.0" encoding="UTF-8"?> | <?xml version="1.0" encoding="UTF-8"?> | ||||||
| <foo>Hello</foo> | <foo>Hello</foo> | ||||||
| ''' | ''' | ||||||
|     f = StringIO.StringIO() |     f = str_io() | ||||||
|     doc = libxml2.parseDoc(input) |     doc = libxml2.parseDoc(input) | ||||||
|     buf = libxml2.createOutputBuffer(f, 'UTF-8') |     buf = libxml2.createOutputBuffer(f, 'UTF-8') | ||||||
|     buf.saveFileTo(doc, 'UTF-8') |     buf.saveFileTo(doc, 'UTF-8') | ||||||
|     if f.getvalue() != expected: |     if f.getvalue() != expected: | ||||||
|         print 'outputBuffer.saveFileTo() call failed.' |         print('outputBuffer.saveFileTo() call failed.') | ||||||
|         print '     got: %s' % repr(f.getvalue()) |         print('     got: %s' % repr(f.getvalue())) | ||||||
|         print 'expected: %s' % repr(expected) |         print('expected: %s' % repr(expected)) | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|     f = StringIO.StringIO() |     f = str_io() | ||||||
|     buf = libxml2.createOutputBuffer(f, 'UTF-8') |     buf = libxml2.createOutputBuffer(f, 'UTF-8') | ||||||
|     buf.saveFormatFileTo(doc, 'UTF-8', 1) |     buf.saveFormatFileTo(doc, 'UTF-8', 1) | ||||||
|     if f.getvalue() != expected: |     if f.getvalue() != expected: | ||||||
|         print 'outputBuffer.saveFormatFileTo() call failed.' |         print('outputBuffer.saveFormatFileTo() call failed.') | ||||||
|         print '     got: %s' % repr(f.getvalue()) |         print('     got: %s' % repr(f.getvalue())) | ||||||
|         print 'expected: %s' % repr(expected) |         print('expected: %s' % repr(expected)) | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|     doc.freeDoc() |     doc.freeDoc() | ||||||
|  |  | ||||||
| @@ -99,7 +104,7 @@ if __name__ == '__main__': | |||||||
|  |  | ||||||
|     libxml2.cleanupParser() |     libxml2.cleanupParser() | ||||||
|     if libxml2.debugMemory(1) == 0: |     if libxml2.debugMemory(1) == 0: | ||||||
|         print "OK" |         print("OK") | ||||||
|     else: |     else: | ||||||
|         print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |         print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|         libxml2.dumpMemory() |         libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -10,11 +10,11 @@ ctxt.parseChunk("/>", 2, 1) | |||||||
| doc = ctxt.doc() | doc = ctxt.doc() | ||||||
| ctxt=None | ctxt=None | ||||||
| if doc.name != "test.xml": | if doc.name != "test.xml": | ||||||
|     print "document name error" |     print("document name error") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| root = doc.children | root = doc.children | ||||||
| if root.name != "foo": | if root.name != "foo": | ||||||
|     print "root element name error" |     print("root element name error") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| i = 10000 | i = 10000 | ||||||
| @@ -29,7 +29,7 @@ ctxt=None | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -51,14 +51,14 @@ ctxt=None | |||||||
|  |  | ||||||
| reference = "startDocument:startElement foo {'url': 'tst'}:characters: bar:endElement foo:endDocument:" | reference = "startDocument:startElement foo {'url': 'tst'}:characters: bar:endElement foo:endDocument:" | ||||||
| if log != reference: | if log != reference: | ||||||
|     print "Error got: %s" % log |     print("Error got: %s" % log) | ||||||
|     print "Exprected: %s" % reference |     print("Exprected: %s" % reference) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -52,14 +52,14 @@ ctxt=None | |||||||
| reference = """startDocument:startElement html None:startElement body None:startElement foo {'url': 'tst'}:error: Tag foo invalid | reference = """startDocument:startElement html None:startElement body None:startElement foo {'url': 'tst'}:error: Tag foo invalid | ||||||
| :characters: bar:endElement foo:endElement body:endElement html:endDocument:""" | :characters: bar:endElement foo:endElement body:endElement html:endDocument:""" | ||||||
| if log != reference: | if log != reference: | ||||||
|     print "Error got: %s" % log |     print("Error got: %s" % log) | ||||||
|     print "Exprected: %s" % reference |     print("Exprected: %s" % reference) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -4,91 +4,96 @@ | |||||||
| # this tests the basic APIs of the XmlTextReader interface | # this tests the basic APIs of the XmlTextReader interface | ||||||
| # | # | ||||||
| import libxml2 | import libxml2 | ||||||
| import StringIO |  | ||||||
| import sys | import sys | ||||||
|  | try: | ||||||
|  |     import StringIO | ||||||
|  |     str_io = StringIO.StringIO | ||||||
|  | except: | ||||||
|  |     import io | ||||||
|  |     str_io = io.StringIO | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.debugMemory(1) | libxml2.debugMemory(1) | ||||||
|  |  | ||||||
| f = StringIO.StringIO("""<a><b b1="b1"/><c>content of c</c></a>""") | f = str_io("""<a><b b1="b1"/><c>content of c</c></a>""") | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("test1") | reader = input.newTextReader("test1") | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test1: Error reading to first element" |     print("test1: Error reading to first element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "a" or reader.IsEmptyElement() != 0 or \ | if reader.Name() != "a" or reader.IsEmptyElement() != 0 or \ | ||||||
|    reader.NodeType() != 1 or reader.HasAttributes() != 0: |    reader.NodeType() != 1 or reader.HasAttributes() != 0: | ||||||
|     print "test1: Error reading the first element" |     print("test1: Error reading the first element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test1: Error reading to second element" |     print("test1: Error reading to second element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "b" or reader.IsEmptyElement() != 1 or \ | if reader.Name() != "b" or reader.IsEmptyElement() != 1 or \ | ||||||
|    reader.NodeType() != 1 or reader.HasAttributes() != 1: |    reader.NodeType() != 1 or reader.HasAttributes() != 1: | ||||||
|     print "test1: Error reading the second element" |     print("test1: Error reading the second element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test1: Error reading to third element" |     print("test1: Error reading to third element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "c" or reader.IsEmptyElement() != 0 or \ | if reader.Name() != "c" or reader.IsEmptyElement() != 0 or \ | ||||||
|    reader.NodeType() != 1 or reader.HasAttributes() != 0: |    reader.NodeType() != 1 or reader.HasAttributes() != 0: | ||||||
|     print "test1: Error reading the third element" |     print("test1: Error reading the third element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test1: Error reading to text node" |     print("test1: Error reading to text node") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "#text" or reader.IsEmptyElement() != 0 or \ | if reader.Name() != "#text" or reader.IsEmptyElement() != 0 or \ | ||||||
|    reader.NodeType() != 3 or reader.HasAttributes() != 0 or \ |    reader.NodeType() != 3 or reader.HasAttributes() != 0 or \ | ||||||
|    reader.Value() != "content of c": |    reader.Value() != "content of c": | ||||||
|     print "test1: Error reading the text node" |     print("test1: Error reading the text node") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test1: Error reading to end of third element" |     print("test1: Error reading to end of third element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "c" or reader.IsEmptyElement() != 0 or \ | if reader.Name() != "c" or reader.IsEmptyElement() != 0 or \ | ||||||
|    reader.NodeType() != 15 or reader.HasAttributes() != 0: |    reader.NodeType() != 15 or reader.HasAttributes() != 0: | ||||||
|     print "test1: Error reading the end of third element" |     print("test1: Error reading the end of third element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test1: Error reading to end of first element" |     print("test1: Error reading to end of first element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "a" or reader.IsEmptyElement() != 0 or \ | if reader.Name() != "a" or reader.IsEmptyElement() != 0 or \ | ||||||
|    reader.NodeType() != 15 or reader.HasAttributes() != 0: |    reader.NodeType() != 15 or reader.HasAttributes() != 0: | ||||||
|     print "test1: Error reading the end of first element" |     print("test1: Error reading the end of first element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "test1: Error reading to end of document" |     print("test1: Error reading to end of document") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| # example from the XmlTextReader docs | # example from the XmlTextReader docs | ||||||
| # | # | ||||||
| f = StringIO.StringIO("""<test xmlns:dt="urn:datatypes" dt:type="int"/>""") | f = str_io("""<test xmlns:dt="urn:datatypes" dt:type="int"/>""") | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("test2") | reader = input.newTextReader("test2") | ||||||
|  |  | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "Error reading test element" |     print("Error reading test element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.GetAttributeNo(0) != "urn:datatypes" or \ | if reader.GetAttributeNo(0) != "urn:datatypes" or \ | ||||||
|    reader.GetAttributeNo(1) != "int" or \ |    reader.GetAttributeNo(1) != "int" or \ | ||||||
|    reader.GetAttributeNs("type", "urn:datatypes") != "int" or \ |    reader.GetAttributeNs("type", "urn:datatypes") != "int" or \ | ||||||
|    reader.GetAttribute("dt:type") != "int": |    reader.GetAttribute("dt:type") != "int": | ||||||
|     print "error reading test attributes" |     print("error reading test attributes") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| # example from the XmlTextReader docs | # example from the XmlTextReader docs | ||||||
| # | # | ||||||
| f = StringIO.StringIO("""<root xmlns:a="urn:456"> | f = str_io("""<root xmlns:a="urn:456"> | ||||||
| <item> | <item> | ||||||
| <ref href="a:b"/> | <ref href="a:b"/> | ||||||
| </item> | </item> | ||||||
| @@ -100,203 +105,203 @@ ret = reader.Read() | |||||||
| while ret == 1: | while ret == 1: | ||||||
|     if reader.Name() == "ref": |     if reader.Name() == "ref": | ||||||
|         if reader.LookupNamespace("a") != "urn:456": |         if reader.LookupNamespace("a") != "urn:456": | ||||||
|             print "error resolving namespace prefix" |             print("error resolving namespace prefix") | ||||||
|             sys.exit(1) |             sys.exit(1) | ||||||
|         break |         break | ||||||
|     ret = reader.Read() |     ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "Error finding the ref element" |     print("Error finding the ref element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| # Home made example for the various attribute access functions | # Home made example for the various attribute access functions | ||||||
| # | # | ||||||
| f = StringIO.StringIO("""<testattr xmlns="urn:1" xmlns:a="urn:2" b="b" a:b="a:b"/>""") | f = str_io("""<testattr xmlns="urn:1" xmlns:a="urn:2" b="b" a:b="a:b"/>""") | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("test4") | reader = input.newTextReader("test4") | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "Error reading the testattr element" |     print("Error reading the testattr element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| # | # | ||||||
| # Attribute exploration by index | # Attribute exploration by index | ||||||
| # | # | ||||||
| if reader.MoveToAttributeNo(0) != 1: | if reader.MoveToAttributeNo(0) != 1: | ||||||
|     print "Failed moveToAttribute(0)" |     print("Failed moveToAttribute(0)") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "urn:1": | if reader.Value() != "urn:1": | ||||||
|     print "Failed to read attribute(0)" |     print("Failed to read attribute(0)") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "xmlns": | if reader.Name() != "xmlns": | ||||||
|     print "Failed to read attribute(0) name" |     print("Failed to read attribute(0) name") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.MoveToAttributeNo(1) != 1: | if reader.MoveToAttributeNo(1) != 1: | ||||||
|     print "Failed moveToAttribute(1)" |     print("Failed moveToAttribute(1)") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "urn:2": | if reader.Value() != "urn:2": | ||||||
|     print "Failed to read attribute(1)" |     print("Failed to read attribute(1)") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "xmlns:a": | if reader.Name() != "xmlns:a": | ||||||
|     print "Failed to read attribute(1) name" |     print("Failed to read attribute(1) name") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.MoveToAttributeNo(2) != 1: | if reader.MoveToAttributeNo(2) != 1: | ||||||
|     print "Failed moveToAttribute(2)" |     print("Failed moveToAttribute(2)") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "b": | if reader.Value() != "b": | ||||||
|     print "Failed to read attribute(2)" |     print("Failed to read attribute(2)") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "b": | if reader.Name() != "b": | ||||||
|     print "Failed to read attribute(2) name" |     print("Failed to read attribute(2) name") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.MoveToAttributeNo(3) != 1: | if reader.MoveToAttributeNo(3) != 1: | ||||||
|     print "Failed moveToAttribute(3)" |     print("Failed moveToAttribute(3)") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "a:b": | if reader.Value() != "a:b": | ||||||
|     print "Failed to read attribute(3)" |     print("Failed to read attribute(3)") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "a:b": | if reader.Name() != "a:b": | ||||||
|     print "Failed to read attribute(3) name" |     print("Failed to read attribute(3) name") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| # | # | ||||||
| # Attribute exploration by name | # Attribute exploration by name | ||||||
| # | # | ||||||
| if reader.MoveToAttribute("xmlns") != 1: | if reader.MoveToAttribute("xmlns") != 1: | ||||||
|     print "Failed moveToAttribute('xmlns')" |     print("Failed moveToAttribute('xmlns')") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "urn:1": | if reader.Value() != "urn:1": | ||||||
|     print "Failed to read attribute('xmlns')" |     print("Failed to read attribute('xmlns')") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.MoveToAttribute("xmlns:a") != 1: | if reader.MoveToAttribute("xmlns:a") != 1: | ||||||
|     print "Failed moveToAttribute('xmlns')" |     print("Failed moveToAttribute('xmlns')") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "urn:2": | if reader.Value() != "urn:2": | ||||||
|     print "Failed to read attribute('xmlns:a')" |     print("Failed to read attribute('xmlns:a')") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.MoveToAttribute("b") != 1: | if reader.MoveToAttribute("b") != 1: | ||||||
|     print "Failed moveToAttribute('b')" |     print("Failed moveToAttribute('b')") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "b": | if reader.Value() != "b": | ||||||
|     print "Failed to read attribute('b')" |     print("Failed to read attribute('b')") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.MoveToAttribute("a:b") != 1: | if reader.MoveToAttribute("a:b") != 1: | ||||||
|     print "Failed moveToAttribute('a:b')" |     print("Failed moveToAttribute('a:b')") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "a:b": | if reader.Value() != "a:b": | ||||||
|     print "Failed to read attribute('a:b')" |     print("Failed to read attribute('a:b')") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.MoveToAttributeNs("b", "urn:2") != 1: | if reader.MoveToAttributeNs("b", "urn:2") != 1: | ||||||
|     print "Failed moveToAttribute('b', 'urn:2')" |     print("Failed moveToAttribute('b', 'urn:2')") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "a:b": | if reader.Value() != "a:b": | ||||||
|     print "Failed to read attribute('b', 'urn:2')" |     print("Failed to read attribute('b', 'urn:2')") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| # | # | ||||||
| # Go back and read in sequence | # Go back and read in sequence | ||||||
| # | # | ||||||
| if reader.MoveToElement() != 1: | if reader.MoveToElement() != 1: | ||||||
|     print "Failed to move back to element" |     print("Failed to move back to element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.MoveToFirstAttribute() != 1: | if reader.MoveToFirstAttribute() != 1: | ||||||
|     print "Failed to move to first attribute" |     print("Failed to move to first attribute") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "urn:1": | if reader.Value() != "urn:1": | ||||||
|     print "Failed to read attribute(0)" |     print("Failed to read attribute(0)") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "xmlns": | if reader.Name() != "xmlns": | ||||||
|     print "Failed to read attribute(0) name" |     print("Failed to read attribute(0) name") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.MoveToNextAttribute() != 1: | if reader.MoveToNextAttribute() != 1: | ||||||
|     print "Failed to move to next attribute" |     print("Failed to move to next attribute") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "urn:2": | if reader.Value() != "urn:2": | ||||||
|     print "Failed to read attribute(1)" |     print("Failed to read attribute(1)") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "xmlns:a": | if reader.Name() != "xmlns:a": | ||||||
|     print "Failed to read attribute(1) name" |     print("Failed to read attribute(1) name") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.MoveToNextAttribute() != 1: | if reader.MoveToNextAttribute() != 1: | ||||||
|     print "Failed to move to next attribute" |     print("Failed to move to next attribute") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "b": | if reader.Value() != "b": | ||||||
|     print "Failed to read attribute(2)" |     print("Failed to read attribute(2)") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "b": | if reader.Name() != "b": | ||||||
|     print "Failed to read attribute(2) name" |     print("Failed to read attribute(2) name") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.MoveToNextAttribute() != 1: | if reader.MoveToNextAttribute() != 1: | ||||||
|     print "Failed to move to next attribute" |     print("Failed to move to next attribute") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Value() != "a:b": | if reader.Value() != "a:b": | ||||||
|     print "Failed to read attribute(3)" |     print("Failed to read attribute(3)") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "a:b": | if reader.Name() != "a:b": | ||||||
|     print "Failed to read attribute(3) name" |     print("Failed to read attribute(3) name") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.MoveToNextAttribute() != 0: | if reader.MoveToNextAttribute() != 0: | ||||||
|     print "Failed to detect last attribute" |     print("Failed to detect last attribute") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
|      |      | ||||||
| # | # | ||||||
| # a couple of tests for namespace nodes | # a couple of tests for namespace nodes | ||||||
| # | # | ||||||
| f = StringIO.StringIO("""<a xmlns="http://example.com/foo"/>""") | f = str_io("""<a xmlns="http://example.com/foo"/>""") | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("test6") | reader = input.newTextReader("test6") | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test6: failed to Read()" |     print("test6: failed to Read()") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.MoveToFirstAttribute() | ret = reader.MoveToFirstAttribute() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test6: failed to MoveToFirstAttribute()" |     print("test6: failed to MoveToFirstAttribute()") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.NamespaceUri() != "http://www.w3.org/2000/xmlns/" or \ | if reader.NamespaceUri() != "http://www.w3.org/2000/xmlns/" or \ | ||||||
|    reader.LocalName() != "xmlns" or reader.Name() != "xmlns" or \ |    reader.LocalName() != "xmlns" or reader.Name() != "xmlns" or \ | ||||||
|    reader.Value() != "http://example.com/foo" or reader.NodeType() != 2: |    reader.Value() != "http://example.com/foo" or reader.NodeType() != 2: | ||||||
|     print "test6: failed to read the namespace node" |     print("test6: failed to read the namespace node") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| f = StringIO.StringIO("""<a xmlns:prefix="http://example.com/foo"/>""") | f = str_io("""<a xmlns:prefix="http://example.com/foo"/>""") | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("test7") | reader = input.newTextReader("test7") | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test7: failed to Read()" |     print("test7: failed to Read()") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.MoveToFirstAttribute() | ret = reader.MoveToFirstAttribute() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test7: failed to MoveToFirstAttribute()" |     print("test7: failed to MoveToFirstAttribute()") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.NamespaceUri() != "http://www.w3.org/2000/xmlns/" or \ | if reader.NamespaceUri() != "http://www.w3.org/2000/xmlns/" or \ | ||||||
|    reader.LocalName() != "prefix" or reader.Name() != "xmlns:prefix" or \ |    reader.LocalName() != "prefix" or reader.Name() != "xmlns:prefix" or \ | ||||||
|    reader.Value() != "http://example.com/foo" or reader.NodeType() != 2: |    reader.Value() != "http://example.com/foo" or reader.NodeType() != 2: | ||||||
|     print "test7: failed to read the namespace node" |     print("test7: failed to read the namespace node") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| # Test for a limit case: | # Test for a limit case: | ||||||
| # | # | ||||||
| f = StringIO.StringIO("""<a/>""") | f = str_io("""<a/>""") | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("test8") | reader = input.newTextReader("test8") | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test8: failed to read the node" |     print("test8: failed to read the node") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "a" or reader.IsEmptyElement() != 1: | if reader.Name() != "a" or reader.IsEmptyElement() != 1: | ||||||
|     print "test8: failed to analyze the node" |     print("test8: failed to analyze the node") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "test8: failed to detect the EOF" |     print("test8: failed to detect the EOF") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| # Another test provided by St<53>phane Bidoul and checked with C# | # Another test provided by St<53>phane Bidoul and checked with C# | ||||||
| # | # | ||||||
| def tst_reader(s): | def tst_reader(s): | ||||||
|     f = StringIO.StringIO(s) |     f = str_io(s) | ||||||
|     input = libxml2.inputBuffer(f) |     input = libxml2.inputBuffer(f) | ||||||
|     reader = input.newTextReader("tst") |     reader = input.newTextReader("tst") | ||||||
|     res = "" |     res = "" | ||||||
| @@ -322,8 +327,8 @@ expect="""1 (a) [None] 0 0 | |||||||
| """ | """ | ||||||
| res = tst_reader(doc) | res = tst_reader(doc) | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test5 failed" |     print("test5 failed") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc="""<test><b/><c/></test>""" | doc="""<test><b/><c/></test>""" | ||||||
| @@ -334,8 +339,8 @@ expect="""1 (test) [None] 0 0 | |||||||
| """ | """ | ||||||
| res = tst_reader(doc) | res = tst_reader(doc) | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test9 failed" |     print("test9 failed") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc="""<a><b>bbb</b><c>ccc</c></a>""" | doc="""<a><b>bbb</b><c>ccc</c></a>""" | ||||||
| @@ -350,8 +355,8 @@ expect="""1 (a) [None] 0 0 | |||||||
| """ | """ | ||||||
| res = tst_reader(doc) | res = tst_reader(doc) | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test10 failed" |     print("test10 failed") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc="""<test a="a"/>""" | doc="""<test a="a"/>""" | ||||||
| @@ -360,8 +365,8 @@ expect="""1 (test) [None] 1 0 | |||||||
| """ | """ | ||||||
| res = tst_reader(doc) | res = tst_reader(doc) | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test11 failed" |     print("test11 failed") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc="""<test><a>aaa</a><b/></test>""" | doc="""<test><a>aaa</a><b/></test>""" | ||||||
| @@ -374,8 +379,8 @@ expect="""1 (test) [None] 0 0 | |||||||
| """ | """ | ||||||
| res = tst_reader(doc) | res = tst_reader(doc) | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test12 failed" |     print("test12 failed") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc="""<test><p></p></test>""" | doc="""<test><p></p></test>""" | ||||||
| @@ -386,8 +391,8 @@ expect="""1 (test) [None] 0 0 | |||||||
| """ | """ | ||||||
| res = tst_reader(doc) | res = tst_reader(doc) | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test13 failed" |     print("test13 failed") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc="""<p></p>""" | doc="""<p></p>""" | ||||||
| @@ -396,8 +401,8 @@ expect="""1 (p) [None] 0 0 | |||||||
| """ | """ | ||||||
| res = tst_reader(doc) | res = tst_reader(doc) | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test14 failed" |     print("test14 failed") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -421,8 +426,8 @@ xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx | |||||||
| """ | """ | ||||||
| res = tst_reader(doc) | res = tst_reader(doc) | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test15 failed" |     print("test15 failed") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -435,7 +440,7 @@ del reader | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -5,8 +5,13 @@ | |||||||
| import sys | import sys | ||||||
| import glob | import glob | ||||||
| import string | import string | ||||||
| import StringIO |  | ||||||
| import libxml2 | import libxml2 | ||||||
|  | try: | ||||||
|  |     import StringIO | ||||||
|  |     str_io = StringIO.StringIO | ||||||
|  | except: | ||||||
|  |     import io | ||||||
|  |     str_io = io.StringIO | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.debugMemory(1) | libxml2.debugMemory(1) | ||||||
| @@ -30,7 +35,11 @@ libxml2.registerErrorHandler(callback, "") | |||||||
| valid_files = glob.glob("../../test/valid/*.x*") | valid_files = glob.glob("../../test/valid/*.x*") | ||||||
| valid_files.sort() | valid_files.sort() | ||||||
| for file in valid_files: | for file in valid_files: | ||||||
|     if string.find(file, "t8") != -1: |     if file.find("t8") != -1: | ||||||
|  |         continue | ||||||
|  |     if file == "../../test/valid/rss.xml": | ||||||
|  |         continue | ||||||
|  |     if file == "../../test/valid/xlink.xml": | ||||||
|         continue |         continue | ||||||
|     reader = libxml2.newTextReaderFilename(file) |     reader = libxml2.newTextReaderFilename(file) | ||||||
|     #print "%s:" % (file) |     #print "%s:" % (file) | ||||||
| @@ -39,11 +48,11 @@ for file in valid_files: | |||||||
|     while ret == 1: |     while ret == 1: | ||||||
|         ret = reader.Read() |         ret = reader.Read() | ||||||
|     if ret != 0: |     if ret != 0: | ||||||
|         print "Error parsing and validating %s" % (file) |         print("Error parsing and validating %s" % (file)) | ||||||
| 	#sys.exit(1) | 	#sys.exit(1) | ||||||
|  |  | ||||||
| if err != expect: | if err != expect: | ||||||
|     print err |     print(err) | ||||||
|  |  | ||||||
| # | # | ||||||
| # another separate test based on Stephane Bidoul one | # another separate test based on Stephane Bidoul one | ||||||
| @@ -79,7 +88,7 @@ expect="""10,test | |||||||
| res="" | res="" | ||||||
| err="" | err="" | ||||||
|  |  | ||||||
| input = libxml2.inputBuffer(StringIO.StringIO(s)) | input = libxml2.inputBuffer(str_io(s)) | ||||||
| reader = input.newTextReader("test2") | reader = input.newTextReader("test2") | ||||||
| reader.SetParserProp(libxml2.PARSER_LOADDTD,1) | reader.SetParserProp(libxml2.PARSER_LOADDTD,1) | ||||||
| reader.SetParserProp(libxml2.PARSER_DEFAULTATTRS,1) | reader.SetParserProp(libxml2.PARSER_DEFAULTATTRS,1) | ||||||
| @@ -89,12 +98,12 @@ while reader.Read() == 1: | |||||||
|     res = res + "%s,%s\n" % (reader.NodeType(),reader.Name()) |     res = res + "%s,%s\n" % (reader.NodeType(),reader.Name()) | ||||||
|  |  | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test2 failed: unexpected output" |     print("test2 failed: unexpected output") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if err != "": | if err != "": | ||||||
|     print "test2 failed: validation error found" |     print("test2 failed: validation error found") | ||||||
|     print err |     print(err) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -124,12 +133,12 @@ res="" | |||||||
|  |  | ||||||
| def myResolver(URL, ID, ctxt): | def myResolver(URL, ID, ctxt): | ||||||
|     if URL == "tst.ent": |     if URL == "tst.ent": | ||||||
|         return(StringIO.StringIO(tst_ent)) |         return(str_io(tst_ent)) | ||||||
|     return None |     return None | ||||||
|  |  | ||||||
| libxml2.setEntityLoader(myResolver) | libxml2.setEntityLoader(myResolver) | ||||||
|  |  | ||||||
| input = libxml2.inputBuffer(StringIO.StringIO(s)) | input = libxml2.inputBuffer(str_io(s)) | ||||||
| reader = input.newTextReader("test3") | reader = input.newTextReader("test3") | ||||||
| reader.SetParserProp(libxml2.PARSER_LOADDTD,1) | reader.SetParserProp(libxml2.PARSER_LOADDTD,1) | ||||||
| reader.SetParserProp(libxml2.PARSER_DEFAULTATTRS,1) | reader.SetParserProp(libxml2.PARSER_DEFAULTATTRS,1) | ||||||
| @@ -139,12 +148,12 @@ while reader.Read() == 1: | |||||||
|     res = res + "%s %s\n" % (reader.NodeType(),reader.Name()) |     res = res + "%s %s\n" % (reader.NodeType(),reader.Name()) | ||||||
|  |  | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test3 failed: unexpected output" |     print("test3 failed: unexpected output") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if err != "": | if err != "": | ||||||
|     print "test3 failed: validation error found" |     print("test3 failed: validation error found") | ||||||
|     print err |     print(err) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -183,7 +192,7 @@ expect="""10 test 0 | |||||||
| res="" | res="" | ||||||
| err="" | err="" | ||||||
|  |  | ||||||
| input = libxml2.inputBuffer(StringIO.StringIO(s)) | input = libxml2.inputBuffer(str_io(s)) | ||||||
| reader = input.newTextReader("test4") | reader = input.newTextReader("test4") | ||||||
| reader.SetParserProp(libxml2.PARSER_LOADDTD,1) | reader.SetParserProp(libxml2.PARSER_LOADDTD,1) | ||||||
| reader.SetParserProp(libxml2.PARSER_DEFAULTATTRS,1) | reader.SetParserProp(libxml2.PARSER_DEFAULTATTRS,1) | ||||||
| @@ -193,12 +202,12 @@ while reader.Read() == 1: | |||||||
|     res = res + "%s %s %d\n" % (reader.NodeType(),reader.Name(),reader.Depth()) |     res = res + "%s %s %d\n" % (reader.NodeType(),reader.Name(),reader.Depth()) | ||||||
|  |  | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test4 failed: unexpected output" |     print("test4 failed: unexpected output") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if err != "": | if err != "": | ||||||
|     print "test4 failed: validation error found" |     print("test4 failed: validation error found") | ||||||
|     print err |     print(err) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -228,18 +237,18 @@ expect="""10 test 0 | |||||||
| res="" | res="" | ||||||
| err="" | err="" | ||||||
|  |  | ||||||
| input = libxml2.inputBuffer(StringIO.StringIO(s)) | input = libxml2.inputBuffer(str_io(s)) | ||||||
| reader = input.newTextReader("test5") | reader = input.newTextReader("test5") | ||||||
| reader.SetParserProp(libxml2.PARSER_VALIDATE,1) | reader.SetParserProp(libxml2.PARSER_VALIDATE,1) | ||||||
| while reader.Read() == 1: | while reader.Read() == 1: | ||||||
|     res = res + "%s %s %d\n" % (reader.NodeType(),reader.Name(),reader.Depth()) |     res = res + "%s %s %d\n" % (reader.NodeType(),reader.Name(),reader.Depth()) | ||||||
|  |  | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test5 failed: unexpected output" |     print("test5 failed: unexpected output") | ||||||
|     print res |     print(res) | ||||||
| if err != "": | if err != "": | ||||||
|     print "test5 failed: validation error found" |     print("test5 failed: validation error found") | ||||||
|     print err |     print(err) | ||||||
|  |  | ||||||
| # | # | ||||||
| # cleanup | # cleanup | ||||||
| @@ -250,7 +259,7 @@ del reader | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -3,8 +3,13 @@ | |||||||
| # this tests the entities substitutions with the XmlTextReader interface | # this tests the entities substitutions with the XmlTextReader interface | ||||||
| # | # | ||||||
| import sys | import sys | ||||||
| import StringIO |  | ||||||
| import libxml2 | import libxml2 | ||||||
|  | try: | ||||||
|  |     import StringIO | ||||||
|  |     str_io = StringIO.StringIO | ||||||
|  | except: | ||||||
|  |     import io | ||||||
|  |     str_io = io.StringIO | ||||||
|  |  | ||||||
| docstr="""<?xml version='1.0'?> | docstr="""<?xml version='1.0'?> | ||||||
| <!DOCTYPE doc [ | <!DOCTYPE doc [ | ||||||
| @@ -18,90 +23,90 @@ libxml2.debugMemory(1) | |||||||
| # | # | ||||||
| # First test, normal don't substitute entities. | # First test, normal don't substitute entities. | ||||||
| # | # | ||||||
| f = StringIO.StringIO(docstr) | f = str_io(docstr) | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("test_noent") | reader = input.newTextReader("test_noent") | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "Error reading to root" |     print("Error reading to root") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() == "doc" or reader.NodeType() == 10: | if reader.Name() == "doc" or reader.NodeType() == 10: | ||||||
|     ret = reader.Read() |     ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "Error reading to root" |     print("Error reading to root") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "doc" or reader.NodeType() != 1: | if reader.Name() != "doc" or reader.NodeType() != 1: | ||||||
|     print "test_normal: Error reading the root element" |     print("test_normal: Error reading the root element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test_normal: Error reading to the entity" |     print("test_normal: Error reading to the entity") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "tst" or reader.NodeType() != 5: | if reader.Name() != "tst" or reader.NodeType() != 5: | ||||||
|     print "test_normal: Error reading the entity" |     print("test_normal: Error reading the entity") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test_normal: Error reading to the end of root" |     print("test_normal: Error reading to the end of root") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "doc" or reader.NodeType() != 15: | if reader.Name() != "doc" or reader.NodeType() != 15: | ||||||
|     print "test_normal: Error reading the end of the root element" |     print("test_normal: Error reading the end of the root element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "test_normal: Error detecting the end" |     print("test_normal: Error detecting the end") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| # Second test, completely substitute the entities. | # Second test, completely substitute the entities. | ||||||
| # | # | ||||||
| f = StringIO.StringIO(docstr) | f = str_io(docstr) | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("test_noent") | reader = input.newTextReader("test_noent") | ||||||
| reader.SetParserProp(libxml2.PARSER_SUBST_ENTITIES, 1) | reader.SetParserProp(libxml2.PARSER_SUBST_ENTITIES, 1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "Error reading to root" |     print("Error reading to root") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() == "doc" or reader.NodeType() == 10: | if reader.Name() == "doc" or reader.NodeType() == 10: | ||||||
|     ret = reader.Read() |     ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "Error reading to root" |     print("Error reading to root") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "doc" or reader.NodeType() != 1: | if reader.Name() != "doc" or reader.NodeType() != 1: | ||||||
|     print "test_noent: Error reading the root element" |     print("test_noent: Error reading the root element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test_noent: Error reading to the entity content" |     print("test_noent: Error reading to the entity content") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "p" or reader.NodeType() != 1: | if reader.Name() != "p" or reader.NodeType() != 1: | ||||||
|     print "test_noent: Error reading the p element from entity" |     print("test_noent: Error reading the p element from entity") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test_noent: Error reading to the text node" |     print("test_noent: Error reading to the text node") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.NodeType() != 3 or reader.Value() != "test": | if reader.NodeType() != 3 or reader.Value() != "test": | ||||||
|     print "test_noent: Error reading the text node" |     print("test_noent: Error reading the text node") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test_noent: Error reading to the end of p element" |     print("test_noent: Error reading to the end of p element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "p" or reader.NodeType() != 15: | if reader.Name() != "p" or reader.NodeType() != 15: | ||||||
|     print "test_noent: Error reading the end of the p element" |     print("test_noent: Error reading the end of the p element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test_noent: Error reading to the end of root" |     print("test_noent: Error reading to the end of root") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "doc" or reader.NodeType() != 15: | if reader.Name() != "doc" or reader.NodeType() != 15: | ||||||
|     print "test_noent: Error reading the end of the root element" |     print("test_noent: Error reading the end of the root element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "test_noent: Error detecting the end" |     print("test_noent: Error detecting the end") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -122,12 +127,12 @@ simplestruct2_ent="""<descr/>""" | |||||||
|  |  | ||||||
| def myResolver(URL, ID, ctxt): | def myResolver(URL, ID, ctxt): | ||||||
|     if URL == "simplestruct2.ent": |     if URL == "simplestruct2.ent": | ||||||
|         return(StringIO.StringIO(simplestruct2_ent)) |         return(str_io(simplestruct2_ent)) | ||||||
|     return None |     return None | ||||||
|  |  | ||||||
| libxml2.setEntityLoader(myResolver) | libxml2.setEntityLoader(myResolver) | ||||||
|  |  | ||||||
| input = libxml2.inputBuffer(StringIO.StringIO(s)) | input = libxml2.inputBuffer(str_io(s)) | ||||||
| reader = input.newTextReader("test3") | reader = input.newTextReader("test3") | ||||||
| reader.SetParserProp(libxml2.PARSER_SUBST_ENTITIES,1) | reader.SetParserProp(libxml2.PARSER_SUBST_ENTITIES,1) | ||||||
| while reader.Read() == 1: | while reader.Read() == 1: | ||||||
| @@ -135,8 +140,8 @@ while reader.Read() == 1: | |||||||
|                                    reader.Depth(),reader.IsEmptyElement()) |                                    reader.Depth(),reader.IsEmptyElement()) | ||||||
|  |  | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test3 failed: unexpected output" |     print("test3 failed: unexpected output") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -149,7 +154,7 @@ del reader | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -3,14 +3,19 @@ | |||||||
| # this tests the basic APIs of the XmlTextReader interface | # this tests the basic APIs of the XmlTextReader interface | ||||||
| # | # | ||||||
| import libxml2 | import libxml2 | ||||||
| import StringIO |  | ||||||
| import sys | import sys | ||||||
|  | try: | ||||||
|  |     import StringIO | ||||||
|  |     str_io = StringIO.StringIO | ||||||
|  | except: | ||||||
|  |     import io | ||||||
|  |     str_io = io.StringIO | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.debugMemory(1) | libxml2.debugMemory(1) | ||||||
|  |  | ||||||
| def tst_reader(s): | def tst_reader(s): | ||||||
|     f = StringIO.StringIO(s) |     f = str_io(s) | ||||||
|     input = libxml2.inputBuffer(f) |     input = libxml2.inputBuffer(f) | ||||||
|     reader = input.newTextReader("tst") |     reader = input.newTextReader("tst") | ||||||
|     res = "" |     res = "" | ||||||
| @@ -32,14 +37,14 @@ expect="""1 (test) [None] 0 | |||||||
| res = tst_reader("""<test><b/><c/></test>""") | res = tst_reader("""<test><b/><c/></test>""") | ||||||
|  |  | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "Did not get the expected error message:" |     print("Did not get the expected error message:") | ||||||
|     print res |     print(res) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -4,7 +4,6 @@ | |||||||
| # this extract the Dragon bibliography entries from the XML specification | # this extract the Dragon bibliography entries from the XML specification | ||||||
| # | # | ||||||
| import libxml2 | import libxml2 | ||||||
| import StringIO |  | ||||||
| import sys | import sys | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| @@ -15,11 +14,11 @@ Ravi Sethi, and Jeffrey D. Ullman. | |||||||
| <emph>Compilers:  Principles, Techniques, and Tools</emph>. | <emph>Compilers:  Principles, Techniques, and Tools</emph>. | ||||||
| Reading:  Addison-Wesley, 1986, rpt. corr. 1988.</bibl>""" | Reading:  Addison-Wesley, 1986, rpt. corr. 1988.</bibl>""" | ||||||
|  |  | ||||||
| f = open('../../test/valid/REC-xml-19980210.xml') | f = open('../../test/valid/REC-xml-19980210.xml', 'rb') | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("REC") | reader = input.newTextReader("REC") | ||||||
| res="" | res="" | ||||||
| while reader.Read(): | while reader.Read() > 0: | ||||||
|     while reader.Name() == 'bibl': |     while reader.Name() == 'bibl': | ||||||
|         node = reader.Expand()            # expand the subtree |         node = reader.Expand()            # expand the subtree | ||||||
|         if node.xpathEval("@id = 'Aho'"): # use XPath on it |         if node.xpathEval("@id = 'Aho'"): # use XPath on it | ||||||
| @@ -28,9 +27,9 @@ while reader.Read(): | |||||||
|             break; |             break; | ||||||
|  |  | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "Error: didn't get the expected output" |     print("Error: didn't get the expected output") | ||||||
|     print "got '%s'" % (res) |     print("got '%s'" % (res)) | ||||||
|     print "expected '%s'" % (expect) |     print("expected '%s'" % (expect)) | ||||||
|      |      | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -42,7 +41,7 @@ del reader | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -3,8 +3,13 @@ | |||||||
| # this tests the entities substitutions with the XmlTextReader interface | # this tests the entities substitutions with the XmlTextReader interface | ||||||
| # | # | ||||||
| import sys | import sys | ||||||
| import StringIO |  | ||||||
| import libxml2 | import libxml2 | ||||||
|  | try: | ||||||
|  |     import StringIO | ||||||
|  |     str_io = StringIO.StringIO | ||||||
|  | except: | ||||||
|  |     import io | ||||||
|  |     str_io = io.StringIO | ||||||
|  |  | ||||||
| schema="""<element name="foo" xmlns="http://relaxng.org/ns/structure/1.0" | schema="""<element name="foo" xmlns="http://relaxng.org/ns/structure/1.0" | ||||||
|          datatypeLibrary="http://www.w3.org/2001/XMLSchema-datatypes"> |          datatypeLibrary="http://www.w3.org/2001/XMLSchema-datatypes"> | ||||||
| @@ -41,7 +46,7 @@ docstr="""<foo> | |||||||
| <item>100</item> | <item>100</item> | ||||||
| </foo>""" | </foo>""" | ||||||
|  |  | ||||||
| f = StringIO.StringIO(docstr) | f = str_io(docstr) | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("correct") | reader = input.newTextReader("correct") | ||||||
| reader.RelaxNGSetSchema(rngs) | reader.RelaxNGSetSchema(rngs) | ||||||
| @@ -50,11 +55,11 @@ while ret == 1: | |||||||
|     ret = reader.Read() |     ret = reader.Read() | ||||||
|  |  | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "Error parsing the document" |     print("Error parsing the document") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| if reader.IsValid() != 1: | if reader.IsValid() != 1: | ||||||
|     print "Document failed to validate" |     print("Document failed to validate") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -84,7 +89,7 @@ def callback(ctx, str): | |||||||
|     err = err + "%s" % (str) |     err = err + "%s" % (str) | ||||||
| libxml2.registerErrorHandler(callback, "") | libxml2.registerErrorHandler(callback, "") | ||||||
|  |  | ||||||
| f = StringIO.StringIO(docstr) | f = str_io(docstr) | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("error") | reader = input.newTextReader("error") | ||||||
| reader.RelaxNGSetSchema(rngs) | reader.RelaxNGSetSchema(rngs) | ||||||
| @@ -93,16 +98,16 @@ while ret == 1: | |||||||
|     ret = reader.Read() |     ret = reader.Read() | ||||||
|  |  | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "Error parsing the document" |     print("Error parsing the document") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| if reader.IsValid() != 0: | if reader.IsValid() != 0: | ||||||
|     print "Document failed to detect the validation error" |     print("Document failed to detect the validation error") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| if err != expect: | if err != expect: | ||||||
|     print "Did not get the expected error message:" |     print("Did not get the expected error message:") | ||||||
|     print err |     print(err) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -117,7 +122,7 @@ libxml2.relaxNGCleanupTypes() | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
| # this tests the entities substitutions with the XmlTextReader interface | # this tests the entities substitutions with the XmlTextReader interface | ||||||
| # | # | ||||||
| import sys | import sys | ||||||
| import StringIO | import io | ||||||
| import libxml2 | import libxml2 | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| @@ -44,12 +44,12 @@ while ret == 1: | |||||||
|     ret = reader.Read() |     ret = reader.Read() | ||||||
|  |  | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "Error parsing the document test1" |     print("Error parsing the document test1") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| if result != expect: | if result != expect: | ||||||
|     print "Unexpected result for test1" |     print("Unexpected result for test1") | ||||||
|     print result |     print(result) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -80,12 +80,12 @@ while ret == 1: | |||||||
|     ret = reader.Read() |     ret = reader.Read() | ||||||
|  |  | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "Error parsing the document test2" |     print("Error parsing the document test2") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| if result != expect: | if result != expect: | ||||||
|     print "Unexpected result for test2" |     print("Unexpected result for test2") | ||||||
|     print result |     print(result) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -96,7 +96,7 @@ del reader | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
| # this tests the entities substitutions with the XmlTextReader interface | # this tests the entities substitutions with the XmlTextReader interface | ||||||
| # | # | ||||||
| import sys | import sys | ||||||
| import StringIO | import io | ||||||
| import libxml2 | import libxml2 | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| @@ -23,7 +23,7 @@ ret = reader.Read() | |||||||
| ret = reader.Close() | ret = reader.Close() | ||||||
|  |  | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "Error closing the document test1" |     print("Error closing the document test1") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| del reader | del reader | ||||||
| @@ -31,7 +31,7 @@ del reader | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
							
								
								
									
										21
									
								
								python/tests/readererr.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										21
									
								
								python/tests/readererr.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -3,8 +3,13 @@ | |||||||
| # this tests the basic APIs of the XmlTextReader interface | # this tests the basic APIs of the XmlTextReader interface | ||||||
| # | # | ||||||
| import libxml2 | import libxml2 | ||||||
| import StringIO |  | ||||||
| import sys | import sys | ||||||
|  | try: | ||||||
|  |     import StringIO | ||||||
|  |     str_io = StringIO.StringIO | ||||||
|  | except: | ||||||
|  |     import io | ||||||
|  |     str_io = io.StringIO | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.debugMemory(1) | libxml2.debugMemory(1) | ||||||
| @@ -17,7 +22,7 @@ def myErrorHandler(arg,msg,severity,locator): | |||||||
|     global err |     global err | ||||||
|     err = err + "%s (%d) %s:%d:%s" % (arg,severity,locator.BaseURI(),locator.LineNumber(),msg) |     err = err + "%s (%d) %s:%d:%s" % (arg,severity,locator.BaseURI(),locator.LineNumber(),msg) | ||||||
|  |  | ||||||
| f = StringIO.StringIO("""<a xmlns="foo"><b b1="b1"/><c>content of c</a>""") | f = str_io("""<a xmlns="foo"><b b1="b1"/><c>content of c</a>""") | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("test1") | reader = input.newTextReader("test1") | ||||||
| reader.SetErrorHandler(myErrorHandler,"-->") | reader.SetErrorHandler(myErrorHandler,"-->") | ||||||
| @@ -25,14 +30,14 @@ while reader.Read() == 1: | |||||||
|     pass |     pass | ||||||
|  |  | ||||||
| if err != expect: | if err != expect: | ||||||
|     print "error" |     print("error") | ||||||
|     print "received %s" %(err) |     print("received %s" %(err)) | ||||||
|     print "expected %s" %(expect) |     print("expected %s" %(expect)) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| reader.SetErrorHandler(None,None) | reader.SetErrorHandler(None,None) | ||||||
| if reader.GetErrorHandler() != (None,None): | if reader.GetErrorHandler() != (None,None): | ||||||
|     print "GetErrorHandler failed" |     print("GetErrorHandler failed") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -45,7 +50,7 @@ del reader | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -4,65 +4,70 @@ | |||||||
| # this tests the next API of the XmlTextReader interface | # this tests the next API of the XmlTextReader interface | ||||||
| # | # | ||||||
| import libxml2 | import libxml2 | ||||||
| import StringIO |  | ||||||
| import sys | import sys | ||||||
|  | try: | ||||||
|  |     import StringIO | ||||||
|  |     str_io = StringIO.StringIO | ||||||
|  | except: | ||||||
|  |     import io | ||||||
|  |     str_io = io.StringIO | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.debugMemory(1) | libxml2.debugMemory(1) | ||||||
|  |  | ||||||
| f = StringIO.StringIO("""<a><b><c /></b><d>content of d</d></a>""") | f = str_io("""<a><b><c /></b><d>content of d</d></a>""") | ||||||
| input = libxml2.inputBuffer(f) | input = libxml2.inputBuffer(f) | ||||||
| reader = input.newTextReader("test_next") | reader = input.newTextReader("test_next") | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test_next: Error reading to first element" |     print("test_next: Error reading to first element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "a" or reader.IsEmptyElement() != 0 or \ | if reader.Name() != "a" or reader.IsEmptyElement() != 0 or \ | ||||||
|    reader.NodeType() != 1 or reader.HasAttributes() != 0: |    reader.NodeType() != 1 or reader.HasAttributes() != 0: | ||||||
|     print "test_next: Error reading the first element" |     print("test_next: Error reading the first element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test_next: Error reading to second element" |     print("test_next: Error reading to second element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "b" or reader.IsEmptyElement() != 0 or \ | if reader.Name() != "b" or reader.IsEmptyElement() != 0 or \ | ||||||
|    reader.NodeType() != 1 or reader.HasAttributes() != 0: |    reader.NodeType() != 1 or reader.HasAttributes() != 0: | ||||||
|     print "test_next: Error reading the second element" |     print("test_next: Error reading the second element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test_next: Error reading to third element" |     print("test_next: Error reading to third element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "c" or reader.NodeType() != 1 or \ | if reader.Name() != "c" or reader.NodeType() != 1 or \ | ||||||
|    reader.HasAttributes() != 0: |    reader.HasAttributes() != 0: | ||||||
|     print "test_next: Error reading the third element" |     print("test_next: Error reading the third element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test_next: Error reading to end of third element" |     print("test_next: Error reading to end of third element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "b" or reader.NodeType() != 15: | if reader.Name() != "b" or reader.NodeType() != 15: | ||||||
|     print "test_next: Error reading to end of second element" |     print("test_next: Error reading to end of second element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Next() | ret = reader.Next() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test_next: Error moving to third element" |     print("test_next: Error moving to third element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "d" or reader.IsEmptyElement() != 0 or \ | if reader.Name() != "d" or reader.IsEmptyElement() != 0 or \ | ||||||
|    reader.NodeType() != 1 or reader.HasAttributes() != 0: |    reader.NodeType() != 1 or reader.HasAttributes() != 0: | ||||||
|     print "test_next: Error reading third element" |     print("test_next: Error reading third element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Next() | ret = reader.Next() | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "test_next: Error reading to end of first element" |     print("test_next: Error reading to end of first element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if reader.Name() != "a" or reader.IsEmptyElement() != 0 or \ | if reader.Name() != "a" or reader.IsEmptyElement() != 0 or \ | ||||||
|    reader.NodeType() != 15 or reader.HasAttributes() != 0: |    reader.NodeType() != 15 or reader.HasAttributes() != 0: | ||||||
|     print "test_next: Error reading the end of first element" |     print("test_next: Error reading the end of first element") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ret = reader.Read() | ret = reader.Read() | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "test_next: Error reading to end of document" |     print("test_next: Error reading to end of document") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -75,7 +80,7 @@ del reader | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								python/tests/regexp.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										14
									
								
								python/tests/regexp.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -6,19 +6,19 @@ libxml2.debugMemory(1) | |||||||
|  |  | ||||||
| re = libxml2.regexpCompile("a|b") | re = libxml2.regexpCompile("a|b") | ||||||
| if re.regexpExec("a") != 1: | if re.regexpExec("a") != 1: | ||||||
|     print "error checking 'a'" |     print("error checking 'a'") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if re.regexpExec("b") != 1: | if re.regexpExec("b") != 1: | ||||||
|     print "error checking 'b'" |     print("error checking 'b'") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if re.regexpExec("ab") != 0: | if re.regexpExec("ab") != 0: | ||||||
|     print "error checking 'ab'" |     print("error checking 'ab'") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if re.regexpExec("") != 0: | if re.regexpExec("") != 0: | ||||||
|     print "error checking 'ab'" |     print("error checking 'ab'") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if re.regexpIsDeterminist() != 1: | if re.regexpIsDeterminist() != 1: | ||||||
|     print "error checking determinism" |     print("error checking determinism") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| del re | del re | ||||||
|      |      | ||||||
| @@ -26,7 +26,7 @@ del re | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -29,7 +29,7 @@ ctxt = rngs.relaxNGNewValidCtxt() | |||||||
| doc = libxml2.parseDoc(instance) | doc = libxml2.parseDoc(instance) | ||||||
| ret = doc.relaxNGValidateDoc(ctxt) | ret = doc.relaxNGValidateDoc(ctxt) | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "error doing RelaxNG validation" |     print("error doing RelaxNG validation") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| @@ -41,8 +41,8 @@ libxml2.relaxNGCleanupTypes() | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,20 +1,25 @@ | |||||||
| #!/usr/bin/python -u | #!/usr/bin/python -u | ||||||
| import sys | import sys | ||||||
| import libxml2 | import libxml2 | ||||||
| import StringIO | try: | ||||||
|  |     import StringIO | ||||||
|  |     str_io = StringIO.StringIO | ||||||
|  | except: | ||||||
|  |     import io | ||||||
|  |     str_io = io.StringIO | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.debugMemory(1) | libxml2.debugMemory(1) | ||||||
|  |  | ||||||
| def myResolver(URL, ID, ctxt): | def myResolver(URL, ID, ctxt): | ||||||
|     return(StringIO.StringIO("<foo/>")) |     return(str_io("<foo/>")) | ||||||
|  |  | ||||||
| libxml2.setEntityLoader(myResolver) | libxml2.setEntityLoader(myResolver) | ||||||
|  |  | ||||||
| doc = libxml2.parseFile("doesnotexist.xml") | doc = libxml2.parseFile("doesnotexist.xml") | ||||||
| root = doc.children | root = doc.children | ||||||
| if root.name != "foo": | if root.name != "foo": | ||||||
|     print "root element name error" |     print("root element name error") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
|  |  | ||||||
| @@ -23,7 +28,7 @@ while i < 5000: | |||||||
|     doc = libxml2.parseFile("doesnotexist.xml") |     doc = libxml2.parseFile("doesnotexist.xml") | ||||||
|     root = doc.children |     root = doc.children | ||||||
|     if root.name != "foo": |     if root.name != "foo": | ||||||
|         print "root element name error" |         print("root element name error") | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|     doc.freeDoc() |     doc.freeDoc() | ||||||
|     i = i + 1 |     i = i + 1 | ||||||
| @@ -32,8 +37,8 @@ while i < 5000: | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|  |  | ||||||
|   | |||||||
| @@ -33,7 +33,7 @@ ctxt_valid  = ctxt_schema.schemaNewValidCtxt() | |||||||
| doc = libxml2.parseDoc(instance) | doc = libxml2.parseDoc(instance) | ||||||
| ret = doc.schemaValidateDoc(ctxt_valid) | ret = doc.schemaValidateDoc(ctxt_valid) | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "error doing schema validation" |     print("error doing schema validation") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| @@ -45,8 +45,8 @@ libxml2.schemaCleanupTypes() | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,13 +13,13 @@ str = doc.serialize() | |||||||
| if str != """<?xml version="1.0"?> | if str != """<?xml version="1.0"?> | ||||||
| <root><foo>hello</foo></root> | <root><foo>hello</foo></root> | ||||||
| """: | """: | ||||||
|    print "error serializing XML document 1" |    print("error serializing XML document 1") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| str = doc.serialize("iso-8859-1") | str = doc.serialize("iso-8859-1") | ||||||
| if str != """<?xml version="1.0" encoding="iso-8859-1"?> | if str != """<?xml version="1.0" encoding="iso-8859-1"?> | ||||||
| <root><foo>hello</foo></root> | <root><foo>hello</foo></root> | ||||||
| """: | """: | ||||||
|    print "error serializing XML document 2" |    print("error serializing XML document 2") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| str = doc.serialize(format=1) | str = doc.serialize(format=1) | ||||||
| if str != """<?xml version="1.0"?> | if str != """<?xml version="1.0"?> | ||||||
| @@ -27,7 +27,7 @@ if str != """<?xml version="1.0"?> | |||||||
|   <foo>hello</foo> |   <foo>hello</foo> | ||||||
| </root> | </root> | ||||||
| """: | """: | ||||||
|    print "error serializing XML document 3" |    print("error serializing XML document 3") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| str = doc.serialize("iso-8859-1", 1) | str = doc.serialize("iso-8859-1", 1) | ||||||
| if str != """<?xml version="1.0" encoding="iso-8859-1"?> | if str != """<?xml version="1.0" encoding="iso-8859-1"?> | ||||||
| @@ -35,7 +35,7 @@ if str != """<?xml version="1.0" encoding="iso-8859-1"?> | |||||||
|   <foo>hello</foo> |   <foo>hello</foo> | ||||||
| </root> | </root> | ||||||
| """: | """: | ||||||
|    print "error serializing XML document 4" |    print("error serializing XML document 4") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -44,23 +44,23 @@ if str != """<?xml version="1.0" encoding="iso-8859-1"?> | |||||||
| root = doc.getRootElement() | root = doc.getRootElement() | ||||||
| str = root.serialize() | str = root.serialize() | ||||||
| if str != """<root><foo>hello</foo></root>""": | if str != """<root><foo>hello</foo></root>""": | ||||||
|    print "error serializing XML root 1" |    print("error serializing XML root 1") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| str = root.serialize("iso-8859-1") | str = root.serialize("iso-8859-1") | ||||||
| if str != """<root><foo>hello</foo></root>""": | if str != """<root><foo>hello</foo></root>""": | ||||||
|    print "error serializing XML root 2" |    print("error serializing XML root 2") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| str = root.serialize(format=1) | str = root.serialize(format=1) | ||||||
| if str != """<root> | if str != """<root> | ||||||
|   <foo>hello</foo> |   <foo>hello</foo> | ||||||
| </root>""": | </root>""": | ||||||
|    print "error serializing XML root 3" |    print("error serializing XML root 3") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| str = root.serialize("iso-8859-1", 1) | str = root.serialize("iso-8859-1", 1) | ||||||
| if str != """<root> | if str != """<root> | ||||||
|   <foo>hello</foo> |   <foo>hello</foo> | ||||||
| </root>""": | </root>""": | ||||||
|    print "error serializing XML root 4" |    print("error serializing XML root 4") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
|  |  | ||||||
| @@ -72,13 +72,13 @@ str = doc.serialize() | |||||||
| if str != """<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"> | if str != """<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"> | ||||||
| <html><head><title>Hello</title></head><body><p>hello</p></body></html> | <html><head><title>Hello</title></head><body><p>hello</p></body></html> | ||||||
| """: | """: | ||||||
|    print "error serializing HTML document 1" |    print("error serializing HTML document 1") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| str = doc.serialize("ISO-8859-1") | str = doc.serialize("ISO-8859-1") | ||||||
| if str != """<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"> | if str != """<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"> | ||||||
| <html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Hello</title></head><body><p>hello</p></body></html> | <html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Hello</title></head><body><p>hello</p></body></html> | ||||||
| """: | """: | ||||||
|    print "error serializing HTML document 2" |    print("error serializing HTML document 2") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| str = doc.serialize(format=1) | str = doc.serialize(format=1) | ||||||
| if str != """<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"> | if str != """<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"> | ||||||
| @@ -90,7 +90,7 @@ if str != """<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http | |||||||
| <body><p>hello</p></body> | <body><p>hello</p></body> | ||||||
| </html> | </html> | ||||||
| """: | """: | ||||||
|    print "error serializing HTML document 3" |    print("error serializing HTML document 3") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| str = doc.serialize("iso-8859-1", 1) | str = doc.serialize("iso-8859-1", 1) | ||||||
| if str != """<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"> | if str != """<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"> | ||||||
| @@ -102,7 +102,7 @@ if str != """<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http | |||||||
| <body><p>hello</p></body> | <body><p>hello</p></body> | ||||||
| </html> | </html> | ||||||
| """: | """: | ||||||
|    print "error serializing HTML document 4" |    print("error serializing HTML document 4") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -112,11 +112,11 @@ doc.htmlSetMetaEncoding(None) | |||||||
| root = doc.getRootElement() | root = doc.getRootElement() | ||||||
| str = root.serialize() | str = root.serialize() | ||||||
| if str != """<html><head><title>Hello</title></head><body><p>hello</p></body></html>""": | if str != """<html><head><title>Hello</title></head><body><p>hello</p></body></html>""": | ||||||
|    print "error serializing HTML root 1" |    print("error serializing HTML root 1") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| str = root.serialize("ISO-8859-1") | str = root.serialize("ISO-8859-1") | ||||||
| if str != """<html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Hello</title></head><body><p>hello</p></body></html>""": | if str != """<html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Hello</title></head><body><p>hello</p></body></html>""": | ||||||
|    print "error serializing HTML root 2" |    print("error serializing HTML root 2") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| str = root.serialize(format=1) | str = root.serialize(format=1) | ||||||
| if str != """<html> | if str != """<html> | ||||||
| @@ -126,7 +126,7 @@ if str != """<html> | |||||||
| </head> | </head> | ||||||
| <body><p>hello</p></body> | <body><p>hello</p></body> | ||||||
| </html>""": | </html>""": | ||||||
|    print "error serializing HTML root 3" |    print("error serializing HTML root 3") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
| str = root.serialize("iso-8859-1", 1) | str = root.serialize("iso-8859-1", 1) | ||||||
| if str != """<html> | if str != """<html> | ||||||
| @@ -136,7 +136,7 @@ if str != """<html> | |||||||
| </head> | </head> | ||||||
| <body><p>hello</p></body> | <body><p>hello</p></body> | ||||||
| </html>""": | </html>""": | ||||||
|    print "error serializing HTML root 4" |    print("error serializing HTML root 4") | ||||||
|    sys.exit(1) |    sys.exit(1) | ||||||
|  |  | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| @@ -144,7 +144,7 @@ doc.freeDoc() | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -50,8 +50,8 @@ ctxt=None | |||||||
|  |  | ||||||
| reference = "startDocument:startElement foo None:startElement bar2 None:endElement bar2:" | reference = "startDocument:startElement foo None:startElement bar2 None:endElement bar2:" | ||||||
| if log != reference: | if log != reference: | ||||||
|     print "Error got: %s" % log |     print("Error got: %s" % log) | ||||||
|     print "Exprected: %s" % reference |     print("Exprected: %s" % reference) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| log="" | log="" | ||||||
| @@ -62,8 +62,8 @@ ctxt=None | |||||||
|  |  | ||||||
| reference = "startDocument:startElement foo None:startElement bar2 None:endElement bar2:" | reference = "startDocument:startElement foo None:startElement bar2 None:endElement bar2:" | ||||||
| if log != reference: | if log != reference: | ||||||
|     print "Error got: %s" % log |     print("Error got: %s" % log) | ||||||
|     print "Exprected: %s" % reference |     print("Exprected: %s" % reference) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| log="" | log="" | ||||||
| @@ -74,8 +74,8 @@ ctxt=None | |||||||
|  |  | ||||||
| reference = "startDocument:startElement foo None:startElement bar2 None:" | reference = "startDocument:startElement foo None:startElement bar2 None:" | ||||||
| if log != reference: | if log != reference: | ||||||
|     print "Error got: %s" % log |     print("Error got: %s" % log) | ||||||
|     print "Exprected: %s" % reference |     print("Exprected: %s" % reference) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| log="" | log="" | ||||||
| @@ -86,8 +86,8 @@ ctxt=None | |||||||
|  |  | ||||||
| reference = "startDocument:startElement foo None:startElement bar2 {'a': '1', 'b': '2'}:endElement bar2:" | reference = "startDocument:startElement foo None:startElement bar2 {'a': '1', 'b': '2'}:endElement bar2:" | ||||||
| if log != reference: | if log != reference: | ||||||
|     print "Error got: %s" % log |     print("Error got: %s" % log) | ||||||
|     print "Exprected: %s" % reference |     print("Exprected: %s" % reference) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| log="" | log="" | ||||||
| @@ -98,8 +98,8 @@ ctxt=None | |||||||
|  |  | ||||||
| reference = "startDocument:startElement foo None:startElement bar2 {'a': '1', 'b': '2'}:" | reference = "startDocument:startElement foo None:startElement bar2 {'a': '1', 'b': '2'}:" | ||||||
| if log != reference: | if log != reference: | ||||||
|     print "Error got: %s" % log |     print("Error got: %s" % log) | ||||||
|     print "Exprected: %s" % reference |     print("Exprected: %s" % reference) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| log="" | log="" | ||||||
| @@ -110,8 +110,8 @@ ctxt=None | |||||||
|  |  | ||||||
| reference = "startDocument:startElement foo None:startElement bar2 {'a': '1', 'b': '2'}:endElement bar2:" | reference = "startDocument:startElement foo None:startElement bar2 {'a': '1', 'b': '2'}:endElement bar2:" | ||||||
| if log != reference: | if log != reference: | ||||||
|     print "Error got: %s" % log |     print("Error got: %s" % log) | ||||||
|     print "Exprected: %s" % reference |     print("Exprected: %s" % reference) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| log="" | log="" | ||||||
| @@ -122,14 +122,14 @@ ctxt=None | |||||||
|  |  | ||||||
| reference = "startDocument:startElement foo None:" | reference = "startDocument:startElement foo None:" | ||||||
| if log != reference: | if log != reference: | ||||||
|     print "Error got: %s" % log |     print("Error got: %s" % log) | ||||||
|     print "Exprected: %s" % reference |     print("Exprected: %s" % reference) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -1,6 +1,9 @@ | |||||||
| #!/usr/bin/python -u | #!/usr/bin/python -u | ||||||
| import string, sys, time | import string, sys, time | ||||||
| import thread | try: | ||||||
|  |     from _thread import get_ident | ||||||
|  | except: | ||||||
|  |     from thread import get_ident | ||||||
| from threading import Thread, Lock | from threading import Thread, Lock | ||||||
|  |  | ||||||
| import libxml2 | import libxml2 | ||||||
| @@ -31,8 +34,8 @@ def test(expectedLineNumbersDefault): | |||||||
|     # check a per thread-global |     # check a per thread-global | ||||||
|     if expectedLineNumbersDefault != getLineNumbersDefault(): |     if expectedLineNumbersDefault != getLineNumbersDefault(): | ||||||
|         failed = 1 |         failed = 1 | ||||||
|         print "FAILED to obtain correct value for " \ |         print("FAILED to obtain correct value for " \ | ||||||
|               "lineNumbersDefault in thread %d" % thread.get_ident() |               "lineNumbersDefault in thread %d" % get_ident()) | ||||||
|     # check ther global error handler  |     # check ther global error handler  | ||||||
|     # (which is NOT per-thread in the python bindings) |     # (which is NOT per-thread in the python bindings) | ||||||
|     try: |     try: | ||||||
| @@ -51,7 +54,7 @@ libxml2.lineNumbersDefault(1) | |||||||
| test(1) | test(1) | ||||||
| ec = len(eh.errors) | ec = len(eh.errors) | ||||||
| if ec == 0: | if ec == 0: | ||||||
|     print "FAILED: should have obtained errors" |     print("FAILED: should have obtained errors") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| ts = [] | ts = [] | ||||||
| @@ -65,7 +68,7 @@ for t in ts: | |||||||
|     t.join() |     t.join() | ||||||
|  |  | ||||||
| if len(eh.errors) != ec+THREADS_COUNT*ec: | if len(eh.errors) != ec+THREADS_COUNT*ec: | ||||||
|     print "FAILED: did not obtain the correct number of errors" |     print("FAILED: did not obtain the correct number of errors") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # set lineNumbersDefault for future new threads | # set lineNumbersDefault for future new threads | ||||||
| @@ -80,17 +83,17 @@ for t in ts: | |||||||
|     t.join() |     t.join() | ||||||
|  |  | ||||||
| if len(eh.errors) != ec+THREADS_COUNT*ec*2: | if len(eh.errors) != ec+THREADS_COUNT*ec*2: | ||||||
|     print "FAILED: did not obtain the correct number of errors" |     print("FAILED: did not obtain the correct number of errors") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| if failed: | if failed: | ||||||
|     print "FAILED" |     print("FAILED") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -7,22 +7,22 @@ libxml2.debugMemory(1) | |||||||
|  |  | ||||||
| doc = libxml2.parseFile("tst.xml") | doc = libxml2.parseFile("tst.xml") | ||||||
| if doc.name != "tst.xml": | if doc.name != "tst.xml": | ||||||
|     print "doc.name failed" |     print("doc.name failed") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| root = doc.children | root = doc.children | ||||||
| if root.name != "doc": | if root.name != "doc": | ||||||
|     print "root.name failed" |     print("root.name failed") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| child = root.children | child = root.children | ||||||
| if child.name != "foo": | if child.name != "foo": | ||||||
|     print "child.name failed" |     print("child.name failed") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -18,7 +18,7 @@ class TestCase(unittest.TestCase): | |||||||
|             libxml2.dumpMemory()  |             libxml2.dumpMemory()  | ||||||
|             self.fail("Memory leak %d bytes" % (libxml2.debugMemory(1),)) |             self.fail("Memory leak %d bytes" % (libxml2.debugMemory(1),)) | ||||||
|         else: |         else: | ||||||
| 	    print "OK" |             print("OK") | ||||||
|  |  | ||||||
|     def failUnlessXmlError(self,f,args,exc,domain,code,message,level,file,line): |     def failUnlessXmlError(self,f,args,exc,domain,code,message,level,file,line): | ||||||
|         """Run function f, with arguments args and expect an exception exc; |         """Run function f, with arguments args and expect an exception exc; | ||||||
| @@ -27,19 +27,19 @@ class TestCase(unittest.TestCase): | |||||||
|         # disable the default error handler |         # disable the default error handler | ||||||
|         libxml2.registerErrorHandler(None,None) |         libxml2.registerErrorHandler(None,None) | ||||||
|         try: |         try: | ||||||
| 	    apply(f,args) |             f(*args) | ||||||
|         except exc: |         except exc: | ||||||
|             e = libxml2.lastError() |             e = libxml2.lastError() | ||||||
|             if e is None: |             if e is None: | ||||||
|                 self.fail("lastError not set") |                 self.fail("lastError not set") | ||||||
|             if 0: |             if 0: | ||||||
|                 print "domain = ",e.domain() |                 print("domain = ",e.domain()) | ||||||
|                 print "code = ",e.code() |                 print("code = ",e.code()) | ||||||
|                 print "message =",repr(e.message()) |                 print("message =",repr(e.message())) | ||||||
|                 print "level =",e.level() |                 print("level =",e.level()) | ||||||
|                 print "file =",e.file() |                 print("file =",e.file()) | ||||||
|                 print "line =",e.line() |                 print("line =",e.line()) | ||||||
|                 print |                 print() | ||||||
|             self.failUnlessEqual(domain,e.domain()) |             self.failUnlessEqual(domain,e.domain()) | ||||||
|             self.failUnlessEqual(code,e.code()) |             self.failUnlessEqual(code,e.code()) | ||||||
|             self.failUnlessEqual(message,e.message()) |             self.failUnlessEqual(message,e.message()) | ||||||
|   | |||||||
| @@ -7,35 +7,35 @@ libxml2.debugMemory(1) | |||||||
|  |  | ||||||
| uri = libxml2.parseURI("http://example.org:8088/foo/bar?query=simple#fragid") | uri = libxml2.parseURI("http://example.org:8088/foo/bar?query=simple#fragid") | ||||||
| if uri.scheme() != 'http': | if uri.scheme() != 'http': | ||||||
|     print "Error parsing URI: wrong scheme" |     print("Error parsing URI: wrong scheme") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if uri.server() != 'example.org': | if uri.server() != 'example.org': | ||||||
|     print "Error parsing URI: wrong server" |     print("Error parsing URI: wrong server") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if uri.port() != 8088: | if uri.port() != 8088: | ||||||
|     print "Error parsing URI: wrong port" |     print("Error parsing URI: wrong port") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if uri.path() != '/foo/bar': | if uri.path() != '/foo/bar': | ||||||
|     print "Error parsing URI: wrong path" |     print("Error parsing URI: wrong path") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if uri.query() != 'query=simple': | if uri.query() != 'query=simple': | ||||||
|     print "Error parsing URI: wrong query" |     print("Error parsing URI: wrong query") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if uri.fragment() != 'fragid': | if uri.fragment() != 'fragid': | ||||||
|     print "Error parsing URI: wrong query" |     print("Error parsing URI: wrong query") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| uri.setScheme("https") | uri.setScheme("https") | ||||||
| uri.setPort(223) | uri.setPort(223) | ||||||
| uri.setFragment(None) | uri.setFragment(None) | ||||||
| result=uri.saveUri() | result=uri.saveUri() | ||||||
| if result != "https://example.org:223/foo/bar?query=simple": | if result != "https://example.org:223/foo/bar?query=simple": | ||||||
|     print "Error modifying or saving the URI" |     print("Error modifying or saving the URI") | ||||||
| uri = None | uri = None | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ libxml2mod.xmlSetValidErrors(ctxt._o, error, error) | |||||||
| doc = libxml2.parseDoc(instance) | doc = libxml2.parseDoc(instance) | ||||||
| ret = doc.validateDtd(ctxt, dtd) | ret = doc.validateDtd(ctxt, dtd) | ||||||
| if ret != 1: | if ret != 1: | ||||||
|     print "error doing DTD validation" |     print("error doing DTD validation") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| @@ -30,7 +30,7 @@ del ctxt | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -25,10 +25,10 @@ doc = libxml2.parseFile("tst.xml") | |||||||
| ctxt = doc.xpathNewContext() | ctxt = doc.xpathNewContext() | ||||||
| res = ctxt.xpathEval("//*") | res = ctxt.xpathEval("//*") | ||||||
| if len(res) != 2: | if len(res) != 2: | ||||||
|     print "xpath query: wrong node set size" |     print("xpath query: wrong node set size") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if res[0].name != "doc" or res[1].name != "foo": | if res[0].name != "doc" or res[1].name != "foo": | ||||||
|     print "xpath query: wrong node set value" |     print("xpath query: wrong node set value") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| libxml2.registerXPathFunction(ctxt._o, "foo", None, foo) | libxml2.registerXPathFunction(ctxt._o, "foo", None, foo) | ||||||
| libxml2.registerXPathFunction(ctxt._o, "bar", None, bar) | libxml2.registerXPathFunction(ctxt._o, "bar", None, bar) | ||||||
| @@ -36,28 +36,28 @@ i = 10000 | |||||||
| while i > 0: | while i > 0: | ||||||
|     res = ctxt.xpathEval("foo(1)") |     res = ctxt.xpathEval("foo(1)") | ||||||
|     if res != 2: |     if res != 2: | ||||||
|         print "xpath extension failure" |         print("xpath extension failure") | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|     i = i - 1 |     i = i - 1 | ||||||
| i = 10000 | i = 10000 | ||||||
| while i > 0: | while i > 0: | ||||||
|     res = ctxt.xpathEval("bar(1)") |     res = ctxt.xpathEval("bar(1)") | ||||||
|     if res != "3": |     if res != "3": | ||||||
|         print "xpath extension failure got %s expecting '3'" |         print("xpath extension failure got %s expecting '3'") | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|     i = i - 1 |     i = i - 1 | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| ctxt.xpathFreeContext() | ctxt.xpathFreeContext() | ||||||
|  |  | ||||||
| if called != "foo": | if called != "foo": | ||||||
|     print "xpath function: failed to access the context" |     print("xpath function: failed to access the context") | ||||||
|     print "xpath function: %s" % (called) |     print("xpath function: %s" % (called)) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| #memory debug specific | #memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ class ErrorHandler: | |||||||
|  |  | ||||||
|     def handler(self, msg, data): |     def handler(self, msg, data): | ||||||
|         if data != ARG: |         if data != ARG: | ||||||
|             raise Exception, "Error handler did not receive correct argument" |             raise Exception("Error handler did not receive correct argument") | ||||||
|         self.errors.append(msg) |         self.errors.append(msg) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -34,7 +34,7 @@ ctxt.setValidityErrorHandler(e.handler, e.handler, ARG) | |||||||
| doc = libxml2.parseDoc(valid) | doc = libxml2.parseDoc(valid) | ||||||
| ret = doc.validateDtd(ctxt, dtd) | ret = doc.validateDtd(ctxt, dtd) | ||||||
| if ret != 1 or e.errors: | if ret != 1 or e.errors: | ||||||
|     print "error doing DTD validation" |     print("error doing DTD validation") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
|  |  | ||||||
| @@ -42,7 +42,7 @@ doc.freeDoc() | |||||||
| doc = libxml2.parseDoc(invalid) | doc = libxml2.parseDoc(invalid) | ||||||
| ret = doc.validateDtd(ctxt, dtd) | ret = doc.validateDtd(ctxt, dtd) | ||||||
| if ret != 0 or not e.errors: | if ret != 0 or not e.errors: | ||||||
|     print "Error: document supposed to be invalid" |     print("Error: document supposed to be invalid") | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
|  |  | ||||||
| dtd.freeDtd() | dtd.freeDtd() | ||||||
| @@ -52,8 +52,8 @@ del ctxt | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|  |  | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ class ErrorHandler: | |||||||
|  |  | ||||||
|     def handler(self, msg, data): |     def handler(self, msg, data): | ||||||
|         if data != ARG: |         if data != ARG: | ||||||
|             raise Exception, "Error handler did not receive correct argument" |             raise Exception("Error handler did not receive correct argument") | ||||||
|         self.errors.append(msg) |         self.errors.append(msg) | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| @@ -49,7 +49,7 @@ ctxt.setValidityErrorHandler(e.handler, e.handler, ARG) | |||||||
| doc = libxml2.parseDoc(valid) | doc = libxml2.parseDoc(valid) | ||||||
| ret = doc.relaxNGValidateDoc(ctxt) | ret = doc.relaxNGValidateDoc(ctxt) | ||||||
| if ret != 0 or e.errors: | if ret != 0 or e.errors: | ||||||
|     print "error doing RelaxNG validation" |     print("error doing RelaxNG validation") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
|  |  | ||||||
| @@ -57,7 +57,7 @@ doc.freeDoc() | |||||||
| doc = libxml2.parseDoc(invalid) | doc = libxml2.parseDoc(invalid) | ||||||
| ret = doc.relaxNGValidateDoc(ctxt) | ret = doc.relaxNGValidateDoc(ctxt) | ||||||
| if ret == 0 or not e.errors: | if ret == 0 or not e.errors: | ||||||
|     print "Error: document supposed to be RelaxNG invalid" |     print("Error: document supposed to be RelaxNG invalid") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
|  |  | ||||||
| @@ -69,8 +69,8 @@ libxml2.relaxNGCleanupTypes() | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|  |  | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ class ErrorHandler: | |||||||
|  |  | ||||||
|     def handler(self, msg, data): |     def handler(self, msg, data): | ||||||
|         if data != ARG: |         if data != ARG: | ||||||
|             raise Exception, "Error handler did not receive correct argument" |             raise Exception("Error handler did not receive correct argument") | ||||||
|         self.errors.append(msg) |         self.errors.append(msg) | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| @@ -56,7 +56,7 @@ ctxt_valid.setValidityErrorHandler(e.handler, e.handler, ARG) | |||||||
| doc = libxml2.parseDoc(valid) | doc = libxml2.parseDoc(valid) | ||||||
| ret = doc.schemaValidateDoc(ctxt_valid) | ret = doc.schemaValidateDoc(ctxt_valid) | ||||||
| if ret != 0 or e.errors: | if ret != 0 or e.errors: | ||||||
|     print "error doing schema validation" |     print("error doing schema validation") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
|  |  | ||||||
| @@ -64,7 +64,7 @@ doc.freeDoc() | |||||||
| doc = libxml2.parseDoc(invalid) | doc = libxml2.parseDoc(invalid) | ||||||
| ret = doc.schemaValidateDoc(ctxt_valid) | ret = doc.schemaValidateDoc(ctxt_valid) | ||||||
| if ret == 0 or not e.errors: | if ret == 0 or not e.errors: | ||||||
|     print "Error: document supposer to be schema invalid" |     print("Error: document supposer to be schema invalid") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
|  |  | ||||||
| @@ -76,8 +76,8 @@ libxml2.schemaCleanupTypes() | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|  |  | ||||||
|   | |||||||
| @@ -12,14 +12,14 @@ doc = ctxt.doc() | |||||||
| valid = ctxt.isValid() | valid = ctxt.isValid() | ||||||
|  |  | ||||||
| if doc.name != "valid.xml": | if doc.name != "valid.xml": | ||||||
|     print "doc.name failed" |     print("doc.name failed") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| root = doc.children | root = doc.children | ||||||
| if root.name != "doc": | if root.name != "doc": | ||||||
|     print "root.name failed" |     print("root.name failed") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if valid != 1: | if valid != 1: | ||||||
|     print "validity chec failed" |     print("validity chec failed") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
|  |  | ||||||
| @@ -32,7 +32,7 @@ while i > 0: | |||||||
|     valid = ctxt.isValid() |     valid = ctxt.isValid() | ||||||
|     doc.freeDoc() |     doc.freeDoc() | ||||||
|     if valid != 1: |     if valid != 1: | ||||||
|         print "validity check failed" |         print("validity check failed") | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|     i = i - 1 |     i = i - 1 | ||||||
|  |  | ||||||
| @@ -48,14 +48,14 @@ ctxt.parseDocument() | |||||||
| doc = ctxt.doc() | doc = ctxt.doc() | ||||||
| valid = ctxt.isValid() | valid = ctxt.isValid() | ||||||
| if doc.name != "invalid.xml": | if doc.name != "invalid.xml": | ||||||
|     print "doc.name failed" |     print("doc.name failed") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| root = doc.children | root = doc.children | ||||||
| if root.name != "doc": | if root.name != "doc": | ||||||
|     print "root.name failed" |     print("root.name failed") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if valid != 0: | if valid != 0: | ||||||
|     print "validity chec failed" |     print("validity chec failed") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
|  |  | ||||||
| @@ -68,7 +68,7 @@ while i > 0: | |||||||
|     valid = ctxt.isValid() |     valid = ctxt.isValid() | ||||||
|     doc.freeDoc() |     doc.freeDoc() | ||||||
|     if valid != 0: |     if valid != 0: | ||||||
|         print "validity check failed" |         print("validity check failed") | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|     i = i - 1 |     i = i - 1 | ||||||
| del ctxt | del ctxt | ||||||
| @@ -76,7 +76,7 @@ del ctxt | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
| # this tests the entities substitutions with the XmlTextReader interface | # this tests the entities substitutions with the XmlTextReader interface | ||||||
| # | # | ||||||
| import sys | import sys | ||||||
| import StringIO | import io | ||||||
| import libxml2 | import libxml2 | ||||||
|  |  | ||||||
| # Memory debug specific | # Memory debug specific | ||||||
| @@ -45,12 +45,12 @@ while ret == 1: | |||||||
|     ret = reader.Read() |     ret = reader.Read() | ||||||
|  |  | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "Error parsing the document test1" |     print("Error parsing the document test1") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| if result != expect: | if result != expect: | ||||||
|     print "Unexpected result for test1" |     print("Unexpected result for test1") | ||||||
|     print result |     print(result) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| @@ -85,12 +85,12 @@ while ret == 1: | |||||||
|     ret = reader.Read() |     ret = reader.Read() | ||||||
|  |  | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "Error parsing the document test2" |     print("Error parsing the document test2") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| if result != expect: | if result != expect: | ||||||
|     print "Unexpected result for test2" |     print("Unexpected result for test2") | ||||||
|     print result |     print(result) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| @@ -123,12 +123,12 @@ while ret == 1: | |||||||
|     ret = reader.Read() |     ret = reader.Read() | ||||||
|  |  | ||||||
| if ret != 0: | if ret != 0: | ||||||
|     print "Error parsing the document test3" |     print("Error parsing the document test3") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| if result != expect: | if result != expect: | ||||||
|     print "Unexpected result for test3" |     print("Unexpected result for test3") | ||||||
|     print result |     print(result) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| # | # | ||||||
| @@ -139,7 +139,7 @@ del reader | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -11,24 +11,24 @@ libxml2.debugMemory(1) | |||||||
|  |  | ||||||
| doc = libxml2.parseFile("tst.xml") | doc = libxml2.parseFile("tst.xml") | ||||||
| if doc.name != "tst.xml": | if doc.name != "tst.xml": | ||||||
|     print "doc.name error" |     print("doc.name error") | ||||||
|     sys.exit(1); |     sys.exit(1); | ||||||
|  |  | ||||||
| ctxt = doc.xpathNewContext() | ctxt = doc.xpathNewContext() | ||||||
| res = ctxt.xpathEval("//*") | res = ctxt.xpathEval("//*") | ||||||
| if len(res) != 2: | if len(res) != 2: | ||||||
|     print "xpath query: wrong node set size" |     print("xpath query: wrong node set size") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if res[0].name != "doc" or res[1].name != "foo": | if res[0].name != "doc" or res[1].name != "foo": | ||||||
|     print "xpath query: wrong node set value" |     print("xpath query: wrong node set value") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| ctxt.setContextNode(res[0]) | ctxt.setContextNode(res[0]) | ||||||
| res = ctxt.xpathEval("foo") | res = ctxt.xpathEval("foo") | ||||||
| if len(res) != 1: | if len(res) != 1: | ||||||
|     print "xpath query: wrong node set size" |     print("xpath query: wrong node set size") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if res[0].name != "foo": | if res[0].name != "foo": | ||||||
|     print "xpath query: wrong node set value" |     print("xpath query: wrong node set value") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| ctxt.xpathFreeContext() | ctxt.xpathFreeContext() | ||||||
| @@ -45,7 +45,7 @@ del ctxt | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -15,10 +15,10 @@ doc = libxml2.parseFile("tst.xml") | |||||||
| ctxt = doc.xpathNewContext() | ctxt = doc.xpathNewContext() | ||||||
| res = ctxt.xpathEval("//*") | res = ctxt.xpathEval("//*") | ||||||
| if len(res) != 2: | if len(res) != 2: | ||||||
|     print "xpath query: wrong node set size" |     print("xpath query: wrong node set size") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if res[0].name != "doc" or res[1].name != "foo": | if res[0].name != "doc" or res[1].name != "foo": | ||||||
|     print "xpath query: wrong node set value" |     print("xpath query: wrong node set value") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| libxml2.registerXPathFunction(ctxt._o, "foo", None, foo) | libxml2.registerXPathFunction(ctxt._o, "foo", None, foo) | ||||||
| @@ -27,14 +27,14 @@ i = 10000 | |||||||
| while i > 0: | while i > 0: | ||||||
|     res = ctxt.xpathEval("foo(1)") |     res = ctxt.xpathEval("foo(1)") | ||||||
|     if res != 2: |     if res != 2: | ||||||
|         print "xpath extension failure" |         print("xpath extension failure") | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|     i = i - 1 |     i = i - 1 | ||||||
| i = 10000 | i = 10000 | ||||||
| while i > 0: | while i > 0: | ||||||
|     res = ctxt.xpathEval("bar(1)") |     res = ctxt.xpathEval("bar(1)") | ||||||
|     if res != "3": |     if res != "3": | ||||||
|         print "xpath extension failure got %s expecting '3'" |         print("xpath extension failure got %s expecting '3'") | ||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
|     i = i - 1 |     i = i - 1 | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| @@ -43,7 +43,7 @@ ctxt.xpathFreeContext() | |||||||
| # Memory debug specific | # Memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								python/tests/xpathleak.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										14
									
								
								python/tests/xpathleak.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -42,24 +42,24 @@ badexprs = ( | |||||||
| for expr in badexprs: | for expr in badexprs: | ||||||
| 	try: | 	try: | ||||||
| 		ctxt.xpathEval(expr) | 		ctxt.xpathEval(expr) | ||||||
| 	except libxml2.xpathError, e: | 	except libxml2.xpathError as e: | ||||||
| 	        pass | 	        pass | ||||||
| 	else: | 	else: | ||||||
| 		print "Unexpectedly legal expression:", expr | 		print("Unexpectedly legal expression:", expr) | ||||||
| ctxt.xpathFreeContext() | ctxt.xpathFreeContext() | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
|  |  | ||||||
| if err != expect: | if err != expect: | ||||||
|     print "error" |     print("error") | ||||||
|     print "received %s" %(err) |     print("received %s" %(err)) | ||||||
|     print "expected %s" %(expect) |     print("expected %s" %(expect)) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| leakedbytes = libxml2.debugMemory(True) | leakedbytes = libxml2.debugMemory(True) | ||||||
| if leakedbytes == 0: | if leakedbytes == 0: | ||||||
| 	print "OK" | 	print("OK") | ||||||
| else: | else: | ||||||
| 	print "Memory leak", leakedbytes, "bytes" | 	print("Memory leak", leakedbytes, "bytes") | ||||||
| 	# drop file to .memdump file in cwd, but won't work if not compiled in | 	# drop file to .memdump file in cwd, but won't work if not compiled in | ||||||
| 	libxml2.dumpMemory() | 	libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -14,8 +14,8 @@ for n in d.xpathEval("//namespace::*"): | |||||||
| d.freeDoc() | d.freeDoc() | ||||||
|  |  | ||||||
| if res != expect: | if res != expect: | ||||||
|     print "test5 failed: unexpected output" |     print("test5 failed: unexpected output") | ||||||
|     print res |     print(res) | ||||||
| del res | del res | ||||||
| del d | del d | ||||||
| del n | del n | ||||||
| @@ -23,7 +23,7 @@ del n | |||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
|  |  | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
| @@ -27,21 +27,21 @@ ctxt = doc.xpathNewContext() | |||||||
| libxml2.registerXPathFunction(ctxt._o, "foo", None, foo) | libxml2.registerXPathFunction(ctxt._o, "foo", None, foo) | ||||||
| res = ctxt.xpathEval("foo('hello')") | res = ctxt.xpathEval("foo('hello')") | ||||||
| if type(res) != type([]): | if type(res) != type([]): | ||||||
|     print "Failed to return a nodeset" |     print("Failed to return a nodeset") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if len(res) != 1: | if len(res) != 1: | ||||||
|     print "Unexpected nodeset size" |     print("Unexpected nodeset size") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| node = res[0] | node = res[0] | ||||||
| if node.name != 'p': | if node.name != 'p': | ||||||
|     print "Unexpected nodeset element result" |     print("Unexpected nodeset element result") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| node = node.children | node = node.children | ||||||
| if node.type != 'text': | if node.type != 'text': | ||||||
|     print "Unexpected nodeset element children type" |     print("Unexpected nodeset element children type") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| if node.content != 'hello': | if node.content != 'hello': | ||||||
|     print "Unexpected nodeset element children content" |     print("Unexpected nodeset element children content") | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
|  |  | ||||||
| doc.freeDoc() | doc.freeDoc() | ||||||
| @@ -51,7 +51,7 @@ ctxt.xpathFreeContext() | |||||||
| #memory debug specific | #memory debug specific | ||||||
| libxml2.cleanupParser() | libxml2.cleanupParser() | ||||||
| if libxml2.debugMemory(1) == 0: | if libxml2.debugMemory(1) == 0: | ||||||
|     print "OK" |     print("OK") | ||||||
| else: | else: | ||||||
|     print "Memory leak %d bytes" % (libxml2.debugMemory(1)) |     print("Memory leak %d bytes" % (libxml2.debugMemory(1))) | ||||||
|     libxml2.dumpMemory() |     libxml2.dumpMemory() | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user