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

Side by Side Diff: android_webview/browser/test/rendering_test.cc

Issue 1943963003: WIP Handle AwContents needing multiple live functors. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Testing framework changes to support testing multiple RenderThreadManager instances. Created 4 years, 7 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 "android_webview/browser/test/rendering_test.h" 5 #include "android_webview/browser/test/rendering_test.h"
6 6
7 #include <utility> 7 #include <utility>
8 8
9 #include "android_webview/browser/browser_view_renderer.h" 9 #include "android_webview/browser/browser_view_renderer.h"
10 #include "android_webview/browser/child_frame.h" 10 #include "android_webview/browser/child_frame.h"
(...skipping 11 matching lines...) Expand all
22 class TestBrowserViewRenderer : public BrowserViewRenderer { 22 class TestBrowserViewRenderer : public BrowserViewRenderer {
23 public: 23 public:
24 TestBrowserViewRenderer( 24 TestBrowserViewRenderer(
25 RenderingTest* rendering_test, 25 RenderingTest* rendering_test,
26 const scoped_refptr<base::SingleThreadTaskRunner>& ui_task_runner) 26 const scoped_refptr<base::SingleThreadTaskRunner>& ui_task_runner)
27 : BrowserViewRenderer(rendering_test, ui_task_runner), 27 : BrowserViewRenderer(rendering_test, ui_task_runner),
28 rendering_test_(rendering_test) {} 28 rendering_test_(rendering_test) {}
29 29
30 ~TestBrowserViewRenderer() override {} 30 ~TestBrowserViewRenderer() override {}
31 31
32 void OnParentDrawConstraintsUpdated() override { 32 void OnParentDrawConstraintsUpdated(
33 BrowserViewRenderer::OnParentDrawConstraintsUpdated(); 33 CompositorFrameConsumer* compositor_frame_consumer) override {
34 BrowserViewRenderer::OnParentDrawConstraintsUpdated(
35 compositor_frame_consumer);
34 rendering_test_->OnParentDrawConstraintsUpdated(); 36 rendering_test_->OnParentDrawConstraintsUpdated();
35 } 37 }
36 38
37 private: 39 private:
38 RenderingTest* const rendering_test_; 40 RenderingTest* const rendering_test_;
39 }; 41 };
40 } 42 }
41 43
42 RenderingTest::RenderingTest() : message_loop_(new base::MessageLoop) { 44 RenderingTest::RenderingTest() : message_loop_(new base::MessageLoop) {
43 ui_task_runner_ = base::ThreadTaskRunnerHandle::Get(); 45 ui_task_runner_ = base::ThreadTaskRunnerHandle::Get();
44 } 46 }
45 47
46 RenderingTest::~RenderingTest() { 48 RenderingTest::~RenderingTest() {
47 DCHECK(ui_task_runner_->BelongsToCurrentThread()); 49 DCHECK(ui_task_runner_->BelongsToCurrentThread());
48 if (window_.get()) 50 if (window_.get())
49 window_->Detach(); 51 window_->Detach();
50 } 52 }
51 53
52 void RenderingTest::SetUpTestHarness() { 54 void RenderingTest::SetUpTestHarness() {
53 DCHECK(!browser_view_renderer_.get()); 55 DCHECK(!browser_view_renderer_.get());
54 DCHECK(!render_thread_manager_.get()); 56 DCHECK(!functor_.get());
55 render_thread_manager_.reset( 57 functor_.reset(new Functor(base::Bind(
56 new RenderThreadManager(this, base::ThreadTaskRunnerHandle::Get())); 58 &RenderingTest::CreateRenderThreadManager, base::Unretained(this))));
57 browser_view_renderer_.reset(new TestBrowserViewRenderer( 59 browser_view_renderer_.reset(
58 this, base::ThreadTaskRunnerHandle::Get())); 60 new TestBrowserViewRenderer(this, base::ThreadTaskRunnerHandle::Get()));
59 browser_view_renderer_->SetCompositorFrameConsumer( 61 browser_view_renderer_->SetCurrentCompositorFrameConsumer(
60 render_thread_manager_.get()); 62 functor_->GetCompositorFrameConsumer());
61 InitializeCompositor(); 63 InitializeCompositor();
62 Attach(); 64 Attach();
63 } 65 }
64 66
67 RenderThreadManager* RenderingTest::CreateRenderThreadManager(
68 RenderThreadManagerClient* client) {
69 return new RenderThreadManager(client, base::ThreadTaskRunnerHandle::Get());
boliu 2016/05/10 15:18:19 hmm, dcheck this is the ui thread?
Tobias Sargeant 2016/05/13 13:23:57 This got removed.
70 }
71
65 CompositorFrameConsumer* RenderingTest::GetCompositorFrameConsumer() { 72 CompositorFrameConsumer* RenderingTest::GetCompositorFrameConsumer() {
66 return render_thread_manager_.get(); 73 return functor_->GetCompositorFrameConsumer();
67 } 74 }
68 75
69 CompositorFrameProducer* RenderingTest::GetCompositorFrameProducer() { 76 CompositorFrameProducer* RenderingTest::GetCompositorFrameProducer() {
70 return browser_view_renderer_.get(); 77 return browser_view_renderer_.get();
71 } 78 }
72 79
73 void RenderingTest::InitializeCompositor() { 80 void RenderingTest::InitializeCompositor() {
74 DCHECK(!compositor_.get()); 81 DCHECK(!compositor_.get());
75 DCHECK(browser_view_renderer_.get()); 82 DCHECK(browser_view_renderer_.get());
76 compositor_.reset(new content::TestSynchronousCompositor); 83 compositor_.reset(new content::TestSynchronousCompositor);
77 compositor_->SetClient(browser_view_renderer_.get()); 84 compositor_->SetClient(browser_view_renderer_.get());
78 } 85 }
79 86
80 void RenderingTest::Attach() { 87 void RenderingTest::Attach() {
81 window_.reset( 88 window_.reset(
82 new FakeWindow(browser_view_renderer_.get(), 89 new FakeWindow(browser_view_renderer_.get(), this, gfx::Rect(100, 100)));
83 base::Bind(&RenderThreadManager::DrawGL, 90 window_->SetDrawFunctor(functor_.get());
84 base::Unretained(render_thread_manager_.get())),
85 this, gfx::Rect(100, 100)));
86 } 91 }
87 92
88 void RenderingTest::RunTest() { 93 void RenderingTest::RunTest() {
89 SetUpTestHarness(); 94 SetUpTestHarness();
90 95
91 ui_task_runner_->PostTask( 96 ui_task_runner_->PostTask(
92 FROM_HERE, base::Bind(&RenderingTest::StartTest, base::Unretained(this))); 97 FROM_HERE, base::Bind(&RenderingTest::StartTest, base::Unretained(this)));
93 message_loop_->Run(); 98 message_loop_->Run();
94 } 99 }
95 100
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
128 resource.id = resource_id; 133 resource.id = resource_id;
129 compositor_frame->delegated_frame_data->resource_list.push_back(resource); 134 compositor_frame->delegated_frame_data->resource_list.push_back(resource);
130 return compositor_frame; 135 return compositor_frame;
131 } 136 }
132 137
133 void RenderingTest::WillOnDraw() { 138 void RenderingTest::WillOnDraw() {
134 DCHECK(compositor_); 139 DCHECK(compositor_);
135 compositor_->SetHardwareFrame(0u, ConstructEmptyFrame()); 140 compositor_->SetHardwareFrame(0u, ConstructEmptyFrame());
136 } 141 }
137 142
138 bool RenderingTest::RequestInvokeGL(bool wait_for_completion) {
139 window_->RequestInvokeGL(wait_for_completion);
140 return true;
141 }
142
143 bool RenderingTest::WillDrawOnRT(AwDrawGLInfo* draw_info) { 143 bool RenderingTest::WillDrawOnRT(AwDrawGLInfo* draw_info) {
144 draw_info->width = window_->surface_size().width(); 144 draw_info->width = window_->surface_size().width();
145 draw_info->height = window_->surface_size().height(); 145 draw_info->height = window_->surface_size().height();
146 draw_info->is_layer = false; 146 draw_info->is_layer = false;
147 gfx::Transform transform; 147 gfx::Transform transform;
148 transform.matrix().asColMajorf(draw_info->transform); 148 transform.matrix().asColMajorf(draw_info->transform);
149 return true; 149 return true;
150 } 150 }
151 151
152 void RenderingTest::OnNewPicture() {} 152 void RenderingTest::OnNewPicture() {}
153 153
154 void RenderingTest::PostInvalidate() { 154 void RenderingTest::PostInvalidate() {
155 if (window_) 155 if (window_)
156 window_->PostInvalidate(); 156 window_->PostInvalidate();
157 } 157 }
158 158
159 void RenderingTest::DetachFunctorFromView() {}
160
161 gfx::Point RenderingTest::GetLocationOnScreen() { 159 gfx::Point RenderingTest::GetLocationOnScreen() {
162 return gfx::Point(); 160 return gfx::Point();
163 } 161 }
164 162
165 } // namespace android_webview 163 } // namespace android_webview
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698