1*635a8641SAndroid Build Coastguard Worker // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2*635a8641SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*635a8641SAndroid Build Coastguard Worker // found in the LICENSE file.
4*635a8641SAndroid Build Coastguard Worker
5*635a8641SAndroid Build Coastguard Worker #include <stddef.h>
6*635a8641SAndroid Build Coastguard Worker
7*635a8641SAndroid Build Coastguard Worker #include "base/macros.h"
8*635a8641SAndroid Build Coastguard Worker #include "testing/gtest/include/gtest/gtest.h"
9*635a8641SAndroid Build Coastguard Worker #include "ui/gfx/geometry/point3_f.h"
10*635a8641SAndroid Build Coastguard Worker
11*635a8641SAndroid Build Coastguard Worker namespace gfx {
12*635a8641SAndroid Build Coastguard Worker
TEST(Point3Test,VectorArithmetic)13*635a8641SAndroid Build Coastguard Worker TEST(Point3Test, VectorArithmetic) {
14*635a8641SAndroid Build Coastguard Worker gfx::Point3F a(1.6f, 5.1f, 3.2f);
15*635a8641SAndroid Build Coastguard Worker gfx::Vector3dF v1(3.1f, -3.2f, 9.3f);
16*635a8641SAndroid Build Coastguard Worker gfx::Vector3dF v2(-8.1f, 1.2f, 3.3f);
17*635a8641SAndroid Build Coastguard Worker
18*635a8641SAndroid Build Coastguard Worker static const struct {
19*635a8641SAndroid Build Coastguard Worker gfx::Point3F expected;
20*635a8641SAndroid Build Coastguard Worker gfx::Point3F actual;
21*635a8641SAndroid Build Coastguard Worker } tests[] = {
22*635a8641SAndroid Build Coastguard Worker { gfx::Point3F(4.7f, 1.9f, 12.5f), a + v1 },
23*635a8641SAndroid Build Coastguard Worker { gfx::Point3F(-1.5f, 8.3f, -6.1f), a - v1 },
24*635a8641SAndroid Build Coastguard Worker { a, a - v1 + v1 },
25*635a8641SAndroid Build Coastguard Worker { a, a + v1 - v1 },
26*635a8641SAndroid Build Coastguard Worker { a, a + gfx::Vector3dF() },
27*635a8641SAndroid Build Coastguard Worker { gfx::Point3F(12.8f, 0.7f, 9.2f), a + v1 - v2 },
28*635a8641SAndroid Build Coastguard Worker { gfx::Point3F(-9.6f, 9.5f, -2.8f), a - v1 + v2 }
29*635a8641SAndroid Build Coastguard Worker };
30*635a8641SAndroid Build Coastguard Worker
31*635a8641SAndroid Build Coastguard Worker for (size_t i = 0; i < arraysize(tests); ++i)
32*635a8641SAndroid Build Coastguard Worker EXPECT_EQ(tests[i].expected.ToString(),
33*635a8641SAndroid Build Coastguard Worker tests[i].actual.ToString());
34*635a8641SAndroid Build Coastguard Worker
35*635a8641SAndroid Build Coastguard Worker a += v1;
36*635a8641SAndroid Build Coastguard Worker EXPECT_EQ(Point3F(4.7f, 1.9f, 12.5f).ToString(), a.ToString());
37*635a8641SAndroid Build Coastguard Worker
38*635a8641SAndroid Build Coastguard Worker a -= v2;
39*635a8641SAndroid Build Coastguard Worker EXPECT_EQ(Point3F(12.8f, 0.7f, 9.2f).ToString(), a.ToString());
40*635a8641SAndroid Build Coastguard Worker }
41*635a8641SAndroid Build Coastguard Worker
TEST(Point3Test,VectorFromPoints)42*635a8641SAndroid Build Coastguard Worker TEST(Point3Test, VectorFromPoints) {
43*635a8641SAndroid Build Coastguard Worker gfx::Point3F a(1.6f, 5.2f, 3.2f);
44*635a8641SAndroid Build Coastguard Worker gfx::Vector3dF v1(3.1f, -3.2f, 9.3f);
45*635a8641SAndroid Build Coastguard Worker
46*635a8641SAndroid Build Coastguard Worker gfx::Point3F b(a + v1);
47*635a8641SAndroid Build Coastguard Worker EXPECT_EQ((b - a).ToString(), v1.ToString());
48*635a8641SAndroid Build Coastguard Worker }
49*635a8641SAndroid Build Coastguard Worker
TEST(Point3Test,Scale)50*635a8641SAndroid Build Coastguard Worker TEST(Point3Test, Scale) {
51*635a8641SAndroid Build Coastguard Worker EXPECT_EQ(Point3F().ToString(), ScalePoint(Point3F(), 2.f).ToString());
52*635a8641SAndroid Build Coastguard Worker EXPECT_EQ(Point3F().ToString(),
53*635a8641SAndroid Build Coastguard Worker ScalePoint(Point3F(), 2.f, 2.f, 2.f).ToString());
54*635a8641SAndroid Build Coastguard Worker
55*635a8641SAndroid Build Coastguard Worker EXPECT_EQ(Point3F(2.f, -2.f, 4.f).ToString(),
56*635a8641SAndroid Build Coastguard Worker ScalePoint(Point3F(1.f, -1.f, 2.f), 2.f).ToString());
57*635a8641SAndroid Build Coastguard Worker EXPECT_EQ(Point3F(2.f, -3.f, 8.f).ToString(),
58*635a8641SAndroid Build Coastguard Worker ScalePoint(Point3F(1.f, -1.f, 2.f), 2.f, 3.f, 4.f).ToString());
59*635a8641SAndroid Build Coastguard Worker
60*635a8641SAndroid Build Coastguard Worker Point3F zero;
61*635a8641SAndroid Build Coastguard Worker zero.Scale(2.f);
62*635a8641SAndroid Build Coastguard Worker zero.Scale(6.f, 3.f, 1.5f);
63*635a8641SAndroid Build Coastguard Worker EXPECT_EQ(Point3F().ToString(), zero.ToString());
64*635a8641SAndroid Build Coastguard Worker
65*635a8641SAndroid Build Coastguard Worker Point3F point(1.f, -1.f, 2.f);
66*635a8641SAndroid Build Coastguard Worker point.Scale(2.f);
67*635a8641SAndroid Build Coastguard Worker point.Scale(6.f, 3.f, 1.5f);
68*635a8641SAndroid Build Coastguard Worker EXPECT_EQ(Point3F(12.f, -6.f, 6.f).ToString(), point.ToString());
69*635a8641SAndroid Build Coastguard Worker }
70*635a8641SAndroid Build Coastguard Worker
71*635a8641SAndroid Build Coastguard Worker } // namespace gfx
72