Line data Source code
1 : // Copyright (c) 2019 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 6 : DebugLogHelper(std::string message, MatchFn match = [](const std::string*){ return true; }); 36 16 : ~DebugLogHelper() { check_found(); } 37 : }; 38 : 39 : #define ASSERT_DEBUG_LOG(message) DebugLogHelper PASTE2(debugloghelper, __COUNTER__)(message) 40 : 41 : #endif // BITCOIN_TEST_UTIL_LOGGING_H