如何使用CSV文件中的数据运行XUnit测试

问题描述 投票:3回答:2

是否有一种方法可以使用XUnit文件作为数据源来运行数据驱动的CSV测试?我已经尝试过Cavity.Data.XUnit,但是它不再与XUnit的最新版本兼容。到目前为止,我只能使用Excel文件实现此目的,但是我需要将其更改为CSV

非常感谢您的帮助。

示例:

[Theory]
[ExcelData(@"Settings\TestFileParam.xls", "Select url, username, password, from TestData")]
//^Replace with a CSV file instead
public void Tester_Method(string url, string username, string password)
{
    //Code reading the data from CSV
    Assert.True(something);
}
c# csv selenium qa xunit
2个回答
3
投票

您需要创建一个自定义xUnit.Sdk.DataAttribute。这是一个以这种形式读入数据的示例。

MyCsv.csv

sep=,
csvRowOne,csvRowTwo,csvRowThree
15,"Just A Test","Apples are Red"

然后您会这样称呼它:

  [Theory]
  [CsvData(@"C:\MyCsv.csv")]
  public void TestWithCSVData(int csvRowOne, string csvRowTwo, string csvRowThree)

它只是解析字符串和整数,但是您可以扩展ConvertParameter方法以执行更多操作。

CsvDataAttribute.cs

[AttributeUsage(AttributeTargets.Method, AllowMultiple = false, Inherited = false)]
public class CsvDataAttribute : DataAttribute
{
    private readonly string _fileName;
    public CsvDataAttribute(string fileName)
    {
        _fileName = fileName;
    }

    public override IEnumerable<object[]> GetData(MethodInfo testMethod)
    {
        var pars = testMethod.GetParameters();
        var parameterTypes = pars.Select(par => par.ParameterType).ToArray();
        using (var csvFile = new StreamReader(_fileName))
        {
            csvFile.ReadLine();// Delimiter Row: "sep=,". Comment out if not used
            csvFile.ReadLine(); // Headings Row. Comment out if not used
            string line;
            while ((line = csvFile.ReadLine()) != null)
            {
                var row = line.Split(',');
                yield return ConvertParameters((object[])row, parameterTypes);
            }
        }
    }

    private static object[] ConvertParameters(IReadOnlyList<object> values, IReadOnlyList<Type> parameterTypes)
    {
        var result = new object[parameterTypes.Count];
        for (var idx = 0; idx < parameterTypes.Count; idx++)
        {
            result[idx] = ConvertParameter(values[idx], parameterTypes[idx]);
        }

        return result;
    }

    private static object ConvertParameter(object parameter, Type parameterType)
    {
        return parameterType == typeof(int) ? Convert.ToInt32(parameter) : parameter;
    }
}

0
投票

xUnit没有内置的确切功能,但是它具有用例类型的扩展点。许多xUnit可以替换和定制,新的测试用例数据源是更常见的数据源之一。

Xunit.Sdk.DataAttributeExcelDataAttribute使用的扩展点。

典型的实现看起来像这样

public class CsvDataAttribute : DataAttribute
{
    readonly string fileName;

    public CsvDataAttribute(string fileName)
    {
        this.fileName = fileName;
    }

    public override IEnumerable<object[]> GetData(MethodInfo testMethod)
    {
        //Parse CSV and return an object[] for each test case
    }
}

此处找到ExcelDataAttribute的实现。 https://github.com/xunit/samples.xunit/blob/885edfc2e84ec4934cd137a985c3b06dda043ab5/ExcelDataExample/ExcelDataAttribute.cs

© www.soinside.com 2019 - 2024. All rights reserved.