Chromium Code Reviews| 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 "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 Loading... | |
| 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 Loading... | |
| 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 |
| OLD | NEW |