java - Gradle 测试 - 为失败的测试打印 stdout/stderror

标签 java testing gradle gradlew

我正在向现有项目引入 Github 操作管道以运行 ./gradlew test。毫不奇怪,由于时区不匹配等各种原因,我遇到过测试在本地通过但在构建机器上未通过的情况。

默认情况下,gradle 不会为这些测试打印 stdout。我知道如果通过 --info 它将这样做,但是测试套件的大小约为 1500 个测试,这使得管道输出非常冗长(如果我打开它,它实际上会使我的浏览器滞后对于完整套件并尝试在 Github 中查看结果输出)。

为了解决最初出现的问题,我还采用了针对失败的套件(例如 ./gradlew test --tests "foo.bar.AppTest"--info)。不过,这有点麻烦。有没有办法告诉 gradle 只为失败的测试打印 stdout 内容?这将使我在前进中处于更好的位置!

最佳答案

This page包含您要查找的内容。

它归结为像这样配置测试任务:

test {
  testLogging {
    // set options for log level LIFECYCLE
    events "failed"
  }
}

如果您阅读该页面,还有更多选项可以精细地控制日志记录。


因为你可能只需要它来执行 github 操作,你可以使用 CI environmental variable仅在 CI 环境中启用您的配置:

test {
  doFirst {
    if (System.getenv('CI')) {
      testLogging {
        // set options for log level LIFECYCLE
        events "failed"
      }
    }
  }
}

Other CI providers还要设置这个环境变量

关于java - Gradle 测试 - 为失败的测试打印 stdout/stderror,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61580713/

相关文章:

java - 我是否需要用 try-catch 包含所有 saveOrUpdate 方法?

java - 在 Intellij Idea 上为 Gradle Runner 和 JUnit 测试设置环境变量

eclipse - 需要使用 gradle 构建文件从 eclipse 中排除依赖项

java - 将句柄传递给 java 中的子类时,我应该使用声明还是 this() ?

java - 我试图用 java 中的 "0"替换Evens,我做错了什么?

java - List 中基于另一个元素的最大值

javascript - Protractor 无法在 ng-click 元素上使用 css 定位元素

javascript - Mocha 不会在 after() 函数中调用 rmdir

ruby-on-rails - 测试 Sidekiq 的重试队列

java - 无法在 Gradle 多项目构建中读取另一个项目中的资源文件