[英]Mockito test - Context onject is null exception
I don't know why but I get null pointer exception when running this code. 我不知道为什么,但是运行此代码时出现空指针异常。 This is a really basic Mockito test which I copied from Android's official documentation.
这是一个非常基本的Mockito测试,我从Android的官方文档中复制了该测试。
Don't mind the logic. 不要介意逻辑。 I made it super simple to show that even this basic example doesn't work
我非常简单地表明,即使这个基本示例也不起作用
package com.matala3.me.matala3;
import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.CoreMatchers.*;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.Mockito;
import org.mockito.runners.MockitoJUnitRunner;
import android.content.Context;
@RunWith(MockitoJUnitRunner.class)
public class Mock_tests {
private static final String FAKE_CONNECED_STRING = "Connected as";
@Mock
Context mMockContext;
@Before
public void before(){
Mockito.when(mMockContext.getString(R.string.connected_as))
.thenReturn("Connected as");
}
@Test
public void checkHeaderString() {
assertThat("Connected as", is(FAKE_CONNECED_STRING));
}
}
I'm getting: 我越来越:
java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.content.res.Resources.getString(int)' on a null object reference
at android.content.Context.getString(Context.java:476)
at com.matala3.me.matala3.ExampleInstrumentedTest.before(ExampleInstrumentedTest.java:26)
at java.lang.reflect.Method.invoke(Native Method)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:24)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
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.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.mockito.internal.runners.JUnit45AndHigherRunnerImpl.run(JUnit45AndHigherRunnerImpl.java:37)
at org.mockito.runners.MockitoJUnitRunner.run(MockitoJUnitRunner.java:62)
at org.junit.runners.Suite.runChild(Suite.java:128)
at org.junit.runners.Suite.runChild(Suite.java:27)
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.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
at org.junit.runner.JUnitCore.run(JUnitCore.java:115)
at android.support.test.internal.runner.TestExecutor.execute(TestExecutor.java:58)
at android.support.test.runner.AndroidJUnitRunner.onStart(AndroidJUnitRunner.java:375)
at android.app.Instrumentation$InstrumentationThread.run(Instrumentation.java:1932)
This statement : 这个说法 :
Mockito.when(mMockContext.getString(R.string.connected_as))
.thenReturn("Connected as");
provokes this exception : 引发此异常:
java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.content.res.Resources.getString(int)' on a null object reference
java.lang.NullPointerException:尝试在空对象引用上调用虚拟方法'java.lang.String android.content.res.Resources.getString(int)'
because mMockContext
is null
. 因为
mMockContext
为null
。
It means that the mocking initialization was not performed here : 这意味着此处未执行模拟初始化:
@Mock
Context mMockContext;
I tested on my machine with Eclipse and Maven and I have the expected behavior : the mock is correctly initialized. 我在Eclipse和Maven的机器上进行了测试,并且具有预期的行为:模拟已正确初始化。
I could not explain the cause but I suspect a side effect with some classes or the way which you run the test (IDE maybe ?). 我无法解释原因,但我怀疑某些类或您运行测试的方式会产生副作用(可能是IDE?)。
This first call : 第一个电话:
android.app.Instrumentation$InstrumentationThread.run(Instrumentation.java:1932)
android.app.Instrumentation $ InstrumentationThread.run(Instrumentation.java:1932)
refers to an instrumented test, that is, with device/emulator aware while you didn't write a instrumented test as you mock device features. 指的是经过测试的测试,也就是说,当您在模拟设备功能时没有编写经过测试的设备时,设备/仿真器可以感知。
So as advice : you could check you don't have configuration or dependencies that enable the instrumentation and try to execute it from command line to ensure that it is not a IDE issue. 因此,建议:您可以检查是否没有启用检测的配置或依赖项,并尝试从命令行执行以确保它不是IDE问题。
If you are using Mockito 2.x, the org.mockito.runners.MockitoJUnitRunner
is deprecated and org.mockito.junit.MockitoJUnitRunner
should be used. 如果使用的是Mockito 2.x,
org.mockito.runners.MockitoJUnitRunner
使用org.mockito.runners.MockitoJUnitRunner,而应使用org.mockito.junit.MockitoJUnitRunner
。
If problem still exists you could initialize the @Mocks
by adding this the @Before
method: 如果问题仍然存在,你可以初始化
@Mocks
加入这个@Before
方法:
@Before
public void before(){
MockitoAnnotations.initMocks(this);
Mockito.when(mMockContext.getString(R.string.connected_as))
.thenReturn("Connected as");
}
Update : 更新 :
I looked a bit at the Context.getString(int) javadocs and it is a final method. 我看了一下Context.getString(int) javadocs,这是一个最终方法。 There is not out-of-the-box support for mocking that kind of methods in Mockito.
在Mockito中没有开箱即用的模拟这种方法的支持。
You would need to use a special plugin , or Powermock which is also explained on that link. 您将需要使用特殊的插件或Powermock,该插件也在该链接上进行了说明。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.