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