ORE Studio 0.0.4
Loading...
Searching...
No Matches
test_timeout_listener.hpp
1/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 *
3 * Copyright (C) 2025 Marco Craveiro <marco.craveiro@gmail.com>
4 *
5 * This program is free software; you can redistribute it and/or modify it under
6 * the terms of the GNU General Public License as published by the Free Software
7 * Foundation; either version 3 of the License, or (at your option) any later
8 * version.
9 *
10 * This program is distributed in the hope that it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
13 * details.
14 *
15 * You should have received a copy of the GNU General Public License along with
16 * this program; if not, write to the Free Software Foundation, Inc., 51
17 * Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 *
19 */
20#ifndef ORES_TESTING_TEST_TIMEOUT_LISTENER_HPP
21#define ORES_TESTING_TEST_TIMEOUT_LISTENER_HPP
22
23#include <atomic>
24#include <chrono>
25#include <thread>
26#include <string>
27#include <catch2/catch_test_case_info.hpp>
28#include <catch2/reporters/catch_reporter_event_listener.hpp>
29#include "ores.logging/make_logger.hpp"
30
31namespace ores::testing {
32
44class test_timeout_listener : public Catch::EventListenerBase {
45private:
46 inline static std::string_view logger_name =
47 "ores.testing.test_timeout_listener";
48
49 static auto& lg() {
50 using namespace ores::logging;
51 static auto instance = make_logger(logger_name);
52 return instance;
53 }
54
55public:
56 using Catch::EventListenerBase::EventListenerBase;
57
58 void testCaseStarting(Catch::TestCaseInfo const& testInfo) override;
59 void testCaseEnded(Catch::TestCaseStats const& testCaseStats) override;
60
61private:
62 void watchdog_thread_func();
63
64 std::chrono::steady_clock::time_point test_start_time_;
65 std::string current_test_name_;
66 std::atomic<bool> test_running_{false};
67 std::thread watchdog_thread_;
68 std::chrono::seconds timeout_{60};
69};
70
71}
72
73#endif
Implements logging infrastructure for ORE Studio.
Definition boost_severity.hpp:28
Testing infrastructure common to all test projects.
Definition database_helper.hpp:27
Catch2 listener that enforces per-test timeouts.
Definition test_timeout_listener.hpp:44