def run_test(desc, docpath, catalog, exp_status="verified", exp_err=[], test_callback=None, root_name="root", root_content="replacement text"): opts = libxml2.XML_PARSE_DTDLOAD | libxml2.XML_PARSE_NONET | libxml2.XML_PARSE_COMPACT actual_err = [] def my_global_error_cb(ctx, msg): actual_err.append((-1, msg)) def my_ctx_error_cb(arg, msg, severity, reserved): actual_err.append((severity, msg)) libxml2.registerErrorHandler(my_global_error_cb, None) try: parser = libxml2.createURLParserCtxt(docpath, opts) parser.setErrorHandler(my_ctx_error_cb, None) if catalog is not None: parser.addLocalCatalog(catalog) if test_callback is not None: test_callback() parser.parseDocument() doc = parser.doc() actual_status = "loaded" e = doc.getRootElement() if e.name == root_name and e.content == root_content: actual_status = "verified" doc.freeDoc() except libxml2.parserError: actual_status = "not loaded" if actual_status != exp_status: print("Test '%s' failed: expect status '%s', actual '%s'" % (desc, exp_status, actual_status)) sys.exit(1) elif actual_err != exp_err: print("Test '%s' failed" % desc) print("Expect errors:") for s, m in exp_err: print(" [%2d] '%s'" % (s, m)) print("Actual errors:") for s, m in actual_err: print(" [%2d] '%s'" % (s, m)) sys.exit(1)
def run_test(desc, docpath, catalog, exp_status="verified", exp_err=[], test_callback=None, root_name="root", root_content="replacement text"): opts = libxml2.XML_PARSE_DTDLOAD | libxml2.XML_PARSE_NONET | libxml2.XML_PARSE_COMPACT actual_err = [] def my_global_error_cb(ctx, msg): actual_err.append((-1, msg)) def my_ctx_error_cb(arg, msg, severity, reserved): actual_err.append((severity, msg)) libxml2.registerErrorHandler(my_global_error_cb, None) try: parser = libxml2.createURLParserCtxt(docpath, opts) parser.setErrorHandler(my_ctx_error_cb, None) if catalog is not None: parser.addLocalCatalog(catalog) if test_callback is not None: test_callback() parser.parseDocument() doc = parser.doc() actual_status = "loaded" e = doc.getRootElement() if e.name == root_name and e.content == root_content: actual_status = "verified" doc.freeDoc() except libxml2.parserError: actual_status = "not loaded" if actual_status != exp_status: print("Test '%s' failed: expect status '%s', actual '%s'" % (desc, exp_status, actual_status)) sys.exit(1) elif actual_err != exp_err: print("Test '%s' failed" % desc) print("Expect errors:") for s,m in exp_err: print(" [%2d] '%s'" % (s,m)) print("Actual errors:") for s,m in actual_err: print(" [%2d] '%s'" % (s,m)) sys.exit(1)