Wiem, że to kolejna późna odpowiedź, ale w moim zespole, który jest zablokowany przy użyciu frameworka MS Test, opracowaliśmy technikę, która opiera się tylko na typach anonimowych do przechowywania tablicy danych testowych i LINQ do zapętlania i testowania każdego wiersza. Nie wymaga żadnych dodatkowych klas ani ram i wydaje się być dość łatwe do odczytania i zrozumienia. Jest również znacznie łatwiejszy do wdrożenia niż testy oparte na danych z wykorzystaniem plików zewnętrznych lub połączonej bazy danych.
Załóżmy na przykład, że masz taką metodę rozszerzenia:
public static class Extensions
{
/// <summary>
/// Get the Qtr with optional offset to add or subtract quarters
/// </summary>
public static int GetQuarterNumber(this DateTime parmDate, int offset = 0)
{
return (int)Math.Ceiling(parmDate.AddMonths(offset * 3).Month / 3m);
}
}
Możesz użyć i tablicy typów anonimowych połączonych z LINQ, aby napisać takie testy:
[TestMethod]
public void MonthReturnsProperQuarterWithOffset()
{
// Arrange
var values = new[] {
new { inputDate = new DateTime(2013, 1, 1), offset = 1, expectedQuarter = 2},
new { inputDate = new DateTime(2013, 1, 1), offset = -1, expectedQuarter = 4},
new { inputDate = new DateTime(2013, 4, 1), offset = 1, expectedQuarter = 3},
new { inputDate = new DateTime(2013, 4, 1), offset = -1, expectedQuarter = 1},
new { inputDate = new DateTime(2013, 7, 1), offset = 1, expectedQuarter = 4},
new { inputDate = new DateTime(2013, 7, 1), offset = -1, expectedQuarter = 2},
new { inputDate = new DateTime(2013, 10, 1), offset = 1, expectedQuarter = 1},
new { inputDate = new DateTime(2013, 10, 1), offset = -1, expectedQuarter = 3}
// Could add as many rows as you want, or extract to a private method that
// builds the array of data
};
values.ToList().ForEach(val =>
{
// Act
int actualQuarter = val.inputDate.GetQuarterNumber(val.offset);
// Assert
Assert.AreEqual(val.expectedQuarter, actualQuarter,
"Failed for inputDate={0}, offset={1} and expectedQuarter={2}.", val.inputDate, val.offset, val.expectedQuarter);
});
}
}
Korzystając z tej techniki, warto użyć sformatowanego komunikatu, który zawiera dane wejściowe w Assert, aby pomóc Ci zidentyfikować wiersz powodujący niepowodzenie testu.
Opisałem to rozwiązanie na blogu AgileCoder.net, podając więcej informacji i szczegółów .