未调用基于单元测试的类中的ClassInitialize属性

问题描述 投票:41回答:5

我在TestBase类中添加了这些方法:

[ClassInitialize]
public static void InitializBeforeAllTests()
{
}

但是当我在Debug中运行单元测试时,Test1()

[TestClass]
public class TestMapping : TestBase
{
    [TestMethod]
    public void Test1()
    {
    }

从未调用过TestBase.InitializBeforeAllTests()方法。为什么?

c# vs-unit-testing-framework
5个回答
13
投票

在方法上声明ClassInitialize属性时,该方法必须是static,public,void,并且应该采用TestContext类型的单个参数。

如果您在同一单元测试中使用了AssemblyInitialize属性的其他方法,则测试将运行但将跳过所有测试方法,并将直接转到AssemblyCleanup或只是退出。

试试ClassInitialize attribute in MSDN上的例子。


8
投票

无论出于何种原因,单元测试框架的UnitTestExecuter只允许为每个测试类定义一个ClassInitialize和一个ClassCleanup方法......不像TestInitialize和TestCleanup方法,它们在派生和基础测试类中被调用......


7
投票

您可以在基类中设置程序集初始化方法。与ClassInitialize不完全相同,但它是一个可行的选择。来源:The Workaround mentioned here.

[TestClass]
public abstract class TestBase
{
    [AssemblyInitializeAttribute]
    public static void Initialize(TestContext context)
    {
        // put your initialize code here
    }
}

您还可以添加清理方法:

[AssemblyCleanup]
public static void Cleanup()
{
   //clean up stuff here
}

0
投票

MS链接不再起作用。无论如何,解决此问题的一种方法是简单地将初始化代码移动到基类的构造函数中。这将确保在实例化时从任何后代类调用它。

[TestClass]
public class TestBase
{
    public TestBase()
    {
        // Initialization Code
    }
}

[TestClass]
public class TestMapping : TestBase
{
    [TestMethod]
    public void Test1()
    {
        // At this point the base constructor should have been called
    }
}

0
投票

在我的情况下,我应用了[Ignore]属性(手动运行测试) 这导致[AssemblyInitialize]永远不会被调用

如果我删除了[Ignore]属性[AssemblyInitialize]按预期调用。

奇怪的是,[AssemblyCleanup]仍被称为有或没有[Ignore]适用于我的测试

© www.soinside.com 2019 - 2024. All rights reserved.