diff options
Diffstat (limited to 'test/type_of.ml')
-rw-r--r-- | test/type_of.ml | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/test/type_of.ml b/test/type_of.ml new file mode 100644 index 0000000..18aae1f --- /dev/null +++ b/test/type_of.ml @@ -0,0 +1,58 @@ +module Check = Make_checkTest.M (Qsp_syntax.Type_of) + +let _position = (Lexing.dummy_pos, Lexing.dummy_pos) + +let _test_instruction : string -> Qsp_syntax.Report.t list -> unit = + Check._test_instruction + +let type_mismatch () = + _test_instruction {|abc = 'ABC'|} + [ + { + level = Error; + loc = _position; + message = "The type Integer is expected but got String"; + }; + ] + +let type_conversion () = + _test_instruction {|abc = '123'|} + [ + { + level = Debug; + loc = _position; + message = "The type Integer is expected but got Integer as String"; + }; + ] + +let type_comparaison () = _test_instruction {|(abc = '123')|} [] + +let type_comparaison_mismatch () = + _test_instruction {|(abc = 'ABC')|} + [ + { + level = Warn; + loc = _position; + message = "The type String is expected but got Integer"; + }; + ] + +let wrong_predicate () = + _test_instruction {| if $var and 1: 0 |} + [ + { + level = Warn; + loc = _position; + message = "The type Bool is expected but got String"; + }; + ] + +let test = + ( "Typechecking", + [ + Alcotest.test_case "Assign" `Quick type_mismatch; + Alcotest.test_case "Conversion" `Quick type_conversion; + Alcotest.test_case "Comparaison" `Quick type_comparaison; + Alcotest.test_case "Comparaison Mismatch" `Quick type_comparaison_mismatch; + Alcotest.test_case "Wrong predicate" `Quick wrong_predicate; + ] ) |