| 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 |