mirror of
https://github.com/catchorg/Catch2.git
synced 2025-08-01 21:05:39 +02:00
Cumulative reporter base records benchmark results
This commit is contained in:
@@ -196,6 +196,18 @@ add_test(
|
||||
COMMAND ${PYTHON_EXECUTABLE} ${CATCH_DIR}/tests/TestScripts/testPartialTestCaseEvent.py $<TARGET_FILE:PartialTestCaseEvents>
|
||||
)
|
||||
|
||||
add_executable(BenchmarksInCumulativeReporter ${TESTS_DIR}/X22-BenchmarksInCumulativeReporter.cpp)
|
||||
target_link_libraries(BenchmarksInCumulativeReporter PRIVATE Catch2::Catch2WithMain)
|
||||
add_test(
|
||||
NAME BenchmarksInCumulativeReporter
|
||||
COMMAND BenchmarksInCumulativeReporter --reporter testReporter
|
||||
)
|
||||
set_tests_properties(
|
||||
BenchmarksInCumulativeReporter
|
||||
PROPERTIES
|
||||
PASS_REGULAR_EXPRESSION "1\n2\n3\n4\n5\n"
|
||||
)
|
||||
|
||||
|
||||
add_executable(CasingInReporterNames ${TESTS_DIR}/X23-CasingInReporterNames.cpp)
|
||||
target_link_libraries(CasingInReporterNames PRIVATE Catch2::Catch2WithMain)
|
||||
|
78
tests/ExtraTests/X22-BenchmarksInCumulativeReporter.cpp
Normal file
78
tests/ExtraTests/X22-BenchmarksInCumulativeReporter.cpp
Normal file
@@ -0,0 +1,78 @@
|
||||
|
||||
// Copyright Catch2 Authors
|
||||
// Distributed under the Boost Software License, Version 1.0.
|
||||
// (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// https://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
// SPDX-License-Identifier: BSL-1.0
|
||||
|
||||
/**\file
|
||||
* Test that the cumulative reporter base stores both assertions and
|
||||
* benchmarks, and stores them in the right order.
|
||||
*
|
||||
* This is done through a custom reporter that writes out the assertions
|
||||
* and benchmarks and checking that the output is in right order.
|
||||
*/
|
||||
|
||||
#include <catch2/catch_test_macros.hpp>
|
||||
#include <catch2/benchmark/catch_benchmark.hpp>
|
||||
#include <catch2/reporters/catch_reporter_cumulative_base.hpp>
|
||||
#include <catch2/catch_reporter_registrars.hpp>
|
||||
|
||||
#include <iostream>
|
||||
|
||||
class CumulativeBenchmarkReporter final : public Catch::CumulativeReporterBase {
|
||||
|
||||
public:
|
||||
CumulativeBenchmarkReporter(Catch::ReporterConfig const& _config) :
|
||||
CumulativeReporterBase(_config) {
|
||||
m_preferences.shouldReportAllAssertions = true;
|
||||
}
|
||||
|
||||
static std::string getDescription() {
|
||||
return "Custom reporter for testing cumulative reporter base";
|
||||
}
|
||||
|
||||
virtual void testRunEndedCumulative() override;
|
||||
};
|
||||
|
||||
CATCH_REGISTER_REPORTER("testReporter", CumulativeBenchmarkReporter)
|
||||
|
||||
#include <chrono>
|
||||
#include <thread>
|
||||
|
||||
TEST_CASE("Some assertions and benchmarks") {
|
||||
using namespace std::chrono_literals;
|
||||
|
||||
REQUIRE(1);
|
||||
BENCHMARK("2") {
|
||||
std::this_thread::sleep_for(1ms);
|
||||
};
|
||||
REQUIRE(3);
|
||||
BENCHMARK("4") {
|
||||
std::this_thread::sleep_for(1ms);
|
||||
};
|
||||
REQUIRE(5);
|
||||
}
|
||||
|
||||
void CumulativeBenchmarkReporter::testRunEndedCumulative() {
|
||||
auto const& testCases = m_testRun->children;
|
||||
assert(testCases.size() == 1);
|
||||
|
||||
auto const& testCase = *testCases.front();
|
||||
auto const& sections = testCase.children;
|
||||
assert(sections.size() == 1);
|
||||
|
||||
auto const& section = *sections.front();
|
||||
assert(section.childSections.empty());
|
||||
for (auto const& aob : section.assertionsAndBenchmarks) {
|
||||
if (aob.isAssertion()) {
|
||||
auto const& assertion = aob.asAssertion();
|
||||
std::cout << assertion.assertionResult.getExpandedExpression() << '\n';
|
||||
}
|
||||
if (aob.isBenchmark()) {
|
||||
auto const& bench = aob.asBenchmark();
|
||||
std::cout << bench.info.name << '\n';
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user