1 module doml.tests.ray_aabb_intersect_test;
2 
3 import doml.ray_aabb_intersection;
4 import doml.tests.dunit_tests;
5 import std.stdio;
6 
7 /*
8  * The MIT License
9  *
10  * Copyright (c) 2016-2021 JOML.
11  &^^%$ Translated by jordan4ibanez
12  *
13  * Permission is hereby granted, free of charge, to any person obtaining a copy
14  * of this software and associated documentation files (the "Software"), to deal
15  * in the Software without restriction, including without limitation the rights
16  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
17  * copies of the Software, and to permit persons to whom the Software is
18  * furnished to do so, subject to the following conditions:
19  *
20  * The above copyright notice and this permission notice shall be included in
21  * all copies or substantial portions of the Software.
22  *
23  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
24  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
26  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
28  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
29  * THE SOFTWARE.
30  */
31 
32 /**
33  * Tests for the {@link RayAabIntersection}.
34  * 
35  * @author Kai Burjack
36  */
37 unittest {
38 
39     writeln("\nTESTING RAY AABB INTERSECT\n");
40 
41     // testPX
42     {
43         RayAabIntersection r = RayAabIntersection();
44         r.set(-1, 0, 0, 1, 0, 0);
45         assertTrue(r.test(-0.5f, -0.5f, -0.5f, 0.5f, 0.5f, 0.5f));
46     }
47 
48     // testPY
49     {
50         RayAabIntersection r = RayAabIntersection();
51         r.set(0, -1, 0, 0, 1, 0);
52         assertTrue(r.test(-0.5f, -0.5f, -0.5f, 0.5f, 0.5f, 0.5f));
53     }
54 
55     // testPZ
56     {
57         RayAabIntersection r = RayAabIntersection();
58         r.set(0, 0, -1, 0, 0, 1);
59         assertTrue(r.test(-0.5f, -0.5f, -0.5f, 0.5f, 0.5f, 0.5f));
60     }
61 
62     // testNX
63     {
64         RayAabIntersection r = RayAabIntersection();
65         r.set(1, 0, 0, -1, 0, 0);
66         assertTrue(r.test(-0.5f, -0.5f, -0.5f, 0.5f, 0.5f, 0.5f));
67     }
68 
69     // testNY
70     {
71         RayAabIntersection r = RayAabIntersection();
72         r.set(0, 1, 0, 0, -1, 0);
73         assertTrue(r.test(-0.5f, -0.5f, -0.5f, 0.5f, 0.5f, 0.5f));
74     }
75 
76     // testNZ
77     {
78         RayAabIntersection r = RayAabIntersection();
79         r.set(0, 0, 1, 0, 0, -1);
80         assertTrue(r.test(-0.5f, -0.5f, -0.5f, 0.5f, 0.5f, 0.5f));
81     }
82 
83     // testPXPY
84     {
85         RayAabIntersection r = RayAabIntersection();
86         r.set(-1, -1, 0, 1, 1, 0);
87         assertTrue(r.test(-0.5f, -0.5f, -0.5f, 0.5f, 0.5f, 0.5f));
88     }
89 
90     // testPXEdge
91     {
92         RayAabIntersection r = RayAabIntersection();
93         r.set(-1, 0.5f, 0, 1, 0, 0);
94         assertTrue(r.test(-0.5f, -0.5f, -0.5f, 0.5f, 0.5f, 0.5f));
95     }
96 
97     // testPXEdgeDelta
98     {
99         RayAabIntersection r = RayAabIntersection();
100         r.set(-1, 0.500001f, 0, 1, 0, 0);
101         assertFalse(r.test(-0.5f, -0.5f, -0.5f, 0.5f, 0.5f, 0.5f));
102     }
103 
104     // testNXEdge
105     {
106         RayAabIntersection r = RayAabIntersection();
107         r.set(-1, -0.5f, 0, 1, 0, 0);
108         assertTrue(r.test(-0.5f, -0.5f, -0.5f, 0.5f, 0.5f, 0.5f));
109     }
110 
111     // testNXEdgeDelta
112     {
113         RayAabIntersection r = RayAabIntersection();
114         r.set(-1, -0.500001f, 0, 1, 0, 0);
115         assertFalse(r.test(-0.5f, -0.5f, -0.5f, 0.5f, 0.5f, 0.5f));
116     }
117     writeln("PASSED!");
118 }