forked from ocaml-multicore/multicoretests
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlin_tests_dsl.ml
33 lines (27 loc) · 1.08 KB
/
lin_tests_dsl.ml
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
(* ********************************************************************** *)
(* Tests of thread-unsafe [Bigarray.Array1] of ints *)
(* ********************************************************************** *)
module BA1Conf =
struct
open Bigarray
type t = (int, int_elt, c_layout) Array1.t
let array_size = 16
let init () =
let arr = Array1.create int C_layout array_size in
Array1.fill arr 0 ;
arr
let cleanup _ = ()
open Lin
let int = int_small
let api =
[ val_ "Bigarray.Array1.size_in_bytes" Array1.size_in_bytes (t @-> returning int);
val_ "Bigarray.Array1.get" Array1.get (t @-> int @-> returning_or_exc int);
val_ "Bigarray.Array1.set" Array1.set (t @-> int @-> int @-> returning_or_exc unit);
val_ "Bigarray.Array1.fill" Array1.fill (t @-> int @-> returning unit);
]
end
module BA1T = Lin_domain.Make(BA1Conf)
let _ =
QCheck_base_runner.run_tests_main [
BA1T.neg_lin_test ~count:5000 ~name:"Lin DSL Bigarray.Array1 (of ints) test with Domain";
]