blob: 8df54509deac01ad93cb53cf608c960eba919520 [file] [log] [blame]
// Copyright 2019 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "src/developer/forensics/utils/log_format.h"
#include <lib/syslog/cpp/macros.h>
#include <lib/syslog/logger.h>
#include <lib/zx/time.h>
#include <gtest/gtest.h>
namespace forensics {
namespace {
constexpr zx::duration kLogMessageBaseTimestamp = zx::sec(15604);
constexpr uint64_t kLogMessageProcessId = 7559;
constexpr uint64_t kLogMessageThreadId = 7687;
fuchsia::logger::LogMessage BuildLogMessage(const int32_t severity, const std::string& text,
const zx::duration timestamp_offset = zx::nsec(0),
const std::vector<std::string>& tags = {}) {
fuchsia::logger::LogMessage msg{};
msg.time = (kLogMessageBaseTimestamp + timestamp_offset).get();
msg.pid = kLogMessageProcessId;
msg.tid = kLogMessageThreadId;
msg.tags = tags;
msg.severity = severity;
msg.msg = text;
return msg;
}
TEST(LogFormatTest, Check_CorrectSeverity) {
std::string log_message;
log_message = Format(BuildLogMessage(FX_LOG_INFO, "line 1"));
EXPECT_EQ(log_message, "[15604.000][07559][07687][] INFO: line 1\n");
log_message = Format(BuildLogMessage(FX_LOG_WARNING, "line 2"));
EXPECT_EQ(log_message, "[15604.000][07559][07687][] WARN: line 2\n");
log_message = Format(BuildLogMessage(FX_LOG_ERROR, "line 3"));
EXPECT_EQ(log_message, "[15604.000][07559][07687][] ERROR: line 3\n");
log_message = Format(BuildLogMessage(FX_LOG_FATAL, "line 4"));
EXPECT_EQ(log_message, "[15604.000][07559][07687][] FATAL: line 4\n");
log_message =
Format(BuildLogMessage(FX_LOG_INFO + FX_LOG_WARNING + FX_LOG_ERROR + FX_LOG_FATAL, "line 5"));
EXPECT_EQ(log_message, "[15604.000][07559][07687][] INVALID: line 5\n");
log_message = Format(BuildLogMessage(FX_LOG_TRACE, "line 6"));
EXPECT_EQ(log_message, "[15604.000][07559][07687][] TRACE: line 6\n");
log_message = Format(BuildLogMessage(FX_LOG_DEBUG, "line 7"));
EXPECT_EQ(log_message, "[15604.000][07559][07687][] DEBUG: line 7\n");
log_message = Format(BuildLogMessage(FX_LOG_INFO - 1, "line 8"));
EXPECT_EQ(log_message, "[15604.000][07559][07687][] VLOG(1): line 8\n");
log_message = Format(BuildLogMessage(FX_LOG_INFO - 12, "line 9"));
EXPECT_EQ(log_message, "[15604.000][07559][07687][] VLOG(12): line 9\n");
}
TEST(LogFormatTest, Check_CorrectTime) {
std::string log_message = Format(BuildLogMessage(FX_LOG_WARNING, "line 1", zx::msec(1)));
EXPECT_EQ(log_message, "[15604.001][07559][07687][] WARN: line 1\n");
}
TEST(LogFormatTest, Check_CorrectTags) {
std::string log_message = Format(BuildLogMessage(FX_LOG_INFO, "line 1", zx::msec(1),
/*tags=*/{"foo", "bar"}));
EXPECT_EQ(log_message, "[15604.001][07559][07687][foo, bar] INFO: line 1\n");
}
} // namespace
} // namespace forensics