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
3 // found in the LICENSE file.
4
5 #include "cc/layers/picture_layer_impl.h"
6
7 #include "cc/debug/lap_timer.h"
8 #include "cc/test/fake_impl_proxy.h"
9 #include "cc/test/fake_layer_tree_host_impl.h"
10 #include "cc/test/fake_output_surface.h"
11 #include "cc/test/fake_picture_layer_impl.h"
12 #include "cc/test/fake_picture_pile_impl.h"
13 #include "cc/test/impl_side_painting_settings.h"
14 #include "cc/test/test_shared_bitmap_manager.h"
15 #include "cc/trees/layer_tree_impl.h"
16 #include "testing/gtest/include/gtest/gtest.h"
17 #include "testing/perf/perf_test.h"
18
19 namespace cc {
20 namespace {
21
22 static const int kTimeLimitMillis = 2000;
23 static const int kWarmupRuns = 5;
24 static const int kTimeCheckInterval = 10;
25
AddTiling(float scale,FakePictureLayerImpl * layer,std::vector<Tile * > * all_tiles)26 void AddTiling(float scale,
27 FakePictureLayerImpl* layer,
28 std::vector<Tile*>* all_tiles) {
29 PictureLayerTiling* tiling = layer->AddTiling(scale);
30
31 tiling->CreateAllTilesForTesting();
32 std::vector<Tile*> tiling_tiles = tiling->AllTilesForTesting();
33 std::copy(
34 tiling_tiles.begin(), tiling_tiles.end(), std::back_inserter(*all_tiles));
35 }
36
37 class PictureLayerImplPerfTest : public testing::Test {
38 public:
PictureLayerImplPerfTest()39 PictureLayerImplPerfTest()
40 : proxy_(base::MessageLoopProxy::current()),
41 host_impl_(ImplSidePaintingSettings(),
42 &proxy_,
43 &shared_bitmap_manager_),
44 timer_(kWarmupRuns,
45 base::TimeDelta::FromMilliseconds(kTimeLimitMillis),
46 kTimeCheckInterval) {}
47
SetUp()48 virtual void SetUp() OVERRIDE {
49 host_impl_.InitializeRenderer(
50 FakeOutputSurface::Create3d().PassAs<OutputSurface>());
51 }
52
SetupPendingTree(const gfx::Size & layer_bounds,const gfx::Size & tile_size)53 void SetupPendingTree(const gfx::Size& layer_bounds,
54 const gfx::Size& tile_size) {
55 scoped_refptr<FakePicturePileImpl> pile =
56 FakePicturePileImpl::CreateFilledPile(tile_size, layer_bounds);
57 host_impl_.CreatePendingTree();
58 LayerTreeImpl* pending_tree = host_impl_.pending_tree();
59 pending_tree->DetachLayerTree();
60
61 scoped_ptr<FakePictureLayerImpl> pending_layer =
62 FakePictureLayerImpl::CreateWithPile(pending_tree, 7, pile);
63 pending_layer->SetDrawsContent(true);
64 pending_tree->SetRootLayer(pending_layer.PassAs<LayerImpl>());
65
66 pending_layer_ = static_cast<FakePictureLayerImpl*>(
67 host_impl_.pending_tree()->LayerById(7));
68 pending_layer_->DoPostCommitInitializationIfNeeded();
69 }
70
RunRasterIteratorConstructAndIterateTest(const std::string & test_name,int num_tiles,const gfx::Size & viewport_size)71 void RunRasterIteratorConstructAndIterateTest(
72 const std::string& test_name,
73 int num_tiles,
74 const gfx::Size& viewport_size) {
75 host_impl_.SetViewportSize(viewport_size);
76 host_impl_.pending_tree()->UpdateDrawProperties();
77
78 timer_.Reset();
79 do {
80 int count = num_tiles;
81 PictureLayerImpl::LayerRasterTileIterator it(pending_layer_, false);
82 while (count--) {
83 ASSERT_TRUE(it) << "count: " << count;
84 ASSERT_TRUE(*it != NULL) << "count: " << count;
85 ++it;
86 }
87 timer_.NextLap();
88 } while (!timer_.HasTimeLimitExpired());
89
90 perf_test::PrintResult("layer_raster_tile_iterator_construct_and_iterate",
91 "",
92 test_name,
93 timer_.LapsPerSecond(),
94 "runs/s",
95 true);
96 }
97
RunRasterIteratorConstructTest(const std::string & test_name,const gfx::Rect & viewport)98 void RunRasterIteratorConstructTest(const std::string& test_name,
99 const gfx::Rect& viewport) {
100 host_impl_.SetViewportSize(viewport.size());
101 pending_layer_->SetScrollOffset(gfx::Vector2d(viewport.x(), viewport.y()));
102 host_impl_.pending_tree()->UpdateDrawProperties();
103
104 timer_.Reset();
105 do {
106 PictureLayerImpl::LayerRasterTileIterator it(pending_layer_, false);
107 timer_.NextLap();
108 } while (!timer_.HasTimeLimitExpired());
109
110 perf_test::PrintResult("layer_raster_tile_iterator_construct",
111 "",
112 test_name,
113 timer_.LapsPerSecond(),
114 "runs/s",
115 true);
116 }
117
RunEvictionIteratorConstructAndIterateTest(const std::string & test_name,int num_tiles,const gfx::Size & viewport_size)118 void RunEvictionIteratorConstructAndIterateTest(
119 const std::string& test_name,
120 int num_tiles,
121 const gfx::Size& viewport_size) {
122 host_impl_.SetViewportSize(viewport_size);
123 host_impl_.pending_tree()->UpdateDrawProperties();
124
125 TreePriority priorities[] = {SAME_PRIORITY_FOR_BOTH_TREES,
126 SMOOTHNESS_TAKES_PRIORITY,
127 NEW_CONTENT_TAKES_PRIORITY};
128 int priority_count = 0;
129 timer_.Reset();
130 do {
131 int count = num_tiles;
132 PictureLayerImpl::LayerEvictionTileIterator it(
133 pending_layer_, priorities[priority_count]);
134 while (count--) {
135 ASSERT_TRUE(it) << "count: " << count;
136 ASSERT_TRUE(*it != NULL) << "count: " << count;
137 ++it;
138 }
139 priority_count = (priority_count + 1) % arraysize(priorities);
140 timer_.NextLap();
141 } while (!timer_.HasTimeLimitExpired());
142
143 perf_test::PrintResult("layer_eviction_tile_iterator_construct_and_iterate",
144 "",
145 test_name,
146 timer_.LapsPerSecond(),
147 "runs/s",
148 true);
149 }
150
RunEvictionIteratorConstructTest(const std::string & test_name,const gfx::Rect & viewport)151 void RunEvictionIteratorConstructTest(const std::string& test_name,
152 const gfx::Rect& viewport) {
153 host_impl_.SetViewportSize(viewport.size());
154 pending_layer_->SetScrollOffset(gfx::Vector2d(viewport.x(), viewport.y()));
155 host_impl_.pending_tree()->UpdateDrawProperties();
156
157 TreePriority priorities[] = {SAME_PRIORITY_FOR_BOTH_TREES,
158 SMOOTHNESS_TAKES_PRIORITY,
159 NEW_CONTENT_TAKES_PRIORITY};
160 int priority_count = 0;
161 timer_.Reset();
162 do {
163 PictureLayerImpl::LayerEvictionTileIterator it(
164 pending_layer_, priorities[priority_count]);
165 priority_count = (priority_count + 1) % arraysize(priorities);
166 timer_.NextLap();
167 } while (!timer_.HasTimeLimitExpired());
168
169 perf_test::PrintResult("layer_eviction_tile_iterator_construct",
170 "",
171 test_name,
172 timer_.LapsPerSecond(),
173 "runs/s",
174 true);
175 }
176
177 protected:
178 TestSharedBitmapManager shared_bitmap_manager_;
179 FakeImplProxy proxy_;
180 FakeLayerTreeHostImpl host_impl_;
181 FakePictureLayerImpl* pending_layer_;
182 LapTimer timer_;
183
184 private:
185 DISALLOW_COPY_AND_ASSIGN(PictureLayerImplPerfTest);
186 };
187
TEST_F(PictureLayerImplPerfTest,LayerRasterTileIteratorConstructAndIterate)188 TEST_F(PictureLayerImplPerfTest, LayerRasterTileIteratorConstructAndIterate) {
189 SetupPendingTree(gfx::Size(10000, 10000), gfx::Size(256, 256));
190
191 float low_res_factor = host_impl_.settings().low_res_contents_scale_factor;
192
193 pending_layer_->AddTiling(low_res_factor);
194 pending_layer_->AddTiling(0.3f);
195 pending_layer_->AddTiling(0.7f);
196 pending_layer_->AddTiling(1.0f);
197 pending_layer_->AddTiling(2.0f);
198
199 RunRasterIteratorConstructAndIterateTest(
200 "32_100x100", 32, gfx::Size(100, 100));
201 RunRasterIteratorConstructAndIterateTest(
202 "32_500x500", 32, gfx::Size(500, 500));
203 RunRasterIteratorConstructAndIterateTest(
204 "64_100x100", 64, gfx::Size(100, 100));
205 RunRasterIteratorConstructAndIterateTest(
206 "64_500x500", 64, gfx::Size(500, 500));
207 }
208
TEST_F(PictureLayerImplPerfTest,LayerRasterTileIteratorConstruct)209 TEST_F(PictureLayerImplPerfTest, LayerRasterTileIteratorConstruct) {
210 SetupPendingTree(gfx::Size(10000, 10000), gfx::Size(256, 256));
211
212 float low_res_factor = host_impl_.settings().low_res_contents_scale_factor;
213
214 pending_layer_->AddTiling(low_res_factor);
215 pending_layer_->AddTiling(0.3f);
216 pending_layer_->AddTiling(0.7f);
217 pending_layer_->AddTiling(1.0f);
218 pending_layer_->AddTiling(2.0f);
219
220 RunRasterIteratorConstructTest("0_0_100x100", gfx::Rect(0, 0, 100, 100));
221 RunRasterIteratorConstructTest("5000_0_100x100",
222 gfx::Rect(5000, 0, 100, 100));
223 RunRasterIteratorConstructTest("9999_0_100x100",
224 gfx::Rect(9999, 0, 100, 100));
225 }
226
TEST_F(PictureLayerImplPerfTest,LayerEvictionTileIteratorConstructAndIterate)227 TEST_F(PictureLayerImplPerfTest, LayerEvictionTileIteratorConstructAndIterate) {
228 SetupPendingTree(gfx::Size(10000, 10000), gfx::Size(256, 256));
229
230 float low_res_factor = host_impl_.settings().low_res_contents_scale_factor;
231
232 std::vector<Tile*> all_tiles;
233 AddTiling(low_res_factor, pending_layer_, &all_tiles);
234 AddTiling(0.3f, pending_layer_, &all_tiles);
235 AddTiling(0.7f, pending_layer_, &all_tiles);
236 AddTiling(1.0f, pending_layer_, &all_tiles);
237 AddTiling(2.0f, pending_layer_, &all_tiles);
238
239 ASSERT_TRUE(host_impl_.tile_manager() != NULL);
240 host_impl_.tile_manager()->InitializeTilesWithResourcesForTesting(all_tiles);
241
242 RunEvictionIteratorConstructAndIterateTest(
243 "32_100x100", 32, gfx::Size(100, 100));
244 RunEvictionIteratorConstructAndIterateTest(
245 "32_500x500", 32, gfx::Size(500, 500));
246 RunEvictionIteratorConstructAndIterateTest(
247 "64_100x100", 64, gfx::Size(100, 100));
248 RunEvictionIteratorConstructAndIterateTest(
249 "64_500x500", 64, gfx::Size(500, 500));
250 }
251
TEST_F(PictureLayerImplPerfTest,LayerEvictionTileIteratorConstruct)252 TEST_F(PictureLayerImplPerfTest, LayerEvictionTileIteratorConstruct) {
253 SetupPendingTree(gfx::Size(10000, 10000), gfx::Size(256, 256));
254
255 float low_res_factor = host_impl_.settings().low_res_contents_scale_factor;
256
257 std::vector<Tile*> all_tiles;
258 AddTiling(low_res_factor, pending_layer_, &all_tiles);
259 AddTiling(0.3f, pending_layer_, &all_tiles);
260 AddTiling(0.7f, pending_layer_, &all_tiles);
261 AddTiling(1.0f, pending_layer_, &all_tiles);
262 AddTiling(2.0f, pending_layer_, &all_tiles);
263
264 ASSERT_TRUE(host_impl_.tile_manager() != NULL);
265 host_impl_.tile_manager()->InitializeTilesWithResourcesForTesting(all_tiles);
266
267 RunEvictionIteratorConstructTest("0_0_100x100", gfx::Rect(0, 0, 100, 100));
268 RunEvictionIteratorConstructTest("5000_0_100x100",
269 gfx::Rect(5000, 0, 100, 100));
270 RunEvictionIteratorConstructTest("9999_0_100x100",
271 gfx::Rect(9999, 0, 100, 100));
272 }
273
274 } // namespace
275 } // namespace cc
276