blob: d50666ce119f5605b1f7323374ceff79bb86c44e [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/feedback/utils/log_format.h"
#include <lib/zx/time.h>
#include "src/lib/syslog/cpp/logger.h"
#include "third_party/googletest/googletest/include/gtest/gtest.h"
namespace feedback {
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(-1, "line 6"));
EXPECT_EQ(log_message, "[15604.000][07559][07687][] VLOG(1): line 6\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 feedback