如何在 gradle 日志中获取更多 junit-failed-details 而无需在调试模式下运行 gradle

问题描述 投票:0回答:3

问题:

有没有办法将失败的 junit4 测试的详细信息添加到 gradle 输出而不使所有 gradle 变得更详细?

背景:

我有一个 java-se junit4 回归测试,用于处理 ical 内容,在我的 win-7-64 本地计算机上运行良好,但是 使用 gradle 在 travis-ci buildserver 上失败。

当我跑步时

./gradlew assemble libIcsJ2se:test

travis-ci 日志的 gradle 输出包含此内容

* What went wrong:

Execution failed for task ':libIcsJ2se:test'.

> There were failing tests. See the report at: 
> file:///home/travis/build/k3b/CalendarIcsAdapter/libIcsJ2se/build/reports/tests/index.html

但是我无法访问此文件,因为它位于构建服务器上,所以我无法找出哪个测试失败以及原因。

当我在调试模式下运行 gradle 时

./gradlew -d assemble libIcsJ2se:test

我在日志中看到了我想要的:

07:06:56.713 [DEBUG] [TestEventLogger] de.k3b.calendar.DtoIcRegressonsTests > shouldBeSameFixThisEvent STARTED
07:06:56.713 [DEBUG] [TestEventLogger] 
07:06:56.713 [DEBUG] [TestEventLogger] de.k3b.calendar.DtoIcRegressonsTests > shouldBeSameFixThisEvent FAILED
07:06:56.714 [DEBUG] [TestEventLogger]     org.junit.ComparisonFailure: expected:

<...
TART:20000502T123456
[DTEND:20000502T171234]
SUMMARY:test title
...> but was:<...
TART:20000502T123456[Z
DTEND:20000502T171234Z]
SUMMARY:test title
...>
07:06:56.717 [DEBUG] [TestEventLogger]         at de.k3b.calendar.DtoIcRegressonsTests.shouldBeSameFixThisEvent(DtoIcRegressonsTests.java:482)

然而,gradle 调试输出包含更多与 junit-tests 无关的细节。

有没有办法只将失败的 junit4 测试的详细信息添加到 gradle 输出而不使所有 gradle 变得更详细?

logging gradle junit reporting travis-ci
3个回答
2
投票

showStandardStreams
设置为
true
。 我也遇到了类似的问题,gradle 吞掉了很多测试细节,例如 WebClient 和 Selenium

JUnit5 的工作配置示例如下:

test {
    useJUnitPlatform()
    testLogging {
        showStandardStreams = true
    }
}

1
投票

请阅读 TestLoggingContainer

文档,了解如何配置运行测试时记录的内容。


0
投票

我认为

showStandardStreams
提供了太多细节。覆盖
exceptionFormat
就是您所需要的。

import org.gradle.api.tasks.testing.logging.TestExceptionFormat
// ...
tasks.test {
    //...
    testLogging {
        exceptionFormat = TestExceptionFormat.FULL
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.