• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 
AsString(talk_base::LoggingSeverity severity)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 
ContainsString(const std::string & original,const char * string_to_match)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 
Initialize(int verbosity_level)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 
TEST(LibjingleLogTest,DefaultConfiguration)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 
TEST(LibjingleLogTest,InfoConfiguration)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 
TEST(LibjingleLogTest,LogEverythingConfiguration)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