Verifier rejected class android

java.lang.VerifyError: Verifier rejected class #607

Comments

h-amg commented Jul 12, 2019

The error occurs when I attempt to retrieve data from firestore while writing data works totally fine.

Exception message:

Caused by: java.lang.VerifyError: Verifier rejected class com.google.firestore.v1.WriteResponse due to bad method java.lang.Object com.google.firestore.v1.WriteResponse.dynamicMethod(com.google.protobuf.GeneratedMessageLite$MethodToInvoke, java.lang.Object, java.lang.Object) (declaration of ‘com.google.firestore.v1.WriteResponse’ appears in /data/app/com.app.android.name-1/split_lib_dependencies_apk.apk:classes2.dex)

The code runs normally anywhere but inside firestore onComplete callback method:

DebugLogs:

07-11 08:02:11.603 27666-27666/com.app.android.name W/DisplayListCanvas: DisplayListCanvas is started on unbinded RenderNode (without mOwningView)
07-11 08:02:11.613 27666-27666/com.app.android.name D/ViewRootImpl: MSG_RESIZED_REPORT: ci=Rect(0, 72 — 0, 0) vi=Rect(0, 72 — 0, 0) or=1
07-11 08:02:11.653 27666-28056/com.app.android.name I/DynamiteModule: Considering local module providerinstaller:0 and remote module providerinstaller:0
07-11 08:02:11.653 27666-28056/com.app.android.name W/ProviderInstaller: Failed to load providerinstaller module: No acceptable module found. Local version is 0 and remote version is 0.
07-11 08:02:11.653 27666-28056/com.app.android.name W/ResourcesManager: getTopLevelResources: /data/app/com.google.android.gms-1/base.apk / 1.0 running in com.app.android.name rsrc of package null
07-11 08:02:11.683 27666-27666/com.app.android.name I/Timeline: Timeline: Activity_idle id: android.os.BinderProxy@ff29e8d time:147037202
07-11 08:02:11.723 27666-29453/com.app.android.name I/art: Verification error in void com.google.firestore.v1.WriteResponse.mergeCommitTime(com.google.protobuf.Timestamp)
07-11 08:02:11.723 27666-29453/com.app.android.name I/art: void com.google.firestore.v1.WriteResponse.mergeCommitTime(com.google.protobuf.Timestamp): [0x10] couldn’t find method com.google.protobuf.Timestamp$Builder.mergeFrom (Lcom/google/protobuf/GeneratedMessageLite;)Lcom/google/protobuf/GeneratedMessageLite$Builder;
07-11 08:02:11.723 27666-29453/com.app.android.name I/art: void com.google.firestore.v1.WriteResponse.mergeCommitTime(com.google.protobuf.Timestamp) failed to verify: void com.google.firestore.v1.WriteResponse.mergeCommitTime(com.google.protobuf.Timestamp): [0x10] register v3 has type Precise Reference: com.google.protobuf.Timestamp but expected Reference: com.google.protobuf.GeneratedMessageLite
07-11 08:02:11.723 27666-29453/com.app.android.name I/art: Verification error in java.lang.Object com.google.firestore.v1.WriteResponse.dynamicMethod(com.google.protobuf.GeneratedMessageLite$MethodToInvoke, java.lang.Object, java.lang.Object)
07-11 08:02:11.723 27666-29453/com.app.android.name I/art: java.lang.Object com.google.firestore.v1.WriteResponse.dynamicMethod(com.google.protobuf.GeneratedMessageLite$MethodToInvoke, java.lang.Object, java.lang.Object): [0x5C] couldn’t find method com.google.protobuf.Timestamp.toBuilder ()Lcom/google/protobuf/GeneratedMessageLite$Builder;
07-11 08:02:11.723 27666-29453/com.app.android.name I/art: java.lang.Object com.google.firestore.v1.WriteResponse.dynamicMethod(com.google.protobuf.GeneratedMessageLite$MethodToInvoke, java.lang.Object, java.lang.Object): [0x73] couldn’t find method com.google.protobuf.Timestamp$Builder.mergeFrom (Lcom/google/protobuf/GeneratedMessageLite;)Lcom/google/protobuf/GeneratedMessageLite$Builder;
07-11 08:02:11.723 27666-29453/com.app.android.name I/art: java.lang.Object com.google.firestore.v1.WriteResponse.dynamicMethod(com.google.protobuf.GeneratedMessageLite$MethodToInvoke, java.lang.Object, java.lang.Object) failed to verify: java.lang.Object com.google.firestore.v1.WriteResponse.dynamicMethod(com.google.protobuf.GeneratedMessageLite$MethodToInvoke, java.lang.Object, java.lang.Object): [0x73] register v5 has type Precise Reference: com.google.protobuf.Timestamp but expected Reference: com.google.protobuf.GeneratedMessageLite
07-11 08:02:11.723 27666-29453/com.app.android.name W/art: Verification failed on class com.google.firestore.v1.WriteResponse in /data/app/com.app.android.name-1/split_lib_dependencies_apk.apk because: Verifier rejected class com.google.firestore.v1.WriteResponse due to bad method java.lang.Object com.google.firestore.v1.WriteResponse.dynamicMethod(com.google.protobuf.GeneratedMessageLite$MethodToInvoke, java.lang.Object, java.lang.Object)
07-11 08:02:11.733 27666-27666/com.app.android.name D/AndroidRuntime: Shutting down VM
07-11 08:02:11.733 27666-27666/com.app.android.name E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.app.android.name, PID: 27666
java.lang.RuntimeException: Internal error in Firestore (20.1.0).
at com.google.firebase.firestore.util.AsyncQueue.lambda$panic$5(com.google.firebase:firebase-firestore@@20.1.0:379)
at com.google.firebase.firestore.util.AsyncQueue$$Lambda$5.run(com.google.firebase:firebase-firestore@@20.1.0)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:158)
at android.app.ActivityThread.main(ActivityThread.java:7224)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)
Caused by: java.lang.VerifyError: Verifier rejected class com.google.firestore.v1.WriteResponse due to bad method java.lang.Object com.google.firestore.v1.WriteResponse.dynamicMethod(com.google.protobuf.GeneratedMessageLite$MethodToInvoke, java.lang.Object, java.lang.Object) (declaration of ‘com.google.firestore.v1.WriteResponse’ appears in /data/app/com.app.android.name-1/split_lib_dependencies_apk.apk)
at com.google.firestore.v1.WriteResponse.getDefaultInstance(com.google.firebase:firebase-firestore@@20.1.0:1012)
at com.google.firestore.v1.FirestoreGrpc.getWriteMethod(com.google.firebase:firebase-firestore@@20.1.0:379)
at com.google.firebase.firestore.remote.WriteStream.(com.google.firebase:firebase-firestore@@20.1.0:74)
at com.google.firebase.firestore.remote.Datastore.createWriteStream(com.google.firebase:firebase-firestore@@20.1.0:104)
at com.google.firebase.firestore.remote.RemoteStore.(com.google.firebase:firebase-firestore@@20.1.0:186)
at com.google.firebase.firestore.core.FirestoreClient.initialize(com.google.firebase:firebase-firestore@@20.1.0:263)
at com.google.firebase.firestore.core.FirestoreClient.lambda$new$2(com.google.firebase:firebase-firestore@@20.1.0:117)
at com.google.firebase.firestore.core.FirestoreClient$$Lambda$2.run(com.google.firebase:firebase-firestore@@20.1.0)
at com.google.firebase.firestore.util.AsyncQueue.lambda$enqueue$4(com.google.firebase:firebase-firestore@@20.1.0:311)
at com.google.firebase.firestore.util.AsyncQueue$$Lambda$4.call(com.google.firebase:firebase-firestore@@20.1.0)
at com.google.firebase.firestore.util.AsyncQueue.lambda$enqueue$3(com.google.firebase:firebase-firestore@@20.1.0:287)
at com.google.firebase.firestore.util.AsyncQueue$$Lambda$3.run(com.google.firebase:firebase-firestore@@20.1.0)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:423)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:154)
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:269)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
at com.google.firebase.firestore.util.AsyncQueue$DelayedStartFactory.run(com.google.firebase:firebase-firestore@@20.1.0:205)
at java.lang.Thread.run(Thread.java:818)
07-11 08:02:11.863 27666-27685/com.app.android.name W/art: Suspending all threads took: 62.326ms
07-11 08:02:11.893 27666-27685/com.app.android.name I/art: Background sticky concurrent mark sweep GC freed 78605(5MB) AllocSpace objects, 48(2MB) LOS objects, 18% free, 28MB/35MB, paused 63.394ms total 143.944ms
07-11 08:02:11.963 27666-28056/com.app.android.name V/NativeCrypto: Registering com/google/android/gms/org/conscrypt/NativeCrypto’s 284 native methods.
07-11 08:02:12.073 27666-28056/com.app.android.name I/art: Rejecting re-init on previously-failed class java.lang.Class
07-11 08:02:12.083 27666-28056/com.app.android.name I/art: Rejecting re-init on previously-failed class java.lang.Class
07-11 08:02:12.083 27666-28056/com.app.android.name I/art: Rejecting re-init on previously-failed class java.lang.Class
07-11 08:02:12.083 27666-28056/com.app.android.name I/art: Rejecting re-init on previously-failed class java.lang.Class
07-11 08:02:12.133 27666-28056/com.app.android.name I/ProviderInstaller: Installed default security provider GmsCore_OpenSSL

