4

我正在运行仪器测试并收到此编译错误:

org.gradle.api.tasks.TaskExecutionException: Execution failed for task ':app:transformClassesAndResourcesWithR8ForDebugAndroidTest'.
        at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter$3.accept(ExecuteActionsTaskExecuter.java:151)
        at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter$3.accept(ExecuteActionsTaskExecuter.java:148)
        at org.gradle.internal.Try$Failure.ifSuccessfulOrElse(Try.java:191)
        at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.execute(ExecuteActionsTaskExecuter.java:141)
        ...
Caused by: java.lang.RuntimeException: com.android.tools.r8.CompilationFailedException: Compilation failed to complete
        at com.android.builder.profile.Recorder$Block.handleException(Recorder.java:55)
        at com.android.builder.profile.ThreadRecorder.record(ThreadRecorder.java:108)
        at com.android.build.gradle.internal.pipeline.TransformTask.transform(TransformTask.java:230)
        at org.gradle.internal.reflect.JavaMethod.invoke(JavaMethod.java:103)
        at org.gradle.api.internal.project.taskfactory.IncrementalTaskInputsTaskAction.doExecute(IncrementalTaskInputsTaskAction.java:46)
        ...
Caused by: com.android.tools.r8.CompilationFailedException: Compilation failed to complete
        at com.android.tools.r8.utils.z.a(:55)
        at com.android.tools.r8.R8.runForTesting(:3)
        at com.android.tools.r8.R8.run(:3)
        at com.android.builder.dexing.R8Tool.runR8(r8Tool.kt:195)

Caused by: com.android.tools.r8.utils.AbortException: Error: offset: 0, line: 16559, column: 1, 'void zza(com.google.android.gms.common.internal.BaseGmsClient,int,android.os.IInterface)' already has a mapping
        at com.android.tools.r8.utils.Reporter.a(:21)
        at com.android.tools.r8.naming.SeedMapper$a.build(:1)
        ...

如果我查看,app/build/outputs/mappings/debug/mapping.txt我会看到该方法列出了两次。

com.google.android.gms.common.internal.BaseGmsClient -> com.google.android.gms.common.internal.BaseGmsClient:
    ...
    344:344:void zza(com.google.android.gms.common.internal.BaseGmsClient,int,android.os.IInterface) -> zza
    ...
    350:350:void zza(com.google.android.gms.common.internal.BaseGmsClient,int,android.os.IInterface) -> zza
  1. 奇怪的是没有发生在基本的应用程序编译上。不知道为什么 R8 用测试代码做任何事情。
  2. 这是 R8 问题还是 Play Services 问题?
  3. 我该如何解决这个问题。gradle clean + invalidate/restart 没有做任何事情,也没有手动删除和重新生成 mappings.txt 文件。
4

2 回答 2

11

我可能有一些答案。

关于 1. 如果您在将 minifyEnabled 设置为 true 的情况下编译您的应用程序并在之后运行检测测试,您的应用程序可能具有缩小的类、方法等。因此,所有测试都需要使用 R8 重新编译,以便在您的测试中更正所有缩小的名称。具体来说,你的测试是由 R8 编译的,你的 app 在 library-path 和一个 proguard 配置,上面写着 -applymapping 。

关于 2。这是一个 R8 问题。通过将以下内容添加到项目级别的 build.gradle 文件中,您可能会获得一些运气:

buildscript {

    repositories {
        maven {
            url 'http://storage.googleapis.com/r8-releases/raw'
        }
    }

    dependencies {
        classpath 'com.android.tools:r8:1.5.45'          // Must be before the Gradle Plugin for Android.
        classpath 'com.android.tools.build:gradle:X.Y.Z' // Your current AGP version.
     }
}

关于 3. 如果 2. 中的修复不起作用,您可以在 R8 错误跟踪器上关注以下错误: https ://issuetracker.google.com/issues/122924648

在问题得到解决之前,也可以在缩小的应用程序上不使用仪器。

于 2019-06-18T14:08:41.180 回答
2

我有完全相同的错误,@MortenKJ的建议对我不起作用。

我的解决方法不是很令人满意,但这是我现在能做的最好的。每当我想运行插桩测试时,我都会设置minifyEnabledtofalseminSdkVersionto 21(因为这个 sdk 版本multidex默认启用,并且没有达到 dex 方法限制的错误)。

仪表测试现在按预期运行。

于 2019-09-13T09:58:46.833 回答