kotlinx.kover.gradle.plugin.dsl.KoverVariantConfig.kt Maven / Gradle / Ivy
/*
* Copyright 2017-2023 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
*/
package kotlinx.kover.gradle.plugin.dsl
import kotlinx.kover.gradle.plugin.commons.KoverIllegalConfigException
import org.gradle.api.Action
import org.gradle.api.file.ConfigurableFileCollection
import org.gradle.api.provider.Property
import org.gradle.api.provider.SetProperty
/**
* Type for customizing report variants shared by the current project.
*
* A report variant is a set of information used to generate a reports, namely:
* project classes, a list of Gradle test tasks, classes that need to be excluded from instrumentation.
*
* ```
* currentProject {
* // create report variant with custom name,
* // in which it is acceptable to add information from other variants of the current project, as well as `kover` dependencies
* createVariant("custom") {
* // ...
* }
*
* // Configure the variant that is automatically created in the current project
* // For example, "jvm" for JVM target or "debug" for Android build variant
* providedVariant("jvm") {
* // ...
* }
*
* // Configure the variant for all the code that is available in the current project.
* // This variant always exists for any type of project.
* totalVariant {
* // ...
* }
* }
* ```
*/
@KoverGradlePluginDsl
public interface KoverCurrentProjectVariantsConfig: KoverVariantConfig {
/**
* Create custom report variant with name [variantName].
* In it is acceptable to add information from other variants of the current project, as well as `kover` dependencies.
*/
public fun createVariant(variantName: String, block: Action)
/**
* Create custom report variant as a copy of the [originalVariantName] variant, however, with the new name [variantName].
*
* Copying variants is useful when you have a single variant with coverage information but want to apply different filters for it:
* You cannot configure the copied variant with [KoverVariantCreateConfig], i.e., add information from other variants to the new one.
* However, you can define report filters and rules for it using `reports { variant(variantName) { ... }}`.
*/
public fun copyVariant(variantName: String, originalVariantName: String)
/**
* Configure the variant with name [variantName] that is automatically created in the current project.
* For example, `"jvm"` for JVM target or `"debug"` for Android build variant.
*/
public fun providedVariant(variantName: String, block: Action)
/**
* Configure the variant for all the code that is available in the current project.
* This variant always exists for any type of project.
*/
public fun totalVariant(block: Action)
/**
* Instrumentation settings for the current Gradle project.
*
* Instrumentation is the modification of classes when they are loaded into the JVM, which helps to determine which code was called and which was not.
* Instrumentation changes the bytecode of the class, so it may disable some JVM optimizations, slow down performance and concurrency tests, and may also be incompatible with other instrumentation libraries.
*
* For this reason, it may be necessary to fine-tune the instrumentation, for example, disabling instrumentation for problematic classes. Note that such classes would be marked as uncovered because of that.
*
* Example:
* ```
* instrumentation {
* // disable instrumentation of test tasks of all classes
* disabledForAll = true
*
* // disable instrumentation of test task `test2`
* disabledForTasks.add("test2")
*
* // The coverage of the test1 and test2 tasks will no longer be taken into account in the reports
* // as well as these tasks will not be called when generating the report.
* // These tasks will not be instrumented even if you explicitly run them
* disabledForTestTasks.addAll("test1", "test2")
*
* // disable instrumentation of specified classes in test tasks
* excludedClasses.addAll("foo.bar.*Biz", "*\$Generated")
* }
* ```
*/
public fun instrumentation(block: Action)
/**
* Instance to configuring of instrumentation for the current Gradle project.
*
* See details in [instrumentation].
*/
public val instrumentation: KoverProjectInstrumentation
}
/**
* Common config for Kover report variants.
*/
@KoverGradlePluginDsl
public interface KoverVariantConfig {
/**
* Limit the classes that will be included in the reports.
* These settings do not affect the instrumentation of classes.
*
* The settings specified here affect all reports in any projects that use the current project depending on.
* However, these settings should be used to regulate classes specific only to the project in which this setting is specified.
*
* Example:
* ```
* sources {
* // exclude classes compiled by Java compiler from all reports
* excludeJava = true
*
* // exclude source classes of specified source sets from all reports
* excludedSourceSets.addAll(excludedSourceSet)
* ```
*/
public fun sources(block: Action)
/**
* Instance to limit the classes that will be included in the reports.
*
* See details in [sources].
*/
public val sources: KoverVariantSources
}
/**
* Limit the classes that will be included in the reports.
* These settings do not affect the instrumentation of classes.
*
* The settings specified here affect all reports in any projects that use the current project depending on.
* However, these settings should be used to regulate classes specific only to the project in which this setting is specified.
*
* Example:
* ```
* sources {
* // exclude classes compiled by Java compiler from all reports
* excludeJava = true
*
* // exclude source classes of specified source sets from all reports
* excludedSourceSets.addAll(excludedSourceSet)
* ```
*/
@KoverGradlePluginDsl
public interface KoverVariantSources {
/**
* Exclude classes compiled by Java compiler from all reports
*/
public val excludeJava: Property
/**
* Exclude source classes of specified source sets from all reports
*/
public val excludedSourceSets: SetProperty
}
/**
* Instrumentation settings for the current Gradle project.
*
* Instrumentation is the modification of classes when they are loaded into the JVM, which helps to determine which code was called and which was not.
* Instrumentation changes the bytecode of the class, so it may disable some JVM optimizations, slow down performance and concurrency tests, and may also be incompatible with other instrumentation libraries.
*
* For this reason, it may be necessary to fine-tune the instrumentation, for example, disabling instrumentation for problematic classes.
*
* Example:
* ```
* instrumentation {
* // disable instrumentation of test tasks of all classes
* disabledForAll = true
*
* // The coverage of the test1 and test2 tasks will no longer be taken into account in the reports
* // as well as these tasks will not be called when generating the report.
* // These tasks will not be instrumented even if you explicitly run them
* disabledForTestTasks.addAll("test1", "test2")
*
* // disable instrumentation of specified classes in test tasks
* excludedClasses.addAll("foo.bar.*Biz", "*\$Generated")
* }
* ```
*/
@KoverGradlePluginDsl
public interface KoverProjectInstrumentation {
/**
* Disable instrumentation in all test tasks.
* No one task from this project will not be called when generating Kover reports and these tasks will not be instrumented even if you explicitly run them.
*/
public val disabledForAll: Property
/**
* Specifies not to use test task with passed names to measure coverage.
* These tasks will also not be called when generating Kover reports and these tasks will not be instrumented even if you explicitly run them.
*/
public val disabledForTestTasks: SetProperty
/**
* Disable instrumentation in test tasks of specified classes
*
* Classes in [excludedClasses] have priority over classes from [includedClasses].
*/
public val excludedClasses: SetProperty
/**
* Enable instrumentation in test tasks only of specified classes.
* All other classes will not be instrumented.
*
* Classes in [excludedClasses] have priority over classes from [includedClasses].
*/
public val includedClasses: SetProperty
}
/**
* The type for creating a custom report variant.
*
* Example:
* ```
* // Add to created variant classes, tests and instrumented classes from "jvm" report variant of current project
* add("jvm")
*
* // add an "nonexistent" option that may not exist in the current project
* add("nonexistent", true)
*
* // Add to created variant classes, tests and instrumented classes from "jvm" report variant of current project, as well as `kover(project("name"))` dependencies
* addWithDependencies("custom")
* ```
*/
@KoverGradlePluginDsl
public interface KoverVariantCreateConfig: KoverVariantConfig {
/**
* Add to created variant classes, tests and instrumented classes from report variant with name [variantNames].
* This variant is taken only from the current project.
*
* If [optional] is `false` and a variant with given name is not found in the current project, an error [KoverIllegalConfigException] is thrown.
*/
public fun add(vararg variantNames: String, optional: Boolean = false)
/**
* Add to created variant classes, tests and instrumented classes from report variant with name [variantNames].
* This variant is taken from the current project and all `kover(project("name"))` dependency projects.
*
* If [optional] is `false` and a variant with given name is not found in the current project, an error [KoverIllegalConfigException] is thrown.
*
* If [optional] is `true` and a variant with given name is not found in the current project - in this case, the variant will not be searched even in dependencies.
*/
public fun addWithDependencies(vararg variantNames: String, optional: Boolean = false)
/**
* Add to created variant classes, tests and instrumented classes from report variant with name [variantNames].
* These variants are taken only from the current project.
*
* If [optional] is `false` and a variant with given name is not found in the current project, an error [KoverIllegalConfigException] is thrown.
*/
public fun add(variantNames: Iterable, optional: Boolean = false)
/**
* Add to created variant classes, tests and instrumented classes from report variant with name [variantNames].
* These variants are taken from the current project and all `kover(project("name"))` dependency projects.
*
* If [optional] is `false` and a variant with given name is not found in the current project, an error [KoverIllegalConfigException] is thrown.
*
* If [optional] is `true` and a variant with given name is not found in the current project - in this case, the variant will not be searched even in dependencies.
*/
public fun addWithDependencies(variantNames: Iterable, optional: Boolean = false)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy