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

Side by Side Diff: services/video_capture/test/mock_device_test.cc

Issue 2824883005: [Mojo Video Capture] Stop service when last client disconnects. (Closed)
Patch Set: Created 3 years, 8 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 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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698