using NUnit.Framework; using FluentAssertions; using MoonTools; using System; namespace Test { public static class EasingTests { public static void CheckFloatArguments(Func easingNormalizedFunction, Func easingRangeFunction) { Action invalidTime = () => easingNormalizedFunction(1.5f); invalidTime.Should().Throw(); invalidTime = () => easingRangeFunction(7, 2, 6); invalidTime.Should().Throw(); } public static void CheckDoubleArguments(Func easingNormalizedFunction, Func easingRangeFunction) { Action invalidTime = () => easingNormalizedFunction(1.5); invalidTime.Should().Throw(); invalidTime = () => easingRangeFunction(7, 2, 6); invalidTime.Should().Throw(); } public class FloatTests { [Test] public void Linear() { Easing.Linear(0.25f).Should().Be(0.25f); Easing.Linear(0.5f).Should().Be(0.5f); Easing.Linear(0.75f).Should().Be(0.75f); Easing.Linear(3, 2, 6).Should().Be(3f); Easing.Linear(4, 2, 6).Should().Be(4f); Easing.Linear(5, 2, 6).Should().Be(5f); CheckFloatArguments(Easing.Linear, Easing.Linear); } [Test] public void InQuad() { Easing.InQuad(0.25f).Should().Be(0.0625f); Easing.InQuad(0.5f).Should().Be(0.25f); Easing.InQuad(0.75f).Should().Be(0.5625f); Easing.InQuad(3, 2, 6).Should().Be(2.25f); Easing.InQuad(4, 2, 6).Should().Be(3f); Easing.InQuad(5, 2, 6).Should().Be(4.25f); CheckFloatArguments(Easing.InQuad, Easing.InQuad); } [Test] public void OutQuad() { Easing.OutQuad(0.25f).Should().Be(0.4375f); Easing.OutQuad(0.5f).Should().Be(0.75f); Easing.OutQuad(0.75f).Should().Be(0.9375f); Easing.OutQuad(3, 2, 6).Should().Be(3.75f); Easing.OutQuad(4, 2, 6).Should().Be(5f); Easing.OutQuad(5, 2, 6).Should().Be(5.75f); CheckFloatArguments(Easing.OutQuad, Easing.OutQuad); } [Test] public void InOutQuad() { Easing.InOutQuad(0.25f).Should().Be(0.125f); Easing.InOutQuad(0.5f).Should().Be(0.5f); Easing.InOutQuad(0.75f).Should().Be(0.875f); Easing.InOutQuad(3, 2, 6).Should().Be(2.5f); Easing.InOutQuad(4, 2, 6).Should().Be(4f); Easing.InOutQuad(5, 2, 6).Should().Be(5.5f); CheckFloatArguments(Easing.InOutQuad, Easing.InOutQuad); } [Test] public void OutInQuad() { Easing.OutInQuad(0.25f).Should().Be(0.375f); Easing.OutInQuad(0.5f).Should().Be(0.5f); Easing.OutInQuad(0.75f).Should().Be(0.625f); Easing.OutInQuad(3, 2, 6).Should().Be(3.5f); Easing.OutInQuad(4, 2, 6).Should().Be(4f); Easing.OutInQuad(5, 2, 6).Should().Be(4.5f); CheckFloatArguments(Easing.OutInQuad, Easing.OutInQuad); } [Test] public void InCubic() { Easing.InCubic(0.25f).Should().Be(0.015625f); Easing.InCubic(0.5f).Should().Be(0.125f); Easing.InCubic(0.75f).Should().Be(0.421875f); Easing.InCubic(3, 2, 6).Should().Be(2.0625f); Easing.InCubic(4, 2, 6).Should().Be(2.5f); Easing.InCubic(5, 2, 6).Should().Be(3.6875f); CheckFloatArguments(Easing.InCubic, Easing.InCubic); } [Test] public void OutCubic() { Easing.OutCubic(0.25f).Should().Be(0.578125f); Easing.OutCubic(0.5f).Should().Be(0.875f); Easing.OutCubic(0.75f).Should().Be(0.984375f); Easing.OutCubic(3, 2, 6).Should().Be(4.3125f); Easing.OutCubic(4, 2, 6).Should().Be(5.5f); Easing.OutCubic(5, 2, 6).Should().Be(5.9375f); CheckFloatArguments(Easing.OutCubic, Easing.OutCubic); } [Test] public void InOutCubic() { Easing.InOutCubic(0.25f).Should().Be(0.0625f); Easing.InOutCubic(0.5f).Should().Be(0.5f); Easing.InOutCubic(0.75f).Should().Be(0.9375f); Easing.InOutCubic(3, 2, 6).Should().Be(2.25f); Easing.InOutCubic(4, 2, 6).Should().Be(4f); Easing.InOutCubic(5, 2, 6).Should().Be(5.75f); CheckFloatArguments(Easing.InOutCubic, Easing.InOutCubic); } [Test] public void OutInCubic() { Easing.OutInCubic(0.25f).Should().Be(0.4375f); Easing.OutInCubic(0.5f).Should().Be(0.5f); Easing.OutInCubic(0.75f).Should().Be(0.5625f); Easing.OutInCubic(3, 2, 6).Should().Be(3.75f); Easing.OutInCubic(4, 2, 6).Should().Be(4f); Easing.OutInCubic(5, 2, 6).Should().Be(4.25f); CheckFloatArguments(Easing.OutInCubic, Easing.OutInCubic); } [Test] public void InQuartic() { Easing.InQuart(0.25f).Should().Be(0.00390625f); Easing.InQuart(0.5f).Should().Be(0.0625f); Easing.InQuart(0.75f).Should().Be(0.31640625f); Easing.InQuart(3, 2, 6).Should().Be(2.015625f); Easing.InQuart(4, 2, 6).Should().Be(2.25f); Easing.InQuart(5, 2, 6).Should().Be(3.265625f); CheckFloatArguments(Easing.InQuart, Easing.InQuart); } [Test] public void OutQuartic() { Easing.OutQuart(0.25f).Should().Be(0.68359375f); Easing.OutQuart(0.5f).Should().Be(0.9375f); Easing.OutQuart(0.75f).Should().Be(0.99609375f); Easing.OutQuart(3, 2, 6).Should().Be(4.734375f); Easing.OutQuart(4, 2, 6).Should().Be(5.75f); Easing.OutQuart(5, 2, 6).Should().Be(5.984375f); CheckFloatArguments(Easing.OutQuart, Easing.OutQuart); } [Test] public void InOutQuartic() { Easing.InOutQuart(0.25f).Should().Be(0.03125f); Easing.InOutQuart(0.5f).Should().Be(0.5f); Easing.InOutQuart(0.75f).Should().Be(0.96875f); Easing.InOutQuart(3, 2, 6).Should().Be(2.125f); Easing.InOutQuart(4, 2, 6).Should().Be(4f); Easing.InOutQuart(5, 2, 6).Should().Be(5.875f); CheckFloatArguments(Easing.InOutQuart, Easing.InOutQuart); } [Test] public void OutInQuartic() { Easing.OutInQuart(0.25f).Should().Be(0.46875f); Easing.OutInQuart(0.5f).Should().Be(0.5f); Easing.OutInQuart(0.75f).Should().Be(0.53125f); Easing.OutInQuart(3, 2, 6).Should().Be(3.875f); Easing.OutInQuart(4, 2, 6).Should().Be(4f); Easing.OutInQuart(5, 2, 6).Should().Be(4.125f); CheckFloatArguments(Easing.OutInQuart, Easing.OutInQuart); } [Test] public void InQuintic() { Easing.InQuint(0.25f).Should().Be(0.0009765625f); Easing.InQuint(0.5f).Should().Be(0.03125f); Easing.InQuint(0.75f).Should().Be(0.2373046875f); Easing.InQuint(3, 2, 6).Should().Be(2.00390625f); Easing.InQuint(4, 2, 6).Should().Be(2.125f); Easing.InQuint(5, 2, 6).Should().Be(2.94921875f); CheckFloatArguments(Easing.InQuint, Easing.InQuint); } [Test] public void OutQuintic() { Easing.OutQuint(0.25f).Should().Be(0.7626953125f); Easing.OutQuint(0.5f).Should().Be(0.96875f); Easing.OutQuint(0.75f).Should().Be(0.9990234375f); Easing.OutQuint(3, 2, 6).Should().Be(5.05078125f); Easing.OutQuint(4, 2, 6).Should().Be(5.875f); Easing.OutQuint(5, 2, 6).Should().Be(5.99609375f); CheckFloatArguments(Easing.OutQuint, Easing.OutQuint); } [Test] public void InOutQuintic() { Easing.InOutQuint(0.25f).Should().Be(0.015625f); Easing.InOutQuint(0.5f).Should().Be(0.5f); Easing.InOutQuint(0.75f).Should().Be(0.984375f); Easing.InOutQuint(3, 2, 6).Should().Be(2.0625f); Easing.InOutQuint(4, 2, 6).Should().Be(4f); Easing.InOutQuint(5, 2, 6).Should().Be(5.9375f); CheckFloatArguments(Easing.InOutQuint, Easing.InOutQuint); } [Test] public void OutInQuintic() { Easing.OutInQuint(0.25f).Should().Be(0.484375f); Easing.OutInQuint(0.5f).Should().Be(0.5f); Easing.OutInQuint(0.75f).Should().Be(0.515625f); Easing.OutInQuint(3, 2, 6).Should().Be(3.9375f); Easing.OutInQuint(4, 2, 6).Should().Be(4f); Easing.OutInQuint(5, 2, 6).Should().Be(4.0625f); CheckFloatArguments(Easing.OutInQuint, Easing.OutInQuint); } [Test] public void InSine() { Easing.InSine(0.25f).Should().BeApproximately(0.076120467488713f, 0.0001f); Easing.InSine(0.5f).Should().BeApproximately(0.29289321881345f, 0.0001f); Easing.InSine(0.75f).Should().BeApproximately(0.61731656763491f, 0.0001f); Easing.InSine(3f, 2, 6).Should().BeApproximately(2.304481869955f, 0.0001f); Easing.InSine(4f, 2, 6).Should().BeApproximately(3.17157287525f, 0.0001f); Easing.InSine(5f, 2, 6).Should().BeApproximately(4.46926627054f, 0.0001f); Action invalidTime = () => Easing.InSine(1.5f); invalidTime.Should().Throw(); invalidTime = () => Easing.InSine(7f, 2, 6); invalidTime.Should().Throw(); } [Test] public void OutSine() { Easing.OutSine(0.25f).Should().BeApproximately(0.38268343236509f, 0.0001f); Easing.OutSine(0.5f).Should().BeApproximately(0.70710678118655f, 0.0001f); Easing.OutSine(0.75f).Should().BeApproximately(0.92387953251129f, 0.0001f); Easing.OutSine(3f, 2, 6).Should().BeApproximately(3.53073372946f, 0.0001f); Easing.OutSine(4f, 2, 6).Should().BeApproximately(4.82842712475f, 0.0001f); Easing.OutSine(5f, 2, 6).Should().BeApproximately(5.69551813005f, 0.0001f); Action invalidTime = () => Easing.OutSine(1.5f); invalidTime.Should().Throw(); invalidTime = () => Easing.OutSine(7f, 2, 6); invalidTime.Should().Throw(); } [Test] public void InOutSine() { Easing.InOutSine(0.25f).Should().BeApproximately(0.14644660940673f, 0.0001f); Easing.InOutSine(0.5f).Should().BeApproximately(0.5f, 0.0001f); Easing.InOutSine(0.75f).Should().BeApproximately(0.85355339059327f, 0.0001f); Easing.InOutSine(3f, 2, 6).Should().BeApproximately(2.585786437627f, 0.0001f); Easing.InOutSine(4f, 2, 6).Should().BeApproximately(4f, 0.0001); Easing.InOutSine(5f, 2, 6).Should().BeApproximately(5.41421356237f, 0.0001f); Action invalidTime = () => Easing.OutSine(1.5f); invalidTime.Should().Throw(); invalidTime = () => Easing.OutSine(7f, 2, 6); invalidTime.Should().Throw(); } [Test] public void OutInSine() { Easing.OutInSine(0.25f).Should().BeApproximately(0.35355339059327f, 0.0001f); Easing.OutInSine(0.5f).Should().BeApproximately(0.5f, 0.0001f); Easing.OutInSine(0.75f).Should().BeApproximately(0.64644660940673f, 0.0001f); Easing.OutInSine(3f, 2, 6).Should().BeApproximately(3.41421356237f, 0.0001f); Easing.OutInSine(4f, 2, 6).Should().BeApproximately(4f, 0.0001f); Easing.OutInSine(5f, 2, 6).Should().BeApproximately(4.58578643763f, 0.0001f); Action invalidTime = () => Easing.OutSine(1.5f); invalidTime.Should().Throw(); invalidTime = () => Easing.OutSine(7f, 2, 6); invalidTime.Should().Throw(); } [Test] public void InExpo() { Easing.InExpo(0.25f).Should().BeApproximately(0.0045242717280199f, 0.0001f); Easing.InExpo(0.5f).Should().BeApproximately(0.03025f, 0.0001f); Easing.InExpo(0.75f).Should().BeApproximately(0.17577669529664f, 0.0001f); Easing.InExpo(3f, 2, 6).Should().BeApproximately(2.0180970869121f, 0.0001f); Easing.InExpo(4f, 2, 6).Should().BeApproximately(2.121f, 0.0001f); Easing.InExpo(5f, 2, 6).Should().BeApproximately(2.703106781187f, 0.0001f); Action invalidTime = () => Easing.InExpo(1.5f); invalidTime.Should().Throw(); invalidTime = () => Easing.InExpo(7f, 2, 6); invalidTime.Should().Throw(); } [Test] public void OutExpo() { Easing.OutExpo(0.25f).Should().BeApproximately(0.82404652800807f, 0.0001f); Easing.OutExpo(0.5f).Should().BeApproximately(0.96971875f, 0.0001f); Easing.OutExpo(0.75f).Should().BeApproximately(0.99547020400025f, 0.0001f); Easing.OutExpo(3f, 2, 6).Should().BeApproximately(5.29618611203f, 0.0001f); Easing.OutExpo(4f, 2, 6).Should().BeApproximately(5.878875f, 0.0001f); Easing.OutExpo(5f, 2, 6).Should().BeApproximately(5.981880816f, 0.0001f); Action invalidTime = () => Easing.OutExpo(1.5f); invalidTime.Should().Throw(); invalidTime = () => Easing.OutExpo(7f, 2, 6); invalidTime.Should().Throw(); } [Test] public void InOutExpo() { Easing.InOutExpo(0.25f).Should().BeApproximately(0.015125f, 0.001f); Easing.InOutExpo(0.5f).Should().BeApproximately(0.5f, 0.001f); Easing.InOutExpo(0.75f).Should().BeApproximately(0.9848671875f, 0.001f); Easing.InOutExpo(3f, 2, 6).Should().BeApproximately(2.0605f, 0.001f); Easing.InOutExpo(4f, 2, 6).Should().BeApproximately(4f, 0.001f); Easing.InOutExpo(5f, 2, 6).Should().BeApproximately(5.93946875f, 0.001f); Action invalidTime = () => Easing.InOutExpo(1.5f); invalidTime.Should().Throw(); invalidTime = () => Easing.InOutExpo(7f, 2, 6); invalidTime.Should().Throw(); } [Test] public void OutInExpo() { Easing.OutInExpo(0.25f).Should().BeApproximately(0.484859375f, 0.001f); Easing.OutInExpo(0.5f).Should().BeApproximately(0.5f, 0.001f); Easing.OutInExpo(0.75f).Should().BeApproximately(0.515125f, 0.001f); Easing.OutInExpo(3f, 2, 6).Should().BeApproximately(3.9394375f, 0.001f); Easing.OutInExpo(4f, 2, 6).Should().BeApproximately(4f, 0.001f); Easing.OutInExpo(5f, 2, 6).Should().BeApproximately(4.0605f, 0.001f); Action invalidTime = () => Easing.OutInExpo(1.5f); invalidTime.Should().Throw(); invalidTime = () => Easing.OutInExpo(7f, 2, 6); invalidTime.Should().Throw(); } [Test] public void InCircular() { Easing.InCirc(0.25f).Should().BeApproximately(0.031754163448146f, 0.001f); Easing.InCirc(0.5f).Should().BeApproximately(0.13397459621556f, 0.001f); Easing.InCirc(0.75f).Should().BeApproximately(0.33856217223385f, 0.001f); Easing.InCirc(3f, 2, 6).Should().BeApproximately(2.127016653793f, 0.001f); Easing.InCirc(4f, 2, 6).Should().BeApproximately(2.535898384862f, 0.001f); Easing.InCirc(5f, 2, 6).Should().BeApproximately(3.35424868894f, 0.001f); Action invalidTime = () => Easing.InCirc(1.5f); invalidTime.Should().Throw(); invalidTime = () => Easing.InCirc(7f, 2, 6); invalidTime.Should().Throw(); } [Test] public void OutCircular() { Easing.OutCirc(0.25f).Should().BeApproximately(0.66143782776615f, 0.001f); Easing.OutCirc(0.5f).Should().BeApproximately(0.86602540378444f, 0.001f); Easing.OutCirc(0.75f).Should().BeApproximately(0.96824583655185f, 0.001f); Easing.OutCirc(3f, 2, 6).Should().BeApproximately(4.64575131107f, 0.001f); Easing.OutCirc(4f, 2, 6).Should().BeApproximately(5.46410161514f, 0.001f); Easing.OutCirc(5f, 2, 6).Should().BeApproximately(5.87298334621f, 0.001f); Action invalidTime = () => Easing.OutCirc(1.5f); invalidTime.Should().Throw(); invalidTime = () => Easing.OutCirc(7f, 2, 6); invalidTime.Should().Throw(); } [Test] public void InOutCircular() { Easing.InOutCirc(0.25f).Should().BeApproximately(0.066987298107781f, 0.001f); Easing.InOutCirc(0.5f).Should().BeApproximately(0.5f, 0.001f); Easing.InOutCirc(0.75f).Should().BeApproximately(0.93301270189222f, 0.001f); Easing.InOutCirc(3f, 2, 6).Should().BeApproximately(2.267949192431f, 0.001f); Easing.InOutCirc(4f, 2, 6).Should().BeApproximately(4f, 0.001f); Easing.InOutCirc(5f, 2, 6).Should().BeApproximately(5.73205080757f, 0.001f); Action invalidTime = () => Easing.InOutCirc(1.5f); invalidTime.Should().Throw(); invalidTime = () => Easing.InOutCirc(7f, 2, 6); invalidTime.Should().Throw(); } [Test] public void OutInCircular() { Easing.OutInCirc(0.25f).Should().BeApproximately(0.43301270189222f, 0.001f); Easing.OutInCirc(0.5f).Should().BeApproximately(0.5f, 0.001f); Easing.OutInCirc(0.75f).Should().BeApproximately(0.56698729810778f, 0.001f); Easing.OutInCirc(3f, 2, 6).Should().BeApproximately(3.73205080757f, 0.001f); Easing.OutInCirc(4f, 2, 6).Should().BeApproximately(4f, 0.001f); Easing.OutInCirc(5f, 2, 6).Should().BeApproximately(4.26794919243f, 0.001f); Action invalidTime = () => Easing.OutInCirc(1.5f); invalidTime.Should().Throw(); invalidTime = () => Easing.OutInCirc(7f, 2, 6); invalidTime.Should().Throw(); } } public class DoubleTests { [Test] public void Linear() { Easing.Linear(0.25).Should().Be(0.25); Easing.Linear(0.5).Should().Be(0.5); Easing.Linear(0.75).Should().Be(0.75); Easing.Linear(3.0, 2, 6).Should().Be(3); Easing.Linear(4.0, 2, 6).Should().Be(4); Easing.Linear(5.0, 2, 6).Should().Be(5); CheckDoubleArguments(Easing.Linear, Easing.Linear); } [Test] public void InQuad() { Easing.InQuad(0.25).Should().Be(0.0625); Easing.InQuad(0.5).Should().Be(0.25); Easing.InQuad(0.75).Should().Be(0.5625); Easing.InQuad(3.0, 2, 6).Should().Be(2.25); Easing.InQuad(4.0, 2, 6).Should().Be(3); Easing.InQuad(5.0, 2, 6).Should().Be(4.25); CheckDoubleArguments(Easing.InQuad, Easing.InQuad); } [Test] public void OutQuad() { Easing.OutQuad(0.25).Should().Be(0.4375); Easing.OutQuad(0.5).Should().Be(0.75); Easing.OutQuad(0.75).Should().Be(0.9375); Easing.OutQuad(3.0, 2, 6).Should().Be(3.75); Easing.OutQuad(4.0, 2, 6).Should().Be(5); Easing.OutQuad(5.0, 2, 6).Should().Be(5.75); CheckDoubleArguments(Easing.OutQuad, Easing.OutQuad); } [Test] public void InOutQuad() { Easing.InOutQuad(0.25).Should().Be(0.125); Easing.InOutQuad(0.5).Should().Be(0.5); Easing.InOutQuad(0.75).Should().Be(0.875); Easing.InOutQuad(3.0, 2, 6).Should().Be(2.5); Easing.InOutQuad(4.0, 2, 6).Should().Be(4); Easing.InOutQuad(5.0, 2, 6).Should().Be(5.5); CheckDoubleArguments(Easing.InOutQuad, Easing.InOutQuad); } [Test] public void OutInQuad() { Easing.OutInQuad(0.25).Should().Be(0.375); Easing.OutInQuad(0.5).Should().Be(0.5); Easing.OutInQuad(0.75).Should().Be(0.625); Easing.OutInQuad(3.0, 2, 6).Should().Be(3.5); Easing.OutInQuad(4.0, 2, 6).Should().Be(4); Easing.OutInQuad(5.0, 2, 6).Should().Be(4.5); CheckDoubleArguments(Easing.OutInQuad, Easing.OutInQuad); } [Test] public void InCubic() { Easing.InCubic(0.25).Should().Be(0.015625); Easing.InCubic(0.5).Should().Be(0.125); Easing.InCubic(0.75).Should().Be(0.421875); Easing.InCubic(3.0, 2, 6).Should().Be(2.0625); Easing.InCubic(4.0, 2, 6).Should().Be(2.5); Easing.InCubic(5.0, 2, 6).Should().Be(3.6875); CheckDoubleArguments(Easing.InCubic, Easing.InCubic); } [Test] public void OutCubic() { Easing.OutCubic(0.25).Should().Be(0.578125); Easing.OutCubic(0.5).Should().Be(0.875); Easing.OutCubic(0.75).Should().Be(0.984375); Easing.OutCubic(3.0, 2, 6).Should().Be(4.3125); Easing.OutCubic(4.0, 2, 6).Should().Be(5.5); Easing.OutCubic(5.0, 2, 6).Should().Be(5.9375); CheckDoubleArguments(Easing.OutCubic, Easing.OutCubic); } [Test] public void InOutCubic() { Easing.InOutCubic(0.25).Should().Be(0.0625); Easing.InOutCubic(0.5).Should().Be(0.5); Easing.InOutCubic(0.75).Should().Be(0.9375); Easing.InOutCubic(3.0, 2, 6).Should().Be(2.25); Easing.InOutCubic(4.0, 2, 6).Should().Be(4); Easing.InOutCubic(5.0, 2, 6).Should().Be(5.75); CheckDoubleArguments(Easing.InOutCubic, Easing.InOutCubic); } [Test] public void OutInCubic() { Easing.OutInCubic(0.25).Should().Be(0.4375); Easing.OutInCubic(0.5).Should().Be(0.5); Easing.OutInCubic(0.75).Should().Be(0.5625); Easing.OutInCubic(3.0, 2, 6).Should().Be(3.75); Easing.OutInCubic(4.0, 2, 6).Should().Be(4); Easing.OutInCubic(5.0, 2, 6).Should().Be(4.25); CheckDoubleArguments(Easing.OutInCubic, Easing.OutInCubic); } [Test] public void InQuartic() { Easing.InQuart(0.25).Should().Be(0.00390625); Easing.InQuart(0.5).Should().Be(0.0625); Easing.InQuart(0.75).Should().Be(0.31640625); Easing.InQuart(3.0, 2, 6).Should().Be(2.015625); Easing.InQuart(4.0, 2, 6).Should().Be(2.25); Easing.InQuart(5.0, 2, 6).Should().Be(3.265625); CheckDoubleArguments(Easing.InQuart, Easing.InQuart); } [Test] public void OutQuartic() { Easing.OutQuart(0.25).Should().Be(0.68359375); Easing.OutQuart(0.5).Should().Be(0.9375); Easing.OutQuart(0.75).Should().Be(0.99609375); Easing.OutQuart(3.0, 2, 6).Should().Be(4.734375); Easing.OutQuart(4.0, 2, 6).Should().Be(5.75); Easing.OutQuart(5.0, 2, 6).Should().Be(5.984375); CheckDoubleArguments(Easing.OutQuart, Easing.OutQuart); } [Test] public void InOutQuartic() { Easing.InOutQuart(0.25).Should().Be(0.03125); Easing.InOutQuart(0.5).Should().Be(0.5); Easing.InOutQuart(0.75).Should().Be(0.96875); Easing.InOutQuart(3.0, 2, 6).Should().Be(2.125); Easing.InOutQuart(4.0, 2, 6).Should().Be(4); Easing.InOutQuart(5.0, 2, 6).Should().Be(5.875); CheckDoubleArguments(Easing.InOutQuart, Easing.InOutQuart); } [Test] public void OutInQuartic() { Easing.OutInQuart(0.25).Should().Be(0.46875); Easing.OutInQuart(0.5).Should().Be(0.5); Easing.OutInQuart(0.75).Should().Be(0.53125); Easing.OutInQuart(3.0, 2, 6).Should().Be(3.875); Easing.OutInQuart(4.0, 2, 6).Should().Be(4); Easing.OutInQuart(5.0, 2, 6).Should().Be(4.125); CheckDoubleArguments(Easing.OutInQuart, Easing.OutInQuart); } [Test] public void InQuintic() { Easing.InQuint(0.25).Should().Be(0.0009765625); Easing.InQuint(0.5).Should().Be(0.03125); Easing.InQuint(0.75).Should().Be(0.2373046875); Easing.InQuint(3.0, 2, 6).Should().Be(2.00390625); Easing.InQuint(4.0, 2, 6).Should().Be(2.125); Easing.InQuint(5.0, 2, 6).Should().Be(2.94921875); CheckDoubleArguments(Easing.InQuint, Easing.InQuint); } [Test] public void OutQuintic() { Easing.OutQuint(0.25).Should().Be(0.7626953125); Easing.OutQuint(0.5).Should().Be(0.96875); Easing.OutQuint(0.75).Should().Be(0.9990234375); Easing.OutQuint(3.0, 2, 6).Should().Be(5.05078125); Easing.OutQuint(4.0, 2, 6).Should().Be(5.875); Easing.OutQuint(5.0, 2, 6).Should().Be(5.99609375); CheckDoubleArguments(Easing.OutQuint, Easing.OutQuint); } [Test] public void InOutQuintic() { Easing.InOutQuint(0.25).Should().Be(0.015625); Easing.InOutQuint(0.5).Should().Be(0.5); Easing.InOutQuint(0.75).Should().Be(0.984375); Easing.InOutQuint(3.0, 2, 6).Should().Be(2.0625); Easing.InOutQuint(4.0, 2, 6).Should().Be(4); Easing.InOutQuint(5.0, 2, 6).Should().Be(5.9375); CheckDoubleArguments(Easing.InOutQuint, Easing.InOutQuint); } [Test] public void OutInQuintic() { Easing.OutInQuint(0.25).Should().Be(0.484375); Easing.OutInQuint(0.5).Should().Be(0.5); Easing.OutInQuint(0.75).Should().Be(0.515625); Easing.OutInQuint(3.0, 2, 6).Should().Be(3.9375); Easing.OutInQuint(4.0, 2, 6).Should().Be(4); Easing.OutInQuint(5.0, 2, 6).Should().Be(4.0625); CheckDoubleArguments(Easing.OutInQuint, Easing.OutInQuint); } [Test] public void InSine() { Easing.InSine(0.25).Should().BeApproximately(0.076120467488713, 0.0001); Easing.InSine(0.5).Should().BeApproximately(0.29289321881345, 0.0001); Easing.InSine(0.75).Should().BeApproximately(0.61731656763491, 0.0001); Easing.InSine(3, 2, 6).Should().BeApproximately(2.304481869955, 0.0001); Easing.InSine(4, 2, 6).Should().BeApproximately(3.17157287525, 0.0001); Easing.InSine(5, 2, 6).Should().BeApproximately(4.46926627054, 0.0001); CheckDoubleArguments(Easing.InSine, Easing.InSine); } [Test] public void OutSine() { Easing.OutSine(0.25).Should().BeApproximately(0.38268343236509, 0.0001); Easing.OutSine(0.5).Should().BeApproximately(0.70710678118655, 0.0001); Easing.OutSine(0.75).Should().BeApproximately(0.92387953251129, 0.0001); Easing.OutSine(3, 2, 6).Should().BeApproximately(3.53073372946, 0.0001); Easing.OutSine(4, 2, 6).Should().BeApproximately(4.82842712475, 0.0001); Easing.OutSine(5, 2, 6).Should().BeApproximately(5.69551813005, 0.0001); CheckDoubleArguments(Easing.OutSine, Easing.OutSine); } [Test] public void InOutSine() { Easing.InOutSine(0.25).Should().BeApproximately(0.14644660940673, 0.0001); Easing.InOutSine(0.5).Should().BeApproximately(0.5, 0.0001); Easing.InOutSine(0.75).Should().BeApproximately(0.85355339059327, 0.0001); Easing.InOutSine(3, 2, 6).Should().BeApproximately(2.585786437627, 0.0001); Easing.InOutSine(4, 2, 6).Should().BeApproximately(4, 0.0001); Easing.InOutSine(5, 2, 6).Should().BeApproximately(5.41421356237, 0.0001); CheckDoubleArguments(Easing.InOutSine, Easing.InOutSine); } [Test] public void OutInSine() { Easing.OutInSine(0.25).Should().BeApproximately(0.35355339059327, 0.0001); Easing.OutInSine(0.5).Should().BeApproximately(0.5, 0.0001); Easing.OutInSine(0.75).Should().BeApproximately(0.64644660940673, 0.0001); Easing.OutInSine(3, 2, 6).Should().BeApproximately(3.41421356237, 0.0001); Easing.OutInSine(4, 2, 6).Should().BeApproximately(4, 0.0001); Easing.OutInSine(5, 2, 6).Should().BeApproximately(4.58578643763, 0.0001); CheckDoubleArguments(Easing.OutInSine, Easing.OutInSine); } [Test] public void InExpo() { Easing.InExpo(0.25).Should().BeApproximately(0.0045242717280199, 0.0001); Easing.InExpo(0.5).Should().BeApproximately(0.03025, 0.0001); Easing.InExpo(0.75).Should().BeApproximately(0.17577669529664, 0.0001); Easing.InExpo(3, 2, 6).Should().BeApproximately(2.0180970869121, 0.0001); Easing.InExpo(4, 2, 6).Should().BeApproximately(2.121, 0.0001); Easing.InExpo(5, 2, 6).Should().BeApproximately(2.703106781187, 0.0001); CheckDoubleArguments(Easing.InExpo, Easing.InExpo); } [Test] public void OutExpo() { Easing.OutExpo(0.25).Should().BeApproximately(0.82404652800807, 0.0001); Easing.OutExpo(0.5).Should().BeApproximately(0.96971875, 0.0001); Easing.OutExpo(0.75).Should().BeApproximately(0.99547020400025, 0.0001); Easing.OutExpo(3, 2, 6).Should().BeApproximately(5.29618611203, 0.0001); Easing.OutExpo(4, 2, 6).Should().BeApproximately(5.878875, 0.0001); Easing.OutExpo(5, 2, 6).Should().BeApproximately(5.981880816, 0.0001); CheckDoubleArguments(Easing.OutExpo, Easing.OutExpo); } [Test] public void InOutExpo() { Easing.InOutExpo(0.25).Should().BeApproximately(0.015125, 0.001); Easing.InOutExpo(0.5).Should().BeApproximately(0.5, 0.001); Easing.InOutExpo(0.75).Should().BeApproximately(0.9848671875, 0.001); Easing.InOutExpo(3, 2, 6).Should().BeApproximately(2.0605, 0.001); Easing.InOutExpo(4, 2, 6).Should().BeApproximately(4, 0.001); Easing.InOutExpo(5, 2, 6).Should().BeApproximately(5.93946875, 0.001); CheckDoubleArguments(Easing.InOutExpo, Easing.InOutExpo); } [Test] public void OutInExpo() { Easing.OutInExpo(0.25).Should().BeApproximately(0.484859375, 0.001); Easing.OutInExpo(0.5).Should().BeApproximately(0.5, 0.001); Easing.OutInExpo(0.75).Should().BeApproximately(0.515125, 0.001); Easing.OutInExpo(3, 2, 6).Should().BeApproximately(3.9394375, 0.001); Easing.OutInExpo(4, 2, 6).Should().BeApproximately(4, 0.001); Easing.OutInExpo(5, 2, 6).Should().BeApproximately(4.0605, 0.001); CheckDoubleArguments(Easing.OutInExpo, Easing.OutInExpo); } [Test] public void InCircular() { Easing.InCirc(0.25).Should().BeApproximately(0.031754163448146, 0.001); Easing.InCirc(0.5).Should().BeApproximately(0.13397459621556, 0.001); Easing.InCirc(0.75).Should().BeApproximately(0.33856217223385, 0.001); Easing.InCirc(3, 2, 6).Should().BeApproximately(2.127016653793, 0.001); Easing.InCirc(4, 2, 6).Should().BeApproximately(2.535898384862, 0.001); Easing.InCirc(5, 2, 6).Should().BeApproximately(3.35424868894, 0.001); CheckDoubleArguments(Easing.InCirc, Easing.InCirc); } [Test] public void OutCircular() { Easing.OutCirc(0.25).Should().BeApproximately(0.66143782776615, 0.001); Easing.OutCirc(0.5).Should().BeApproximately(0.86602540378444, 0.001); Easing.OutCirc(0.75).Should().BeApproximately(0.96824583655185, 0.001); Easing.OutCirc(3, 2, 6).Should().BeApproximately(4.64575131107, 0.001); Easing.OutCirc(4, 2, 6).Should().BeApproximately(5.46410161514, 0.001); Easing.OutCirc(5, 2, 6).Should().BeApproximately(5.87298334621, 0.001); CheckDoubleArguments(Easing.OutCirc, Easing.OutCirc); } [Test] public void InOutCircular() { Easing.InOutCirc(0.25).Should().BeApproximately(0.066987298107781, 0.001); Easing.InOutCirc(0.5).Should().BeApproximately(0.5, 0.001); Easing.InOutCirc(0.75).Should().BeApproximately(0.93301270189222, 0.001); Easing.InOutCirc(3, 2, 6).Should().BeApproximately(2.267949192431, 0.001); Easing.InOutCirc(4, 2, 6).Should().BeApproximately(4, 0.001); Easing.InOutCirc(5, 2, 6).Should().BeApproximately(5.73205080757, 0.001); CheckDoubleArguments(Easing.InOutCirc, Easing.InOutCirc); } [Test] public void OutInCircular() { Easing.OutInCirc(0.25).Should().BeApproximately(0.43301270189222, 0.001); Easing.OutInCirc(0.5).Should().BeApproximately(0.5, 0.001); Easing.OutInCirc(0.75).Should().BeApproximately(0.56698729810778, 0.001); Easing.OutInCirc(3, 2, 6).Should().BeApproximately(3.73205080757, 0.001); Easing.OutInCirc(4, 2, 6).Should().BeApproximately(4, 0.001); Easing.OutInCirc(5, 2, 6).Should().BeApproximately(4.26794919243, 0.001); CheckDoubleArguments(Easing.OutInCirc, Easing.OutInCirc); } [Test] public void InElasticDefault() { Easing.InElasticNormalized(0.25).Should().BeApproximately(-0.0055242717280199, 0.001); Easing.InElasticNormalized(0.5).Should().BeApproximately(-0.015625, 0.001); Easing.InElasticNormalized(0.75).Should().BeApproximately(0.088388347648318, 0.001); Easing.InElasticTimeRange(3, 2, 6).Should().BeApproximately(1.97790291309, 0.001); Easing.InElasticTimeRange(4, 2, 6).Should().BeApproximately(1.9375, 0.001); Easing.InElasticTimeRange(5, 2, 6).Should().BeApproximately(2.35355339059, 0.001); CheckDoubleArguments(Easing.InElasticNormalized, Easing.InElasticTimeRange); } [Test] public void InElasticWithA() { Easing.InElasticNormalized(0.25, 10).Should().BeApproximately(-0.0055242717280198, 0.001); Easing.InElasticNormalized(0.5, 10).Should().BeApproximately(-0.28490137405647, 0.001); Easing.InElasticNormalized(0.75, 10).Should().BeApproximately(-1.4348688532209, 0.001); Easing.InElasticTimeRange(3, 2, 6, 10).Should().BeApproximately(1.97790291309, 0.001); Easing.InElasticTimeRange(4, 2, 6, 10).Should().BeApproximately(0.860394503774, 0.001); Easing.InElasticTimeRange(5, 2, 6, 10).Should().BeApproximately(-3.73947541288, 0.001); } [Test] public void InElasticWithAAndP() { Easing.InElasticNormalized(0.25, 10, 0.5).Should().BeApproximately(-0.0055242717280199, 0.001); Easing.InElasticNormalized(0.5, 10, 0.5).Should().BeApproximately(0.03125, 0.001); Easing.InElasticNormalized(0.75, 10, 0.5).Should().BeApproximately(-0.17677669529664, 0.001); Easing.InElasticTimeRange(3, 2, 6, 10, 0.5).Should().BeApproximately(1.97790291309, 0.001); Easing.InElasticTimeRange(4, 2, 6, 10, 0.5).Should().BeApproximately(2.125, 0.001); Easing.InElasticTimeRange(5, 2, 6, 10, 0.5).Should().BeApproximately(1.29289321881, 0.001); } [Test] public void OutElasticDefault() { Easing.OutElasticNormalized(0.25).Should().BeApproximately(0.91161165235168, 0.001); Easing.OutElasticNormalized(0.5).Should().BeApproximately(1.015625, 0.001); Easing.OutElasticNormalized(0.75).Should().BeApproximately(1.005524271728, 0.001); Easing.OutElasticTimeRange(3, 2, 6).Should().BeApproximately(5.64644660941, 0.001); Easing.OutElasticTimeRange(4, 2, 6).Should().BeApproximately(6.0625, 0.001); Easing.OutElasticTimeRange(5, 2, 6).Should().BeApproximately(6.02209708691, 0.001); CheckDoubleArguments(Easing.OutElasticNormalized, Easing.OutElasticTimeRange); } [Test] public void OutElasticWithA() { Easing.OutElasticNormalized(0.25, 10).Should().BeApproximately(-0.61164554851756, 0.001); Easing.OutElasticNormalized(0.5, 10).Should().BeApproximately(0.74634862594353, 0.001); Easing.OutElasticNormalized(0.75, 10).Should().BeApproximately(1.005524271728, 0.001); Easing.OutElasticTimeRange(3, 2, 6, 10).Should().BeApproximately(-0.44658219407, 0.001); Easing.OutElasticTimeRange(4, 2, 6, 10).Should().BeApproximately(4.98539450378, 0.001); Easing.OutElasticTimeRange(5, 2, 6, 10).Should().BeApproximately(6.02209708691, 0.001); } [Test] public void OutElasticWithAAndP() { Easing.OutElasticNormalized(0.25, 10, 0.5).Should().BeApproximately(1.1767766952966, 0.001); Easing.OutElasticNormalized(0.5, 10, 0.5).Should().BeApproximately(0.96875, 0.001); Easing.OutElasticNormalized(0.75, 10, 0.5).Should().BeApproximately(1.005524271728, 0.001); Easing.OutElasticTimeRange(3, 2, 6, 10, 0.5).Should().BeApproximately(6.70710678118, 0.001); Easing.OutElasticTimeRange(4, 2, 6, 10, 0.5).Should().BeApproximately(5.875, 0.001); Easing.OutElasticTimeRange(5, 2, 6, 10, 0.5).Should().BeApproximately(6.02209708691, 0.001); } [Test] public void InOutElasticDefault() { Easing.InOutElasticNormalized(0.25).Should().BeApproximately(0.011969444423734, 0.001); Easing.InOutElasticNormalized(0.5).Should().BeApproximately(0.5, 0.001); Easing.InOutElasticNormalized(0.75).Should().BeApproximately(0.98803055557627, 0.001); Easing.InOutElasticTimeRange(3, 2, 6).Should().BeApproximately(2.0478777777, 0.001); Easing.InOutElasticTimeRange(4, 2, 6).Should().BeApproximately(4, 0.001); Easing.InOutElasticTimeRange(5, 2, 6).Should().BeApproximately(5.9521222223, 0.001); CheckDoubleArguments(Easing.InOutElasticNormalized, Easing.InOutElasticTimeRange); } [Test] public void InOutElasticWithA() { Easing.InOutElasticNormalized(0.25, 10).Should().BeApproximately(0.11190156885591, 0.001); Easing.InOutElasticNormalized(0.5, 10).Should().BeApproximately(0.5, 0.001); Easing.InOutElasticNormalized(0.75, 10).Should().BeApproximately(1.0879626800084, 0.001); Easing.InOutElasticTimeRange(3, 2, 6, 10).Should().BeApproximately(2.44760627542, 0.001); Easing.InOutElasticTimeRange(4, 2, 6, 10).Should().BeApproximately(4, 0.001); Easing.InOutElasticTimeRange(5, 2, 6, 10).Should().BeApproximately(6.35185072004, 0.001); } [Test] public void InOutElasticWithAAndP() { Easing.InOutElasticNormalized(0.25, 10, 0.5).Should().BeApproximately(0.015625, 0.001); Easing.InOutElasticNormalized(0.5, 10, 0.5).Should().BeApproximately(0.5, 0.001); Easing.InOutElasticNormalized(0.75, 10, 0.5).Should().BeApproximately(0.984375, 0.001); Easing.InOutElasticTimeRange(3, 2, 6, 10, 0.5).Should().BeApproximately(2.0625, 0.001); Easing.InOutElasticTimeRange(4, 2, 6, 10, 0.5).Should().BeApproximately(4, 0.001); Easing.InOutElasticTimeRange(5, 2, 6, 10, 0.5).Should().BeApproximately(5.9375, 0.001); } [Test] public void OutInElasticDefault() { Easing.OutInElasticNormalized(0.25).Should().BeApproximately(0.5078125, 0.001); Easing.OutInElasticNormalized(0.5).Should().BeApproximately(0.5, 0.001); Easing.OutInElasticNormalized(0.75).Should().BeApproximately(0.4921875, 0.001); Easing.OutInElasticTimeRange(3, 2, 6).Should().BeApproximately(4.03125, 0.001); Easing.OutInElasticTimeRange(4, 2, 6).Should().BeApproximately(4, 0.001); Easing.OutInElasticTimeRange(5, 2, 6).Should().BeApproximately(3.96875, 0.001); CheckDoubleArguments(Easing.OutInElasticNormalized, Easing.OutInElasticTimeRange); } [Test] public void OutInElasticWithA() { Easing.OutInElasticNormalized(0.25, 10).Should().BeApproximately(0.2375180641874, 0.001); Easing.OutInElasticNormalized(0.5, 10).Should().BeApproximately(0.5, 0.001); Easing.OutInElasticNormalized(0.75, 10).Should().BeApproximately(0.2218930641874, 0.001); Easing.OutInElasticTimeRange(3, 2, 6, 10).Should().BeApproximately(2.95007225675, 0.001); Easing.OutInElasticTimeRange(4, 2, 6, 10).Should().BeApproximately(4, 0.001); Easing.OutInElasticTimeRange(5, 2, 6, 10).Should().BeApproximately(2.88757225675, 0.001); } [Test] public void OutInElasticWithAAndP() { Easing.OutInElasticNormalized(0.25, 10, 0.5).Should().BeApproximately(0.484375, 0.001); Easing.OutInElasticNormalized(0.5, 10, 0.5).Should().BeApproximately(0.5, 0.001); Easing.OutInElasticNormalized(0.75, 10, 0.5).Should().BeApproximately(0.515625, 0.001); Easing.OutInElasticTimeRange(3, 2, 6, 10, 0.5).Should().BeApproximately(3.9375, 0.001); Easing.OutInElasticTimeRange(4, 2, 6, 10, 0.5).Should().BeApproximately(4, 0.001); Easing.OutInElasticTimeRange(5, 2, 6, 10, 0.5).Should().BeApproximately(4.0625, 0.001); } [Test] public void InBackDefault() { Easing.InBackNormalized(0.25).Should().BeApproximately(-0.0641365625, 0.001); Easing.InBackNormalized(0.5).Should().BeApproximately(-0.0876975, 0.001); Easing.InBackNormalized(0.75).Should().BeApproximately(0.1825903125, 0.001); Easing.InBackTimeRange(3, 2, 6).Should().BeApproximately(1.74345375, 0.001); Easing.InBackTimeRange(4, 2, 6).Should().BeApproximately(1.64921, 0.001); Easing.InBackTimeRange(5, 2, 6).Should().BeApproximately(2.73036125, 0.001); CheckDoubleArguments(Easing.InBackNormalized, Easing.InBackTimeRange); } [Test] public void InBackWithSize() { Easing.InBackNormalized(0.25, 3).Should().BeApproximately(-0.125, 0.001); Easing.InBackNormalized(0.5, 3).Should().BeApproximately(-0.25, 0.001); Easing.InBackNormalized(0.75, 3).Should().BeApproximately(0, 0.001); Easing.InBackTimeRange(3, 2, 6, 3).Should().BeApproximately(1.5, 0.001); Easing.InBackTimeRange(4, 2, 6, 3).Should().BeApproximately(1, 0.001); Easing.InBackTimeRange(5, 2, 6, 3).Should().BeApproximately(2, 0.001); } [Test] public void OutBackDefault() { Easing.OutBackNormalized(0.25).Should().BeApproximately(0.8174096875, 0.001); Easing.OutBackNormalized(0.5).Should().BeApproximately(1.0876975, 0.001); Easing.OutBackNormalized(0.75).Should().BeApproximately(1.0641365625, 0.001); Easing.OutBackTimeRange(3, 2, 6).Should().BeApproximately(5.26963875, 0.001); Easing.OutBackTimeRange(4, 2, 6).Should().BeApproximately(6.35079, 0.001); Easing.OutBackTimeRange(5, 2, 6).Should().BeApproximately(6.25654625, 0.001); CheckDoubleArguments(Easing.OutBackNormalized, Easing.OutBackTimeRange); } [Test] public void OutBackWithSize() { Easing.OutBackNormalized(0.25, 3).Should().BeApproximately(1, 0.001); Easing.OutBackNormalized(0.5, 3).Should().BeApproximately(1.25, 0.001); Easing.OutBackNormalized(0.75, 3).Should().BeApproximately(1.125, 0.001); Easing.OutBackTimeRange(3, 2, 6, 3).Should().BeApproximately(6, 0.001); Easing.OutBackTimeRange(4, 2, 6, 3).Should().BeApproximately(7, 0.001); Easing.OutBackTimeRange(5, 2, 6, 3).Should().BeApproximately(6.5, 0.001); } [Test] public void InOutBackDefault() { Easing.InOutBackNormalized(0.25).Should().BeApproximately(-0.09968184375, 0.001); Easing.InOutBackNormalized(0.5).Should().BeApproximately(0.5, 0.001); Easing.InOutBackNormalized(0.75).Should().BeApproximately(1.09968184375, 0.001); Easing.InOutBackTimeRange(3, 2, 6).Should().BeApproximately(1.601272625, 0.001); Easing.InOutBackTimeRange(4, 2, 6).Should().BeApproximately(4, 0.001); Easing.InOutBackTimeRange(5, 2, 6).Should().BeApproximately(6.398727375, 0.001); CheckDoubleArguments(Easing.InOutBackNormalized, Easing.InOutBackTimeRange); } [Test] public void InOutBackWithSize() { Easing.InOutBackNormalized(0.25, 3).Should().BeApproximately(-0.2234375, 0.001); Easing.InOutBackNormalized(0.5, 3).Should().BeApproximately(0.5, 0.001); Easing.InOutBackNormalized(0.75, 3).Should().BeApproximately(1.2234375, 0.001); Easing.InOutBackTimeRange(3, 2, 6, 3).Should().BeApproximately(1.10625, 0.001); Easing.InOutBackTimeRange(4, 2, 6, 3).Should().BeApproximately(4, 0.001); Easing.InOutBackTimeRange(5, 2, 6, 3).Should().BeApproximately(6.89375, 0.001); } [Test] public void OutInBackDefault() { Easing.OutInBackNormalized(0.25).Should().BeApproximately(0.54384875, 0.001); Easing.OutInBackNormalized(0.5).Should().BeApproximately(0.5, 0.001); Easing.OutInBackNormalized(0.75).Should().BeApproximately(0.45615125, 0.001); Easing.OutInBackTimeRange(3, 2, 6).Should().BeApproximately(4.175395, 0.001); Easing.OutInBackTimeRange(4, 2, 6).Should().BeApproximately(4, 0.001); Easing.OutInBackTimeRange(5, 2, 6).Should().BeApproximately(3.824605, 0.001); CheckDoubleArguments(Easing.OutInBackNormalized, Easing.OutInBackTimeRange); } [Test] public void OutInBackWithSize() { Easing.OutInBackNormalized(0.25, 3).Should().BeApproximately(0.625, 0.001); Easing.OutInBackNormalized(0.5, 3).Should().BeApproximately(0.5, 0.001); Easing.OutInBackNormalized(0.75, 3).Should().BeApproximately(0.375, 0.001); Easing.OutInBackTimeRange(3, 2, 6, 3).Should().BeApproximately(4.5, 0.001); Easing.OutInBackTimeRange(4, 2, 6, 3).Should().BeApproximately(4, 0.001); Easing.OutInBackTimeRange(5, 2, 6, 3).Should().BeApproximately(3.5, 0.001); } [Test] public void OutBounce() { Easing.OutBounce(0.25).Should().BeApproximately(0.47265625, 0.001); Easing.OutBounce(0.5).Should().BeApproximately(0.765625, 0.001); Easing.OutBounce(0.75).Should().BeApproximately(0.97265625, 0.001); Easing.OutBounce(3, 2, 6).Should().BeApproximately(3.890625, 0.001); Easing.OutBounce(4, 2, 6).Should().BeApproximately(5.0625, 0.001); Easing.OutBounce(5, 2, 6).Should().BeApproximately(5.890625, 0.001); CheckDoubleArguments(Easing.OutBounce, Easing.OutBounce); } [Test] public void InBounce() { Easing.InBounce(0.25).Should().BeApproximately(0.02734375, 0.001); Easing.InBounce(0.5).Should().BeApproximately(0.234375, 0.001); Easing.InBounce(0.75).Should().BeApproximately(0.52734375, 0.001); Easing.InBounce(3, 2, 6).Should().BeApproximately(2.109375, 0.001); Easing.InBounce(4, 2, 6).Should().BeApproximately(2.9375, 0.001); Easing.InBounce(5, 2, 6).Should().BeApproximately(4.109375, 0.001); CheckDoubleArguments(Easing.InBounce, Easing.InBounce); } [Test] public void InOutBounce() { Easing.InOutBounce(0.25).Should().BeApproximately(0.1171875, 0.001); Easing.InOutBounce(0.5).Should().BeApproximately(0.5, 0.001); Easing.InOutBounce(0.75).Should().BeApproximately(0.8828125, 0.001); Easing.InOutBounce(3, 2, 6).Should().BeApproximately(2.46875, 0.001); Easing.InOutBounce(4, 2, 6).Should().BeApproximately(4, 0.001); Easing.InOutBounce(5, 2, 6).Should().BeApproximately(5.53125, 0.001); CheckDoubleArguments(Easing.InOutBounce, Easing.InOutBounce); } [Test] public void OutInBounce() { Easing.OutInBounce(0.25).Should().BeApproximately(0.3828125, 0.001); Easing.OutInBounce(0.5).Should().BeApproximately(0.5, 0.001); Easing.OutInBounce(0.75).Should().BeApproximately(0.6171875, 0.001); Easing.OutInBounce(3, 2, 6).Should().BeApproximately(3.53125, 0.001); Easing.OutInBounce(4, 2, 6).Should().BeApproximately(4, 0.001); Easing.OutInBounce(5, 2, 6).Should().BeApproximately(4.46875, 0.001); CheckDoubleArguments(Easing.OutInBounce, Easing.OutInBounce); } } } }