|  | /* | 
|  | * 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 |