现在,如果你有一个看起来像这样的测试:
[TestMethod]
[DeploymentItem("DataSource.csv")]
[DataSource(
Microsoft.VisualStudio.TestTools.DataSource.CSV,
"DataSource.csv",
"DataSource#csv",
DataAccessMethod.Sequential)]
public void TestSomething()
{
string data = TestContext.DataRow["ColumnHeader"].ToString();
/*
do something with the data
*/
}当您执行此测试时,您将获得与您拥有的数据值一样多的测试运行。
我想做的是在代码中复制这种行为,同时仍然有一个数据源。例如:假设我想在一个web服务的多个部署版本上运行这个测试(这是一个功能测试,所以没有任何东西被模拟。这很可能是一个针对部署到多个主机的网站的codedui测试)。
[TestMethod]
[DeploymentItem("DataSource.csv")]
[DataSource(
Microsoft.VisualStudio.TestTools.DataSource.CSV,
"DataSource.csv",
"DataSource#csv",
DataAccessMethod.Sequential)]
public void TestSomething()
{
var svc = helper.GetService(/* external file - NOT a datasource */);
string data = TestContext.DataRow["ColumnHeader"].ToString();
/*
do something with the data
*/
}现在,如果我在外部文件中列出了2个部署位置,并在数据源中为testmethod列出了2个值,那么我应该得到4个测试。
您可能会问,为什么我不直接将值添加到数据源。外部文件中的数据将通过测试运行的.testsettings中的部署项被拉入,因为它们可以并将为每个运行测试的人定义不同的内容,我不想为了运行测试而强制重新构建测试代码,也不想爆炸测试数据文件的数量。每个测试可能/应该能够指定它想要测试的位置(类型在编译时是已知的,而不是物理位置)。
同样,为每个部署位置创建测试是不可能的,因为部署位置可以并且将在位置和数量上是动态的。
有没有人能告诉我一些可以帮助我解决这个问题的信息?
发布于 2011-11-09 18:08:43
更新!这适用于Visual Studio2010,但似乎不适用于2012和2013。
我有一个类似的问题,我有一堆文件,我想在数据驱动的测试中用作测试数据。在执行数据驱动测试之前,我通过生成CSV文件解决了这个问题。生成发生在用ClassInitialize属性修饰的静态方法中。
我猜你基本上可以做一些类似的事情,合并你当前的数据源和你的“外部文件”,并输出一个新的CSV数据源,供你的数据驱动测试使用。
public TestContext TestContext { get; set; }
const string NameColumn = "NAME";
const string BaseResourceName = "MyAssembly.UnitTests.Regression.Source";
[ClassInitialize()]
public static void Initialize(TestContext context)
{
var path = Path.Combine(context.TestDeploymentDir, "TestCases.csv");
using (var writer = new StreamWriter(path, false))
{
// Write column headers
writer.WriteLine(NameColumn);
string[] resourceNames = typeof(RegressionTests).Assembly.GetManifestResourceNames();
foreach (string resourceName in resourceNames)
{
if (resourceName.StartsWith(BaseResourceName))
{
writer.WriteLine(resourceName);
}
}
}
}
[TestMethod]
[DataSource("Microsoft.VisualStudio.TestTools.DataSource.CSV", "|DataDirectory|\\TestCases.csv", "TestCases#csv", DataAccessMethod.Random)]
public void RegressionTest()
{
var resourceName = TestContext.DataRow[NameColumn].ToString();
// Get testdata from resource and perform test.
}https://stackoverflow.com/questions/6943403
复制相似问题