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

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

Issue 1920843002: Test: deleting RTM before BVR does not leak resources. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fix clang compile error Created 4 years, 8 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
« no previous file with comments | « android_webview/browser/test/rendering_test.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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"
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 { 19 namespace {
20 // BrowserViewRenderer subclass used for enabling tests to observe 20 // BrowserViewRenderer subclass used for enabling tests to observe
21 // OnParentDrawConstraintsUpdated. 21 // OnParentDrawConstraintsUpdated.
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 {}
31
30 void OnParentDrawConstraintsUpdated() override { 32 void OnParentDrawConstraintsUpdated() override {
31 BrowserViewRenderer::OnParentDrawConstraintsUpdated(); 33 BrowserViewRenderer::OnParentDrawConstraintsUpdated();
32 rendering_test_->OnParentDrawConstraintsUpdated(); 34 rendering_test_->OnParentDrawConstraintsUpdated();
33 } 35 }
34 36
35 private: 37 private:
36 RenderingTest* const rendering_test_; 38 RenderingTest* const rendering_test_;
37 }; 39 };
38 } 40 }
39 41
40 RenderingTest::RenderingTest() : message_loop_(new base::MessageLoop) { 42 RenderingTest::RenderingTest() : message_loop_(new base::MessageLoop) {
41 ui_task_runner_ = base::ThreadTaskRunnerHandle::Get(); 43 ui_task_runner_ = base::ThreadTaskRunnerHandle::Get();
42 } 44 }
43 45
44 RenderingTest::~RenderingTest() { 46 RenderingTest::~RenderingTest() {
47 DCHECK(ui_task_runner_->BelongsToCurrentThread());
45 if (window_.get()) 48 if (window_.get())
46 window_->Detach(); 49 window_->Detach();
47 } 50 }
48 51
49 void RenderingTest::SetUpTestHarness() { 52 void RenderingTest::SetUpTestHarness() {
50 DCHECK(!browser_view_renderer_.get()); 53 DCHECK(!browser_view_renderer_.get());
51 DCHECK(!render_thread_manager_.get()); 54 DCHECK(!render_thread_manager_.get());
52 render_thread_manager_.reset( 55 render_thread_manager_.reset(
53 new RenderThreadManager(this, base::ThreadTaskRunnerHandle::Get())); 56 new RenderThreadManager(this, base::ThreadTaskRunnerHandle::Get()));
54 browser_view_renderer_.reset(new TestBrowserViewRenderer( 57 browser_view_renderer_.reset(new TestBrowserViewRenderer(
(...skipping 13 matching lines...) Expand all
68 } 71 }
69 72
70 void RenderingTest::InitializeCompositor() { 73 void RenderingTest::InitializeCompositor() {
71 DCHECK(!compositor_.get()); 74 DCHECK(!compositor_.get());
72 DCHECK(browser_view_renderer_.get()); 75 DCHECK(browser_view_renderer_.get());
73 compositor_.reset(new content::TestSynchronousCompositor); 76 compositor_.reset(new content::TestSynchronousCompositor);
74 compositor_->SetClient(browser_view_renderer_.get()); 77 compositor_->SetClient(browser_view_renderer_.get());
75 } 78 }
76 79
77 void RenderingTest::Attach() { 80 void RenderingTest::Attach() {
78 window_.reset(new FakeWindow(browser_view_renderer_.get(), 81 window_.reset(
79 render_thread_manager_.get(), this, 82 new FakeWindow(browser_view_renderer_.get(),
80 gfx::Rect(100, 100))); 83 base::Bind(&RenderThreadManager::DrawGL,
84 base::Unretained(render_thread_manager_.get())),
85 this, gfx::Rect(100, 100)));
81 } 86 }
82 87
83 void RenderingTest::RunTest() { 88 void RenderingTest::RunTest() {
84 SetUpTestHarness(); 89 SetUpTestHarness();
85 90
86 ui_task_runner_->PostTask( 91 ui_task_runner_->PostTask(
87 FROM_HERE, base::Bind(&RenderingTest::StartTest, base::Unretained(this))); 92 FROM_HERE, base::Bind(&RenderingTest::StartTest, base::Unretained(this)));
88 message_loop_->Run(); 93 message_loop_->Run();
89 } 94 }
90 95
(...skipping 18 matching lines...) Expand all
109 std::unique_ptr<cc::DelegatedFrameData> frame(new cc::DelegatedFrameData); 114 std::unique_ptr<cc::DelegatedFrameData> frame(new cc::DelegatedFrameData);
110 std::unique_ptr<cc::RenderPass> root_pass(cc::RenderPass::Create()); 115 std::unique_ptr<cc::RenderPass> root_pass(cc::RenderPass::Create());
111 gfx::Rect viewport(browser_view_renderer_->size()); 116 gfx::Rect viewport(browser_view_renderer_->size());
112 root_pass->SetNew(cc::RenderPassId(1, 1), viewport, viewport, 117 root_pass->SetNew(cc::RenderPassId(1, 1), viewport, viewport,
113 gfx::Transform()); 118 gfx::Transform());
114 frame->render_pass_list.push_back(std::move(root_pass)); 119 frame->render_pass_list.push_back(std::move(root_pass));
115 compositor_frame->delegated_frame_data = std::move(frame); 120 compositor_frame->delegated_frame_data = std::move(frame);
116 return compositor_frame; 121 return compositor_frame;
117 } 122 }
118 123
124 std::unique_ptr<cc::CompositorFrame> RenderingTest::ConstructFrame(
125 cc::ResourceId resource_id) {
126 std::unique_ptr<cc::CompositorFrame> compositor_frame(ConstructEmptyFrame());
127 cc::TransferableResource resource;
128 resource.id = resource_id;
129 compositor_frame->delegated_frame_data->resource_list.push_back(resource);
130 return compositor_frame;
131 }
132
119 void RenderingTest::WillOnDraw() { 133 void RenderingTest::WillOnDraw() {
120 DCHECK(compositor_); 134 DCHECK(compositor_);
121 compositor_->SetHardwareFrame(0u, ConstructEmptyFrame()); 135 compositor_->SetHardwareFrame(0u, ConstructEmptyFrame());
122 } 136 }
123 137
124 bool RenderingTest::RequestInvokeGL(bool wait_for_completion) { 138 bool RenderingTest::RequestInvokeGL(bool wait_for_completion) {
125 window_->RequestInvokeGL(wait_for_completion); 139 window_->RequestInvokeGL(wait_for_completion);
126 return true; 140 return true;
127 } 141 }
128 142
129 bool RenderingTest::WillDrawOnRT(RenderThreadManager* functor, 143 bool RenderingTest::WillDrawOnRT(AwDrawGLInfo* draw_info) {
130 AwDrawGLInfo* draw_info) {
131 draw_info->width = window_->surface_size().width(); 144 draw_info->width = window_->surface_size().width();
132 draw_info->height = window_->surface_size().height(); 145 draw_info->height = window_->surface_size().height();
133 draw_info->is_layer = false; 146 draw_info->is_layer = false;
134 gfx::Transform transform; 147 gfx::Transform transform;
135 transform.matrix().asColMajorf(draw_info->transform); 148 transform.matrix().asColMajorf(draw_info->transform);
136 return true; 149 return true;
137 } 150 }
138 151
139 void RenderingTest::OnNewPicture() { 152 void RenderingTest::OnNewPicture() {}
140 }
141 153
142 void RenderingTest::PostInvalidate() { 154 void RenderingTest::PostInvalidate() {
143 if (window_) 155 if (window_)
144 window_->PostInvalidate(); 156 window_->PostInvalidate();
145 } 157 }
146 158
147 void RenderingTest::DetachFunctorFromView() { 159 void RenderingTest::DetachFunctorFromView() {}
148 }
149 160
150 gfx::Point RenderingTest::GetLocationOnScreen() { 161 gfx::Point RenderingTest::GetLocationOnScreen() {
151 return gfx::Point(); 162 return gfx::Point();
152 } 163 }
153 164
154 } // namespace android_webview 165 } // namespace android_webview
OLDNEW
« no previous file with comments | « android_webview/browser/test/rendering_test.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698