java – 在Mockito中调用实际方法,但拦截结果

前端之家收集整理的这篇文章主要介绍了java – 在Mockito中调用实际方法,但拦截结果前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

简化一下,我们的系统有两个部分. “我们的”部分,反过来使用由另一个团队(在相同的代码库中)实现的较低级别部分.我们有一个相当复杂的功能测试设置,我们将入口点包装在间谍对象的较低层.在积极的测试中,我们使用该级别的实际实现,但是我们模拟了应该因某些预定义错误而失败的调用.

现在我正在尝试添加对更复杂场景的支持,我想为基础级别的调用添加一个人工延迟(显然是假的时钟).为此,我想定义一个模拟,它将(1)调用实际实现(2)获取返回的结果Future对象,并将其与自定义函数相结合,该函数将相应地注入延迟.所以理想情况下我希望有类似的东西:

doAnswer(invocationOnMock -> 
    { 
      result = call real method on mySpy; 
      return Futures.combile(result,myFunction);
    }).when(mySpy).myMethod();

我怎样才能实现它?

最佳答案
至于我,最简单的方法就是在初始化Spy对象时保存读取对象的链接

Foo realFoo = new Foo();
Foo spyFoo = Mockito.spy(realFoo);

现在你可以像这样存根:

doAnswer(invocation -> realFoo.getSome() + "spyMethod").when(spyFoo).getSome();

另一种方法调用invocation.callRealMethod():

doAnswer(invocation -> invocation.callRealMethod() + "spyMethod").when(spyFoo).getSome();

但在这种情况下,只要invocation.callRealMethod()返回Object,您可能需要转换返回值.

猜你在找的Java相关文章