Size: 1219 bytes.


 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
// cs/renderer/geo/vector3_test.cc
#include "cs/renderer/geo/vector3.h"

#include <sstream>

#include "gmock/gmock.h"
#include "gtest/gtest.h"

using p3 = ::cs::renderer::geo::Point3;
using v3 = ::cs::renderer::geo::Vector3;
using ::testing::HasSubstr;

TEST(Vector3, OneArgConstructor) {
  EXPECT_EQ(v3(p3(1, 1, 1)), v3(1, 1, 1));
}

TEST(Vector3, OperatorAdd) {
  EXPECT_EQ(v3(p3(1, 1, 1)) + v3(p3(1, 2, 3)),
            v3(p3(2, 3, 4)));
}

TEST(Vector3, OperatorSubtract) {
  EXPECT_EQ(v3(p3(1, 1, 1)) - v3(p3(1, 2, 3)),
            v3(p3(0, -1, -2)));
}

TEST(Vector3, MagnitudeTest) {
  // Inline the variables for the test case
  p3 a(1.0f, 2.0f, 3.0f);
  p3 b(4.0f, 5.0f, 6.0f);
  v3 vec(b - a);

  // Calculate the magnitude manually (sqrt((4-1)^2 +
  // (5-2)^2 + (6-3)^2) = sqrt(27) ≈ 5.196152)
  EXPECT_FLOAT_EQ(vec.magnitude(), 5.196152f);
}

TEST(Vector3, Unit) {
  EXPECT_EQ(v3(p3(1, 1, 1)).unit(),
            v3(p3(0.57735026918962576450914878050196,
                  0.57735026918962576450914878050196,
                  0.57735026918962576450914878050196)));
}

TEST(Vector3, StreamOutput) {
  std::ostringstream os;
  os << v3(1.0f, 2.0f, 3.0f);
  EXPECT_THAT(os.str(), HasSubstr("Vector3("));
}
v0 (commit) © 2025 @p13i.io | Load balancer proxied to: cs-code-viewer-2:8080 in 4ms.