Build.gradle:

Читайте также:  Бой с тенью для андроид с кешем

Note:
I had duplicate classes issue between firebase and dialogflow earlier hence the excluded classes below:

The text was updated successfully, but these errors were encountered:

Источник

java.lang.VerifyError: Verifier rejected class #17

Comments

siddhpuraamitr commented Dec 8, 2020 •

I don’t want to use callback, for that I am using suspendCancellableCoroutine,
Below function, I have used to get deviceId

I am always getting an error like below

The text was updated successfully, but these errors were encountered:

Alexey-Verkhovsky commented Dec 8, 2020 •

Hi!
I tried to reproduce the issue, and the following code works fine:

Have you tried to clean the project? Invalidate cache/Restart in Android Studio?

siddhpuraamitr commented Dec 9, 2020 •

Don’t know, why I am getting same error again and again,

If I use it without Coroutine it is working fine!!

Tried, Invalidate Cache/ Restart, Rebuild, Reinstall App, Different Phone.

My configuration is

Alexey-Verkhovsky commented Dec 9, 2020 •

I’ve found an issue, and the error is very similar. That one happened because of the bug in the compiler in version 1.3.6. Yours is 1.3.3, but probably this is another one. I tried to reproduce it with my simple application and it’s still working fine. Maybe the problem reproduces only with more complex classes and nested coroutines as you have.

