Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (c) 2013, Google Inc. All rights reserved. | 2 * Copyright (c) 2013, Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 29 */ | 29 */ |
| 30 | 30 |
| 31 #include "config.h" | 31 #include "config.h" |
| 32 #include "core/animation/AnimationTimeline.h" | 32 #include "core/animation/AnimationTimeline.h" |
| 33 | 33 |
| 34 #include "core/animation/Animation.h" | |
| 35 #include "core/animation/AnimationClock.h" | 34 #include "core/animation/AnimationClock.h" |
| 36 #include "core/animation/AnimationNode.h" | 35 #include "core/animation/AnimationEffect.h" |
| 36 #include "core/animation/KeyframeEffect.h" | |
| 37 #include "core/animation/KeyframeEffectModel.h" | 37 #include "core/animation/KeyframeEffectModel.h" |
| 38 #include "core/dom/Document.h" | 38 #include "core/dom/Document.h" |
| 39 #include "core/dom/Element.h" | 39 #include "core/dom/Element.h" |
| 40 #include "core/dom/QualifiedName.h" | 40 #include "core/dom/QualifiedName.h" |
| 41 #include "platform/weborigin/KURL.h" | 41 #include "platform/weborigin/KURL.h" |
| 42 | 42 |
| 43 #include <gmock/gmock.h> | 43 #include <gmock/gmock.h> |
| 44 #include <gtest/gtest.h> | 44 #include <gtest/gtest.h> |
| 45 | 45 |
| 46 namespace blink { | 46 namespace blink { |
| (...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 132 }; | 132 }; |
| 133 | 133 |
| 134 TEST_F(AnimationAnimationTimelineTest, HasStarted) | 134 TEST_F(AnimationAnimationTimelineTest, HasStarted) |
| 135 { | 135 { |
| 136 timeline = AnimationTimeline::create(document.get()); | 136 timeline = AnimationTimeline::create(document.get()); |
| 137 } | 137 } |
| 138 | 138 |
| 139 TEST_F(AnimationAnimationTimelineTest, EmptyKeyframeAnimation) | 139 TEST_F(AnimationAnimationTimelineTest, EmptyKeyframeAnimation) |
| 140 { | 140 { |
| 141 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa lueKeyframeEffectModel::create(AnimatableValueKeyframeVector()); | 141 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa lueKeyframeEffectModel::create(AnimatableValueKeyframeVector()); |
| 142 RefPtrWillBeRawPtr<Animation> anim = Animation::create(element.get(), effect , timing); | 142 RefPtrWillBeRawPtr<KeyframeEffect> anim = KeyframeEffect::create(element.get (), effect, timing); |
|
alancutter (OOO until 2018)
2015/05/05 01:04:51
s/anim/keyframeEffect/g
dstockwell
2015/05/05 03:33:25
Done!!!!
| |
| 143 | 143 |
| 144 timeline->play(anim.get()); | 144 timeline->play(anim.get()); |
| 145 | 145 |
| 146 platformTiming->expectNoMoreActions(); | 146 platformTiming->expectNoMoreActions(); |
| 147 updateClockAndService(0); | 147 updateClockAndService(0); |
| 148 EXPECT_FLOAT_EQ(0, timeline->currentTimeInternal()); | 148 EXPECT_FLOAT_EQ(0, timeline->currentTimeInternal()); |
| 149 EXPECT_FALSE(anim->isInEffect()); | 149 EXPECT_FALSE(anim->isInEffect()); |
| 150 | 150 |
| 151 platformTiming->expectNoMoreActions(); | 151 platformTiming->expectNoMoreActions(); |
| 152 updateClockAndService(100); | 152 updateClockAndService(100); |
| 153 EXPECT_FLOAT_EQ(100, timeline->currentTimeInternal()); | 153 EXPECT_FLOAT_EQ(100, timeline->currentTimeInternal()); |
| 154 } | 154 } |
| 155 | 155 |
| 156 TEST_F(AnimationAnimationTimelineTest, EmptyForwardsKeyframeAnimation) | 156 TEST_F(AnimationAnimationTimelineTest, EmptyForwardsKeyframeAnimation) |
| 157 { | 157 { |
| 158 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa lueKeyframeEffectModel::create(AnimatableValueKeyframeVector()); | 158 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa lueKeyframeEffectModel::create(AnimatableValueKeyframeVector()); |
| 159 timing.fillMode = Timing::FillModeForwards; | 159 timing.fillMode = Timing::FillModeForwards; |
| 160 RefPtrWillBeRawPtr<Animation> anim = Animation::create(element.get(), effect , timing); | 160 RefPtrWillBeRawPtr<KeyframeEffect> anim = KeyframeEffect::create(element.get (), effect, timing); |
| 161 | 161 |
| 162 timeline->play(anim.get()); | 162 timeline->play(anim.get()); |
| 163 | 163 |
| 164 platformTiming->expectNoMoreActions(); | 164 platformTiming->expectNoMoreActions(); |
| 165 updateClockAndService(0); | 165 updateClockAndService(0); |
| 166 EXPECT_FLOAT_EQ(0, timeline->currentTimeInternal()); | 166 EXPECT_FLOAT_EQ(0, timeline->currentTimeInternal()); |
| 167 EXPECT_TRUE(anim->isInEffect()); | 167 EXPECT_TRUE(anim->isInEffect()); |
| 168 | 168 |
| 169 platformTiming->expectNoMoreActions(); | 169 platformTiming->expectNoMoreActions(); |
| 170 updateClockAndService(100); | 170 updateClockAndService(100); |
| (...skipping 168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 339 | 339 |
| 340 timeline->setCurrentTime(2000); | 340 timeline->setCurrentTime(2000); |
| 341 EXPECT_EQ(2000, timeline->currentTime()); | 341 EXPECT_EQ(2000, timeline->currentTime()); |
| 342 EXPECT_EQ(zeroTime + 198, timeline->zeroTime()); | 342 EXPECT_EQ(zeroTime + 198, timeline->zeroTime()); |
| 343 } | 343 } |
| 344 | 344 |
| 345 TEST_F(AnimationAnimationTimelineTest, PauseForTesting) | 345 TEST_F(AnimationAnimationTimelineTest, PauseForTesting) |
| 346 { | 346 { |
| 347 float seekTime = 1; | 347 float seekTime = 1; |
| 348 timing.fillMode = Timing::FillModeForwards; | 348 timing.fillMode = Timing::FillModeForwards; |
| 349 RefPtrWillBeRawPtr<Animation> anim1 = Animation::create(element.get(), Anima tableValueKeyframeEffectModel::create(AnimatableValueKeyframeVector()), timing); | 349 RefPtrWillBeRawPtr<KeyframeEffect> anim1 = KeyframeEffect::create(element.ge t(), AnimatableValueKeyframeEffectModel::create(AnimatableValueKeyframeVector()) , timing); |
| 350 RefPtrWillBeRawPtr<Animation> anim2 = Animation::create(element.get(), Anim atableValueKeyframeEffectModel::create(AnimatableValueKeyframeVector()), timing) ; | 350 RefPtrWillBeRawPtr<KeyframeEffect> anim2 = KeyframeEffect::create(element.g et(), AnimatableValueKeyframeEffectModel::create(AnimatableValueKeyframeVector() ), timing); |
| 351 AnimationPlayer* player1 = timeline->play(anim1.get()); | 351 Animation* player1 = timeline->play(anim1.get()); |
| 352 AnimationPlayer* player2 = timeline->play(anim2.get()); | 352 Animation* player2 = timeline->play(anim2.get()); |
| 353 timeline->pauseAnimationsForTesting(seekTime); | 353 timeline->pauseAnimationsForTesting(seekTime); |
| 354 | 354 |
| 355 EXPECT_FLOAT_EQ(seekTime, player1->currentTime() / 1000.0); | 355 EXPECT_FLOAT_EQ(seekTime, player1->currentTime() / 1000.0); |
| 356 EXPECT_FLOAT_EQ(seekTime, player2->currentTime() / 1000.0); | 356 EXPECT_FLOAT_EQ(seekTime, player2->currentTime() / 1000.0); |
| 357 } | 357 } |
| 358 | 358 |
| 359 TEST_F(AnimationAnimationTimelineTest, DelayBeforeAnimationStart) | 359 TEST_F(AnimationAnimationTimelineTest, DelayBeforeAnimationStart) |
| 360 { | 360 { |
| 361 timing.iterationDuration = 2; | 361 timing.iterationDuration = 2; |
| 362 timing.startDelay = 5; | 362 timing.startDelay = 5; |
| 363 | 363 |
| 364 RefPtrWillBeRawPtr<Animation> anim = Animation::create(element.get(), nullpt r, timing); | 364 RefPtrWillBeRawPtr<KeyframeEffect> anim = KeyframeEffect::create(element.get (), nullptr, timing); |
| 365 | 365 |
| 366 timeline->play(anim.get()); | 366 timeline->play(anim.get()); |
| 367 | 367 |
| 368 // TODO: Put the player startTime in the future when we add the capability t o change player startTime | 368 // TODO: Put the player startTime in the future when we add the capability t o change player startTime |
| 369 platformTiming->expectDelayedAction(timing.startDelay - minimumDelay()); | 369 platformTiming->expectDelayedAction(timing.startDelay - minimumDelay()); |
| 370 updateClockAndService(0); | 370 updateClockAndService(0); |
| 371 | 371 |
| 372 platformTiming->expectDelayedAction(timing.startDelay - minimumDelay() - 1.5 ); | 372 platformTiming->expectDelayedAction(timing.startDelay - minimumDelay() - 1.5 ); |
| 373 updateClockAndService(1.5); | 373 updateClockAndService(1.5); |
| 374 | 374 |
| 375 EXPECT_CALL(*platformTiming, serviceOnNextFrame()); | 375 EXPECT_CALL(*platformTiming, serviceOnNextFrame()); |
| 376 wake(); | 376 wake(); |
| 377 | 377 |
| 378 platformTiming->expectNextFrameAction(); | 378 platformTiming->expectNextFrameAction(); |
| 379 updateClockAndService(4.98); | 379 updateClockAndService(4.98); |
| 380 } | 380 } |
| 381 | 381 |
| 382 TEST_F(AnimationAnimationTimelineTest, PlayAfterDocumentDeref) | 382 TEST_F(AnimationAnimationTimelineTest, PlayAfterDocumentDeref) |
| 383 { | 383 { |
| 384 timing.iterationDuration = 2; | 384 timing.iterationDuration = 2; |
| 385 timing.startDelay = 5; | 385 timing.startDelay = 5; |
| 386 | 386 |
| 387 timeline = &document->timeline(); | 387 timeline = &document->timeline(); |
| 388 element = nullptr; | 388 element = nullptr; |
| 389 document = nullptr; | 389 document = nullptr; |
| 390 | 390 |
| 391 RefPtrWillBeRawPtr<Animation> anim = Animation::create(0, nullptr, timing); | 391 RefPtrWillBeRawPtr<KeyframeEffect> anim = KeyframeEffect::create(0, nullptr, timing); |
| 392 // Test passes if this does not crash. | 392 // Test passes if this does not crash. |
| 393 timeline->play(anim.get()); | 393 timeline->play(anim.get()); |
| 394 } | 394 } |
| 395 | 395 |
| 396 TEST_F(AnimationAnimationTimelineTest, UseAnimationPlayerAfterTimelineDeref) | 396 TEST_F(AnimationAnimationTimelineTest, UseAnimationAfterTimelineDeref) |
| 397 { | 397 { |
| 398 RefPtrWillBeRawPtr<AnimationPlayer> player = timeline->play(0); | 398 RefPtrWillBeRawPtr<Animation> player = timeline->play(0); |
|
alancutter (OOO until 2018)
2015/05/05 01:04:51
s/player/animation/
dstockwell
2015/05/05 03:33:25
DONE!
| |
| 399 timeline.clear(); | 399 timeline.clear(); |
| 400 // Test passes if this does not crash. | 400 // Test passes if this does not crash. |
| 401 player->setStartTime(0); | 401 player->setStartTime(0); |
| 402 } | 402 } |
| 403 | 403 |
| 404 } | 404 } |
| OLD | NEW |