我正在尝试设置最小起订量对象以针对使用 EF6 的业务层对象运行一些单元测试。 到目前为止,我可以测试简单的方法调用并检查是否调用了这些方法。但是,有没有一种方法可以测试对象是否实际插入到基础集合中。
这是我的模拟方法
private Mock<DbSet<T>> CreateMockDbSet<T>(IQueryable<T> entities) where T : class
{
var mockSet = new Mock<DbSet<T>>();
mockSet.As<IQueryable<T>>().Setup(m => m.Provider).Returns(entities.Provider);
mockSet.As<IQueryable<T>>().Setup(m => m.Expression).Returns(entities.Expression);
mockSet.As<IQueryable<T>>().Setup(m => m.ElementType).Returns(entities.ElementType);
mockSet.As<IQueryable<T>>().Setup(m => m.GetEnumerator()).Returns(entities.GetEnumerator());
IList<T> list = entities as IList<T>;
mockSet.As<IList<T>>().Setup(m => m.Add(It.IsAny<T>())).Returns(list.Add(It.IsAny<T>()));
mockSet.Setup(m => m.Include(It.IsAny<string>())).Returns(mockSet.Object);
return mockSet;
}
我试图从列表中模拟实际的 Add
方法,但正如上面所写的那样,没有方法 .Return
。
这可能吗?
我需要验证对象是否在某些逻辑发生后插入到我的模拟集合中。
最佳答案
IList.Add
方法返回 void
所以你不能设置返回,而是使用 .Callback
mockSet.As<IList<T>>()
.Setup(m => m.Add(It.IsAny<T>()))
.Callback<T>(item => list.Add(item));
或使用Capture.In
mockSet.As<IList<T>>()
.Setup(m => m.Add(Capture.In(list)));
关于c# - 使用 Moq 模拟 IList.Add,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55785701/