我正在设置通过 SonarQube 服务器分析项目。使用的工具集是:
- 科特林 1.3.61
- 摇篮6.0.1
- 雅可可0.7.9
- 声纳Qube 7.5
- SonarQube Gradle 插件 2.7
问题是我在 SonarQube 中有 0.0% 的覆盖率,但是,同时我有格式良好的 jacoco 测试覆盖率报告。
这是来自的片段build.gradle.tks
:
plugins {
...
id("org.sonarqube") version "2.7"
}
sonarqube {
properties {
property("sonar.host.url", "http://localhost:9000")
property("sonar.sources", "src/main/")
property("sonar.tests", "src/test/")
property("sonar.exclusions", "src/generated/")
property("sonar.jacoco.reportPath", "build/jacoco/test.exec")
property("sonar.junit.reportsPath","build/test-results/test")
property("sonar.core.codeCoveragePlugin","jacoco")
property("sonar.verbose", "true")
property("sonar.binaries" ,"build/classes/kotlin")
property("sonar.java.binaries" ,"build/classes/java, build/classes/kotlin")
property("sonar.dynamicAnalysis", "reuseReports")
}
}
jacoco {
toolVersion = "0.7.9"
reportsDir = file("${project.projectDir}/build/reports")
}
tasks.named("sonarqube") {
dependsOn(tasks.named("jacocoTestReport"))
}
我在执行期间有下一个日志条目./gradlew sonarqube --info
:
任务:jacocoTestReport
删除过时的输出文件:/home/xxx/project/build/reports/test/html
不包括[]
任务 ':jacocoTestReport' 禁用缓存,因为:
构建缓存已禁用
任务“:jacocoTestReport”不是最新的,因为:
任务“:jacocoTestReport”的一项或多项附加操作已更改。
[ant:jacocoReport] 加载执行数据文件 /home/xxx/project/build/jacoco/test.exec
[ant:jacocoReport] 编写包含 43 个类的包“项目”
代码覆盖率报告:file:///home/xxx/project/build/reports/jacoco/test/html/index.html
:jacocoTestReport (Thread[Execution worker for ':',5,main]) 已完成。花了 0.398 秒。
:sonarqube (Thread[Execution worker for ':',5,main]) 启动。
And:
Task :sonarqube
Load global settings
Load global settings (done) | time=48ms
Server id: BF41A1F2-AW2xHg7ddKb9ks8-VzQt
User cache: /home/xxx/.sonar/cache
Load/download plugins
Load plugins index
Load plugins index (done) | time=41ms
Load/download plugins (done) | time=52ms
Loaded core extensions:
Process project properties
Execute project builders
Execute project builders (done) | time=2ms
Load project repositories
Load project repositories (done) | time=41ms
Load quality profiles
Load quality profiles (done) | time=24ms
Load active rules
Load active rules (done) | time=2524ms
Load metrics repository
Load metrics repository (done) | time=50ms
Project key: project
Project base dir: /home/xxx/project
------------- Scan project
Base dir: /home/xxx/project
Working dir: /home/xxx/project/build/sonar
Source paths: src/main
Test paths: src/test
Source encoding: UTF-8, default locale: en_US
Index files
Excluded sources:
src/generated/
33 files indexed
15/15 source files have been analyzed
1/1 source files have been analyzed
CPD calculation finished
> Task :sonarqube
0 files ignored because of inclusion/exclusion patterns
Quality profile for kotlin: Sonar way
Quality profile for xml: Sonar way
Sensor JaCoCo XML Report Importer [jacoco]
Sensor JaCoCo XML Report Importer [jacoco] (done) | time=2ms
Sensor Kotlin Sensor [kotlin]
15 source files to be analyzed
Sensor Kotlin Sensor [kotlin] (done) | time=551ms
Sensor SonarJavaXmlFileSensor [java]
1 source files to be analyzed
Sensor SonarJavaXmlFileSensor [java] (done) | time=18ms
Sensor XML Sensor [xml]
Metric 'comment_lines_data' is deprecated. Provided value is ignored.
Sensor XML Sensor [xml] (done) | time=100ms
Sensor Zero Coverage Sensor
Sensor Zero Coverage Sensor (done) | time=14ms
9 files had no CPD blocks
Calculating CPD for 6 files
Analysis report generated in 82ms, dir size=138 KB
Analysis reports compressed in 28ms, zip size=50 KB
Analysis report generated in /home/xxx/project/build/sonar/scanner-report
Analysis report uploaded in 64ms
ANALYSIS SUCCESSFUL, you can browse http://localhost:9000/dashboard?id=project
Task total time: 4.773 s
:sonarqube (Thread[Execution worker for ':',5,main]) completed. Took 5.206 secs.
配置出了什么问题?是不是漏掉了什么?
UPDATE:
另外,我在执行 gradle 任务后找到了下一个条目DEBUG mode:
[DEBUG] [org.sonarqube.gradle.SonarQubeTask] Sensors : JaCoCo XML Report Importer -> Kotlin Sensor -> SonarJavaXmlFileSensor -> XML Sensor -> Zero Coverage Sensor
[INFO] [org.sonarqube.gradle.SonarQubeTask] Sensor JaCoCo XML Report Importer [jacoco]
[DEBUG] [org.sonarqube.gradle.SonarQubeTask] No reports found
[INFO] [org.sonarqube.gradle.SonarQubeTask] Sensor JaCoCo XML Report Importer [jacoco] (done) | time=2ms