File: uStorageTest.ml

package info (click to toggle)
camomile 2.0.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 39,888 kB
  • sloc: ml: 14,026; xml: 230; makefile: 22
file content (113 lines) | stat: -rw-r--r-- 4,067 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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
(* Tests for UStorage *)

open Camomile
open UPervasives
open Blender
open Printf

module Make (Text : UnicodeString.Type) = struct
  let test ?(char_gen = fun _ -> uchar_of_int (Random.int 0x8000000)) ~desc ~log
      () =
    random_test ~desc ~log
      ~data:(fun size -> Array.init size char_gen)
      ~body:(fun a ->
        expect_pass ~body:(fun () ->
            (* tests for ustring *)
            let s = Text.init (Array.length a) (Array.get a) in
            let len = Text.length s in
            expect_equal ~msg:(lazy "init") len (Array.length a);

            for _ = 0 to 50 do
              let i = Random.int len in
              expect_equal
                ~msg:(lazy (sprintf "set/get: location %d" i))
                (Text.get s i) a.(i)
            done;

            let r = ref 0 in
            Text.iter
              (fun u ->
                expect_equal
                  ~msg:(lazy (sprintf "iter: location %d" !r))
                  u a.(!r);
                incr r)
              s;
            expect_equal ~msg:(lazy (sprintf "iter: count %d" !r)) !r len;

            let cur = ref (Text.nth s 0) in
            let r = ref 0 in
            while not (Text.out_of_range s !cur) do
              expect_equal
                ~msg:(lazy (sprintf "index look: location %d" !r))
                (Text.look s !cur) a.(!r);
              cur := Text.next s !cur;
              incr r
            done;
            expect_equal ~msg:(lazy (sprintf "index: count %d" !r)) !r len;

            for _ = 0 to 100 do
              let pos = Random.int len in
              let cur = Text.nth s pos in
              expect_equal
                ~msg:(lazy (sprintf "nth: location %d" pos))
                (Text.look s cur) a.(pos);
              if pos = 0 then ()
              else (
                let cur' = Text.prev s cur in
                expect_equal_app
                  ~msg:(lazy (sprintf "cursor prev : location %d" pos))
                  (fun () -> Text.look s cur')
                  ()
                  (fun i -> a.(i))
                  (pos - 1);
                if pos = len - 1 then ()
                else (
                  let cur' = Text.next s cur in
                  expect_equal_app
                    ~msg:(lazy (sprintf "cursor next : location %d" pos))
                    (fun () -> Text.look s cur')
                    ()
                    (fun i -> a.(i))
                    (pos + 1)))
              (* let m = Random.int 32 in
                 if pos + m < 0 || pos + m >= len then () else
                 let cur' = Text.move s cur m in
                 expect_equal_app
                 ~msg:(lazy (sprintf "cursor move : location %d, move %d" pos m))
                 (fun () -> Text.look s cur') ()
                 (fun i -> a.(i)) (pos + m); *)
            done;

            (* Buffer *)
            let b = Text.Buf.create 0 in

            let p = Random.int len in
            let s1 = Text.init p (Array.get a) in
            let s2 = Text.init (len - p) (fun x -> Array.get a (p + x)) in

            Text.Buf.add_string b s1;
            Text.Buf.add_string b s2;
            let s' = Text.Buf.contents b in
            expect_true ~msg:(lazy "step 1") (Text.compare s s' = 0);

            Text.Buf.clear b;
            Text.iter (Text.Buf.add_char b) s;
            let s' = Text.Buf.contents b in
            expect_true ~msg:(lazy "step 2") (Text.compare s s' = 0);

            Text.Buf.clear b;
            let b' = Text.Buf.create 16 in
            let pos = Random.int len in
            for i = 0 to len - 1 do
              if i < pos then Text.Buf.add_char b a.(i)
              else Text.Buf.add_char b' a.(i)
            done;
            Text.Buf.add_buffer b b';
            let s' = Text.Buf.contents b in
            expect_true ~msg:(lazy "step 3") (Text.compare s s' = 0);

            Text.Buf.reset b;
            Text.Buf.add_string b s;
            let s' = Text.Buf.contents b in
            expect_true ~msg:(lazy "step 4") (Text.compare s s' = 0)))
end