Mockito与通用方法



我试图用mockito在我的类上模拟一个泛型方法,但是当测试代码运行时,我总是得到一个NullPointerException。

这就是我想模拟的班级。

public abstract class MyClass{
      public abstract <T> T find(T t);
}

我的测试代码看起来像这样。

@Mock private MyClass myClass;
public testOnReceive(){
             Mockito.when(
                myClass.find(Mockito.isA(BroadcastReceiver.class))).
                thenReturn(broadcastReceiver);
                myReceiver.onReceive(context,intent);
}

最后,我尝试测试的类是BroadcastReceiver类的扩展,这就是我要测试的代码

public class MyReceiver extendes BroadcastReceiver{
       public onReceive(Context context , Intent intent){
             ...
             ...
             myClass.find(this);
       }
}

问题在于对班级的嘲笑。该类实际上被嘲笑(它不是空的),但是当调用泛型方法时,我得到一个空。

有什么想法吗?

谢谢

这是一个应该适合您的解决方案,即使您有部分模拟(即对于某些方法,您希望调用真正的方法,而有时您希望模拟):

public class AbstractMethodMocker implements Answer<Object> {
    @Override
    public Object answer(InvocationOnMock invocation) throws Throwable
    {
        Answer<Object> answer;
        if (isAbstract(invocation.getMethod().getModifiers()))
            answer = RETURNS_DEFAULTS;
        else
            answer = CALLS_REAL_METHODS;
        return answer.answer(invocation);
    }
}
@Test
public void testOnReceive() {
    MyClass clazz = mock(MyClass.class, new AbstractMethodMocker());
    when(clazz.find(any(BroadcastReceiver.class)).thenReturn(broadcastReceiver);
    myReceiver.onReceive(context, intent);
}

这是一个很棒的博客,讨论了使用 Mockito 框架处理抽象类(及其方法)的策略。

我的解决方案类似于 Tim 的建议,但使用了不同类型的 Answer 对象。虽然我不完全明白为什么,但对我有用的是以下内容。

MyClass myClass = Mockito.mock(MyClass.class , Mockito.RETURNS_DEEP_STUBS);

之后,我不需要指定有关何时调用该方法的任何内容。

相关内容

  • 没有找到相关文章