| | |
| | |
| | |
| | |
| | |
| | import sys |
| | import glob |
| | import os |
| | import setup_test |
| | import libxml2 |
| | try: |
| | import StringIO |
| | str_io = StringIO.StringIO |
| | except: |
| | import io |
| | str_io = io.StringIO |
| |
|
| | |
| | libxml2.debugMemory(1) |
| |
|
| | err = "" |
| | basedir = os.path.dirname(os.path.realpath(__file__)) |
| | dir_prefix = os.path.realpath(os.path.join(basedir, "..", "..", "test", "valid")) |
| |
|
| | |
| | |
| | |
| |
|
| | expect = { |
| | '766956': |
| | """{0}/dtds/766956.dtd:2: parser error : PEReference: expecting ';' |
| | %ä%ent; |
| | ^ |
| | {0}/dtds/766956.dtd:2: parser error : Content error in the external subset |
| | %ä%ent; |
| | ^ |
| | Entity: line 1: |
| | value |
| | ^ |
| | """.format(dir_prefix), |
| | '781333': |
| | """{0}/781333.xml:4: element a: validity error : Element a content does not follow the DTD, expecting ( ..., got |
| | <a/> |
| | ^ |
| | {0}/781333.xml:5: element a: validity error : Element a content does not follow the DTD, Expecting more children |
| | |
| | ^ |
| | """.format(dir_prefix), |
| | 'cond_sect2': |
| | """{0}/dtds/cond_sect2.dtd:15: parser error : Parameter entity must match extSubsetDecl |
| | %ent; |
| | ^ |
| | Entity: line 1: |
| | ]]> |
| | ^ |
| | {0}/dtds/cond_sect2.dtd:15: parser error : Content error in the external subset |
| | %ent; |
| | ^ |
| | Entity: line 1: |
| | ]]> |
| | ^ |
| | """.format(dir_prefix), |
| | 'rss': |
| | """{0}/rss.xml:177: element rss: validity error : Element rss does not carry attribute version |
| | </rss> |
| | ^ |
| | """.format(dir_prefix), |
| | 't8': |
| | """{0}/t8.xml:6: parser error : Content error in the internal subset |
| | %defroot; %defmiddle; %deftest; |
| | ^ |
| | Entity: line 1: |
| | <!ELEMENT root (middle) > |
| | ^ |
| | """.format(dir_prefix), |
| | 't8a': |
| | """{0}/t8a.xml:6: parser error : Content error in the internal subset |
| | %defroot;%defmiddle;%deftest; |
| | ^ |
| | Entity: line 1: |
| | <!ELEMENT root (middle) > |
| | ^ |
| | """.format(dir_prefix), |
| | 'xlink': |
| | """{0}/xlink.xml:450: element termdef: validity error : ID dt-arc already defined |
| | <p><termdef id="dt-arc" term="Arc">An <ter |
| | ^ |
| | validity error : attribute def line 199 references an unknown ID "dt-xlg" |
| | """.format(dir_prefix), |
| | } |
| |
|
| | |
| | expect = {os.path.join(dir_prefix, key + ".xml"): val for key, val in expect.items()} |
| |
|
| | def callback(ctx, str): |
| | global err |
| | err = err + "%s" % (str) |
| | libxml2.registerErrorHandler(callback, "") |
| |
|
| | parsing_error_files = ["766956", "cond_sect2", "t8", "t8a", "pe-in-text-decl"] |
| | expect_parsing_error = [os.path.join(dir_prefix, f + ".xml") for f in parsing_error_files] |
| |
|
| | valid_files = glob.glob(os.path.join(dir_prefix, "*.x*")) |
| | assert valid_files, "found no valid files in '{}'".format(dir_prefix) |
| | valid_files.sort() |
| | failures = 0 |
| | for file in valid_files: |
| | err = "" |
| | reader = libxml2.newTextReaderFilename(file) |
| | |
| | reader.SetParserProp(libxml2.PARSER_VALIDATE, 1) |
| | ret = reader.Read() |
| | while ret == 1: |
| | ret = reader.Read() |
| | if ret != 0 and file not in expect_parsing_error: |
| | print("Error parsing and validating %s" % (file)) |
| | |
| | if file in expect and err != expect[file]: |
| | failures += 1 |
| | print("Error: ", err) |
| | if file in expect: |
| | print("Expected: ", expect[file]) |
| |
|
| | if failures: |
| | print("Failed %d tests" % failures) |
| | sys.exit(1) |
| |
|
| | |
| | |
| | |
| | s = """ |
| | <!DOCTYPE test [ |
| | <!ELEMENT test (x,b)> |
| | <!ELEMENT x (c)> |
| | <!ELEMENT b (#PCDATA)> |
| | <!ELEMENT c (#PCDATA)> |
| | <!ENTITY x "<x><c>xxx</c></x>"> |
| | ]> |
| | <test> |
| | &x; |
| | <b>bbb</b> |
| | </test> |
| | """ |
| | expect="""10,test |
| | 1,test |
| | 14,#text |
| | 1,x |
| | 1,c |
| | 3,#text |
| | 15,c |
| | 15,x |
| | 14,#text |
| | 1,b |
| | 3,#text |
| | 15,b |
| | 14,#text |
| | 15,test |
| | """ |
| | res="" |
| | err="" |
| |
|
| | input = libxml2.inputBuffer(str_io(s)) |
| | reader = input.newTextReader("test2") |
| | reader.SetParserProp(libxml2.PARSER_LOADDTD,1) |
| | reader.SetParserProp(libxml2.PARSER_DEFAULTATTRS,1) |
| | reader.SetParserProp(libxml2.PARSER_SUBST_ENTITIES,1) |
| | reader.SetParserProp(libxml2.PARSER_VALIDATE,1) |
| | while reader.Read() == 1: |
| | res = res + "%s,%s\n" % (reader.NodeType(),reader.Name()) |
| |
|
| | if res != expect: |
| | print("test2 failed: unexpected output") |
| | print(res) |
| | sys.exit(1) |
| | if err != "": |
| | print("test2 failed: validation error found") |
| | print(err) |
| | sys.exit(1) |
| |
|
| | |
| | |
| | |
| |
|
| | s = """<!DOCTYPE test [ |
| | <!ELEMENT test (x)> |
| | <!ELEMENT x (#PCDATA)> |
| | <!ENTITY e SYSTEM "tst.ent"> |
| | ]> |
| | <test> |
| | &e; |
| | </test> |
| | """ |
| | tst_ent = """<x>hello</x>""" |
| | expect="""10 test |
| | 1 test |
| | 14 #text |
| | 1 x |
| | 3 #text |
| | 15 x |
| | 14 #text |
| | 15 test |
| | """ |
| | res="" |
| |
|
| | def myResolver(URL, ID, ctxt): |
| | if URL == "tst.ent": |
| | return(str_io(tst_ent)) |
| | return None |
| |
|
| | libxml2.setEntityLoader(myResolver) |
| |
|
| | input = libxml2.inputBuffer(str_io(s)) |
| | reader = input.newTextReader("test3") |
| | reader.SetParserProp(libxml2.PARSER_LOADDTD,1) |
| | reader.SetParserProp(libxml2.PARSER_DEFAULTATTRS,1) |
| | reader.SetParserProp(libxml2.PARSER_SUBST_ENTITIES,1) |
| | reader.SetParserProp(libxml2.PARSER_VALIDATE,1) |
| | while reader.Read() == 1: |
| | res = res + "%s %s\n" % (reader.NodeType(),reader.Name()) |
| |
|
| | if res != expect: |
| | print("test3 failed: unexpected output") |
| | print(res) |
| | sys.exit(1) |
| | if err != "": |
| | print("test3 failed: validation error found") |
| | print(err) |
| | sys.exit(1) |
| |
|
| | |
| | |
| | |
| | |
| |
|
| | s = """<!DOCTYPE test [ |
| | <!ELEMENT test (x, x)> |
| | <!ELEMENT x (y)> |
| | <!ELEMENT y (#PCDATA)> |
| | <!ENTITY x "<x>&y;</x>"> |
| | <!ENTITY y "<y>yyy</y>"> |
| | ]> |
| | <test> |
| | &x; |
| | &x; |
| | </test>""" |
| | expect="""10 test 0 |
| | 1 test 0 |
| | 14 #text 1 |
| | 1 x 1 |
| | 1 y 2 |
| | 3 #text 3 |
| | 15 y 2 |
| | 15 x 1 |
| | 14 #text 1 |
| | 1 x 1 |
| | 1 y 2 |
| | 3 #text 3 |
| | 15 y 2 |
| | 15 x 1 |
| | 14 #text 1 |
| | 15 test 0 |
| | """ |
| | res="" |
| | err="" |
| |
|
| | input = libxml2.inputBuffer(str_io(s)) |
| | reader = input.newTextReader("test4") |
| | reader.SetParserProp(libxml2.PARSER_LOADDTD,1) |
| | reader.SetParserProp(libxml2.PARSER_DEFAULTATTRS,1) |
| | reader.SetParserProp(libxml2.PARSER_SUBST_ENTITIES,1) |
| | reader.SetParserProp(libxml2.PARSER_VALIDATE,1) |
| | while reader.Read() == 1: |
| | res = res + "%s %s %d\n" % (reader.NodeType(),reader.Name(),reader.Depth()) |
| |
|
| | if res != expect: |
| | print("test4 failed: unexpected output") |
| | print(res) |
| | sys.exit(1) |
| | if err != "": |
| | print("test4 failed: validation error found") |
| | print(err) |
| | sys.exit(1) |
| |
|
| | |
| | |
| | |
| |
|
| | s = """<!DOCTYPE test [ |
| | <!ELEMENT test (x, x)> |
| | <!ELEMENT x (y)> |
| | <!ELEMENT y (#PCDATA)> |
| | <!ENTITY x "<x>&y;</x>"> |
| | <!ENTITY y "<y>yyy</y>"> |
| | ]> |
| | <test> |
| | &x; |
| | &x; |
| | </test>""" |
| | expect="""10 test 0 |
| | 1 test 0 |
| | 14 #text 1 |
| | 5 x 1 |
| | 14 #text 1 |
| | 5 x 1 |
| | 14 #text 1 |
| | 15 test 0 |
| | """ |
| | res="" |
| | err="" |
| |
|
| | input = libxml2.inputBuffer(str_io(s)) |
| | reader = input.newTextReader("test5") |
| | reader.SetParserProp(libxml2.PARSER_VALIDATE,1) |
| | while reader.Read() == 1: |
| | res = res + "%s %s %d\n" % (reader.NodeType(),reader.Name(),reader.Depth()) |
| |
|
| | if res != expect: |
| | print("test5 failed: unexpected output") |
| | print(res) |
| | sys.exit(1) |
| | if err != "": |
| | print("test5 failed: validation error found") |
| | print(err) |
| | sys.exit(1) |
| |
|
| | |
| | |
| | |
| | del input |
| | del reader |
| |
|
| | |
| | libxml2.cleanupParser() |
| | if libxml2.debugMemory(1) == 0: |
| | print("OK") |
| | else: |
| | print("Memory leak %d bytes" % (libxml2.debugMemory(1))) |
| |
|