summaryrefslogtreecommitdiffstats
path: root/chromium/third_party/WebKit/Source/core/animation/interpolation/LengthStyleInterpolationTest.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'chromium/third_party/WebKit/Source/core/animation/interpolation/LengthStyleInterpolationTest.cpp')
-rw-r--r--chromium/third_party/WebKit/Source/core/animation/interpolation/LengthStyleInterpolationTest.cpp119
1 files changed, 119 insertions, 0 deletions
diff --git a/chromium/third_party/WebKit/Source/core/animation/interpolation/LengthStyleInterpolationTest.cpp b/chromium/third_party/WebKit/Source/core/animation/interpolation/LengthStyleInterpolationTest.cpp
new file mode 100644
index 00000000000..8120e846fdf
--- /dev/null
+++ b/chromium/third_party/WebKit/Source/core/animation/interpolation/LengthStyleInterpolationTest.cpp
@@ -0,0 +1,119 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "config.h"
+#include "core/animation/interpolation/LengthStyleInterpolation.h"
+
+#include "core/css/CSSPrimitiveValue.h"
+#include "core/css/StylePropertySet.h"
+
+#include <gtest/gtest.h>
+
+namespace WebCore {
+
+class AnimationLengthStyleInterpolationTest : public ::testing::Test {
+protected:
+ static PassOwnPtrWillBeRawPtr<InterpolableValue> lengthToInterpolableValue(CSSValue* value)
+ {
+ return LengthStyleInterpolation::lengthToInterpolableValue(value);
+ }
+
+ static PassRefPtrWillBeRawPtr<CSSValue> interpolableValueToLength(InterpolableValue* value, ValueRange range)
+ {
+ return LengthStyleInterpolation::interpolableValueToLength(value, range);
+ }
+
+ static PassRefPtrWillBeRawPtr<CSSValue> roundTrip(PassRefPtrWillBeRawPtr<CSSValue> value)
+ {
+ return interpolableValueToLength(lengthToInterpolableValue(value.get()).get(), ValueRangeAll);
+ }
+
+ static void testPrimitiveValue(RefPtrWillBeRawPtr<CSSValue> value, double doubleValue, CSSPrimitiveValue::UnitType unitType)
+ {
+ EXPECT_TRUE(value->isPrimitiveValue());
+ EXPECT_EQ(doubleValue, toCSSPrimitiveValue(value.get())->getDoubleValue());
+ EXPECT_EQ(unitType, toCSSPrimitiveValue(value.get())->primitiveType());
+ }
+
+ static PassOwnPtrWillBeRawPtr<InterpolableList> createInterpolableLength(double a, double b, double c, double d, double e, double f, double g, double h, double i, double j)
+ {
+ OwnPtrWillBeRawPtr<InterpolableList> list = InterpolableList::create(10);
+ list->set(0, InterpolableNumber::create(a));
+ list->set(1, InterpolableNumber::create(b));
+ list->set(2, InterpolableNumber::create(c));
+ list->set(3, InterpolableNumber::create(d));
+ list->set(4, InterpolableNumber::create(e));
+ list->set(5, InterpolableNumber::create(f));
+ list->set(6, InterpolableNumber::create(g));
+ list->set(7, InterpolableNumber::create(h));
+ list->set(8, InterpolableNumber::create(i));
+ list->set(9, InterpolableNumber::create(j));
+
+ return list.release();
+ }
+
+ void initLengthArray(CSSLengthArray& lengthArray)
+ {
+ lengthArray.resize(CSSPrimitiveValue::LengthUnitTypeCount);
+ for (size_t i = 0; i < CSSPrimitiveValue::LengthUnitTypeCount; ++i)
+ lengthArray.at(i) = 0;
+ }
+
+ CSSLengthArray& setLengthArray(CSSLengthArray& lengthArray, String text)
+ {
+ initLengthArray(lengthArray);
+ RefPtr<MutableStylePropertySet> propertySet = MutableStylePropertySet::create();
+ propertySet->setProperty(CSSPropertyLeft, text);
+ toCSSPrimitiveValue(propertySet->getPropertyCSSValue(CSSPropertyLeft).get())->accumulateLengthArray(lengthArray);
+ return lengthArray;
+ }
+
+ bool lengthArraysEqual(CSSLengthArray& a, CSSLengthArray& b)
+ {
+ for (size_t i = 0; i < CSSPrimitiveValue::LengthUnitTypeCount; ++i) {
+ if (a.at(i) != b.at(i))
+ return false;
+ }
+ return true;
+ }
+};
+
+TEST_F(AnimationLengthStyleInterpolationTest, ZeroLength)
+{
+ RefPtrWillBeRawPtr<CSSValue> value = roundTrip(CSSPrimitiveValue::create(0, CSSPrimitiveValue::CSS_PX));
+ testPrimitiveValue(value, 0, CSSPrimitiveValue::CSS_PX);
+
+ value = roundTrip(CSSPrimitiveValue::create(0, CSSPrimitiveValue::CSS_EMS));
+ testPrimitiveValue(value, 0, CSSPrimitiveValue::CSS_PX);
+}
+
+TEST_F(AnimationLengthStyleInterpolationTest, SingleUnit)
+{
+ RefPtrWillBeRawPtr<CSSValue> value = roundTrip(CSSPrimitiveValue::create(10, CSSPrimitiveValue::CSS_PX));
+ testPrimitiveValue(value, 10, CSSPrimitiveValue::CSS_PX);
+
+ value = roundTrip(CSSPrimitiveValue::create(30, CSSPrimitiveValue::CSS_PERCENTAGE));
+ testPrimitiveValue(value, 30, CSSPrimitiveValue::CSS_PERCENTAGE);
+
+ value = roundTrip(CSSPrimitiveValue::create(-10, CSSPrimitiveValue::CSS_EMS));
+ testPrimitiveValue(value, -10, CSSPrimitiveValue::CSS_EMS);
+}
+
+TEST_F(AnimationLengthStyleInterpolationTest, SingleClampedUnit)
+{
+ RefPtrWillBeRawPtr<CSSValue> value = CSSPrimitiveValue::create(-10, CSSPrimitiveValue::CSS_EMS);
+ value = interpolableValueToLength(lengthToInterpolableValue(value.get()).get(), ValueRangeNonNegative);
+ testPrimitiveValue(value, 0, CSSPrimitiveValue::CSS_EMS);
+}
+
+TEST_F(AnimationLengthStyleInterpolationTest, MultipleUnits)
+{
+ CSSLengthArray actual, expectation;
+ initLengthArray(expectation);
+ OwnPtrWillBeRawPtr<InterpolableList> list = createInterpolableLength(0, 10, 0, 10, 0, 10, 0, 10, 0, 10);
+ toCSSPrimitiveValue(interpolableValueToLength(list.get(), ValueRangeAll).get())->accumulateLengthArray(expectation);
+ EXPECT_TRUE(lengthArraysEqual(expectation, setLengthArray(actual, "calc(10%% + 10ex + 10ch + 10vh + 10vmax)")));
+}
+
+}