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

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: 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 browser_view_renderer_.reset(
56 new RenderThreadManager(this, base::ThreadTaskRunnerHandle::Get())); 58 new TestBrowserViewRenderer(this, base::ThreadTaskRunnerHandle::Get()));
57 browser_view_renderer_.reset(new TestBrowserViewRenderer(
58 this, base::ThreadTaskRunnerHandle::Get()));
59 browser_view_renderer_->SetCompositorFrameConsumer(
60 render_thread_manager_.get());
61 InitializeCompositor(); 59 InitializeCompositor();
62 Attach(); 60 std::unique_ptr<FakeWindow> window(
61 new FakeWindow(browser_view_renderer_.get(), this, gfx::Rect(100, 100)));
62 functor_.reset(new FakeFunctor);
63 functor_->Init(window.get(),
64 std::unique_ptr<RenderThreadManager>(new RenderThreadManager(
boliu 2016/05/13 16:09:03 base::WrapUnique
Tobias Sargeant 2016/05/13 17:02:37 Done.
65 functor_.get(), base::ThreadTaskRunnerHandle::Get())));
66 browser_view_renderer_->SetCurrentCompositorFrameConsumer(
67 functor_->GetCompositorFrameConsumer());
68 window_ = std::move(window);
63 } 69 }
64 70
65 CompositorFrameConsumer* RenderingTest::GetCompositorFrameConsumer() { 71 CompositorFrameConsumer* RenderingTest::GetCompositorFrameConsumer() {
66 return render_thread_manager_.get(); 72 return functor_->GetCompositorFrameConsumer();
67 } 73 }
68 74
69 CompositorFrameProducer* RenderingTest::GetCompositorFrameProducer() { 75 CompositorFrameProducer* RenderingTest::GetCompositorFrameProducer() {
70 return browser_view_renderer_.get(); 76 return browser_view_renderer_.get();
71 } 77 }
72 78
73 void RenderingTest::InitializeCompositor() { 79 void RenderingTest::InitializeCompositor() {
74 DCHECK(!compositor_.get()); 80 DCHECK(!compositor_.get());
75 DCHECK(browser_view_renderer_.get()); 81 DCHECK(browser_view_renderer_.get());
76 compositor_.reset(new content::TestSynchronousCompositor); 82 compositor_.reset(new content::TestSynchronousCompositor);
77 compositor_->SetClient(browser_view_renderer_.get()); 83 compositor_->SetClient(browser_view_renderer_.get());
78 } 84 }
79 85
80 void RenderingTest::Attach() { 86 void RenderingTest::Attach() {
boliu 2016/05/13 16:09:02 remove
81 window_.reset(
82 new FakeWindow(browser_view_renderer_.get(),
83 base::Bind(&RenderThreadManager::DrawGL,
84 base::Unretained(render_thread_manager_.get())),
85 this, gfx::Rect(100, 100)));
86 } 87 }
87 88
88 void RenderingTest::RunTest() { 89 void RenderingTest::RunTest() {
89 SetUpTestHarness(); 90 SetUpTestHarness();
90 91
91 ui_task_runner_->PostTask( 92 ui_task_runner_->PostTask(
92 FROM_HERE, base::Bind(&RenderingTest::StartTest, base::Unretained(this))); 93 FROM_HERE, base::Bind(&RenderingTest::StartTest, base::Unretained(this)));
93 message_loop_->Run(); 94 message_loop_->Run();
94 } 95 }
95 96
(...skipping 27 matching lines...) Expand all
123 124
124 std::unique_ptr<cc::CompositorFrame> RenderingTest::ConstructFrame( 125 std::unique_ptr<cc::CompositorFrame> RenderingTest::ConstructFrame(
125 cc::ResourceId resource_id) { 126 cc::ResourceId resource_id) {
126 std::unique_ptr<cc::CompositorFrame> compositor_frame(ConstructEmptyFrame()); 127 std::unique_ptr<cc::CompositorFrame> compositor_frame(ConstructEmptyFrame());
127 cc::TransferableResource resource; 128 cc::TransferableResource resource;
128 resource.id = resource_id; 129 resource.id = resource_id;
129 compositor_frame->delegated_frame_data->resource_list.push_back(resource); 130 compositor_frame->delegated_frame_data->resource_list.push_back(resource);
130 return compositor_frame; 131 return compositor_frame;
131 } 132 }
132 133
134 FakeFunctor* RenderingTest::GetFunctorForView(BrowserViewRenderer* view) {
135 return functor_.get();
136 }
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