1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style license that can be 3 // found in the LICENSE file. 4 5 // Note: this test tests LOG_V and LOG_E since all other logs are expressed 6 // in forms of them. LOG is also tested for good measure. 7 // Also note that we are only allowed to call InitLogging() twice so the test 8 // cases are more dense than normal. 9 10 // The following include must be first in this file. It ensures that 11 // libjingle style logging is used. 12 #define LOGGING_INSIDE_LIBJINGLE 13 14 #include "third_party/libjingle/overrides/talk/base/logging.h" 15 16 #include "base/command_line.h" 17 #include "base/file_util.h" 18 #include "testing/gtest/include/gtest/gtest.h" 19 20 #if defined(OS_WIN) 21 static const wchar_t* const log_file_name = L"libjingle_logging.log"; 22 #else 23 static const char* const log_file_name = "libjingle_logging.log"; 24 #endif 25 26 static const int kDefaultVerbosity = 0; 27 28 static const char* AsString(talk_base::LoggingSeverity severity) { 29 switch (severity) { 30 case talk_base::LS_ERROR: 31 return "LS_ERROR"; 32 case talk_base::LS_WARNING: 33 return "LS_WARNING"; 34 case talk_base::LS_INFO: 35 return "LS_INFO"; 36 case talk_base::LS_VERBOSE: 37 return "LS_VERBOSE"; 38 case talk_base::LS_SENSITIVE: 39 return "LS_SENSITIVE"; 40 default: 41 return ""; 42 } 43 } 44 45 static bool ContainsString(const std::string& original, 46 const char* string_to_match) { 47 return original.find(string_to_match) != std::string::npos; 48 } 49 50 static bool Initialize(int verbosity_level) { 51 if (verbosity_level != kDefaultVerbosity) { 52 // Update the command line with specified verbosity level for this file. 53 CommandLine* command_line = CommandLine::ForCurrentProcess(); 54 std::ostringstream value_stream; 55 value_stream << "logging_unittest=" << verbosity_level; 56 const std::string& value = value_stream.str(); 57 command_line->AppendSwitchASCII("vmodule", value); 58 } 59 60 // The command line flags are parsed here and the log file name is set. 61 logging::LoggingSettings settings; 62 settings.logging_dest = logging::LOG_TO_FILE; 63 settings.log_file = log_file_name; 64 settings.lock_log = logging::DONT_LOCK_LOG_FILE; 65 settings.delete_old = logging::DELETE_OLD_LOG_FILE; 66 if (!logging::InitLogging(settings)) { 67 return false; 68 } 69 EXPECT_TRUE(VLOG_IS_ON(verbosity_level)); 70 EXPECT_FALSE(VLOG_IS_ON(verbosity_level + 1)); 71 return true; 72 } 73 74 TEST(LibjingleLogTest, DefaultConfiguration) { 75 ASSERT_TRUE(Initialize(kDefaultVerbosity)); 76 77 // In the default configuration nothing should be logged. 78 LOG_V(talk_base::LS_ERROR) << AsString(talk_base::LS_ERROR); 79 LOG_V(talk_base::LS_WARNING) << AsString(talk_base::LS_WARNING); 80 LOG_V(talk_base::LS_INFO) << AsString(talk_base::LS_INFO); 81 LOG_V(talk_base::LS_VERBOSE) << AsString(talk_base::LS_VERBOSE); 82 LOG_V(talk_base::LS_SENSITIVE) << AsString(talk_base::LS_SENSITIVE); 83 84 // Read file to string. 85 base::FilePath file_path(log_file_name); 86 std::string contents_of_file; 87 base::ReadFileToString(file_path, &contents_of_file); 88 89 // Make sure string contains the expected values. 90 EXPECT_FALSE(ContainsString(contents_of_file, AsString(talk_base::LS_ERROR))); 91 EXPECT_FALSE(ContainsString(contents_of_file, 92 AsString(talk_base::LS_WARNING))); 93 EXPECT_FALSE(ContainsString(contents_of_file, AsString(talk_base::LS_INFO))); 94 EXPECT_FALSE(ContainsString(contents_of_file, 95 AsString(talk_base::LS_VERBOSE))); 96 EXPECT_FALSE(ContainsString(contents_of_file, 97 AsString(talk_base::LS_SENSITIVE))); 98 } 99 100 TEST(LibjingleLogTest, InfoConfiguration) { 101 ASSERT_TRUE(Initialize(talk_base::LS_INFO)); 102 103 // In this configuration everything lower or equal to LS_INFO should be 104 // logged. 105 LOG_V(talk_base::LS_ERROR) << AsString(talk_base::LS_ERROR); 106 LOG_V(talk_base::LS_WARNING) << AsString(talk_base::LS_WARNING); 107 LOG_V(talk_base::LS_INFO) << AsString(talk_base::LS_INFO); 108 LOG_V(talk_base::LS_VERBOSE) << AsString(talk_base::LS_VERBOSE); 109 LOG_V(talk_base::LS_SENSITIVE) << AsString(talk_base::LS_SENSITIVE); 110 111 // Read file to string. 112 base::FilePath file_path(log_file_name); 113 std::string contents_of_file; 114 base::ReadFileToString(file_path, &contents_of_file); 115 116 // Make sure string contains the expected values. 117 EXPECT_TRUE(ContainsString(contents_of_file, AsString(talk_base::LS_ERROR))); 118 EXPECT_TRUE(ContainsString(contents_of_file, 119 AsString(talk_base::LS_WARNING))); 120 EXPECT_TRUE(ContainsString(contents_of_file, AsString(talk_base::LS_INFO))); 121 EXPECT_FALSE(ContainsString(contents_of_file, 122 AsString(talk_base::LS_VERBOSE))); 123 EXPECT_FALSE(ContainsString(contents_of_file, 124 AsString(talk_base::LS_SENSITIVE))); 125 126 // Also check that the log is proper. 127 EXPECT_TRUE(ContainsString(contents_of_file, "logging_unittest.cc")); 128 EXPECT_FALSE(ContainsString(contents_of_file, "logging.h")); 129 EXPECT_FALSE(ContainsString(contents_of_file, "logging.cc")); 130 } 131 132 TEST(LibjingleLogTest, LogEverythingConfiguration) { 133 ASSERT_TRUE(Initialize(talk_base::LS_SENSITIVE)); 134 135 // In this configuration everything should be logged. 136 LOG_V(talk_base::LS_ERROR) << AsString(talk_base::LS_ERROR); 137 LOG_V(talk_base::LS_WARNING) << AsString(talk_base::LS_WARNING); 138 LOG(LS_INFO) << AsString(talk_base::LS_INFO); 139 static const int kFakeError = 1; 140 LOG_E(LS_INFO, EN, kFakeError) << "LOG_E(" << AsString(talk_base::LS_INFO) << 141 ")"; 142 LOG_V(talk_base::LS_VERBOSE) << AsString(talk_base::LS_VERBOSE); 143 LOG_V(talk_base::LS_SENSITIVE) << AsString(talk_base::LS_SENSITIVE); 144 145 // Read file to string. 146 base::FilePath file_path(log_file_name); 147 std::string contents_of_file; 148 base::ReadFileToString(file_path, &contents_of_file); 149 150 // Make sure string contains the expected values. 151 EXPECT_TRUE(ContainsString(contents_of_file, AsString(talk_base::LS_ERROR))); 152 EXPECT_TRUE(ContainsString(contents_of_file, 153 AsString(talk_base::LS_WARNING))); 154 EXPECT_TRUE(ContainsString(contents_of_file, AsString(talk_base::LS_INFO))); 155 // LOG_E 156 EXPECT_TRUE(ContainsString(contents_of_file, strerror(kFakeError))); 157 EXPECT_TRUE(ContainsString(contents_of_file, 158 AsString(talk_base::LS_VERBOSE))); 159 EXPECT_TRUE(ContainsString(contents_of_file, 160 AsString(talk_base::LS_SENSITIVE))); 161 } 162