|
Packit |
423ecb |
#!/usr/bin/python -u
|
|
Packit |
423ecb |
#
|
|
Packit |
423ecb |
# this tests the DTD validation with the XmlTextReader interface
|
|
Packit |
423ecb |
#
|
|
Packit |
423ecb |
import sys
|
|
Packit |
423ecb |
import glob
|
|
Packit |
423ecb |
import string
|
|
Packit |
423ecb |
import libxml2
|
|
Packit |
423ecb |
try:
|
|
Packit |
423ecb |
import StringIO
|
|
Packit |
423ecb |
str_io = StringIO.StringIO
|
|
Packit |
423ecb |
except:
|
|
Packit |
423ecb |
import io
|
|
Packit |
423ecb |
str_io = io.StringIO
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
# Memory debug specific
|
|
Packit |
423ecb |
libxml2.debugMemory(1)
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
err=""
|
|
Packit |
423ecb |
expect="""../../test/valid/rss.xml:177: element rss: validity error : Element rss does not carry attribute version
|
|
Packit |
423ecb |
</rss>
|
|
Packit |
423ecb |
^
|
|
Packit |
423ecb |
../../test/valid/xlink.xml:450: element termdef: validity error : ID dt-arc already defined
|
|
Packit |
423ecb |
<termdef id="dt-arc" term="Arc">An
|
|
Packit |
423ecb |
^
|
|
Packit |
423ecb |
../../test/valid/xlink.xml:530: validity error : attribute def line 199 references an unknown ID "dt-xlg"
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
^
|
|
Packit |
423ecb |
"""
|
|
Packit |
423ecb |
def callback(ctx, str):
|
|
Packit |
423ecb |
global err
|
|
Packit |
423ecb |
err = err + "%s" % (str)
|
|
Packit |
423ecb |
libxml2.registerErrorHandler(callback, "")
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
valid_files = glob.glob("../../test/valid/*.x*")
|
|
Packit |
423ecb |
valid_files.sort()
|
|
Packit |
423ecb |
for file in valid_files:
|
|
Packit |
423ecb |
if file.find("t8") != -1:
|
|
Packit |
423ecb |
continue
|
|
Packit |
423ecb |
if file == "../../test/valid/rss.xml":
|
|
Packit |
423ecb |
continue
|
|
Packit |
423ecb |
if file == "../../test/valid/xlink.xml":
|
|
Packit |
423ecb |
continue
|
|
Packit |
423ecb |
reader = libxml2.newTextReaderFilename(file)
|
|
Packit |
423ecb |
#print "%s:" % (file)
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_VALIDATE, 1)
|
|
Packit |
423ecb |
ret = reader.Read()
|
|
Packit |
423ecb |
while ret == 1:
|
|
Packit |
423ecb |
ret = reader.Read()
|
|
Packit |
423ecb |
if ret != 0:
|
|
Packit |
423ecb |
print("Error parsing and validating %s" % (file))
|
|
Packit |
423ecb |
#sys.exit(1)
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
if err != expect:
|
|
Packit |
423ecb |
print(err)
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
#
|
|
Packit |
423ecb |
# another separate test based on Stephane Bidoul one
|
|
Packit |
423ecb |
#
|
|
Packit |
423ecb |
s = """
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
<c>xxx</c></x>">
|
|
Packit |
423ecb |
]>
|
|
Packit |
423ecb |
<test>
|
|
Packit |
423ecb |
&x;
|
|
Packit |
423ecb |
bbb
|
|
Packit |
423ecb |
</test>
|
|
Packit |
423ecb |
"""
|
|
Packit |
423ecb |
expect="""10,test
|
|
Packit |
423ecb |
1,test
|
|
Packit |
423ecb |
14,#text
|
|
Packit |
423ecb |
1,x
|
|
Packit |
423ecb |
1,c
|
|
Packit |
423ecb |
3,#text
|
|
Packit |
423ecb |
15,c
|
|
Packit |
423ecb |
15,x
|
|
Packit |
423ecb |
14,#text
|
|
Packit |
423ecb |
1,b
|
|
Packit |
423ecb |
3,#text
|
|
Packit |
423ecb |
15,b
|
|
Packit |
423ecb |
14,#text
|
|
Packit |
423ecb |
15,test
|
|
Packit |
423ecb |
"""
|
|
Packit |
423ecb |
res=""
|
|
Packit |
423ecb |
err=""
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
input = libxml2.inputBuffer(str_io(s))
|
|
Packit |
423ecb |
reader = input.newTextReader("test2")
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_LOADDTD,1)
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_DEFAULTATTRS,1)
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_SUBST_ENTITIES,1)
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_VALIDATE,1)
|
|
Packit |
423ecb |
while reader.Read() == 1:
|
|
Packit |
423ecb |
res = res + "%s,%s\n" % (reader.NodeType(),reader.Name())
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
if res != expect:
|
|
Packit |
423ecb |
print("test2 failed: unexpected output")
|
|
Packit |
423ecb |
print(res)
|
|
Packit |
423ecb |
sys.exit(1)
|
|
Packit |
423ecb |
if err != "":
|
|
Packit |
423ecb |
print("test2 failed: validation error found")
|
|
Packit |
423ecb |
print(err)
|
|
Packit |
423ecb |
sys.exit(1)
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
#
|
|
Packit |
423ecb |
# Another test for external entity parsing and validation
|
|
Packit |
423ecb |
#
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
s = """
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
]>
|
|
Packit |
423ecb |
<test>
|
|
Packit |
423ecb |
&e;
|
|
Packit |
423ecb |
</test>
|
|
Packit |
423ecb |
"""
|
|
Packit |
423ecb |
tst_ent = """<x>hello</x>"""
|
|
Packit |
423ecb |
expect="""10 test
|
|
Packit |
423ecb |
1 test
|
|
Packit |
423ecb |
14 #text
|
|
Packit |
423ecb |
1 x
|
|
Packit |
423ecb |
3 #text
|
|
Packit |
423ecb |
15 x
|
|
Packit |
423ecb |
14 #text
|
|
Packit |
423ecb |
15 test
|
|
Packit |
423ecb |
"""
|
|
Packit |
423ecb |
res=""
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
def myResolver(URL, ID, ctxt):
|
|
Packit |
423ecb |
if URL == "tst.ent":
|
|
Packit |
423ecb |
return(str_io(tst_ent))
|
|
Packit |
423ecb |
return None
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
libxml2.setEntityLoader(myResolver)
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
input = libxml2.inputBuffer(str_io(s))
|
|
Packit |
423ecb |
reader = input.newTextReader("test3")
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_LOADDTD,1)
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_DEFAULTATTRS,1)
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_SUBST_ENTITIES,1)
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_VALIDATE,1)
|
|
Packit |
423ecb |
while reader.Read() == 1:
|
|
Packit |
423ecb |
res = res + "%s %s\n" % (reader.NodeType(),reader.Name())
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
if res != expect:
|
|
Packit |
423ecb |
print("test3 failed: unexpected output")
|
|
Packit |
423ecb |
print(res)
|
|
Packit |
423ecb |
sys.exit(1)
|
|
Packit |
423ecb |
if err != "":
|
|
Packit |
423ecb |
print("test3 failed: validation error found")
|
|
Packit |
423ecb |
print(err)
|
|
Packit |
423ecb |
sys.exit(1)
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
#
|
|
Packit |
423ecb |
# Another test for recursive entity parsing, validation, and replacement of
|
|
Packit |
423ecb |
# entities, making sure the entity ref node doesn't show up in that case
|
|
Packit |
423ecb |
#
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
s = """
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
&y;</x>">
|
|
Packit |
423ecb |
yyy</y>">
|
|
Packit |
423ecb |
]>
|
|
Packit |
423ecb |
<test>
|
|
Packit |
423ecb |
&x;
|
|
Packit |
423ecb |
&x;
|
|
Packit |
423ecb |
</test>"""
|
|
Packit |
423ecb |
expect="""10 test 0
|
|
Packit |
423ecb |
1 test 0
|
|
Packit |
423ecb |
14 #text 1
|
|
Packit |
423ecb |
1 x 1
|
|
Packit |
423ecb |
1 y 2
|
|
Packit |
423ecb |
3 #text 3
|
|
Packit |
423ecb |
15 y 2
|
|
Packit |
423ecb |
15 x 1
|
|
Packit |
423ecb |
14 #text 1
|
|
Packit |
423ecb |
1 x 1
|
|
Packit |
423ecb |
1 y 2
|
|
Packit |
423ecb |
3 #text 3
|
|
Packit |
423ecb |
15 y 2
|
|
Packit |
423ecb |
15 x 1
|
|
Packit |
423ecb |
14 #text 1
|
|
Packit |
423ecb |
15 test 0
|
|
Packit |
423ecb |
"""
|
|
Packit |
423ecb |
res=""
|
|
Packit |
423ecb |
err=""
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
input = libxml2.inputBuffer(str_io(s))
|
|
Packit |
423ecb |
reader = input.newTextReader("test4")
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_LOADDTD,1)
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_DEFAULTATTRS,1)
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_SUBST_ENTITIES,1)
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_VALIDATE,1)
|
|
Packit |
423ecb |
while reader.Read() == 1:
|
|
Packit |
423ecb |
res = res + "%s %s %d\n" % (reader.NodeType(),reader.Name(),reader.Depth())
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
if res != expect:
|
|
Packit |
423ecb |
print("test4 failed: unexpected output")
|
|
Packit |
423ecb |
print(res)
|
|
Packit |
423ecb |
sys.exit(1)
|
|
Packit |
423ecb |
if err != "":
|
|
Packit |
423ecb |
print("test4 failed: validation error found")
|
|
Packit |
423ecb |
print(err)
|
|
Packit |
423ecb |
sys.exit(1)
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
#
|
|
Packit |
423ecb |
# The same test but without entity substitution this time
|
|
Packit |
423ecb |
#
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
s = """
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
&y;</x>">
|
|
Packit |
423ecb |
yyy</y>">
|
|
Packit |
423ecb |
]>
|
|
Packit |
423ecb |
<test>
|
|
Packit |
423ecb |
&x;
|
|
Packit |
423ecb |
&x;
|
|
Packit |
423ecb |
</test>"""
|
|
Packit |
423ecb |
expect="""10 test 0
|
|
Packit |
423ecb |
1 test 0
|
|
Packit |
423ecb |
14 #text 1
|
|
Packit |
423ecb |
5 x 1
|
|
Packit |
423ecb |
14 #text 1
|
|
Packit |
423ecb |
5 x 1
|
|
Packit |
423ecb |
14 #text 1
|
|
Packit |
423ecb |
15 test 0
|
|
Packit |
423ecb |
"""
|
|
Packit |
423ecb |
res=""
|
|
Packit |
423ecb |
err=""
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
input = libxml2.inputBuffer(str_io(s))
|
|
Packit |
423ecb |
reader = input.newTextReader("test5")
|
|
Packit |
423ecb |
reader.SetParserProp(libxml2.PARSER_VALIDATE,1)
|
|
Packit |
423ecb |
while reader.Read() == 1:
|
|
Packit |
423ecb |
res = res + "%s %s %d\n" % (reader.NodeType(),reader.Name(),reader.Depth())
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
if res != expect:
|
|
Packit |
423ecb |
print("test5 failed: unexpected output")
|
|
Packit |
423ecb |
print(res)
|
|
Packit |
423ecb |
if err != "":
|
|
Packit |
423ecb |
print("test5 failed: validation error found")
|
|
Packit |
423ecb |
print(err)
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
#
|
|
Packit |
423ecb |
# cleanup
|
|
Packit |
423ecb |
#
|
|
Packit |
423ecb |
del input
|
|
Packit |
423ecb |
del reader
|
|
Packit |
423ecb |
|
|
Packit |
423ecb |
# Memory debug specific
|
|
Packit |
423ecb |
libxml2.cleanupParser()
|
|
Packit |
423ecb |
if libxml2.debugMemory(1) == 0:
|
|
Packit |
423ecb |
print("OK")
|
|
Packit |
423ecb |
else:
|
|
Packit |
423ecb |
print("Memory leak %d bytes" % (libxml2.debugMemory(1)))
|
|
Packit |
423ecb |
libxml2.dumpMemory()
|