我有以下代码要进行单元测试:
public void foo() {
Entity entity = //...
persistence.save(entity);
entity.setDate(new Date());
persistence.save(entity);
}
我想,以验证上的第一次调用persistence.save
entity.getDate()
返回null
。
因此,我无法使用,Mockito.verify(/*...*/)
因为那时该方法foo
已经完成entity.setDate(Date)
并被调用。
因此,我认为我需要在调用发生时已经对调用进行验证。如何使用Mockito做到这一点?
我创建了以下Answer
实现:
public class CapturingAnswer<T, R> implements Answer<T> {
private final Function<InvocationOnMock, R> capturingFunction;
private final List<R> capturedValues = new ArrayList<R>();
public CapturingAnswer(final Function<InvocationOnMock, R> capturingFunction) {
super();
this.capturingFunction = capturingFunction;
}
@Override
public T answer(final InvocationOnMock invocation) throws Throwable {
capturedValues.add(capturingFunction.apply(invocation));
return null;
}
public List<R> getCapturedValues() {
return Collections.unmodifiableList(capturedValues);
}
}
此答案捕获正在进行的调用的属性。然后capturedValues
可以将其用于简单的断言。该实现使用Java 8
API。如果那不可用,则需要使用能够将转换InvocationOnMock
为捕获值的接口。测试用例中的用法是这样的:
@Test
public void testSomething() {
CapturingAnswer<Void,Date> captureDates = new CapturingAnswer<>(this::getEntityDate)
Mockito.doAnswer(captureDates).when(persistence).save(Mockito.any(Entity.class));
service.foo();
Assert.assertNull(captureDates.getCapturedValues().get(0));
}
private Date getEntityDate(InvocationOnMock invocation) {
Entity entity = (Entity)invocation.getArguments()[0];
return entity.getDate();
}
Answer
通过Mockitos无法实现由所实现的捕获,ArgumentCaptor
因为这仅在调用被测方法之后使用。
问题内容: 设置如下: 显然,它被配置为返回一些值,并且确实是被嘲笑的。结果是:mockito抱怨我经常打给我(强调:NOT !),并且希望只打一次它! 以下更改有效: 我的问题很简单:这是怎么回事?为什么Mockito会验证对传递给函数的 参数 的调用,而不是对函数本身的调用? 问题答案: 正如我在评论中提到的那样,Mockito实际上以不直观的方式处于有状态状态。很多时候,存根或验证的方法
问题内容: 有没有一种方法可以使存根方法在后续调用中返回不同的对象?我想这样做是为了测试来自的不确定响应。即,不管方法的返回顺序如何进行测试,结果都保持恒定。 我要测试的代码看起来像这样。 问题答案: 你可以使用方法来做到这一点(与链接时): 或使用等效的静态doAnswer方法:
出于学校目的,我正在创建一个使用股票API的应用程序。 我正在尝试为一种获取过去10年所有股票数据的方法编写一个测试。我不想实际获取所有这些数据,而是想抛出一个异常。 我想测试的方法: 股票时间系列(....)调用可以抛出阿尔法仓位异常。 我这样嘲弄了TimeSeries类: 在我的测试类中,我想模拟这个调用,并返回一个异常而不是实际数据。 无论我多么试图嘲笑这段代码,它永远不会抛出异常。它将始终
我有一个方法,它被用作: 模拟遵循的方法如下: 选项1: 这甚至不工作,因为我认为只需要do返回工作,然后回答不会在这里工作。 选项 2: 获取运行时异常: 错误!Java . lang . runtime exception:org . mock ITO . exceptions . misusing . wrongtypeofrentvalue:ReturnsArgumentAt不能由getP
我有一些测试方法: 当我尝试运行此方法时,出现了异常: 我怎么能嘲弄这种方法呢?
问题内容: 似乎模拟仅验证模拟对象的方法是否被调用,并且模拟对象始终具有类似以下内容的东西 但是我可以创建一个模拟对象并定义 然后验证另一个对象的方法是否被调用吗? 这是我想做的事情:我定义了一个模拟环境,无论发生什么情况都返回一个响应。但是然后我想验证在不同情况下调用anotherObj的不同方法。 怎么做? 问题答案: 您可以为此使用Mockito Spy。如果您设置为间谍,则可以验证该对象上