考虑:
<ParentTag>
<Firstchild ID="id1" Title="title1">
<secondchild ID="" Title="">
<TagOfInterest ID="value1" Title=""/>
<TagOfInterest ID="value2" Title=""/>
<TagOfInterest ID="value3" Title=""/>
</secondchild>
</Firstchild>
</ParentTag>
和:
<secondxml>
<something ID="id1" Title="title1">
<anotherthing ID="" Title="">
<TagOfInterest ID="value1" Title=""/>
<TagOfInterest ID="dinosaur" Title=""/>
<TagOfInterest ID="nomore" Title=""/>
</anotherthing>
</something>
</secondxml>
我正在使用 XML 单元,
要求 1:比较引擎应仅按标签名称“tagofInterest”进行比较。
要求 2:如果存在差异,则在该标签内按属性进行比较。
仅打印标签名称的实现,但对感兴趣的标签或内部属性的差异没有太多控制。在使用 XML Unit 的方式上有什么更好的建议吗?
fr1 = new FileReader(expectedXML);
fr2 = new FileReader(actualXML);
Diff diff = new Diff(fr1, fr2);
DetailedDiff detDiff = new DetailedDiff(diff);
detDiff.overrideMatchTracker(new MatchTrackerImpl());
detDiff.overrideElementQualifier(new ElementNameQualifier());
detDiff.getAllDifferences();
class MatchTrackerImpl implements MatchTracker {
public void matchFound(Difference difference) {
if (difference != null) {
NodeDetail controlNode = difference.getControlNodeDetail();
NodeDetail testNode = difference.getTestNodeDetail();
System.out.println(printNode(controlNode.getNode()));
System.out.println(printNode(testNode.getNode()));
}
}
private static String printNode(Node node) {
if (node != null && node.getNodeType() == Node.ELEMENT_NODE) {
StringWriter sw = new StringWriter();
try {
Transformer t = TransformerFactory.newInstance().newTransformer();
t.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes");
t.transform(new DOMSource(node), new StreamResult(sw));
} catch (TransformerException te) {
System.out.println("nodeToString Transformer Exception");
}
return sw.toString();
}
return null;
}
}