3

我的单元测试数据源有问题。我想将记录保存在 XML 中。据我所知,这是受支持的,但我不断收到此错误“单元测试适配器无法连接到数据源......”。

我已按如下方式设置了我的 app.config:

<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>
  <connectionStrings>
    <add name="PersonTestData" connectionString="Dsn=XML Files;dbq=PersonTestData.xml;defaultdir=.\; driverid=790;maxbuffersize=2048;pagetimeout=5" providerName="System.Data.Odbc" />
  </connectionStrings>
  <microsoft.visualstudio.testtools>
    <dataSources>
      <add name="PersonTestData" connectionString="PersonTestData" dataTableName="PersonData" dataAccessMethod="Sequential"/>
    </dataSources>
  </microsoft.visualstudio.testtools>
</configuration>

我正在使用的代码是这样的:

[TestMethod()]
[DeploymentItem("PersonTestData.xml")]
[DataSource("PersonTestData")]
public void CompareToTest()
{
    Person Test = (Person)TestContext.DataRow["Person"];
    Int32 result = Main.CompareTo(Test);
    Assert.IsNotNull(result);
}

最后是 XML 文件它自己:

<?xml version="1.0" encoding="utf-8" ?>
<PersonData xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <Person>
    <LastName>Jones</LastName>
    <FirstName>Bill</FirstName>
    <Age>24</Age>
  </Person>
  <Person>
    <LastName>West</LastName>
    <FirstName>John</FirstName>
    <Age>24</Age>
  </Person>
  <Person>
   <LastName>Jones</LastName>
   <FirstName>Bill</FirstName>
   <Age>24</Age>
  </Person>
</PersonData>

不知道我现在哪里出错了。

4

1 回答 1

1

我认为您不需要 ODBC 连接字符串来读取 xml 文件。只需使用 DataSource 属性,如下所示。还有“PersonTestData.xml”属性。CopyToOutputDirectory 设置为“CopyAlways”。

[TestClass]
public class UnitTest1
{
    private TestContext testContextInstance;
    public TestContext TestContext
    {
        get { return testContextInstance; }
        set { testContextInstance = value; }
    }

    [TestMethod]
    [DeploymentItem("PersonTestData.xml")]
    [DataSource("Microsoft.VisualStudio.TestTools.DataSource.XML",
               "|DataDirectory|\\PersonTestData.xml",
               "Person",
                DataAccessMethod.Sequential)]
    public void CompareToTest()
    {
        var row = TestContext.DataRow;
        var firstName = row["FirstName"].ToString();
        var lastName = row["LastName"].ToString();

        //Asserts...                 
    }
}
于 2013-11-04T02:33:47.100 回答