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

Side by Side Diff: content/browser/frame_host/render_widget_host_view_child_frame_unittest.cc

Issue 2299333003: Revert of Revert "Revert of content: Fix Context creation logic in ContextProviderFactoryImpl." (Closed)
Patch Set: Created 4 years, 3 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 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
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
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
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
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
OLDNEW
« no previous file with comments | « content/browser/browser_main_loop.cc ('k') | content/browser/frame_host/render_widget_host_view_guest_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698