diff options
| author | Simon Hausmann <simon.hausmann@nokia.com> | 2012-05-25 15:09:11 +0200 | 
|---|---|---|
| committer | Simon Hausmann <simon.hausmann@nokia.com> | 2012-05-25 15:09:11 +0200 | 
| commit | a89b2ebb8e192c5e8cea21079bda2ee2c0c7dddd (patch) | |
| tree | b7abd9f49ae1d4d2e426a5883bfccd42b8e2ee12 /Source/WebKit/chromium/tests/CCLayerAnimationControllerTest.cpp | |
| parent | 8d473cf9743f1d30a16a27114e93bd5af5648d23 (diff) | |
| download | qtwebkit-a89b2ebb8e192c5e8cea21079bda2ee2c0c7dddd.tar.gz | |
Imported WebKit commit eb5c1b8fe4d4b1b90b5137433fc58a91da0e6878 (http://svn.webkit.org/repository/webkit/trunk@118516)
Diffstat (limited to 'Source/WebKit/chromium/tests/CCLayerAnimationControllerTest.cpp')
| -rw-r--r-- | Source/WebKit/chromium/tests/CCLayerAnimationControllerTest.cpp | 28 | 
1 files changed, 28 insertions, 0 deletions
| diff --git a/Source/WebKit/chromium/tests/CCLayerAnimationControllerTest.cpp b/Source/WebKit/chromium/tests/CCLayerAnimationControllerTest.cpp index 1d5409f98..827194bbc 100644 --- a/Source/WebKit/chromium/tests/CCLayerAnimationControllerTest.cpp +++ b/Source/WebKit/chromium/tests/CCLayerAnimationControllerTest.cpp @@ -747,4 +747,32 @@ TEST(CCLayerAnimationControllerTest, AbortAGroupedAnimation)      EXPECT_EQ(0.75, dummy.opacity());  } +TEST(CCLayerAnimationControllerTest, ForceSyncWhenSynchronizedStartTimeNeeded) +{ +    FakeLayerAnimationControllerClient dummyImpl; +    OwnPtr<CCLayerAnimationController> controllerImpl(CCLayerAnimationController::create(&dummyImpl)); +    OwnPtr<CCAnimationEventsVector> events(adoptPtr(new CCAnimationEventsVector)); +    FakeLayerAnimationControllerClient dummy; +    OwnPtr<CCLayerAnimationController> controller( +        CCLayerAnimationController::create(&dummy)); + +    OwnPtr<CCActiveAnimation> toAdd(createActiveAnimation(adoptPtr(new FakeFloatTransition(2, 0, 1)), 0, CCActiveAnimation::Opacity)); +    toAdd->setNeedsSynchronizedStartTime(true); +    controller->add(toAdd.release()); + +    controller->animate(0, 0); +    EXPECT_TRUE(controller->hasActiveAnimation()); +    CCActiveAnimation* activeAnimation = controller->getActiveAnimation(0, CCActiveAnimation::Opacity); +    EXPECT_TRUE(activeAnimation); +    EXPECT_TRUE(activeAnimation->needsSynchronizedStartTime()); + +    controller->setForceSync(); + +    controller->pushAnimationUpdatesTo(controllerImpl.get()); + +    activeAnimation = controllerImpl->getActiveAnimation(0, CCActiveAnimation::Opacity); +    EXPECT_TRUE(activeAnimation); +    EXPECT_EQ(CCActiveAnimation::WaitingForTargetAvailability, activeAnimation->runState()); +} +  } // namespace | 
