我正在使用实体框架,并且我有一个单元测试项目,我想要实践我到目前为止所做的工作。当它完成时,我希望它不实际更新我的测试数据库。如果我使用的是SQL,我会创建一个事务,然后在最后回滚它。
我怎么能在这里做同样的事情呢?
据我所知,context.SaveChanges();有效地对数据库进行了写操作。如果没有,那么在我给allCartTypes赋值为context.CarTypes.ToList()之后,它就是空的
下面是我的一个Test类的示例。
using System;
using System.Diagnostics;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using Trains;
using System.Linq;
namespace TrainsTest
{
[TestClass]
public class TestCarType : TestBase
{
[TestMethod]
public void TestCarTypeCreate_Success()
{
var tankerCarType = new CarType {Name = "Tanker"};
var boxCarType = new CarType { Name = "Box" };
using (var context = new TrainEntities())
{
context.CarTypes.Add(tankerCarType);
context.CarTypes.Add(boxCarType);
context.SaveChanges();
var allCartTypes = context.CarTypes.ToList();
foreach (var cartType in allCartTypes)
{
Debug.WriteLine(cartType.CarTypeId + " - " + cartType.Name);
}
}
}
}
}我知道我错过了一些基本的东西,但我不知道它是什么。我在谷歌上搜索也是徒劳的。
发布于 2014-09-10 06:55:04
有一篇关于ef事务的MSDN文章。
http://msdn.microsoft.com/en-gb/library/vstudio/bb738523(v=vs.100).aspx
https://stackoverflow.com/questions/25754412
复制相似问题