blob: f9886dd70178eb066ffd907bad137a53af844830 [file] [log] [blame]
// Copyright 2018 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 <lib/ddk/driver.h>
#include <cstdlib>
#include <gtest/gtest.h>
#include "src/connectivity/bluetooth/core/bt-host/common/log.h"
#include "src/lib/fxl/command_line.h"
#include "src/lib/fxl/log_settings_command_line.h"
#include "src/lib/fxl/test/test_settings.h"
BT_DECLARE_FAKE_DRIVER();
using bt::LogSeverity;
namespace {
LogSeverity FxlLogToBtLogLevel(syslog::LogSeverity severity) {
switch (severity) {
case syslog::LOG_ERROR:
return LogSeverity::ERROR;
case syslog::LOG_WARNING:
return LogSeverity::WARN;
case syslog::LOG_INFO:
return LogSeverity::INFO;
case syslog::LOG_DEBUG:
return LogSeverity::DEBUG;
case syslog::LOG_TRACE:
return LogSeverity::TRACE;
default:
break;
}
if (severity < 0) {
return LogSeverity::TRACE;
}
return LogSeverity::ERROR;
}
} // namespace
int main(int argc, char** argv) {
auto cl = fxl::CommandLineFromArgcArgv(argc, argv);
if (!fxl::SetTestSettings(cl)) {
return EXIT_FAILURE;
}
syslog::LogSettings log_settings;
log_settings.min_log_level = syslog::LOG_ERROR;
if (!fxl::ParseLogSettings(cl, &log_settings)) {
return EXIT_FAILURE;
}
// Set all library log messages to use printf instead ddk logging.
bt::UsePrintf(FxlLogToBtLogLevel(log_settings.min_log_level));
testing::InitGoogleTest(&argc, argv);
return RUN_ALL_TESTS();
}