我有以下方法希望验证其行为。
public void methodToTest(Exception e, ActionErrors errors) {
...
errors.add("exception.message",
ActionMessageFactory.createErrorMessage(e.toString()));
errors.add("exception.detail",
ActionMessageFactory.createErrorMessage(e.getStackTrace()[0].toString()));
...
}
在我的@Test 类(class)中,我希望做这样的事情来验证 errors.add()
是用“exception.message”调用的,然后又是用“exception.detail”调用的
verify(errors).add(eq("exception.message"), any(ActionError.class));
verify(errors).add(eq("exception.detail"), any(ActionError.class));
然而 Mockito 提示如下
Argument(s) are different! Wanted:
actionErrors.add(
"exception.message",
<any>
);
Actual invocation has different arguments:
actionErrors.add(
"exception.detail",
org.apache.struts.action.ActionError@38063806
);
如何让 Mockito 检查这两个值?
最佳答案
进一步阅读使我尝试使用 ArgumentCaptors 和以下作品,尽管比我想要的要冗长得多。
ArgumentCaptor<String> argument = ArgumentCaptor.forClass(String.class);
verify(errors, atLeastOnce()).add(argument.capture(), any(ActionMessage.class));
List<String> values = argument.getAllValues();
assertTrue(values.contains("exception.message"));
assertTrue(values.contains("exception.detail"));
关于java - 如何验证具有不同参数的多个方法调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8504074/