当前位置: 首页 > 面试题库 >

如何用相同的参数验证相同的模拟方法的调用,该参数会改变模拟中调用之间的状态?

宁飞宇
2023-03-14
问题内容

我有以下代码要进行单元测试:

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。如果您设置为间谍,则可以验证该对象上