我们的解决方案有两个不同的数据库提供程序,它们都位于不同的项目中。它们都继承了IDbProvider
位于我们核心项目中的共同点。
namespace OurApp.Data
{
public interface IDbProvider
{
// truncated
}
}
namespace OurApp.Data.SqlServer
{
public class DbProvider : IDbProvider {}
}
namespace OurApp.Data.Sqlite
{
public class DbProvider : IDbProvider {}
}
数据库的功能必须相同,并且我们已经进行了针对SqlServer.DbProvider
.
目前,所有 RepositoryTests 都继承自一个基类。
public abstract class RepositoryTestsBase
{
protected IDbConnectionProvider Connection;
protected IDbProvider DbProvider;
[SetUp]
public void Setup()
{
// Need to create a new connection to the server and make sure there is no database
ConnectionStringSettings dbConnection = ConfigurationManager.ConnectionStrings["databaseConnection"];
string testDatabaseName = ConfigurationManager.AppSettings["databaseName"];
Connection = new DbConnectionProvider(dbConnection.ConnectionString, dbConnection.ProviderName);
DbProvider = new DbProvider(Connection, testDatabaseName);
}
我真的很讨厌不得不CTRL+ C/ CTRL+V 我所有的集成测试只是为了更改 DbProvider。
有没有一种方法可以运行所有集成测试两次,同时为每次运行注入不同的 DbProvider?我希望能够(显然)在我们的 Powershell 版本中执行此操作,但也可以在 IDE 中执行此操作。
我最初的想法是创建两个公共方法和一个私有方法,注入适当的数据库提供程序。
[Test]
public void ShouldDoStuff_SQLServer() {
var dbProvider = sqlserver.DbProvider;
ShouldDoStuff(dbprovider);
}
[Test]
public void ShouldDoStuff_Sqlite() {
var dbProvider = sqlite.DbProvider;
ShouldDoStuff(dbprovider);
}
private void ShouldDoStuff (IDbProvider dbprovider){
// Assert
}