| Index: cc/resources/picture_layer_tiling_unittest.cc
|
| diff --git a/cc/resources/picture_layer_tiling_unittest.cc b/cc/resources/picture_layer_tiling_unittest.cc
|
| index 5e29b826275064786933a743a10812754c712c7c..6f3a822f82eb40cbfb3e676e41f9f901122a87fa 100644
|
| --- a/cc/resources/picture_layer_tiling_unittest.cc
|
| +++ b/cc/resources/picture_layer_tiling_unittest.cc
|
| @@ -421,6 +421,7 @@ TEST_F(PictureLayerTilingIteratorTest, TilesExist) {
|
| ACTIVE_TREE,
|
| layer_bounds, // device viewport
|
| gfx::Rect(layer_bounds), // viewport in layer space
|
| + gfx::Rect(layer_bounds), // visible content rect
|
| layer_bounds, // last layer bounds
|
| layer_bounds, // current layer bounds
|
| 1.f, // last contents scale
|
| @@ -438,6 +439,7 @@ TEST_F(PictureLayerTilingIteratorTest, TilesExist) {
|
| ACTIVE_TREE,
|
| layer_bounds, // device viewport
|
| gfx::Rect(), // viewport in layer space
|
| + gfx::Rect(), // visible content rect
|
| layer_bounds, // last layer bounds
|
| layer_bounds, // current layer bounds
|
| 1.f, // last contents scale
|
| @@ -451,5 +453,78 @@ TEST_F(PictureLayerTilingIteratorTest, TilesExist) {
|
| VerifyTiles(1.f, gfx::Rect(layer_bounds), base::Bind(&TileExists, false));
|
| }
|
|
|
| +TEST_F(PictureLayerTilingIteratorTest, TilesExistGiantViewport) {
|
| + gfx::Size layer_bounds(1099, 801);
|
| + Initialize(gfx::Size(100, 100), 1.f, layer_bounds);
|
| + VerifyTilesExactlyCoverRect(1.f, gfx::Rect(layer_bounds));
|
| + VerifyTiles(1.f, gfx::Rect(layer_bounds), base::Bind(&TileExists, false));
|
| +
|
| + gfx::Rect giant_rect(-10000000, -10000000, 1000000000, 1000000000);
|
| +
|
| + tiling_->UpdateTilePriorities(
|
| + ACTIVE_TREE,
|
| + layer_bounds, // device viewport
|
| + giant_rect, // viewport in layer space
|
| + gfx::Rect(layer_bounds), // visible content rect
|
| + layer_bounds, // last layer bounds
|
| + layer_bounds, // current layer bounds
|
| + 1.f, // last contents scale
|
| + 1.f, // current contents scale
|
| + gfx::Transform(), // last screen transform
|
| + gfx::Transform(), // current screen transform
|
| + 1, // current frame number
|
| + 1.0, // current frame time
|
| + false, // store screen space quads on tiles
|
| + 10000); // max tiles in tile manager
|
| + VerifyTiles(1.f, gfx::Rect(layer_bounds), base::Bind(&TileExists, true));
|
| +
|
| + // If the visible content rect is empty, it should still have live tiles.
|
| + tiling_->UpdateTilePriorities(
|
| + ACTIVE_TREE,
|
| + layer_bounds, // device viewport
|
| + giant_rect, // viewport in layer space
|
| + gfx::Rect(), // visible content rect
|
| + layer_bounds, // last layer bounds
|
| + layer_bounds, // current layer bounds
|
| + 1.f, // last contents scale
|
| + 1.f, // current contents scale
|
| + gfx::Transform(), // last screen transform
|
| + gfx::Transform(), // current screen transform
|
| + 2, // current frame number
|
| + 2.0, // current frame time
|
| + false, // store screen space quads on tiles
|
| + 10000); // max tiles in tile manager
|
| + VerifyTiles(1.f, gfx::Rect(layer_bounds), base::Bind(&TileExists, true));
|
| +}
|
| +
|
| +TEST_F(PictureLayerTilingIteratorTest, TilesExistOutsideViewport) {
|
| + gfx::Size layer_bounds(1099, 801);
|
| + Initialize(gfx::Size(100, 100), 1.f, layer_bounds);
|
| + VerifyTilesExactlyCoverRect(1.f, gfx::Rect(layer_bounds));
|
| + VerifyTiles(1.f, gfx::Rect(layer_bounds), base::Bind(&TileExists, false));
|
| +
|
| + // This rect does not intersect with the layer, as the layer is outside the
|
| + // viewport.
|
| + gfx::Rect viewport_rect(1100, 0, 1000, 1000);
|
| + EXPECT_FALSE(viewport_rect.Intersects(gfx::Rect(layer_bounds)));
|
| +
|
| + tiling_->UpdateTilePriorities(
|
| + ACTIVE_TREE,
|
| + layer_bounds, // device viewport
|
| + viewport_rect, // viewport in layer space
|
| + gfx::Rect(), // visible content rect
|
| + layer_bounds, // last layer bounds
|
| + layer_bounds, // current layer bounds
|
| + 1.f, // last contents scale
|
| + 1.f, // current contents scale
|
| + gfx::Transform(), // last screen transform
|
| + gfx::Transform(), // current screen transform
|
| + 2, // current frame number
|
| + 2.0, // current frame time
|
| + false, // store screen space quads on tiles
|
| + 10000); // max tiles in tile manager
|
| + VerifyTiles(1.f, gfx::Rect(layer_bounds), base::Bind(&TileExists, true));
|
| +}
|
| +
|
| } // namespace
|
| } // namespace cc
|
|
|