Aru*_*gal 5 testing integration code-coverage jacoco sonarqube
在运行基于Gradle的构建和集成测试后,我在"build/jacoco"文件夹中成功生成了Jacoco的2个.exec文件.
Gradle命令:"gradle clean build integrationTest"
完成后,它会在build/jacoco文件夹下生成以下.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项目的仪表板.Project的声纳仪表板有两个配置为单元/集成测试的小部件,我还包括用于显示整体覆盖范围的IT测试.总体覆盖率显示为34.5%(单位测试%值).Sonar确实看到了test.exec,integrationTest.exec,并且在此操作过程中也自动生成了total-xxx.exec文件.
注意:我不在哪里 - 在Gradle构建脚本中的单独putty/linux控制台-OR上启动tomcat,为Jacoco提供任何值或设置JAVA Agent.我已经获得了integrationTest.exec文件和test.exec文件,所以不确定在IT测试完成运行后是否需要停止JVM.我不认为我需要那些,因为我有.exec文件的有效文件大小.
我的?: - 为什么声纳没有在仪表板上获得IT覆盖,即使我正确设置/传递以下变量:
sonar.jacoco.itReportPath=build/jacoco/integrationTest.exec
Run Code Online (Sandbox Code Playgroud)
-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
Run Code Online (Sandbox Code Playgroud)
缩小原因:我认为这是由于集成测试的 .exec 文件造成的。为了证明这一点:我将 UT exex 文件传递给 Sonar 变量中的两个 reportsPaths,即以下内容,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
Run Code Online (Sandbox Code Playgroud)
好的,找到问题了。我正在 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
Run Code Online (Sandbox Code Playgroud)
然后,当 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
Run Code Online (Sandbox Code Playgroud)