This plugin aims to convert the JaCoCo XML report to a Cobertura report for GitLab to use the data for showing the lines covered by tests in the Merge Request.
This project adapts the python version cover2cover.
plugins {
jacoco
id("net.razvan.jacoco-to-cobertura") version "<see latest version above>"
}
Property | Description | Default Value |
---|---|---|
inputFile |
JaCoCo XML file to read | XML report of single JacocoReport task found in the project; must be specified manually if zero or more than one JacocoReport task exists |
outputFile |
Cobertura XML file to generate | cobertura-${inputFile.nameWithoutExtension}.xml in the directory of inputFile |
sourceDirectories |
Directories containing source files the JaCoCo report used | Source directories of single JacocoReport task found in the project; must be specified manually if zero or more than one JacocoReport tasks exist |
splitByPackage |
Whether to generate one Cobertura report per package | false |
rootPackageToRemove |
Root package to remove from the begging of filenames | `` |
Note Due to the way the default values are set, projects that apply either the JaCoCo plugin or the JaCoCo Report Aggregation plugin, work without requiring custom configuration of the
inputFile
,outputFile
andsourceDirectories
properties.
Should the default values not work for you, you can configure the task manually. For example:
tasks.named<JacocoToCoberturaTask>(JacocoToCoberturaPlugin.TASK_NAME) {
inputFile.set(layout.buildDirectory.file("reports/xml/coverage.xml"))
outputFile.set(layout.buildDirectory.file("reports/xml/cobertura.xml"))
sourceDirectories.from(layout.projectDirectory.dir("src/main/java"))
splitByPackage.set(true)
rootPackageToRemove.set("com.example")
}
Note If you don't want the
JacocoToCobertura
task to fail if the inputFile does not exist use theonlyIf
on the configuration to make sure the task runs only if the file exists:
tasks.named<JacocoToCoberturaTask>(JacocoToCoberturaPlugin.TASK_NAME) {
val jacocoReport = project.layout.buildDirectory.file("reports/kover/report_that_does_not_exist.xml")
onlyIf {
jacocoReport.get().asFile.exists()
}
inputFile.set(jacocoReport)
outputFile.set(project.layout.buildDirectory.file("reports/kover/cobertura.xml"))
}
Run the task jacocoToCobertura
:
./gradlew jacocoToCobertura
To ensure the Cobertura report is generated whenever the JaCoCo task executes, the plugin task should be run after the JacocoReport
task, e.g., jacocoTestReport
. As the configuration table above shows, the default values should work in most cases. However, if your project works differently, you must manually ensure the report task runs before this plugin's conversion task. For example:
tasks.jacocoTestReport {
finalizedBy(tasks.jacocoToCobertura)
}
or
tasks.koverXmlReport {
finalizedBy(tasks.jacocoToCobertura)
}