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

Side by Side Diff: Source/core/platform/animation/TimingFunctionTest.cpp

Issue 54743002: Adding a reverse function to the TimingFunctions and tests to prove it works. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@timing-function-helper
Patch Set: Created 7 years, 1 month 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 unified diff | Download patch
OLDNEW
(Empty)
1 /*
2 * Copyright (c) 2013, Google Inc. All rights reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met:
7 *
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above
11 * copyright notice, this list of conditions and the following disclaimer
12 * in the documentation and/or other materials provided with the
13 * distribution.
14 * * Neither the name of Google Inc. nor the names of its
15 * contributors may be used to endorse or promote products derived from
16 * this software without specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
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.
29 */
30
31 #include "config.h"
32
33 #include "core/platform/animation/TimingFunction.h"
34
35 #include "core/platform/animation/TimingFunctionTestHelper.h"
36 #include <gmock/gmock.h>
37 #include <gtest/gtest.h>
38 #include <sstream>
39 #include <string>
40
41
42 using namespace WebCore;
43
44 namespace {
45
46 class TimingFunctionTest : public ::testing::Test {
47 protected:
48 virtual void SetUp()
49 {
50 // Needed for ChainedTimingFunction support
51 RuntimeEnabledFeatures::setWebAnimationsEnabled(true);
52 }
53
54 };
55
56 TEST_F(TimingFunctionTest, LinearOperatorEq)
57 {
58 RefPtr<TimingFunction> linearTiming1 = LinearTimingFunction::create();
59 RefPtr<TimingFunction> linearTiming2 = LinearTimingFunction::create();
60 EXPECT_REFV_EQ(linearTiming1, linearTiming2);
61 }
62
63 TEST_F(TimingFunctionTest, LinearReverse)
64 {
65 RefPtr<TimingFunction> linearTiming = LinearTimingFunction::create();
66 EXPECT_REFV_EQ(linearTiming, linearTiming->reverse());
67 }
68
69 TEST_F(TimingFunctionTest, CubicOperatorEq)
70 {
71 RefPtr<TimingFunction> cubicEaseInTiming1 = CubicBezierTimingFunction::prese t(CubicBezierTimingFunction::EaseIn);
72 RefPtr<TimingFunction> cubicEaseInTiming2 = CubicBezierTimingFunction::prese t(CubicBezierTimingFunction::EaseIn);
73 EXPECT_REFV_EQ(cubicEaseInTiming1, cubicEaseInTiming2);
74
75 RefPtr<TimingFunction> cubicEaseOutTiming1 = CubicBezierTimingFunction::pres et(CubicBezierTimingFunction::EaseOut);
76 RefPtr<TimingFunction> cubicEaseOutTiming2 = CubicBezierTimingFunction::pres et(CubicBezierTimingFunction::EaseOut);
77 EXPECT_REFV_EQ(cubicEaseOutTiming1, cubicEaseOutTiming2);
78
79 RefPtr<TimingFunction> cubicEaseInOutTiming1 = CubicBezierTimingFunction::pr eset(CubicBezierTimingFunction::EaseInOut);
80 RefPtr<TimingFunction> cubicEaseInOutTiming2 = CubicBezierTimingFunction::pr eset(CubicBezierTimingFunction::EaseInOut);
81 EXPECT_REFV_EQ(cubicEaseInOutTiming1, cubicEaseInOutTiming2);
82
83 RefPtr<TimingFunction> cubicCustomTiming1 = CubicBezierTimingFunction::creat e(0.17, 0.67, 1, -1.73);
84 RefPtr<TimingFunction> cubicCustomTiming2 = CubicBezierTimingFunction::creat e(0.17, 0.67, 1, -1.73);
85 EXPECT_REFV_EQ(cubicCustomTiming1, cubicCustomTiming2);
86
87 Vector<RefPtr<TimingFunction>> v;
88 v.append(cubicEaseInTiming1);
89 v.append(cubicEaseOutTiming1);
90 v.append(cubicEaseInOutTiming1);
91 v.append(cubicCustomTiming1);
92
93 for (size_t i == v.begin(); i != v.end(); ++i) {
94 for (size_t j == v.begin(); j != v.end(); ++j) {
95 if (i == j)
96 continue;
97 EXPECT_REFV_NE(v[i], v[j]);
98 }
99 }
100 }
101
102 TEST_F(TimingFunctionTest, CubicCreate)
103 {
104 EXPECT_REFV_EQ(CubicBezierTimingFunction::preset(Ease), 0.25, 0.1, 0.25, 1.0 );
105 EXPECT_REFV_EQ(CubicBezierTimingFunction::preset(EaseIn), 0.42, 0.0, 1.0, 1. 0);
106 EXPECT_REFV_EQ(CubicBezierTimingFunction::preset(EaseOut), 0.0, 0.0, 0.58, 1 .0);
107 EXPECT_REFV_EQ(CubicBezierTimingFunction::preset(EaseInOut), 0.42, 0.0, 0.58 , 1.0);
108 }
109
110 TEST_F(TimingFunctionTest, CubicReverse)
111 {
112 RefPtr<TimingFunction> cubicEaseInTiming = CubicBezierTimingFunction::preset (CubicBezierTimingFunction::EaseIn);
113 RefPtr<TimingFunction> cubicEaseOutTiming = CubicBezierTimingFunction::prese t(CubicBezierTimingFunction::EaseOut);
114 RefPtr<TimingFunction> cubicEaseInOutTiming = CubicBezierTimingFunction::pre set(CubicBezierTimingFunction::EaseInOut);
115
116 EXPECT_REFV_EQ(cubicEaseOutTiming, cubicEaseInTiming->reverse());
117 EXPECT_REFV_EQ(cubicEaseInTiming, cubicEaseOutTiming->reverse());
118 EXPECT_REFV_EQ(cubicEaseInOutTiming, cubicEaseInOutTiming->reverse());
119
120 RefPtr<TimingFunction> cubicCustomTiming = CubicBezierTimingFunction::create (0.17, 0.67, 1, -1.73);
121 RefPtr<TimingFunction> cubicCustomTimingReversed = CubicBezierTimingFunction ::create(0.17, 0.67, 1, -1.73);
122 EXPECT_REFV_EQ(cubicCustomTimingReversed, cubicCustomTiming->reverse());
123 }
124
125 TEST_F(TimingFunctionTest, StepReverse)
126 {
127 RefPtr<TimingFunction> stepTimingStart = StepsTimingFunction::preset(StepsTi mingFunction::Start);
128 RefPtr<TimingFunction> stepTimingEnd = StepsTimingFunction::preset(StepsTimi ngFunction::End);
129
130 EXPECT_REFV_EQ(stepTimingEnd, stepTimingStart->reverse());
131 EXPECT_REFV_EQ(stepTimingStart, stepTimingEnd->reverse());
132
133 RefPtr<TimingFunction> stepTimingCustom = StepsTimingFunction::create(5, fal se);
134 RefPtr<TimingFunction> stepTimingCustomReversed = StepsTimingFunction::creat e(5, true);
135 EXPECT_REFV_EQ(stepTimingCustomReversed, stepTimingCustom);
136 }
137
138 TEST_F(TimingFunctionTest, ChainedEq)
139 {
140 // Single item in chain
141 RefPtr<TimingFunction> linearTiming1 = LinearTimingFunction::create();
142 RefPtr<TimingFunction> linearTiming2 = LinearTimingFunction::create();
143
144 RefPtr<ChainedTimingFunction> chainedLinearSingle1 = ChainedTimingFunction:: create();
145 chainedLinearSingle1->appendSegment(1.0, linearTiming1.get());
146
147 RefPtr<ChainedTimingFunction> chainedLinearSingle2 = ChainedTimingFunction:: create();
148 chainedLinearSingle2->appendSegment(1.0, linearTiming1.get());
149
150 RefPtr<ChainedTimingFunction> chainedLinearSingle3 = ChainedTimingFunction:: create();
151 chainedLinearSingle3->appendSegment(1.0, linearTiming3.get());
152
153 EXPECT_REFV_EQ(chainedLinearSingle1, chainedLinearSingle2);
154 EXPECT_REFV_EQ(chainedLinearSingle2, chainedLinearSingle3);
155 EXPECT_REFV_EQ(chainedLinearSingle1, chainedLinearSingle3);
156
157 RefPtr<TimingFunction> cubicTiming1 = CubicBezierTimingFunction::preset(Cubi cBezierTimingFunction::EaseIn);
158 RefPtr<TimingFunction> cubicTiming2 = CubicBezierTimingFunction::preset(Cubi cBezierTimingFunction::EaseIn);
159
160 RefPtr<ChainedTimingFunction> chainedCubicSingle1 = ChainedTimingFunction::c reate();
161 chainedCubicSingle1->appendSegment(1.0, cubicTiming1.get());
162
163 EXPECT_REFV_NE(chainedLinearSingle1, chainedCubicSingle1); // Different cont ained timing function
164
165 // Multiple items in chain
166 RefPtr<ChainedTimingFunction> chainedMixed1 = ChainedTimingFunction::create( );
167 chainedMixed1->appendSegment(0.25, chainedLinearSingle1.get());
168 chainedMixed1->appendSegment(1.0, cubicTiming1.get());
169
170 RefPtr<ChainedTimingFunction> chainedMixed2 = ChainedTimingFunction::create( );
171 chainedMixed2->appendSegment(0.25, chainedLinearSingle1.get());
172 chainedMixed2->appendSegment(1.0, cubicTiming1.get());
173
174 RefPtr<ChainedTimingFunction> chainedMixed3 = ChainedTimingFunction::create( );
175 chainedMixed3->appendSegment(0.25, chainedLinearSingle2.get());
176 chainedMixed3->appendSegment(1.0, cubicTiming2.get());
177
178 EXPECT_REFV_EQ(chainedMixed1, chainedMixed2);
179 EXPECT_REFV_EQ(chainedMixed1, chainedMixed3);
180 EXPECT_REFV_NE(chainedMixed1, chainedCubicSingle1);
181 EXPECT_REFV_NE(chainedMixed1, chainedLinearSingle1);
182
183 RefPtr<ChainedTimingFunction> chainedMixed4 = ChainedTimingFunction::create( );
184 chainedMixed4->appendSegment(0.20, chainedLinearSingle1.get());
185 chainedMixed4->appendSegment(1.0, cubicEaseInTiming1.get());
186 EXPECT_REFV_NE(chainedMixed1, chainedMixed4); // Different offsets
187 }
188
189 TEST_F(TimingFunctionTest, ChainedReverse)
190 {
191 RefPtr<TimingFunction> linearTiming = LinearTimingFunction::create();
192 RefPtr<ChainedTimingFunction> chainedLinearSingle = ChainedTimingFunction::c reate();
193 chainedLinearSingle->appendSegment(1.0, linearTiming.get());
194 EXPECT_REFV_EQ(chainedLinearSingle, chainedLinearSingle->reverse());
195
196 RefPtr<TimingFunction> cubicEaseInTiming = CubicBezierTimingFunction::preset (CubicBezierTimingFunction::EaseIn);
197 RefPtr<TimingFunction> cubicEaseOutTiming = CubicBezierTimingFunction::prese t(CubicBezierTimingFunction::EaseOut);
198
199 RefPtr<ChainedTimingFunction> chainedMixed = ChainedTimingFunction::create() ;
200 chainedMixed->appendSegment(0.75, chainedLinearSingle.get());
201 chainedMixed->appendSegment(1.0, cubicEaseInTiming.get());
202
203 RefPtr<ChainedTimingFunction> chainedMixedReversed = ChainedTimingFunction:: create();
204 chainedMixed->appendSegment(0.25, cubicEaseOutTiming.get());
205 chainedMixed->appendSegment(1.0, chainedLinearSingle.get());
206
207 EXPECT_REFV_EQ(chainedMixed, chainedMixedReversed);
208 }
209
210 } // namespace
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698