File: util_pp.ml

package info (click to toggle)
ocaml-multicoretests 0.11-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,520 kB
  • sloc: ml: 8,909; awk: 66; ansic: 23; makefile: 11; sh: 1
file content (57 lines) | stat: -rw-r--r-- 2,305 bytes parent folder | download
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
(* Tests of Util.Pp *)

open Util.Pp

let pr name pp x = Printf.printf "Test of %s:\n%s\n\n" name (to_show pp x)

let seq_interval x y () =
  let rec aux i =
    let open Seq in
    if i <= y then Cons (i, fun () -> aux (i + 1)) else Nil
  in
  aux x

let fun_val () =
  let open QCheck in
  let bool = set_gen (Gen.return true) bool in (* fix co-domain/range across RNGs *)
  let gen = fun3 Observable.(option int) Observable.char Observable.string bool in
  let fun_ = Gen.generate1 gen.gen in
  let _ = Fn.apply fun_ (Some (-123456)) 'a' "xyz" in
  let _ = Fn.apply fun_ None 'b' "" in
  fun_

let _ =
  pr "pp_bool" pp_bool true;
  pr "pp_int (positive)" pp_int 12345;
  pr "pp_int (negative)" pp_int (-12345);
  pr "pp_int32 (positive)" pp_int32 12345l;
  pr "pp_int64 (negative)" pp_int64 (-12345L);
  pr "pp_float (infinity)" pp_float Float.infinity;
  pr "pp_float (neg_infinity)" pp_float Float.neg_infinity;
  pr "pp_float (nan)" pp_float nan;
(*pr "pp_float (-. nan)" pp_float (-. nan);*)
  pr "pp_float (pi)" pp_float Float.pi;
  pr "pp_char (printable)" pp_char 'a';
  pr "pp_char (unprintable)" pp_char '\000';
  pr "pp_string" pp_string "Hello world";
  pr "pp_string (long)" pp_string (String.make 1234 'a');
  pr "pp_bytes (empty)" pp_bytes Bytes.empty;
  pr "pp_bytes (long)" pp_bytes (Bytes.make 1234 'b');
  pr "pp_option pp_int (positive)" (pp_option pp_int) (Some 12345);
  pr "pp_option pp_int (negative)" (pp_option pp_int) (Some (-12345));
  pr "pp_result pp_int pp_string" (pp_result pp_int pp_string) (Ok (-12345));
  pr "pp_result pp_int pp_string" (pp_result pp_int pp_string) (Error "Failure");
  pr "pp_pair pp_char pp_int" (pp_pair pp_char pp_int) ('a', -12345);
  let l = [ 1; 2; 3; -1; -2; -3 ] in
  pr "pp_list pp_int" (pp_list pp_int) l;
  let l = l @ l @ l @ l in
  let l = l @ l @ l @ l in
  let l = l @ l @ l @ l in
  pr "pp_list pp_int (long)" (pp_list pp_int) l;
  pr "pp_seq pp_int" (pp_seq pp_int) (seq_interval (-5) 5);
  pr "pp_seq pp_int (long)" (pp_seq pp_int) (seq_interval (-50) 50);
  pr "pp_array pp_int" (pp_array pp_int) [| 1; 2; 3; -1; -2; -3 |];
  pr "pp_array pp_int (long)" (pp_array pp_int) (Array.make 100 0);
  pr "pp_record" pp_record
    [ pp_field "key" pp_int 123; pp_field "value" pp_string "content" ];
  pr "pp_fun_" pp_fun_ (fun_val ())