Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/test/chromedriver/logging.h" | 5 #include "chrome/test/chromedriver/logging.h" |
| 6 | 6 |
| 7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
| 8 #include "base/logging.h" | 8 #include "base/logging.h" |
| 9 #include "base/time.h" | 9 #include "base/time.h" |
| 10 #include "chrome/test/chromedriver/capabilities.h" | 10 #include "chrome/test/chromedriver/capabilities.h" |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 26 WebDriverLog::WebDriverLevel kLogLevelToWebDriverLevels[] = { | 26 WebDriverLog::WebDriverLevel kLogLevelToWebDriverLevels[] = { |
| 27 WebDriverLog::kWdDebug, // kDebug | 27 WebDriverLog::kWdDebug, // kDebug |
| 28 WebDriverLog::kWdInfo, // kLog | 28 WebDriverLog::kWdInfo, // kLog |
| 29 WebDriverLog::kWdWarning, // kWarning | 29 WebDriverLog::kWdWarning, // kWarning |
| 30 WebDriverLog::kWdSevere // kError | 30 WebDriverLog::kWdSevere // kError |
| 31 }; | 31 }; |
| 32 | 32 |
| 33 WebDriverLog::WebDriverLevel LogLevelToWebDriverLevel(Log::Level level) { | 33 WebDriverLog::WebDriverLevel LogLevelToWebDriverLevel(Log::Level level) { |
| 34 const int index = level - Log::kDebug; | 34 const int index = level - Log::kDebug; |
| 35 CHECK(index >= 0); | 35 CHECK(index >= 0); |
| 36 CHECK(static_cast<size_t>(index) < arraysize(kLogLevelToWebDriverLevels)); | 36 CHECK(static_cast<size_t>(index) < arraysize(kLogLevelToWebDriverLevels)); |
|
jdennett
2013/05/13 17:56:49
Why not CHECK_GE and CHECK_LT?
klm
2013/05/13 20:35:57
Done.
| |
| 37 return kLogLevelToWebDriverLevels[index]; | 37 return kLogLevelToWebDriverLevels[index]; |
| 38 } | 38 } |
| 39 | 39 |
| 40 std::string GetWebDriverLevelName( | 40 std::string GetWebDriverLevelName( |
| 41 const WebDriverLog::WebDriverLevel level) { | 41 const WebDriverLog::WebDriverLevel level) { |
| 42 const int index = level - WebDriverLog::kWdAll; | 42 const int index = level - WebDriverLog::kWdAll; |
| 43 CHECK(index >= 0); | 43 CHECK(index >= 0); |
| 44 CHECK(static_cast<size_t>(index) < arraysize(kWebDriverLevelNames)); | 44 CHECK(static_cast<size_t>(index) < arraysize(kWebDriverLevelNames)); |
| 45 return kWebDriverLevelNames[index]; | 45 return kWebDriverLevelNames[index]; |
| 46 } | 46 } |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 63 WebDriverLog::WebDriverLog( | 63 WebDriverLog::WebDriverLog( |
| 64 const std::string& type, WebDriverLog::WebDriverLevel min_wd_level) | 64 const std::string& type, WebDriverLog::WebDriverLevel min_wd_level) |
| 65 : type_(type), | 65 : type_(type), |
| 66 min_wd_level_(min_wd_level), | 66 min_wd_level_(min_wd_level), |
| 67 entries_(new base::ListValue()) { | 67 entries_(new base::ListValue()) { |
| 68 VLOG(1) << "Log(" << type_ << ", " << min_wd_level_ << ")"; | 68 VLOG(1) << "Log(" << type_ << ", " << min_wd_level_ << ")"; |
| 69 } | 69 } |
| 70 | 70 |
| 71 WebDriverLog::~WebDriverLog() { | 71 WebDriverLog::~WebDriverLog() { |
| 72 VLOG(1) << "Log type '" << type_ << "' lost " | 72 VLOG(1) << "Log type '" << type_ << "' lost " |
| 73 << entries_->GetSize() << " entries on destruction"; | 73 << entries_->GetSize() << " entries on destruction"; |
|
jdennett
2013/05/13 17:56:49
Align first << with the first one of the previous
klm
2013/05/13 20:35:57
Done.
| |
| 74 } | 74 } |
| 75 | 75 |
| 76 const std::string& WebDriverLog::GetType() { | 76 const std::string& WebDriverLog::GetType() { |
| 77 return type_; | 77 return type_; |
| 78 } | 78 } |
| 79 | 79 |
| 80 void WebDriverLog::AddEntry(const base::Time& time, | 80 void WebDriverLog::AddEntry(const base::Time& time, |
| 81 Log::Level level, | 81 Log::Level level, |
| 82 const std::string& message) { | 82 const std::string& message) { |
| 83 const WebDriverLog::WebDriverLevel wd_level = LogLevelToWebDriverLevel(level); | 83 const WebDriverLog::WebDriverLevel wd_level = LogLevelToWebDriverLevel(level); |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 103 ScopedVector<DevToolsEventListener> listeners; | 103 ScopedVector<DevToolsEventListener> listeners; |
| 104 WebDriverLog::WebDriverLevel browser_log_level = WebDriverLog::kWdInfo; | 104 WebDriverLog::WebDriverLevel browser_log_level = WebDriverLog::kWdInfo; |
| 105 | 105 |
| 106 if (capabilities.logging_prefs) { | 106 if (capabilities.logging_prefs) { |
| 107 for (DictionaryValue::Iterator pref(*capabilities.logging_prefs); | 107 for (DictionaryValue::Iterator pref(*capabilities.logging_prefs); |
| 108 !pref.IsAtEnd(); pref.Advance()) { | 108 !pref.IsAtEnd(); pref.Advance()) { |
| 109 const std::string type = pref.key(); | 109 const std::string type = pref.key(); |
| 110 std::string level_name; | 110 std::string level_name; |
| 111 if (!pref.value().GetAsString(&level_name)) { | 111 if (!pref.value().GetAsString(&level_name)) { |
| 112 return Status(kUnknownError, | 112 return Status(kUnknownError, |
| 113 "logging level must be a string for log type: " + type); | 113 "logging level must be a string for log type: " + type); |
|
jdennett
2013/05/13 17:56:49
StrCat would have one small readability advantage
klm
2013/05/13 20:35:57
Offhand doesn't look like there is StrCat in Chrom
| |
| 114 } | 114 } |
| 115 WebDriverLog::WebDriverLevel level = WebDriverLog::kWdOff; | 115 WebDriverLog::WebDriverLevel level = WebDriverLog::kWdOff; |
| 116 if (!WebDriverLog::NameToLevel(level_name, &level)) { | 116 if (!WebDriverLog::NameToLevel(level_name, &level)) { |
| 117 return Status(kUnknownError, | 117 return Status(kUnknownError, |
| 118 "invalid log level \"" + level_name + | 118 "invalid log level \"" + level_name + |
| 119 "\" for type: " + type); | 119 "\" for type: " + type); |
| 120 } | 120 } |
| 121 if ("performance" == type) { | 121 if ("performance" == type) { |
| 122 if (WebDriverLog::kWdOff != level) { | 122 if (WebDriverLog::kWdOff != level) { |
| 123 WebDriverLog* log = new WebDriverLog(type, WebDriverLog::kWdAll); | 123 WebDriverLog* log = new WebDriverLog(type, WebDriverLog::kWdAll); |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 138 WebDriverLog* browser_log = new WebDriverLog("browser", browser_log_level); | 138 WebDriverLog* browser_log = new WebDriverLog("browser", browser_log_level); |
| 139 devtools_logs.push_back(browser_log); | 139 devtools_logs.push_back(browser_log); |
| 140 // If the level is OFF, don't even bother listening for DevTools events. | 140 // If the level is OFF, don't even bother listening for DevTools events. |
| 141 if (browser_log_level != WebDriverLog::kWdOff) | 141 if (browser_log_level != WebDriverLog::kWdOff) |
| 142 listeners.push_back(new ConsoleLogger(browser_log)); | 142 listeners.push_back(new ConsoleLogger(browser_log)); |
| 143 | 143 |
| 144 out_devtools_logs->swap(devtools_logs); | 144 out_devtools_logs->swap(devtools_logs); |
| 145 out_listeners->swap(listeners); | 145 out_listeners->swap(listeners); |
| 146 return Status(kOk); | 146 return Status(kOk); |
| 147 } | 147 } |
| 148 | |
| OLD | NEW |