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

Side by Side Diff: cc/resources/picture_layer_tiling_set_unittest.cc

Issue 62283012: cc: Added tile bundles (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: review Created 7 years 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 | Annotate | Revision Log
OLDNEW
1 // Copyright 2012 The Chromium Authors. All rights reserved. 1 // Copyright 2012 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 "cc/resources/picture_layer_tiling_set.h" 5 #include "cc/resources/picture_layer_tiling_set.h"
6 6
7 #include <map> 7 #include <map>
8 #include <vector> 8 #include <vector>
9 9
10 #include "cc/resources/resource_pool.h" 10 #include "cc/resources/resource_pool.h"
11 #include "cc/resources/resource_provider.h" 11 #include "cc/resources/resource_provider.h"
12 #include "cc/test/fake_output_surface.h" 12 #include "cc/test/fake_output_surface.h"
13 #include "cc/test/fake_output_surface_client.h" 13 #include "cc/test/fake_output_surface_client.h"
14 #include "cc/test/fake_picture_layer_tiling_client.h" 14 #include "cc/test/fake_picture_layer_tiling_client.h"
15 #include "cc/test/fake_tile_manager.h"
15 #include "cc/test/fake_tile_manager_client.h" 16 #include "cc/test/fake_tile_manager_client.h"
16 #include "testing/gtest/include/gtest/gtest.h" 17 #include "testing/gtest/include/gtest/gtest.h"
17 #include "ui/gfx/size_conversions.h" 18 #include "ui/gfx/size_conversions.h"
18 19
19 namespace cc { 20 namespace cc {
20 namespace { 21 namespace {
21 22
22 TEST(PictureLayerTilingSetTest, NoResources) { 23 TEST(PictureLayerTilingSetTest, NoResources) {
23 FakePictureLayerTilingClient client; 24 FakeTileManagerClient tile_manager_client;
25 FakeTileManager tile_manager(&tile_manager_client);
26 FakePictureLayerTilingClient client(&tile_manager);
24 gfx::Size layer_bounds(1000, 800); 27 gfx::Size layer_bounds(1000, 800);
25 PictureLayerTilingSet set(&client, layer_bounds); 28 PictureLayerTilingSet set(&client, layer_bounds);
26 client.SetTileSize(gfx::Size(256, 256)); 29 client.SetTileSize(gfx::Size(256, 256));
27 30
28 set.AddTiling(1.0); 31 set.AddTiling(1.0);
29 set.AddTiling(1.5); 32 set.AddTiling(1.5);
30 set.AddTiling(2.0); 33 set.AddTiling(2.0);
31 34
32 float contents_scale = 2.0; 35 float contents_scale = 2.0;
33 gfx::Size content_bounds( 36 gfx::Size content_bounds(
(...skipping 27 matching lines...) Expand all
61 float ideal_contents_scale, 64 float ideal_contents_scale,
62 float expected_scale) { 65 float expected_scale) {
63 FakeOutputSurfaceClient output_surface_client; 66 FakeOutputSurfaceClient output_surface_client;
64 scoped_ptr<FakeOutputSurface> output_surface = 67 scoped_ptr<FakeOutputSurface> output_surface =
65 FakeOutputSurface::Create3d(); 68 FakeOutputSurface::Create3d();
66 CHECK(output_surface->BindToClient(&output_surface_client)); 69 CHECK(output_surface->BindToClient(&output_surface_client));
67 70
68 scoped_ptr<ResourceProvider> resource_provider = 71 scoped_ptr<ResourceProvider> resource_provider =
69 ResourceProvider::Create(output_surface.get(), NULL, 0, false, 1); 72 ResourceProvider::Create(output_surface.get(), NULL, 0, false, 1);
70 73
71 FakePictureLayerTilingClient client(resource_provider.get()); 74 FakeTileManagerClient tile_manager_client;
75 FakeTileManager tile_manager(&tile_manager_client, resource_provider.get());
76
77 FakePictureLayerTilingClient client(&tile_manager);
72 client.SetTileSize(gfx::Size(256, 256)); 78 client.SetTileSize(gfx::Size(256, 256));
73 gfx::Size layer_bounds(1000, 800); 79 gfx::Size layer_bounds(1000, 800);
74 PictureLayerTilingSet set(&client, layer_bounds); 80 PictureLayerTilingSet set(&client, layer_bounds);
75 81
76 float scale = min_scale; 82 float scale = min_scale;
77 for (int i = 0; i < num_tilings; ++i, scale += scale_increment) { 83 for (int i = 0; i < num_tilings; ++i, scale += scale_increment) {
78 PictureLayerTiling* tiling = set.AddTiling(scale); 84 PictureLayerTiling* tiling = set.AddTiling(scale);
79 tiling->CreateAllTilesForTesting(); 85 tiling->CreateAllTilesForTesting();
80 std::vector<Tile*> tiles = tiling->AllTilesForTesting(); 86 std::vector<Tile*> tiles = tiling->AllTilesForTesting();
81 client.tile_manager()->InitializeTilesWithResourcesForTesting( 87 client.tile_manager()->InitializeTilesWithResourcesForTesting(
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after
143 TEST_F(PictureLayerTilingSetTestWithResources, ManyTilings_NotEqual) { 149 TEST_F(PictureLayerTilingSetTestWithResources, ManyTilings_NotEqual) {
144 runTest(10, 1.f, 1.f, 4.5f, 5.f); 150 runTest(10, 1.f, 1.f, 4.5f, 5.f);
145 } 151 }
146 152
147 class PictureLayerTilingSetSyncTest : public testing::Test { 153 class PictureLayerTilingSetSyncTest : public testing::Test {
148 public: 154 public:
149 PictureLayerTilingSetSyncTest() 155 PictureLayerTilingSetSyncTest()
150 : tile_size_(gfx::Size(10, 10)), 156 : tile_size_(gfx::Size(10, 10)),
151 source_bounds_(gfx::Size(30, 20)), 157 source_bounds_(gfx::Size(30, 20)),
152 target_bounds_(gfx::Size(30, 30)) { 158 target_bounds_(gfx::Size(30, 30)) {
153 source_client_.SetTileSize(tile_size_); 159 output_surface_ = FakeOutputSurface::Create3d();
154 target_client_.SetTileSize(tile_size_); 160 CHECK(output_surface_->BindToClient(&output_surface_client_));
155 source_.reset(new PictureLayerTilingSet(&source_client_, source_bounds_)); 161 resource_provider_ =
156 target_.reset(new PictureLayerTilingSet(&target_client_, target_bounds_)); 162 ResourceProvider::Create(output_surface_.get(), NULL, 0, false, 1);
163 tile_manager_ = make_scoped_ptr(
164 new FakeTileManager(&tile_manager_client_, resource_provider_.get()));
165 source_client_ =
166 make_scoped_ptr(new FakePictureLayerTilingClient(tile_manager_.get()));
167 target_client_ =
168 make_scoped_ptr(new FakePictureLayerTilingClient(tile_manager_.get()));
169
170 source_client_->SetTileSize(tile_size_);
171 target_client_->SetTileSize(tile_size_);
172
173 source_.reset(
174 new PictureLayerTilingSet(source_client_.get(), source_bounds_));
175 target_.reset(
176 new PictureLayerTilingSet(target_client_.get(), target_bounds_));
157 } 177 }
158 178
159 // Sync from source to target. 179 // Sync from source to target.
160 void SyncTilings(gfx::Size new_bounds, 180 void SyncTilings(gfx::Size new_bounds,
161 const Region& invalidation, 181 const Region& invalidation,
162 float minimum_scale) { 182 float minimum_scale) {
163 for (size_t i = 0; i < source_->num_tilings(); ++i) 183 for (size_t i = 0; i < source_->num_tilings(); ++i)
164 source_->tiling_at(i)->CreateAllTilesForTesting(); 184 source_->tiling_at(i)->CreateTilesForTesting(ACTIVE_TREE);
165 for (size_t i = 0; i < target_->num_tilings(); ++i) 185 for (size_t i = 0; i < target_->num_tilings(); ++i)
166 target_->tiling_at(i)->CreateAllTilesForTesting(); 186 target_->tiling_at(i)->CreateTilesForTesting(PENDING_TREE);
167 187
168 target_->SyncTilings( 188 target_->SyncTilings(
169 *source_.get(), new_bounds, invalidation, minimum_scale); 189 *source_.get(), new_bounds, invalidation, minimum_scale);
170 } 190 }
171 void SyncTilings(gfx::Size new_bounds) { 191 void SyncTilings(gfx::Size new_bounds) {
172 Region invalidation; 192 Region invalidation;
173 SyncTilings(new_bounds, invalidation, 0.f); 193 SyncTilings(new_bounds, invalidation, 0.f);
174 } 194 }
175 void SyncTilings(gfx::Size new_bounds, const Region& invalidation) { 195 void SyncTilings(gfx::Size new_bounds, const Region& invalidation) {
176 SyncTilings(new_bounds, invalidation, 0.f); 196 SyncTilings(new_bounds, invalidation, 0.f);
(...skipping 11 matching lines...) Expand all
188 for (size_t i = 0; i < target_->num_tilings(); ++i) { 208 for (size_t i = 0; i < target_->num_tilings(); ++i) {
189 ASSERT_GT(source_->num_tilings(), i); 209 ASSERT_GT(source_->num_tilings(), i);
190 const PictureLayerTiling* source_tiling = source_->tiling_at(i); 210 const PictureLayerTiling* source_tiling = source_->tiling_at(i);
191 const PictureLayerTiling* target_tiling = target_->tiling_at(i); 211 const PictureLayerTiling* target_tiling = target_->tiling_at(i);
192 EXPECT_EQ(target_tiling->layer_bounds().ToString(), 212 EXPECT_EQ(target_tiling->layer_bounds().ToString(),
193 new_bounds.ToString()); 213 new_bounds.ToString());
194 EXPECT_EQ(source_tiling->contents_scale(), 214 EXPECT_EQ(source_tiling->contents_scale(),
195 target_tiling->contents_scale()); 215 target_tiling->contents_scale());
196 } 216 }
197 217
198 EXPECT_EQ(source_->client(), &source_client_); 218 EXPECT_EQ(source_->client(), source_client_.get());
199 EXPECT_EQ(target_->client(), &target_client_); 219 EXPECT_EQ(target_->client(), target_client_.get());
200 ValidateTargetTilingSet(); 220 ValidateTargetTilingSet();
201 } 221 }
202 222
203 void ValidateTargetTilingSet() const { 223 void ValidateTargetTilingSet() const {
204 // Tilings should be sorted largest to smallest. 224 // Tilings should be sorted largest to smallest.
205 if (target_->num_tilings() > 0) { 225 if (target_->num_tilings() > 0) {
206 float last_scale = target_->tiling_at(0)->contents_scale(); 226 float last_scale = target_->tiling_at(0)->contents_scale();
207 for (size_t i = 1; i < target_->num_tilings(); ++i) { 227 for (size_t i = 1; i < target_->num_tilings(); ++i) {
208 const PictureLayerTiling* target_tiling = target_->tiling_at(i); 228 const PictureLayerTiling* target_tiling = target_->tiling_at(i);
209 EXPECT_LT(target_tiling->contents_scale(), last_scale); 229 EXPECT_LT(target_tiling->contents_scale(), last_scale);
210 last_scale = target_tiling->contents_scale(); 230 last_scale = target_tiling->contents_scale();
211 } 231 }
212 } 232 }
213 233
214 for (size_t i = 0; i < target_->num_tilings(); ++i) 234 for (size_t i = 0; i < target_->num_tilings(); ++i)
215 ValidateTiling(target_->tiling_at(i), target_client_.pile()); 235 ValidateTiling(target_->tiling_at(i), target_client_->pile());
216 } 236 }
217 237
218 void ValidateTiling(const PictureLayerTiling* tiling, 238 void ValidateTiling(const PictureLayerTiling* tiling,
219 const PicturePileImpl* pile) const { 239 const PicturePileImpl* pile) const {
220 if (tiling->ContentRect().IsEmpty()) 240 if (tiling->ContentRect().IsEmpty())
221 EXPECT_TRUE(tiling->live_tiles_rect().IsEmpty()); 241 EXPECT_TRUE(tiling->live_tiles_rect().IsEmpty());
222 else if (!tiling->live_tiles_rect().IsEmpty()) 242 else if (!tiling->live_tiles_rect().IsEmpty())
223 EXPECT_TRUE(tiling->ContentRect().Contains(tiling->live_tiles_rect())); 243 EXPECT_TRUE(tiling->ContentRect().Contains(tiling->live_tiles_rect()));
224 244
225 std::vector<Tile*> tiles = tiling->AllTilesForTesting(); 245 std::vector<Tile*> tiles = tiling->TilesForTesting(PENDING_TREE);
226 for (size_t i = 0; i < tiles.size(); ++i) { 246 for (size_t i = 0; i < tiles.size(); ++i) {
227 const Tile* tile = tiles[i]; 247 const Tile* tile = tiles[i];
228 ASSERT_TRUE(!!tile); 248 ASSERT_TRUE(!!tile);
229 EXPECT_EQ(tile->picture_pile(), pile); 249 EXPECT_EQ(tile->picture_pile(), pile);
230 EXPECT_TRUE(tile->content_rect().Intersects(tiling->live_tiles_rect())) 250 EXPECT_TRUE(tile->content_rect().Intersects(tiling->live_tiles_rect()))
231 << "All tiles must be inside the live tiles rect."; 251 << "All tiles must be inside the live tiles rect.";
232 } 252 }
233 253
234 for (PictureLayerTiling::CoverageIterator iter( 254 for (PictureLayerTiling::CoverageIterator iter(
235 tiling, tiling->contents_scale(), tiling->live_tiles_rect()); 255 tiling, tiling->contents_scale(), tiling->live_tiles_rect());
236 iter; 256 iter;
237 ++iter) { 257 ++iter) {
238 EXPECT_TRUE(*iter) << "The live tiles rect must be full."; 258 EXPECT_TRUE(*iter) << "The live tiles rect must be full.";
239 } 259 }
240 } 260 }
241 261
262 scoped_ptr<FakeOutputSurface> output_surface_;
263 FakeOutputSurfaceClient output_surface_client_;
264
242 gfx::Size tile_size_; 265 gfx::Size tile_size_;
266 scoped_ptr<ResourceProvider> resource_provider_;
267 scoped_ptr<FakeTileManager> tile_manager_;
268 FakeTileManagerClient tile_manager_client_;
243 269
244 FakePictureLayerTilingClient source_client_; 270 scoped_ptr<FakePictureLayerTilingClient> source_client_;
245 gfx::Size source_bounds_; 271 gfx::Size source_bounds_;
246 scoped_ptr<PictureLayerTilingSet> source_; 272 scoped_ptr<PictureLayerTilingSet> source_;
247 273
248 FakePictureLayerTilingClient target_client_; 274 scoped_ptr<FakePictureLayerTilingClient> target_client_;
249 gfx::Size target_bounds_; 275 gfx::Size target_bounds_;
250 scoped_ptr<PictureLayerTilingSet> target_; 276 scoped_ptr<PictureLayerTilingSet> target_;
251 }; 277 };
252 278
253 TEST_F(PictureLayerTilingSetSyncTest, EmptyBounds) { 279 TEST_F(PictureLayerTilingSetSyncTest, EmptyBounds) {
254 float source_scales[] = {1.f, 1.2f}; 280 float source_scales[] = {1.f, 1.2f};
255 for (size_t i = 0; i < arraysize(source_scales); ++i) 281 for (size_t i = 0; i < arraysize(source_scales); ++i)
256 source_->AddTiling(source_scales[i]); 282 source_->AddTiling(source_scales[i]);
257 283
258 gfx::Size new_bounds; 284 gfx::Size new_bounds;
(...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after
341 SyncTilings(new_bounds, minimum_scale); 367 SyncTilings(new_bounds, minimum_scale);
342 368
343 EXPECT_EQ(target_->num_tilings(), 1u); 369 EXPECT_EQ(target_->num_tilings(), 1u);
344 EXPECT_EQ(target_->tiling_at(0)->contents_scale(), 2.f); 370 EXPECT_EQ(target_->tiling_at(0)->contents_scale(), 2.f);
345 ValidateTargetTilingSet(); 371 ValidateTargetTilingSet();
346 } 372 }
347 373
348 TEST_F(PictureLayerTilingSetSyncTest, Invalidation) { 374 TEST_F(PictureLayerTilingSetSyncTest, Invalidation) {
349 source_->AddTiling(2.f); 375 source_->AddTiling(2.f);
350 target_->AddTiling(2.f); 376 target_->AddTiling(2.f);
351 target_->tiling_at(0)->CreateAllTilesForTesting(); 377 target_->tiling_at(0)->CreateTilesForTesting(PENDING_TREE);
352 378
353 Region layer_invalidation; 379 Region layer_invalidation;
354 layer_invalidation.Union(gfx::Rect(0, 0, 1, 1)); 380 layer_invalidation.Union(gfx::Rect(0, 0, 1, 1));
355 layer_invalidation.Union(gfx::Rect(0, 15, 1, 1)); 381 layer_invalidation.Union(gfx::Rect(0, 15, 1, 1));
356 // Out of bounds layer_invalidation. 382 // Out of bounds layer_invalidation.
357 layer_invalidation.Union(gfx::Rect(100, 100, 1, 1)); 383 layer_invalidation.Union(gfx::Rect(100, 100, 1, 1));
358 384
359 Region content_invalidation; 385 Region content_invalidation;
360 for (Region::Iterator iter(layer_invalidation); iter.has_rect(); 386 for (Region::Iterator iter(layer_invalidation); iter.has_rect();
361 iter.next()) { 387 iter.next()) {
(...skipping 23 matching lines...) Expand all
385 411
386 TEST_F(PictureLayerTilingSetSyncTest, TileSizeChange) { 412 TEST_F(PictureLayerTilingSetSyncTest, TileSizeChange) {
387 source_->AddTiling(1.f); 413 source_->AddTiling(1.f);
388 target_->AddTiling(1.f); 414 target_->AddTiling(1.f);
389 415
390 target_->tiling_at(0)->CreateAllTilesForTesting(); 416 target_->tiling_at(0)->CreateAllTilesForTesting();
391 std::vector<Tile*> original_tiles = 417 std::vector<Tile*> original_tiles =
392 target_->tiling_at(0)->AllTilesForTesting(); 418 target_->tiling_at(0)->AllTilesForTesting();
393 EXPECT_GT(original_tiles.size(), 0u); 419 EXPECT_GT(original_tiles.size(), 0u);
394 gfx::Size new_tile_size(100, 100); 420 gfx::Size new_tile_size(100, 100);
395 target_client_.SetTileSize(new_tile_size); 421 target_client_->SetTileSize(new_tile_size);
396 EXPECT_NE(target_->tiling_at(0)->tile_size().ToString(), 422 EXPECT_NE(target_->tiling_at(0)->tile_size().ToString(),
397 new_tile_size.ToString()); 423 new_tile_size.ToString());
398 424
399 gfx::Size new_bounds(15, 40); 425 gfx::Size new_bounds(15, 40);
400 SyncTilings(new_bounds); 426 SyncTilings(new_bounds);
401 VerifyTargetEqualsSource(new_bounds); 427 VerifyTargetEqualsSource(new_bounds);
402 428
403 EXPECT_EQ(target_->tiling_at(0)->tile_size().ToString(), 429 EXPECT_EQ(target_->tiling_at(0)->tile_size().ToString(),
404 new_tile_size.ToString()); 430 new_tile_size.ToString());
405 431
406 // All old tiles should not be present in new tiles. 432 // All old tiles should not be present in new tiles.
407 std::vector<Tile*> new_tiles = target_->tiling_at(0)->AllTilesForTesting(); 433 std::vector<Tile*> new_tiles = target_->tiling_at(0)->AllTilesForTesting();
408 for (size_t i = 0; i < original_tiles.size(); ++i) { 434 for (size_t i = 0; i < original_tiles.size(); ++i) {
409 std::vector<Tile*>::iterator find = 435 std::vector<Tile*>::iterator find =
410 std::find(new_tiles.begin(), new_tiles.end(), original_tiles[i]); 436 std::find(new_tiles.begin(), new_tiles.end(), original_tiles[i]);
411 EXPECT_TRUE(find == new_tiles.end()); 437 EXPECT_TRUE(find == new_tiles.end());
412 } 438 }
413 } 439 }
414 440
415 } // namespace 441 } // namespace
416 } // namespace cc 442 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698