Используйте массив структур (называемый, скажем, Combination
) для хранения ваших тестовых данных и циклически просматривайте каждую запись в одном тесте. Проверяйте каждую комбинацию, используя EXPECT_EQ
вместо ASSERT_EQ
, чтобы тест не прерывался и вы могли продолжить проверку других комбинаций.
Перегрузите operator<<
для Combination
, чтобы вы могли вывести его на ostream
:
ostream& operator<<(ostream& os, const Combination& combo)
{
os << "(" << combo.field1 << ", " << combo.field2 << ")";
return os;
}
Перегрузите operator==
для Combination
, чтобы вы могли легко сравнить две комбинации на равенство:
bool operator==(const Combination& c1, const Combination& c2)
{
return (c1.field1 == c2.field1) && (c1.field2 == c2.field2);
}
И модульный тест может выглядеть примерно так:
TEST(myTestCase, myTestName)
{
int failureCount = 0;
for (each index i in expectedComboTable)
{
Combination expected = expectedComboTable[i];
Combination actual = generateCombination(i);
EXPECT_EQ(expected, actual);
failureCount += (expected == actual) ? 0 : 1;
}
ASSERT_EQ(0, failureCount) << "some combinations failed";
}
person
Emile Cormier
schedule
04.11.2012