File: StdMeshVectorTest.cpp

package info (click to toggle)
openclonk 8.1-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 169,656 kB
  • sloc: cpp: 180,484; ansic: 108,988; xml: 31,371; python: 1,223; php: 767; makefile: 148; sh: 101; javascript: 34
file content (100 lines) | stat: -rw-r--r-- 3,067 bytes parent folder | download | duplicates (5)
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
/*
 * OpenClonk, http://www.openclonk.org
 *
 * Copyright (c) 2015, The OpenClonk Team and contributors
 *
 * Distributed under the terms of the ISC license; see accompanying file
 * "COPYING" for details.
 *
 * "Clonk" is a registered trademark of Matthes Bender, used with permission.
 * See accompanying file "TRADEMARK" for details.
 *
 * To redistribute this file separately, substitute the full license texts
 * for the above references.
 */

// Tests StdMeshMath classes

#include <gtest/gtest.h>
#include <gmock/gmock.h>

#include "C4Include.h"
#include "lib/StdMeshMath.h"

void PrintTo(const StdMeshVector &vec, ::std::ostream *os)
{
	*os << "{ " << vec.x << ", " << vec.y << ", " << vec.z << " }";
}

auto VectorEq = [](float x, float y, float z) {
	return ::testing::AllOf(
		::testing::Field(&StdMeshVector::x, ::testing::FloatEq(x)),
		::testing::Field(&StdMeshVector::y, ::testing::FloatEq(y)),
		::testing::Field(&StdMeshVector::z, ::testing::FloatEq(z))
		);
};

TEST(StdMeshVector, InitializerTest)
{
	StdMeshVector z = StdMeshVector::Zero();
	EXPECT_THAT(z, VectorEq(0.0f, 0.0f, 0.0f));

	StdMeshVector id = StdMeshVector::UnitScale();
	EXPECT_THAT(id, VectorEq(1.0f, 1.0f, 1.0f));

	StdMeshVector xl = StdMeshVector::Translate(4.0f, 29.0f, 15.0f);
	EXPECT_THAT(xl, VectorEq(4.0f, 29.0f, 15.0f));
}

TEST(StdMeshVector, VecOpVecTest)
{
	const StdMeshVector v1 = StdMeshVector::Translate(1.0f, 3.0f, 7.0f);
	const StdMeshVector v2 = StdMeshVector::Translate(2.0f, 4.0f, 8.0f);

	EXPECT_THAT(v1 + v2, VectorEq(3.0f, 7.0f, 15.0f));
	EXPECT_THAT(v2 + v1, VectorEq(3.0f, 7.0f, 15.0f));
	
	EXPECT_THAT(v1 * v2, VectorEq(2.0f, 12.0f, 56.0f));
	EXPECT_THAT(v2 * v1, VectorEq(2.0f, 12.0f, 56.0f));

	EXPECT_THAT(v1 / v2, VectorEq(0.5f, 0.75f, 0.875f));
	EXPECT_THAT(v2 / v1, VectorEq(2.0f, 1.33333333f, 1.14285719f));
}

TEST(StdMeshVector, VecOpFloatTest)
{
	const StdMeshVector v1 = StdMeshVector::Translate(1.0f, 3.0f, 7.0f);
	const StdMeshVector v2 = StdMeshVector::Translate(2.0f, 4.0f, 8.0f);

	EXPECT_THAT(v1 * 2.0f, VectorEq(2.0f, 6.0f, 14.0f));
	EXPECT_THAT(3.0f * v2, VectorEq(6.0f, 12.0f, 24.0f));
	EXPECT_THAT(v2 * 0.5f, VectorEq(1.0f, 2.0f, 4.0f));

	EXPECT_THAT(v2 / 2.0f, VectorEq(1.0f, 2.0f, 4.0f));
	EXPECT_THAT(2.0f / v2, VectorEq(1.0f, 0.5f, 0.25f));
	EXPECT_THAT(v1 / v1, VectorEq(1.0f, 1.0f, 1.0f));
	
	EXPECT_THAT(v1 * 0.5f, VectorEq(0.5f, 1.5f, 3.5f));
	EXPECT_THAT(0.5f * v1, VectorEq(0.5f, 1.5f, 3.5f));

	EXPECT_THAT(v2 / 8.0f, VectorEq(0.25f, 0.5f, 1.0f));
	EXPECT_THAT(8.0f / v2, VectorEq(4.0f, 2.0f, 1.0f));

	StdMeshVector v3 = v2;
	v3 *= 2.0f;
	EXPECT_THAT(v3, VectorEq(4.0f, 8.0f, 16.0f));

	StdMeshVector v4 = v2;
	v4 += v1;
	EXPECT_THAT(v4, VectorEq(3.0f, 7.0f, 15.0f));

	StdMeshVector c12 = StdMeshVector::Cross(v1, v2);
	EXPECT_THAT(c12, VectorEq(-4.0f, 6.0f, -2.0f));
	StdMeshVector c21 = StdMeshVector::Cross(v2, v1);
	EXPECT_THAT(c21, VectorEq(4.0f, -6.0f, 2.0f));

	StdMeshVector c11 = StdMeshVector::Cross(v1, v1);
	EXPECT_THAT(c11, VectorEq(0.0f, 0.0f, 0.0f));

	EXPECT_THAT(-v1, VectorEq(-1.0f, -3.0f, -7.0f));
}