ocaml-containers/tests/data/t_immutarray.ml
Simon Cruanes 10865eaced reformat
2022-07-04 13:36:06 -04:00

77 lines
1.9 KiB
OCaml

module Test = (val Containers_testlib.make ~__FILE__ ())
open Test
open CCImmutArray
let print_array f a = to_list a |> Array.of_list |> Q.Print.(array f);;
eq ~printer:(print_array Q.Print.int) (of_list [ 0 ]) (set (of_list [ 5 ]) 0 0)
;;
eq ~printer:(print_array Q.Print.int)
(of_list [ 1; 3; 4; 5 ])
(set (of_list [ 1; 2; 4; 5 ]) 1 3)
let eq' = eq ~printer:(print_array Q.Print.int);;
eq' empty (append empty empty);;
eq' (of_list [ 1; 2; 3 ]) (append empty (of_list [ 1; 2; 3 ]));;
eq' (of_list [ 1; 2; 3 ]) (append (of_list [ 1; 2; 3 ]) empty);;
eq'
(of_list [ 3; 1; 4; 1; 5 ])
(append (of_list [ 3; 1 ]) (of_list [ 4; 1; 5 ]))
;;
eq
~printer:Q.Print.(list (pair int string))
[ 2, "baz"; 1, "bar"; 0, "foo" ]
(foldi (fun l i a -> (i, a) :: l) [] (of_list [ "foo"; "bar"; "baz" ]))
let eq' = eq ~printer:Q.Print.bool;;
eq' true (for_all (fun _ -> false) empty);;
eq' false (for_all (fun _ -> false) (singleton 3));;
eq' true (for_all (fun n -> n mod 2 = 0) (of_list [ 2; 4; 8 ]));;
eq' false (for_all (fun n -> n mod 2 = 0) (of_list [ 2; 4; 5; 8 ]));;
eq' false (exists (fun _ -> true) empty);;
eq' true (exists (fun _ -> true) (singleton 3));;
eq' false (exists (fun _ -> false) (singleton 3));;
eq' false (exists (fun n -> n mod 2 = 1) (of_list [ 2; 4; 8 ]));;
eq' true (exists (fun n -> n mod 2 = 1) (of_list [ 2; 4; 5; 8 ]));;
q
Q.(list bool)
(fun l ->
let a = of_list l in
not @@ exists (fun b -> b) a = for_all not a)
;;
q
Q.(list bool)
(fun l ->
let a = of_list l in
not @@ for_all (fun b -> b) a = exists not a)
;;
q
Q.(list bool)
(fun l -> exists (fun b -> b) (of_list l) = List.fold_left ( || ) false l)
;;
q
Q.(list bool)
(fun l -> for_all (fun b -> b) (of_list l) = List.fold_left ( && ) true l)
;;
q
Q.(list int)
(fun l ->
let g = Iter.of_list l in
of_iter g |> to_iter |> Iter.to_list = l)
;;
q
Q.(list int)
(fun l ->
let g = Gen.of_list l in
of_gen g |> to_gen |> Gen.to_list = l)