aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRob Austein <sra@hactrn.net>2007-08-02 17:44:27 +0000
committerRob Austein <sra@hactrn.net>2007-08-02 17:44:27 +0000
commit12ef79c8114e1b66c6d1e52a19e97bdcb4d1e36a (patch)
treef4ad150c384ea2c5e381f3e29253aa7c6a296688
parent2a46fbe7fcdd0a4b549e00507edc4f673b320f51 (diff)
Checkpoint
svn path=/scripts/xml-parse-test.py; revision=821
-rwxr-xr-xscripts/xml-parse-test.py35
1 files changed, 21 insertions, 14 deletions
diff --git a/scripts/xml-parse-test.py b/scripts/xml-parse-test.py
index 0993a02f..8a76ba91 100755
--- a/scripts/xml-parse-test.py
+++ b/scripts/xml-parse-test.py
@@ -3,29 +3,33 @@
import glob, rpki.up_down, rpki.left_right, xml.sax, lxml.etree, lxml.sax, pprint, POW, POW.pkix
def test(fileglob, schema, sax_handler, encoding, tester=None):
+
rng = lxml.etree.RelaxNG(lxml.etree.parse(schema))
+ def validate(x):
+ try:
+ rng.assertValid(x)
+ except lxml.etree.DocumentInvalid:
+ print rng.error_log.last_error
+ raise
+
files = glob.glob(fileglob)
files.sort()
for f in files:
print "\n<!--", f, "-->"
handler = sax_handler()
- et = lxml.etree.parse(f)
- rng.assertValid(et)
- lxml.sax.saxify(et, handler)
+ elt_in = lxml.etree.parse(f).getroot()
+ validate(elt_in)
+ lxml.sax.saxify(elt_in, handler)
+ elt_out = handler.result.toXML()
+ validate(elt_out)
if (tester):
- tester(et, handler.result)
- et = handler.result.toXML()
- print lxml.etree.tostring(et, pretty_print=True, encoding=encoding, xml_declaration=True)
- try:
- rng.assertValid(et)
- except lxml.etree.DocumentInvalid:
- print rng.error_log.last_error
- raise
+ tester(elt_in, elt_out, handler.result)
+ print lxml.etree.tostring(elt_out, pretty_print=True, encoding=encoding, xml_declaration=True)
def pprint_cert(cert):
print POW.derRead(POW.X509_CERTIFICATE, cert.toString()).pprint()
-def ud_tester(et, msg):
+def ud_tester(elt_in, elt_out, msg):
assert isinstance(msg, rpki.up_down.message_pdu)
if isinstance(msg.payload, rpki.up_down.list_response_pdu):
for c in msg.payload.classes:
@@ -34,9 +38,12 @@ def ud_tester(et, msg):
pprint_cert(c.certs[i].cert)
print "[Issuer]"
pprint_cert(c.issuer)
- print "Type:", et.getroot().get("type")
-def lr_tester(et, msg):
+ nsmap = { "x" : "http://www.apnic.net/specs/rescerts/up-down/" }
+ for c in elt_in.xpath("//x:issuer | //x:certificate", nsmap):
+ print c.tag, c.text
+
+def lr_tester(elt_in, elt_out, msg):
assert isinstance(msg, rpki.left_right.msg)
test(fileglob="up-down-protocol-samples/*.xml",