blob: ff15c974b5e0bfa70aa2fa32992433a0a4a2d2de [file] [log] [blame]
// Copyright 2013 The Flutter 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 <math.h>
#include "fml/logging.h"
#include "gtest/gtest.h"
#include "flutter/impeller/geometry/trig.h"
namespace impeller {
namespace testing {
TEST(TrigTest, TrigAngles) {
{
Trig trig(Degrees(0.0));
EXPECT_EQ(trig.cos, 1.0);
EXPECT_EQ(trig.sin, 0.0);
}
{
Trig trig(Radians(0.0));
EXPECT_EQ(trig.cos, 1.0);
EXPECT_EQ(trig.sin, 0.0);
}
{
Trig trig(Degrees(30.0));
EXPECT_NEAR(trig.cos, sqrt(0.75), kEhCloseEnough);
EXPECT_NEAR(trig.sin, 0.5, kEhCloseEnough);
}
{
Trig trig(Radians(kPi / 6.0));
EXPECT_NEAR(trig.cos, sqrt(0.75), kEhCloseEnough);
EXPECT_NEAR(trig.sin, 0.5, kEhCloseEnough);
}
{
Trig trig(Degrees(60.0));
EXPECT_NEAR(trig.cos, 0.5, kEhCloseEnough);
EXPECT_NEAR(trig.sin, sqrt(0.75), kEhCloseEnough);
}
{
Trig trig(Radians(kPi / 3.0));
EXPECT_NEAR(trig.cos, 0.5, kEhCloseEnough);
EXPECT_NEAR(trig.sin, sqrt(0.75), kEhCloseEnough);
}
{
Trig trig(Degrees(90.0));
EXPECT_NEAR(trig.cos, 0.0, kEhCloseEnough);
EXPECT_NEAR(trig.sin, 1.0, kEhCloseEnough);
}
{
Trig trig(Radians(kPi / 2.0));
EXPECT_NEAR(trig.cos, 0.0, kEhCloseEnough);
EXPECT_NEAR(trig.sin, 1.0, kEhCloseEnough);
}
}
TEST(TrigTest, MultiplyByScalarRadius) {
for (int i = 0; i <= 360; i++) {
for (int i = 1; i <= 10; i++) {
Scalar radius = i * 5.0f;
EXPECT_EQ(Trig(Degrees(i)) * radius,
Point(radius * std::cos(i * kPi / 180),
radius * std::sin(i * kPi / 180)))
<< "at " << i << " degrees and radius " << radius;
}
}
}
} // namespace testing
} // namespace impeller