Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "services/video_capture/test/mock_device_test.h" | 5 #include "services/video_capture/test/mock_device_test.h" |
| 6 | 6 |
| 7 #include "base/memory/ptr_util.h" | 7 #include "base/memory/ptr_util.h" |
| 8 #include "base/run_loop.h" | 8 #include "base/run_loop.h" |
| 9 #include "media/capture/video/video_capture_jpeg_decoder.h" | 9 #include "media/capture/video/video_capture_jpeg_decoder.h" |
| 10 #include "media/capture/video/video_capture_system_impl.h" | 10 #include "media/capture/video/video_capture_system_impl.h" |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 22 } // anonymous namespace | 22 } // anonymous namespace |
| 23 | 23 |
| 24 namespace video_capture { | 24 namespace video_capture { |
| 25 | 25 |
| 26 MockDevice::MockDevice() = default; | 26 MockDevice::MockDevice() = default; |
| 27 | 27 |
| 28 MockDevice::~MockDevice() = default; | 28 MockDevice::~MockDevice() = default; |
| 29 | 29 |
| 30 void MockDevice::SendStubFrame(const media::VideoCaptureFormat& format, | 30 void MockDevice::SendStubFrame(const media::VideoCaptureFormat& format, |
| 31 int rotation, | 31 int rotation, |
| 32 int frame_id) { | 32 int frame_feedback_id) { |
| 33 auto stub_frame = media::VideoFrame::CreateZeroInitializedFrame( | 33 auto stub_frame = media::VideoFrame::CreateZeroInitializedFrame( |
| 34 format.pixel_format, format.frame_size, | 34 format.pixel_format, format.frame_size, |
| 35 gfx::Rect(format.frame_size.width(), format.frame_size.height()), | 35 gfx::Rect(format.frame_size.width(), format.frame_size.height()), |
| 36 format.frame_size, base::TimeDelta()); | 36 format.frame_size, base::TimeDelta()); |
| 37 client_->OnIncomingCapturedData( | 37 client_->OnIncomingCapturedData( |
| 38 stub_frame->data(0), | 38 stub_frame->data(0), |
| 39 static_cast<int>(media::VideoFrame::AllocationSize( | 39 static_cast<int>(media::VideoFrame::AllocationSize( |
| 40 stub_frame->format(), stub_frame->coded_size())), | 40 stub_frame->format(), stub_frame->coded_size())), |
| 41 format, rotation, base::TimeTicks(), base::TimeDelta(), frame_id); | 41 format, rotation, base::TimeTicks(), base::TimeDelta(), |
| 42 frame_feedback_id); | |
| 42 } | 43 } |
| 43 | 44 |
| 44 void MockDevice::AllocateAndStart(const media::VideoCaptureParams& params, | 45 void MockDevice::AllocateAndStart(const media::VideoCaptureParams& params, |
| 45 std::unique_ptr<Client> client) { | 46 std::unique_ptr<Client> client) { |
| 46 client_ = std::move(client); | 47 client_ = std::move(client); |
| 47 DoAllocateAndStart(params, &client); | 48 DoAllocateAndStart(params, &client); |
| 48 } | 49 } |
| 49 | 50 |
| 50 void MockDevice::StopAndDeAllocate() { | 51 void MockDevice::StopAndDeAllocate() { |
| 51 DoStopAndDeAllocate(); | 52 DoStopAndDeAllocate(); |
| 52 client_.reset(); | 53 client_.reset(); |
| 53 } | 54 } |
| 54 | 55 |
| 55 void MockDevice::GetPhotoCapabilities(GetPhotoCapabilitiesCallback callback) { | 56 void MockDevice::GetPhotoCapabilities(GetPhotoCapabilitiesCallback callback) { |
| 56 DoGetPhotoCapabilities(&callback); | 57 DoGetPhotoCapabilities(&callback); |
| 57 } | 58 } |
| 58 | 59 |
| 59 void MockDevice::SetPhotoOptions(media::mojom::PhotoSettingsPtr settings, | 60 void MockDevice::SetPhotoOptions(media::mojom::PhotoSettingsPtr settings, |
| 60 SetPhotoOptionsCallback callback) { | 61 SetPhotoOptionsCallback callback) { |
| 61 DoSetPhotoOptions(&settings, &callback); | 62 DoSetPhotoOptions(&settings, &callback); |
| 62 } | 63 } |
| 63 | 64 |
| 64 void MockDevice::TakePhoto(TakePhotoCallback callback) { | 65 void MockDevice::TakePhoto(TakePhotoCallback callback) { |
| 65 DoTakePhoto(&callback); | 66 DoTakePhoto(&callback); |
| 66 } | 67 } |
| 67 | 68 |
| 68 MockDeviceTest::MockDeviceTest() = default; | 69 MockDeviceTest::MockDeviceTest() : ref_factory_(base::Bind([]() {})) {} |
|
mcasas
2017/04/26 22:12:31
base::DoNothing() ?
chfremer
2017/04/26 23:33:36
Done.
| |
| 69 | 70 |
| 70 MockDeviceTest::~MockDeviceTest() = default; | 71 MockDeviceTest::~MockDeviceTest() = default; |
| 71 | 72 |
| 72 void MockDeviceTest::SetUp() { | 73 void MockDeviceTest::SetUp() { |
| 73 message_loop_ = base::MakeUnique<base::MessageLoop>(); | 74 message_loop_ = base::MakeUnique<base::MessageLoop>(); |
| 74 auto mock_device_factory = base::MakeUnique<MockDeviceFactory>(); | 75 auto mock_device_factory = base::MakeUnique<MockDeviceFactory>(); |
| 75 // We keep a pointer to the MockDeviceFactory as a member so that we can | 76 // We keep a pointer to the MockDeviceFactory as a member so that we can |
| 76 // invoke its AddMockDevice(). Ownership of the MockDeviceFactory is moved | 77 // invoke its AddMockDevice(). Ownership of the MockDeviceFactory is moved |
| 77 // to the DeviceFactoryMediaToMojoAdapter. | 78 // to the DeviceFactoryMediaToMojoAdapter. |
| 78 mock_device_factory_ = mock_device_factory.get(); | 79 mock_device_factory_ = mock_device_factory.get(); |
| 79 auto video_capture_system = base::MakeUnique<media::VideoCaptureSystemImpl>( | 80 auto video_capture_system = base::MakeUnique<media::VideoCaptureSystemImpl>( |
| 80 std::move(mock_device_factory)); | 81 std::move(mock_device_factory)); |
| 81 mock_device_factory_adapter_ = | 82 mock_device_factory_adapter_ = |
| 82 base::MakeUnique<DeviceFactoryMediaToMojoAdapter>( | 83 base::MakeUnique<DeviceFactoryMediaToMojoAdapter>( |
| 83 std::move(video_capture_system), base::Bind(CreateJpegDecoder)); | 84 ref_factory_.CreateRef(), std::move(video_capture_system), |
| 85 base::Bind(CreateJpegDecoder)); | |
| 84 | 86 |
| 85 mock_factory_binding_ = base::MakeUnique<mojo::Binding<mojom::DeviceFactory>>( | 87 mock_factory_binding_ = base::MakeUnique<mojo::Binding<mojom::DeviceFactory>>( |
| 86 mock_device_factory_adapter_.get(), mojo::MakeRequest(&factory_)); | 88 mock_device_factory_adapter_.get(), mojo::MakeRequest(&factory_)); |
| 87 | 89 |
| 88 media::VideoCaptureDeviceDescriptor mock_descriptor; | 90 media::VideoCaptureDeviceDescriptor mock_descriptor; |
| 89 mock_descriptor.device_id = "MockDeviceId"; | 91 mock_descriptor.device_id = "MockDeviceId"; |
| 90 mock_device_factory_->AddMockDevice(&mock_device_, mock_descriptor); | 92 mock_device_factory_->AddMockDevice(&mock_device_, mock_descriptor); |
| 91 | 93 |
| 92 // Obtain the mock device from the factory | 94 // Obtain the mock device from the factory |
| 93 base::RunLoop wait_loop; | 95 base::RunLoop wait_loop; |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 106 requested_settings_.resolution_change_policy = | 108 requested_settings_.resolution_change_policy = |
| 107 media::RESOLUTION_POLICY_FIXED_RESOLUTION; | 109 media::RESOLUTION_POLICY_FIXED_RESOLUTION; |
| 108 requested_settings_.power_line_frequency = | 110 requested_settings_.power_line_frequency = |
| 109 media::PowerLineFrequency::FREQUENCY_DEFAULT; | 111 media::PowerLineFrequency::FREQUENCY_DEFAULT; |
| 110 | 112 |
| 111 mock_receiver_ = | 113 mock_receiver_ = |
| 112 base::MakeUnique<MockReceiver>(mojo::MakeRequest(&mock_receiver_proxy_)); | 114 base::MakeUnique<MockReceiver>(mojo::MakeRequest(&mock_receiver_proxy_)); |
| 113 } | 115 } |
| 114 | 116 |
| 115 } // namespace video_capture | 117 } // namespace video_capture |
| OLD | NEW |