2

A 有一个具有典型场景数据访问层 (DAL) 的应用程序:

  • 使用实体框架 (EF) 创建的数据上下文。
  • 使用由 EF 生成的实体,用作整个应用程序的通用 DTO。
  • DAL 包含扩展 RepositoryBase 抽象类的不同存储库,该抽象类实现基本的 CRUD 操作;特定的存储库对其实体类型只有特定的方法。可以软删除的实体的存储库扩展了 SoftDeleteRepositoryBase,它本身扩展了 RepositoryBase。

为了给出一些上下文,这里有一些类/接口。

通用存储库接口:

public interface IRepository<T> : IDisposable where T : class
{
    void Add(T entity);
    void Update(T entity);
    void Obliterate(T entity);
    void Obliterate(Expression<Func<T, bool>> where);
    T GetById(long id);
    T GetById(string id);
    IQueryable<T> GetAll();
    IQueryable<T> GetMany(Expression<Func<T, bool>> where);
    T GetSingle(Expression<Func<T, bool>> where);
    void SaveChanges();
}

存储库基础:

public abstract class RepositoryBase<T> : IRepository<T> where T : class
{
    ...
}

Foo 实体的存储库:

public class FooRepository : RepositoryBase<File>, IFooRepository
{
    // Specific methods here
    ...
}

我应该如何测试存储库?现在我为每个存储库都有一个测试类,测试方法在所有存储库中都非常相似,因为它们主要测试来自 RepositoryBase 的通用方法。很明显,我需要针对特定​​方法进行测试,但是对于全局通用方法,我应该继续针对每个不同的实体进行测试吗?我不知道假设如果插入例如适用于 Foo 实体它也适用于其他实体是否明智;但是,在测试创建和维护方面,对每个测试都有额外的开销。你能推荐任何关于这个的最佳实践吗?

(顺便说一下,这些是集成测试)

谢谢

4

1 回答 1

2

我不知道假设如果插入例如适用于 Foo 实体它也适用于其他实体是否明智

不,你不能假设这一点。如果某些实体没有正确的映射怎么办?如果您忘记定义DbSet<Bar>您的DbContext? 如果您想完全确定,您应该测试所有具体存储库的所有方法。

但是,在测试创建和维护方面,对每个测试都有额外的开销

正确的。这就是为什么不要只为存储库编写集成测试,而是为您的应用程序编写验收测试。您将练习整个堆栈,并将涉及具体的存储库。

于 2013-06-19T17:35:36.317 回答