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 <map> | 5 #include <map> |
6 #include <string> | 6 #include <string> |
7 | 7 |
8 #include "base/bind.h" | 8 #include "base/bind.h" |
9 #include "base/file_util.h" | 9 #include "base/file_util.h" |
10 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
(...skipping 181 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
192 } | 192 } |
193 | 193 |
194 void OnBufferFilledDispatch(int device_id, | 194 void OnBufferFilledDispatch(int device_id, |
195 int buffer_id, | 195 int buffer_id, |
196 base::Time timestamp, | 196 base::Time timestamp, |
197 const media::VideoCaptureFormat& frame_format) { | 197 const media::VideoCaptureFormat& frame_format) { |
198 base::SharedMemory* dib = filled_dib_[buffer_id]; | 198 base::SharedMemory* dib = filled_dib_[buffer_id]; |
199 ASSERT_TRUE(dib != NULL); | 199 ASSERT_TRUE(dib != NULL); |
200 if (dump_video_) { | 200 if (dump_video_) { |
201 if (!format_.IsValid()) { | 201 if (!format_.IsValid()) { |
202 dumper_.StartDump(frame_format.width, frame_format.height); | 202 dumper_.StartDump(frame_format.frame_size.width(), |
| 203 frame_format.frame_size.height()); |
203 format_ = frame_format; | 204 format_ = frame_format; |
204 } | 205 } |
205 ASSERT_EQ(format_.width, frame_format.width) | 206 ASSERT_EQ(format_.frame_size.width(), frame_format.frame_size.width()) |
206 << "Dump format does not handle variable resolution."; | 207 << "Dump format does not handle variable resolution."; |
207 ASSERT_EQ(format_.height, frame_format.height) | 208 ASSERT_EQ(format_.frame_size.height(), frame_format.frame_size.height()) |
208 << "Dump format does not handle variable resolution.";; | 209 << "Dump format does not handle variable resolution."; |
209 dumper_.NewVideoFrame(dib->memory()); | 210 dumper_.NewVideoFrame(dib->memory()); |
210 } | 211 } |
211 | 212 |
212 OnBufferFilled(device_id, buffer_id, timestamp, frame_format); | 213 OnBufferFilled(device_id, buffer_id, timestamp, frame_format); |
213 if (return_buffers_) { | 214 if (return_buffers_) { |
214 VideoCaptureHost::OnReceiveEmptyBuffer(device_id, buffer_id); | 215 VideoCaptureHost::OnReceiveEmptyBuffer(device_id, buffer_id); |
215 } | 216 } |
216 } | 217 } |
217 | 218 |
218 void OnStateChangedDispatch(int device_id, VideoCaptureState state) { | 219 void OnStateChangedDispatch(int device_id, VideoCaptureState state) { |
(...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
340 EXPECT_CALL(*host_, OnNewBufferCreated(kDeviceId, _, _, _)) | 341 EXPECT_CALL(*host_, OnNewBufferCreated(kDeviceId, _, _, _)) |
341 .Times(AnyNumber()).WillRepeatedly(Return()); | 342 .Times(AnyNumber()).WillRepeatedly(Return()); |
342 | 343 |
343 base::RunLoop run_loop; | 344 base::RunLoop run_loop; |
344 EXPECT_CALL(*host_, OnBufferFilled(kDeviceId, _, _, _)) | 345 EXPECT_CALL(*host_, OnBufferFilled(kDeviceId, _, _, _)) |
345 .Times(AnyNumber()).WillOnce(ExitMessageLoop( | 346 .Times(AnyNumber()).WillOnce(ExitMessageLoop( |
346 message_loop_, run_loop.QuitClosure())); | 347 message_loop_, run_loop.QuitClosure())); |
347 | 348 |
348 media::VideoCaptureParams params; | 349 media::VideoCaptureParams params; |
349 params.requested_format = media::VideoCaptureFormat( | 350 params.requested_format = media::VideoCaptureFormat( |
350 352, 288, 30, media::ConstantResolutionVideoCaptureDevice); | 351 gfx::Size(352, 288), 30, media::PIXEL_FORMAT_I420); |
351 params.session_id = opened_session_id_; | 352 host_->OnStartCapture(kDeviceId, opened_session_id_, params); |
352 host_->OnStartCapture(kDeviceId, params); | |
353 run_loop.Run(); | 353 run_loop.Run(); |
354 } | 354 } |
355 | 355 |
356 void StartStopCapture() { | 356 void StartStopCapture() { |
357 // Quickly start and then stop capture, without giving much chance for | 357 // Quickly start and then stop capture, without giving much chance for |
358 // asynchronous start operations to complete. | 358 // asynchronous start operations to complete. |
359 InSequence s; | 359 InSequence s; |
360 base::RunLoop run_loop; | 360 base::RunLoop run_loop; |
361 EXPECT_CALL(*host_, OnStateChanged(kDeviceId, VIDEO_CAPTURE_STATE_STOPPED)); | 361 EXPECT_CALL(*host_, OnStateChanged(kDeviceId, VIDEO_CAPTURE_STATE_STOPPED)); |
362 media::VideoCaptureParams params; | 362 media::VideoCaptureParams params; |
363 params.requested_format = media::VideoCaptureFormat( | 363 params.requested_format = media::VideoCaptureFormat( |
364 352, 288, 30, media::ConstantResolutionVideoCaptureDevice); | 364 gfx::Size(352, 288), 30, media::PIXEL_FORMAT_I420); |
365 params.session_id = opened_session_id_; | 365 host_->OnStartCapture(kDeviceId, opened_session_id_, params); |
366 host_->OnStartCapture(kDeviceId, params); | |
367 host_->OnStopCapture(kDeviceId); | 366 host_->OnStopCapture(kDeviceId); |
368 run_loop.RunUntilIdle(); | 367 run_loop.RunUntilIdle(); |
369 } | 368 } |
370 | 369 |
371 #ifdef DUMP_VIDEO | 370 #ifdef DUMP_VIDEO |
372 void CaptureAndDumpVideo(int width, int height, int frame_rate) { | 371 void CaptureAndDumpVideo(int width, int height, int frame_rate) { |
373 InSequence s; | 372 InSequence s; |
374 EXPECT_CALL(*host_.get(), OnNewBufferCreated(kDeviceId, _, _, _)) | 373 EXPECT_CALL(*host_.get(), OnNewBufferCreated(kDeviceId, _, _, _)) |
375 .Times(AnyNumber()).WillRepeatedly(Return()); | 374 .Times(AnyNumber()).WillRepeatedly(Return()); |
376 | 375 |
377 base::RunLoop run_loop; | 376 base::RunLoop run_loop; |
378 EXPECT_CALL(*host_, OnBufferFilled(kDeviceId, _, _, _)) | 377 EXPECT_CALL(*host_, OnBufferFilled(kDeviceId, _, _, _)) |
379 .Times(AnyNumber()) | 378 .Times(AnyNumber()) |
380 .WillOnce(ExitMessageLoop(message_loop_, run_loop.QuitClosure())); | 379 .WillOnce(ExitMessageLoop(message_loop_, run_loop.QuitClosure())); |
381 | 380 |
382 media::VideoCaptureParams params; | 381 media::VideoCaptureParams params; |
383 params.requested_format = media::VideoCaptureFormat( | 382 params.requested_format = |
384 width, height, frame_rate, media::ConstantResolutionVideoCaptureDevice); | 383 media::VideoCaptureFormat(gfx::Size(width, height), frame_rate); |
385 params.session_id = opened_session_id_; | |
386 host_->SetDumpVideo(true); | 384 host_->SetDumpVideo(true); |
387 host_->OnStartCapture(kDeviceId, params); | 385 host_->OnStartCapture(kDeviceId, opened_session_id_, params); |
388 run_loop.Run(); | 386 run_loop.Run(); |
389 } | 387 } |
390 #endif | 388 #endif |
391 | 389 |
392 void StopCapture() { | 390 void StopCapture() { |
393 base::RunLoop run_loop; | 391 base::RunLoop run_loop; |
394 EXPECT_CALL(*host_, OnStateChanged(kDeviceId, VIDEO_CAPTURE_STATE_STOPPED)) | 392 EXPECT_CALL(*host_, OnStateChanged(kDeviceId, VIDEO_CAPTURE_STATE_STOPPED)) |
395 .WillOnce(ExitMessageLoop(message_loop_, run_loop.QuitClosure())); | 393 .WillOnce(ExitMessageLoop(message_loop_, run_loop.QuitClosure())); |
396 | 394 |
397 host_->OnStopCapture(kDeviceId); | 395 host_->OnStopCapture(kDeviceId); |
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
483 #ifdef DUMP_VIDEO | 481 #ifdef DUMP_VIDEO |
484 TEST_F(VideoCaptureHostTest, CaptureAndDumpVideoVga) { | 482 TEST_F(VideoCaptureHostTest, CaptureAndDumpVideoVga) { |
485 CaptureAndDumpVideo(640, 480, 30); | 483 CaptureAndDumpVideo(640, 480, 30); |
486 } | 484 } |
487 TEST_F(VideoCaptureHostTest, CaptureAndDump720P) { | 485 TEST_F(VideoCaptureHostTest, CaptureAndDump720P) { |
488 CaptureAndDumpVideo(1280, 720, 30); | 486 CaptureAndDumpVideo(1280, 720, 30); |
489 } | 487 } |
490 #endif | 488 #endif |
491 | 489 |
492 } // namespace content | 490 } // namespace content |
OLD | NEW |