这将是一个简单的问题,但如果我的类路径中包含两个库,我找不到它们之间的区别以及使用哪一个?
问问题
30702 次
1 回答
99
Hamcrest 匹配器方法返回Matcher<T>
,Mockito 匹配器返回 T。因此,例如:org.hamcrest.Matchers.any(Integer.class)
返回 的实例org.hamcrest.Matcher<Integer>
,并org.mockito.Matchers.any(Integer.class)
返回 的实例Integer
。
这意味着您只能Matcher<?>
在签名中需要一个对象时使用 Hamcrest 匹配器 - 通常是在assertThat
调用中。在调用模拟对象的方法的地方设置期望或验证时,使用 Mockito 匹配器。
例如(为清楚起见,使用完全限定名称):
@Test
public void testGetDelegatedBarByIndex() {
Foo mockFoo = mock(Foo.class);
// inject our mock
objectUnderTest.setFoo(mockFoo);
Bar mockBar = mock(Bar.class);
when(mockFoo.getBarByIndex(org.mockito.Matchers.any(Integer.class))).
thenReturn(mockBar);
Bar actualBar = objectUnderTest.getDelegatedBarByIndex(1);
assertThat(actualBar, org.hamcrest.Matchers.any(Bar.class));
verify(mockFoo).getBarByIndex(org.mockito.Matchers.any(Integer.class));
}
如果您想在需要 Mockito 匹配器的上下文中使用 Hamcrest 匹配器,您可以使用org.mockito.Matchers.argThat
(或org.mockito.hamcrest.MockitoHamcrest.argThat
在Mockito 2中)。它将 Hamcrest 匹配器转换为 Mockito 匹配器。因此,假设您想以某种精度(但不多)匹配双精度值。在这种情况下,您可以这样做:
when(mockFoo.getBarByDouble(argThat(is(closeTo(1.0, 0.001))))).
thenReturn(mockBar);
于 2011-12-02T02:26:33.073 回答