|
|
|
|
|
import sys |
|
|
import setup_test |
|
|
import libxml2 |
|
|
|
|
|
|
|
|
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) |
|
|
|
|
|
|
|
|
libxml2.cleanupParser() |
|
|
if libxml2.debugMemory(1) == 0: |
|
|
print("OK") |
|
|
else: |
|
|
print("Memory leak %d bytes" % (libxml2.debugMemory(1))) |
|
|
|