当通过 Gradle 启动 JUnit 测试时,是否已经有可能生成 HTML 报告?任何提示或评论表示赞赏。
3 回答
更新
Gradle 4.6 提供了对JUnit 平台的内置支持,允许您使用标准 Gradletest
任务运行 JUnit Jupiter 测试,该任务生成开箱即用的 HTML 报告。
4.6 之前的 Gradle 版本的答案
JUnit Platform Gradle 插件生成 JUnit 4 风格的 XML 测试报告。
这些 XML 文件build/test-results/junit-platform
默认输出到。
因此,如果您的构建服务器知道如何解析 JUnit 4 样式的 XML 报告,您只需将其指向该目录中的 XML 文件,然后让构建服务器为您生成 HTML 报告。
但是,如果您询问Gradle是否可以为您通过任务运行的测试生成 HTML 报告junitPlatformTest
,那么答案是“不,很遗憾不能”。原因是标准的 Gradletest
任务仅根据自己专有的“二进制”报告格式生成 HTML 报告。由于该junitPlatformTest
任务不会生成 Gradle 二进制格式的报告,因此 Gradle 本身无法为 JUnit Platform 测试生成 HTML 报告。
话虽如此,但实际上有一个变通方法:您可以在 Gradle 构建中使用 Ant。Ant 的任务是聚合基于 JUnit 4 的 XML 报告并从这些聚合报告生成 HTML 报告。输出不是很现代,但至少是人类可读的。缺点是默认的 XSLT 样式表不显示通过 JUnit 平台运行的测试的测试类名称。
在任何情况下,您都可以在 Gradle 中配置 Ant 的JUnitReport任务,如下所示。
junitPlatform {
// configure as normal
}
configurations {
junitXmlToHtml
}
task generateHtmlTestReports << {
def reportsDir = new File(buildDir, 'test-reports')
reportsDir.mkdirs()
ant.taskdef(
name: 'junitReport',
classname: 'org.apache.tools.ant.taskdefs.optional.junit.XMLResultAggregator',
classpath: configurations.junitXmlToHtml.asPath
)
ant.junitReport(todir: "$buildDir/test-results/junit-platform", tofile: "aggregated-test-results.xml") {
fileset(dir: "$buildDir/test-results/junit-platform")
report(format: 'frames', todir: reportsDir)
}
}
afterEvaluate {
def junitPlatformTestTask = tasks.getByName('junitPlatformTest')
generateHtmlTestReports.dependsOn(junitPlatformTestTask)
check.dependsOn(generateHtmlTestReports)
}
dependencies {
// configure as normal ...
junitXmlToHtml 'org.apache.ant:ant-junit:1.9.7'
}
然后,执行gradle check
将在build/test-reports/index.html
.
问候,
Sam(核心 JUnit 5 提交者)
将以下行添加到TEST-junit-jupiter.xml
在我的target/test-result
文件夹中创建的 java 命令。此 xml 文件包含有关运行的测试用例数量、通过/失败的测试数量等的所有信息
--reports-dir target/test-result
是的,您可以使用 Jacoco 插件。
这是一个例子:
apply plugin: 'war' or apply plugin: 'java'
apply plugin: "jacoco"
test {
reports.junitXml.destination="build/test-results"
jacoco {
destinationFile = file("build/jacoco/jacoco.exec")
append=true
}
}
jacocoTestReport {
reports {
xml.enabled false
csv.enabled false
html.destination "${buildDir}/jacocoHtml"
}
}
问候。