lib/schematron.rb in schematron-0.0.3 vs lib/schematron.rb in schematron-0.1.0
- old
+ new
@@ -41,26 +41,34 @@
def validate(instance_doc)
# Validate the xml
results_doc = @validator_xsl.apply instance_doc
- # compile the errors
+ # compile the errors and log any messages
+ rule_hits(results_doc, instance_doc, 'assert', '//svrl:failed-assert') +
+ rule_hits(results_doc, instance_doc, 'report', '//svrl:successful-report')
+ end
+
+ # Look for reported or failed rules of a particular type in the instance doc
+ def rule_hits(results_doc, instance_doc, rule_type, xpath)
+
results = []
- results_doc.root.find('//svrl:failed-assert', NS_PREFIXES).each do |assert|
- context = instance_doc.root.find_first assert['location']
-
- assert.find('svrl:text/text()', NS_PREFIXES).each do |message|
+ results_doc.root.find(xpath, NS_PREFIXES).each do |hit|
+ context = instance_doc.root.find_first hit['location']
+
+ hit.find('svrl:text/text()', NS_PREFIXES).each do |message|
results << {
+ :rule_type => rule_type,
:type => context.node_type_name,
:name => context.name,
:line => context.line_num,
:message => message.content.strip }
end
-
end
results
+
end
end
end