テストランナーにはVS2012.3 .NET4.5とR#でMSTESTを使用します。MSTESTの複数のTestInitialize属性
以下のコードは、1,2,3,4の順番で動作します。これは許可され、ドキュメントだけで、複数のTestInitialize
属性がで許可されていないことを意味しています:私は、複数のTestInitialize
属性がMSDN
質問サポートされていないとして、それは常にこの順序で実行されないことが心配ですが
同じクラスですか?
私は、TransactedTestBaseを継承した多数の統合テストがあり、セットアップに別のSQLスクリプトを必要とするため、この構造を維持したいと考えています。
同じ動作をhere
[TestClass]
public class DelegationTest : TransactedTestBase
{
[TestInitialize]
public void Setup()
{
Console.WriteLine("2 Setup");
//var script = "INSERT INTO blah...";
//var sqlConnect = new SqlConnection(dbConnection.ConnectionString);
//sqlConnect.Open();
//var server = new Server(sqlConnect);
//var database = server.Databases[sqlConnect.Database];
//database.ExecuteNonQuery(script);
}
[TestMethod]
public void TestMethod1()
{
Console.WriteLine("3 Test Method");
}
}
[TestClass]
public class TransactedTestBase
{
//protected userEntities userEntities;
//private TransactionScope scope;
//public static SqlDatabase dbConnection;
//private const bool ShouldWriteToDB = true;
//private const bool ShouldWriteToDB = false;
[TestInitialize()]
public virtual void TestStart()
{
Console.WriteLine("1 TestStart");
//if (ShouldWriteToDB)
//{
// dbConnection = EnterpriseLibraryContainer.Current.GetInstance<SqlDatabase>("DBConnect");
// return;
//}
//scope = new TransactionScope(TransactionScopeOption.RequiresNew);
//user = new userEntities();
//dbConnection = EnterpriseLibraryContainer.Current.GetInstance<SqlDatabase>("DBConnect");
}
[TestCleanup()]
public virtual void TestEnd()
{
Console.WriteLine("4 TestEnd");
//if (ShouldWriteToDB) return;
//scope.Dispose();
}
}
あなたは驚きを避け、直接基底クラスのメソッドを呼び出すことができます[TestInitialize] 公共オーバーライド無効TestStart(){ base.TestStart(); Console.WriteLine( "2 Setup"); } – SlavaGu