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 // Unit test for VideoCaptureManager. | 5 // Unit test for VideoCaptureManager. |
6 | 6 |
7 #include "content/browser/renderer_host/media/video_capture_manager.h" | 7 #include "content/browser/renderer_host/media/video_capture_manager.h" |
8 | 8 |
9 #include <stdint.h> | 9 #include <stdint.h> |
10 | 10 |
(...skipping 23 matching lines...) Expand all Loading... | |
34 namespace content { | 34 namespace content { |
35 | 35 |
36 // Listener class used to track progress of VideoCaptureManager test. | 36 // Listener class used to track progress of VideoCaptureManager test. |
37 class MockMediaStreamProviderListener : public MediaStreamProviderListener { | 37 class MockMediaStreamProviderListener : public MediaStreamProviderListener { |
38 public: | 38 public: |
39 MockMediaStreamProviderListener() {} | 39 MockMediaStreamProviderListener() {} |
40 ~MockMediaStreamProviderListener() {} | 40 ~MockMediaStreamProviderListener() {} |
41 | 41 |
42 MOCK_METHOD2(Opened, void(MediaStreamType, int)); | 42 MOCK_METHOD2(Opened, void(MediaStreamType, int)); |
43 MOCK_METHOD2(Closed, void(MediaStreamType, int)); | 43 MOCK_METHOD2(Closed, void(MediaStreamType, int)); |
44 MOCK_METHOD2(Aborted, void(MediaStreamType, int)); | |
45 | |
46 // No longer part of MediaStreamProviderListener, but still useful for | |
47 // testing. | |
hta - Chromium
2016/09/20 09:41:39
Does this mean that we mock a method that isn't pr
Guido Urdaneta
2016/09/20 13:59:27
Removed the method.
| |
44 MOCK_METHOD2(DevicesEnumerated, void(MediaStreamType, | 48 MOCK_METHOD2(DevicesEnumerated, void(MediaStreamType, |
45 const StreamDeviceInfoArray&)); | 49 const StreamDeviceInfoArray&)); |
46 MOCK_METHOD2(Aborted, void(MediaStreamType, int)); | |
47 }; // class MockMediaStreamProviderListener | 50 }; // class MockMediaStreamProviderListener |
48 | 51 |
49 // Needed as an input argument to StartCaptureForClient(). | 52 // Needed as an input argument to StartCaptureForClient(). |
50 class MockFrameObserver : public VideoCaptureControllerEventHandler { | 53 class MockFrameObserver : public VideoCaptureControllerEventHandler { |
51 public: | 54 public: |
52 MOCK_METHOD1(OnError, void(VideoCaptureControllerID id)); | 55 MOCK_METHOD1(OnError, void(VideoCaptureControllerID id)); |
53 | 56 |
54 void OnBufferCreated(VideoCaptureControllerID id, | 57 void OnBufferCreated(VideoCaptureControllerID id, |
55 base::SharedMemoryHandle handle, | 58 base::SharedMemoryHandle handle, |
56 int length, int buffer_id) override {} | 59 int length, int buffer_id) override {} |
57 void OnBufferCreated2(VideoCaptureControllerID id, | 60 void OnBufferCreated2(VideoCaptureControllerID id, |
58 const std::vector<gfx::GpuMemoryBufferHandle>& handles, | 61 const std::vector<gfx::GpuMemoryBufferHandle>& handles, |
59 const gfx::Size& size, | 62 const gfx::Size& size, |
60 int buffer_id) override {} | 63 int buffer_id) override {} |
61 void OnBufferDestroyed(VideoCaptureControllerID id, int buffer_id) override {} | 64 void OnBufferDestroyed(VideoCaptureControllerID id, int buffer_id) override {} |
62 void OnBufferReady(VideoCaptureControllerID id, | 65 void OnBufferReady(VideoCaptureControllerID id, |
63 int buffer_id, | 66 int buffer_id, |
64 const scoped_refptr<media::VideoFrame>& frame) override {} | 67 const scoped_refptr<media::VideoFrame>& frame) override {} |
65 void OnEnded(VideoCaptureControllerID id) override {} | 68 void OnEnded(VideoCaptureControllerID id) override {} |
66 | 69 |
67 void OnGotControllerCallback(VideoCaptureControllerID) {} | 70 void OnGotControllerCallback(VideoCaptureControllerID) {} |
68 }; | 71 }; |
69 | 72 |
73 static void HandleEnumerationResult( | |
74 MockMediaStreamProviderListener* listener, | |
75 const media::VideoCaptureDeviceDescriptors& descriptors) { | |
76 StreamDeviceInfoArray devices; | |
77 for (const auto& descriptor : descriptors) { | |
78 devices.emplace_back(MEDIA_DEVICE_VIDEO_CAPTURE, | |
79 descriptor.GetNameAndModel(), descriptor.device_id); | |
80 } | |
81 listener->DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, devices); | |
82 } | |
83 | |
70 // Test class | 84 // Test class |
71 class VideoCaptureManagerTest : public testing::Test { | 85 class VideoCaptureManagerTest : public testing::Test { |
72 public: | 86 public: |
73 VideoCaptureManagerTest() : next_client_id_(1) {} | 87 VideoCaptureManagerTest() : next_client_id_(1) {} |
74 ~VideoCaptureManagerTest() override {} | 88 ~VideoCaptureManagerTest() override {} |
75 | 89 |
76 protected: | 90 protected: |
77 void SetUp() override { | 91 void SetUp() override { |
78 listener_.reset(new MockMediaStreamProviderListener()); | 92 listener_.reset(new MockMediaStreamProviderListener()); |
79 message_loop_.reset(new base::MessageLoopForIO); | 93 message_loop_.reset(new base::MessageLoopForIO); |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
184 // Try to open, start, stop and close a device. | 198 // Try to open, start, stop and close a device. |
185 TEST_F(VideoCaptureManagerTest, CreateAndClose) { | 199 TEST_F(VideoCaptureManagerTest, CreateAndClose) { |
186 StreamDeviceInfoArray devices; | 200 StreamDeviceInfoArray devices; |
187 | 201 |
188 InSequence s; | 202 InSequence s; |
189 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 203 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
190 .WillOnce(SaveArg<1>(&devices)); | 204 .WillOnce(SaveArg<1>(&devices)); |
191 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 205 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
192 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 206 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
193 | 207 |
194 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 208 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
195 | 209 |
196 // Wait to get device callback. | 210 // Wait to get device callback. |
197 base::RunLoop().RunUntilIdle(); | 211 base::RunLoop().RunUntilIdle(); |
198 | 212 |
199 int video_session_id = vcm_->Open(devices.front()); | 213 int video_session_id = vcm_->Open(devices.front()); |
200 VideoCaptureControllerID client_id = StartClient(video_session_id, true); | 214 VideoCaptureControllerID client_id = StartClient(video_session_id, true); |
201 | 215 |
202 StopClient(client_id); | 216 StopClient(client_id); |
203 vcm_->Close(video_session_id); | 217 vcm_->Close(video_session_id); |
204 | 218 |
205 // Wait to check callbacks before removing the listener. | 219 // Wait to check callbacks before removing the listener. |
206 base::RunLoop().RunUntilIdle(); | 220 base::RunLoop().RunUntilIdle(); |
207 vcm_->Unregister(); | 221 vcm_->Unregister(); |
208 } | 222 } |
209 | 223 |
210 TEST_F(VideoCaptureManagerTest, CreateAndCloseMultipleTimes) { | 224 TEST_F(VideoCaptureManagerTest, CreateAndCloseMultipleTimes) { |
211 StreamDeviceInfoArray devices; | 225 StreamDeviceInfoArray devices; |
212 | 226 |
213 InSequence s; | 227 InSequence s; |
214 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 228 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
215 .WillOnce(SaveArg<1>(&devices)); | 229 .WillOnce(SaveArg<1>(&devices)); |
216 | 230 |
217 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 231 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
218 | 232 |
219 // Wait to get device callback. | 233 // Wait to get device callback. |
220 base::RunLoop().RunUntilIdle(); | 234 base::RunLoop().RunUntilIdle(); |
221 | 235 |
222 for (int i = 1 ; i < 3 ; ++i) { | 236 for (int i = 1 ; i < 3 ; ++i) { |
223 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, i)); | 237 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, i)); |
224 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, i)); | 238 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, i)); |
225 int video_session_id = vcm_->Open(devices.front()); | 239 int video_session_id = vcm_->Open(devices.front()); |
226 VideoCaptureControllerID client_id = StartClient(video_session_id, true); | 240 VideoCaptureControllerID client_id = StartClient(video_session_id, true); |
227 | 241 |
228 StopClient(client_id); | 242 StopClient(client_id); |
229 vcm_->Close(video_session_id); | 243 vcm_->Close(video_session_id); |
230 } | 244 } |
231 | 245 |
232 // Wait to check callbacks before removing the listener. | 246 // Wait to check callbacks before removing the listener. |
233 base::RunLoop().RunUntilIdle(); | 247 base::RunLoop().RunUntilIdle(); |
234 vcm_->Unregister(); | 248 vcm_->Unregister(); |
235 } | 249 } |
236 | 250 |
237 // Try to open, start, and abort a device. | 251 // Try to open, start, and abort a device. |
238 TEST_F(VideoCaptureManagerTest, CreateAndAbort) { | 252 TEST_F(VideoCaptureManagerTest, CreateAndAbort) { |
239 StreamDeviceInfoArray devices; | 253 StreamDeviceInfoArray devices; |
240 | 254 |
241 InSequence s; | 255 InSequence s; |
242 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 256 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
243 .WillOnce(SaveArg<1>(&devices)); | 257 .WillOnce(SaveArg<1>(&devices)); |
244 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 258 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
245 EXPECT_CALL(*listener_, Aborted(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 259 EXPECT_CALL(*listener_, Aborted(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
246 | 260 |
247 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 261 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
248 | 262 |
249 // Wait to get device callback. | 263 // Wait to get device callback. |
250 base::RunLoop().RunUntilIdle(); | 264 base::RunLoop().RunUntilIdle(); |
251 | 265 |
252 int video_session_id = vcm_->Open(devices.front()); | 266 int video_session_id = vcm_->Open(devices.front()); |
253 VideoCaptureControllerID client_id = StartClient(video_session_id, true); | 267 VideoCaptureControllerID client_id = StartClient(video_session_id, true); |
254 | 268 |
255 // Wait for device opened. | 269 // Wait for device opened. |
256 base::RunLoop().RunUntilIdle(); | 270 base::RunLoop().RunUntilIdle(); |
257 | 271 |
258 vcm_->StopCaptureForClient(controllers_[client_id], client_id, | 272 vcm_->StopCaptureForClient(controllers_[client_id], client_id, |
259 frame_observer_.get(), true); | 273 frame_observer_.get(), true); |
260 | 274 |
261 // Wait to check callbacks before removing the listener. | 275 // Wait to check callbacks before removing the listener. |
262 base::RunLoop().RunUntilIdle(); | 276 base::RunLoop().RunUntilIdle(); |
263 vcm_->Unregister(); | 277 vcm_->Unregister(); |
264 } | 278 } |
265 | 279 |
266 // Open the same device twice. | 280 // Open the same device twice. |
267 TEST_F(VideoCaptureManagerTest, OpenTwice) { | 281 TEST_F(VideoCaptureManagerTest, OpenTwice) { |
268 StreamDeviceInfoArray devices; | 282 StreamDeviceInfoArray devices; |
269 | 283 |
270 InSequence s; | 284 InSequence s; |
271 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 285 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
272 .WillOnce(SaveArg<1>(&devices)); | 286 .WillOnce(SaveArg<1>(&devices)); |
273 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)).Times(2); | 287 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)).Times(2); |
274 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)).Times(2); | 288 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)).Times(2); |
275 | 289 |
276 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 290 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
277 | 291 |
278 // Wait to get device callback. | 292 // Wait to get device callback. |
279 base::RunLoop().RunUntilIdle(); | 293 base::RunLoop().RunUntilIdle(); |
280 | 294 |
281 int video_session_id_first = vcm_->Open(devices.front()); | 295 int video_session_id_first = vcm_->Open(devices.front()); |
282 | 296 |
283 // This should trigger an error callback with error code | 297 // This should trigger an error callback with error code |
284 // 'kDeviceAlreadyInUse'. | 298 // 'kDeviceAlreadyInUse'. |
285 int video_session_id_second = vcm_->Open(devices.front()); | 299 int video_session_id_second = vcm_->Open(devices.front()); |
286 EXPECT_NE(video_session_id_first, video_session_id_second); | 300 EXPECT_NE(video_session_id_first, video_session_id_second); |
287 | 301 |
288 vcm_->Close(video_session_id_first); | 302 vcm_->Close(video_session_id_first); |
289 vcm_->Close(video_session_id_second); | 303 vcm_->Close(video_session_id_second); |
290 | 304 |
291 // Wait to check callbacks before removing the listener. | 305 // Wait to check callbacks before removing the listener. |
292 base::RunLoop().RunUntilIdle(); | 306 base::RunLoop().RunUntilIdle(); |
293 vcm_->Unregister(); | 307 vcm_->Unregister(); |
294 } | 308 } |
295 | 309 |
296 // Connect and disconnect devices. | 310 // Connect and disconnect devices. |
297 TEST_F(VideoCaptureManagerTest, ConnectAndDisconnectDevices) { | 311 TEST_F(VideoCaptureManagerTest, ConnectAndDisconnectDevices) { |
298 StreamDeviceInfoArray devices; | 312 StreamDeviceInfoArray devices; |
299 int number_of_devices_keep = | 313 int number_of_devices_keep = |
300 video_capture_device_factory_->number_of_devices(); | 314 video_capture_device_factory_->number_of_devices(); |
301 | 315 |
302 InSequence s; | 316 InSequence s; |
303 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 317 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
304 .WillOnce(SaveArg<1>(&devices)); | 318 .WillOnce(SaveArg<1>(&devices)); |
305 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 319 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
306 base::RunLoop().RunUntilIdle(); | 320 base::RunLoop().RunUntilIdle(); |
307 ASSERT_EQ(devices.size(), 2u); | 321 ASSERT_EQ(devices.size(), 2u); |
308 | 322 |
309 // Simulate we remove 1 fake device. | 323 // Simulate we remove 1 fake device. |
310 video_capture_device_factory_->set_number_of_devices(1); | 324 video_capture_device_factory_->set_number_of_devices(1); |
311 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 325 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
312 .WillOnce(SaveArg<1>(&devices)); | 326 .WillOnce(SaveArg<1>(&devices)); |
313 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 327 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
314 base::RunLoop().RunUntilIdle(); | 328 base::RunLoop().RunUntilIdle(); |
315 ASSERT_EQ(devices.size(), 1u); | 329 ASSERT_EQ(devices.size(), 1u); |
316 | 330 |
317 // Simulate we add 2 fake devices. | 331 // Simulate we add 2 fake devices. |
318 video_capture_device_factory_->set_number_of_devices(3); | 332 video_capture_device_factory_->set_number_of_devices(3); |
319 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 333 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
320 .WillOnce(SaveArg<1>(&devices)); | 334 .WillOnce(SaveArg<1>(&devices)); |
321 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 335 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
322 base::RunLoop().RunUntilIdle(); | 336 base::RunLoop().RunUntilIdle(); |
323 ASSERT_EQ(devices.size(), 3u); | 337 ASSERT_EQ(devices.size(), 3u); |
324 | 338 |
325 vcm_->Unregister(); | 339 vcm_->Unregister(); |
326 video_capture_device_factory_->set_number_of_devices(number_of_devices_keep); | 340 video_capture_device_factory_->set_number_of_devices(number_of_devices_keep); |
327 } | 341 } |
328 | 342 |
329 // Enumerate devices and open the first, then check the list of supported | 343 // Enumerate devices and open the first, then check the list of supported |
330 // formats. Then start the opened device. The capability list should stay the | 344 // formats. Then start the opened device. The capability list should stay the |
331 // same. Finally stop the device and check that the capabilities stay unchanged. | 345 // same. Finally stop the device and check that the capabilities stay unchanged. |
332 TEST_F(VideoCaptureManagerTest, ManipulateDeviceAndCheckCapabilities) { | 346 TEST_F(VideoCaptureManagerTest, ManipulateDeviceAndCheckCapabilities) { |
333 StreamDeviceInfoArray devices; | 347 StreamDeviceInfoArray devices; |
334 | 348 |
335 // Before enumerating the devices, requesting formats should return false. | 349 // Before enumerating the devices, requesting formats should return false. |
336 int video_session_id = 0; | 350 int video_session_id = 0; |
337 media::VideoCaptureFormats supported_formats; | 351 media::VideoCaptureFormats supported_formats; |
338 supported_formats.clear(); | 352 supported_formats.clear(); |
339 EXPECT_FALSE( | 353 EXPECT_FALSE( |
340 vcm_->GetDeviceSupportedFormats(video_session_id, &supported_formats)); | 354 vcm_->GetDeviceSupportedFormats(video_session_id, &supported_formats)); |
341 | 355 |
342 InSequence s; | 356 InSequence s; |
343 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 357 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
344 .WillOnce(SaveArg<1>(&devices)); | 358 .WillOnce(SaveArg<1>(&devices)); |
345 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 359 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
346 base::RunLoop().RunUntilIdle(); | 360 base::RunLoop().RunUntilIdle(); |
347 ASSERT_GE(devices.size(), 2u); | 361 ASSERT_GE(devices.size(), 2u); |
348 | 362 |
349 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 363 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
350 video_session_id = vcm_->Open(devices.front()); | 364 video_session_id = vcm_->Open(devices.front()); |
351 base::RunLoop().RunUntilIdle(); | 365 base::RunLoop().RunUntilIdle(); |
352 | 366 |
353 // Right after opening the device, we should see all its formats. | 367 // Right after opening the device, we should see all its formats. |
354 supported_formats.clear(); | 368 supported_formats.clear(); |
355 EXPECT_TRUE( | 369 EXPECT_TRUE( |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
398 // use, which should be an empty vector. Then start the opened device. The | 412 // use, which should be an empty vector. Then start the opened device. The |
399 // format(s) in use should be just one format (the one used when configuring- | 413 // format(s) in use should be just one format (the one used when configuring- |
400 // starting the device). Finally stop the device and check that the formats in | 414 // starting the device). Finally stop the device and check that the formats in |
401 // use is an empty vector. | 415 // use is an empty vector. |
402 TEST_F(VideoCaptureManagerTest, StartDeviceAndGetDeviceFormatInUse) { | 416 TEST_F(VideoCaptureManagerTest, StartDeviceAndGetDeviceFormatInUse) { |
403 StreamDeviceInfoArray devices; | 417 StreamDeviceInfoArray devices; |
404 | 418 |
405 InSequence s; | 419 InSequence s; |
406 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 420 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
407 .WillOnce(SaveArg<1>(&devices)); | 421 .WillOnce(SaveArg<1>(&devices)); |
408 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 422 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
409 base::RunLoop().RunUntilIdle(); | 423 base::RunLoop().RunUntilIdle(); |
410 ASSERT_GE(devices.size(), 2u); | 424 ASSERT_GE(devices.size(), 2u); |
411 | 425 |
412 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 426 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
413 int video_session_id = vcm_->Open(devices.front()); | 427 int video_session_id = vcm_->Open(devices.front()); |
414 base::RunLoop().RunUntilIdle(); | 428 base::RunLoop().RunUntilIdle(); |
415 | 429 |
416 // Right after opening the device, we should see no format in use. | 430 // Right after opening the device, we should see no format in use. |
417 media::VideoCaptureFormats formats_in_use; | 431 media::VideoCaptureFormats formats_in_use; |
418 EXPECT_TRUE(vcm_->GetDeviceFormatsInUse(video_session_id, &formats_in_use)); | 432 EXPECT_TRUE(vcm_->GetDeviceFormatsInUse(video_session_id, &formats_in_use)); |
(...skipping 28 matching lines...) Expand all Loading... | |
447 // Open two different devices. | 461 // Open two different devices. |
448 TEST_F(VideoCaptureManagerTest, OpenTwo) { | 462 TEST_F(VideoCaptureManagerTest, OpenTwo) { |
449 StreamDeviceInfoArray devices; | 463 StreamDeviceInfoArray devices; |
450 | 464 |
451 InSequence s; | 465 InSequence s; |
452 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 466 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
453 .WillOnce(SaveArg<1>(&devices)); | 467 .WillOnce(SaveArg<1>(&devices)); |
454 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)).Times(2); | 468 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)).Times(2); |
455 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)).Times(2); | 469 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)).Times(2); |
456 | 470 |
457 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 471 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
458 | 472 |
459 // Wait to get device callback. | 473 // Wait to get device callback. |
460 base::RunLoop().RunUntilIdle(); | 474 base::RunLoop().RunUntilIdle(); |
461 | 475 |
462 StreamDeviceInfoArray::iterator it = devices.begin(); | 476 StreamDeviceInfoArray::iterator it = devices.begin(); |
463 | 477 |
464 int video_session_id_first = vcm_->Open(*it); | 478 int video_session_id_first = vcm_->Open(*it); |
465 ++it; | 479 ++it; |
466 int video_session_id_second = vcm_->Open(*it); | 480 int video_session_id_second = vcm_->Open(*it); |
467 | 481 |
468 vcm_->Close(video_session_id_first); | 482 vcm_->Close(video_session_id_first); |
469 vcm_->Close(video_session_id_second); | 483 vcm_->Close(video_session_id_second); |
470 | 484 |
471 // Wait to check callbacks before removing the listener. | 485 // Wait to check callbacks before removing the listener. |
472 base::RunLoop().RunUntilIdle(); | 486 base::RunLoop().RunUntilIdle(); |
473 vcm_->Unregister(); | 487 vcm_->Unregister(); |
474 } | 488 } |
475 | 489 |
476 // Try open a non-existing device. | 490 // Try open a non-existing device. |
477 TEST_F(VideoCaptureManagerTest, OpenNotExisting) { | 491 TEST_F(VideoCaptureManagerTest, OpenNotExisting) { |
478 StreamDeviceInfoArray devices; | 492 StreamDeviceInfoArray devices; |
479 | 493 |
480 InSequence s; | 494 InSequence s; |
481 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 495 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
482 .WillOnce(SaveArg<1>(&devices)); | 496 .WillOnce(SaveArg<1>(&devices)); |
483 EXPECT_CALL(*frame_observer_, OnError(_)); | 497 EXPECT_CALL(*frame_observer_, OnError(_)); |
484 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 498 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
485 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 499 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
486 | 500 |
487 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 501 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
488 | 502 |
489 // Wait to get device callback. | 503 // Wait to get device callback. |
490 base::RunLoop().RunUntilIdle(); | 504 base::RunLoop().RunUntilIdle(); |
491 | 505 |
492 MediaStreamType stream_type = MEDIA_DEVICE_VIDEO_CAPTURE; | 506 MediaStreamType stream_type = MEDIA_DEVICE_VIDEO_CAPTURE; |
493 std::string device_name("device_doesnt_exist"); | 507 std::string device_name("device_doesnt_exist"); |
494 std::string device_id("id_doesnt_exist"); | 508 std::string device_id("id_doesnt_exist"); |
495 StreamDeviceInfo dummy_device(stream_type, device_name, device_id); | 509 StreamDeviceInfo dummy_device(stream_type, device_name, device_id); |
496 | 510 |
497 // This should fail with an error to the controller. | 511 // This should fail with an error to the controller. |
(...skipping 23 matching lines...) Expand all Loading... | |
521 base::RunLoop run_loop; | 535 base::RunLoop run_loop; |
522 | 536 |
523 InSequence s; | 537 InSequence s; |
524 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 538 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
525 .WillOnce( | 539 .WillOnce( |
526 DoAll(SaveArg<1>(&devices), | 540 DoAll(SaveArg<1>(&devices), |
527 InvokeWithoutArgs(&run_loop, &base::RunLoop::Quit))); | 541 InvokeWithoutArgs(&run_loop, &base::RunLoop::Quit))); |
528 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 542 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
529 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 543 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
530 | 544 |
531 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 545 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
532 | 546 |
533 // Wait to get device callback. | 547 // Wait to get device callback. |
534 run_loop.Run(); | 548 run_loop.Run(); |
535 ASSERT_FALSE(devices.empty()); | 549 ASSERT_FALSE(devices.empty()); |
536 int video_session_id = vcm_->Open(devices.front()); | 550 int video_session_id = vcm_->Open(devices.front()); |
537 | 551 |
538 VideoCaptureControllerID client_id = StartClient(video_session_id, true); | 552 VideoCaptureControllerID client_id = StartClient(video_session_id, true); |
539 | 553 |
540 // Close will stop the running device, an assert will be triggered in | 554 // Close will stop the running device, an assert will be triggered in |
541 // VideoCaptureManager destructor otherwise. | 555 // VideoCaptureManager destructor otherwise. |
542 vcm_->Close(video_session_id); | 556 vcm_->Close(video_session_id); |
543 StopClient(client_id); | 557 StopClient(client_id); |
544 | 558 |
545 // Wait to check callbacks before removing the listener | 559 // Wait to check callbacks before removing the listener |
546 base::RunLoop().RunUntilIdle(); | 560 base::RunLoop().RunUntilIdle(); |
547 vcm_->Unregister(); | 561 vcm_->Unregister(); |
548 } | 562 } |
549 | 563 |
550 // Try to open, start, pause and resume a device. | 564 // Try to open, start, pause and resume a device. |
551 TEST_F(VideoCaptureManagerTest, PauseAndResumeClient) { | 565 TEST_F(VideoCaptureManagerTest, PauseAndResumeClient) { |
552 StreamDeviceInfoArray devices; | 566 StreamDeviceInfoArray devices; |
553 | 567 |
554 InSequence s; | 568 InSequence s; |
555 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 569 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
556 .WillOnce(SaveArg<1>(&devices)); | 570 .WillOnce(SaveArg<1>(&devices)); |
557 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 571 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
558 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 572 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
559 | 573 |
560 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 574 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
hta - Chromium
2016/09/20 09:41:39
With the number of calls to this particular functi
Guido Urdaneta
2016/09/20 13:59:27
Done. The only slightly ugly thing is that HandleE
| |
561 | 575 |
562 // Wait to get device callback. | 576 // Wait to get device callback. |
563 base::RunLoop().RunUntilIdle(); | 577 base::RunLoop().RunUntilIdle(); |
564 | 578 |
565 int video_session_id = vcm_->Open(devices.front()); | 579 int video_session_id = vcm_->Open(devices.front()); |
566 VideoCaptureControllerID client_id = StartClient(video_session_id, true); | 580 VideoCaptureControllerID client_id = StartClient(video_session_id, true); |
567 | 581 |
568 // Resume client a second time should cause no problem. | 582 // Resume client a second time should cause no problem. |
569 PauseClient(client_id); | 583 PauseClient(client_id); |
570 ResumeClient(video_session_id, client_id); | 584 ResumeClient(video_session_id, client_id); |
(...skipping 11 matching lines...) Expand all Loading... | |
582 // Try to open, start, pause and resume a device. | 596 // Try to open, start, pause and resume a device. |
583 TEST_F(VideoCaptureManagerTest, PauseAndResumeDevice) { | 597 TEST_F(VideoCaptureManagerTest, PauseAndResumeDevice) { |
584 StreamDeviceInfoArray devices; | 598 StreamDeviceInfoArray devices; |
585 | 599 |
586 InSequence s; | 600 InSequence s; |
587 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) | 601 EXPECT_CALL(*listener_, DevicesEnumerated(MEDIA_DEVICE_VIDEO_CAPTURE, _)) |
588 .WillOnce(SaveArg<1>(&devices)); | 602 .WillOnce(SaveArg<1>(&devices)); |
589 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 603 EXPECT_CALL(*listener_, Opened(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
590 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)); | 604 EXPECT_CALL(*listener_, Closed(MEDIA_DEVICE_VIDEO_CAPTURE, _)); |
591 | 605 |
592 vcm_->EnumerateDevices(MEDIA_DEVICE_VIDEO_CAPTURE); | 606 vcm_->EnumerateDevices(base::Bind(&HandleEnumerationResult, listener_.get())); |
593 | 607 |
594 // Wait to get device callback. | 608 // Wait to get device callback. |
595 base::RunLoop().RunUntilIdle(); | 609 base::RunLoop().RunUntilIdle(); |
596 | 610 |
597 int video_session_id = vcm_->Open(devices.front()); | 611 int video_session_id = vcm_->Open(devices.front()); |
598 VideoCaptureControllerID client_id = StartClient(video_session_id, true); | 612 VideoCaptureControllerID client_id = StartClient(video_session_id, true); |
599 | 613 |
600 // Release/ResumeDevices according to ApplicationStatus. Should cause no | 614 // Release/ResumeDevices according to ApplicationStatus. Should cause no |
601 // problem in any order. Check https://crbug.com/615557 for more details. | 615 // problem in any order. Check https://crbug.com/615557 for more details. |
602 ApplicationStateChange( | 616 ApplicationStateChange( |
(...skipping 13 matching lines...) Expand all Loading... | |
616 // Wait to check callbacks before removing the listener. | 630 // Wait to check callbacks before removing the listener. |
617 base::RunLoop().RunUntilIdle(); | 631 base::RunLoop().RunUntilIdle(); |
618 vcm_->Unregister(); | 632 vcm_->Unregister(); |
619 } | 633 } |
620 #endif | 634 #endif |
621 | 635 |
622 // TODO(mcasas): Add a test to check consolidation of the supported formats | 636 // TODO(mcasas): Add a test to check consolidation of the supported formats |
623 // provided by the device when http://crbug.com/323913 is closed. | 637 // provided by the device when http://crbug.com/323913 is closed. |
624 | 638 |
625 } // namespace content | 639 } // namespace content |
OLD | NEW |