java - 如何捕获 AssertPathsEqual 并将错误打印到控制台?

标签 java unit-testing junit xmlunit

我怎样才能捕获这个 AssertionFailedError 并向控制台打印一条消息:

“[ 的/xpathResult[1]/result[2]/field[1]/field[1]/field[6]/text()[1] 处的预期文本值为“55555”,但结果为“55556” testFileName] 和 [testName]"

我不太确定如何从断言中捕获值,而不必“破解”并手动解析差异输出字符串。我宁愿有一个优雅的方法而不是“hack”方法。

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 文本输出?

最佳答案

您可以捕获 AssertionError 以将详细的错误消息发送到控制台。

你可以尝试这样的事情:

       try{
           // say you are comparing FileReader objects that
           // refer to XML documents
           assertXMLEqual(filereader1, filereader2); 
        } catch (final SAXException e) {
           // show faiulre message
        } catch (final IOException e) {
           // show failure message
        } catch (final AssertionError e) {
            System.err.println(e.toString());
        }

但我认为,与其捕获 AssertionError,不如获取更多详细信息
通过使用“Diff”类(来自 org.custommonkey.xmlunit)断言失败。
您可以使用此类来检查所比较的 XML 文档是否相似
(或相同)并获取有关差异的更多详细信息。您还可以使用
DetailedDiff 类来获取详细的差异。

检查示例4和示例5 XMLUnit文档。这些示例展示了 Diff 和DetailedDiff 的用法。

关于java - 如何捕获 AssertPathsEqual 并将错误打印到控制台?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1861419/

相关文章:

java - 断言 JMockit 期望结果与构造的实例相同

java - Java 8 中的深度优先目录流

java - 为不太可能的场景创建单元测试,这值得吗?

java - JUnit 断言失败

c# - 重写操作系统查询方法以使其可测试

java - 如何比较同一数组中的两个元素?

java - 当类包含嵌套静态类时使用 "this"

java - 获取Java中定义的String的实际长度

java - 如何重置构造函数的 getter 和 setter

java - 是否可以使测试方法参数化,而不是整个类?