问题:
有没有办法将失败的 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 变得更详细?
将
showStandardStreams
设置为 true
。
我也遇到了类似的问题,gradle 吞掉了很多测试细节,例如 WebClient 和 Selenium
JUnit5 的工作配置示例如下:
test {
useJUnitPlatform()
testLogging {
showStandardStreams = true
}
}
我认为
showStandardStreams
提供了太多细节。覆盖 exceptionFormat
就是您所需要的。
import org.gradle.api.tasks.testing.logging.TestExceptionFormat
// ...
tasks.test {
//...
testLogging {
exceptionFormat = TestExceptionFormat.FULL
}
}