SonarQube: JaCoCo-Pfad-Mapping durch per-Modul-Reports lösen
Problem: Der Aggregate-Report enthält Klassen aller Module. SonarQube analysiert jedes Modul isoliert und findet für Klassen anderer Module keine Quellen → "File not found" für alle Einträge. Das Coverage-Modul (kein Java-Code) lehnt beim Import alle Einträge ab. Lösung: - jacoco:report-Goal (verify-Phase) im Root-POM ergänzt → jedes Modul erzeugt target/site/jacoco/jacoco.xml nur für seine eigenen Klassen - sonar.coverage.jacoco.xmlReportPaths auf relativen Pfad target/site/jacoco/jacoco.xml umgestellt → SonarQube löst pro Modul auf, liest ausschließlich dessen eigene Klassen, keine Cross-Modul-Kollisionen mehr - sonar.skip=true in pdf-umbenenner-coverage und pdf-umbenenner-packaging gesetzt → Aggregator-/Packaging-Module ohne Java-Quellen werden von SonarQube nicht mehr analysiert Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -10,6 +10,11 @@
|
|||||||
<artifactId>pdf-umbenenner-coverage</artifactId>
|
<artifactId>pdf-umbenenner-coverage</artifactId>
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
<!-- Kein Java-Quellcode in diesem Aggregator-Modul; SonarQube-Analyse überspringen. -->
|
||||||
|
<sonar.skip>true</sonar.skip>
|
||||||
|
</properties>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>de.gecheckt</groupId>
|
<groupId>de.gecheckt</groupId>
|
||||||
|
|||||||
@@ -26,6 +26,8 @@
|
|||||||
Beim Release-Build: -Drevision=MAJOR.MINOR.BUILD_NUMBER
|
Beim Release-Build: -Drevision=MAJOR.MINOR.BUILD_NUMBER
|
||||||
-->
|
-->
|
||||||
<app.version>${revision}</app.version>
|
<app.version>${revision}</app.version>
|
||||||
|
<!-- Kein Java-Quellcode in diesem Packaging-Modul; SonarQube-Analyse überspringen. -->
|
||||||
|
<sonar.skip>true</sonar.skip>
|
||||||
</properties>
|
</properties>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
|
|||||||
@@ -31,12 +31,13 @@
|
|||||||
false (default) when running as part of the full multi-module build. -->
|
false (default) when running as part of the full multi-module build. -->
|
||||||
<pitest.aggregate.skip>false</pitest.aggregate.skip>
|
<pitest.aggregate.skip>false</pitest.aggregate.skip>
|
||||||
|
|
||||||
<!-- SonarQube: Pfad zum JaCoCo-Aggregate-Report, den das Coverage-Modul erzeugt.
|
<!-- SonarQube: relativer Pfad zum per-Modul-JaCoCo-XML-Report.
|
||||||
${project.basedir} wird von Maven pro Modul zu einem absoluten Pfad aufgelöst,
|
Wird von SonarQube für jedes Modul relativ zu dessen Basisverzeichnis aufgelöst.
|
||||||
bevor der Wert an das Sonar-Plugin übergeben wird. Da alle Kind-Module
|
Der jacoco:report-Goal (gebunden an verify) erzeugt diese Datei für jedes Modul
|
||||||
Geschwister von pdf-umbenenner-coverage sind, zeigt ../pdf-umbenenner-coverage/...
|
mit eigenen Java-Quellen. Für Aggregator-/Packaging-Module ohne Java-Quellen
|
||||||
für jedes Kind-Modul korrekt auf den Aggregate-Report. -->
|
(pdf-umbenenner-coverage, pdf-umbenenner-packaging) ist sonar.skip=true gesetzt,
|
||||||
<sonar.coverage.jacoco.xmlReportPaths>${project.basedir}/../pdf-umbenenner-coverage/target/site/jacoco-aggregate/jacoco.xml</sonar.coverage.jacoco.xmlReportPaths>
|
sodass SonarQube diese Module nicht analysiert. -->
|
||||||
|
<sonar.coverage.jacoco.xmlReportPaths>target/site/jacoco/jacoco.xml</sonar.coverage.jacoco.xmlReportPaths>
|
||||||
|
|
||||||
<!-- Library versions -->
|
<!-- Library versions -->
|
||||||
<javafx.version>21.0.2</javafx.version>
|
<javafx.version>21.0.2</javafx.version>
|
||||||
@@ -291,6 +292,13 @@
|
|||||||
<goal>prepare-agent</goal>
|
<goal>prepare-agent</goal>
|
||||||
</goals>
|
</goals>
|
||||||
</execution>
|
</execution>
|
||||||
|
<execution>
|
||||||
|
<id>jacoco-report</id>
|
||||||
|
<phase>verify</phase>
|
||||||
|
<goals>
|
||||||
|
<goal>report</goal>
|
||||||
|
</goals>
|
||||||
|
</execution>
|
||||||
</executions>
|
</executions>
|
||||||
</plugin>
|
</plugin>
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user