次の JVM オプションを使用して、jenkins ビルド サーバーとは別のサーバーにあるマルチモジュール アプリケーション インスタンスを起動できました。"-javaagent:${MAIN_DIR}/lib/jacocoagent.jar==destfile=/jacoco.exec,output=tcpserver,address=*"
私の Jenkins ビルドでは、次のような Pre Steps があります: ターゲット jacocoReport を呼び出す Ant タスク。この目的で使用している build.xml には次のコードがあります。
<taskdef uri="antlib:org.jacoco.ant" resource="org/jacoco/ant/antlib.xml">
<classpath path="/opt/hudson/tools/jacocoant.jar"/>
</taskdef>
<target name="jacocoReport">
<jacoco:dump address="${jacoco.host}" port="${jacoco.port}" dump="true" reset="true" destfile="${jacocoReportFile}" append="false"/>
</target>
<target name="jacocoReset">
<jacoco:dump address="${jacoco.host}" port="${jacoco.port}" reset="true" destfile="${jacocoReportFile}" append="false"/>
<delete file="${jacocoReportFile}"/>
</target>
そして最後に、sonar:sonar を呼び出す Maven ビルドステップがあります。
これは、私の統合レポートに関連する POM のセクションです。
<sonar.java.coveragePlugin>jacoco</sonar.java.coveragePlugin>
<sonar.dynamicAnalysis>reuseReports</sonar.dynamicAnalysis>
<sonar.jacoco.itReportPath>${WORKSPACE}/it-jacoco.exec</sonar.jacoco.itReportPath>
<sonar.language>java</sonar.language>
<sonar.branch>9.9.5</sonar.branch>
ここに私のプラグイン構成があります:
<plugin>
<groupId>org.jacoco</groupId>
<artifactId>jacoco-maven-plugin</artifactId>
<configuration>
<append>true</append>
</configuration>
<executions>
<execution>
<id>pre-test</id>
<goals>
<goal>prepare-agent</goal>
</goals>
</execution>
<execution>
<id>post-test</id>
<phase>test</phase>
<goals>
<goal>report</goal>
<goal>report-integration</goal>
</goals>
</execution>
</executions>
</plugin>
ビルドが終了しても、統合テストの Sonar エントリは 0% のままです。しかし、同じ it-jacoco.exec レポートを取得し、Eclipse の Jacoco インポート カバレッジ セッションを使用してインポートすると、26% のカバレッジが得られます。
最後に、Jenkins のビルド ログを調べると、次のように表示されます。
Sensor JaCoCoItSensor...
Analysing /var/lib/jenkins/workspace/XXXXXX/it-jacoco.exec
No information about coverage per test.
Sensor JaCoCoItSensor done: 34 ms
現在、自動化された統合テストはありません。外部テスト マシンから統合レポートをインポートしたいだけです。