Let’s try to localize the problem and perform a few experiments:

What if you change your code to the following, will it still be crashing? I just removed all the code with fingerprinter to check for problems with coroutines.

What if you remove try/catch construction?

Читайте также:  Гонки с русскими машинами для андроид

What if you remove it.cancel() ?

Another option is to update the coroutine library from 1.3.3 to 1.3.6. If it won’t help then update to 1.4.0 and check for the result again.

Источник

java.lang.VerifyError: Verifier rejected class ProductCursor: long failed to verify: long. [0x50A] register v256 has type Undefined but expected Integer #465

Comments

shripal17 commented Jun 8, 2018 •

Please help us to fix issues asap:

Issue Basics

  • ObjectBox version : 1.5.0
  • Reproducibility: always

Reproducing the bug

Description

This issue started occurring only after upgrading to Android Studio v3.1.3 from v3.1.2.

Occurs whenever i try to access the Box for my Product
prodBox.all.size == 0

Logs & stackstraces

Entities

I also tried from Android Studio 3.2 Canary 17 but it still doesn’t work.
The app works normally if i downgrade to the last APK Built from Android Studio 3.1.2 (code is still same).
I even tried disabling R8 by adding the following line to gradle.properties
android.enableR8 = false

I am using the following dependencies/libraries:
-Apache POI for Android 3.12

The text was updated successfully, but these errors were encountered:

shripal17 commented Jun 8, 2018

I also tried the following procedures:
Clean Project -> Make Project
Rebuild Project -> Make Project

Closing the Project in Android Studio, Deleting build folders and objectbox-models folders

Re-opening in Android Studio

PDharam commented Jun 9, 2018

Method threw ‘java.lang.VerifyError’ exception.
same error occured.

PDharam commented Jun 9, 2018

