实体框架 – 在每个单元测试之前重新创建和重新设置LocalDb

我正在尝试为我的ASP.NET Web API项目编写单元/集成测试,并努力孤立地运行每个测试.请允许我解释

我有一个配置了部署设置的* .testsettings文件.在每次测试运行之前,将一个空的* .mdf文件部署到测试位置.由于我使用的是实体框架代码,我可以使用数据库初始化程序将我的架构推送到数据库,并将一个特定的表格种成2行.这很好.

我遇到的问题是,如果所有ApiController的所有操作都能以错误的顺序执行,则可以对对方的脚趾进行各种测试.例如,如果我在POST测试之前运行GET测试,则GET返回2个对象,如果它们以相反的顺序运行,则GET返回3个对象.

我想我需要做的是在每次测试之前放下,重新创建和重新设置我的数据库.这是一个好主意还是有更好的方法?如果这是最好的,我可以在每次测试之前重新设置我的数据库.

解决方法

这是我最终为有兴趣的人做的事情.

我扩展了DropCreateDatabaseAlways< TContext>并覆盖Seed方法,以我的单元测试可以依赖的已知测试数据填充我的数据库.

public class MyDatabaseInitializer : System.Data.Entity.DropCreateDatabaseAlways<MyDbContext>
{
    protected override void Seed(MyDbContext context)
    {
        // Add entities to database.

        context.SaveChanges();
    }
}

然后我实现了一个[AssemblyInitialize]方法,它设置数据库初始化程序.

[TestClass]
public class Global
{
    [AssemblyInitialize]
    public static void AssemblyInitialize(TestContext context)
    {
        System.Data.Entity.Database.Setinitializer(new MyDatabaseInitializer());
    }
}

这将设置数据库的初始化程序,但实际上并不运行它.初始化程序在我写的[Testinitialize]方法中运行,这将强制在每次测试之前删除,重新创建和重新使用数据库.

[TestClass]
public class MyTestClass
{
    [Testinitialize]
    public void Testinitialize()
    {
        MyDbContext context = new MyDbContext();
        context.Database.Initialize(true);
    }

    [TestMethod]
    public void MyUnittest()
    {
        Assert.IsTrue(true);
    }
}

相关文章

这篇文章主要讲解了“WPF如何实现带筛选功能的DataGrid”,文...
本篇内容介绍了“基于WPF如何实现3D画廊动画效果”的有关知识...
Some samples are below for ASP.Net web form controls:(fr...
问题描述: 对于未定义为 System.String 的列,唯一有效的值...
最近用到了CalendarExtender,结果不知道为什么发生了错位,...
ASP.NET 2.0 page lifecyle ASP.NET 2.0 event sequence cha...