考虑以下情况,在这里我正在测试注入依赖项的方法被称为特定次数:

[Fact]
public void WhenBossTalksEmployeeBlinksTwice()
{
    // arrange
    var employee = new Mock<IEmployee>();
    employee.Setup(e => e.Blink());

    var boss = new Boss(employee.Object);

    // act
    boss.Talk();

    // assert
    employee.Verify(e => e.Blink(), Times.Exactly(2)); // Passes as expected
    employee.Verify(e => e.Blink(), Times.Exactly(1)); // Fails as expected
}


当我强制测试失败时,输出为:


Moq.MockException:1次未对模拟执行调用:e
=> e.Blink()


最好是这样的:


Moq.MockException:调用意外地执行了2次,而不是1次:e
=> e.Blink()


以下是与测试有关的项目:

public interface IEmployee { void Blink(); }

public class Boss {
    private readonly IEmployee _employee;
    public Boss(IEmployee employee) { _employee = employee; }

    public void Talk() {
        _employee.Blink();
        _employee.Blink();
    }
}


是否可以在失败的测试的错误消息中收集并显示调用依赖项方法的实际次数?

我不确定是否很重要,但是我正在使用Moq v3.1.416.3(我知道不是最新的,但是我正在使用的另一个库尚未更新到Moq 4.x ...)

最佳答案

我不知道在Moq3中收集信息的直接方法。
我要做的是在Blink的设置上使用回调

int count = 0;
employee.Setup(e => e.Blink()).Callback(() => count++);

...
employee.Verify(e => e.Blink(), Times.Exactly(1), "Moq.MockException: Invocation was unexpectedly performed " + count + " times, not 1 time: e => e.Blink()"); // Fails as expected

关于unit-testing - 使用Moq Verify()方法调用计数时,测试失败的错误消息包含使用Moq的实际方法调用计数,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/16693078/

10-13 21:27