如何使用rhino mocks测试异步查询

时间:2015-09-09 07:54:59

标签: c# entity-framework unit-testing rhino-mocks iqueryable

以下是我的功能

 public async Task<IEnumerable<Books>> GetAsync(Guid customerId) {
        var BookList= await _bookStore.FindBy(AnExpression(customerId)).ToListAsync();
        return vehicleList;
    }

我试图模拟返回IQueryable的_bookStore.FindBy()方法

  var Books= new List<Books>(2){
                new Books(),
                new Books()
            }.AsQueryable();

 mock.Expect(viewStore => viewStore.FindBy(Arg<Expression<Func<Books, bool>>>.Is.Anything)).Return(Books);

viewStore是一个界面:

public interface IRepository<T> : IDisposable where T : class
{
    IQueryable<T> FindBy(Expression<Func<T, bool>> predicate);
}

我收到以下错误

System.InvalidOperationException:源IQueryable没有实现IDbAsyncEnumerable。只有实现IDbAsyncEnumerable的源才能用于实体框架异步操作

我尝试实现像https://msdn.microsoft.com/en-us/data/dn314429#async

这样的AsyncQueryProvider

但是Moq没有使用Rhino mock显示实现。

1 个答案:

答案 0 :(得分:3)

您必须使用已在您提供的链接中实施的TestDbAsyncEnumerable

替换:

var Books= new List<Books>(2){
            new Books(),
            new Books()
        }.AsQueryable();

mock.Expect(viewStore => viewStore.FindBy(Arg<Expression<Func<Books, bool>>>.Is.Anything))
    .Return(Books);

使用:

var Books = new List<Books>(2){
            new Books(),
            new Books()
        }.AsQueryable();

var asycEnumarable = new TestDbAsyncEnumerable<Books>(Books);

var viewStore = MockRepository.GenerateStub<IRepository<Books>>();

viewStore.Stub(x => x.FindBy(Arg<Expression<Func<Books, bool>>>.Is.Anything))
         .Return(asycEnumarable);