我正在模拟类MockClass的对象,并在调用其中一个方法时使用when子句返回someClassObject(这是methodToBeTested内部的)。现在在下面的代码的最后一行,当我调用methodToBeTested时,我希望对someMethod的内部调用将成功运行。但是有一个nullPointerException发生在对someMethod的调用行中。为什么我的mockObject仍然为null?我正在使用@RunWith(MockitoJUnitRunner.class),这里有许多主题。
编辑:根据@Dawood,我用@InjectMocks MockClass mockObject替换了@Mock MockClass mockObject。我下面的输出是在更换之后。我的想法是someMethod没有在下面的行中执行。 当(mockObject.someMethod(ARG1,ARG2) 但它确实被执行了,我从它内部抛出异常。我在这里做错了什么,因为我只想模拟方法并定义它给出的输出而不是调用它
@RunWith(MockitoJUnitRunner.class)
public testClassToBeTested{
@Mock
MockClass mockObject;
@Before
public void setUp() throws Exception {
Whitebox.setInternalState(ClassToBeTested, "argumentName",
arg2);
}
@Test
public void methodToBeTested{
Class1 arg1 = new Class1();
Class1.setUserId("test");
//someMethod which is called within methodToBeTested
when(mockObject.someMethod(arg1,arg2).thenReturn(someClassObject));
ClassAnotherClass anotherClassObject = ClassToBeTested.methodToBeTested(arg1);
}
}
控制台输出:
java.lang.NullPointerException
at com.mycompany.utils.MockClass.someMethod(MockClass.java:36)
at com.mycompany.impl.ClassToBeTested.methodToBeTested(ClassToBeTested.java:21)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
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.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
at org.junit.rules.ExpectedException$ExpectedExceptionStatement.evaluate(ExpectedException.java:239)
at org.junit.rules.RunRules.evaluate(RunRules.java:20)
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.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:678)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)
答案 0 :(得分:0)
由于您的代码示例不完整而不是直接复制,因此有点难以辨别,并且您也没有粘贴NPE或其发生的行。机会是:
在这种情况下,您可以将@Inject放在类的构造函数上,并在测试中手动注入模拟,以确保。
如果模拟参数不匹配,或者模拟代码中有其他错误,则会发生这种情况。
在示例中,您没有正确模拟:
when(mockObject.someMethod(arg1,arg2).thenReturn(someClassObject));
应该是
when(mockObject.someMethod(arg1,arg2)).thenReturn(someClassObject);
注意括号中的更改