2016-01-14 3 views
1

Я пытаюсь обновить Robolectric до 3.0. Я использую RobolectricGradleTestRunner, а также добавил @Config(constants = BuildConfig.class) выше моего тестового класса. Я также пробовал использовать testCompile org.robolectric:robolectric:3.1-SNAPSHOT. Ниже показана трассировка стека, которую я вижу в журналах.Robolectric 3.0 возвращает нулевой указатель

java.lang.NullPointerException 
    at org.robolectric.res.builder.DefaultPackageManager.metaDataToBundle(DefaultPackageManager.java:725) 
    at org.robolectric.res.builder.DefaultPackageManager.addManifest(DefaultPackageManager.java:503) 
    at org.robolectric.internal.ParallelUniverse.setUpApplicationState(ParallelUniverse.java:80) 
    at org.robolectric.RobolectricTestRunner.setUpApplicationState(RobolectricTestRunner.java:440) 
    at org.robolectric.RobolectricTestRunner$2.evaluate(RobolectricTestRunner.java:244) 
    at org.robolectric.RobolectricTestRunner.runChild(RobolectricTestRunner.java:185) 
    at org.robolectric.RobolectricTestRunner.runChild(RobolectricTestRunner.java:54) 
    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.RobolectricTestRunner$1.evaluate(RobolectricTestRunner.java:151) 
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363) 
    at org.gradle.api.internal.tasks.testing.junit.JUnitTestClassExecuter.runTestClass(JUnitTestClassExecuter.java:86) 
    at org.gradle.api.internal.tasks.testing.junit.JUnitTestClassExecuter.execute(JUnitTestClassExecuter.java:49) 
    at org.gradle.api.internal.tasks.testing.junit.JUnitTestClassProcessor.processTestClass(JUnitTestClassProcessor.java:69) 
    at org.gradle.api.internal.tasks.testing.SuiteTestClassProcessor.processTestClass(SuiteTestClassProcessor.java:48) 
    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:483) 
    at org.gradle.messaging.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:35) 
    at org.gradle.messaging.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:24) 
    at org.gradle.messaging.dispatch.ContextClassLoaderDispatch.dispatch(ContextClassLoaderDispatch.java:32) 
    at org.gradle.messaging.dispatch.ProxyDispatchAdapter$DispatchingInvocationHandler.invoke(ProxyDispatchAdapter.java:93) 
    at com.sun.proxy.$Proxy2.processTestClass(Unknown Source) 
    at org.gradle.api.internal.tasks.testing.worker.TestWorker.processTestClass(TestWorker.java:105) 
    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:483) 
    at org.gradle.messaging.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:35) 
    at org.gradle.messaging.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:24) 
    at org.gradle.messaging.remote.internal.hub.MessageHub$Handler.run(MessageHub.java:360) 
    at org.gradle.internal.concurrent.DefaultExecutorFactory$StoppableExecutorImpl$1.run(DefaultExecutorFactory.java:64) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
    at java.lang.Thread.run(Thread.java:745) 
+0

Добавлено форматирование кода для трассировки стека для читаемость. – jbafford

ответ

0

У меня были подобные проблемы. Не могу сказать, что я знаю, что сделал причиной их, но мои Gradle модульные тесты работают, если мой TestClass помечается

@RunWith(RobolectricGradleTestRunner.class) 
@Config(emulateSdk = 19, constants = BuildConfig.class) 

Пожалуйста, попробуйте запустить его из консоли с gradle testCompile

+0

Я бегу из командной строки с помощью этой команды: ./gradlew testDebug -Dpre-dex = false -info --stacktrace Я все еще вижу ту же проблему. – user3773337

Смежные вопросы