Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(79)

Unified Diff: third_party/WebKit/Source/platform/animation/CompositorFloatAnimationCurveTest.cpp

Issue 1616653002: CC Animation: Move files from cc_blink to Source/platform/animation (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase. Fix copyrights and years. Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/platform/animation/CompositorFloatAnimationCurveTest.cpp
diff --git a/third_party/WebKit/Source/platform/animation/CompositorFloatAnimationCurveTest.cpp b/third_party/WebKit/Source/platform/animation/CompositorFloatAnimationCurveTest.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..0f10b2d6d0fdc0d5a826dee027c56a14c699a438
--- /dev/null
+++ b/third_party/WebKit/Source/platform/animation/CompositorFloatAnimationCurveTest.cpp
@@ -0,0 +1,246 @@
+// Copyright 2016 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 "platform/animation/CompositorFloatAnimationCurve.h"
+
+#include "base/memory/scoped_ptr.h"
+#include "cc/animation/timing_function.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+using blink::CompositorAnimationCurve;
+using blink::CompositorFloatAnimationCurve;
+using blink::CompositorFloatKeyframe;
+
+namespace blink {
+
+// Tests that a float animation with one keyframe works as expected.
+TEST(WebFloatAnimationCurveTest, OneFloatKeyframe)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ curve->add(CompositorFloatKeyframe(0, 2),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+ EXPECT_FLOAT_EQ(2, curve->getValue(-1));
+ EXPECT_FLOAT_EQ(2, curve->getValue(0));
+ EXPECT_FLOAT_EQ(2, curve->getValue(0.5));
+ EXPECT_FLOAT_EQ(2, curve->getValue(1));
+ EXPECT_FLOAT_EQ(2, curve->getValue(2));
+}
+
+// Tests that a float animation with two keyframes works as expected.
+TEST(WebFloatAnimationCurveTest, TwoFloatKeyframe)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ curve->add(CompositorFloatKeyframe(0, 2),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+ curve->add(CompositorFloatKeyframe(1, 4),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+ EXPECT_FLOAT_EQ(2, curve->getValue(-1));
+ EXPECT_FLOAT_EQ(2, curve->getValue(0));
+ EXPECT_FLOAT_EQ(3, curve->getValue(0.5));
+ EXPECT_FLOAT_EQ(4, curve->getValue(1));
+ EXPECT_FLOAT_EQ(4, curve->getValue(2));
+}
+
+// Tests that a float animation with three keyframes works as expected.
+TEST(WebFloatAnimationCurveTest, ThreeFloatKeyframe)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ curve->add(CompositorFloatKeyframe(0, 2),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+ curve->add(CompositorFloatKeyframe(1, 4),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+ curve->add(CompositorFloatKeyframe(2, 8),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+ EXPECT_FLOAT_EQ(2, curve->getValue(-1));
+ EXPECT_FLOAT_EQ(2, curve->getValue(0));
+ EXPECT_FLOAT_EQ(3, curve->getValue(0.5));
+ EXPECT_FLOAT_EQ(4, curve->getValue(1));
+ EXPECT_FLOAT_EQ(6, curve->getValue(1.5));
+ EXPECT_FLOAT_EQ(8, curve->getValue(2));
+ EXPECT_FLOAT_EQ(8, curve->getValue(3));
+}
+
+// Tests that a float animation with multiple keys at a given time works sanely.
+TEST(WebFloatAnimationCurveTest, RepeatedFloatKeyTimes)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ curve->add(CompositorFloatKeyframe(0, 4),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+ curve->add(CompositorFloatKeyframe(1, 4),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+ curve->add(CompositorFloatKeyframe(1, 6),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+ curve->add(CompositorFloatKeyframe(2, 6),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+
+ EXPECT_FLOAT_EQ(4, curve->getValue(-1));
+ EXPECT_FLOAT_EQ(4, curve->getValue(0));
+ EXPECT_FLOAT_EQ(4, curve->getValue(0.5));
+
+ // There is a discontinuity at 1. Any value between 4 and 6 is valid.
+ float value = curve->getValue(1);
+ EXPECT_TRUE(value >= 4 && value <= 6);
+
+ EXPECT_FLOAT_EQ(6, curve->getValue(1.5));
+ EXPECT_FLOAT_EQ(6, curve->getValue(2));
+ EXPECT_FLOAT_EQ(6, curve->getValue(3));
+}
+
+// Tests that the keyframes may be added out of order.
+TEST(WebFloatAnimationCurveTest, UnsortedKeyframes)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ curve->add(CompositorFloatKeyframe(2, 8),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+ curve->add(CompositorFloatKeyframe(0, 2),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+ curve->add(CompositorFloatKeyframe(1, 4),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+
+ EXPECT_FLOAT_EQ(2, curve->getValue(-1));
+ EXPECT_FLOAT_EQ(2, curve->getValue(0));
+ EXPECT_FLOAT_EQ(3, curve->getValue(0.5));
+ EXPECT_FLOAT_EQ(4, curve->getValue(1));
+ EXPECT_FLOAT_EQ(6, curve->getValue(1.5));
+ EXPECT_FLOAT_EQ(8, curve->getValue(2));
+ EXPECT_FLOAT_EQ(8, curve->getValue(3));
+}
+
+// Tests that a cubic bezier timing function works as expected.
+TEST(WebFloatAnimationCurveTest, CubicBezierTimingFunction)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ curve->add(CompositorFloatKeyframe(0, 0), 0.25, 0, 0.75, 1);
+ curve->add(CompositorFloatKeyframe(1, 1),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+
+ EXPECT_FLOAT_EQ(0, curve->getValue(0));
+ EXPECT_LT(0, curve->getValue(0.25));
+ EXPECT_GT(0.25, curve->getValue(0.25));
+ EXPECT_NEAR(curve->getValue(0.5), 0.5, 0.00015);
+ EXPECT_LT(0.75, curve->getValue(0.75));
+ EXPECT_GT(1, curve->getValue(0.75));
+ EXPECT_FLOAT_EQ(1, curve->getValue(1));
+}
+
+// Tests that an ease timing function works as expected.
+TEST(WebFloatAnimationCurveTest, EaseTimingFunction)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ curve->add(CompositorFloatKeyframe(0, 0),
+ CompositorAnimationCurve::TimingFunctionTypeEase);
+ curve->add(CompositorFloatKeyframe(1, 1),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+
+ scoped_ptr<cc::TimingFunction> timingFunction(
+ cc::EaseTimingFunction::Create());
+ for (int i = 0; i <= 4; ++i) {
+ const double time = i * 0.25;
+ EXPECT_FLOAT_EQ(timingFunction->GetValue(time), curve->getValue(time));
+ }
+}
+
+// Tests using a linear timing function.
+TEST(WebFloatAnimationCurveTest, LinearTimingFunction)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ curve->add(CompositorFloatKeyframe(0, 0),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+ curve->add(CompositorFloatKeyframe(1, 1),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+
+ for (int i = 0; i <= 4; ++i) {
+ const double time = i * 0.25;
+ EXPECT_FLOAT_EQ(time, curve->getValue(time));
+ }
+}
+
+// Tests that an ease in timing function works as expected.
+TEST(WebFloatAnimationCurveTest, EaseInTimingFunction)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ curve->add(CompositorFloatKeyframe(0, 0),
+ CompositorAnimationCurve::TimingFunctionTypeEaseIn);
+ curve->add(CompositorFloatKeyframe(1, 1),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+
+ scoped_ptr<cc::TimingFunction> timingFunction(
+ cc::EaseInTimingFunction::Create());
+ for (int i = 0; i <= 4; ++i) {
+ const double time = i * 0.25;
+ EXPECT_FLOAT_EQ(timingFunction->GetValue(time), curve->getValue(time));
+ }
+}
+
+// Tests that an ease in timing function works as expected.
+TEST(WebFloatAnimationCurveTest, EaseOutTimingFunction)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ curve->add(CompositorFloatKeyframe(0, 0),
+ CompositorAnimationCurve::TimingFunctionTypeEaseOut);
+ curve->add(CompositorFloatKeyframe(1, 1),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+
+ scoped_ptr<cc::TimingFunction> timingFunction(
+ cc::EaseOutTimingFunction::Create());
+ for (int i = 0; i <= 4; ++i) {
+ const double time = i * 0.25;
+ EXPECT_FLOAT_EQ(timingFunction->GetValue(time), curve->getValue(time));
+ }
+}
+
+// Tests that an ease in timing function works as expected.
+TEST(WebFloatAnimationCurveTest, EaseInOutTimingFunction)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ curve->add(CompositorFloatKeyframe(0, 0),
+ CompositorAnimationCurve::TimingFunctionTypeEaseInOut);
+ curve->add(CompositorFloatKeyframe(1, 1),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+
+ scoped_ptr<cc::TimingFunction> timingFunction(
+ cc::EaseInOutTimingFunction::Create());
+ for (int i = 0; i <= 4; ++i) {
+ const double time = i * 0.25;
+ EXPECT_FLOAT_EQ(timingFunction->GetValue(time), curve->getValue(time));
+ }
+}
+
+// Tests that an ease in timing function works as expected.
+TEST(WebFloatAnimationCurveTest, CustomBezierTimingFunction)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ double x1 = 0.3;
+ double y1 = 0.2;
+ double x2 = 0.8;
+ double y2 = 0.7;
+ curve->add(CompositorFloatKeyframe(0, 0), x1, y1, x2, y2);
+ curve->add(CompositorFloatKeyframe(1, 1),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+
+ scoped_ptr<cc::TimingFunction> timingFunction(
+ cc::CubicBezierTimingFunction::Create(x1, y1, x2, y2));
+ for (int i = 0; i <= 4; ++i) {
+ const double time = i * 0.25;
+ EXPECT_FLOAT_EQ(timingFunction->GetValue(time), curve->getValue(time));
+ }
+}
+
+// Tests that the default timing function is indeed ease.
+TEST(WebFloatAnimationCurveTest, DefaultTimingFunction)
+{
+ scoped_ptr<CompositorFloatAnimationCurve> curve(new CompositorFloatAnimationCurve);
+ curve->add(CompositorFloatKeyframe(0, 0));
+ curve->add(CompositorFloatKeyframe(1, 1),
+ CompositorAnimationCurve::TimingFunctionTypeLinear);
+
+ scoped_ptr<cc::TimingFunction> timingFunction(
+ cc::EaseTimingFunction::Create());
+ for (int i = 0; i <= 4; ++i) {
+ const double time = i * 0.25;
+ EXPECT_FLOAT_EQ(timingFunction->GetValue(time), curve->getValue(time));
+ }
+}
+
+} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698