我正在尝试用C#构建Test类的数据驱动单元测试。我想使用3个数据库:一个来自SQL,一个来自Access,一个来自Excel。 这是我的app.config文件:
<?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"/>
</configSections>
<connectionStrings>
<add name="MyJetConn"
connectionString="Provider=Microsoft.ACE.OLEDB.12.0;
Data Source=H:\SQA\CoolMath\CoolMath\Database1.accdb;
Persist Security Info=False;"
providerName="System.Data.OleDb" />
<add name="MyExcelConn"
connectionString="Dsn=Excel Files;
dbq=H:\SQA\CoolMath\CoolMath\CoolMathExcelDataTable.xlsx;
defaultdir=.;
driverid=1046;
maxbuffersize=2048;
pagetimeout=5"
providerName="System.Data.Odbc" />
<add name="MSSQLConn"
connectionString="Data Source=H:\SQA\CoolMath\CoolMath\SQLExpress;
Initial Catalog=MSSQLDB;
Integrated Security=SSPI;"
providerName="System.Data.SqlClient" />
</connectionStrings>
<microsoft.visualstudio.testtools>
<dataSources>
<add name="MyJetDataSource"
connectionString="MyJetConn"
dataTableName="CoolMathAcessDataTable"
dataAccessMethod="Sequential"/>
<add name="MyExcelDataSource"
connectionString="MyExcelConn"
dataTableName="Sheet1$"
dataAccessMethod="Sequential"/>
<add name="MSSQLDataSource"
connectionString="MSSQLConn"
dataTableName="dbo.CoolMathDataTable"
dataAccessMethod="Sequential"/>
</dataSources>
</microsoft.visualstudio.testtools>
</configuration>
当我尝试运行测试时,它们都会失败并显示消息:
“在测试配置设置中找不到数据源”。
我看不出我做错了什么,也许是数据库的位置? (它们都与代码项目和XML文件位于同一个库中。)
在单元测试之上我放置了以下属性:
[TestMethod()] [DeploymentItem("CoolMath\\CoolMathExcelDataTable.xlsx")]
[DataSource("MyExcelDataSource")]
答案 0 :(得分:0)
使用Visual Studio,DataSources的相对路径已移动。 我使用的是XML文件,但如果xlsx文件有同样的问题,我也不会感到惊讶。我不得不使用以下内容来使文件正常工作
[DeploymentItem("TestData\\Search.xml")]
[DataSource("Microsoft.VisualStudio.TestTools.DataSource.XML",
@"|DataDirectory|\\..\TestData\Search.xml",
"Row",
DataAccessMethod.Sequential)]
注意第2行的路径,它以\ ..开头。
这是因为相对路径从Solution变为Project(反之亦然)。 Test_Data是项目顶部的文件夹。