递归 – 使用XMLUnit查找缺少的元素

我有以下test
XML

<root>
   <a>test</a>
   <b>bee</b>
   <d/>
</root>

虽然templateXML看起来像这样

<root>
  <a/>
  <b/>
  <c/>
  <d>
    <e/>
  </d>
</root>

我希望XMLUnit返回缺少的元素,在这种情况下,’c’和’e’缺失

/ root [1] / c [1]丢失了
缺少/ root [1] / d [1] / e [1]

我的代码看起来像这样

public static ArrayList<Difference> testCompareToSkeletonXML(String xml, String template) throws Exception {

    XMLUnit.setCompareUnmatched(false);
    XMLUnit.setIgnoreAttributeOrder(true);
    XMLUnit.setIgnoreComments(true);
    XMLUnit.setIgnoreWhitespace(true);
    XMLUnit.setIgnoreDiffBetweenTextAndCDATA(true);     

    DifferenceListener myDifferenceListener = new IgnoreTextAndAttributeValuesDifferenceListener();
    DetailedDiff myDiff = new DetailedDiff(new Diff(template, xml));
   // myDiff.overrideDifferenceListener(myDifferenceListener);
    myDiff.overrideElementQualifier(new RecursiveElementNameAndTextQualifier());
    ArrayList<Difference> returnList = new ArrayList<Difference>();
    List<Object> allDifferences = myDiff.getAllDifferences();
    for(Object obj: allDifferences){
        Difference dif = (Difference) obj;          
        if(dif.getTestNodeDetail().getNode()== null){
            //returnList.add(dif);          
            System.out.println(dif.getControlNodeDetail().getXpathLocation());
        }   
    }
    return returnList;
}

生成的输出看起来像这样

/根[1] / A [1]
/根[1] / B [1]
/根[1] / C [1]
/根[1] / d [1]

谢谢您的帮助
–SD

最佳答案 如果元素名称和嵌套文本相同,则告诉XMLUnit仅匹配元素.对于a或b元素(嵌套文本不同),情况并非如此,这就是您在列表中看到它们的原因.

根据RecursiveElementNameAndTextQualifier的规则,您会看到d而不是嵌套e,因为顶级ds是不同的.如果删除行设置RecursiveElementNameAndTextQualifier,则列表缩小为

/root[1]/c[1]
/root[1]/d[1]/e[1]

这是你所期待的.

点赞