如何针对两个不同的数据库运行集成测试?

Cha*_*ell 2 c# integration-testing nunit

我们的解决方案有两个不同的数据库提供程序,它们都位于不同的项目中。IDbProvider他们都继承了位于我们核心项目中的共同点。

namespace OurApp.Data
{
    public interface IDbProvider
    {
       // truncated
    }
}
Run Code Online (Sandbox Code Playgroud)
namespace OurApp.Data.SqlServer
{
    public class DbProvider : IDbProvider {}
}
Run Code Online (Sandbox Code Playgroud)
namespace OurApp.Data.Sqlite
{
    public class DbProvider : IDbProvider {}
}
Run Code Online (Sandbox Code Playgroud)

数据库的功能必须相同,并且我们已经针对SqlServer.DbProvider.

目前,所有 RepositoryTest 都继承自基类。

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);
    }
Run Code Online (Sandbox Code Playgroud)

我真的不想不得不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
}
Run Code Online (Sandbox Code Playgroud)

Dav*_*rno 5

一种解决方案可能是使用参数化测试。这个想法是,您的测试每次运行都会传递不同的数据,从而允许您运行测试两次,针对每个数据库运行一次。

查看http://www.nunit.org/index.php?p=testCaseSource&r=2.6.2看看它是否满足您的需求。

在你的情况下,你可能会遇到类似的情况:

static IDbProvider[] DbProviders = new IDbProvider[] 
{
    sqlserver.DbProvider,  
    sqlite.DbProvider
};

[Test, TestCaseSource("DbProviders")]
public void TestMethod(IDbProvider dbProvider)
{
    ShouldDoStuff(dbprovider);
} 
Run Code Online (Sandbox Code Playgroud)

或者,要针对两个提供程序运行类中的所有测试,请尝试如下操作:

[TestFixture(0)]
[TestFixture(1)]
public class RepositoryTests
{
    private IDbProvider _provider;

    public IDbProvider(int index)
    {
        _provider = IDbProvider[index];
    }


    static IDbProvider[] DbProviders = new IDbProvider[] 
    {
        sqlserver.DbProvider,  
        sqlite.DbProvider
    };

    [Test]
    public void TestMethod(IDbProvider dbProvider)
    {
        ShouldDoStuff(_provider);
    }
}
Run Code Online (Sandbox Code Playgroud)