/ src / test / util / logging.cpp
logging.cpp
 1  // Copyright (c) 2019-present 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 <cstdlib>
12  #include <iostream>
13  
14  DebugLogHelper::DebugLogHelper(std::string message, MatchFn match)
15      : m_message{std::move(message)}, m_match(std::move(match))
16  {
17      m_print_connection = LogInstance().PushBackCallback(
18          [this](const std::string& s) {
19              if (m_found) return;
20              m_found = s.find(m_message) != std::string::npos && m_match(&s);
21          });
22      noui_test_redirect();
23  }
24  
25  DebugLogHelper::~DebugLogHelper()
26  {
27      noui_reconnect();
28      LogInstance().DeleteCallback(m_print_connection);
29      if (!m_found && m_match(nullptr)) {
30          tfm::format(std::cerr, "Fatal error: expected message not found in the debug log: '%s'\n", m_message);
31          std::abort();
32      }
33  }