| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "content/browser/frame_host/render_widget_host_view_child_frame.h" | 5 #include "content/browser/frame_host/render_widget_host_view_child_frame.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include <utility> | 9 #include <utility> |
| 10 | 10 |
| (...skipping 14 matching lines...) Expand all Loading... |
| 25 #include "content/browser/renderer_host/render_widget_host_impl.h" | 25 #include "content/browser/renderer_host/render_widget_host_impl.h" |
| 26 #include "content/common/view_messages.h" | 26 #include "content/common/view_messages.h" |
| 27 #include "content/public/browser/render_widget_host_view.h" | 27 #include "content/public/browser/render_widget_host_view.h" |
| 28 #include "content/public/test/mock_render_process_host.h" | 28 #include "content/public/test/mock_render_process_host.h" |
| 29 #include "content/public/test/test_browser_context.h" | 29 #include "content/public/test/test_browser_context.h" |
| 30 #include "content/test/test_render_view_host.h" | 30 #include "content/test/test_render_view_host.h" |
| 31 #include "testing/gtest/include/gtest/gtest.h" | 31 #include "testing/gtest/include/gtest/gtest.h" |
| 32 | 32 |
| 33 #if defined(OS_ANDROID) | 33 #if defined(OS_ANDROID) |
| 34 #include "content/browser/renderer_host/context_provider_factory_impl_android.h" | 34 #include "content/browser/renderer_host/context_provider_factory_impl_android.h" |
| 35 #include "content/test/mock_gpu_channel_establish_factory.h" | |
| 36 #endif | 35 #endif |
| 37 | 36 |
| 38 namespace content { | 37 namespace content { |
| 39 namespace { | 38 namespace { |
| 40 class MockRenderWidgetHostDelegate : public RenderWidgetHostDelegate { | 39 class MockRenderWidgetHostDelegate : public RenderWidgetHostDelegate { |
| 41 public: | 40 public: |
| 42 MockRenderWidgetHostDelegate() {} | 41 MockRenderWidgetHostDelegate() {} |
| 43 ~MockRenderWidgetHostDelegate() override {} | 42 ~MockRenderWidgetHostDelegate() override {} |
| 44 private: | 43 private: |
| 45 void Cut() override {} | 44 void Cut() override {} |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 79 RenderWidgetHostViewChildFrameTest() {} | 78 RenderWidgetHostViewChildFrameTest() {} |
| 80 | 79 |
| 81 void SetUp() override { | 80 void SetUp() override { |
| 82 browser_context_.reset(new TestBrowserContext); | 81 browser_context_.reset(new TestBrowserContext); |
| 83 | 82 |
| 84 // ImageTransportFactory doesn't exist on Android. | 83 // ImageTransportFactory doesn't exist on Android. |
| 85 #if !defined(OS_ANDROID) | 84 #if !defined(OS_ANDROID) |
| 86 ImageTransportFactory::InitializeForUnitTests( | 85 ImageTransportFactory::InitializeForUnitTests( |
| 87 base::WrapUnique(new NoTransportImageTransportFactory)); | 86 base::WrapUnique(new NoTransportImageTransportFactory)); |
| 88 #else | 87 #else |
| 89 ContextProviderFactoryImpl::Initialize(&gpu_channel_factory_); | |
| 90 ui::ContextProviderFactory::SetInstance( | 88 ui::ContextProviderFactory::SetInstance( |
| 91 ContextProviderFactoryImpl::GetInstance()); | 89 ContextProviderFactoryImpl::GetInstance()); |
| 92 #endif | 90 #endif |
| 93 | 91 |
| 94 MockRenderProcessHost* process_host = | 92 MockRenderProcessHost* process_host = |
| 95 new MockRenderProcessHost(browser_context_.get()); | 93 new MockRenderProcessHost(browser_context_.get()); |
| 96 int32_t routing_id = process_host->GetNextRoutingID(); | 94 int32_t routing_id = process_host->GetNextRoutingID(); |
| 97 widget_host_ = | 95 widget_host_ = |
| 98 new RenderWidgetHostImpl(&delegate_, process_host, routing_id, false); | 96 new RenderWidgetHostImpl(&delegate_, process_host, routing_id, false); |
| 99 view_ = new RenderWidgetHostViewChildFrame(widget_host_); | 97 view_ = new RenderWidgetHostViewChildFrame(widget_host_); |
| (...skipping 10 matching lines...) Expand all Loading... |
| 110 | 108 |
| 111 browser_context_.reset(); | 109 browser_context_.reset(); |
| 112 | 110 |
| 113 message_loop_.task_runner()->DeleteSoon(FROM_HERE, | 111 message_loop_.task_runner()->DeleteSoon(FROM_HERE, |
| 114 browser_context_.release()); | 112 browser_context_.release()); |
| 115 base::RunLoop().RunUntilIdle(); | 113 base::RunLoop().RunUntilIdle(); |
| 116 #if !defined(OS_ANDROID) | 114 #if !defined(OS_ANDROID) |
| 117 ImageTransportFactory::Terminate(); | 115 ImageTransportFactory::Terminate(); |
| 118 #else | 116 #else |
| 119 ui::ContextProviderFactory::SetInstance(nullptr); | 117 ui::ContextProviderFactory::SetInstance(nullptr); |
| 120 ContextProviderFactoryImpl::Terminate(); | |
| 121 #endif | 118 #endif |
| 122 } | 119 } |
| 123 | 120 |
| 124 cc::SurfaceId surface_id() { return view_->surface_id_; } | 121 cc::SurfaceId surface_id() { return view_->surface_id_; } |
| 125 | 122 |
| 126 protected: | 123 protected: |
| 127 base::MessageLoopForUI message_loop_; | 124 base::MessageLoopForUI message_loop_; |
| 128 std::unique_ptr<BrowserContext> browser_context_; | 125 std::unique_ptr<BrowserContext> browser_context_; |
| 129 MockRenderWidgetHostDelegate delegate_; | 126 MockRenderWidgetHostDelegate delegate_; |
| 130 | 127 |
| 131 // Tests should set these to NULL if they've already triggered their | 128 // Tests should set these to NULL if they've already triggered their |
| 132 // destruction. | 129 // destruction. |
| 133 RenderWidgetHostImpl* widget_host_; | 130 RenderWidgetHostImpl* widget_host_; |
| 134 RenderWidgetHostViewChildFrame* view_; | 131 RenderWidgetHostViewChildFrame* view_; |
| 135 MockCrossProcessFrameConnector* test_frame_connector_; | 132 MockCrossProcessFrameConnector* test_frame_connector_; |
| 136 | 133 |
| 137 #if defined(OS_ANDROID) | |
| 138 MockGpuChannelEstablishFactory gpu_channel_factory_; | |
| 139 #endif | |
| 140 | |
| 141 private: | 134 private: |
| 142 DISALLOW_COPY_AND_ASSIGN(RenderWidgetHostViewChildFrameTest); | 135 DISALLOW_COPY_AND_ASSIGN(RenderWidgetHostViewChildFrameTest); |
| 143 }; | 136 }; |
| 144 | 137 |
| 145 cc::CompositorFrame CreateDelegatedFrame(float scale_factor, | 138 cc::CompositorFrame CreateDelegatedFrame(float scale_factor, |
| 146 gfx::Size size, | 139 gfx::Size size, |
| 147 const gfx::Rect& damage) { | 140 const gfx::Rect& damage) { |
| 148 cc::CompositorFrame frame; | 141 cc::CompositorFrame frame; |
| 149 frame.metadata.device_scale_factor = scale_factor; | 142 frame.metadata.device_scale_factor = scale_factor; |
| 150 frame.delegated_frame_data.reset(new cc::DelegatedFrameData); | 143 frame.delegated_frame_data.reset(new cc::DelegatedFrameData); |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 190 | 183 |
| 191 // Surface ID should have been passed to CrossProcessFrameConnector to | 184 // Surface ID should have been passed to CrossProcessFrameConnector to |
| 192 // be sent to the embedding renderer. | 185 // be sent to the embedding renderer. |
| 193 EXPECT_EQ(id, test_frame_connector_->last_surface_id_received_); | 186 EXPECT_EQ(id, test_frame_connector_->last_surface_id_received_); |
| 194 EXPECT_EQ(view_size, test_frame_connector_->last_frame_size_received_); | 187 EXPECT_EQ(view_size, test_frame_connector_->last_frame_size_received_); |
| 195 EXPECT_EQ(scale_factor, test_frame_connector_->last_scale_factor_received_); | 188 EXPECT_EQ(scale_factor, test_frame_connector_->last_scale_factor_received_); |
| 196 } | 189 } |
| 197 } | 190 } |
| 198 | 191 |
| 199 } // namespace content | 192 } // namespace content |
| OLD | NEW |