import Test.HUnit
import Test.QuickCheck (Testable ())
+import FunctionValues (function_values_tests, function_values_properties)
+import Misc (misc_tests, misc_properties)
import Tests.Cardinal
import Tests.Cube as TC
-import Tests.FunctionValues
import Tests.Grid
-import Tests.Misc
import Tests.Tetrahedron as TT
main :: IO ()
testGroup "Cardinal Tests" [
tc "c-tilde_2100 rotation correct" test_c_tilde_2100_rotation_correct ]
-function_values_tests :: Test.Framework.Test
-function_values_tests =
- testGroup "FunctionValues Tests" [ tc "test directions" test_directions ]
grid_tests :: Test.Framework.Test
grid_tests =
tc "tetrahedra collision test isn't too sensitive"
test_tetrahedra_collision_sensitivity,
tc "trilinear reproduced" test_trilinear_reproduced,
- tc "zeros reproduced" test_zeros_reproduced,
- tc "trilinear9x9x9 reproduced" test_trilinear9x9x9_reproduced ]
-
+ tc "zeros reproduced" test_zeros_reproduced ]
-misc_tests :: Test.Framework.Test
-misc_tests =
- testGroup "Misc Tests" [
- tc "flatten (1)" test_flatten1 ]
tetrahedron_tests :: Test.Framework.Test
tetrahedron_tests =
tp :: Test.QuickCheck.Testable a => Test.Framework.TestName -> a -> Test.Framework.Test
tp = testProperty
-misc_properties :: Test.Framework.Test
-misc_properties =
- testGroup "Misc Properties" [
- tp "factorial greater" prop_factorial_greater ]
cardinal_properties :: Test.Framework.Test
cardinal_properties =
cube_properties :: Test.Framework.Test
cube_properties =
testGroup "Cube Properties" [
+ tp "front/back tetrahedra are disjoint" prop_front_back_tetrahedra_disjoint,
+ tp "top/down tetrahedra are disjoint" prop_top_down_tetrahedra_disjoint,
+ tp "left/right tetrahedra are disjoint" prop_left_right_tetrahedra_disjoint,
tp "all volumes positive" prop_all_volumes_positive,
tp "all volumes exact" prop_all_volumes_exact,
tp "v0 all equal" prop_v0_all_equal,
tp "swapping_vertices_doesnt_affect_coefficients3"
$ prop_swapping_vertices_doesnt_affect_coefficients3,
tp "swapping_vertices_doesnt_affect_coefficients4"
- $ prop_swapping_vertices_doesnt_affect_coefficients4,
- tp "x rotation doesn't affect front" prop_x_rotation_doesnt_affect_front,
- tp "x rotation doesn't affect back" prop_x_rotation_doesnt_affect_back,
- tp "y rotation doesn't affect left" prop_y_rotation_doesnt_affect_left,
- tp "y rotation doesn't affect right" prop_y_rotation_doesnt_affect_right,
- tp "z rotation doesn't affect top" prop_z_rotation_doesnt_affect_top,
- tp "z rotation doesn't affect down" prop_z_rotation_doesnt_affect_down ]
-
+ $ prop_swapping_vertices_doesnt_affect_coefficients4 ]
+
+
+-- Do the slow tests last so we can stop paying attention.
+slow_tests :: Test.Framework.Test
+slow_tests =
+ testGroup "Slow Tests" [
+ tp "cube indices within bounds" prop_cube_indices_never_go_out_of_bounds,
+ tc "trilinear9x9x9 reproduced" test_trilinear9x9x9_reproduced ]
+
+
tests :: [Test.Framework.Test]
tests = [ cardinal_tests,
function_values_tests,
-- p78_25_properties,
p79_26_properties,
p79_27_properties,
- p79_28_properties ]
+ p79_28_properties,
+ slow_tests ]