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)