| Index: cc/layer_impl_unittest.cc
|
| diff --git a/cc/layer_impl_unittest.cc b/cc/layer_impl_unittest.cc
|
| index bf8e96ec47cde094cab91ab6fc955b4497154736..f355da67c700728d5bf3865272e9ee71cd1d2115 100644
|
| --- a/cc/layer_impl_unittest.cc
|
| +++ b/cc/layer_impl_unittest.cc
|
| @@ -51,6 +51,18 @@ namespace {
|
| EXPECT_FALSE(grandChild->layerPropertyChanged()); \
|
| EXPECT_TRUE(root->layerSurfacePropertyChanged())
|
|
|
| +#define VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(codeToTest) \
|
| + root->resetAllChangeTrackingForSubtree(); \
|
| + hostImpl.resetNeedsUpdateDrawPropertiesForTesting(); \
|
| + codeToTest; \
|
| + EXPECT_TRUE(hostImpl.needsUpdateDrawProperties());
|
| +
|
| +#define VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(codeToTest) \
|
| + root->resetAllChangeTrackingForSubtree(); \
|
| + hostImpl.resetNeedsUpdateDrawPropertiesForTesting(); \
|
| + codeToTest; \
|
| + EXPECT_FALSE(hostImpl.needsUpdateDrawProperties());
|
| +
|
| TEST(LayerImplTest, verifyLayerChangesAreTrackedProperly)
|
| {
|
| //
|
| @@ -154,5 +166,87 @@ TEST(LayerImplTest, verifyLayerChangesAreTrackedProperly)
|
| EXECUTE_AND_VERIFY_SUBTREE_DID_NOT_CHANGE(root->setBounds(arbitrarySize));
|
| }
|
|
|
| +TEST(LayerImplTest, VerifyNeedsUpdateDrawProperties)
|
| +{
|
| + FakeImplProxy proxy;
|
| + FakeLayerTreeHostImpl hostImpl(&proxy);
|
| + scoped_ptr<LayerImpl> root = LayerImpl::create(&hostImpl, 1);
|
| +
|
| + gfx::PointF arbitraryPointF = gfx::PointF(0.125f, 0.25f);
|
| + float arbitraryNumber = 0.352f;
|
| + gfx::Size arbitrarySize = gfx::Size(111, 222);
|
| + gfx::Point arbitraryPoint = gfx::Point(333, 444);
|
| + gfx::Vector2d arbitraryVector2d = gfx::Vector2d(111, 222);
|
| + gfx::Vector2d largeVector2d = gfx::Vector2d(1000, 1000);
|
| + gfx::Rect arbitraryRect = gfx::Rect(arbitraryPoint, arbitrarySize);
|
| + gfx::RectF arbitraryRectF = gfx::RectF(arbitraryPointF, gfx::SizeF(1.234f, 5.678f));
|
| + SkColor arbitraryColor = SkColorSetRGB(10, 20, 30);
|
| + gfx::Transform arbitraryTransform;
|
| + arbitraryTransform.Scale3d(0.1, 0.2, 0.3);
|
| + WebFilterOperations arbitraryFilters;
|
| + arbitraryFilters.append(WebFilterOperation::createOpacityFilter(0.5));
|
| + skia::RefPtr<SkImageFilter> arbitraryFilter = skia::AdoptRef(new SkBlurImageFilter(SK_Scalar1, SK_Scalar1));
|
| +
|
| + // Related filter functions.
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setFilters(arbitraryFilters));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setFilters(arbitraryFilters));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setFilters(WebFilterOperations()));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setFilter(arbitraryFilter));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setFilter(arbitraryFilter));
|
| +
|
| + // Related scrolling functions.
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setMaxScrollOffset(largeVector2d));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setMaxScrollOffset(largeVector2d));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->scrollBy(arbitraryVector2d));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->scrollBy(gfx::Vector2d()));
|
| + root->setScrollDelta(gfx::Vector2d(0, 0));
|
| + hostImpl.resetNeedsUpdateDrawPropertiesForTesting();
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setScrollDelta(arbitraryVector2d));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setScrollDelta(arbitraryVector2d));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setScrollOffset(arbitraryVector2d));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setScrollOffset(arbitraryVector2d));
|
| +
|
| + // Unrelated functions, always set to new values, always set needs update.
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setAnchorPointZ(arbitraryNumber));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setMaskLayer(LayerImpl::create(&hostImpl, 4)));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setMasksToBounds(true));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setContentsOpaque(true));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setReplicaLayer(LayerImpl::create(&hostImpl, 5)));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setPosition(arbitraryPointF));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setPreserves3D(true));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setDoubleSided(false)); // constructor initializes it to "true".
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setImplTransform(arbitraryTransform));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setContentBounds(arbitrarySize));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setContentsScale(arbitraryNumber, arbitraryNumber));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setDrawsContent(true));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setBackgroundColor(SK_ColorGRAY));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setBackgroundFilters(arbitraryFilters));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setOpacity(arbitraryNumber));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setTransform(arbitraryTransform));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setSublayerTransform(arbitraryTransform));
|
| + VERIFY_NEEDS_UPDATE_DRAW_PROPERTIES(root->setBounds(arbitrarySize));
|
| +
|
| + // Unrelated functions, set to the same values, no needs update.
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setAnchorPointZ(arbitraryNumber));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setFilter(arbitraryFilter));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setMaskLayer(LayerImpl::create(&hostImpl, 4)));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setMasksToBounds(true));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setContentsOpaque(true));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setReplicaLayer(LayerImpl::create(&hostImpl, 5)));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setPosition(arbitraryPointF));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setPreserves3D(true));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setDoubleSided(false)); // constructor initializes it to "true".
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setImplTransform(arbitraryTransform));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setContentBounds(arbitrarySize));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setContentsScale(arbitraryNumber, arbitraryNumber));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setDrawsContent(true));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setBackgroundColor(SK_ColorGRAY));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setBackgroundFilters(arbitraryFilters));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setOpacity(arbitraryNumber));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setTransform(arbitraryTransform));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setSublayerTransform(arbitraryTransform));
|
| + VERIFY_NO_NEEDS_UPDATE_DRAW_PROPERTIES(root->setBounds(arbitrarySize));
|
| +}
|
| +
|
| } // namespace
|
| } // namespace cc
|
|
|