Как отловить AssertPathsEqual и вывести ошибку на консоль? - PullRequest
0 голосов
/ 07 декабря 2009

Как я могу перехватить эту AssertionFailedError и вывести на консоль сообщение, которое говорит:

"Ожидаемое текстовое значение« 55555 », но было« 55556 »в / xpathResult [1] / результате [2] / поле [1] / поле [1] / поле [6] / text () [1] для [ testFileName] и [testName] "

Я не совсем уверен, как извлечь значения из утверждения без необходимости "взламывать" и вручную анализировать строку вывода 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?

1 Ответ

1 голос
/ 07 декабря 2009

Вы можете перехватить 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-документы
(или идентичные) и получить более подробную информацию о разнице. Вы также можете использовать
класс DetailDiff для получения подробных различий.

Проверьте Пример 4 и Пример 5 из XMLUnit документация. Эти примеры показывают использование Diff и DetailDiff.

...