58 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //
 | |
| // Copyright(c) 2018 Gabi Melman.
 | |
| // Distributed under the MIT License (http://opensource.org/licenses/MIT)
 | |
| //
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include "spdlog/details/null_mutex.h"
 | |
| #include "spdlog/sinks/base_sink.h"
 | |
| 
 | |
| #include <chrono>
 | |
| #include <mutex>
 | |
| #include <thread>
 | |
| 
 | |
| namespace spdlog {
 | |
| namespace sinks {
 | |
| 
 | |
| template<class Mutex>
 | |
| class test_sink : public base_sink<Mutex>
 | |
| {
 | |
| public:
 | |
|     size_t msg_counter()
 | |
|     {
 | |
|         return msg_counter_;
 | |
|     }
 | |
| 
 | |
|     size_t flush_counter()
 | |
|     {
 | |
|         return flush_counter_;
 | |
|     }
 | |
| 
 | |
|     void set_delay(std::chrono::milliseconds delay)
 | |
|     {
 | |
|         delay_ = delay;
 | |
|     }
 | |
| 
 | |
| protected:
 | |
|     void _sink_it(const details::log_msg &) override
 | |
|     {
 | |
|         msg_counter_++;
 | |
|         std::this_thread::sleep_for(delay_);
 | |
|     }
 | |
| 
 | |
|     void _flush() override
 | |
|     {
 | |
|         flush_counter_++;
 | |
|     }
 | |
|     size_t msg_counter_{0};
 | |
|     size_t flush_counter_{0};
 | |
|     std::chrono::milliseconds delay_{0};
 | |
| };
 | |
| 
 | |
| using test_sink_mt = test_sink<std::mutex>;
 | |
| using test_sink_st = test_sink<details::null_mutex>;
 | |
| 
 | |
| } // namespace sinks
 | |
| } // namespace spdlog
 |