在 VS2012.3 .NET4.5 和 R# 中使用 MSTEST 进行测试。
下面的代码按 1、2、3、4 的顺序工作。
但是我担心它可能不会总是按此顺序执行,因为不支持多个 TestInitialize
属性 MSDN
问题:这是允许的吗,文档是否只是意味着在同一个类中不允许使用多个 TestInitialize
属性?
我想保留这个结构,因为许多集成测试继承了 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();
}
}
最佳答案
我相信文档指的是使用 TestInitializeAttribute
多次使用相同的方法。这是由 AttributeUsage(AllowMultiple=false)
控制的. FWIW,我有一个中等规模的测试套件(~200 个测试),它基于你所展示的按预期工作的代码:TestStart
在 Setup
之前调用.
制作 TestInitialize
时出现问题方法 virtual 和覆盖它(参见 here )和 ClassInitialize
的继承方法 ( MsTest ClassInitialize and Inheritance )。
关于c# - MSTEST 中的多个 TestInitialize 属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18511269/