我想这更像是一个集成测试,但是有没有人有一个关于如何测试以确保实体框架 (4) 模型中的关联按预期工作的好教程的链接?
我的想法是为此使用 sqllite 之类的东西,因为我想确保我可以保存一个实体,并添加一个子实体并保持它等等。
我想这更像是一个集成测试,但是有没有人有一个关于如何测试以确保实体框架 (4) 模型中的关联按预期工作的好教程的链接?
我的想法是为此使用 sqllite 之类的东西,因为我想确保我可以保存一个实体,并添加一个子实体并保持它等等。
如果您首先使用代码,则可以使用模拟框架来测试您的实现。
至于您可以在那里使用的 IDbSet 实例,以下内容很有用:
public class InMemoryDbSet<T> : IDbSet<T> where T : class
{
private readonly HashSet<T> _data;
private readonly IQueryable _query;
public Type ElementType
{
get
{
return this._query.ElementType;
}
}
public Expression Expression
{
get
{
return this._query.Expression;
}
}
public IQueryProvider Provider
{
get
{
return this._query.Provider;
}
}
public InMemoryDbSet()
{
this._data = new HashSet<T>();
this._query = _data.AsQueryable();
}
public T Add(T entity)
{
this._data.Add(entity);
return entity;
}
public T Attach(T entity)
{
this._data.Add(entity);
return entity;
}
public TDerivedEntity Create<TDerivedEntity>() where TDerivedEntity : class, T
{
throw new NotImplementedException();
}
public T Create()
{
return Activator.CreateInstance<T>();
}
public virtual T Find(params Object[] keyValues)
{
throw new NotImplementedException("Derive from FakeDbSet and override Find");
}
public System.Collections.ObjectModel.ObservableCollection<T> Local
{
get
{
return new System.Collections.ObjectModel.ObservableCollection<T>(_data);
}
}
public T Remove(T entity)
{
this._data.Remove(entity);
return entity;
}
public IEnumerator<T> GetEnumerator()
{
return this._data.GetEnumerator();
}
IEnumerator IEnumerable.GetEnumerator()
{
return this._data.GetEnumerator();
}
}
使用这种方法应该可以让您完全在内存中运行测试,而无需访问数据库,但是,正如我所说,仅在代码中优先,因为据我所知,IDbContext 仅用于那里。