在运行基于 Gradle 的构建和集成测试后,我在“build/jacoco”文件夹中成功地生成了 2 个 .exec 文件。
Gradle 命令:“gradle clean build integrationTest”
完成后,它会在 build/jacoco 文件夹下生成以下 .exec 文件。
- 测试执行
- 集成测试.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