Android-测试运行失败-NullPointerException



我刚刚为正在开发的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

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

  • 如果您使用Android Studio/Gradle命令行运行测试,请确保将测试放置在正确的位置
  • 确保您在Android Studio的Build Variants部分中选择了正确的测试工件;如果您使用的是Instrumentation相关测试,则需要选择Android Instrumentation Tests;如果您使用没有Instrumentation相关的纯JUnit测试Unit Tests

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

Vogella教程的这一部分对测试进行了更详细的描述。

事实证明(正如怀疑的那样)我忽略了一些相当明显的东西。实际上,我正在扩展一个Instrumentation Test类,尽管我连接了一个Android设备,但我没有运行要测试的活动。

先运行我的应用程序,然后运行测试用例,结果很好。

相关内容

最新更新