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

Side by Side Diff: cc/trees/layer_tree_host_unittest_no_message_loop.cc

Issue 1177033008: cc: Turn impl_side_painting and use_one_copy on in LayerTreeSettings. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 6 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 "base/thread_task_runner_handle.h" 5 #include "base/thread_task_runner_handle.h"
6 #include "base/threading/simple_thread.h" 6 #include "base/threading/simple_thread.h"
7 #include "cc/layers/delegated_frame_provider.h" 7 #include "cc/layers/delegated_frame_provider.h"
8 #include "cc/layers/delegated_frame_resource_collection.h" 8 #include "cc/layers/delegated_frame_resource_collection.h"
9 #include "cc/layers/delegated_renderer_layer.h" 9 #include "cc/layers/delegated_renderer_layer.h"
10 #include "cc/layers/layer.h" 10 #include "cc/layers/layer.h"
11 #include "cc/layers/solid_color_layer.h" 11 #include "cc/layers/solid_color_layer.h"
12 #include "cc/output/delegated_frame_data.h" 12 #include "cc/output/delegated_frame_data.h"
13 #include "cc/output/output_surface.h" 13 #include "cc/output/output_surface.h"
14 #include "cc/output/output_surface_client.h" 14 #include "cc/output/output_surface_client.h"
15 #include "cc/resources/resource_provider.h" 15 #include "cc/resources/resource_provider.h"
16 #include "cc/scheduler/begin_frame_source.h" 16 #include "cc/scheduler/begin_frame_source.h"
17 #include "cc/test/fake_delegated_renderer_layer.h" 17 #include "cc/test/fake_delegated_renderer_layer.h"
18 #include "cc/test/test_context_provider.h" 18 #include "cc/test/test_context_provider.h"
19 #include "cc/test/test_task_graph_runner.h"
19 #include "cc/trees/layer_tree_host.h" 20 #include "cc/trees/layer_tree_host.h"
20 #include "cc/trees/layer_tree_host_client.h" 21 #include "cc/trees/layer_tree_host_client.h"
21 #include "cc/trees/layer_tree_host_single_thread_client.h" 22 #include "cc/trees/layer_tree_host_single_thread_client.h"
22 #include "testing/gtest/include/gtest/gtest.h" 23 #include "testing/gtest/include/gtest/gtest.h"
23 #include "third_party/skia/include/core/SkColor.h" 24 #include "third_party/skia/include/core/SkColor.h"
24 25
25 namespace cc { 26 namespace cc {
26 namespace { 27 namespace {
27 28
28 class NoMessageLoopOutputSurface : public OutputSurface { 29 class NoMessageLoopOutputSurface : public OutputSurface {
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after
102 103
103 void SetupLayerTreeHost() { 104 void SetupLayerTreeHost() {
104 LayerTreeSettings settings; 105 LayerTreeSettings settings;
105 settings.single_thread_proxy_scheduler = false; 106 settings.single_thread_proxy_scheduler = false;
106 settings.verify_property_trees = false; 107 settings.verify_property_trees = false;
107 settings.raster_enabled = false; 108 settings.raster_enabled = false;
108 109
109 LayerTreeHost::InitParams params; 110 LayerTreeHost::InitParams params;
110 params.client = this; 111 params.client = this;
111 params.settings = &settings; 112 params.settings = &settings;
113 params.task_graph_runner = &task_graph_runner_;
112 layer_tree_host_ = LayerTreeHost::CreateSingleThreaded(this, &params); 114 layer_tree_host_ = LayerTreeHost::CreateSingleThreaded(this, &params);
113 layer_tree_host_->SetViewportSize(size_); 115 layer_tree_host_->SetViewportSize(size_);
114 layer_tree_host_->SetRootLayer(root_layer_); 116 layer_tree_host_->SetRootLayer(root_layer_);
115 } 117 }
116 118
117 void Composite() { 119 void Composite() {
118 did_commit_ = false; 120 did_commit_ = false;
119 did_commit_and_draw_frame_ = false; 121 did_commit_and_draw_frame_ = false;
120 layer_tree_host_->Composite(base::TimeTicks::Now()); 122 layer_tree_host_->Composite(base::TimeTicks::Now());
121 EXPECT_TRUE(did_initialize_output_surface_); 123 EXPECT_TRUE(did_initialize_output_surface_);
122 EXPECT_TRUE(did_commit_); 124 EXPECT_TRUE(did_commit_);
123 EXPECT_TRUE(did_commit_and_draw_frame_); 125 EXPECT_TRUE(did_commit_and_draw_frame_);
124 } 126 }
125 127
126 void TearDownLayerTreeHost() { 128 void TearDownLayerTreeHost() {
127 // Explicit teardown to make failures easier to debug. 129 // Explicit teardown to make failures easier to debug.
128 layer_tree_host_ = nullptr; 130 layer_tree_host_ = nullptr;
129 root_layer_ = nullptr; 131 root_layer_ = nullptr;
130 } 132 }
131 133
132 // All protected member variables are accessed only on |no_loop_thread_|. 134 // All protected member variables are accessed only on |no_loop_thread_|.
135 TestTaskGraphRunner task_graph_runner_;
133 scoped_ptr<LayerTreeHost> layer_tree_host_; 136 scoped_ptr<LayerTreeHost> layer_tree_host_;
134 scoped_refptr<Layer> root_layer_; 137 scoped_refptr<Layer> root_layer_;
135 138
136 bool did_initialize_output_surface_; 139 bool did_initialize_output_surface_;
137 bool did_commit_; 140 bool did_commit_;
138 bool did_commit_and_draw_frame_; 141 bool did_commit_and_draw_frame_;
139 gfx::Size size_; 142 gfx::Size size_;
140 143
141 private: 144 private:
142 base::DelegateSimpleThread no_loop_thread_; 145 base::DelegateSimpleThread no_loop_thread_;
(...skipping 97 matching lines...) Expand 10 before | Expand all | Expand 10 after
240 scoped_refptr<DelegatedFrameProvider> frame_provider_; 243 scoped_refptr<DelegatedFrameProvider> frame_provider_;
241 scoped_refptr<DelegatedRendererLayer> delegated_layer_; 244 scoped_refptr<DelegatedRendererLayer> delegated_layer_;
242 }; 245 };
243 246
244 TEST_F(LayerTreeHostNoMessageLoopDelegatedLayer, SingleDelegatedLayer) { 247 TEST_F(LayerTreeHostNoMessageLoopDelegatedLayer, SingleDelegatedLayer) {
245 RunTest(); 248 RunTest();
246 } 249 }
247 250
248 } // namespace 251 } // namespace
249 } // namespace cc 252 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698