Blame python/tests/reader2.py

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()