Android - 测试运行失败 - NullPointerException

时间:2015-11-10 10:27:34

标签: java android eclipse unit-testing junit

我刚为我正在开发的Android应用程序设置了我的第一个JUnit测试用例项目。我为其中一个项目类添加了一个(非常简单的)测试用例,但似乎无法运行它。我已经关注了几个单独的教程,以确保在编写测试用例时我没有忽略某些东西。

我得到NullPointerException - Attempt to invoke virtual method 'java.lang.Classloader android.content.Context.getClassLoader() on a null object reference。我已经完成了多次搜索,寻找相同的问题,但我们无法找到解决方案。下面是logcat输出(注意:我在发布之前用通用术语替换了我的包名称):

11-10 09:56:42.942: E/AndroidRuntime(31147): FATAL EXCEPTION: main
11-10 09:56:42.942: E/AndroidRuntime(31147): Process: <target package name>, PID: 31147
11-10 09:56:42.942: E/AndroidRuntime(31147): java.lang.RuntimeException: Exception thrown in onCreate() of ComponentInfo{<test package name>/android.test.InstrumentationTestRunner}: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.ClassLoader android.content.Context.getClassLoader()' on a null object reference
11-10 09:56:42.942: E/AndroidRuntime(31147):    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5107)
11-10 09:56:42.942: E/AndroidRuntime(31147):    at android.app.ActivityThread.access$1600(ActivityThread.java:177)
11-10 09:56:42.942: E/AndroidRuntime(31147):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1509)
11-10 09:56:42.942: E/AndroidRuntime(31147):    at android.os.Handler.dispatchMessage(Handler.java:102)
11-10 09:56:42.942: E/AndroidRuntime(31147):    at android.os.Looper.loop(Looper.java:145)
11-10 09:56:42.942: E/AndroidRuntime(31147):    at android.app.ActivityThread.main(ActivityThread.java:5942)
11-10 09:56:42.942: E/AndroidRuntime(31147):    at java.lang.reflect.Method.invoke(Native Method)
11-10 09:56:42.942: E/AndroidRuntime(31147):    at java.lang.reflect.Method.invoke(Method.java:372)
11-10 09:56:42.942: E/AndroidRuntime(31147):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1400)
11-10 09:56:42.942: E/AndroidRuntime(31147):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1195)
11-10 09:56:42.942: E/AndroidRuntime(31147): Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.ClassLoader android.content.Context.getClassLoader()' on a null object reference
11-10 09:56:42.942: E/AndroidRuntime(31147):    at android.test.AndroidTestRunner.loadTestClass(AndroidTestRunner.java:87)
11-10 09:56:42.942: E/AndroidRuntime(31147):    at android.test.AndroidTestRunner.setTestClassName(AndroidTestRunner.java:50)
11-10 09:56:42.942: E/AndroidRuntime(31147):    at android.test.InstrumentationTestRunner.onCreate(InstrumentationTestRunner.java:379)
11-10 09:56:42.942: E/AndroidRuntime(31147):    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5104)
11-10 09:56:42.942: E/AndroidRuntime(31147):    ... 9 more

2 个答案:

答案 0 :(得分:1)

这听起来与配置/设置相关(假设您在这里使用Android Studio):

  • 如果您使用的是Android Studio / Gradle命令行来运行测试,请确保已放置测试 in the correct location
  • 确保您在Android Studio的Build Variants部分中有 selected the correct Test Artifact ;如果您正在使用与仪器相关的测试,则需要选择Android Instrumentation测试;如果您使用的是没有Instrumentation依赖项的纯JUnit 测试,则需要单元测试。

当你在InstrumentationTestRunner上获得NPE时,我认为你已经选择了单元测试,这就是问题。

更详细地描述了in this section of the Vogella tutorial测试。

答案 1 :(得分:1)

结果(怀疑)我忽略了一些相当明显的事情。我实际上正在扩展一个Instrumentation Test类,虽然我连接了一个Android设备,但我还没有运行测试的活动。

首先是我的应用程序,然后是测试用例,它运行正常。