我花了最后的时间抽出头发试图在测试中发现问题,最终发现这与模拟采用原始参数的方法有关。这是一个演示该问题的样本测试:

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()

问题:
  • 有人知道如何解决此错误吗?
  • 如果可以重现此内容,是否可以从堆栈跟踪中获取更多信息?
  • 最佳答案

    您应该匹配长时间不匹配任何对象的匹配器:

    verify(foo, times(1)).causeProblems(anyLong());
    

    我检查了它是否可以正常运行。

    09-10 17:04