-
-
Notifications
You must be signed in to change notification settings - Fork 32
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
JaCoCo coverage metrics changed by enabling Sentry tracingInstrumentation
#763
Comments
Our AGP version is 8.5.0 and our Jacoco version is 0.8.7 |
Additional context from the customer:
|
We bumped Jacoco to its latest version (0.8.12) but unfortunately it still looks like enabling instrumentation drops our coverage by over 10% |
hi, I've taken a look at this, and it seems like an issue is on the AGP's side: https://issuetracker.google.com/issues/233251847. Unfortunately, there's no fix yet, but the suggested workaround looks reasonable to me. Do you use a custom task for jacoco? If so, I think the workaround should be straightforward to apply. Could you also share your jacoco task/setup, so we could think of applying the workaround automatically on our side? I'm also not sure if it's possible to fix on the AGP's side, as it seems they are supplying the classpath to the unit-test task after bytecode transformations (which is correct), but then the very same classpath has to be used for jacoco as well. |
Thanks for finding that @romtsn! Just finished some testing with that workaround and the numbers definitely look a lot better. We're still losing about 3% in coverage in our |
@LeonRa could you share how you applied the workaround? Did you only replace your kotlin classes with the asm_transformed ones or also java classes? |
Only replaced the Kotlin classes as we're 100% Kotlin, unless that's a mistake and I should replace the Java ones as well? I will call out that the branch with incorrect coverage is the Android |
Workaround was applied as the following in our custom Jacoco class: val buildDir = project.layout.buildDirectory.asFile.get().path
val excludes =
Action<ConfigurableFileTree> {
exclude(ANDROID_COVERAGE_EXCLUSIONS)
exclude(ANDROID_HILT_EXCLUSIONS)
}
val classesFileTree: ConfigurableFileTree =
if (project.plugins.hasPlugin("com.android.application")) {
project.fileTree(
"$buildDir/intermediates/classes/${variant.name}/transform${variant.name.capitalize()}ClassesWithAsm/dirs",
excludes
)
} else {
project.fileTree("$buildDir/tmp/kotlin-classes/${variant.name}", excludes)
} |
@LeonRa yeah that looks legit. Do you notice any patterns in those files that lose coverage? I see from my tests that the |
Unfortunately I can't say that I see any patterns in regards to what's losing coverage. The one thing I will note is that I'm seeing is a large increase in the number of branches and instructions, which increases the size of the denominator, hence decreasing the coverage. The numerator does shift as well, but not by nearly as much. For example, we have
Yup, I see both folders on our end and I verified that that
|
Did some more exploration today and, for the sake of sanity, disable the Sentry instrumentation while keeping the fix in place. This has the following results:
The difference is stark and, further, subtracting these out shows that enabling Sentry instrumentation results in a drop of 1,066 instructions and 65 branches, leading me to believe that the underlying problem is actually the workaround in this case. |
that's probably because you have some other gradle plugins that do bytecode instrumentation (like firebase performance or dagger hilt, etc.), I guess they were not included in your baseline, hence the increase in instructions/branches. Tbh, I'm not sure if there's a proper fix right now, other than disabling instrumentation for tests altogether. On the other hand, it seems like a correct thing to do to test your already instrumented code, also Google does it for their internal tests (this will return already instrumented classes). |
Thanks for your help here @romtsn! Happy to confirm that I've gotten things to work by adding a few extra exclusions on top of the workaround above:
|
@LeonRa that's great to hear! I will formalize this and put onto our troubleshooting page, as I doubt we can do something on the plugin's side here |
Integration
sentry-android
Build System
Gradle
AGP Version
8.5.0
Proguard
Enabled
Version
7.14.0
Steps to Reproduce
(opening on behalf of a customer)
0.8.7
]tracingInstrumentation
per https://docs.sentry.io/platforms/android/troubleshooting/#auto-instrumentation-issues. Rerun unit test suite, it is back to the same coverage number as in step 1Expected Result
Expected result is that default Gradle
tracingInstrumentation
should not affect test coverage.Actual Result
Unit test coverage drops by 15%, which we do not want. Is there an alternative to keep coverage normal, other than disabling
tracingInstrumentation
?The text was updated successfully, but these errors were encountered: