ClassInitialize 中生成的数据驱动测试:不再在 Visual Studio 2012 中工作

问题描述 投票:0回答:1

我已从 Visual Studio 2010 升级到 Visual Studio 2012。

在我的单元测试项目中,我有一个 [ClassInitialize] 方法,它生成一个 CSV 文件,然后使用连接到 CSV 的 [DataSource] 将其输入到数据驱动的 [TestMethod] 中。

这在 Visual Studio 2010 中非常有效。

我无法让它在 Visual Studio 2012 中工作。

在 VS2012 中,MS 测试运行程序似乎要求连接到 [DataSource] 的文件已经存在,否则任何测试都不会运行。如果我自己创建 CSV,数据驱动的测试会运行,但它们不会获取在 [ClassInitialize] 中创建的数据:似乎是在 [ClassInitialize] 运行之前评估 [DataSource] 中的测试列表。

有解决办法吗?


这是一个重现问题的最小项目。对我来说,这在 VS2010 中成功,但在 VS2012 中失败。

TestProject.cs

using System.Diagnostics;
using System.IO;
using Microsoft.VisualStudio.TestTools.UnitTesting;

namespace TestProject
{
    [TestClass]
    public class DataDrivenUnitTest
    {
        private static bool _classInitializeCalled;
        private static int _testCount;

        public TestContext TestContext { get; set; }

        [ClassInitialize]
        public static void ClassInitialize(TestContext testContext)
        {
            // Generate the csv list of tests
            //TestContext = testContext;
            _classInitializeCalled = true;
            string testDirectory;
            testDirectory = testContext.DeploymentDirectory;
            using (var f = new StreamWriter(testDirectory + @"\" + "TestList.csv"))
            {
                f.WriteLine("TestName");
                f.WriteLine("TestA");
                f.WriteLine("TestB");
            }
        }

        [TestMethod]
        [DataSource("CsvTestData32")]
        public void TestMethod1()
        {
            _testCount++;
            var testName = TestContext.DataRow["TestName"];
            Debug.Print("Test {0}: {1}", _testCount, testName);
        }

        [ClassCleanup]
        public static void ClassCleanup()
        {
            Assert.IsTrue(_classInitializeCalled);
            Assert.AreEqual(_testCount, 2);
            Debug.Print("Tests completed: Tests run {0}", _testCount);
        }
    }
}

在我的例子中,“以 32 位运行测试”是默认设置;这可能会在 -

下更改
  • 在 VS2012 中:测试 > 测试设置 > 默认处理器架构
  • 在VS2010中右键单击解决方案资源管理器“解决方案项目”>添加>新项目>测试设置,然后,
  • VS2010 主菜单 > 测试 > 编辑测试设置 > 主机 > 在 32 位或 64 位进程中运行测试。

如果您使用 64 位,请使用 [DataSource("CsvTestData64")],并且可能需要安装 MS Access 64 位 ODBC 驱动程序。最简单的方法是坚持使用 32 位。

应用程序配置

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="microsoft.visualstudio.testtools" type="Microsoft.VisualStudio.TestTools.UnitTesting.TestConfigurationSection, Microsoft.VisualStudio.QualityTools.UnitTestFramework, Version=10.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
  </configSections>

  <microsoft.visualstudio.testtools>
    <dataSources>
      <add name="CsvTestData32" connectionString="CsvConn32" dataTableName="`TestList.csv`" dataAccessMethod="Sequential" />
      <add name="CsvTestData64" connectionString="CsvConn64" dataTableName="`TestTest.csv`" dataAccessMethod="Sequential" />
    </dataSources>
  </microsoft.visualstudio.testtools>

  <connectionStrings>
    <add name="CsvConn32" connectionString="Driver={Microsoft Text Driver (*.txt; *.csv)};.\;Extensions=csv;" providerName="System.Data.Odbc" />
    <add name="CsvConn64" connectionString="Driver={Microsoft Access Text Driver (*.txt, *.csv)};Dbq=.\;Extensions=csv" providerName="System.Data.Odbc" />
  </connectionStrings>
</configuration>
c# unit-testing visual-studio-2012 mstest data-driven-tests
1个回答
4
投票

MSTestHacks 可能会有所帮助。

它允许您的测试类上的

IEnumerable
用作您的
DataSource
TestMethod

来自网站:

运行时数据源:您的测试类必须继承自

TestBase

[TestClass]
public class UnitTest1 : TestBase
{ }

创建返回

IEnumerable

的属性、字段或方法
[TestClass]
public class UnitTest1 : TestBase
{
    private IEnumerable<int> Stuff
    {
        get
        {
            //This could do anything, fetch a dynamic list from anywhere....
            return new List<int> { 1, 2, 3 };
        }
    }
}

DataSource
属性添加到您的测试方法中,指向之前创建的
IEnumerable
名称。这需要完全合格。

[TestMethod]
[DataSource("Namespace.UnitTest1.Stuff")]
public void TestMethod1()
{
    var number = this.TestContext.GetRuntimeDataSourceObject<int>();

    Assert.IsNotNull(number);
}
© www.soinside.com 2019 - 2024. All rights reserved.