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 "media/blink/webmediaplayer_impl.h" | 5 #include "media/blink/webmediaplayer_impl.h" |
6 | 6 |
7 #include <stdint.h> | 7 #include <stdint.h> |
8 | 8 |
9 #include <memory> | 9 #include <memory> |
10 | 10 |
11 #include "base/bind.h" | 11 #include "base/bind.h" |
12 #include "base/callback_helpers.h" | 12 #include "base/callback_helpers.h" |
13 #include "base/memory/ptr_util.h" | 13 #include "base/memory/ptr_util.h" |
14 #include "base/memory/ref_counted.h" | 14 #include "base/memory/ref_counted.h" |
15 #include "base/memory/weak_ptr.h" | 15 #include "base/memory/weak_ptr.h" |
16 #include "base/message_loop/message_loop.h" | 16 #include "base/message_loop/message_loop.h" |
17 #include "base/threading/thread.h" | 17 #include "base/threading/thread.h" |
18 #include "base/threading/thread_task_runner_handle.h" | 18 #include "base/threading/thread_task_runner_handle.h" |
19 #include "media/base/audio_hardware_config.h" | |
20 #include "media/base/media_log.h" | 19 #include "media/base/media_log.h" |
21 #include "media/base/test_helpers.h" | 20 #include "media/base/test_helpers.h" |
22 #include "media/blink/mock_webframeclient.h" | 21 #include "media/blink/mock_webframeclient.h" |
23 #include "media/blink/webmediaplayer_delegate.h" | 22 #include "media/blink/webmediaplayer_delegate.h" |
24 #include "media/blink/webmediaplayer_params.h" | 23 #include "media/blink/webmediaplayer_params.h" |
25 #include "media/renderers/default_renderer_factory.h" | 24 #include "media/renderers/default_renderer_factory.h" |
26 #include "testing/gmock/include/gmock/gmock.h" | 25 #include "testing/gmock/include/gmock/gmock.h" |
27 #include "testing/gtest/include/gtest/gtest.h" | 26 #include "testing/gtest/include/gtest/gtest.h" |
28 #include "third_party/WebKit/public/platform/WebMediaPlayerClient.h" | 27 #include "third_party/WebKit/public/platform/WebMediaPlayerClient.h" |
29 #include "third_party/WebKit/public/platform/WebSecurityOrigin.h" | 28 #include "third_party/WebKit/public/platform/WebSecurityOrigin.h" |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
84 | 83 |
85 class WebMediaPlayerImplTest : public testing::Test { | 84 class WebMediaPlayerImplTest : public testing::Test { |
86 public: | 85 public: |
87 WebMediaPlayerImplTest() | 86 WebMediaPlayerImplTest() |
88 : media_thread_("MediaThreadForTest"), | 87 : media_thread_("MediaThreadForTest"), |
89 web_view_(blink::WebView::create(nullptr)), | 88 web_view_(blink::WebView::create(nullptr)), |
90 web_local_frame_( | 89 web_local_frame_( |
91 blink::WebLocalFrame::create(blink::WebTreeScopeType::Document, | 90 blink::WebLocalFrame::create(blink::WebTreeScopeType::Document, |
92 &web_frame_client_)), | 91 &web_frame_client_)), |
93 media_log_(new MediaLog()), | 92 media_log_(new MediaLog()), |
94 audio_parameters_(TestAudioParameters::Normal()), | 93 audio_parameters_(TestAudioParameters::Normal()) { |
95 audio_hardware_config_(audio_parameters_, audio_parameters_) { | |
96 web_view_->setMainFrame(web_local_frame_); | 94 web_view_->setMainFrame(web_local_frame_); |
97 media_thread_.StartAndWaitForTesting(); | 95 media_thread_.StartAndWaitForTesting(); |
98 | 96 |
99 wmpi_.reset(new WebMediaPlayerImpl( | 97 wmpi_.reset(new WebMediaPlayerImpl( |
100 web_local_frame_, &client_, nullptr, | 98 web_local_frame_, &client_, nullptr, |
101 base::WeakPtr<WebMediaPlayerDelegate>(), | 99 base::WeakPtr<WebMediaPlayerDelegate>(), |
102 base::WrapUnique(new DefaultRendererFactory( | 100 base::WrapUnique(new DefaultRendererFactory( |
103 media_log_, nullptr, DefaultRendererFactory::GetGpuFactoriesCB(), | 101 media_log_, nullptr, DefaultRendererFactory::GetGpuFactoriesCB())), |
104 audio_hardware_config_)), | |
105 url_index_, | 102 url_index_, |
106 WebMediaPlayerParams( | 103 WebMediaPlayerParams( |
107 WebMediaPlayerParams::DeferLoadCB(), | 104 WebMediaPlayerParams::DeferLoadCB(), |
108 scoped_refptr<SwitchableAudioRendererSink>(), media_log_, | 105 scoped_refptr<SwitchableAudioRendererSink>(), media_log_, |
109 media_thread_.task_runner(), message_loop_.task_runner(), | 106 media_thread_.task_runner(), message_loop_.task_runner(), |
110 message_loop_.task_runner(), WebMediaPlayerParams::Context3DCB(), | 107 message_loop_.task_runner(), WebMediaPlayerParams::Context3DCB(), |
111 base::Bind(&OnAdjustAllocatedMemory), nullptr, nullptr, nullptr))); | 108 base::Bind(&OnAdjustAllocatedMemory), nullptr, nullptr, nullptr))); |
112 } | 109 } |
113 | 110 |
114 ~WebMediaPlayerImplTest() override { | 111 ~WebMediaPlayerImplTest() override { |
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
175 // Blink state. | 172 // Blink state. |
176 MockWebFrameClient web_frame_client_; | 173 MockWebFrameClient web_frame_client_; |
177 blink::WebView* web_view_; | 174 blink::WebView* web_view_; |
178 blink::WebLocalFrame* web_local_frame_; | 175 blink::WebLocalFrame* web_local_frame_; |
179 | 176 |
180 scoped_refptr<MediaLog> media_log_; | 177 scoped_refptr<MediaLog> media_log_; |
181 linked_ptr<media::UrlIndex> url_index_; | 178 linked_ptr<media::UrlIndex> url_index_; |
182 | 179 |
183 // Audio hardware configuration. | 180 // Audio hardware configuration. |
184 AudioParameters audio_parameters_; | 181 AudioParameters audio_parameters_; |
185 AudioHardwareConfig audio_hardware_config_; | |
186 | 182 |
187 // The client interface used by |wmpi_|. Just a dummy for now, but later we | 183 // The client interface used by |wmpi_|. Just a dummy for now, but later we |
188 // may want a mock or intelligent fake. | 184 // may want a mock or intelligent fake. |
189 DummyWebMediaPlayerClient client_; | 185 DummyWebMediaPlayerClient client_; |
190 | 186 |
191 // The WebMediaPlayerImpl instance under test. | 187 // The WebMediaPlayerImpl instance under test. |
192 std::unique_ptr<WebMediaPlayerImpl> wmpi_; | 188 std::unique_ptr<WebMediaPlayerImpl> wmpi_; |
193 | 189 |
194 private: | 190 private: |
195 DISALLOW_COPY_AND_ASSIGN(WebMediaPlayerImplTest); | 191 DISALLOW_COPY_AND_ASSIGN(WebMediaPlayerImplTest); |
(...skipping 171 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
367 EXPECT_FALSE(state.is_memory_reporting_enabled); | 363 EXPECT_FALSE(state.is_memory_reporting_enabled); |
368 EXPECT_FALSE(state.is_suspended); | 364 EXPECT_FALSE(state.is_suspended); |
369 | 365 |
370 state = ComputeIdlePlayState(); | 366 state = ComputeIdlePlayState(); |
371 EXPECT_EQ(WebMediaPlayerImpl::DelegateState::ENDED, state.delegate_state); | 367 EXPECT_EQ(WebMediaPlayerImpl::DelegateState::ENDED, state.delegate_state); |
372 EXPECT_FALSE(state.is_memory_reporting_enabled); | 368 EXPECT_FALSE(state.is_memory_reporting_enabled); |
373 EXPECT_TRUE(state.is_suspended); | 369 EXPECT_TRUE(state.is_suspended); |
374 } | 370 } |
375 | 371 |
376 } // namespace media | 372 } // namespace media |
OLD | NEW |