在我的单元测试中,我试图从我的接口Run()
模拟IPipeline
异步方法并模拟延迟,在类PipelineScheduler
中调用它
public interface IPipeline
{
Task Run();
}
我的测试:
[SetUp]
public void SetUp()
{
_mockPipeline = new Mock<IPipeline>();
_mockPipeline.Setup(x => x.Run()).Returns(async () =>
{
await Task.Delay(3000);
});
_scheduler = new PipelineScheduler(_mockPipeline.Object);
}
但是当我运行测试和调试时,调用模拟方法
await _pipeline.Run().ConfigureAwait(false);
没有延迟,立即在此行之后继续执行。
但是,如果我用存根类替换模拟,延迟工作正常。
private class MockPipeline : IPipeline
{
public async Task Run()
{
await Task.Delay(3000);
}
}
[SetUp]
public void SetUp()
{
_mockPipeline = new MockPipeline();
_scheduler = new PipelineScheduler(_mockPipeline);
}
所以我想这个问题与我如何用moq和我的存根类创建延迟有什么不同?
不同之处在于设置配置不正确。
返回一个任务,即:.Returns(Task.Delay(3000));
是设置表现所需的全部内容。之前的设置是火,忘了async void
这就是为什么前面的例子没有等待并立即继续。
以下最小示例演示了如何设置模拟
[TestClass]
public class MyTestClass {
[TestMethod]
public async Task MyTestMethod() {
//Arrange
var _mockPipeline = new Mock<IPipeline>();
_mockPipeline.Setup(x => x.Run()).Returns(Task.Delay(3000)).Verifiable();
var sut = new PipelineScheduler(_mockPipeline.Object);
//Act
await sut.MethodUnderTest();
//Assert
_mockPipeline.Verify();
}
}
public interface IPipeline {
Task Run();
}
public class PipelineScheduler {
private IPipeline _pipeline;
public PipelineScheduler(IPipeline pipeline) {
this._pipeline = pipeline;
}
public async Task MethodUnderTest() {
await _pipeline.Run().ConfigureAwait(false);
}
}
运行时,测试延迟配置3秒。