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

Unified Diff: cc/blink/web_float_animation_curve_unittest.cc

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
« no previous file with comments | « cc/blink/web_float_animation_curve_impl.cc ('k') | cc/blink/web_layer_impl.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/blink/web_float_animation_curve_unittest.cc
diff --git a/cc/blink/web_float_animation_curve_unittest.cc b/cc/blink/web_float_animation_curve_unittest.cc
deleted file mode 100644
index 14afdd07830b67df185adc0502c815bc9d9b1f69..0000000000000000000000000000000000000000
--- a/cc/blink/web_float_animation_curve_unittest.cc
+++ /dev/null
@@ -1,234 +0,0 @@
-// 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 "base/memory/scoped_ptr.h"
-#include "cc/animation/timing_function.h"
-#include "cc/blink/web_float_animation_curve_impl.h"
-#include "testing/gtest/include/gtest/gtest.h"
-
-using blink::WebCompositorAnimationCurve;
-using blink::WebFloatAnimationCurve;
-using blink::WebFloatKeyframe;
-
-namespace cc_blink {
-namespace {
-
-// Tests that a float animation with one keyframe works as expected.
-TEST(WebFloatAnimationCurveTest, OneFloatKeyframe) {
- scoped_ptr<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- curve->add(WebFloatKeyframe(0, 2),
- WebCompositorAnimationCurve::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<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- curve->add(WebFloatKeyframe(0, 2),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
- curve->add(WebFloatKeyframe(1, 4),
- WebCompositorAnimationCurve::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<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- curve->add(WebFloatKeyframe(0, 2),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
- curve->add(WebFloatKeyframe(1, 4),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
- curve->add(WebFloatKeyframe(2, 8),
- WebCompositorAnimationCurve::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<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- curve->add(WebFloatKeyframe(0, 4),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
- curve->add(WebFloatKeyframe(1, 4),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
- curve->add(WebFloatKeyframe(1, 6),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
- curve->add(WebFloatKeyframe(2, 6),
- WebCompositorAnimationCurve::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<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- curve->add(WebFloatKeyframe(2, 8),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
- curve->add(WebFloatKeyframe(0, 2),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
- curve->add(WebFloatKeyframe(1, 4),
- WebCompositorAnimationCurve::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<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- curve->add(WebFloatKeyframe(0, 0), 0.25, 0, 0.75, 1);
- curve->add(WebFloatKeyframe(1, 1),
- WebCompositorAnimationCurve::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<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- curve->add(WebFloatKeyframe(0, 0),
- WebCompositorAnimationCurve::TimingFunctionTypeEase);
- curve->add(WebFloatKeyframe(1, 1),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
-
- scoped_ptr<cc::TimingFunction> timing_function(
- cc::EaseTimingFunction::Create());
- for (int i = 0; i <= 4; ++i) {
- const double time = i * 0.25;
- EXPECT_FLOAT_EQ(timing_function->GetValue(time), curve->getValue(time));
- }
-}
-
-// Tests using a linear timing function.
-TEST(WebFloatAnimationCurveTest, LinearTimingFunction) {
- scoped_ptr<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- curve->add(WebFloatKeyframe(0, 0),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
- curve->add(WebFloatKeyframe(1, 1),
- WebCompositorAnimationCurve::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<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- curve->add(WebFloatKeyframe(0, 0),
- WebCompositorAnimationCurve::TimingFunctionTypeEaseIn);
- curve->add(WebFloatKeyframe(1, 1),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
-
- scoped_ptr<cc::TimingFunction> timing_function(
- cc::EaseInTimingFunction::Create());
- for (int i = 0; i <= 4; ++i) {
- const double time = i * 0.25;
- EXPECT_FLOAT_EQ(timing_function->GetValue(time), curve->getValue(time));
- }
-}
-
-// Tests that an ease in timing function works as expected.
-TEST(WebFloatAnimationCurveTest, EaseOutTimingFunction) {
- scoped_ptr<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- curve->add(WebFloatKeyframe(0, 0),
- WebCompositorAnimationCurve::TimingFunctionTypeEaseOut);
- curve->add(WebFloatKeyframe(1, 1),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
-
- scoped_ptr<cc::TimingFunction> timing_function(
- cc::EaseOutTimingFunction::Create());
- for (int i = 0; i <= 4; ++i) {
- const double time = i * 0.25;
- EXPECT_FLOAT_EQ(timing_function->GetValue(time), curve->getValue(time));
- }
-}
-
-// Tests that an ease in timing function works as expected.
-TEST(WebFloatAnimationCurveTest, EaseInOutTimingFunction) {
- scoped_ptr<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- curve->add(WebFloatKeyframe(0, 0),
- WebCompositorAnimationCurve::TimingFunctionTypeEaseInOut);
- curve->add(WebFloatKeyframe(1, 1),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
-
- scoped_ptr<cc::TimingFunction> timing_function(
- cc::EaseInOutTimingFunction::Create());
- for (int i = 0; i <= 4; ++i) {
- const double time = i * 0.25;
- EXPECT_FLOAT_EQ(timing_function->GetValue(time), curve->getValue(time));
- }
-}
-
-// Tests that an ease in timing function works as expected.
-TEST(WebFloatAnimationCurveTest, CustomBezierTimingFunction) {
- scoped_ptr<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- double x1 = 0.3;
- double y1 = 0.2;
- double x2 = 0.8;
- double y2 = 0.7;
- curve->add(WebFloatKeyframe(0, 0), x1, y1, x2, y2);
- curve->add(WebFloatKeyframe(1, 1),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
-
- scoped_ptr<cc::TimingFunction> timing_function(
- cc::CubicBezierTimingFunction::Create(x1, y1, x2, y2));
- for (int i = 0; i <= 4; ++i) {
- const double time = i * 0.25;
- EXPECT_FLOAT_EQ(timing_function->GetValue(time), curve->getValue(time));
- }
-}
-
-// Tests that the default timing function is indeed ease.
-TEST(WebFloatAnimationCurveTest, DefaultTimingFunction) {
- scoped_ptr<WebFloatAnimationCurve> curve(new WebFloatAnimationCurveImpl);
- curve->add(WebFloatKeyframe(0, 0));
- curve->add(WebFloatKeyframe(1, 1),
- WebCompositorAnimationCurve::TimingFunctionTypeLinear);
-
- scoped_ptr<cc::TimingFunction> timing_function(
- cc::EaseTimingFunction::Create());
- for (int i = 0; i <= 4; ++i) {
- const double time = i * 0.25;
- EXPECT_FLOAT_EQ(timing_function->GetValue(time), curve->getValue(time));
- }
-}
-
-} // namespace
-} // namespace cc_blink
« no previous file with comments | « cc/blink/web_float_animation_curve_impl.cc ('k') | cc/blink/web_layer_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698