Skip to content

razvn/jacoco-to-cobertura-gradle-plugin

Repository files navigation

JacocoToCobertura Gradle Plugin

Current release Gradle Plugin Portal

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.

How to use the plugin

Add the plugin to your project

plugins {
    jacoco
    id("net.razvan.jacoco-to-cobertura") version "<see latest version above>"
}

Configure the task

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 and sourceDirectories 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 the onlyIf 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

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)
}

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •  

Languages