我正在尝试使用列值作为测试名称,以便在每行的Visual Studio中的测试资源管理器窗格中显示所有行。
以下是是我的测试,消耗CSV文件中的数据。我尝试使用" TestName"属性和切片(" {15:16}")我希望用作测试名称的字符串部分的默认名称。我现在肯定是正确的,因为它只是给我方法名称的名称。
第二种方法是我的阅读操作。此外,我不想将数据分配给变量,然后必须传递它们。我正在寻找一种更优雅的方式来解决阅读和使用CSV数据进行命名和测试,所以如果有任何经验或想法,我很乐意听到它们。
如果我和#请告诉我39;我们留下了任何可以进一步澄清我的目标的信息。
class MegaTests
{
[TestCase(TestName = "{15:16}")]
[Test, TestCaseSource("GetTestData")]
public void MyExample_Test(string TestName, string json, string ExpectedResult, string Environment, string ChannelMessage, string ChannelSubject, string MessageCenterMessage, string MessageCenterSubject)
{
Console.WriteLine(TestName + " " + json + " " + ExpectedResult + " " + Environment + " " + ChannelMessage + " " + ChannelSubject + " " + MessageCenterMessage + " " + MessageCenterSubject);
}
private static IEnumerable<string[]> GetTestData()
{
//using (var csv = new CsvReader(new StreamReader(@"../../csv/data.csv"), true))
using (var csv = new CsvReader(new StreamReader(@"DataDriveFromCSV/csv/data.csv"), true))
{
while (csv.ReadNextRecord())
{
string TestName = csv[0];
string json = csv[1];
string ExpectedResult = csv[2];
string Environment = csv[3];
string ChannelMessage = csv[4];
string ChannelSubject = csv[5];
string MessageCenterMessage = csv[6];
string MessageCenterSubject = csv[7];
yield return new[] { TestName, json, ExpectedResult, Environment, ChannelMessage, ChannelSubject, MessageCenterMessage, MessageCenterSubject };
}
}
}
答案 0 :(得分:0)
[TestCase]
和[TestCaseSource]
是将数据输入测试的替代正交方法。他们不以任何方式合作,尽管你可以用两种方式来获取数据。
如果您使用[TestCase(TestName="{15:16}")]
,则表示您创建的测试没有参数且名称为&#34; {15:16}&#34;。使用TestCaseSource是执行您想要做的事情的正确方法。
如果你仔细考虑,你会发现你不能将测试的名称作为测试的参数。必须存在测试以便首先调用它,一旦存在它就已经有了名称。
您应该返回TestCaseData
的实例,而不是返回参数数组,这将允许您传递参数以及设置测试的名称。
答案 1 :(得分:0)
对于其他任何有此问题的人......
{
using (var csv = new CsvReader(new StreamReader("PATH TO YOUR CSV FILE"), false))
{
List<string> Lines = new List<string>();
int counter = 0;
while (csv.ReadNextRecord())
{
if (counter == 0)
{
for (int i = 0; i < csv.FieldCount; i++)
{
Lines.Add(csv[i]);
}
}
else
{
Dictionary<string, string> testData = new Dictionary<string, string>();
for (int i = 0; i < Lines.Count; i++)
{
testData.Add(Lines[i], csv[i]);
}
yield return new TestCaseData(testData).SetName(csv[0].ToString());
}
counter++;
}
}
}