diff --git a/tests/src/TestCases.cpp b/tests/src/TestCases.cpp index 493b9b3..a8376df 100644 --- a/tests/src/TestCases.cpp +++ b/tests/src/TestCases.cpp @@ -31,6 +31,13 @@ class TestCaseBase Part2TestContext part2TestContext{ getInputPaths() }; Part1TestContext part1ExampleTestContext{ getExampleInputPaths() }; Part2TestContext part2ExampleTestContext{ getExampleInputPaths() }; + void run(std::unique_ptr&& solver, const long long int expected, const TestContext& context) + { + SolverEngine solverEngine{ context.getInputPaths() }; + solverEngine.run(*solver); + + REQUIRE(expected == context.getResult(*solver)); + } private: std::vector getInputPaths() const { @@ -43,33 +50,23 @@ class TestCaseBase } }; -template -void runTest(const long long int expected, const TestContext& context) -{ - auto solver = std::make_unique(); - SolverEngine solverEngine{ context.getInputPaths() }; - solverEngine.run(*solver); - - REQUIRE(expected == context.getResult(*solver)); -} - TEST_CASE("[HistorianHysteriaTests]") { TestCaseBase test; SECTION("FullData1") { - runTest(2176849, test.part1TestContext); + test.run(std::make_unique(), 2176849, test.part1TestContext); } SECTION("FullData2") { - runTest(23384288, test.part2TestContext); + test.run(std::make_unique(), 23384288, test.part2TestContext); } SECTION("ExampleData1") { - runTest(11, test.part1ExampleTestContext); + test.run(std::make_unique(), 11, test.part1ExampleTestContext); } SECTION("ExampleData2") { - runTest(31, test.part2ExampleTestContext); + test.run(std::make_unique(), 31, test.part2ExampleTestContext); } }