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 "base/memory/shared_memory.h" | |
5 #include "base/message_loop/message_loop.h" | 6 #include "base/message_loop/message_loop.h" |
6 #include "content/child/child_process.h" | 7 #include "content/child/child_process.h" |
7 #include "content/common/media/video_capture_messages.h" | 8 #include "content/common/media/video_capture_messages.h" |
8 #include "content/renderer/media/video_capture_impl.h" | 9 #include "content/renderer/media/video_capture_impl.h" |
9 #include "media/base/bind_to_current_loop.h" | 10 #include "media/base/bind_to_current_loop.h" |
10 #include "testing/gmock/include/gmock/gmock.h" | 11 #include "testing/gmock/include/gmock/gmock.h" |
11 #include "testing/gtest/include/gtest/gtest.h" | 12 #include "testing/gtest/include/gtest/gtest.h" |
12 | 13 |
13 using ::testing::_; | 14 using ::testing::_; |
14 using ::testing::AtLeast; | 15 using ::testing::AtLeast; |
(...skipping 12 matching lines...) Expand all Loading... | |
27 // Filter implementation. | 28 // Filter implementation. |
28 MOCK_METHOD1(Send, bool(IPC::Message* message)); | 29 MOCK_METHOD1(Send, bool(IPC::Message* message)); |
29 | 30 |
30 protected: | 31 protected: |
31 virtual ~MockVideoCaptureMessageFilter() {} | 32 virtual ~MockVideoCaptureMessageFilter() {} |
32 | 33 |
33 private: | 34 private: |
34 DISALLOW_COPY_AND_ASSIGN(MockVideoCaptureMessageFilter); | 35 DISALLOW_COPY_AND_ASSIGN(MockVideoCaptureMessageFilter); |
35 }; | 36 }; |
36 | 37 |
37 class VideoCaptureImplTest : public ::testing::Test { | 38 struct BufferReceivedTestArg { |
39 BufferReceivedTestArg(int buffer_id, | |
40 media::VideoPixelFormat pixel_format, | |
41 media::VideoCapturePixelFormat capture_pixel_format, | |
42 const gfx::Size& coded_size, | |
43 const gpu::MailboxHolder& mailbox_holder) | |
44 : buffer_id(buffer_id), pixel_format(pixel_format), | |
45 capture_pixel_format(capture_pixel_format), coded_size(coded_size), | |
46 mailbox_holder(mailbox_holder) {} | |
47 | |
48 int buffer_id; | |
49 media::VideoPixelFormat pixel_format; | |
50 media::VideoCapturePixelFormat capture_pixel_format; | |
51 const gfx::Size coded_size; | |
52 const gpu::MailboxHolder mailbox_holder; | |
53 }; | |
54 | |
55 class VideoCaptureImplTest : | |
56 public ::testing::TestWithParam<BufferReceivedTestArg> { | |
38 public: | 57 public: |
39 class MockVideoCaptureImpl : public VideoCaptureImpl { | 58 class MockVideoCaptureImpl : public VideoCaptureImpl { |
40 public: | 59 public: |
41 MockVideoCaptureImpl(const media::VideoCaptureSessionId id, | 60 MockVideoCaptureImpl(const media::VideoCaptureSessionId id, |
42 VideoCaptureMessageFilter* filter) | 61 VideoCaptureMessageFilter* filter) |
43 : VideoCaptureImpl(id, filter) { | 62 : VideoCaptureImpl(id, filter), received_buffer_count_(0) { |
44 } | 63 } |
45 ~MockVideoCaptureImpl() override {} | 64 ~MockVideoCaptureImpl() override {} |
46 | 65 |
47 // Override Send() to mimic device to send events. | 66 // Override Send() to mimic device to send events. |
48 void Send(IPC::Message* message) override { | 67 void Send(IPC::Message* message) override { |
49 CHECK(message); | 68 CHECK(message); |
50 | 69 |
51 // In this method, messages are sent to the according handlers as if | 70 // In this method, messages are sent to the according handlers as if |
52 // we are the device. | 71 // we are the device. |
53 bool handled = true; | 72 bool handled = true; |
(...skipping 11 matching lines...) Expand all Loading... | |
65 IPC_END_MESSAGE_MAP() | 84 IPC_END_MESSAGE_MAP() |
66 EXPECT_TRUE(handled); | 85 EXPECT_TRUE(handled); |
67 delete message; | 86 delete message; |
68 } | 87 } |
69 | 88 |
70 void DeviceStartCapture(int device_id, | 89 void DeviceStartCapture(int device_id, |
71 media::VideoCaptureSessionId session_id, | 90 media::VideoCaptureSessionId session_id, |
72 const media::VideoCaptureParams& params) { | 91 const media::VideoCaptureParams& params) { |
73 // Do not call OnStateChanged(VIDEO_CAPTURE_STATE_STARTED) here, as this | 92 // Do not call OnStateChanged(VIDEO_CAPTURE_STATE_STARTED) here, as this |
74 // does not accurately reflect the behavior of the VideoCaptureHost. | 93 // does not accurately reflect the behavior of the VideoCaptureHost. |
75 capture_params_ = params; | |
76 } | 94 } |
77 | 95 |
78 void DevicePauseCapture(int device_id) {} | 96 void DevicePauseCapture(int device_id) {} |
mcasas
2015/09/01 18:09:53
Suggest mocking these two fellas since they do not
msu.koo
2015/09/02 08:38:10
It's better approach but I think changing these fu
mcasas
2015/09/02 16:51:26
SGTM, you can do that in a CL afterwards
but usua
| |
79 | 97 |
80 void DeviceStopCapture(int device_id) { | 98 void DeviceStopCapture(int device_id) { |
81 OnStateChanged(VIDEO_CAPTURE_STATE_STOPPED); | 99 OnStateChanged(VIDEO_CAPTURE_STATE_STOPPED); |
82 } | 100 } |
83 | 101 |
84 void DeviceReceiveEmptyBuffer(int device_id, | 102 void DeviceReceiveEmptyBuffer(int device_id, |
85 int buffer_id, | 103 int buffer_id, |
86 uint32 sync_point, | 104 uint32 sync_point, |
87 double consumer_resource_utilization) {} | 105 double consumer_resource_utilization) { |
106 received_buffer_count_++; | |
107 } | |
88 | 108 |
89 void DeviceGetSupportedFormats(int device_id, | 109 void DeviceGetSupportedFormats(int device_id, |
90 media::VideoCaptureSessionId session_id) { | 110 media::VideoCaptureSessionId session_id) { |
91 // When the mock message filter receives a request for the device | 111 // When the mock message filter receives a request for the device |
92 // supported formats, replies immediately with an empty format list. | 112 // supported formats, replies immediately with an empty format list. |
93 OnDeviceSupportedFormatsEnumerated(media::VideoCaptureFormats()); | 113 OnDeviceSupportedFormatsEnumerated(media::VideoCaptureFormats()); |
94 } | 114 } |
95 | 115 |
96 void DeviceGetFormatsInUse(int device_id, | 116 void DeviceGetFormatsInUse(int device_id, |
97 media::VideoCaptureSessionId session_id) { | 117 media::VideoCaptureSessionId session_id) { |
98 OnDeviceFormatsInUseReceived(media::VideoCaptureFormats()); | 118 OnDeviceFormatsInUseReceived(media::VideoCaptureFormats()); |
99 } | 119 } |
100 | 120 |
101 void ReceiveStateChangeMessage(VideoCaptureState state) { | 121 void ReceiveStateChangeMessage(VideoCaptureState state) { |
102 OnStateChanged(state); | 122 OnStateChanged(state); |
103 } | 123 } |
104 | 124 |
105 const media::VideoCaptureParams& capture_params() const { | 125 int received_buffer_count() const { return received_buffer_count_; } |
106 return capture_params_; | |
107 } | |
108 | 126 |
109 private: | 127 private: |
110 media::VideoCaptureParams capture_params_; | 128 int received_buffer_count_; |
111 }; | 129 }; |
112 | 130 |
113 VideoCaptureImplTest() { | 131 VideoCaptureImplTest() { |
114 params_small_.requested_format = media::VideoCaptureFormat( | 132 params_small_.requested_format = media::VideoCaptureFormat( |
115 gfx::Size(176, 144), 30, media::VIDEO_CAPTURE_PIXEL_FORMAT_I420); | 133 gfx::Size(176, 144), 30, media::VIDEO_CAPTURE_PIXEL_FORMAT_I420); |
116 | 134 |
117 params_large_.requested_format = media::VideoCaptureFormat( | 135 params_large_.requested_format = media::VideoCaptureFormat( |
118 gfx::Size(320, 240), 30, media::VIDEO_CAPTURE_PIXEL_FORMAT_I420); | 136 gfx::Size(320, 240), 30, media::VIDEO_CAPTURE_PIXEL_FORMAT_I420); |
119 | 137 |
120 child_process_.reset(new ChildProcess()); | 138 child_process_.reset(new ChildProcess()); |
(...skipping 26 matching lines...) Expand all Loading... | |
147 void StartCapture(const media::VideoCaptureParams& params) { | 165 void StartCapture(const media::VideoCaptureParams& params) { |
148 video_capture_impl_->StartCapture( | 166 video_capture_impl_->StartCapture( |
149 params, base::Bind(&VideoCaptureImplTest::OnStateUpdate, | 167 params, base::Bind(&VideoCaptureImplTest::OnStateUpdate, |
150 base::Unretained(this)), | 168 base::Unretained(this)), |
151 base::Bind(&VideoCaptureImplTest::OnFrameReady, | 169 base::Bind(&VideoCaptureImplTest::OnFrameReady, |
152 base::Unretained(this))); | 170 base::Unretained(this))); |
153 } | 171 } |
154 | 172 |
155 void StopCapture() { video_capture_impl_->StopCapture(); } | 173 void StopCapture() { video_capture_impl_->StopCapture(); } |
156 | 174 |
175 void NewBuffer(int buffer_id, const base::SharedMemory& shm) { | |
176 video_capture_impl_->OnBufferCreated( | |
177 base::SharedMemory::DuplicateHandle(shm.handle()), | |
178 shm.mapped_size(), buffer_id); | |
179 } | |
180 | |
181 void BufferReceived(int buffer_id, const gfx::Size& size, | |
182 media::VideoPixelFormat pixel_format, | |
183 const gpu::MailboxHolder& mailbox_holder) { | |
184 video_capture_impl_->OnBufferReceived( | |
185 buffer_id, base::TimeTicks::Now(), base::DictionaryValue(), | |
186 pixel_format, media::VideoFrame::STORAGE_SHMEM, size, | |
187 gfx::Rect(size), mailbox_holder); | |
188 } | |
189 | |
190 void BufferDestroyed(int buffer_id) { | |
191 video_capture_impl_->OnBufferDestroyed(buffer_id); | |
192 } | |
193 | |
157 void DeInit() { | 194 void DeInit() { |
158 video_capture_impl_->DeInit(); | 195 video_capture_impl_->DeInit(); |
159 } | 196 } |
160 | 197 |
161 void GetDeviceSupportedFormats() { | 198 void GetDeviceSupportedFormats() { |
162 const base::Callback<void(const media::VideoCaptureFormats&)> | 199 const base::Callback<void(const media::VideoCaptureFormats&)> |
163 callback = base::Bind( | 200 callback = base::Bind( |
164 &VideoCaptureImplTest::OnDeviceSupportedFormats, | 201 &VideoCaptureImplTest::OnDeviceSupportedFormats, |
165 base::Unretained(this)); | 202 base::Unretained(this)); |
166 video_capture_impl_->GetDeviceSupportedFormats(callback); | 203 video_capture_impl_->GetDeviceSupportedFormats(callback); |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
221 // Check that a request to GetDeviceFormatsInUse() ends up eventually in the | 258 // Check that a request to GetDeviceFormatsInUse() ends up eventually in the |
222 // provided callback. | 259 // provided callback. |
223 TEST_F(VideoCaptureImplTest, GetDeviceFormatsInUse) { | 260 TEST_F(VideoCaptureImplTest, GetDeviceFormatsInUse) { |
224 EXPECT_CALL(*this, OnDeviceFormatsInUse(_)); | 261 EXPECT_CALL(*this, OnDeviceFormatsInUse(_)); |
225 | 262 |
226 Init(); | 263 Init(); |
227 GetDeviceFormatsInUse(); | 264 GetDeviceFormatsInUse(); |
228 DeInit(); | 265 DeInit(); |
229 } | 266 } |
230 | 267 |
268 TEST_P(VideoCaptureImplTest, BufferReceivedWithFormat) { | |
269 EXPECT_CALL(*this, OnStateUpdate(VIDEO_CAPTURE_STATE_STARTED)).Times(1); | |
270 EXPECT_CALL(*this, OnStateUpdate(VIDEO_CAPTURE_STATE_STOPPED)).Times(1); | |
271 EXPECT_CALL(*this, OnFrameReady(_, _)).Times(1); | |
272 | |
273 const BufferReceivedTestArg& buffer_arg = GetParam(); | |
274 | |
275 // Create a fake shared memory for buffer. | |
276 base::SharedMemory shm; | |
277 const size_t frame_size = media::VideoFrame::AllocationSize( | |
278 buffer_arg.pixel_format, buffer_arg.coded_size); | |
279 ASSERT_TRUE(shm.CreateAndMapAnonymous(frame_size)); | |
280 | |
281 media::VideoCaptureParams params; | |
282 params.requested_format = media::VideoCaptureFormat( | |
283 buffer_arg.coded_size, 30, buffer_arg.capture_pixel_format); | |
284 | |
285 Init(); | |
286 StartCapture(params); | |
287 NewBuffer(buffer_arg.buffer_id, shm); | |
288 BufferReceived(buffer_arg.buffer_id, buffer_arg.coded_size, | |
289 buffer_arg.pixel_format, buffer_arg.mailbox_holder); | |
290 StopCapture(); | |
291 BufferDestroyed(buffer_arg.buffer_id); | |
292 DeInit(); | |
293 } | |
294 | |
295 const BufferReceivedTestArg kBufferFormats[] = { | |
296 BufferReceivedTestArg(0, media::PIXEL_FORMAT_I420, | |
297 media::VIDEO_CAPTURE_PIXEL_FORMAT_I420, | |
298 gfx::Size(1280, 720), | |
299 gpu::MailboxHolder()), | |
300 BufferReceivedTestArg(0, media::PIXEL_FORMAT_ARGB, | |
301 media::VIDEO_CAPTURE_PIXEL_FORMAT_ARGB, | |
302 gfx::Size(1280, 720), | |
303 gpu::MailboxHolder(gpu::Mailbox::Generate(), 0, 0))}; | |
304 | |
305 INSTANTIATE_TEST_CASE_P(I420AndARGB, | |
306 VideoCaptureImplTest, | |
307 testing::ValuesIn(kBufferFormats)); | |
mcasas
2015/09/01 18:09:53
I meant defining it inside the INSTANTIATE_...
so
msu.koo
2015/09/02 08:38:10
Done.
| |
308 | |
309 TEST_F(VideoCaptureImplTest, BufferReceivedAfterStop) { | |
310 EXPECT_CALL(*this, OnStateUpdate(VIDEO_CAPTURE_STATE_STARTED)).Times(1); | |
311 EXPECT_CALL(*this, OnStateUpdate(VIDEO_CAPTURE_STATE_STOPPED)).Times(1); | |
312 EXPECT_CALL(*this, OnFrameReady(_, _)).Times(0); | |
313 | |
314 // Create a fake shared memory for buffer. | |
315 base::SharedMemory shm; | |
316 const size_t i420_frame_size = media::VideoFrame::AllocationSize( | |
317 media::PIXEL_FORMAT_I420, params_large_.requested_format.frame_size); | |
318 ASSERT_TRUE(shm.CreateAndMapAnonymous(i420_frame_size)); | |
319 | |
320 Init(); | |
321 StartCapture(params_large_); | |
322 NewBuffer(0, shm); | |
323 StopCapture(); | |
324 BufferReceived(0, params_large_.requested_format.frame_size, | |
325 media::PIXEL_FORMAT_I420, gpu::MailboxHolder()); | |
326 BufferDestroyed(0); | |
327 DeInit(); | |
328 | |
329 EXPECT_EQ(this->video_capture_impl_->received_buffer_count(), 1); | |
330 } | |
331 | |
231 TEST_F(VideoCaptureImplTest, EndedBeforeStop) { | 332 TEST_F(VideoCaptureImplTest, EndedBeforeStop) { |
232 EXPECT_CALL(*this, OnStateUpdate(VIDEO_CAPTURE_STATE_STARTED)); | 333 EXPECT_CALL(*this, OnStateUpdate(VIDEO_CAPTURE_STATE_STARTED)); |
233 EXPECT_CALL(*this, OnStateUpdate(VIDEO_CAPTURE_STATE_STOPPED)); | 334 EXPECT_CALL(*this, OnStateUpdate(VIDEO_CAPTURE_STATE_STOPPED)); |
234 | 335 |
235 Init(); | 336 Init(); |
236 StartCapture(params_small_); | 337 StartCapture(params_small_); |
237 | 338 |
238 // Receive state change message from browser. | 339 // Receive state change message from browser. |
239 video_capture_impl_->ReceiveStateChangeMessage(VIDEO_CAPTURE_STATE_ENDED); | 340 video_capture_impl_->ReceiveStateChangeMessage(VIDEO_CAPTURE_STATE_ENDED); |
240 | 341 |
241 StopCapture(); | 342 StopCapture(); |
242 DeInit(); | 343 DeInit(); |
243 } | 344 } |
244 | 345 |
245 TEST_F(VideoCaptureImplTest, ErrorBeforeStop) { | 346 TEST_F(VideoCaptureImplTest, ErrorBeforeStop) { |
246 EXPECT_CALL(*this, OnStateUpdate(VIDEO_CAPTURE_STATE_STARTED)); | 347 EXPECT_CALL(*this, OnStateUpdate(VIDEO_CAPTURE_STATE_STARTED)); |
247 EXPECT_CALL(*this, OnStateUpdate(VIDEO_CAPTURE_STATE_ERROR)); | 348 EXPECT_CALL(*this, OnStateUpdate(VIDEO_CAPTURE_STATE_ERROR)); |
248 | 349 |
249 Init(); | 350 Init(); |
250 StartCapture(params_small_); | 351 StartCapture(params_small_); |
251 | 352 |
252 // Receive state change message from browser. | 353 // Receive state change message from browser. |
253 video_capture_impl_->ReceiveStateChangeMessage(VIDEO_CAPTURE_STATE_ERROR); | 354 video_capture_impl_->ReceiveStateChangeMessage(VIDEO_CAPTURE_STATE_ERROR); |
254 | 355 |
255 StopCapture(); | 356 StopCapture(); |
256 DeInit(); | 357 DeInit(); |
257 } | 358 } |
258 | 359 |
259 } // namespace content | 360 } // namespace content |
OLD | NEW |