]> gitweb.michael.orlitzky.com - spline3.git/blob - test/TestSuite.hs
Split the exact volume test into seven separate ones.
[spline3.git] / test / TestSuite.hs
1 import Test.HUnit
2 import Test.QuickCheck
3
4 import Tests.Cardinal
5 import Tests.Cube
6 import Tests.Face as TF
7 import Tests.Misc
8 import Tests.Tetrahedron as TT
9
10 -- The list of HUnit tests.
11 test_suite = TestList (concat [face_tests,
12 misc_tests,
13 tetrahedron_tests])
14
15 main :: IO ()
16 main = do
17 putStrLn "HUnit"
18 putStrLn "-----"
19 runTestTT test_suite
20 putStrLn ""
21 putStrLn "QuickCheck"
22 putStrLn "----------"
23 let qc_args = stdArgs { maxSuccess = 100,
24 maxDiscard = 500,
25 maxSize = 100 }
26
27 putStr "prop_all_volumes_positive... "
28 quickCheckWith qc_args prop_all_volumes_positive
29
30 putStr "prop_tetrahedron0_volumes_exact... "
31 quickCheckWith qc_args prop_tetrahedron0_volumes_exact
32
33 putStr "prop_tetrahedron1_volumes_exact... "
34 quickCheckWith qc_args prop_tetrahedron1_volumes_exact
35
36 putStr "prop_tetrahedron2_volumes_exact... "
37 quickCheckWith qc_args prop_tetrahedron2_volumes_exact
38
39 putStr "prop_tetrahedron3_volumes_exact... "
40 quickCheckWith qc_args prop_tetrahedron3_volumes_exact
41
42 putStr "prop_tetrahedron4_volumes_exact... "
43 quickCheckWith qc_args prop_tetrahedron4_volumes_exact
44
45 putStr "prop_tetrahedron4_volumes_exact... "
46 quickCheckWith qc_args prop_tetrahedron4_volumes_exact
47
48 putStr "prop_tetrahedron5_volumes_exact... "
49 quickCheckWith qc_args prop_tetrahedron5_volumes_exact
50
51 putStr "prop_tetrahedron6_volumes_exact... "
52 quickCheckWith qc_args prop_tetrahedron6_volumes_exact
53
54 putStr "prop_tetrahedron7_volumes_exact... "
55 quickCheckWith qc_args prop_tetrahedron7_volumes_exact
56
57 putStr "prop_tetrahedron0_volumes_positive... "
58 quickCheckWith qc_args prop_tetrahedron0_volumes_positive
59
60 putStr "prop_tetrahedron1_volumes_positive... "
61 quickCheckWith qc_args prop_tetrahedron1_volumes_positive
62
63 putStr "prop_tetrahedron2_volumes_positive... "
64 quickCheckWith qc_args prop_tetrahedron2_volumes_positive
65
66 putStr "prop_tetrahedron3_volumes_positive... "
67 quickCheckWith qc_args prop_tetrahedron3_volumes_positive
68
69 putStr "prop_tetrahedron4_volumes_positive... "
70 quickCheckWith qc_args prop_tetrahedron4_volumes_positive
71
72 putStr "prop_tetrahedron5_volumes_positive... "
73 quickCheckWith qc_args prop_tetrahedron5_volumes_positive
74
75 putStr "prop_tetrahedron6_volumes_positive... "
76 quickCheckWith qc_args prop_tetrahedron6_volumes_positive
77
78 putStr "prop_tetrahedron7_volumes_positive... "
79 quickCheckWith qc_args prop_tetrahedron7_volumes_positive
80
81 putStr "prop_v0_all_equal... "
82 quickCheckWith qc_args prop_v0_all_equal
83
84 putStr "prop_factorial_greater... "
85 quickCheckWith qc_args prop_factorial_greater
86
87 putStr "prop_b0_v0_always_unity... "
88 quickCheckWith qc_args prop_b0_v0_always_unity
89
90 putStr "prop_b0_v1_always_zero... "
91 quickCheckWith qc_args prop_b0_v1_always_zero
92
93 putStr "prop_b0_v2_always_zero... "
94 quickCheckWith qc_args prop_b0_v2_always_zero
95
96 putStr "prop_b0_v3_always_zero... "
97 quickCheckWith qc_args prop_b0_v3_always_zero
98
99 putStr "prop_b1_v1_always_unity... "
100 quickCheckWith qc_args prop_b1_v1_always_unity
101
102 putStr "prop_b1_v0_always_zero... "
103 quickCheckWith qc_args prop_b1_v0_always_zero
104
105 putStr "prop_b1_v2_always_zero... "
106 quickCheckWith qc_args prop_b1_v2_always_zero
107
108 putStr "prop_b1_v3_always_zero... "
109 quickCheckWith qc_args prop_b1_v3_always_zero
110
111 putStr "prop_b2_v2_always_unity... "
112 quickCheckWith qc_args prop_b2_v2_always_unity
113
114 putStr "prop_b2_v0_always_zero... "
115 quickCheckWith qc_args prop_b2_v0_always_zero
116
117 putStr "prop_b2_v1_always_zero... "
118 quickCheckWith qc_args prop_b2_v1_always_zero
119
120 putStr "prop_b2_v3_always_zero... "
121 quickCheckWith qc_args prop_b2_v3_always_zero
122
123 putStr "prop_b3_v3_always_unity... "
124 quickCheckWith qc_args prop_b3_v3_always_unity
125
126 putStr "prop_b3_v0_always_zero... "
127 quickCheckWith qc_args prop_b3_v0_always_zero
128
129 putStr "prop_b3_v1_always_zero... "
130 quickCheckWith qc_args prop_b3_v1_always_zero
131
132 putStr "prop_b3_v2_always_zero... "
133 quickCheckWith qc_args prop_b3_v2_always_zero
134
135 -- putStrLn "\np. 78, (2.4)\n"
136
137 -- putStr "prop_c3000_identity... "
138 -- quickCheckWith qc_args TT.prop_c3000_identity
139
140 -- putStr "prop_c2100_identity... "
141 -- quickCheckWith qc_args TT.prop_c2100_identity
142
143 -- putStr "prop_c1110_identity... "
144 -- quickCheckWith qc_args TT.prop_c1110_identity
145
146 -- putStrLn "\np. 78, (2.5)\n"
147
148 -- putStr "prop_cijk1_identity... "
149 -- quickCheckWith qc_args prop_cijk1_identity
150 -- putStrLn "\np. 79, (2.6)\n"
151
152 -- putStr "prop_c0120_identity1... "
153 -- quickCheckWith qc_args TF.prop_c0120_identity1
154
155 -- putStr "prop_c0210_identity1... "
156 -- quickCheckWith qc_args TF.prop_c0210_identity1
157
158 -- putStr "prop_c0300_identity1... "
159 -- quickCheckWith qc_args TF.prop_c0300_identity1
160
161 -- putStr "prop_c1110_identity... "
162 -- quickCheckWith qc_args TF.prop_c1110_identity
163
164 -- putStr "prop_c1200_identity1... "
165 -- quickCheckWith qc_args prop_c1200_identity1
166
167 -- putStr "prop_c2100_identity1... "
168 -- quickCheckWith qc_args TF.prop_c2100_identity1
169
170 -- putStrLn "\np. 79, (2.7)\n"
171
172 -- putStr "prop_c0102_identity1... "
173 -- quickCheckWith qc_args TF.prop_c0102_identity1
174
175 -- putStr "prop_c0201_identity1... "
176 -- quickCheckWith qc_args TF.prop_c0201_identity1
177
178 -- putStr "prop_c0300_identity2... "
179 -- quickCheckWith qc_args TF.prop_c0300_identity2
180
181 -- putStr "prop_c1101_identity... "
182 -- quickCheckWith qc_args TF.prop_c1101_identity
183
184 -- putStr "prop_c1200_identity2... "
185 -- quickCheckWith qc_args TF.prop_c1200_identity2
186
187 -- putStr "prop_c2100_identity2... "
188 -- quickCheckWith qc_args TF.prop_c2100_identity2
189
190 -- putStrLn "\np. 79, (2.8)\n"
191
192 -- putStr "prop_c3000_identity... "
193 -- quickCheckWith qc_args TF.prop_c3000_identity
194
195 -- putStr "prop_c2010_identity... "
196 -- quickCheckWith qc_args TF.prop_c2010_identity
197
198 -- putStr "prop_c2001_identity... "
199 -- quickCheckWith qc_args TF.prop_c2001_identity
200
201 -- putStr "prop_c1020_identity... "
202 -- quickCheckWith qc_args TF.prop_c1020_identity
203
204 -- putStr "prop_c1002_identity... "
205 -- quickCheckWith qc_args TF.prop_c1002_identity
206
207 -- putStr "prop_c1011_identity... "
208 -- quickCheckWith qc_args TF.prop_c1011_identity
209
210 -- putStrLn "\np. 80, (2.9)\n"
211
212 -- putStr "prop_c0120_identity2... "
213 -- quickCheckWith qc_args TF.prop_c0120_identity2
214
215 -- putStr "prop_c0102_identity2... "
216 -- quickCheckWith qc_args TF.prop_c0102_identity2
217
218 -- putStr "prop_c0111_identity... "
219 -- quickCheckWith qc_args TF.prop_c0111_identity
220
221 -- putStr "prop_c0210_identity2... "
222 -- quickCheckWith qc_args TF.prop_c0210_identity2
223
224 -- putStr "prop_c0201_identity2... "
225 -- quickCheckWith qc_args TF.prop_c0201_identity2
226
227 -- putStr "prop_c0300_identity3... "
228 -- quickCheckWith qc_args TF.prop_c0300_identity3
229
230 putStr "prop_ccwx_rotation_changes_direction... "
231 quickCheckWith qc_args prop_ccwx_rotation_changes_direction
232
233 putStr "prop_cwx_rotation_changes_direction... "
234 quickCheckWith qc_args prop_cwx_rotation_changes_direction
235
236 return ()