| 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 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 47 PassRefPtrWillBeRawPtr<AnimatableValue> unknownAnimatableValue(double n) | 47 PassRefPtrWillBeRawPtr<AnimatableValue> unknownAnimatableValue(double n) |
| 48 { | 48 { |
| 49 return AnimatableUnknown::create(CSSPrimitiveValue::create(n, CSSPrimitiveVa
lue::CSS_UNKNOWN).get()); | 49 return AnimatableUnknown::create(CSSPrimitiveValue::create(n, CSSPrimitiveVa
lue::CSS_UNKNOWN).get()); |
| 50 } | 50 } |
| 51 | 51 |
| 52 PassRefPtrWillBeRawPtr<AnimatableValue> pixelAnimatableValue(double n) | 52 PassRefPtrWillBeRawPtr<AnimatableValue> pixelAnimatableValue(double n) |
| 53 { | 53 { |
| 54 return AnimatableLength::create(CSSPrimitiveValue::create(n, CSSPrimitiveVal
ue::CSS_PX).get()); | 54 return AnimatableLength::create(CSSPrimitiveValue::create(n, CSSPrimitiveVal
ue::CSS_PX).get()); |
| 55 } | 55 } |
| 56 | 56 |
| 57 KeyframeEffectModel::KeyframeVector keyframesAtZeroAndOne(PassRefPtrWillBeRawPtr
<AnimatableValue> zeroValue, PassRefPtrWillBeRawPtr<AnimatableValue> oneValue) | 57 AnimatableValueKeyframeVector keyframesAtZeroAndOne(PassRefPtrWillBeRawPtr<Anima
tableValue> zeroValue, PassRefPtrWillBeRawPtr<AnimatableValue> oneValue) |
| 58 { | 58 { |
| 59 KeyframeEffectModel::KeyframeVector keyframes(2); | 59 AnimatableValueKeyframeVector keyframes(2); |
| 60 keyframes[0] = Keyframe::create(); | 60 keyframes[0] = AnimatableValueKeyframe::create(); |
| 61 keyframes[0]->setOffset(0.0); | 61 keyframes[0]->setOffset(0.0); |
| 62 keyframes[0]->setPropertyValue(CSSPropertyLeft, zeroValue.get()); | 62 keyframes[0]->setPropertyValue(CSSPropertyLeft, zeroValue.get()); |
| 63 keyframes[1] = Keyframe::create(); | 63 keyframes[1] = AnimatableValueKeyframe::create(); |
| 64 keyframes[1]->setOffset(1.0); | 64 keyframes[1]->setOffset(1.0); |
| 65 keyframes[1]->setPropertyValue(CSSPropertyLeft, oneValue.get()); | 65 keyframes[1]->setPropertyValue(CSSPropertyLeft, oneValue.get()); |
| 66 return keyframes; | 66 return keyframes; |
| 67 } | 67 } |
| 68 | 68 |
| 69 void expectProperty(CSSPropertyID property, PassRefPtrWillBeRawPtr<Interpolation
> interpolationValue) | 69 void expectProperty(CSSPropertyID property, PassRefPtrWillBeRawPtr<Interpolation
> interpolationValue) |
| 70 { | 70 { |
| 71 LegacyStyleInterpolation* interpolation = toLegacyStyleInterpolation(interpo
lationValue.get()); | 71 LegacyStyleInterpolation* interpolation = toLegacyStyleInterpolation(interpo
lationValue.get()); |
| 72 ASSERT_EQ(property, interpolation->id()); | 72 ASSERT_EQ(property, interpolation->id()); |
| 73 } | 73 } |
| (...skipping 20 matching lines...) Expand all Loading... |
| 94 LegacyStyleInterpolation* value = toLegacyStyleInterpolation(values.at(i
).get()); | 94 LegacyStyleInterpolation* value = toLegacyStyleInterpolation(values.at(i
).get()); |
| 95 if (value->id() == id) | 95 if (value->id() == id) |
| 96 return value; | 96 return value; |
| 97 } | 97 } |
| 98 return 0; | 98 return 0; |
| 99 } | 99 } |
| 100 | 100 |
| 101 | 101 |
| 102 TEST(AnimationKeyframeEffectModel, BasicOperation) | 102 TEST(AnimationKeyframeEffectModel, BasicOperation) |
| 103 { | 103 { |
| 104 KeyframeEffectModel::KeyframeVector keyframes = keyframesAtZeroAndOne(unknow
nAnimatableValue(3.0), unknownAnimatableValue(5.0)); | 104 AnimatableValueKeyframeVector keyframes = keyframesAtZeroAndOne(unknownAnima
tableValue(3.0), unknownAnimatableValue(5.0)); |
| 105 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 105 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 106 OwnPtrWillBeRawPtr<WillBeHeapVector<RefPtrWillBeMember<Interpolation> > > va
lues = effect->sample(0, 0.6, duration); | 106 OwnPtrWillBeRawPtr<WillBeHeapVector<RefPtrWillBeMember<Interpolation> > > va
lues = effect->sample(0, 0.6, duration); |
| 107 ASSERT_EQ(1UL, values->size()); | 107 ASSERT_EQ(1UL, values->size()); |
| 108 expectProperty(CSSPropertyLeft, values->at(0)); | 108 expectProperty(CSSPropertyLeft, values->at(0)); |
| 109 expectDoubleValue(5.0, values->at(0)); | 109 expectDoubleValue(5.0, values->at(0)); |
| 110 } | 110 } |
| 111 | 111 |
| 112 TEST(AnimationKeyframeEffectModel, CompositeReplaceNonInterpolable) | 112 TEST(AnimationKeyframeEffectModel, CompositeReplaceNonInterpolable) |
| 113 { | 113 { |
| 114 KeyframeEffectModel::KeyframeVector keyframes = keyframesAtZeroAndOne(unknow
nAnimatableValue(3.0), unknownAnimatableValue(5.0)); | 114 AnimatableValueKeyframeVector keyframes = keyframesAtZeroAndOne(unknownAnima
tableValue(3.0), unknownAnimatableValue(5.0)); |
| 115 keyframes[0]->setComposite(AnimationEffect::CompositeReplace); | 115 keyframes[0]->setComposite(AnimationEffect::CompositeReplace); |
| 116 keyframes[1]->setComposite(AnimationEffect::CompositeReplace); | 116 keyframes[1]->setComposite(AnimationEffect::CompositeReplace); |
| 117 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 117 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 118 expectDoubleValue(5.0, effect->sample(0, 0.6, duration)->at(0)); | 118 expectDoubleValue(5.0, effect->sample(0, 0.6, duration)->at(0)); |
| 119 } | 119 } |
| 120 | 120 |
| 121 TEST(AnimationKeyframeEffectModel, CompositeReplace) | 121 TEST(AnimationKeyframeEffectModel, CompositeReplace) |
| 122 { | 122 { |
| 123 KeyframeEffectModel::KeyframeVector keyframes = keyframesAtZeroAndOne(pixelA
nimatableValue(3.0), pixelAnimatableValue(5.0)); | 123 AnimatableValueKeyframeVector keyframes = keyframesAtZeroAndOne(pixelAnimata
bleValue(3.0), pixelAnimatableValue(5.0)); |
| 124 keyframes[0]->setComposite(AnimationEffect::CompositeReplace); | 124 keyframes[0]->setComposite(AnimationEffect::CompositeReplace); |
| 125 keyframes[1]->setComposite(AnimationEffect::CompositeReplace); | 125 keyframes[1]->setComposite(AnimationEffect::CompositeReplace); |
| 126 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 126 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 127 expectDoubleValue(3.0 * 0.4 + 5.0 * 0.6, effect->sample(0, 0.6, duration)->a
t(0)); | 127 expectDoubleValue(3.0 * 0.4 + 5.0 * 0.6, effect->sample(0, 0.6, duration)->a
t(0)); |
| 128 } | 128 } |
| 129 | 129 |
| 130 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. | 130 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. |
| 131 TEST(AnimationKeyframeEffectModel, DISABLED_CompositeAdd) | 131 TEST(AnimationKeyframeEffectModel, DISABLED_CompositeAdd) |
| 132 { | 132 { |
| 133 KeyframeEffectModel::KeyframeVector keyframes = keyframesAtZeroAndOne(pixelA
nimatableValue(3.0), pixelAnimatableValue(5.0)); | 133 AnimatableValueKeyframeVector keyframes = keyframesAtZeroAndOne(pixelAnimata
bleValue(3.0), pixelAnimatableValue(5.0)); |
| 134 keyframes[0]->setComposite(AnimationEffect::CompositeAdd); | 134 keyframes[0]->setComposite(AnimationEffect::CompositeAdd); |
| 135 keyframes[1]->setComposite(AnimationEffect::CompositeAdd); | 135 keyframes[1]->setComposite(AnimationEffect::CompositeAdd); |
| 136 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 136 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 137 expectDoubleValue((7.0 + 3.0) * 0.4 + (7.0 + 5.0) * 0.6, effect->sample(0, 0
.6, duration)->at(0)); | 137 expectDoubleValue((7.0 + 3.0) * 0.4 + (7.0 + 5.0) * 0.6, effect->sample(0, 0
.6, duration)->at(0)); |
| 138 } | 138 } |
| 139 | 139 |
| 140 TEST(AnimationKeyframeEffectModel, CompositeEaseIn) | 140 TEST(AnimationKeyframeEffectModel, CompositeEaseIn) |
| 141 { | 141 { |
| 142 KeyframeEffectModel::KeyframeVector keyframes = keyframesAtZeroAndOne(pixelA
nimatableValue(3.0), pixelAnimatableValue(5.0)); | 142 AnimatableValueKeyframeVector keyframes = keyframesAtZeroAndOne(pixelAnimata
bleValue(3.0), pixelAnimatableValue(5.0)); |
| 143 RefPtrWillBeRawPtr<CSSValue> timingFunction = BisonCSSParser::parseAnimation
TimingFunctionValue("ease-in"); | 143 RefPtrWillBeRawPtr<CSSValue> timingFunction = BisonCSSParser::parseAnimation
TimingFunctionValue("ease-in"); |
| 144 keyframes[0]->setComposite(AnimationEffect::CompositeReplace); | 144 keyframes[0]->setComposite(AnimationEffect::CompositeReplace); |
| 145 keyframes[0]->setEasing(CSSToStyleMap::animationTimingFunction(timingFunctio
n.get(), false)); | 145 keyframes[0]->setEasing(CSSToStyleMap::animationTimingFunction(timingFunctio
n.get(), false)); |
| 146 keyframes[1]->setComposite(AnimationEffect::CompositeReplace); | 146 keyframes[1]->setComposite(AnimationEffect::CompositeReplace); |
| 147 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 147 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 148 expectDoubleValue(3.8579516, effect->sample(0, 0.6, duration)->at(0)); | 148 expectDoubleValue(3.8579516, effect->sample(0, 0.6, duration)->at(0)); |
| 149 expectDoubleValue(3.8582394, effect->sample(0, 0.6, duration * 100)->at(0)); | 149 expectDoubleValue(3.8582394, effect->sample(0, 0.6, duration * 100)->at(0)); |
| 150 } | 150 } |
| 151 | 151 |
| 152 TEST(AnimationKeyframeEffectModel, CompositeCubicBezier) | 152 TEST(AnimationKeyframeEffectModel, CompositeCubicBezier) |
| 153 { | 153 { |
| 154 KeyframeEffectModel::KeyframeVector keyframes = keyframesAtZeroAndOne(pixelA
nimatableValue(3.0), pixelAnimatableValue(5.0)); | 154 AnimatableValueKeyframeVector keyframes = keyframesAtZeroAndOne(pixelAnimata
bleValue(3.0), pixelAnimatableValue(5.0)); |
| 155 RefPtrWillBeRawPtr<CSSValue> timingFunction = BisonCSSParser::parseAnimation
TimingFunctionValue("cubic-bezier(0.42, 0, 0.58, 1)"); | 155 RefPtrWillBeRawPtr<CSSValue> timingFunction = BisonCSSParser::parseAnimation
TimingFunctionValue("cubic-bezier(0.42, 0, 0.58, 1)"); |
| 156 keyframes[0]->setComposite(AnimationEffect::CompositeReplace); | 156 keyframes[0]->setComposite(AnimationEffect::CompositeReplace); |
| 157 keyframes[0]->setEasing(CSSToStyleMap::animationTimingFunction(timingFunctio
n.get(), false)); | 157 keyframes[0]->setEasing(CSSToStyleMap::animationTimingFunction(timingFunctio
n.get(), false)); |
| 158 keyframes[1]->setComposite(AnimationEffect::CompositeReplace); | 158 keyframes[1]->setComposite(AnimationEffect::CompositeReplace); |
| 159 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 159 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 160 expectDoubleValue(4.3363357, effect->sample(0, 0.6, duration)->at(0)); | 160 expectDoubleValue(4.3363357, effect->sample(0, 0.6, duration)->at(0)); |
| 161 expectDoubleValue(4.3362322, effect->sample(0, 0.6, duration * 1000)->at(0))
; | 161 expectDoubleValue(4.3362322, effect->sample(0, 0.6, duration * 1000)->at(0))
; |
| 162 } | 162 } |
| 163 | 163 |
| 164 TEST(AnimationKeyframeEffectModel, ExtrapolateReplaceNonInterpolable) | 164 TEST(AnimationKeyframeEffectModel, ExtrapolateReplaceNonInterpolable) |
| 165 { | 165 { |
| 166 KeyframeEffectModel::KeyframeVector keyframes = keyframesAtZeroAndOne(unknow
nAnimatableValue(3.0), unknownAnimatableValue(5.0)); | 166 AnimatableValueKeyframeVector keyframes = keyframesAtZeroAndOne(unknownAnima
tableValue(3.0), unknownAnimatableValue(5.0)); |
| 167 keyframes[0]->setComposite(AnimationEffect::CompositeReplace); | 167 keyframes[0]->setComposite(AnimationEffect::CompositeReplace); |
| 168 keyframes[1]->setComposite(AnimationEffect::CompositeReplace); | 168 keyframes[1]->setComposite(AnimationEffect::CompositeReplace); |
| 169 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 169 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 170 expectDoubleValue(5.0, effect->sample(0, 1.6, duration)->at(0)); | 170 expectDoubleValue(5.0, effect->sample(0, 1.6, duration)->at(0)); |
| 171 } | 171 } |
| 172 | 172 |
| 173 TEST(AnimationKeyframeEffectModel, ExtrapolateReplace) | 173 TEST(AnimationKeyframeEffectModel, ExtrapolateReplace) |
| 174 { | 174 { |
| 175 KeyframeEffectModel::KeyframeVector keyframes = keyframesAtZeroAndOne(pixelA
nimatableValue(3.0), pixelAnimatableValue(5.0)); | 175 AnimatableValueKeyframeVector keyframes = keyframesAtZeroAndOne(pixelAnimata
bleValue(3.0), pixelAnimatableValue(5.0)); |
| 176 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 176 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 177 keyframes[0]->setComposite(AnimationEffect::CompositeReplace); | 177 keyframes[0]->setComposite(AnimationEffect::CompositeReplace); |
| 178 keyframes[1]->setComposite(AnimationEffect::CompositeReplace); | 178 keyframes[1]->setComposite(AnimationEffect::CompositeReplace); |
| 179 expectDoubleValue(3.0 * -0.6 + 5.0 * 1.6, effect->sample(0, 1.6, duration)->
at(0)); | 179 expectDoubleValue(3.0 * -0.6 + 5.0 * 1.6, effect->sample(0, 1.6, duration)->
at(0)); |
| 180 } | 180 } |
| 181 | 181 |
| 182 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. | 182 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. |
| 183 TEST(AnimationKeyframeEffectModel, DISABLED_ExtrapolateAdd) | 183 TEST(AnimationKeyframeEffectModel, DISABLED_ExtrapolateAdd) |
| 184 { | 184 { |
| 185 KeyframeEffectModel::KeyframeVector keyframes = keyframesAtZeroAndOne(pixelA
nimatableValue(3.0), pixelAnimatableValue(5.0)); | 185 AnimatableValueKeyframeVector keyframes = keyframesAtZeroAndOne(pixelAnimata
bleValue(3.0), pixelAnimatableValue(5.0)); |
| 186 keyframes[0]->setComposite(AnimationEffect::CompositeAdd); | 186 keyframes[0]->setComposite(AnimationEffect::CompositeAdd); |
| 187 keyframes[1]->setComposite(AnimationEffect::CompositeAdd); | 187 keyframes[1]->setComposite(AnimationEffect::CompositeAdd); |
| 188 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 188 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 189 expectDoubleValue((7.0 + 3.0) * -0.6 + (7.0 + 5.0) * 1.6, effect->sample(0,
1.6, duration)->at(0)); | 189 expectDoubleValue((7.0 + 3.0) * -0.6 + (7.0 + 5.0) * 1.6, effect->sample(0,
1.6, duration)->at(0)); |
| 190 } | 190 } |
| 191 | 191 |
| 192 TEST(AnimationKeyframeEffectModel, ZeroKeyframes) | 192 TEST(AnimationKeyframeEffectModel, ZeroKeyframes) |
| 193 { | 193 { |
| 194 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(KeyframeEffectModel::KeyframeVector()); | 194 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(AnimatableValueKeyframeVector()); |
| 195 EXPECT_TRUE(effect->sample(0, 0.5, duration)->isEmpty()); | 195 EXPECT_TRUE(effect->sample(0, 0.5, duration)->isEmpty()); |
| 196 } | 196 } |
| 197 | 197 |
| 198 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. | 198 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. |
| 199 TEST(AnimationKeyframeEffectModel, DISABLED_SingleKeyframeAtOffsetZero) | 199 TEST(AnimationKeyframeEffectModel, DISABLED_SingleKeyframeAtOffsetZero) |
| 200 { | 200 { |
| 201 KeyframeEffectModel::KeyframeVector keyframes(1); | 201 AnimatableValueKeyframeVector keyframes(1); |
| 202 keyframes[0] = Keyframe::create(); | 202 keyframes[0] = AnimatableValueKeyframe::create(); |
| 203 keyframes[0]->setOffset(0.0); | 203 keyframes[0]->setOffset(0.0); |
| 204 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(3.0).
get()); | 204 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(3.0).
get()); |
| 205 | 205 |
| 206 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 206 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 207 expectDoubleValue(3.0, effect->sample(0, 0.6, duration)->at(0)); | 207 expectDoubleValue(3.0, effect->sample(0, 0.6, duration)->at(0)); |
| 208 } | 208 } |
| 209 | 209 |
| 210 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. | 210 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. |
| 211 TEST(AnimationKeyframeEffectModel, DISABLED_SingleKeyframeAtOffsetOne) | 211 TEST(AnimationKeyframeEffectModel, DISABLED_SingleKeyframeAtOffsetOne) |
| 212 { | 212 { |
| 213 KeyframeEffectModel::KeyframeVector keyframes(1); | 213 AnimatableValueKeyframeVector keyframes(1); |
| 214 keyframes[0] = Keyframe::create(); | 214 keyframes[0] = AnimatableValueKeyframe::create(); |
| 215 keyframes[0]->setOffset(1.0); | 215 keyframes[0]->setOffset(1.0); |
| 216 keyframes[0]->setPropertyValue(CSSPropertyLeft, pixelAnimatableValue(5.0).ge
t()); | 216 keyframes[0]->setPropertyValue(CSSPropertyLeft, pixelAnimatableValue(5.0).ge
t()); |
| 217 | 217 |
| 218 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 218 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 219 expectDoubleValue(7.0 * 0.4 + 5.0 * 0.6, effect->sample(0, 0.6, duration)->a
t(0)); | 219 expectDoubleValue(7.0 * 0.4 + 5.0 * 0.6, effect->sample(0, 0.6, duration)->a
t(0)); |
| 220 } | 220 } |
| 221 | 221 |
| 222 TEST(AnimationKeyframeEffectModel, MoreThanTwoKeyframes) | 222 TEST(AnimationKeyframeEffectModel, MoreThanTwoKeyframes) |
| 223 { | 223 { |
| 224 KeyframeEffectModel::KeyframeVector keyframes(3); | 224 AnimatableValueKeyframeVector keyframes(3); |
| 225 keyframes[0] = Keyframe::create(); | 225 keyframes[0] = AnimatableValueKeyframe::create(); |
| 226 keyframes[0]->setOffset(0.0); | 226 keyframes[0]->setOffset(0.0); |
| 227 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(3.0).
get()); | 227 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(3.0).
get()); |
| 228 keyframes[1] = Keyframe::create(); | 228 keyframes[1] = AnimatableValueKeyframe::create(); |
| 229 keyframes[1]->setOffset(0.5); | 229 keyframes[1]->setOffset(0.5); |
| 230 keyframes[1]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(4.0).
get()); | 230 keyframes[1]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(4.0).
get()); |
| 231 keyframes[2] = Keyframe::create(); | 231 keyframes[2] = AnimatableValueKeyframe::create(); |
| 232 keyframes[2]->setOffset(1.0); | 232 keyframes[2]->setOffset(1.0); |
| 233 keyframes[2]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(5.0).
get()); | 233 keyframes[2]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(5.0).
get()); |
| 234 | 234 |
| 235 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 235 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 236 expectDoubleValue(4.0, effect->sample(0, 0.3, duration)->at(0)); | 236 expectDoubleValue(4.0, effect->sample(0, 0.3, duration)->at(0)); |
| 237 expectDoubleValue(5.0, effect->sample(0, 0.8, duration)->at(0)); | 237 expectDoubleValue(5.0, effect->sample(0, 0.8, duration)->at(0)); |
| 238 } | 238 } |
| 239 | 239 |
| 240 TEST(AnimationKeyframeEffectModel, EndKeyframeOffsetsUnspecified) | 240 TEST(AnimationKeyframeEffectModel, EndKeyframeOffsetsUnspecified) |
| 241 { | 241 { |
| 242 KeyframeEffectModel::KeyframeVector keyframes(3); | 242 AnimatableValueKeyframeVector keyframes(3); |
| 243 keyframes[0] = Keyframe::create(); | 243 keyframes[0] = AnimatableValueKeyframe::create(); |
| 244 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(3.0).
get()); | 244 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(3.0).
get()); |
| 245 keyframes[1] = Keyframe::create(); | 245 keyframes[1] = AnimatableValueKeyframe::create(); |
| 246 keyframes[1]->setOffset(0.5); | 246 keyframes[1]->setOffset(0.5); |
| 247 keyframes[1]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(4.0).
get()); | 247 keyframes[1]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(4.0).
get()); |
| 248 keyframes[2] = Keyframe::create(); | 248 keyframes[2] = AnimatableValueKeyframe::create(); |
| 249 keyframes[2]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(5.0).
get()); | 249 keyframes[2]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(5.0).
get()); |
| 250 | 250 |
| 251 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 251 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 252 expectDoubleValue(3.0, effect->sample(0, 0.1, duration)->at(0)); | 252 expectDoubleValue(3.0, effect->sample(0, 0.1, duration)->at(0)); |
| 253 expectDoubleValue(4.0, effect->sample(0, 0.6, duration)->at(0)); | 253 expectDoubleValue(4.0, effect->sample(0, 0.6, duration)->at(0)); |
| 254 expectDoubleValue(5.0, effect->sample(0, 0.9, duration)->at(0)); | 254 expectDoubleValue(5.0, effect->sample(0, 0.9, duration)->at(0)); |
| 255 } | 255 } |
| 256 | 256 |
| 257 TEST(AnimationKeyframeEffectModel, SampleOnKeyframe) | 257 TEST(AnimationKeyframeEffectModel, SampleOnKeyframe) |
| 258 { | 258 { |
| 259 KeyframeEffectModel::KeyframeVector keyframes(3); | 259 AnimatableValueKeyframeVector keyframes(3); |
| 260 keyframes[0] = Keyframe::create(); | 260 keyframes[0] = AnimatableValueKeyframe::create(); |
| 261 keyframes[0]->setOffset(0.0); | 261 keyframes[0]->setOffset(0.0); |
| 262 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(3.0).
get()); | 262 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(3.0).
get()); |
| 263 keyframes[1] = Keyframe::create(); | 263 keyframes[1] = AnimatableValueKeyframe::create(); |
| 264 keyframes[1]->setOffset(0.5); | 264 keyframes[1]->setOffset(0.5); |
| 265 keyframes[1]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(4.0).
get()); | 265 keyframes[1]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(4.0).
get()); |
| 266 keyframes[2] = Keyframe::create(); | 266 keyframes[2] = AnimatableValueKeyframe::create(); |
| 267 keyframes[2]->setOffset(1.0); | 267 keyframes[2]->setOffset(1.0); |
| 268 keyframes[2]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(5.0).
get()); | 268 keyframes[2]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(5.0).
get()); |
| 269 | 269 |
| 270 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 270 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 271 expectDoubleValue(3.0, effect->sample(0, 0.0, duration)->at(0)); | 271 expectDoubleValue(3.0, effect->sample(0, 0.0, duration)->at(0)); |
| 272 expectDoubleValue(4.0, effect->sample(0, 0.5, duration)->at(0)); | 272 expectDoubleValue(4.0, effect->sample(0, 0.5, duration)->at(0)); |
| 273 expectDoubleValue(5.0, effect->sample(0, 1.0, duration)->at(0)); | 273 expectDoubleValue(5.0, effect->sample(0, 1.0, duration)->at(0)); |
| 274 } | 274 } |
| 275 | 275 |
| 276 TEST(AnimationKeyframeEffectModel, MultipleKeyframesWithSameOffset) | 276 TEST(AnimationKeyframeEffectModel, MultipleKeyframesWithSameOffset) |
| 277 { | 277 { |
| 278 KeyframeEffectModel::KeyframeVector keyframes(9); | 278 AnimatableValueKeyframeVector keyframes(9); |
| 279 keyframes[0] = Keyframe::create(); | 279 keyframes[0] = AnimatableValueKeyframe::create(); |
| 280 keyframes[0]->setOffset(0.0); | 280 keyframes[0]->setOffset(0.0); |
| 281 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(0.0).
get()); | 281 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(0.0).
get()); |
| 282 keyframes[1] = Keyframe::create(); | 282 keyframes[1] = AnimatableValueKeyframe::create(); |
| 283 keyframes[1]->setOffset(0.1); | 283 keyframes[1]->setOffset(0.1); |
| 284 keyframes[1]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(1.0).
get()); | 284 keyframes[1]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(1.0).
get()); |
| 285 keyframes[2] = Keyframe::create(); | 285 keyframes[2] = AnimatableValueKeyframe::create(); |
| 286 keyframes[2]->setOffset(0.1); | 286 keyframes[2]->setOffset(0.1); |
| 287 keyframes[2]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(2.0).
get()); | 287 keyframes[2]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(2.0).
get()); |
| 288 keyframes[3] = Keyframe::create(); | 288 keyframes[3] = AnimatableValueKeyframe::create(); |
| 289 keyframes[3]->setOffset(0.5); | 289 keyframes[3]->setOffset(0.5); |
| 290 keyframes[3]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(3.0).
get()); | 290 keyframes[3]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(3.0).
get()); |
| 291 keyframes[4] = Keyframe::create(); | 291 keyframes[4] = AnimatableValueKeyframe::create(); |
| 292 keyframes[4]->setOffset(0.5); | 292 keyframes[4]->setOffset(0.5); |
| 293 keyframes[4]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(4.0).
get()); | 293 keyframes[4]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(4.0).
get()); |
| 294 keyframes[5] = Keyframe::create(); | 294 keyframes[5] = AnimatableValueKeyframe::create(); |
| 295 keyframes[5]->setOffset(0.5); | 295 keyframes[5]->setOffset(0.5); |
| 296 keyframes[5]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(5.0).
get()); | 296 keyframes[5]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(5.0).
get()); |
| 297 keyframes[6] = Keyframe::create(); | 297 keyframes[6] = AnimatableValueKeyframe::create(); |
| 298 keyframes[6]->setOffset(0.9); | 298 keyframes[6]->setOffset(0.9); |
| 299 keyframes[6]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(6.0).
get()); | 299 keyframes[6]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(6.0).
get()); |
| 300 keyframes[7] = Keyframe::create(); | 300 keyframes[7] = AnimatableValueKeyframe::create(); |
| 301 keyframes[7]->setOffset(0.9); | 301 keyframes[7]->setOffset(0.9); |
| 302 keyframes[7]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(7.0).
get()); | 302 keyframes[7]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(7.0).
get()); |
| 303 keyframes[8] = Keyframe::create(); | 303 keyframes[8] = AnimatableValueKeyframe::create(); |
| 304 keyframes[8]->setOffset(1.0); | 304 keyframes[8]->setOffset(1.0); |
| 305 keyframes[8]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(7.0).
get()); | 305 keyframes[8]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(7.0).
get()); |
| 306 | 306 |
| 307 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 307 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 308 expectDoubleValue(0.0, effect->sample(0, 0.0, duration)->at(0)); | 308 expectDoubleValue(0.0, effect->sample(0, 0.0, duration)->at(0)); |
| 309 expectDoubleValue(2.0, effect->sample(0, 0.2, duration)->at(0)); | 309 expectDoubleValue(2.0, effect->sample(0, 0.2, duration)->at(0)); |
| 310 expectDoubleValue(3.0, effect->sample(0, 0.4, duration)->at(0)); | 310 expectDoubleValue(3.0, effect->sample(0, 0.4, duration)->at(0)); |
| 311 expectDoubleValue(5.0, effect->sample(0, 0.5, duration)->at(0)); | 311 expectDoubleValue(5.0, effect->sample(0, 0.5, duration)->at(0)); |
| 312 expectDoubleValue(5.0, effect->sample(0, 0.6, duration)->at(0)); | 312 expectDoubleValue(5.0, effect->sample(0, 0.6, duration)->at(0)); |
| 313 expectDoubleValue(6.0, effect->sample(0, 0.8, duration)->at(0)); | 313 expectDoubleValue(6.0, effect->sample(0, 0.8, duration)->at(0)); |
| 314 expectDoubleValue(7.0, effect->sample(0, 1.0, duration)->at(0)); | 314 expectDoubleValue(7.0, effect->sample(0, 1.0, duration)->at(0)); |
| 315 } | 315 } |
| 316 | 316 |
| 317 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. | 317 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. |
| 318 TEST(AnimationKeyframeEffectModel, DISABLED_PerKeyframeComposite) | 318 TEST(AnimationKeyframeEffectModel, DISABLED_PerKeyframeComposite) |
| 319 { | 319 { |
| 320 KeyframeEffectModel::KeyframeVector keyframes(2); | 320 AnimatableValueKeyframeVector keyframes(2); |
| 321 keyframes[0] = Keyframe::create(); | 321 keyframes[0] = AnimatableValueKeyframe::create(); |
| 322 keyframes[0]->setOffset(0.0); | 322 keyframes[0]->setOffset(0.0); |
| 323 keyframes[0]->setPropertyValue(CSSPropertyLeft, pixelAnimatableValue(3.0).ge
t()); | 323 keyframes[0]->setPropertyValue(CSSPropertyLeft, pixelAnimatableValue(3.0).ge
t()); |
| 324 keyframes[1] = Keyframe::create(); | 324 keyframes[1] = AnimatableValueKeyframe::create(); |
| 325 keyframes[1]->setOffset(1.0); | 325 keyframes[1]->setOffset(1.0); |
| 326 keyframes[1]->setPropertyValue(CSSPropertyLeft, pixelAnimatableValue(5.0).ge
t()); | 326 keyframes[1]->setPropertyValue(CSSPropertyLeft, pixelAnimatableValue(5.0).ge
t()); |
| 327 keyframes[1]->setComposite(AnimationEffect::CompositeAdd); | 327 keyframes[1]->setComposite(AnimationEffect::CompositeAdd); |
| 328 | 328 |
| 329 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 329 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 330 expectDoubleValue(3.0 * 0.4 + (7.0 + 5.0) * 0.6, effect->sample(0, 0.6, dura
tion)->at(0)); | 330 expectDoubleValue(3.0 * 0.4 + (7.0 + 5.0) * 0.6, effect->sample(0, 0.6, dura
tion)->at(0)); |
| 331 } | 331 } |
| 332 | 332 |
| 333 TEST(AnimationKeyframeEffectModel, MultipleProperties) | 333 TEST(AnimationKeyframeEffectModel, MultipleProperties) |
| 334 { | 334 { |
| 335 KeyframeEffectModel::KeyframeVector keyframes(2); | 335 AnimatableValueKeyframeVector keyframes(2); |
| 336 keyframes[0] = Keyframe::create(); | 336 keyframes[0] = AnimatableValueKeyframe::create(); |
| 337 keyframes[0]->setOffset(0.0); | 337 keyframes[0]->setOffset(0.0); |
| 338 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(3.0).
get()); | 338 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(3.0).
get()); |
| 339 keyframes[0]->setPropertyValue(CSSPropertyRight, unknownAnimatableValue(4.0)
.get()); | 339 keyframes[0]->setPropertyValue(CSSPropertyRight, unknownAnimatableValue(4.0)
.get()); |
| 340 keyframes[1] = Keyframe::create(); | 340 keyframes[1] = AnimatableValueKeyframe::create(); |
| 341 keyframes[1]->setOffset(1.0); | 341 keyframes[1]->setOffset(1.0); |
| 342 keyframes[1]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(5.0).
get()); | 342 keyframes[1]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(5.0).
get()); |
| 343 keyframes[1]->setPropertyValue(CSSPropertyRight, unknownAnimatableValue(6.0)
.get()); | 343 keyframes[1]->setPropertyValue(CSSPropertyRight, unknownAnimatableValue(6.0)
.get()); |
| 344 | 344 |
| 345 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 345 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 346 OwnPtrWillBeRawPtr<WillBeHeapVector<RefPtrWillBeMember<Interpolation> > > va
lues = effect->sample(0, 0.6, duration); | 346 OwnPtrWillBeRawPtr<WillBeHeapVector<RefPtrWillBeMember<Interpolation> > > va
lues = effect->sample(0, 0.6, duration); |
| 347 EXPECT_EQ(2UL, values->size()); | 347 EXPECT_EQ(2UL, values->size()); |
| 348 Interpolation* leftValue = findValue(*values.get(), CSSPropertyLeft); | 348 Interpolation* leftValue = findValue(*values.get(), CSSPropertyLeft); |
| 349 ASSERT_TRUE(leftValue); | 349 ASSERT_TRUE(leftValue); |
| 350 expectDoubleValue(5.0, leftValue); | 350 expectDoubleValue(5.0, leftValue); |
| 351 Interpolation* rightValue = findValue(*values.get(), CSSPropertyRight); | 351 Interpolation* rightValue = findValue(*values.get(), CSSPropertyRight); |
| 352 ASSERT_TRUE(rightValue); | 352 ASSERT_TRUE(rightValue); |
| 353 expectDoubleValue(6.0, rightValue); | 353 expectDoubleValue(6.0, rightValue); |
| 354 } | 354 } |
| 355 | 355 |
| 356 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. | 356 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. |
| 357 TEST(AnimationKeyframeEffectModel, DISABLED_RecompositeCompositableValue) | 357 TEST(AnimationKeyframeEffectModel, DISABLED_RecompositeCompositableValue) |
| 358 { | 358 { |
| 359 KeyframeEffectModel::KeyframeVector keyframes = keyframesAtZeroAndOne(pixelA
nimatableValue(3.0), pixelAnimatableValue(5.0)); | 359 AnimatableValueKeyframeVector keyframes = keyframesAtZeroAndOne(pixelAnimata
bleValue(3.0), pixelAnimatableValue(5.0)); |
| 360 keyframes[0]->setComposite(AnimationEffect::CompositeAdd); | 360 keyframes[0]->setComposite(AnimationEffect::CompositeAdd); |
| 361 keyframes[1]->setComposite(AnimationEffect::CompositeAdd); | 361 keyframes[1]->setComposite(AnimationEffect::CompositeAdd); |
| 362 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 362 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 363 OwnPtrWillBeRawPtr<WillBeHeapVector<RefPtrWillBeMember<Interpolation> > > va
lues = effect->sample(0, 0.6, duration); | 363 OwnPtrWillBeRawPtr<WillBeHeapVector<RefPtrWillBeMember<Interpolation> > > va
lues = effect->sample(0, 0.6, duration); |
| 364 expectDoubleValue((7.0 + 3.0) * 0.4 + (7.0 + 5.0) * 0.6, values->at(0)); | 364 expectDoubleValue((7.0 + 3.0) * 0.4 + (7.0 + 5.0) * 0.6, values->at(0)); |
| 365 expectDoubleValue((9.0 + 3.0) * 0.4 + (9.0 + 5.0) * 0.6, values->at(0)); | 365 expectDoubleValue((9.0 + 3.0) * 0.4 + (9.0 + 5.0) * 0.6, values->at(0)); |
| 366 } | 366 } |
| 367 | 367 |
| 368 TEST(AnimationKeyframeEffectModel, MultipleIterations) | 368 TEST(AnimationKeyframeEffectModel, MultipleIterations) |
| 369 { | 369 { |
| 370 KeyframeEffectModel::KeyframeVector keyframes = keyframesAtZeroAndOne(pixelA
nimatableValue(1.0), pixelAnimatableValue(3.0)); | 370 AnimatableValueKeyframeVector keyframes = keyframesAtZeroAndOne(pixelAnimata
bleValue(1.0), pixelAnimatableValue(3.0)); |
| 371 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 371 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 372 expectDoubleValue(2.0, effect->sample(0, 0.5, duration)->at(0)); | 372 expectDoubleValue(2.0, effect->sample(0, 0.5, duration)->at(0)); |
| 373 expectDoubleValue(2.0, effect->sample(1, 0.5, duration)->at(0)); | 373 expectDoubleValue(2.0, effect->sample(1, 0.5, duration)->at(0)); |
| 374 expectDoubleValue(2.0, effect->sample(2, 0.5, duration)->at(0)); | 374 expectDoubleValue(2.0, effect->sample(2, 0.5, duration)->at(0)); |
| 375 } | 375 } |
| 376 | 376 |
| 377 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. | 377 // FIXME: Re-enable this test once compositing of CompositeAdd is supported. |
| 378 TEST(AnimationKeyframeEffectModel, DISABLED_DependsOnUnderlyingValue) | 378 TEST(AnimationKeyframeEffectModel, DISABLED_DependsOnUnderlyingValue) |
| 379 { | 379 { |
| 380 KeyframeEffectModel::KeyframeVector keyframes(3); | 380 AnimatableValueKeyframeVector keyframes(3); |
| 381 keyframes[0] = Keyframe::create(); | 381 keyframes[0] = AnimatableValueKeyframe::create(); |
| 382 keyframes[0]->setOffset(0.0); | 382 keyframes[0]->setOffset(0.0); |
| 383 keyframes[0]->setPropertyValue(CSSPropertyLeft, pixelAnimatableValue(1.0).ge
t()); | 383 keyframes[0]->setPropertyValue(CSSPropertyLeft, pixelAnimatableValue(1.0).ge
t()); |
| 384 keyframes[0]->setComposite(AnimationEffect::CompositeAdd); | 384 keyframes[0]->setComposite(AnimationEffect::CompositeAdd); |
| 385 keyframes[1] = Keyframe::create(); | 385 keyframes[1] = AnimatableValueKeyframe::create(); |
| 386 keyframes[1]->setOffset(0.5); | 386 keyframes[1]->setOffset(0.5); |
| 387 keyframes[1]->setPropertyValue(CSSPropertyLeft, pixelAnimatableValue(1.0).ge
t()); | 387 keyframes[1]->setPropertyValue(CSSPropertyLeft, pixelAnimatableValue(1.0).ge
t()); |
| 388 keyframes[2] = Keyframe::create(); | 388 keyframes[2] = AnimatableValueKeyframe::create(); |
| 389 keyframes[2]->setOffset(1.0); | 389 keyframes[2]->setOffset(1.0); |
| 390 keyframes[2]->setPropertyValue(CSSPropertyLeft, pixelAnimatableValue(1.0).ge
t()); | 390 keyframes[2]->setPropertyValue(CSSPropertyLeft, pixelAnimatableValue(1.0).ge
t()); |
| 391 | 391 |
| 392 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 392 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 393 EXPECT_TRUE(effect->sample(0, 0, duration)->at(0)); | 393 EXPECT_TRUE(effect->sample(0, 0, duration)->at(0)); |
| 394 EXPECT_TRUE(effect->sample(0, 0.1, duration)->at(0)); | 394 EXPECT_TRUE(effect->sample(0, 0.1, duration)->at(0)); |
| 395 EXPECT_TRUE(effect->sample(0, 0.25, duration)->at(0)); | 395 EXPECT_TRUE(effect->sample(0, 0.25, duration)->at(0)); |
| 396 EXPECT_TRUE(effect->sample(0, 0.4, duration)->at(0)); | 396 EXPECT_TRUE(effect->sample(0, 0.4, duration)->at(0)); |
| 397 EXPECT_FALSE(effect->sample(0, 0.5, duration)->at(0)); | 397 EXPECT_FALSE(effect->sample(0, 0.5, duration)->at(0)); |
| 398 EXPECT_FALSE(effect->sample(0, 0.6, duration)->at(0)); | 398 EXPECT_FALSE(effect->sample(0, 0.6, duration)->at(0)); |
| 399 EXPECT_FALSE(effect->sample(0, 0.75, duration)->at(0)); | 399 EXPECT_FALSE(effect->sample(0, 0.75, duration)->at(0)); |
| 400 EXPECT_FALSE(effect->sample(0, 0.8, duration)->at(0)); | 400 EXPECT_FALSE(effect->sample(0, 0.8, duration)->at(0)); |
| 401 EXPECT_FALSE(effect->sample(0, 1, duration)->at(0)); | 401 EXPECT_FALSE(effect->sample(0, 1, duration)->at(0)); |
| 402 } | 402 } |
| 403 | 403 |
| 404 TEST(AnimationKeyframeEffectModel, AddSyntheticKeyframes) | 404 TEST(AnimationKeyframeEffectModel, AddSyntheticKeyframes) |
| 405 { | 405 { |
| 406 KeyframeEffectModel::KeyframeVector keyframes(1); | 406 AnimatableValueKeyframeVector keyframes(1); |
| 407 keyframes[0] = Keyframe::create(); | 407 keyframes[0] = AnimatableValueKeyframe::create(); |
| 408 keyframes[0]->setOffset(0.5); | 408 keyframes[0]->setOffset(0.5); |
| 409 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(4.0).
get()); | 409 keyframes[0]->setPropertyValue(CSSPropertyLeft, unknownAnimatableValue(4.0).
get()); |
| 410 | 410 |
| 411 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 411 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 412 const KeyframeEffectModel::PropertySpecificKeyframeVector& propertySpecificK
eyframes = effect->getPropertySpecificKeyframes(CSSPropertyLeft); | 412 const AnimatableValuePropertySpecificKeyframeVector& propertySpecificKeyfram
es = effect->getPropertySpecificKeyframes(CSSPropertyLeft); |
| 413 EXPECT_EQ(3U, propertySpecificKeyframes.size()); | 413 EXPECT_EQ(3U, propertySpecificKeyframes.size()); |
| 414 EXPECT_DOUBLE_EQ(0.0, propertySpecificKeyframes[0]->offset()); | 414 EXPECT_DOUBLE_EQ(0.0, propertySpecificKeyframes[0]->offset()); |
| 415 EXPECT_DOUBLE_EQ(0.5, propertySpecificKeyframes[1]->offset()); | 415 EXPECT_DOUBLE_EQ(0.5, propertySpecificKeyframes[1]->offset()); |
| 416 EXPECT_DOUBLE_EQ(1.0, propertySpecificKeyframes[2]->offset()); | 416 EXPECT_DOUBLE_EQ(1.0, propertySpecificKeyframes[2]->offset()); |
| 417 } | 417 } |
| 418 | 418 |
| 419 TEST(AnimationKeyframeEffectModel, ToKeyframeEffectModel) | 419 TEST(AnimationKeyframeEffectModel, ToKeyframeEffectModel) |
| 420 { | 420 { |
| 421 KeyframeEffectModel::KeyframeVector keyframes(0); | 421 AnimatableValueKeyframeVector keyframes(0); |
| 422 RefPtrWillBeRawPtr<KeyframeEffectModel> effect = KeyframeEffectModel::create
(keyframes); | 422 RefPtrWillBeRawPtr<AnimatableValueKeyframeEffectModel> effect = AnimatableVa
lueKeyframeEffectModel::create(keyframes); |
| 423 | 423 |
| 424 AnimationEffect* baseEffect = effect.get(); | 424 AnimationEffect* baseEffect = effect.get(); |
| 425 EXPECT_TRUE(toKeyframeEffectModel(baseEffect)); | 425 EXPECT_TRUE(toAnimatableValueKeyframeEffectModel(baseEffect)); |
| 426 } | 426 } |
| 427 | 427 |
| 428 } // namespace | 428 } // namespace |
| 429 | 429 |
| 430 namespace WebCore { | 430 namespace WebCore { |
| 431 | 431 |
| 432 class KeyframeEffectModelTest : public ::testing::Test { | 432 class KeyframeEffectModelTest : public ::testing::Test { |
| 433 public: | 433 public: |
| 434 typedef KeyframeEffectModel::KeyframeVector KeyframeVector; | |
| 435 | |
| 436 static KeyframeVector normalizedKeyframes(const KeyframeVector& keyframes) | 434 static KeyframeVector normalizedKeyframes(const KeyframeVector& keyframes) |
| 437 { | 435 { |
| 438 return KeyframeEffectModel::normalizedKeyframes(keyframes); | 436 return KeyframeEffectModelBase::normalizedKeyframes(keyframes); |
| 439 } | 437 } |
| 440 }; | 438 }; |
| 441 | 439 |
| 442 TEST_F(KeyframeEffectModelTest, NotLooselySorted) | 440 TEST_F(KeyframeEffectModelTest, NotLooselySorted) |
| 443 { | 441 { |
| 444 KeyframeEffectModel::KeyframeVector keyframes(4); | 442 KeyframeVector keyframes(4); |
| 445 keyframes[0] = Keyframe::create(); | 443 keyframes[0] = AnimatableValueKeyframe::create(); |
| 446 keyframes[1] = Keyframe::create(); | 444 keyframes[1] = AnimatableValueKeyframe::create(); |
| 447 keyframes[1]->setOffset(9); | 445 keyframes[1]->setOffset(9); |
| 448 keyframes[2] = Keyframe::create(); | 446 keyframes[2] = AnimatableValueKeyframe::create(); |
| 449 keyframes[3] = Keyframe::create(); | 447 keyframes[3] = AnimatableValueKeyframe::create(); |
| 450 keyframes[3]->setOffset(1); | 448 keyframes[3]->setOffset(1); |
| 451 | 449 |
| 452 const KeyframeVector result = normalizedKeyframes(keyframes); | 450 const KeyframeVector result = normalizedKeyframes(keyframes); |
| 453 EXPECT_EQ(0U, result.size()); | 451 EXPECT_EQ(0U, result.size()); |
| 454 } | 452 } |
| 455 | 453 |
| 456 TEST_F(KeyframeEffectModelTest, LastOne) | 454 TEST_F(KeyframeEffectModelTest, LastOne) |
| 457 { | 455 { |
| 458 KeyframeEffectModel::KeyframeVector keyframes(3); | 456 KeyframeVector keyframes(3); |
| 459 keyframes[0] = Keyframe::create(); | 457 keyframes[0] = AnimatableValueKeyframe::create(); |
| 460 keyframes[0]->setOffset(-1); | 458 keyframes[0]->setOffset(-1); |
| 461 keyframes[1] = Keyframe::create(); | 459 keyframes[1] = AnimatableValueKeyframe::create(); |
| 462 keyframes[2] = Keyframe::create(); | 460 keyframes[2] = AnimatableValueKeyframe::create(); |
| 463 keyframes[2]->setOffset(2); | 461 keyframes[2]->setOffset(2); |
| 464 | 462 |
| 465 const KeyframeVector result = normalizedKeyframes(keyframes); | 463 const KeyframeVector result = normalizedKeyframes(keyframes); |
| 466 EXPECT_EQ(1U, result.size()); | 464 EXPECT_EQ(1U, result.size()); |
| 467 EXPECT_DOUBLE_EQ(1.0, result[0]->offset()); | 465 EXPECT_DOUBLE_EQ(1.0, result[0]->offset()); |
| 468 } | 466 } |
| 469 | 467 |
| 470 TEST_F(KeyframeEffectModelTest, FirstZero) | 468 TEST_F(KeyframeEffectModelTest, FirstZero) |
| 471 { | 469 { |
| 472 KeyframeEffectModel::KeyframeVector keyframes(3); | 470 KeyframeVector keyframes(3); |
| 473 keyframes[0] = Keyframe::create(); | 471 keyframes[0] = AnimatableValueKeyframe::create(); |
| 474 keyframes[0]->setOffset(-1); | 472 keyframes[0]->setOffset(-1); |
| 475 keyframes[1] = Keyframe::create(); | 473 keyframes[1] = AnimatableValueKeyframe::create(); |
| 476 keyframes[2] = Keyframe::create(); | 474 keyframes[2] = AnimatableValueKeyframe::create(); |
| 477 keyframes[2]->setOffset(0.25); | 475 keyframes[2]->setOffset(0.25); |
| 478 | 476 |
| 479 const KeyframeVector result = normalizedKeyframes(keyframes); | 477 const KeyframeVector result = normalizedKeyframes(keyframes); |
| 480 EXPECT_EQ(2U, result.size()); | 478 EXPECT_EQ(2U, result.size()); |
| 481 EXPECT_DOUBLE_EQ(0.0, result[0]->offset()); | 479 EXPECT_DOUBLE_EQ(0.0, result[0]->offset()); |
| 482 EXPECT_DOUBLE_EQ(0.25, result[1]->offset()); | 480 EXPECT_DOUBLE_EQ(0.25, result[1]->offset()); |
| 483 } | 481 } |
| 484 | 482 |
| 485 TEST_F(KeyframeEffectModelTest, EvenlyDistributed1) | 483 TEST_F(KeyframeEffectModelTest, EvenlyDistributed1) |
| 486 { | 484 { |
| 487 KeyframeEffectModel::KeyframeVector keyframes(5); | 485 KeyframeVector keyframes(5); |
| 488 keyframes[0] = Keyframe::create(); | 486 keyframes[0] = AnimatableValueKeyframe::create(); |
| 489 keyframes[0]->setOffset(0.125); | 487 keyframes[0]->setOffset(0.125); |
| 490 keyframes[1] = Keyframe::create(); | 488 keyframes[1] = AnimatableValueKeyframe::create(); |
| 491 keyframes[2] = Keyframe::create(); | 489 keyframes[2] = AnimatableValueKeyframe::create(); |
| 492 keyframes[3] = Keyframe::create(); | 490 keyframes[3] = AnimatableValueKeyframe::create(); |
| 493 keyframes[4] = Keyframe::create(); | 491 keyframes[4] = AnimatableValueKeyframe::create(); |
| 494 keyframes[4]->setOffset(0.625); | 492 keyframes[4]->setOffset(0.625); |
| 495 | 493 |
| 496 const KeyframeVector result = normalizedKeyframes(keyframes); | 494 const KeyframeVector result = normalizedKeyframes(keyframes); |
| 497 EXPECT_EQ(5U, result.size()); | 495 EXPECT_EQ(5U, result.size()); |
| 498 EXPECT_DOUBLE_EQ(0.125, result[0]->offset()); | 496 EXPECT_DOUBLE_EQ(0.125, result[0]->offset()); |
| 499 EXPECT_DOUBLE_EQ(0.25, result[1]->offset()); | 497 EXPECT_DOUBLE_EQ(0.25, result[1]->offset()); |
| 500 EXPECT_DOUBLE_EQ(0.375, result[2]->offset()); | 498 EXPECT_DOUBLE_EQ(0.375, result[2]->offset()); |
| 501 EXPECT_DOUBLE_EQ(0.5, result[3]->offset()); | 499 EXPECT_DOUBLE_EQ(0.5, result[3]->offset()); |
| 502 EXPECT_DOUBLE_EQ(0.625, result[4]->offset()); | 500 EXPECT_DOUBLE_EQ(0.625, result[4]->offset()); |
| 503 } | 501 } |
| 504 | 502 |
| 505 TEST_F(KeyframeEffectModelTest, EvenlyDistributed2) | 503 TEST_F(KeyframeEffectModelTest, EvenlyDistributed2) |
| 506 { | 504 { |
| 507 KeyframeEffectModel::KeyframeVector keyframes(8); | 505 KeyframeVector keyframes(8); |
| 508 keyframes[0] = Keyframe::create(); | 506 keyframes[0] = AnimatableValueKeyframe::create(); |
| 509 keyframes[0]->setOffset(-0.1); | 507 keyframes[0]->setOffset(-0.1); |
| 510 keyframes[1] = Keyframe::create(); | 508 keyframes[1] = AnimatableValueKeyframe::create(); |
| 511 keyframes[2] = Keyframe::create(); | 509 keyframes[2] = AnimatableValueKeyframe::create(); |
| 512 keyframes[3] = Keyframe::create(); | 510 keyframes[3] = AnimatableValueKeyframe::create(); |
| 513 keyframes[4] = Keyframe::create(); | 511 keyframes[4] = AnimatableValueKeyframe::create(); |
| 514 keyframes[4]->setOffset(0.75); | 512 keyframes[4]->setOffset(0.75); |
| 515 keyframes[5] = Keyframe::create(); | 513 keyframes[5] = AnimatableValueKeyframe::create(); |
| 516 keyframes[6] = Keyframe::create(); | 514 keyframes[6] = AnimatableValueKeyframe::create(); |
| 517 keyframes[7] = Keyframe::create(); | 515 keyframes[7] = AnimatableValueKeyframe::create(); |
| 518 keyframes[7]->setOffset(1.1); | 516 keyframes[7]->setOffset(1.1); |
| 519 | 517 |
| 520 const KeyframeVector result = normalizedKeyframes(keyframes); | 518 const KeyframeVector result = normalizedKeyframes(keyframes); |
| 521 EXPECT_EQ(6U, result.size()); | 519 EXPECT_EQ(6U, result.size()); |
| 522 EXPECT_DOUBLE_EQ(0.0, result[0]->offset()); | 520 EXPECT_DOUBLE_EQ(0.0, result[0]->offset()); |
| 523 EXPECT_DOUBLE_EQ(0.25, result[1]->offset()); | 521 EXPECT_DOUBLE_EQ(0.25, result[1]->offset()); |
| 524 EXPECT_DOUBLE_EQ(0.5, result[2]->offset()); | 522 EXPECT_DOUBLE_EQ(0.5, result[2]->offset()); |
| 525 EXPECT_DOUBLE_EQ(0.75, result[3]->offset()); | 523 EXPECT_DOUBLE_EQ(0.75, result[3]->offset()); |
| 526 EXPECT_DOUBLE_EQ(0.875, result[4]->offset()); | 524 EXPECT_DOUBLE_EQ(0.875, result[4]->offset()); |
| 527 EXPECT_DOUBLE_EQ(1.0, result[5]->offset()); | 525 EXPECT_DOUBLE_EQ(1.0, result[5]->offset()); |
| 528 } | 526 } |
| 529 | 527 |
| 530 TEST_F(KeyframeEffectModelTest, EvenlyDistributed3) | 528 TEST_F(KeyframeEffectModelTest, EvenlyDistributed3) |
| 531 { | 529 { |
| 532 KeyframeEffectModel::KeyframeVector keyframes(12); | 530 KeyframeVector keyframes(12); |
| 533 keyframes[0] = Keyframe::create(); | 531 keyframes[0] = AnimatableValueKeyframe::create(); |
| 534 keyframes[0]->setOffset(0); | 532 keyframes[0]->setOffset(0); |
| 535 keyframes[1] = Keyframe::create(); | 533 keyframes[1] = AnimatableValueKeyframe::create(); |
| 536 keyframes[2] = Keyframe::create(); | 534 keyframes[2] = AnimatableValueKeyframe::create(); |
| 537 keyframes[3] = Keyframe::create(); | 535 keyframes[3] = AnimatableValueKeyframe::create(); |
| 538 keyframes[4] = Keyframe::create(); | 536 keyframes[4] = AnimatableValueKeyframe::create(); |
| 539 keyframes[4]->setOffset(0.5); | 537 keyframes[4]->setOffset(0.5); |
| 540 keyframes[5] = Keyframe::create(); | 538 keyframes[5] = AnimatableValueKeyframe::create(); |
| 541 keyframes[6] = Keyframe::create(); | 539 keyframes[6] = AnimatableValueKeyframe::create(); |
| 542 keyframes[7] = Keyframe::create(); | 540 keyframes[7] = AnimatableValueKeyframe::create(); |
| 543 keyframes[7]->setOffset(0.8); | 541 keyframes[7]->setOffset(0.8); |
| 544 keyframes[8] = Keyframe::create(); | 542 keyframes[8] = AnimatableValueKeyframe::create(); |
| 545 keyframes[9] = Keyframe::create(); | 543 keyframes[9] = AnimatableValueKeyframe::create(); |
| 546 keyframes[10] = Keyframe::create(); | 544 keyframes[10] = AnimatableValueKeyframe::create(); |
| 547 keyframes[11] = Keyframe::create(); | 545 keyframes[11] = AnimatableValueKeyframe::create(); |
| 548 | 546 |
| 549 const KeyframeVector result = normalizedKeyframes(keyframes); | 547 const KeyframeVector result = normalizedKeyframes(keyframes); |
| 550 EXPECT_EQ(12U, result.size()); | 548 EXPECT_EQ(12U, result.size()); |
| 551 EXPECT_DOUBLE_EQ(0.0, result[0]->offset()); | 549 EXPECT_DOUBLE_EQ(0.0, result[0]->offset()); |
| 552 EXPECT_DOUBLE_EQ(0.125, result[1]->offset()); | 550 EXPECT_DOUBLE_EQ(0.125, result[1]->offset()); |
| 553 EXPECT_DOUBLE_EQ(0.25, result[2]->offset()); | 551 EXPECT_DOUBLE_EQ(0.25, result[2]->offset()); |
| 554 EXPECT_DOUBLE_EQ(0.375, result[3]->offset()); | 552 EXPECT_DOUBLE_EQ(0.375, result[3]->offset()); |
| 555 EXPECT_DOUBLE_EQ(0.5, result[4]->offset()); | 553 EXPECT_DOUBLE_EQ(0.5, result[4]->offset()); |
| 556 EXPECT_DOUBLE_EQ(0.6, result[5]->offset()); | 554 EXPECT_DOUBLE_EQ(0.6, result[5]->offset()); |
| 557 EXPECT_DOUBLE_EQ(0.7, result[6]->offset()); | 555 EXPECT_DOUBLE_EQ(0.7, result[6]->offset()); |
| 558 EXPECT_DOUBLE_EQ(0.8, result[7]->offset()); | 556 EXPECT_DOUBLE_EQ(0.8, result[7]->offset()); |
| 559 EXPECT_DOUBLE_EQ(0.85, result[8]->offset()); | 557 EXPECT_DOUBLE_EQ(0.85, result[8]->offset()); |
| 560 EXPECT_DOUBLE_EQ(0.9, result[9]->offset()); | 558 EXPECT_DOUBLE_EQ(0.9, result[9]->offset()); |
| 561 EXPECT_DOUBLE_EQ(0.95, result[10]->offset()); | 559 EXPECT_DOUBLE_EQ(0.95, result[10]->offset()); |
| 562 EXPECT_DOUBLE_EQ(1.0, result[11]->offset()); | 560 EXPECT_DOUBLE_EQ(1.0, result[11]->offset()); |
| 563 } | 561 } |
| 564 | 562 |
| 565 } // namespace WebCore | 563 } // namespace WebCore |
| OLD | NEW |