我正在尝试为我的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); } }