テストクラスと以下のようなクラスがあります。
public class Foo
{
private IDbOjbect _db;
public Foo(string conn)
{
_db = new DbOjbect(conn);
}
internal Foo(IDbObject db)
{
_db= db;
}
internal bool TestOne()
{
if (_db.CurrentDbType == DBType.Oracle)
{
//do something
return true;
}
return false;
}
internal bool TestTwo()
{
if (_db.CurrentDbType == DBType.SqlServer ||
_db.CurrentDbType == DBType.SqlServerCE)
{
//do something
return true
}
return false;
}
internal bool TestThree()
{
if (_db.CurrentDbType == DBType.MySql ||
_db.CurrentDbType == DBType.PostgreSQL ||
_db.CurrentDbType == DBType.SQLite)
{
//do something
return true
}
return false;
}
public void RunProcesses()
{
TestOne();
TestTwo();
TestThree();
}
}
[TestFixture("sqlserver")]
[TestFixture("sqlserverce")]
[TestFixture("oracle")]
[TestFixture("mysql")]
[TestFixture("sqlite")]
[TestFixture("postgre")]
public class Tests
{
private string _conn;
private Foo f;
public Tests(string conn)
{
_conn = conn;
}
[SetUp]
public void SetUp()
{
db = new Mock<IDbObject>();
switch (_conn)
{
case "sqlserver":
db.Setup(x => x.CurrentDbType).Returns(DBType.SqlServer);
break;
case "sqlserverce":
db.Setup(x => x.CurrentDbType).Returns(DBType.SqlServerCE);
break;
case "mysql":
db.Setup(x => x.CurrentDbType).Returns(DBType.MySql);
break;
case "postgre":
db.Setup(x => x.CurrentDbType).Returns(DBType.PostgreSQL);
break;
case "sqlite":
db.Setup(x => x.CurrentDbType).Returns(DBType.SQLite);
break;
case "oracle":
db.Setup(x => x.CurrentDbType).Returns(DBType.Oracle);
break;
}
f = new Foo(db.Object);
}
[Test]
public void TestOne()
{
Assert.IsTrue(f.TestOne());
}
[Test]
public void TestTwo()
{
Assert.IsTrue(f.TestTwo());
}
[Test]
public void TestThree()
{
Assert.IsTrue(f.TestThree());
}
}
_conn が oracle の場合、TestOne メソッドを実行させたい。_conn が sqlserver または sqlserverce の場合、TestThree メソッドを実行したい。_conn が mysql,sqlite, postgre の場合、TestTwo メソッドを実行させたい。これどうやってするの ?これにはnunitの属性はありますか?