Issue is resolved.

Issue not for Android Studio 3.1.3.

change build.gradle version

com.android.tools.build:gradle:3.1.3
to
com.android.tools.build:gradle:3.1.2

shripal17 commented Jun 9, 2018

That’s not a permanent solution.

PDharam commented Jun 9, 2018

Yes, problem with updated gradle version, need to fix this.

Joslyn-Chen commented Jun 11, 2018

I also encountered this problem.

Joslyn-Chen commented Jun 11, 2018

@shripal17 Did you solve this problem?

greenrobot commented Jun 11, 2018

Seems like this is either an error in Google’s byte code verifier or on our side. We’ll investigate, but it might take some days. So, meanwhile, please stick to com.android.tools.build:gradle:3.1.2 until there’s an update.

shripal17 commented Jun 11, 2018

@greenrobot thanks a lot for your response. I will wait until the issue gets fixed.
and @Joslyn-Chen No, i couldn’t solve this issue. I reverted back to Android Studio 3.1.2

Joslyn-Chen commented Jun 11, 2018

@shripal17 Ok,Excuse me, how toreverted back to Android Studio 3.1.2? re-install?

greenrobot commented Jun 11, 2018

@Joslyn-Chen Check #465 (comment); you can still use Androis Studio 3.1.3 but use com.android.tools.build:gradle:3.1.2

Joslyn-Chen commented Jun 12, 2018

@greenrobot Thank you very much。

greenrobot-team commented Jun 18, 2018

I can’t reproduce this by upgrading our Kotlin example to com.android.tools.build:gradle:3.1.3 using Android Studio 3.1.3 and an Android 8.1.0 emulator. I also added the same method call ( val size = notesBox.all.size ).

Читайте также:  Девушка с часами для андроид

Could anybody share a small example project that reproduces this issue? Or some more details on which devices (Android version, model) this fails?
-ut

shripal17 commented Jun 18, 2018

Device details on which the issue was faced by me:
Model: Lenovo TB-7304F
Android Version: 7.0, API 24

I will now try it on Android 8.1.0, API 27

shripal17 commented Jun 18, 2018

@greenrobot-team can you check the issue with the data class i have used above.

Additional note: just remove the @Parcelize annotation and : Parcelable interface implementation before testing

greenrobot-team commented Jun 18, 2018 •

@shripal17 OK, can reproduce with the given entity. Will try to determine cause now.

Update:

  • As stated, the error disappears when reverting to com.android.tools.build:gradle:3.1.2 .
  • Updating the Kotlin plugin has no effect.
  • Java classes are also affected.
  • The error disappears if at least 2 String properties are removed. Adding removing properties with other types seems to have no effect. For Java classes the limit appears to be 60 String properties, for a Kotlin data class 68 String properties.
  • Can not be related to our bytecode modifications as this only happens if there are relations, which in this case there are none.

For now the only viable workaround is to stick with com.android.tools.build:gradle:3.1.2 and not update to 3.1.3 . Not seeing how we are causing a problem there. May need to submit an issue to the Android build tools team.

shripal17 commented Jun 18, 2018

Okay thanks a lot for your response @greenrobot-team
Will await for improvements on this issue

greenrobot-team commented Jun 19, 2018

greenrobot-team commented Jul 3, 2018

This error continues to exist with Android Gradle Plugin 3.2.0-beta02.

However, I narrowed the problem down to the new compiler, D8.

By adding the flag android.enableD8=false to the projects gradle.properties file, as suggested in the Android plugin release notes, the error disappears.
-ut

shripal17 commented Jul 3, 2018

Okay thanks a lot for your solution! I will try it soon and report back

madsager commented Jul 3, 2018 •

Thanks for the report! The issue was routed to the D8 team today. We have a fix and will be pushing it to the 3.2 release branch as soon as possible. We hope to get the fix out for 3.2.0-beta04.

shripal17 commented Jul 3, 2018

As mentioned above, disabling D8 works on Android Studio 3.2.0-beta02 (y)

madsager commented Jul 4, 2018 •

Instead of turning off D8, here is how to use the latest stable D8 build with the fix in Android Studio 3.1 and 3.2 until this fix makes it out in the official studio builds.

Источник

Оцените статью