我正在尝试设置一个模拟对象,以便它只是将输入变量之一回显给调用者。
_resultThrottler = new Mock<IResultThrottler>();
_resultThrottler
.Setup(x => x.Throttle(It.IsAny<IEnumerable<ProductResult>>(), It.IsAny<Guid>()))
.Returns((IEnumerable<ProductResult> input, Guid resultSetId) => input );
但是,当它实际被调用时,输出始终为空。
var throttledResults = _resultThrottler.Throttle(results, resultSetId).ToList();
我可能做错了什么?
编辑:根据要求:
public interface IResultThrottler
{
IEnumerable<TType> Throttle<TType>(IEnumerable<TType> collectionToThrottle,
Guid sessionId) where TType : ProductResult;
}
变量results
的完整初始化序列相当复杂,但在测试中,它作为长度为 5 的 System.Collections.Generic<IEnumerable<(type that inherits from ProductResult)>>
类型的对象进入,并从长度为零的模拟对象中出来。
似乎 Moq 不喜欢我试图使用继承的类型而不是实际的特定类型来模拟。
我已经移动了代码以采用类型参数 -
public class ResultThrottlerStubBuilder<TType> where TType : ProductResult
{
private Mock<IResultThrottler> _resultThrottler;
public IResultThrottler Build()
{
_resultThrottler = new Mock<IResultThrottler>();
_resultThrottler
.Setup(x => x.Throttle(It.IsAny<IEnumerable<TType>>(), It.IsAny<Guid>()))
.Returns((IEnumerable<TType> input, Guid resultSetId) => input );
return _resultThrottler.Object;
}
}
并更改了测试代码以匹配,测试现在通过。 感谢评论者将我的想法推向正确的方向:-(