【发布时间】:2011-12-01 20:46:12
【问题描述】:
这将是一个简单的问题,但如果我的类路径中包含两个库,我找不到它们之间的区别以及使用哪一个?
【问题讨论】:
这将是一个简单的问题,但如果我的类路径中包含两个库,我找不到它们之间的区别以及使用哪一个?
【问题讨论】:
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(或 Mockito 2 中的 org.mockito.hamcrest.MockitoHamcrest.argThat)。它将 Hamcrest 匹配器转换为 Mockito 匹配器。因此,假设您想以某种精度(但不多)匹配双精度值。在这种情况下,您可以这样做:
when(mockFoo.getBarByDouble(argThat(is(closeTo(1.0, 0.001))))).
thenReturn(mockBar);
【讨论】:
Matchers 一起使用的 argThat 重载已移动 MockitoHamcrest。 What's new in Mockito 2 在其“与 1.10 不兼容的更改”部分中对此进行了讨论。