mirror of
https://gitlab.gnome.org/GNOME/libxml2.git
synced 2024-12-24 21:33:51 +03:00
Add the directory containing libxml2.dll with os.add_dll_directory to make tests work on MinGW. This has changed in Python 3.8 but for some reason, the issue only turned up with Python 3.11 on MinGW. Contrary to documentation, copying libxml2.dll into the directory containing the .pyd file doesn't work.
139 lines
3.8 KiB
Python
Executable File
139 lines
3.8 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
import sys
|
|
import setup_test
|
|
import libxml2
|
|
|
|
# Memory debug specific
|
|
libxml2.debugMemory(1)
|
|
|
|
log = ""
|
|
|
|
class callback:
|
|
def startDocument(self):
|
|
global log
|
|
log = log + "startDocument:"
|
|
|
|
def endDocument(self):
|
|
global log
|
|
log = log + "endDocument:"
|
|
|
|
def startElement(self, tag, attrs):
|
|
global log
|
|
log = log + "startElement %s %s:" % (tag, attrs)
|
|
|
|
def endElement(self, tag):
|
|
global log
|
|
log = log + "endElement %s:" % (tag)
|
|
|
|
def characters(self, data):
|
|
global log
|
|
log = log + "characters: %s:" % (data)
|
|
|
|
def warning(self, msg):
|
|
global log
|
|
log = log + "warning: %s:" % (msg)
|
|
|
|
def error(self, msg):
|
|
global log
|
|
log = log + "error: %s:" % (msg)
|
|
|
|
def fatalError(self, msg):
|
|
global log
|
|
log = log + "fatalError: %s:" % (msg)
|
|
|
|
handler = callback()
|
|
|
|
log=""
|
|
chunk="""<foo><bar2/>"""
|
|
ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
|
|
ctxt.parseChunk(chunk, len(chunk), 0)
|
|
ctxt=None
|
|
|
|
reference = "startDocument:startElement foo None:startElement bar2 None:endElement bar2:"
|
|
if log != reference:
|
|
print("Error got: %s" % log)
|
|
print("Expected: %s" % reference)
|
|
sys.exit(1)
|
|
|
|
log=""
|
|
chunk="""<foo><bar2></bar2>"""
|
|
ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
|
|
ctxt.parseChunk(chunk, len(chunk), 0)
|
|
ctxt=None
|
|
|
|
reference = "startDocument:startElement foo None:startElement bar2 None:endElement bar2:"
|
|
if log != reference:
|
|
print("Error got: %s" % log)
|
|
print("Expected: %s" % reference)
|
|
sys.exit(1)
|
|
|
|
log=""
|
|
chunk="""<foo><bar2>"""
|
|
ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
|
|
ctxt.parseChunk(chunk, len(chunk), 0)
|
|
ctxt=None
|
|
|
|
reference = "startDocument:startElement foo None:startElement bar2 None:"
|
|
if log != reference:
|
|
print("Error got: %s" % log)
|
|
print("Expected: %s" % reference)
|
|
sys.exit(1)
|
|
|
|
log=""
|
|
chunk="""<foo><bar2 a="1" b='2' />"""
|
|
ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
|
|
ctxt.parseChunk(chunk, len(chunk), 0)
|
|
ctxt=None
|
|
|
|
reference1 = "startDocument:startElement foo None:startElement bar2 {'a': '1', 'b': '2'}:endElement bar2:"
|
|
reference2 = "startDocument:startElement foo None:startElement bar2 {'b': '2', 'a': '1'}:endElement bar2:"
|
|
if log not in (reference1, reference2):
|
|
print("Error got: %s" % log)
|
|
print("Expected: %s" % reference)
|
|
sys.exit(1)
|
|
|
|
log=""
|
|
chunk="""<foo><bar2 a="1" b='2' >"""
|
|
ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
|
|
ctxt.parseChunk(chunk, len(chunk), 0)
|
|
ctxt=None
|
|
|
|
reference1 = "startDocument:startElement foo None:startElement bar2 {'a': '1', 'b': '2'}:"
|
|
reference2 = "startDocument:startElement foo None:startElement bar2 {'b': '2', 'a': '1'}:"
|
|
if log not in (reference1, reference2):
|
|
print("Error got: %s" % log)
|
|
print("Expected: %s" % reference)
|
|
sys.exit(1)
|
|
|
|
log=""
|
|
chunk="""<foo><bar2 a="1" b='2' ></bar2>"""
|
|
ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
|
|
ctxt.parseChunk(chunk, len(chunk), 0)
|
|
ctxt=None
|
|
|
|
reference1 = "startDocument:startElement foo None:startElement bar2 {'a': '1', 'b': '2'}:endElement bar2:"
|
|
reference2 = "startDocument:startElement foo None:startElement bar2 {'b': '2', 'a': '1'}:endElement bar2:"
|
|
if log not in (reference1, reference2):
|
|
print("Error got: %s" % log)
|
|
print("Expected: %s" % reference)
|
|
sys.exit(1)
|
|
|
|
log=""
|
|
chunk="""<foo><bar2 a="b='1' />"""
|
|
ctxt = libxml2.createPushParser(handler, None, 0, "test.xml")
|
|
ctxt.parseChunk(chunk, len(chunk), 0)
|
|
ctxt=None
|
|
|
|
reference = "startDocument:startElement foo None:"
|
|
if log != reference:
|
|
print("Error got: %s" % log)
|
|
print("Expected: %s" % reference)
|
|
sys.exit(1)
|
|
|
|
# Memory debug specific
|
|
libxml2.cleanupParser()
|
|
if libxml2.debugMemory(1) == 0:
|
|
print("OK")
|
|
else:
|
|
print("Memory leak %d bytes" % (libxml2.debugMemory(1)))
|