/** ========================================================================== * 2013 by KjellKod.cc. This is PUBLIC DOMAIN to use at your own risk and comes * with no warranties. This code is yours to share, use and modify with no * strings attached and no restrictions or obligations. * * For more information see g3log/LICENSE or refer refer to http://unlicense.org * ============================================================================*/ #pragma once #include #include #include #include #include #include #include "g3log/logworker.hpp" #include "g3log/logmessage.hpp" #include "g3log/filesink.hpp" namespace testing_helpers { std::string mockFatalMessage(); int mockFatalSignal(); bool mockFatalWasCalled(); void mockFatalCall(g3::FatalMessagePtr fatal_message); void clearMockFatal(); bool removeFile(std::string path_to_file); bool verifyContent(const std::string& total_text, std::string msg_to_find); std::string readFileToText(std::string filename); /** After initializing ScopedCout all std::couts is redirected to the buffer @verbatim Example: stringstream buffer; ScopedCout guard(std::cout, &buffer); // std::cerr is also fine cout << "Hello World"; ASSERT_STREQ(buffer.str().c_str(), "Hello World"); */ class ScopedOut { std::ostream& _out_type; std::streambuf* _old_cout; public: explicit ScopedOut(std::ostream& out_type, std::stringstream* buffer) : _out_type(out_type) , _old_cout(_out_type.rdbuf()) { _out_type.rdbuf(buffer->rdbuf()); } virtual ~ScopedOut() { _out_type.rdbuf(_old_cout); } }; /// RAII cluttering files cleanup class LogFileCleaner { private: std::vector logs_to_clean_; std::mutex g_mutex; public: size_t size(); LogFileCleaner() {} virtual ~LogFileCleaner(); void addLogToClean(std::string path_to_log); }; struct ScopedLogger { ScopedLogger(); virtual ~ScopedLogger(); g3::LogWorker* get(); std::unique_ptr _currentWorker; }; /** RAII temporarily replace of logger * and restoration of original logger at scope end*/ struct RestoreFileLogger { explicit RestoreFileLogger(std::string directory); ~RestoreFileLogger(); std::unique_ptr _scope; void reset() { _scope.reset();} template typename std::result_of::type callToLogger(Call call, Args&& ... args) { auto func = std::bind(call, _scope->get(), std::forward(args)...); return func(); } std::string logFile(); std::string resetAndRetrieveContent(); std::unique_ptr> _handle; std::string _log_file; }; typedef std::shared_ptr> AtomicBoolPtr; typedef std::shared_ptr> AtomicIntPtr; struct ScopedSetTrue { AtomicBoolPtr _flag; AtomicIntPtr _count; explicit ScopedSetTrue(AtomicBoolPtr flag, AtomicIntPtr count) : _flag(flag), _count(count) { } void ReceiveMsg(std::string message) { std::chrono::milliseconds wait{100}; std::this_thread::sleep_for(wait); ++(*_count); } ~ScopedSetTrue() { (*_flag) = true; } }; } // testing_helpers #ifdef CHANGE_G3LOG_DEBUG_TO_DBUG #undef DEBUG #define DEBUG DBUG #endif