我对NBuilder真的很陌生,但它看起来很棒,所以我想我会试一试。我有一个像这样DatabaseContext
继承的DbContext
:
public class DatabaseContext : DbContext
现在,我创建了一个DatabaseContext
像这样查询的服务:
public async Task<List<Strategy>> Handle(StrategyList query, CancellationToken cancellationToken)
{
return _databaseContext.Strategies.ToList();
}
现在我想做一个测试。我这样设置这个上下文:
public class StrategyListContext
{
public readonly DatabaseContext DatabaseContext;
private StrategyListContext()
{
DatabaseContext = CreateDatabaseContext();
}
private DatabaseContext CreateDatabaseContext()
{
var dbContext = Substitute.For<DatabaseContext>();
var items = Builder<Strategy>.CreateListOfSize(10).Build();
dbContext.Strategies.ToList().Returns(items);
return dbContext;
}
public static StrategyListContext GivenServices() => new StrategyListContext();
public StrategyListHandler WhenCreateHandler() => new StrategyListHandler(DatabaseContext);
}
最重要的部分是CreateDatabaseContext
方法。它是这样的:
private DatabaseContext CreateDatabaseContext()
{
var dbContext = Substitute.For<DatabaseContext>();
var items = Builder<Strategy>.CreateListOfSize(10).Build();
dbContext.Strategies.ToList().Returns(items);
return dbContext;
}
但是当我运行测试时,我得到了这个错误:
System.InvalidCastException:无法将“Castle.Proxies.ObjectProxy”类型的对象转换为“Microsoft.EntityFrameworkCore.Metadata.Internal.Model”类型。
有谁知道我能做些什么来让它工作?
所以我发现了这个问题: How do I mock DbContext using NSubstitute and then add/remove data
我已经将我的方法更改为:
private DatabaseContext CreateDatabaseContext()
{
var dbContext = Substitute.For<DatabaseContext>();
var items = Builder<Strategy>.CreateListOfSize(10).Build().AsQueryable();
var dbSet = Substitute.For<DbSet<Strategy>, IQueryable<Strategy>>();
((IQueryable<Strategy>)dbSet).Provider.Returns(items.Provider);
((IQueryable<Strategy>)dbSet).Expression.Returns(items.Expression);
((IQueryable<Strategy>)dbSet).ElementType.Returns(items.ElementType);
((IQueryable<Strategy>)dbSet).GetEnumerator().Returns(items.GetEnumerator());
dbContext.Set<Strategy>().Returns(dbSet);
return dbContext;
}
但我仍然得到同样的错误......