由于GRPC和R8,Firestore(0.6.6-dev)中的内部错误



更新了 Firebase 依赖项后,我的应用停止了运行。崩溃报告显示以下日志:

java.lang.RuntimeException: Internal error in Firestore (0.6.6-dev).
at com.google.firebase.firestore.g.b.a(com.google.firebase:firebase-firestore@@17.0.5:324)
at com.google.firebase.firestore.g.d.run(com.google.firebase:firebase-firestore@@17.0.5)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6165)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:888)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:778)
Caused by: java.lang.AbstractMethodError: abstract method "b.d.g.z$d b.d.g.z$d.a(int)"
at b.d.g.u.a(GeneratedMessageLite.java:1319)
at b.d.c.a.y.a(com.google.firebase:firebase-firestore@@17.0.5:8440)
at b.d.c.a.y$a.a(com.google.firebase:firebase-firestore@@17.0.5:6589)
at com.google.firebase.firestore.f.n.b(com.google.firebase:firebase-firestore@@17.0.5:689)
at com.google.firebase.firestore.c.N.a(com.google.firebase:firebase-firestore@@17.0.5:152)
at com.google.firebase.firestore.c.w.b(com.google.firebase:firebase-firestore@@17.0.5:82)
at com.google.firebase.firestore.c.O.a(com.google.firebase:firebase-firestore@@17.0.5:479)
at com.google.firebase.firestore.c.V.run(com.google.firebase:firebase-firestore@@17.0.5)
at com.google.firebase.firestore.c.u.a(com.google.firebase:firebase-firestore@@17.0.5:117)
at com.google.firebase.firestore.c.O.a(com.google.firebase:firebase-firestore@@17.0.5:474)
at com.google.firebase.firestore.b.f.a(com.google.firebase:firebase-firestore@@17.0.5:165)
at com.google.firebase.firestore.b.o.a(com.google.firebase:firebase-firestore@@17.0.5:79)
at com.google.firebase.firestore.b.r.c(com.google.firebase:firebase-firestore@@17.0.5:132)
at com.google.firebase.firestore.b.w.run(com.google.firebase:firebase-firestore@@17.0.5)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:428)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:272)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
at com.google.firebase.firestore.g.b$a.run(com.google.firebase:firebase-firestore@@17.0.5:190)
at java.lang.Thread.run(Thread.java:761)

由于日志对我的源代码没有任何类引用,因此我试图找出依赖项。

终于明白了,问题是因为R8缩小器和GRPC。

以下是上述问题的解决方案:

  1. android.enableR8=false
  2. -keep class io.grpc.** { *; }

上述两种解决方案对我来说都不是很有趣。

我不想应用第一个解决方案,因为禁用 R8 会增加我的 APK 大小 200 KB。第二个解决方案对我来说是一个黑客。我不赞成在单个类引起问题时保留整个库。

现在的问题是,如何使我的应用程序启用 R8 并且不使grpc库远离混淆?

我使用 R8 和 gRPC 浏览了 Firestore 的快速入门示例应用程序,即使使用 com.google.firebase:firebase-firestore:17.0.5 版本(这似乎是您从堆栈跟踪中使用的版本(,也没有任何问题。我想你可能遇到了 https://github.com/firebase/FirebaseUI-Android/issues/1175,这应该在最近的 firestore 版本中修复,例如 17.1.2。(根据他们的发行说明,17.0.5 包含一个错误,不应使用(。如果无法进行升级,则应该能够手动将以下内容添加到保护规则中,如 Firestore 快速入门示例中所做的那样:

-dontwarn okio.**

(我无法重现您描述的错误,但这似乎是快速入门示例中唯一适用于 gRPC 依赖项的 proguard 规则(

最新更新