使用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查询联系起来。也许有一种方法可以使它工作,但现在我只是将通用属性更改为对象