/* * Copyright (C) 2018 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include <gtest/gtest.h> #include "netdutils/Log.h" android::netdutils::LogEntry globalFunctionName() { return android::netdutils::LogEntry().function(__FUNCTION__); } android::netdutils::LogEntry globalPrettyFunctionName() { return android::netdutils::LogEntry().prettyFunction(__PRETTY_FUNCTION__); } namespace android { namespace netdutils { namespace { LogEntry functionName() { return LogEntry().function(__FUNCTION__); } LogEntry prettyFunctionName() { return LogEntry().prettyFunction(__PRETTY_FUNCTION__); } } // namespace class AAA { public: AAA() = default; LogEntry functionName() { return LogEntry().function(__FUNCTION__); } LogEntry prettyFunctionName() { return LogEntry().prettyFunction(__PRETTY_FUNCTION__); } class BBB { public: BBB() = default; LogEntry functionName() { return LogEntry().function(__FUNCTION__); } LogEntry prettyFunctionName() { return LogEntry().prettyFunction(__PRETTY_FUNCTION__); } }; }; TEST(LogEntryTest, Empty) { LogEntry empty; EXPECT_EQ("", empty.toString()); } TEST(LogEntryTest, GlobalFunction) { EXPECT_EQ("globalFunctionName()", ::globalFunctionName().toString()); } TEST(LogEntryTest, GlobalPrettyFunction) { EXPECT_EQ("globalPrettyFunctionName()", ::globalPrettyFunctionName().toString()); } TEST(LogEntryTest, UnnamedNamespaceFunction) { const LogEntry entry = functionName(); EXPECT_EQ("functionName()", entry.toString()); } TEST(LogEntryTest, UnnamedNamespacePrettyFunction) { const LogEntry entry = prettyFunctionName(); EXPECT_EQ("prettyFunctionName()", entry.toString()); } TEST(LogEntryTest, ClassFunction) { const LogEntry entry = AAA().functionName(); EXPECT_EQ("functionName()", entry.toString()); } TEST(LogEntryTest, ClassPrettyFunction) { const LogEntry entry = AAA().prettyFunctionName(); EXPECT_EQ("AAA::prettyFunctionName()", entry.toString()); } TEST(LogEntryTest, InnerClassFunction) { const LogEntry entry = AAA::BBB().functionName(); EXPECT_EQ("functionName()", entry.toString()); } TEST(LogEntryTest, InnerClassPrettyFunction) { const LogEntry entry = AAA::BBB().prettyFunctionName(); EXPECT_EQ("BBB::prettyFunctionName()", entry.toString()); } TEST(LogEntryTest, PrintChainedArguments) { const LogEntry entry = LogEntry() .function("testFunc") .arg("hello") .arg(42) .arg(true); EXPECT_EQ("testFunc(hello, 42, true)", entry.toString()); } TEST(LogEntryTest, PrintIntegralTypes) { const LogEntry entry = LogEntry() .function("testFunc") .arg('A') .arg(100U) .arg(-1000LL); EXPECT_EQ("testFunc(65, 100, -1000)", entry.toString()); } TEST(LogEntryTest, PrintHex) { const std::vector<uint8_t> buf{0xDE, 0xAD, 0xBE, 0xEF}; const LogEntry entry = LogEntry().function("testFunc").arg(buf); EXPECT_EQ("testFunc({deadbeef})", entry.toString()); } TEST(LogEntryTest, PrintArgumentPack) { const LogEntry entry = LogEntry().function("testFunc").args("hello", 42, false); EXPECT_EQ("testFunc(hello, 42, false)", entry.toString()); } } // namespace netdutils } // namespace android