争论的Mockito匹配器(如any
,argThat
,eq
,same
,和ArgumentCaptor.capture()
)表现非常不同,从Hamcrest匹配器.
Mockito匹配器经常导致InvalidUseOfMatchersException,即使在使用任何匹配器后执行很长时间的代码中也是如此.
Mockito匹配器受到奇怪的规则的影响,例如,如果给定方法中的一个参数使用匹配器,则只需要对所有参数使用Mockito匹配器.
当覆盖Answer
s或使用(Integer) any()
等时,Mockito匹配器可能会导致NullPointerException .
使用Mockito匹配器以某种方式重构代码可能会产生异常和意外行为,并且可能完全失败.
为什么Mockito匹配器是这样设计的,它们是如何实现的?
我有一个Foo
方法接口int Foo.bar(int)
,我想用Mockito模拟.99
如果我传入,我希望模拟的方法返回1
,但所有其他值将抛出异常.我可以这样做吗?
final Foo foo = mock(Foo.class);
when(foo.bar(1)).thenReturn(99);
when(foo.bar(anyInt())).thenThrow(new IllegalArgumentException());
Run Code Online (Sandbox Code Playgroud)
换句话说,1
优先考虑anyInt()
?我不希望它抛出异常1
.该文档说,对于多个定义,最后的定义是比较重要的,但我不能告诉这是否意味着对于相同的参数或没有.如果它适用于此,我是否需要先定义通配符anyInt()
?或者两者甚至有任何关系,因为其中一个是匹配器而另一个只是一个值?