我此刻正在吃东西.就像Entity Framework不可测试一样.我已经阅读了很多帖子和帖子,他们使用工作单元或moq或repo模式.
我处于一个阶段,我无法改变我的应用程序的架构.该应用程序在此时完全正常工作,但为了确保我需要具有高代码覆盖率,因此测试它是.
为了测试,我使用’伪上下文’方法,我可以使用假的一个用于模拟,而真实的一个用于连接到数据库.
我用这个作为例子.
http://romiller.com/2010/09/07/ef-ctp4-tips-tricks-testing-with-fake-dbcontext/
在那里,您可以看到上下文被拆分并用作接口.喜欢:
public interface IEmployeeContext { IDbSet Department Departments { get; } IDbSet Employee Employees { get; } int SaveChanges(); } public class EmployeeContext : DbContext,IEmployeeContext { public IDbSet Department Departments { get; set; } public IDbSet Employee Employees { get; set; } } public class FakeEmployeeContext : IEmployeeContext { public FakeEmployeeContext() { this.Departments = new FakeDepartmentSet(); this.Employees = new FakeEmployeeSet(); } public IDbSet Department Departments { get; private set; } public IDbSet Employee Employees { get; private set; } public int SaveChanges() { return 0; } } }
所以测试和一切都有效.我似乎无法做的唯一事情就是在其中测试一个带有.State的控制器,在那里我检查它是否改变了如下:
EntityState.Modified
因为这使用了一个接口,我需要将它添加到接口上下文中.并创建一个新的.或者我错过了什么?我可能不打算在该上下文中创建整个方法.我怎样才能设法让它工作
解决方法
您是否考虑过执行集成测试?
您可以对真正的EF DBContext进行集成测试,
只需在unit-tests项目的App.config中给它一个不同的连接字符串.
阅读this及其所有答案.