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" |
| 11 #include "android_webview/browser/render_thread_manager.h" | 11 #include "android_webview/browser/render_thread_manager.h" |
| 12 #include "base/location.h" | 12 #include "base/location.h" |
| 13 #include "base/thread_task_runner_handle.h" | 13 #include "base/thread_task_runner_handle.h" |
| 14 #include "cc/output/compositor_frame.h" | 14 #include "cc/output/compositor_frame.h" |
| 15 #include "content/public/test/test_synchronous_compositor_android.h" | 15 #include "content/public/test/test_synchronous_compositor_android.h" |
| 16 | 16 |
| 17 namespace android_webview { | 17 namespace android_webview { |
| 18 | 18 |
| 19 namespace { | |
| 20 // BrowserViewRenderer subclass used for enabling tests to observe | |
| 21 // OnParentDrawConstraintsUpdated. | |
| 22 class BrowserViewRendererTest : public BrowserViewRenderer { | |
|
boliu
2016/04/21 18:14:11
TestFoo, not FooTest. FooTest means it's the test
Tobias Sargeant
2016/04/22 11:42:22
Done.
| |
| 23 public: | |
| 24 BrowserViewRendererTest( | |
| 25 RenderingTest* rendering_test, | |
| 26 const scoped_refptr<base::SingleThreadTaskRunner>& ui_task_runner, | |
| 27 bool disable_page_visibility) | |
| 28 : BrowserViewRenderer(rendering_test, | |
| 29 ui_task_runner, | |
| 30 disable_page_visibility), | |
| 31 rendering_test_(rendering_test) {} | |
| 32 | |
| 33 void OnParentDrawConstraintsUpdated() override { | |
| 34 BrowserViewRenderer::OnParentDrawConstraintsUpdated(); | |
| 35 rendering_test_->OnParentDrawConstraintsUpdated(); | |
| 36 } | |
| 37 | |
| 38 private: | |
| 39 RenderingTest* rendering_test_; | |
|
boliu
2016/04/21 18:14:11
* const
Tobias Sargeant
2016/04/22 11:42:22
Done.
| |
| 40 }; | |
| 41 } | |
| 42 | |
| 19 RenderingTest::RenderingTest() : message_loop_(new base::MessageLoop) { | 43 RenderingTest::RenderingTest() : message_loop_(new base::MessageLoop) { |
| 20 ui_task_runner_ = base::ThreadTaskRunnerHandle::Get(); | 44 ui_task_runner_ = base::ThreadTaskRunnerHandle::Get(); |
| 21 } | 45 } |
| 22 | 46 |
| 23 RenderingTest::~RenderingTest() { | 47 RenderingTest::~RenderingTest() { |
| 24 if (window_.get()) | 48 if (window_.get()) |
| 25 window_->Detach(); | 49 window_->Detach(); |
| 26 } | 50 } |
| 27 | 51 |
| 28 void RenderingTest::SetUpTestHarness() { | 52 void RenderingTest::SetUpTestHarness() { |
| 29 DCHECK(!browser_view_renderer_.get()); | 53 DCHECK(!browser_view_renderer_.get()); |
| 30 DCHECK(!render_thread_manager_.get()); | 54 DCHECK(!render_thread_manager_.get()); |
| 31 render_thread_manager_.reset( | 55 render_thread_manager_.reset( |
| 32 new RenderThreadManager(this, base::ThreadTaskRunnerHandle::Get())); | 56 new RenderThreadManager(this, base::ThreadTaskRunnerHandle::Get())); |
| 33 browser_view_renderer_.reset(new BrowserViewRenderer( | 57 browser_view_renderer_.reset(new BrowserViewRendererTest( |
| 34 this, base::ThreadTaskRunnerHandle::Get(), false)); | 58 this, base::ThreadTaskRunnerHandle::Get(), false)); |
| 35 browser_view_renderer_->SetRenderThreadManager(render_thread_manager_.get()); | 59 browser_view_renderer_->SetCompositorFrameConsumer( |
| 60 render_thread_manager_.get()); | |
|
boliu
2016/04/21 18:14:11
hmm, this totally gives us the test ability to put
Tobias Sargeant
2016/04/22 11:42:22
Acknowledged.
| |
| 36 InitializeCompositor(); | 61 InitializeCompositor(); |
| 37 Attach(); | 62 Attach(); |
| 38 } | 63 } |
| 39 | 64 |
| 40 void RenderingTest::InitializeCompositor() { | 65 void RenderingTest::InitializeCompositor() { |
| 41 DCHECK(!compositor_.get()); | 66 DCHECK(!compositor_.get()); |
| 42 DCHECK(browser_view_renderer_.get()); | 67 DCHECK(browser_view_renderer_.get()); |
| 43 compositor_.reset(new content::TestSynchronousCompositor); | 68 compositor_.reset(new content::TestSynchronousCompositor); |
| 44 compositor_->SetClient(browser_view_renderer_.get()); | 69 compositor_->SetClient(browser_view_renderer_.get()); |
| 45 } | 70 } |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 107 } | 132 } |
| 108 | 133 |
| 109 void RenderingTest::OnNewPicture() { | 134 void RenderingTest::OnNewPicture() { |
| 110 } | 135 } |
| 111 | 136 |
| 112 void RenderingTest::PostInvalidate() { | 137 void RenderingTest::PostInvalidate() { |
| 113 if (window_) | 138 if (window_) |
| 114 window_->PostInvalidate(); | 139 window_->PostInvalidate(); |
| 115 } | 140 } |
| 116 | 141 |
| 117 void RenderingTest::OnParentDrawConstraintsUpdated() { | |
| 118 browser_view_renderer_->OnParentDrawConstraintsUpdated(); | |
| 119 } | |
| 120 | |
| 121 void RenderingTest::DetachFunctorFromView() { | 142 void RenderingTest::DetachFunctorFromView() { |
| 122 } | 143 } |
| 123 | 144 |
| 124 gfx::Point RenderingTest::GetLocationOnScreen() { | 145 gfx::Point RenderingTest::GetLocationOnScreen() { |
| 125 return gfx::Point(); | 146 return gfx::Point(); |
| 126 } | 147 } |
| 127 | 148 |
| 128 } // namespace android_webview | 149 } // namespace android_webview |
| OLD | NEW |