带有函数参数的接口的最小起订量设置
Moq setup for interface with function argument
我想用 Moq 4.14.7 编写单元测试。待测方法如下:
public IFoo Get(Guid id)
{
Func<IFoo> getData = () => _repository.Get(id);
if (_cache.TryGetAndSet(vaultId, getData, out var result))
{
return result;
}
}
简单说明一下。我有一个通用缓存 class。它检查缓存中是否存在具有传递的 guid 的实体。如果不是这种情况,则调用存储库。
现在我对缓存进行了以下设置:
_cache.Setup
(
x => x.TryGetAndSet
(
_vaultId,
It.IsAny<Func<IFoo>>(),
out foo
)
)
.Returns(true);
到目前为止测试有效,但我没有用它达到 100% 的覆盖率,因为 func 没有被覆盖。
这里有比使用 It.IsAny
并获得 100% 覆盖率更好的方法吗?
捕获传递给成员的参数并根据需要调用函数。
//...
IFoo mockedFoo = Mock.Of<IFoo>();
IFoo foo = null;
_repo.Setup(_ => _.Get(It.IsAny<Guid>()).Returns(mockedFoo);
_cache
.Setup(_ => _.TryGetAndSet(It.IsAny<Guid>(), It.IsAny<Func<IFoo>>(), out foo))
.Returns((Guid vid, Func<IFoo> func, IFoo f) => {
foo = func(); //<-- invoke the function and assign to out parameter.
return true;
});
//...
//Assertion can later verify that the repository.Get was invoked
//Assertion can later assert that foo equals mockedFoo
TryGetAndSet
将 return true
,out 参数将 return mockedFoo,惰性计算
我想用 Moq 4.14.7 编写单元测试。待测方法如下:
public IFoo Get(Guid id)
{
Func<IFoo> getData = () => _repository.Get(id);
if (_cache.TryGetAndSet(vaultId, getData, out var result))
{
return result;
}
}
简单说明一下。我有一个通用缓存 class。它检查缓存中是否存在具有传递的 guid 的实体。如果不是这种情况,则调用存储库。
现在我对缓存进行了以下设置:
_cache.Setup
(
x => x.TryGetAndSet
(
_vaultId,
It.IsAny<Func<IFoo>>(),
out foo
)
)
.Returns(true);
到目前为止测试有效,但我没有用它达到 100% 的覆盖率,因为 func 没有被覆盖。
这里有比使用 It.IsAny
并获得 100% 覆盖率更好的方法吗?
捕获传递给成员的参数并根据需要调用函数。
//...
IFoo mockedFoo = Mock.Of<IFoo>();
IFoo foo = null;
_repo.Setup(_ => _.Get(It.IsAny<Guid>()).Returns(mockedFoo);
_cache
.Setup(_ => _.TryGetAndSet(It.IsAny<Guid>(), It.IsAny<Func<IFoo>>(), out foo))
.Returns((Guid vid, Func<IFoo> func, IFoo f) => {
foo = func(); //<-- invoke the function and assign to out parameter.
return true;
});
//...
//Assertion can later verify that the repository.Get was invoked
//Assertion can later assert that foo equals mockedFoo
TryGetAndSet
将 return true
,out 参数将 return mockedFoo,惰性计算