mirror of
https://gitlab.gnome.org/GNOME/libxml2.git
synced 2025-02-19 09:57:23 +03:00
* parser.c: make sure SAX endDocument is always called as this could result in a Python memory leak otherwise (it's used to decrement ref-counting) * python/generator.py python/libxml.c python/libxml.py python/libxml2-python-api.xml python/libxml2class.txt python/tests/error.py python/tests/xpath.py: implemented the suggestions made by Gary Benson and extended the tests to match it. Daniel
52 lines
1.2 KiB
Python
Executable File
52 lines
1.2 KiB
Python
Executable File
#!/usr/bin/python -u
|
|
#
|
|
# this test exercise the XPath basic engine, parser, etc, and
|
|
# allows to detect memory leaks
|
|
#
|
|
import sys
|
|
import libxml2
|
|
|
|
# Memory debug specific
|
|
libxml2.debugMemory(1)
|
|
|
|
doc = libxml2.parseFile("tst.xml")
|
|
if doc.name != "tst.xml":
|
|
print "doc.name error"
|
|
sys.exit(1);
|
|
|
|
ctxt = doc.xpathNewContext()
|
|
res = ctxt.xpathEval("//*")
|
|
if len(res) != 2:
|
|
print "xpath query: wrong node set size"
|
|
sys.exit(1)
|
|
if res[0].name != "doc" or res[1].name != "foo":
|
|
print "xpath query: wrong node set value"
|
|
sys.exit(1)
|
|
ctxt.setContextNode(res[0])
|
|
res = ctxt.xpathEval("foo")
|
|
if len(res) != 1:
|
|
print "xpath query: wrong node set size"
|
|
sys.exit(1)
|
|
if res[0].name != "foo":
|
|
print "xpath query: wrong node set value"
|
|
sys.exit(1)
|
|
doc.freeDoc()
|
|
ctxt.xpathFreeContext()
|
|
i = 1000
|
|
while i > 0:
|
|
doc = libxml2.parseFile("tst.xml")
|
|
ctxt = doc.xpathNewContext()
|
|
res = ctxt.xpathEval("//*")
|
|
doc.freeDoc()
|
|
ctxt.xpathFreeContext()
|
|
i = i -1
|
|
del ctxt
|
|
|
|
# Memory debug specific
|
|
libxml2.cleanupParser()
|
|
if libxml2.debugMemory(1) == 0:
|
|
print "OK"
|
|
else:
|
|
print "Memory leak %d bytes" % (libxml2.debugMemory(1))
|
|
libxml2.dumpMemory()
|