这困扰了我好几天.我只需要通过比较找出第二个xml中缺少的节点.我试过xmlunit,但它并没有真正帮助我找到丢失的节点,因为它逐行比较.两个样本xml如下:
XML1:
XML1:
<test testcase="101"> <value="1"> <value="2"> <value="3"> </test>
XML2:
<test testcase="101"> <value="3"> <value="2"> </test>
请注意,value = 3实际上在第二个副本中它只是到达第一个节点,但我仍然认为它没有丢失.我如何找到丢失的节点值=“1”?
解决方法
我必须尝试它的工作
package WebInitalizar; import java.util.List; import org.custommonkey.xmlunit.DetailedDiff; import org.custommonkey.xmlunit.XMLUnit; import org.junit.Assert; public class TestXml { public static void main(String[] args) throws Exception { String result = "<test testcase=\"101\"><value1>10</value1></test>"; // will be ok assertXMLEquals("<test testcase=\"1010\"><value1>10</value1><value2>10</value2></test>",result); } public static void assertXMLEquals(String expectedXML,String actualXML) throws Exception { XMLUnit.setIgnoreWhitespace(true); XMLUnit.setIgnoreAttributeOrder(true); DetailedDiff diff = new DetailedDiff(XMLUnit.compareXML(expectedXML,actualXML)); List<?> allDifferences = diff.getAllDifferences(); System.out.println(allDifferences); Assert.assertEquals("Differences found: "+ diff.toString(),allDifferences.size()); } }