blob: 51e2013c404a2d07248f571dc7baee39c6afeb05 [file] [log] [blame]
// Copyright 2021 The Chromium 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 "base/fuchsia/scoped_fx_logger.h"
#include <fuchsia/logger/cpp/fidl.h>
#include <lib/fidl/cpp/binding.h>
#include <lib/sys/cpp/component_context.h>
#include "base/fuchsia/fuchsia_logging.h"
#include "base/fuchsia/process_context.h"
#include "base/fuchsia/test_log_listener_safe.h"
#include "base/logging.h"
#include "base/process/process.h"
#include "base/test/scoped_logging_settings.h"
#include "base/test/task_environment.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace base {
namespace {
class MockLogSource {
public:
MOCK_METHOD0(Log, const char*());
};
// Configures |listener| to listen for messages from the current process.
void ListenFilteredByPid(SimpleTestLogListener& listener) {
// Connect the test LogListenerSafe to the Log.
std::unique_ptr<fuchsia::logger::LogFilterOptions> options =
std::make_unique<fuchsia::logger::LogFilterOptions>();
options->filter_by_pid = true;
options->pid = Process::Current().Pid();
options->min_severity = fuchsia::logger::LogLevelFilter::INFO;
fuchsia::logger::LogPtr log =
ComponentContextForProcess()->svc()->Connect<fuchsia::logger::Log>();
listener.ListenToLog(log.get(), std::move(options));
}
} // namespace
// Verifies that calling the log macro goes to the Fuchsia system logs, by
// default.
TEST(FuchsiaLoggingTest, SystemLogging) {
constexpr char kLogMessage[] = "This is FuchsiaLoggingTest.SystemLogging!";
test::SingleThreadTaskEnvironment task_environment_{
test::SingleThreadTaskEnvironment::MainThreadType::IO};
SimpleTestLogListener listener;
ListenFilteredByPid(listener);
// Ensure that logging is directed to the system debug log.
logging::ScopedLoggingSettings scoped_logging_settings;
CHECK(logging::InitLogging({.logging_dest = logging::LOG_DEFAULT}));
// Emit the test log message, and spin the loop until it is reported to the
// test listener.
LOG(ERROR) << kLogMessage;
absl::optional<fuchsia::logger::LogMessage> logged_message =
listener.RunUntilMessageReceived(kLogMessage);
ASSERT_TRUE(logged_message.has_value());
EXPECT_EQ(logged_message->severity,
static_cast<int32_t>(fuchsia::logger::LogLevelFilter::ERROR));
ASSERT_EQ(logged_message->tags.size(), 1u);
EXPECT_EQ(logged_message->tags[0], "base_unittests__exec");
}
// Verifies that configuring a system logger with multiple tags works.
TEST(FuchsiaLoggingTest, SystemLoggingMultipleTags) {
constexpr char kLogMessage[] =
"This is FuchsiaLoggingTest.SystemLoggingMultipleTags!";
const std::vector<StringPiece> kTags = {"tag1", "tag2"};
test::SingleThreadTaskEnvironment task_environment_{
test::SingleThreadTaskEnvironment::MainThreadType::IO};
SimpleTestLogListener listener;
ListenFilteredByPid(listener);
// Create a logger with multiple tags and emit a message to it.
ScopedFxLogger logger = ScopedFxLogger::CreateFromLogSink(
ComponentContextForProcess()->svc()->Connect<fuchsia::logger::LogSink>(),
kTags);
logger.LogMessage("", 0, kLogMessage, FUCHSIA_LOG_ERROR);
absl::optional<fuchsia::logger::LogMessage> logged_message =
listener.RunUntilMessageReceived(kLogMessage);
ASSERT_TRUE(logged_message.has_value());
auto tags = std::vector<StringPiece>(logged_message->tags.begin(),
logged_message->tags.end());
EXPECT_EQ(tags, kTags);
}
// Verifies the Fuchsia-specific ZX_*() logging macros.
TEST(FuchsiaLoggingTest, FuchsiaLogging) {
MockLogSource mock_log_source;
EXPECT_CALL(mock_log_source, Log())
.Times(DCHECK_IS_ON() ? 2 : 1)
.WillRepeatedly(testing::Return("log message"));
logging::ScopedLoggingSettings scoped_logging_settings;
logging::SetMinLogLevel(logging::LOGGING_INFO);
EXPECT_TRUE(LOG_IS_ON(INFO));
EXPECT_EQ(DCHECK_IS_ON(), DLOG_IS_ON(INFO));
ZX_LOG(INFO, ZX_ERR_INTERNAL) << mock_log_source.Log();
ZX_DLOG(INFO, ZX_ERR_INTERNAL) << mock_log_source.Log();
ZX_CHECK(true, ZX_ERR_INTERNAL);
ZX_DCHECK(true, ZX_ERR_INTERNAL);
}
} // namespace base