Как использовать google test для C++ для запуска комбинаций данных

У меня есть модульный тест, который мне нужно запустить для 200 возможных комбинаций данных. (В производственной реализации есть данные для тестирования в файлах конфигурации. Я знаю, как издеваться над этими значениями). Я предпочитаю не писать отдельный тестовый пример для каждой комбинации и использовать какой-либо способ циклического просмотра данных. Есть ли такой прямой способ использовать тест Google для С++?

Спасибо, Картик


person Karthick S    schedule 03.11.2012    source источник
comment
Почему бы вам не использовать массив структур для хранения ваших тестовых данных и не перебирать каждую запись в цикле? У вас может быть только один тестовый пример, который проверяет все комбинации.   -  person Emile Cormier    schedule 04.11.2012
comment
Привет Эмиль, спасибо за предложение. Когда я попробовал это, если одна комбинация терпит неудачу, она останавливает дальнейшее выполнение тестового примера и не сообщает об успешности должным образом. В конце концов, для меня это разные тесты.   -  person Karthick S    schedule 04.11.2012


Ответы (2)


Вы можете использовать параметризованные тесты gtest. для этого.

Использование этого в сочетании с генератором Combine(g1, g2, ..., gN) звучит как лучший выбор.

В следующем примере заполняются 2 vector, один из int, а другой из string, а затем с помощью всего одного тестового прибора создаются тесты для каждой комбинации доступных значений в 2 vector:

#include <iostream>
#include <string>
#include <tuple>
#include <vector>
#include "gtest/gtest.h"

std::vector<int> ints;
std::vector<std::string> strings;

class CombinationsTest :
    public ::testing::TestWithParam<std::tuple<int, std::string>> {};

TEST_P(CombinationsTest, Basic) {
  std::cout << "int: "        << std::get<0>(GetParam())
            << "  string: \"" << std::get<1>(GetParam())
            << "\"\n";
}

INSTANTIATE_TEST_CASE_P(AllCombinations,
                        CombinationsTest,
                        ::testing::Combine(::testing::ValuesIn(ints),
                                           ::testing::ValuesIn(strings)));

int main(int argc, char **argv) {
  for (int i = 0; i < 10; ++i) {
    ints.push_back(i * 100);
    strings.push_back(std::string("String ") + static_cast<char>(i + 65));
  }
  testing::InitGoogleTest(&argc, argv);
  return RUN_ALL_TESTS();
}
person Fraser    schedule 05.11.2012
comment
Позвольте мне попробовать это и вернуться к вам. - person Karthick S; 07.11.2012
comment
Работает отлично. Большое спасибо. - person Karthick S; 15.11.2012
comment
INSTANTIATE_TEST_CASE_P устарел, используйте INSTANTIATE_TEST_SUITE_P github.com/google/googletest/blob/ - person hojin; 28.05.2021

Используйте массив структур (называемый, скажем, 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
comment
Позвольте мне попробовать и вернуться к вам. - person Karthick S; 07.11.2012
comment
Привет, Эмиль, хотя это звучит просто, я получаю количество тестовых случаев, выполненных как 1, даже для сотен комбинаций в ожидаемом ComboTable. Из-за этого мне нужно будет переделать панель отчетности и др., чтобы указать точное количество неудачных комбинаций для случаев, в которых есть комбинации. Слишком сильная головная боль. Значит, я не смогу его использовать. Спасибо за идею. - person Karthick S; 09.11.2012