Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Kover task to execute action after coverage evaluation #605

Open
shanshin opened this issue May 10, 2024 · 2 comments
Open

Add Kover task to execute action after coverage evaluation #605

shanshin opened this issue May 10, 2024 · 2 comments
Assignees
Labels
Feature Feature request issue type Implement in KGP

Comments

@shanshin
Copy link
Collaborator

shanshin commented May 10, 2024

What is your use-case and why do you need this feature?
In some cases, it is necessary to perform additional actions after measuring the coverage: for example, perform conditional verification, write values to the log, write the coverage values to the file in any form.

Kover cannot provide for all use cases.
However, we can provide a factory with which users can create tasks that perform coverage processing

Describe the solution you'd like

kover {
    reports {
        total {
            evaluations.create("myLog") {
               // use build caching
                isCacheable = false

                // action to execute
                action {
                    logger.info("Total coverage: ${lines.coveredPercentage}%")
                }

                // a way to get a task to specify future dependencies
                taskProvider
            }
        }
    }
}

and later executed via koverMyLogAction

Use cases: #545 and #419

@mgroth0
Copy link

mgroth0 commented Oct 19, 2024

I was just looking for something like this. Similar to #545, I need slightly more advanced verification logic:

pseudocode

if (numberOfBranches > 50 && branchesCoveredPercent < 1) {
    failVerfication()
}

Just like #545, I have some very small modules failing verifications because in shared build logic I make it so all modules have to cover at bare minimum 1 percent of branches. I've had cases where a module has less than 10 branches and this is not ideal for me to fail verification in this case.

@shanshin
Copy link
Collaborator Author

shanshin commented Jan 3, 2025

This task will be taken into account when migrating to Kotlin Gradle Plugin.

In the future, it will be moved to the Kotlin task tracker, or closed if it loses relevance.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Feature Feature request issue type Implement in KGP
Projects
None yet
Development

No branches or pull requests

2 participants