Модульный тест Robolectric завершается с ошибкой NoClassDefFoundError, когда приложение зависит от AppsFlyerLib

Мое приложение имеет следующие зависимости appsflyer:

'com.appsflyer:af-android-sdk:4.8.15' 'com.android.installreferrer:installreferrer:1.0'

И я попытался запустить модульный тест Robolectric с добавленной зависимостью appsflyer, но мой тест не запустился, а просто выдал ошибку, которая приведена ниже (я могу запустить тест, и тест завершится успешно, если я удалю зависимость appsflyer.)

java.lang.NoClassDefFoundError: com/appsflyer/r (wrong name: com/appsflyer/R)
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:763)
at java.lang.ClassLoader.defineClass(ClassLoader.java:642)
at org.robolectric.internal.bytecode.SandboxClassLoader.maybeInstrumentClass(SandboxClassLoader.java:134)
at org.robolectric.internal.bytecode.SandboxClassLoader.lambda$findClass$0(SandboxClassLoader.java:111)
at org.robolectric.util.PerfStatsCollector.measure(PerfStatsCollector.java:50)
at org.robolectric.internal.bytecode.SandboxClassLoader.findClass(SandboxClassLoader.java:110)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
at com.appsflyer.AppsFlyerLib.<init>(:176)
at com.appsflyer.AppsFlyerLib.<clinit>(:162)
at ... org.robolectric.android.internal.ParallelUniverse.lambda$setUpApplicationState$0(ParallelUniverse.java:260)
at org.robolectric.util.PerfStatsCollector.measure(PerfStatsCollector.java:72)
at org.robolectric.android.internal.ParallelUniverse.setUpApplicationState(ParallelUniverse.java:260)
at org.robolectric.RobolectricTestRunner.beforeTest(RobolectricTestRunner.java:377)
at org.robolectric.internal.SandboxTestRunner$2.evaluate(SandboxTestRunner.java:252)
at org.robolectric.internal.SandboxTestRunner.runChild(SandboxTestRunner.java:130)
at org.robolectric.internal.SandboxTestRunner.runChild(SandboxTestRunner.java:42)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.robolectric.internal.SandboxTestRunner$1.evaluate(SandboxTestRunner.java:84)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at androidx.test.ext.junit.runners.AndroidJUnit4.run(AndroidJUnit4.java:104)
at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68)
at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:47)
at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242)
at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at com.intellij.rt.execution.application.AppMainV2.main(AppMainV2.java:131) [Robolectric] jp.co.matchingagent.cocotsure.ui.contact.ContactActionCreatorTest.loadMoreNewMatchRoomListTest exist data: sdk=27; resources=legacy [Robolectric] NOTICE: legacy resources mode is deprecated; see http://robolectric.org/migrating/#migrating-to-40java.lang.IllegalStateException: this method should only be called by Robolectric at org.robolectric.shadows.ShadowDisplayManager.configureDefaultDisplay(ShadowDisplayManager.java:43)
at org.robolectric.android.Bootstrap.setUpDisplay(Bootstrap.java:18)
at org.robolectric.android.internal.ParallelUniverse.setUpApplicationState(ParallelUniverse.java:194)
at org.robolectric.RobolectricTestRunner.beforeTest(RobolectricTestRunner.java:377)
at org.robolectric.internal.SandboxTestRunner$2.evaluate(SandboxTestRunner.java:252)
at org.robolectric.internal.SandboxTestRunner.runChild(SandboxTestRunner.java:130)
at org.robolectric.internal.SandboxTestRunner.runChild(SandboxTestRunner.java:42)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.robolectric.internal.SandboxTestRunner$1.evaluate(SandboxTestRunner.java:84)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at androidx.test.ext.junit.runners.AndroidJUnit4.run(AndroidJUnit4.java:104)
at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68)
at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:47)
at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242)
at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at com.intellij.rt.execution.application.AppMainV2.main(AppMainV2.java:131)

Заранее спасибо!


person shoheikawano    schedule 29.11.2018    source источник
comment
согласно java.lang.NoClassDefFoundError: com/appsflyer/r (wrong name: com/appsflyer/R), похоже, проблема с версией библиотеки.   -  person shizhen    schedule 29.11.2018
comment
@shizhen спасибо за ваш комментарий. Вы имеете в виду, что если я укажу другую версию библиотеки для библиотеки appsflyer, это решит проблему? Я пробовал, но это не так.   -  person shoheikawano    schedule 29.11.2018
comment
можете опубликовать полную конфигурацию зависимостей в build.gradle?   -  person shizhen    schedule 29.11.2018
comment
NoClassDefFoundError — это ошибка, возникающая, когда определенный класс присутствует во время компиляции, но отсутствует во время выполнения. Проверьте правильность конфигурации сборки Gradle для com/appsflyer/r.   -  person shizhen    schedule 29.11.2018
comment
› Проверьте правильность конфигурации сборки Gradle для com/appsflyer/r. Означает ли это, что мне нужно настроить что-то в build.gradle специально для appsflyer при тестировании?   -  person shoheikawano    schedule 03.12.2018
comment
Я предполагаю, что многомодульная структура может иметь отношение к этой проблеме?   -  person shoheikawano    schedule 03.12.2018
comment
Обновление версии библиотеки appsflyer, кажется, решило проблему.   -  person shoheikawano    schedule 26.02.2019


Ответы (1)


Исправлено в AppsFlyer версии 4.8.19.

person kreker    schedule 02.04.2019