我花了最后一点时间试图在测试中找到问题,最终发现这与嘲笑一个使用原始参数的方法有关。下面是一个演示问题的示例测试:
import static org.mockito.Matchers.any;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.times;
import static org.mockito.Mockito.verify;
import org.junit.Test;
public class MockitoTest {
public static interface Foo {
public Object causeProblems(long arg);
}
@Test
public void testFoo() {
Foo foo = mock(Foo.class);
foo.causeProblems(123);
verify(foo, times(1)).causeProblems(any());
}
}
当运行这个测试时(我使用的是Mockito 1.10和Java8),由于某种原因,我的堆栈跟踪在verify
行上显示了一个NPE:
java.lang.NullPointerException
at com.amazon.jetstream.executor.worker.invoke.MockitoTest.testFoo(MockitoTest.java:19)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
....
我认为我的部分堆栈跟踪被抑制了(?)进一步挖掘它,如果我在Eclipse中运行它并"检查"行,我可以从中获得更多的信息,告诉我简单:
java.lang.NullPointerException at longValue()
问题:
- 有人知道如何解决这个错误吗
- 如果你能复制这个,你能从堆栈跟踪中获得更多信息吗
您应该匹配long而不是任何对象的matcher:
verify(foo, times(1)).causeProblems(anyLong());
我检查了它是否正常运行。