Тестирование, ориентированное на данные в NUNIT?
-
26-09-2019 - |
Вопрос
В MSTEST вы можете сделать что-то вроде:
[TestMethod]
[DataSource("Microsoft.VisualStudio.TestTools.DataSource.CSV",
"testdata.csv", "testdata#csv", DataAccessMethod.Sequential)]
public void TestSomething()
{
double column1 = Convert.ToDouble(TestContext.DataRow["column1"]);
...
Assert.AreEqual(...);
}
Какой эквивалентный код в NUNIT 2.5?
Решение
Я бы посмотрел на Параметризованные тесты документации в NUNIT 2.5 И посмотрите, можете ли вы сделать что-то вроде того, что вы делаете там. Я не вспоминаю NUNIT, имеющий встроенный атрибут чтения CSV для привода параметризованных тестов. Там может быть плагин сообщества где-то, хотя.
Я также должен указать, что, если вы просто ищете библиотеки Framework Testying Non-MS Unit, чтобы помочь вам, Xunit.net имеет эту функциональность. Проверьте это Сообщение в блоге от Бен Холл
Другие советы
Я получил тестирование на основе CSV в NUNIT, работаю следующим образом:
Использовать CSV Reader от кода проекта, завернутый в частном методе, возвращающемся IENumerable в вашем классе тестов, а затем ссылаться на это атрибут TestCaseSource в ваших тестовых случаях. Включите ваш файл CSV в вашем проекте и настроен »Скопируйте в каталог вывода" к "Скопировать всегда ".
using System.Collections.Generic;
using System.IO;
using LumenWorks.Framework.IO.Csv;
using NUnit.Framework;
namespace mytests
{
class MegaTests
{
[Test, TestCaseSource("GetTestData")]
public void MyExample_Test(int data1, int data2, int expectedOutput)
{
var methodOutput = MethodUnderTest(data2, data1);
Assert.AreEqual(expectedOutput, methodOutput, string.Format("Method failed for data1: {0}, data2: {1}", data1, data2));
}
private int MethodUnderTest(int data2, int data1)
{
return 42; //todo: real implementation
}
private IEnumerable<int[]> GetTestData()
{
using (var csv = new CsvReader(new StreamReader("test-data.csv"), true))
{
while (csv.ReadNextRecord())
{
int data1 = int.Parse(csv[0]);
int data2 = int.Parse(csv[1]);
int expectedOutput = int.Parse(csv[2]);
yield return new[] { data1, data2, expectedOutput };
}
}
}
}
}
Оригинальный пост на: http://timwise.blogspot.com/2011/05/data-with-test-in-nunit-with-csv.html.
Вот еще один пример, очень похожий на Tim Abell, однако не использует рамки для читателя CSV и показывает специфику теста. Примечание. При использовании TestCaseAttribute Testattribute может быть опущен.
[TestCaseSource("GetDataFromCSV")]
public void TestDataFromCSV(int num1,int num2,int num3)
{
Assert.AreEqual(num1 + num2 ,num3);
}
private IEnumerable<int[]> GetDataFromCSV()
{
CsvReader reader = new CsvReader(path);
while (reader.Next())
{
int column1 = int.Parse(reader[0]);
int column2 = int.Parse(reader[1]);
int column3 = int.Parse(reader[2]);
yield return new int[] { column1, column2, column3 };
}
}
public class CsvReader : IDisposable
{
private string path;
private string[] currentData;
private StreamReader reader;
public CsvReader(string path)
{
if (!File.Exists(path)) throw new InvalidOperationException("path does not exist");
this.path = path;
Initialize();
}
private void Initialize()
{
FileStream stream = new FileStream(path, FileMode.Open, FileAccess.Read);
reader = new StreamReader(stream);
}
public bool Next()
{
string current = null;
if ((current = reader.ReadLine()) == null) return false;
currentData = current.Split(',');
return true;
}
public string this[int index]
{
get { return currentData[index]; }
}
public void Dispose()
{
reader.Close();
}
}
Данные CSV:
10,200,210 20,190,210 30,180,210 40,170,210 50,160,210 60,150,210 70,140,210 80,130,210 90,120,210 100,110,210
Примечание. 3-й столбец представляет собой сумму первых двух столбцов, и это будет утверждено в модульном тесте.
Результаты:
Найдите ниже альтернативы, используя объекты TestCasedata и настроить тип возврата (который OUF-курс является обязательным)
[TestCaseSource("GetDataFromCSV2")]
public int TestDataFromCSV2(int num1, int num2)
{
return num1 + num2;
}
private IEnumerable GetDataFromCSV2()
{
CsvReader reader = new CsvReader(path);
while (reader.Next())
{
int column1 = int.Parse(reader[0]);
int column2 = int.Parse(reader[1]);
int column3 = int.Parse(reader[2]);
yield return new TestCaseData(column1, column2).Returns(column3);
}
}
MS Test предоставляет механизм для ваших тестовых данных из разных источников. Однако это не доступно из коробки от NUNIT.
Я в пользу использования отделения данных и кода для тестов, которые имеют некоторые значительные размеры. Когда я отделяю обоих, мои ожидания являются 1. читаемость данных тестирования 2. Тестовые данные должны быть простыми в модификации 3. Установка тестов должна работать удобно в локальной и создании среды
То JsonsecteReader Ниже есть все особенности, которые я хотел бы иметь. Инструмент способен читать разделы данных из встроенных файлов JSON. Он также обеспечивает очень удобный механизм для десериализации.
https://www.nuget.org/packages/wondertools.jsonsectionReader/
PS Я являюсь сопровождающим этого проекта, и этот проект был создан, потому что я не нашел никакого другого инструмента, который решает эту проблему до такой степени, в которой я хотел.
Я думаю, что эквивилиент NUNIT состоит в том, чтобы отметить способ в качестве метода установки, а затем загружать данные в поле, которое будет использоваться в последующих тестах.
Вы должны кодировать это самостоятельно, более или менее.