我正在尝试对我拥有的存储库进行定量,该存储库定义为:
public IQueryable<TEntity> GetAll(Expression<Func<TEntity, bool>> predicate = null, Func<IQueryable<TEntity>, IOrderedQueryable<TEntity>> orderBy = null, Func<IQueryable<TEntity>, IIncludableQueryable<TEntity, object>> include = null, bool disableTracking = true)
有没有办法模拟这个?我想使用我提供的回购数据来执行查询。我不确定如何告诉MOQ,当我调用GetAll时,我希望它仍然运行传入的查询,但是这样做可以消除我提供的数据集。因此它不会进入数据库,而是针对我配置的模拟集。我能够创建数据,它包含12条记录,但是我希望getall moq调用执行它的查询并将其过滤为仅应返回的2条。
呼叫发生的实际服务是:
var list = await _unitOfWork.GetRepository<CASE_ACTIVITY>().GetAll(predicate: x => x.SM_SITE_ID == siteId && x.CMS_USER_ID == userId
&& x.IS_DELETED == "N" && x.Appointment.IS_DELETED == "N" && x.Appointment.IS_ARCHIVED == "N" && x.IS_ARCHIVED == "N"
&& ((x.Appointment.APPOINTMENT_DATETIME.HasValue && x.Appointment.APPOINTMENT_DATETIME.Value.Date == DateTime.Today.Date)
|| (!x.Appointment.APPOINTMENT_DATETIME.HasValue && x.ACTIVITY_STATUS_ID == _appSettings.CASE_ACTIVITY_STATUS_ID_PENDING)))
.Include(x => x.Activity_Lookup).Include(x => x.Appointment).ThenInclude(x => x.Cms_Client).Include(x => x.Cms_Case)
.ToListAsync();
答案 0 :(得分:1)
假设您对GetRepository()
方法具有足够的控制权以使 it 返回您的模拟存储库,则模拟方法本身非常简单(如果有点冗长)。我只是将GetAll
方法转储到名为IRepository
的接口中,这就是模拟的样子。在Returns
方法内部,您可以随意访问要执行或忽略的每个参数。
var mock = new Moq.Mock<IRepository>();
mock.Setup(a => a.GetAll<int>(It.IsAny<Expression<Func<int, bool>>>(), It.IsAny<Func<IQueryable<int>, IOrderedQueryable<int>>>(), It.IsAny<Func<IQueryable<int>, IIncludableQueryable<int, object>>>(), It.IsAny<bool>()))
.Returns<Expression<Func<int, bool>>, Func<IQueryable<int>, IOrderedQueryable<int>>, Func<IQueryable<int>, IIncludableQueryable<int, object>>, bool>((param1, param2, param3, param4) =>
{
return new[] { 1, 2, 3 }.AsQueryable();
});
var result = mock.Object.GetAll<int>();
从这里开始,如果没有更多代码,我们将无济于事。不过,用抽象的术语来说,您将使用mock.Object
(类型为IRepository
)并将其提供给GetRepository()所引用的任何集合。当然,还请注意,我对通用参数使用了int -您将使用任何类型将其替换。可以制作一个接受通用参数的模拟程序,但希望没有必要!