我们可以使用ArgumentCaptor来检查Mockito中的日志消息吗



我在ATG中有一个表单处理程序,具有以下处理方法-

    public boolean handleFindCards(DynamoHttpServletRequest pRequest, DynamoHttpServletResponse pResponse)
        throws IOException, ServletException {
    Card card = cardService.getCard();
    if (card == null) {
         if (isLoggingError()) {
             logError("Card Service is null");
         }
    } else {
        // Other code
    }
    return checkFormRedirect(getSuccessURL(), getSuccessURL(), pRequest, pResponse);
}

表单处理程序正在使用它的一个超类GenericService中的日志记录。我想写一个测试来检查cardService是否为null。在上面的代码中,当卡服务为null时,它会使用logError写入一条错误消息。我们可以在这里使用ArgumentCaptor来验证消息吗。或者有其他方法来测试这种情况吗?

在这里,嘲笑和间谍将如何协同工作?我应该将获取卡对象的调用存根为-

when(cardServiceMock.getCard()).thenReturn(cardMock);

这是我的测试方法-

    @Test
    public void testHandleCardServiceIfCardIsNull() throws IOException, ServletException {
        CardService cardServiceMock = mock(CardService.class);
        when(cardServiceMock.getCard()).thenReturn(null);
        CardOperationsFormHandler testObjSpy = spy(new CardOperationsFormHandler());
        testObjSpy.handleFindCards(requestMock, responseMock);
        ArgumentCaptor<String> argumentCaptor = ArgumentCaptor.forClass(String.class);
        Mockito.verify(testObjSpy).logError(argumentCaptor.capture());
        Assert.assertEquals(argumentCaptor.getValue(), "Card Service is null");
    }

谢谢。

正如David Wallace所说,您需要使用Mockito.spy(T object)

所以用一个简单的方法:

public void runArgumentCaptor() {
    logError("This is an error");
}

测试可以是这样的:

    @Spy @InjectMocks private SomeClassName testObj;
    @Test(groups = { "unit" })
    public void runArgumentCaptorTest() throws Exception {
        testObj.runArgumentCaptor();
        ArgumentCaptor<String> argumentCaptor = ArgumentCaptor.forClass(String.class);
        Mockito.verify(testObj).logError(argumentCaptor.capture());
        Assert.assertEquals(argumentCaptor.getValue(), "This is an error");
    }

[EDIT]添加了testObj的声明。注意附加的@Spy。还更新了测试方法。

现在可以工作了。正如radimpe所说,我已经用间谍取代了mock。所以,我在这里创建cardServiceSpy而不是cardServiceMock,然后使用存根。此外,需要使用doReturn进行存根处理。这是方法-

    @Test
    public void testHandleCardServiceIfCardIsNull() throws IOException, ServletException {
        CardService cardServiceSpy = spy(new CardService());
        doReturn(null).when(cardServiceSpy).getCard();
        CardOperationsFormHandler testObjSpy = spy(new CardOperationsFormHandler());
        testObjSpy.handleFindCards(requestMock, responseMock);
        ArgumentCaptor<String> argumentCaptor = ArgumentCaptor.forClass(String.class);
        Mockito.verify(testObjSpy).logError(argumentCaptor.capture());
        Assert.assertEquals(argumentCaptor.getValue(), "Card Service is null");
    }

相关内容

  • 没有找到相关文章

最新更新