Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(812)

Side by Side Diff: content/browser/renderer_host/media/video_capture_manager_unittest.cc

Issue 2350693002: Remove device enumeration, caching and monitoring from MediaStreamManager. (Closed)
Patch Set: Minor DCHECK fix Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
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
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
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
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698