blob: 18aae1f49f7fcb0be9af98edd6f7ccc50a443f4e (
plain)
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
|
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;
] )
|