OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 <stddef.h> | 5 #include <stddef.h> |
6 | 6 |
7 #include "base/json/json_writer.h" | 7 #include "base/json/json_writer.h" |
8 #include "base/strings/string_split.h" | 8 #include "base/strings/string_split.h" |
9 #include "base/strings/stringprintf.h" | 9 #include "base/strings/stringprintf.h" |
10 #include "chrome/browser/browser_process.h" | 10 #include "chrome/browser/browser_process.h" |
(...skipping 15 matching lines...) Expand all Loading... |
26 using extensions::WebrtcLoggingPrivateSetMetaDataFunction; | 26 using extensions::WebrtcLoggingPrivateSetMetaDataFunction; |
27 using extensions::WebrtcLoggingPrivateStartFunction; | 27 using extensions::WebrtcLoggingPrivateStartFunction; |
28 using extensions::WebrtcLoggingPrivateStartRtpDumpFunction; | 28 using extensions::WebrtcLoggingPrivateStartRtpDumpFunction; |
29 using extensions::WebrtcLoggingPrivateStopFunction; | 29 using extensions::WebrtcLoggingPrivateStopFunction; |
30 using extensions::WebrtcLoggingPrivateStopRtpDumpFunction; | 30 using extensions::WebrtcLoggingPrivateStopRtpDumpFunction; |
31 using extensions::WebrtcLoggingPrivateStoreFunction; | 31 using extensions::WebrtcLoggingPrivateStoreFunction; |
32 using extensions::WebrtcLoggingPrivateUploadFunction; | 32 using extensions::WebrtcLoggingPrivateUploadFunction; |
33 using extensions::WebrtcLoggingPrivateUploadStoredFunction; | 33 using extensions::WebrtcLoggingPrivateUploadStoredFunction; |
34 using extensions::WebrtcLoggingPrivateStartAudioDebugRecordingsFunction; | 34 using extensions::WebrtcLoggingPrivateStartAudioDebugRecordingsFunction; |
35 using extensions::WebrtcLoggingPrivateStopAudioDebugRecordingsFunction; | 35 using extensions::WebrtcLoggingPrivateStopAudioDebugRecordingsFunction; |
| 36 using extensions::WebrtcLoggingPrivateStartRtcEventLoggingFunction; |
| 37 using extensions::WebrtcLoggingPrivateStopRtcEventLoggingFunction; |
36 | 38 |
37 namespace utils = extension_function_test_utils; | 39 namespace utils = extension_function_test_utils; |
38 | 40 |
39 namespace { | 41 namespace { |
40 | 42 |
41 static const char kTestLoggingSessionIdKey[] = "app_session_id"; | 43 static const char kTestLoggingSessionIdKey[] = "app_session_id"; |
42 static const char kTestLoggingSessionIdValue[] = "0123456789abcdef"; | 44 static const char kTestLoggingSessionIdValue[] = "0123456789abcdef"; |
43 static const char kTestLoggingUrl[] = "dummy url string"; | 45 static const char kTestLoggingUrl[] = "dummy url string"; |
44 | 46 |
45 std::string ParamsToString(const base::ListValue& parameters) { | 47 std::string ParamsToString(const base::ListValue& parameters) { |
(...skipping 128 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
174 params, true); | 176 params, true); |
175 } | 177 } |
176 | 178 |
177 bool StopAudioDebugRecordings() { | 179 bool StopAudioDebugRecordings() { |
178 base::ListValue params; | 180 base::ListValue params; |
179 AppendTabIdAndUrl(¶ms); | 181 AppendTabIdAndUrl(¶ms); |
180 return RunFunction<WebrtcLoggingPrivateStopAudioDebugRecordingsFunction>( | 182 return RunFunction<WebrtcLoggingPrivateStopAudioDebugRecordingsFunction>( |
181 params, true); | 183 params, true); |
182 } | 184 } |
183 | 185 |
| 186 bool StartRtcEventLogging(int seconds) { |
| 187 base::ListValue params; |
| 188 AppendTabIdAndUrl(¶ms); |
| 189 params.AppendInteger(seconds); |
| 190 return RunFunction<WebrtcLoggingPrivateStartRtcEventLoggingFunction>(params, |
| 191 true); |
| 192 } |
| 193 |
| 194 bool StopRtcEventLogging() { |
| 195 base::ListValue params; |
| 196 AppendTabIdAndUrl(¶ms); |
| 197 return RunFunction<WebrtcLoggingPrivateStopRtcEventLoggingFunction>(params, |
| 198 true); |
| 199 } |
| 200 |
184 private: | 201 private: |
185 scoped_refptr<Extension> extension_; | 202 scoped_refptr<Extension> extension_; |
186 }; | 203 }; |
187 | 204 |
188 // Helper class to temporarily tell the uploader to save the multipart buffer to | 205 // Helper class to temporarily tell the uploader to save the multipart buffer to |
189 // a test string instead of uploading. | 206 // a test string instead of uploading. |
190 class ScopedOverrideUploadBuffer { | 207 class ScopedOverrideUploadBuffer { |
191 public: | 208 public: |
192 ScopedOverrideUploadBuffer() { | 209 ScopedOverrideUploadBuffer() { |
193 g_browser_process->webrtc_log_uploader()-> | 210 g_browser_process->webrtc_log_uploader()-> |
(...skipping 242 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
436 ASSERT_TRUE(StartAudioDebugRecordings(0)); | 453 ASSERT_TRUE(StartAudioDebugRecordings(0)); |
437 ASSERT_TRUE(StopAudioDebugRecordings()); | 454 ASSERT_TRUE(StopAudioDebugRecordings()); |
438 } | 455 } |
439 | 456 |
440 IN_PROC_BROWSER_TEST_F(WebrtcLoggingPrivateApiTest, | 457 IN_PROC_BROWSER_TEST_F(WebrtcLoggingPrivateApiTest, |
441 TestStartTimedAudioDebugRecordings) { | 458 TestStartTimedAudioDebugRecordings) { |
442 base::CommandLine::ForCurrentProcess()->AppendSwitch( | 459 base::CommandLine::ForCurrentProcess()->AppendSwitch( |
443 switches::kEnableAudioDebugRecordingsFromExtension); | 460 switches::kEnableAudioDebugRecordingsFromExtension); |
444 ASSERT_TRUE(StartAudioDebugRecordings(1)); | 461 ASSERT_TRUE(StartAudioDebugRecordings(1)); |
445 } | 462 } |
| 463 |
| 464 IN_PROC_BROWSER_TEST_F(WebrtcLoggingPrivateApiTest, |
| 465 TestStartStopRtcEventLogging) { |
| 466 // TODO(terelius): These tests are missing verification of the actual RTC |
| 467 // event log data. Maybe this could be incorporated into crbug.com/569957, |
| 468 // and solved at the same time? |
| 469 base::CommandLine::ForCurrentProcess()->AppendSwitch( |
| 470 switches::kEnableRtcEventLoggingFromExtension); |
| 471 ASSERT_TRUE(StartRtcEventLogging(0)); |
| 472 ASSERT_TRUE(StopRtcEventLogging()); |
| 473 } |
| 474 |
| 475 IN_PROC_BROWSER_TEST_F(WebrtcLoggingPrivateApiTest, |
| 476 TestStartTimedRtcEventLogging) { |
| 477 base::CommandLine::ForCurrentProcess()->AppendSwitch( |
| 478 switches::kEnableRtcEventLoggingFromExtension); |
| 479 ASSERT_TRUE(StartRtcEventLogging(1)); |
| 480 } |
OLD | NEW |