Branch data Line data Source code
1 : : // Copyright (c) 2019-2021 The Bitcoin Core developers 2 : : // Distributed under the MIT software license, see the accompanying 3 : : // file COPYING or http://www.opensource.org/licenses/mit-license.php. 4 : : 5 : : #include <test/util/logging.h> 6 : : 7 : : #include <logging.h> 8 : : #include <noui.h> 9 : : #include <tinyformat.h> 10 : : 11 : : #include <stdexcept> 12 : : 13 : 0 : DebugLogHelper::DebugLogHelper(std::string message, MatchFn match) 14 : 0 : : m_message{std::move(message)}, m_match(std::move(match)) 15 : : { 16 : 0 : m_print_connection = LogInstance().PushBackCallback( 17 : 0 : [this](const std::string& s) { 18 : 0 : if (m_found) return; 19 : 0 : m_found = s.find(m_message) != std::string::npos && m_match(&s); 20 : 0 : }); 21 : 0 : noui_test_redirect(); 22 : 0 : } 23 : : 24 : 0 : void DebugLogHelper::check_found() 25 : : { 26 : 0 : noui_reconnect(); 27 : 0 : LogInstance().DeleteCallback(m_print_connection); 28 : 0 : if (!m_found && m_match(nullptr)) { 29 : 0 : throw std::runtime_error(strprintf("'%s' not found in debug log\n", m_message)); 30 : : } 31 : 0 : }