Add a fork test case for logging

This commit is contained in:
Sebastian Meßmer 2015-10-17 16:42:56 +02:00
parent 82e4aefdd2
commit 08c09e4af8
2 changed files with 18 additions and 1 deletions

View File

@ -62,3 +62,20 @@ TEST_F(LoggingTest, ErrorLog) {
LOG(ERROR) << "My log message"; LOG(ERROR) << "My log message";
EXPECT_THAT(mockLogger.capturedLog(), MatchesRegex(".*\\[MockLogger\\].*\\[error\\].*My log message.*")); EXPECT_THAT(mockLogger.capturedLog(), MatchesRegex(".*\\[MockLogger\\].*\\[error\\].*My log message.*"));
} }
void logAndExit(const string &message) {
LOG(INFO) << message;
abort();
}
// fork() only forks the main thread. This test ensures that logging doesn't depend on threads that suddenly aren't
// there anymore after a fork().
TEST_F(LoggingTest, LoggingAlsoWorksAfterFork) {
auto sink = std::make_shared<spdlog::sinks::ostream_sink<std::mutex>>(std::cerr, true);
setLogger(spdlog::create("StderrLogger", {sink}));
//TODO Use EXPECT_EXIT instead once the gtest version is new enough to support it
EXPECT_DEATH(
logAndExit("My log message"),
"My log message"
);
}

View File

@ -11,7 +11,7 @@ public:
MockLogger(): MockLogger():
_capturedLogData(), _capturedLogData(),
_sink(std::make_shared<spdlog::sinks::ostream_sink<std::mutex>>(_capturedLogData, true)), _sink(std::make_shared<spdlog::sinks::ostream_sink<std::mutex>>(_capturedLogData, true)),
_logger(std::make_shared<spdlog::logger>("MockLogger", _sink)) { _logger(spdlog::create("MockLogger", {_sink})) {
} }
~MockLogger() { ~MockLogger() {