45

这将是一个简单的问题,但如果我的类路径中包含两个库,我找不到它们之间的区别以及使用哪一个?

4

1 回答 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.argThatMockito 2中)。它将 Hamcrest 匹配器转换为 Mockito 匹配器。因此,假设您想以某种精度(但不多)匹配双精度值。在这种情况下,您可以这样做:

when(mockFoo.getBarByDouble(argThat(is(closeTo(1.0, 0.001))))).
    thenReturn(mockBar);
于 2011-12-02T02:26:33.073 回答