| 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 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 base::WrapUnique(new RenderThreadManager( |
| 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() { | |
| 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 | |
| 88 void RenderingTest::RunTest() { | 86 void RenderingTest::RunTest() { |
| 89 SetUpTestHarness(); | 87 SetUpTestHarness(); |
| 90 | 88 |
| 91 ui_task_runner_->PostTask( | 89 ui_task_runner_->PostTask( |
| 92 FROM_HERE, base::Bind(&RenderingTest::StartTest, base::Unretained(this))); | 90 FROM_HERE, base::Bind(&RenderingTest::StartTest, base::Unretained(this))); |
| 93 message_loop_->Run(); | 91 message_loop_->Run(); |
| 94 } | 92 } |
| 95 | 93 |
| 96 void RenderingTest::StartTest() { | 94 void RenderingTest::StartTest() { |
| 97 EndTest(); | 95 EndTest(); |
| (...skipping 25 matching lines...) Expand all Loading... |
| 123 | 121 |
| 124 std::unique_ptr<cc::CompositorFrame> RenderingTest::ConstructFrame( | 122 std::unique_ptr<cc::CompositorFrame> RenderingTest::ConstructFrame( |
| 125 cc::ResourceId resource_id) { | 123 cc::ResourceId resource_id) { |
| 126 std::unique_ptr<cc::CompositorFrame> compositor_frame(ConstructEmptyFrame()); | 124 std::unique_ptr<cc::CompositorFrame> compositor_frame(ConstructEmptyFrame()); |
| 127 cc::TransferableResource resource; | 125 cc::TransferableResource resource; |
| 128 resource.id = resource_id; | 126 resource.id = resource_id; |
| 129 compositor_frame->delegated_frame_data->resource_list.push_back(resource); | 127 compositor_frame->delegated_frame_data->resource_list.push_back(resource); |
| 130 return compositor_frame; | 128 return compositor_frame; |
| 131 } | 129 } |
| 132 | 130 |
| 131 FakeFunctor* RenderingTest::GetFunctor() { |
| 132 return functor_.get(); |
| 133 } |
| 134 |
| 133 void RenderingTest::WillOnDraw() { | 135 void RenderingTest::WillOnDraw() { |
| 134 DCHECK(compositor_); | 136 DCHECK(compositor_); |
| 135 compositor_->SetHardwareFrame(0u, ConstructEmptyFrame()); | 137 compositor_->SetHardwareFrame(0u, ConstructEmptyFrame()); |
| 136 } | 138 } |
| 137 | 139 |
| 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) { | 140 bool RenderingTest::WillDrawOnRT(AwDrawGLInfo* draw_info) { |
| 144 draw_info->width = window_->surface_size().width(); | 141 draw_info->width = window_->surface_size().width(); |
| 145 draw_info->height = window_->surface_size().height(); | 142 draw_info->height = window_->surface_size().height(); |
| 146 draw_info->is_layer = false; | 143 draw_info->is_layer = false; |
| 147 gfx::Transform transform; | 144 gfx::Transform transform; |
| 148 transform.matrix().asColMajorf(draw_info->transform); | 145 transform.matrix().asColMajorf(draw_info->transform); |
| 149 return true; | 146 return true; |
| 150 } | 147 } |
| 151 | 148 |
| 152 void RenderingTest::OnNewPicture() {} | 149 void RenderingTest::OnNewPicture() {} |
| 153 | 150 |
| 154 void RenderingTest::PostInvalidate() { | 151 void RenderingTest::PostInvalidate() { |
| 155 if (window_) | 152 if (window_) |
| 156 window_->PostInvalidate(); | 153 window_->PostInvalidate(); |
| 157 } | 154 } |
| 158 | 155 |
| 159 void RenderingTest::DetachFunctorFromView() {} | |
| 160 | |
| 161 gfx::Point RenderingTest::GetLocationOnScreen() { | 156 gfx::Point RenderingTest::GetLocationOnScreen() { |
| 162 return gfx::Point(); | 157 return gfx::Point(); |
| 163 } | 158 } |
| 164 | 159 |
| 165 } // namespace android_webview | 160 } // namespace android_webview |
| OLD | NEW |