LCOV - code coverage report
Current view: top level - src/test/util - logging.h (source / functions) Coverage Total Hit
Test: test_bitcoin_coverage.info Lines: 100.0 % 1 1
Test Date: 2025-01-22 04:36:36 Functions: 100.0 % 1 1

            Line data    Source code
       1              : // Copyright (c) 2019-2022 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              : #ifndef BITCOIN_TEST_UTIL_LOGGING_H
       6              : #define BITCOIN_TEST_UTIL_LOGGING_H
       7              : 
       8              : #include <util/macros.h>
       9              : 
      10              : #include <functional>
      11              : #include <list>
      12              : #include <string>
      13              : 
      14              : class DebugLogHelper
      15              : {
      16              :     const std::string m_message;
      17              :     bool m_found{false};
      18              :     std::list<std::function<void(const std::string&)>>::iterator m_print_connection;
      19              : 
      20              :     //! Custom match checking function.
      21              :     //!
      22              :     //! Invoked with pointers to lines containing matching strings, and with
      23              :     //! null if check_found() is called without any successful match.
      24              :     //!
      25              :     //! Can return true to enable default DebugLogHelper behavior of:
      26              :     //! (1) ending search after first successful match, and
      27              :     //! (2) raising an error in check_found if no match was found
      28              :     //! Can return false to do the opposite in either case.
      29              :     using MatchFn = std::function<bool(const std::string* line)>;
      30              :     MatchFn m_match;
      31              : 
      32              :     void check_found();
      33              : 
      34              : public:
      35              :     explicit DebugLogHelper(std::string message, MatchFn match = [](const std::string*){ return true; });
      36           55 :     ~DebugLogHelper() { check_found(); }
      37              : };
      38              : 
      39              : #define ASSERT_DEBUG_LOG(message) DebugLogHelper UNIQUE_NAME(debugloghelper)(message)
      40              : 
      41              : #endif // BITCOIN_TEST_UTIL_LOGGING_H
        

Generated by: LCOV version 2.0-1