测试时的努力问题

时间:2016-07-18 16:15:31

标签: c# .net entity-framework unit-testing

我一直在阅读使用Effort进行单元测试,因为在内存中设置数据库非常“简单”。我一直在尝试在我的测试数据服务中实现这一点,但我一直在遇到问题。 我正在使用Entity Framework 6和从现有表生成的模型。

上下文模型

public partial class Entities : DbContext
{
    public Entities()
        : base("name=Entities")
    {
    }

    //Overloading for effort unit test
    public Entities(DbConnection connection) : base(connection,true)
    {

    }

    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        //throw new UnintentionalCodeFirstException();
    }

    public virtual DbSet<REPAIR_CHECK_IN_TABLE> REPAIR_CHECK_IN_TABLEs { get; set; }
    public virtual DbSet<tblPlanarWarranty> tblPlanarWarranties { get; set; }
}

测试数据服务

private IDataLoader loader;
    private Entities context;


    public TestDataService()
    {

        loader = new Effort.DataLoaders.CsvDataLoader(@"_TestDataFiles\");
        context = new Entities(Effort.DbConnectionFactory.CreateTransient(loader));
    }

最初我会收到以下错误。

  

没有实体名称为'Effort.Provider'的ADO.NET提供程序的实体框架提供程序

然后我将所述提供程序添加到应用程序配置文件的提供程序部分,并开始收到此错误。

  

实体Framework提供程序类型'Effort.ProviderServices,Effort,Version-1.0.0.0的'Instance'成员没有返回继承自'System.Data.Entity.Core.Common.DBProviderServices'的对象

有没有人对我做错了什么有所了解?在网站上它就像几行一样容易,但这已经变成了一个巨大的混乱。

1 个答案:

答案 0 :(得分:0)

小心!使用EF6时,请勿安装 ZZZ Projects的努力

通过相同的ZZZ项目安装 Effort.EF6

class SchoolDbContext : DbContext
{
    // the standard constructors you probably already use:
    public SchooldDbContext() : base(...) {}
    public SchoolDbContext(string nameOrConnectionString) : base(nameOrConnectionString) {}

    // add this one for effort:
    public SchoolDbContext(DbConnection existingConnection, bool contextOwnsConnection) 
        : base(existingConnection, contextOwnsConnection) { }

    ... // DbSets, etc

使用干净的空数据库

var dbConnection = Effort.DbConnectionFactory.CreateTransient();
using (var dbContext = new SchoolDbContext(dbConnection, true)
{
      dbContext.Schools.Add(new School {...});
      dbConext.SaveChanges();

      // this database exists as long as the connection exists
      var schoolCount = dbContext.Schools.Count();
      // expect one school
}

// a new empty database will be created: there won't be any schools
dbConnection = Effort.DbConnectionFactory.CreateTransient();
using (var dbContext = new SchoolDbContext(dbConnection)
{
     var schoolCount = dbContext.Schools.Count();
     // expect no schools
}

重用数据库

该数据库将在您的程序执行期间保留。该模型只会蠕动一次。

const string dbName = "MyDb"
var dbConnection = Effort.DbConnectionFactory.CreatePersistent(dbName);
using (var dbContext = new SchoolDbContext(dbConnection)
{
      dbContext.Schools.Add(new School {...});
      dbContext.SaveChanges();
}

dbConnection = Effort.DbConnectionFactory.CreatePersistent(dbName);
using (var dbContext = new SchoolDbContext(dbConnection)
{
     var schoolCount = dbContext.Schools.Count();
     // expect the school you just added
}