使用Moq进行单元测试并设置GetAll包含
问题描述:
我有最小订单量这个奇怪的问题,我不能使用GetAll('include')方法来测试我的控制器。使用Moq进行单元测试并设置GetAll包含
我的测试初始化
// GetAll
menusDb.Setup(m => m.GetAll()).Returns(menus.AsQueryable());
menusDb.Setup(m => m.GetAll(It.IsAny<Expression<Func<Menu, object>>>()))
.Returns((Expression<Func<Menu,object>> pred) => {
return menus.AsQueryable();
});
// FindByIdAsync
menusDb.Setup(m => m.FindByByIdAsync(It.IsAny<int>()))
.Returns((int x) => Task.FromResult(menus.Find(m => m.ID == x)));
menusDb.Setup(m => m.FindByByIdAsync(It.IsAny<int>(), It.IsAny<Expression<Func<Menu, object>>[]>()))
.Returns((int x, Expression<Func<Menu,
object>>[] includeProperties) => Task.FromResult(menus.Find(m => m.ID == x)));
现在,每当我试图测试
_menusDB.GetAll(s=>s.Sections)
menusdb.getAll的MOQ()方法,是不是在所有
所有其他的起订量解雇方法正确触发... 示例
_menusDB.GetAll();
_menusDB.FindByByIdAsync(id,
m => m.Sections.Select(s => s.Image),
m => m.Sections.Select(s => s.MenuItems.Select(mi => mi.Image)));
这些都是Getall,并且在我的通用资源库中使用include查找函数。
public IQueryable<TEntity> GetAll<TProperty>(Expression<Func<TEntity, TProperty>> propertyToInclude) {
return ObjectSet.Include(propertyToInclude);
}
public async Task<TEntity> FindByByIdAsync(int id, params Expression<Func<TEntity, object>>[] propertiesToInclude) {
var query = propertiesToInclude.Aggregate(ObjectSet as IQueryable<TEntity>, (current, property) => current.Include(property));
return await query.SingleOrDefaultAsync(entity => entity.ID == id).ConfigureAwait(false);
}
答
我终于发现问题在哪里。 GetAll with include使用通用TProperty而不是对象来包含属性。模拟不知何故将Tproperty对象与我在测试中提供的linq查询联系起来。也许有一种方法可以使它工作,但现在我只是将通用属性更改为对象