6

在运行基于 Gradle 的构建和集成测试后,我在“build/jacoco”文件夹中成功地生成了 2 个 .exec 文件。

Gradle 命令:“gradle clean build integrationTest”

完成后,它会在 build/jacoco 文件夹下生成以下 .exec 文件。

  1. 测试执行
  2. 集成测试.exec

以下是我的 sonar-project.properties 文件。当我从 Linux 提示符运行“sonar-runner”时,它会完成,但在该项目的 SonarQube 仪表板上,我看到单元测试显示大约 34.5%,但集成测试显示为 0.0%。两个 .exec 文件都有有效的大小。我还在 .exec 文件上执行了“cat”,并将输出通过管道传输到 Linux 中的“strings”命令,并看到 integrationTest.exec 确实命中了测试函数——我只有 1 个 .java 文件。

当我运行“gradle clean build integrationTest sonarRunner -Dxxx.xxx=yyy -Dyyy.xx=zzz”时,即通过使用 -D 选项传递 sonar-project.properties 文件中提到的所有声纳变量,它可以工作但结果相同SonarQube 项目的仪表板。项目的声纳仪表板具有为单元/集成测试配置的两个小部件,我包括 IT 测试以显示整体覆盖率。总体覆盖率显示为 34.5%(这是单元测试百分比值)。Sonar 确实会看到 test.exec、integrationTest.exec 并且在此操作期间也会自动生成整体 xxx.exec 文件。

注意:我不在 - 在单独的 putty / linux 控制台上启动 tomcat 时 - 或者在 Gradle 构建脚本中,为 Jacoco 提供任何值或设置 JAVA 代理。我已经获得了 integrationTest.exec 文件和 test.exec 文件,因此不确定 IT 测试完成运行后是否需要停止 JVM。我认为我不需要这些,因为我有 .exec 文件的有效文件大小。

我的?: -为什么即使我正确设置/传递了以下变量,声纳也没有在仪表板上获得 IT 覆盖:

sonar.jacoco.itReportPath=build/jacoco/integrationTest.exec

-bash-3.2$ cat sonar-project.properties

# Root project information
sonar.projectKey=com:company:product:ProjectA
sonar.projectName=ProjectA
sonar.projectVersion=1.0
# optional description
sonar.projectDescription=ProjectA Service

#Tells SonarQube that the code coverage tool by unit tests is JaCoCo
sonar.java.coveragePlugin=jacoco

#Tells SonarQube to reuse existing reports for unit tests execution and coverage reports
sonar.dynamicAnalysis=reuseReports

# Some properties that will be inherited by the modules
sonar.sources=src/java,test/java,src/java-test

# Sonar Unit Test Report path
sonar.jacoco.reportPath=build/jacoco/test.exec

# Sonar Integration Test Report Path
sonar.jacoco.itReportPath=build/jacoco/integrationTest.exec

sonar.junit.reportsPath=build/UT/results

# Sonar Binaries
sonar.binaries=build/classes/main
4

1 回答 1

2

缩小原因:我认为这是由于用于集成测试的 .exec 文件。为了证明这一点:我将 UT exex 文件传递​​给 Sonar 变量中的两个报告路径,即以下和 SonarQube 选择了 UT/IT 测试覆盖率。这证明如果用于 IT 测试的 .exec 文件很好(我认为它是好的,但我需要仔细检查),那么 Sonar 将选择 .exec 文件并显示有效的覆盖率 % 而不是 0.0%。注意:以下只是为了证明 Sonar 是否选择了这些值。itReportPath 变量应该使用 Jacoco 的集成测试生成的 .exe 文件。

sonar.jacoco.reportPath=build/jacoco/test.exec

# Sonar Integration Test Report Path
#sonar.jacoco.itReportPath=build/jacoco/testintegrationTest.exec
sonar.jacoco.itReportPath=build/jacoco/test.exec

好的 发现问题。我在 Gradle 中运行 integrationTest 任务,并且没有将 jacocoagent.jar(根据 Jacoco 文档)附加到目标 JVM(Tomcat 的实例)范围。一旦我这样做了,我从 Gradle 中的 integrationTest 任务中删除了 jacoco { ... } 部分(build.gradle 或 GRADLE_HOME/init.d/some.common.gradle 文件,因为这会将 jacoco 代理附加到运行 Gradle 的 Java JVM )。现在,一旦将 jacocoagent.jar 附加到 Tomcat 的 JVM(根据我在 Tomcat 的 startup.sh 脚本中添加的下面的行并将变量添加到启动 Tomcat 的命令中),然后我运行 Gradle (integrationTest) 任务来运行 IT 测试.

PROJ_EXTRA_JVM_OPTS=-javaagent:tomcat/jacocoagent.jar=destfile=build/jacoco/IT/jacocoIT.exec,append=false

然后,当 Gradle 正在进行时,测试运行了,我得到了一个文件(在给定位置的 jacocoIT.exec),它有一些文件大小,但这还不是最后一个。我必须通过运行 Tomcat 的 stop.sh 脚本来停止 Tomcat 会话/JVM 实例。停止 Tomcat 后,我​​看到 jacocoIT.exec 文件大小显着增加,这是有效的最终 jacocoIT.exec 文件(我需要 sonarRunner Gradle 任务或 sonar-runner 可执行文件来选择并成功将 IT 代码覆盖率数据推送到项目的声纳仪表板)。完成后,我得到了 UT + IT 和组合代码覆盖率。

sonar.jacoco.reportPath=build/jacoco/UT/jacocoUT.exec
sonar.jacoco.itReportPath=build/jacoco/IT/jacocoIT.exec
于 2013-11-11T19:55:13.810 回答