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 <stddef.h> | 5 #include <stddef.h> |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
11 #include "base/location.h" | 11 #include "base/location.h" |
12 #include "base/macros.h" | 12 #include "base/macros.h" |
13 #include "base/run_loop.h" | 13 #include "base/run_loop.h" |
14 #include "base/single_thread_task_runner.h" | |
15 #include "base/strings/string_number_conversions.h" | 14 #include "base/strings/string_number_conversions.h" |
16 #include "base/thread_task_runner_handle.h" | 15 #include "base/thread_task_runner_handle.h" |
17 #include "build/build_config.h" | 16 #include "build/build_config.h" |
18 #include "content/browser/browser_thread_impl.h" | 17 #include "content/browser/browser_thread_impl.h" |
19 #include "content/browser/renderer_host/media/media_stream_manager.h" | 18 #include "content/browser/renderer_host/media/media_stream_manager.h" |
20 #include "content/browser/renderer_host/media/media_stream_requester.h" | 19 #include "content/browser/renderer_host/media/media_stream_requester.h" |
21 #include "content/browser/renderer_host/media/media_stream_ui_proxy.h" | 20 #include "content/browser/renderer_host/media/media_stream_ui_proxy.h" |
22 #include "content/common/media/media_stream_options.h" | 21 #include "content/common/media/media_stream_options.h" |
23 #include "content/public/common/content_switches.h" | 22 #include "content/public/common/content_switches.h" |
24 #include "content/public/test/test_browser_thread_bundle.h" | 23 #include "content/public/test/test_browser_thread_bundle.h" |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
64 | 63 |
65 ResourceContext::SaltCallback GetMockSaltCallback() { | 64 ResourceContext::SaltCallback GetMockSaltCallback() { |
66 return base::Bind(&ReturnMockSalt); | 65 return base::Bind(&ReturnMockSalt); |
67 } | 66 } |
68 | 67 |
69 // This class mocks the audio manager and overrides some methods to ensure that | 68 // This class mocks the audio manager and overrides some methods to ensure that |
70 // we can run our tests on the buildbots. | 69 // we can run our tests on the buildbots. |
71 class MockAudioManager : public AudioManagerPlatform { | 70 class MockAudioManager : public AudioManagerPlatform { |
72 public: | 71 public: |
73 MockAudioManager() | 72 MockAudioManager() |
74 : AudioManagerPlatform(&fake_audio_log_factory_), | 73 : AudioManagerPlatform(base::ThreadTaskRunnerHandle::Get(), |
| 74 base::ThreadTaskRunnerHandle::Get(), |
| 75 &fake_audio_log_factory_), |
75 num_output_devices_(2) {} | 76 num_output_devices_(2) {} |
76 ~MockAudioManager() override {} | 77 ~MockAudioManager() override {} |
77 | 78 |
78 void GetAudioInputDeviceNames( | 79 void GetAudioInputDeviceNames( |
79 media::AudioDeviceNames* device_names) override { | 80 media::AudioDeviceNames* device_names) override { |
80 DCHECK(device_names->empty()); | 81 DCHECK(device_names->empty()); |
81 if (HasAudioInputDevices()) { | 82 if (HasAudioInputDevices()) { |
82 AudioManagerBase::GetAudioInputDeviceNames(device_names); | 83 AudioManagerBase::GetAudioInputDeviceNames(device_names); |
83 } else { | 84 } else { |
84 device_names->push_back(media::AudioDeviceName("fake_device_name", | 85 device_names->push_back(media::AudioDeviceName("fake_device_name", |
(...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
168 DISALLOW_COPY_AND_ASSIGN(MockMediaStreamRequester); | 169 DISALLOW_COPY_AND_ASSIGN(MockMediaStreamRequester); |
169 base::RunLoop* run_loop_; | 170 base::RunLoop* run_loop_; |
170 size_t num_expected_devices_; | 171 size_t num_expected_devices_; |
171 }; | 172 }; |
172 | 173 |
173 } // namespace | 174 } // namespace |
174 | 175 |
175 class MediaStreamManagerTest : public ::testing::Test { | 176 class MediaStreamManagerTest : public ::testing::Test { |
176 public: | 177 public: |
177 MediaStreamManagerTest() | 178 MediaStreamManagerTest() |
178 : thread_bundle_(content::TestBrowserThreadBundle::IO_MAINLOOP), | 179 : thread_bundle_(content::TestBrowserThreadBundle::IO_MAINLOOP) { |
179 task_runner_(base::ThreadTaskRunnerHandle::Get()) { | |
180 audio_manager_.reset(new MockAudioManager()); | 180 audio_manager_.reset(new MockAudioManager()); |
181 media_stream_manager_.reset(new MediaStreamManager(audio_manager_.get())); | 181 media_stream_manager_.reset(new MediaStreamManager(audio_manager_.get())); |
182 } | 182 base::RunLoop().RunUntilIdle(); |
| 183 } |
183 | 184 |
184 virtual ~MediaStreamManagerTest() { | 185 ~MediaStreamManagerTest() override {} |
185 } | |
186 | 186 |
187 MOCK_METHOD1(Response, void(int index)); | 187 MOCK_METHOD1(Response, void(int index)); |
188 void ResponseCallback(int index, | 188 void ResponseCallback(int index, |
189 const MediaStreamDevices& devices, | 189 const MediaStreamDevices& devices, |
190 std::unique_ptr<MediaStreamUIProxy> ui_proxy) { | 190 std::unique_ptr<MediaStreamUIProxy> ui_proxy) { |
191 Response(index); | 191 Response(index); |
192 task_runner_->PostTask(FROM_HERE, run_loop_.QuitClosure()); | 192 base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, |
| 193 run_loop_.QuitClosure()); |
193 } | 194 } |
194 | 195 |
195 protected: | 196 protected: |
196 std::string MakeMediaAccessRequest(int index) { | 197 std::string MakeMediaAccessRequest(int index) { |
197 const int render_process_id = 1; | 198 const int render_process_id = 1; |
198 const int render_frame_id = 1; | 199 const int render_frame_id = 1; |
199 const int page_request_id = 1; | 200 const int page_request_id = 1; |
200 const GURL security_origin; | 201 const GURL security_origin; |
201 MediaStreamManager::MediaRequestResponseCallback callback = | 202 MediaStreamManager::MediaRequestResponseCallback callback = |
202 base::Bind(&MediaStreamManagerTest::ResponseCallback, | 203 base::Bind(&MediaStreamManagerTest::ResponseCallback, |
203 base::Unretained(this), index); | 204 base::Unretained(this), index); |
204 StreamControls controls(true, true); | 205 StreamControls controls(true, true); |
205 return media_stream_manager_->MakeMediaAccessRequest( | 206 return media_stream_manager_->MakeMediaAccessRequest( |
206 render_process_id, render_frame_id, page_request_id, controls, | 207 render_process_id, render_frame_id, page_request_id, controls, |
207 security_origin, callback); | 208 security_origin, callback); |
208 } | 209 } |
209 | 210 |
210 std::unique_ptr<MockAudioManager> audio_manager_; | 211 // media_stream_manager_ needs to outlive thread_bundle_ because it is a |
| 212 // MessageLoop::DestructionObserver. audio_manager_ needs to outlive |
| 213 // thread_bundle_ because it uses the underlying message loop. |
211 std::unique_ptr<MediaStreamManager> media_stream_manager_; | 214 std::unique_ptr<MediaStreamManager> media_stream_manager_; |
212 content::TestBrowserThreadBundle thread_bundle_; | 215 content::TestBrowserThreadBundle thread_bundle_; |
213 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; | 216 std::unique_ptr<MockAudioManager, media::AudioManagerDeleter> audio_manager_; |
214 base::RunLoop run_loop_; | 217 base::RunLoop run_loop_; |
215 | 218 |
216 private: | 219 private: |
217 DISALLOW_COPY_AND_ASSIGN(MediaStreamManagerTest); | 220 DISALLOW_COPY_AND_ASSIGN(MediaStreamManagerTest); |
218 }; | 221 }; |
219 | 222 |
220 TEST_F(MediaStreamManagerTest, MakeMediaAccessRequest) { | 223 TEST_F(MediaStreamManagerTest, MakeMediaAccessRequest) { |
221 MakeMediaAccessRequest(0); | 224 MakeMediaAccessRequest(0); |
222 | 225 |
223 // Expecting the callback will be triggered and quit the test. | 226 // Expecting the callback will be triggered and quit the test. |
224 EXPECT_CALL(*this, Response(0)); | 227 EXPECT_CALL(*this, Response(0)); |
225 run_loop_.Run(); | 228 run_loop_.Run(); |
226 } | 229 } |
227 | 230 |
228 TEST_F(MediaStreamManagerTest, MakeAndCancelMediaAccessRequest) { | 231 TEST_F(MediaStreamManagerTest, MakeAndCancelMediaAccessRequest) { |
229 std::string label = MakeMediaAccessRequest(0); | 232 std::string label = MakeMediaAccessRequest(0); |
230 // No callback is expected. | 233 // No callback is expected. |
231 media_stream_manager_->CancelRequest(label); | 234 media_stream_manager_->CancelRequest(label); |
232 run_loop_.RunUntilIdle(); | 235 run_loop_.RunUntilIdle(); |
233 media_stream_manager_->WillDestroyCurrentMessageLoop(); | |
234 } | 236 } |
235 | 237 |
236 TEST_F(MediaStreamManagerTest, MakeMultipleRequests) { | 238 TEST_F(MediaStreamManagerTest, MakeMultipleRequests) { |
237 // First request. | 239 // First request. |
238 std::string label1 = MakeMediaAccessRequest(0); | 240 std::string label1 = MakeMediaAccessRequest(0); |
239 | 241 |
240 // Second request. | 242 // Second request. |
241 int render_process_id = 2; | 243 int render_process_id = 2; |
242 int render_frame_id = 2; | 244 int render_frame_id = 2; |
243 int page_request_id = 2; | 245 int page_request_id = 2; |
(...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
319 std::string label = media_stream_manager_->EnumerateDevices( | 321 std::string label = media_stream_manager_->EnumerateDevices( |
320 &requester, render_process_id, render_frame_id, GetMockSaltCallback(), | 322 &requester, render_process_id, render_frame_id, GetMockSaltCallback(), |
321 page_request_id, MEDIA_DEVICE_AUDIO_OUTPUT, security_origin); | 323 page_request_id, MEDIA_DEVICE_AUDIO_OUTPUT, security_origin); |
322 run_loop.Run(); | 324 run_loop.Run(); |
323 // CancelRequest is necessary for enumeration requests. | 325 // CancelRequest is necessary for enumeration requests. |
324 media_stream_manager_->CancelRequest(label); | 326 media_stream_manager_->CancelRequest(label); |
325 } | 327 } |
326 } | 328 } |
327 | 329 |
328 } // namespace content | 330 } // namespace content |
OLD | NEW |