我怎么能抓住这个AssertionFailedError异常,并打印到控制台,上面写着一个消息:如何捕获AssertPathsEqual并将控制台打印错误?
“预期的文本值 '55555' 但 '55556' 在/ xpathResult [1] /结果[2] /场[1]/field [1]/field [6]/text()[1]为[testFileName]和[testName]“
我不完全确定如何从断言中捕获值而不必”hack “并手动解析diff输出字符串。我宁愿有一个优雅的方法,而不是“黑客”方法。
junit.framework.AssertionFailedError: org.custommonkey.xmlunit.Diff
[different] Expected text value '55555' but was '55556' - comparing <field ...>55555</field> at /xpathResult[1]/result[2]/field[1]/field[1]/field[6]/text()[1] to <field ...>55556</field> at /xpathResult[1]/result[2]/field[1]/field[1]/field[6]/text()[1]
at junit.framework.Assert.fail(Assert.java:47)
at org.custommonkey.xmlunit.XMLAssert.assertXMLEqual(XMLAssert.java:125)
at org.custommonkey.xmlunit.XMLAssert.assertXMLEqual(XMLAssert.java:113)
at org.custommonkey.xmlunit.XMLAssert.assertXpathEquality(XMLAssert.java:582)
at org.custommonkey.xmlunit.XMLAssert.assertXpathsEqual(XMLAssert.java:453)
at org.custommonkey.xmlunit.XMLAssert.assertXpathsEqual(XMLAssert.java:435)
at org.custommonkey.xmlunit.XMLTestCase.assertXpathsEqual(XMLTestCase.java:454)
at tst.PatrolTests.compareXMLEqualityToLastTest(PatrolTests.java:353)
at tst.PatrolTests.doPlate(PatrolTests.java:141)
at tst.PatrolTests.testPlate(PatrolTests.java:117)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at junit.framework.TestCase.runTest(TestCase.java:168)
at junit.framework.TestCase.runBare(TestCase.java:134)
at junit.framework.TestResult$1.protect(TestResult.java:110)
at junit.framework.TestResult.runProtected(TestResult.java:128)
at junit.framework.TestResult.run(TestResult.java:113)
at junit.framework.TestCase.run(TestCase.java:124)
at junit.framework.TestSuite.runTest(TestSuite.java:232)
at junit.framework.TestSuite.run(TestSuite.java:227)
at org.junit.internal.runners.JUnit38ClassRunner.run(JUnit38ClassRunner.java:79)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:46)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
我将不得不编写我自己的DiffDescriber类来解析Diff文本输出吗?
感谢您参考示例。我需要的是一个获取Diff属性的方法。当存在差异时,我想知道文件中差异的检测位置以及差异。通过这些例子,我所能做的就是解析丑陋的diff输出字符串以获得这些属性值。没有其他办法吗? – djangofan 2009-12-07 19:08:41
据我所知,你想要的是一种方法来获取diff的上下文来检测XML文件的不同位置。我在那个方向上尝试了一下,但是找不到方法。一种方法是通过使用DetailedDiff类中的方法“getAllDifferences”来获取不同的XML节点,然后对它们进行比较。 DetailedDiff nd = new DetailedDiff(d); (Object o:nd.getAllDifferences()){ Difference f =(Difference)o; 节点c = f.getControlNodeDetail()。getNode(); 节点t = f.getTestNodeDetail()。getNode(); .. – sateesh 2009-12-08 08:17:48