最小起订量以回显 IEnumerable 返回空



我正在尝试设置一个模拟对象,以便它只是将输入变量之一回显给调用者。

_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;
    }
}

并更改了测试代码以匹配,测试现在通过。 感谢评论者将我的想法推向正确的方向:-(

最新更新