mirror of
https://github.com/c-cube/moonpool.git
synced 2025-12-06 03:05:30 -05:00
60 lines
1.1 KiB
OCaml
60 lines
1.1 KiB
OCaml
open Moonpool
|
|
|
|
let rec fib x =
|
|
if x <= 1 then
|
|
1
|
|
else
|
|
fib (x - 1) + fib (x - 2)
|
|
|
|
let () = assert (List.init 10 fib = [ 1; 1; 2; 3; 5; 8; 13; 21; 34; 55 ])
|
|
|
|
let run_test () =
|
|
let pool = Pool.create ~min:4 () in
|
|
let fibs = Array.init 30 (fun n -> Fut.spawn ~on:pool (fun () -> fib n)) in
|
|
let res = Fut.join_array fibs |> Fut.wait_block in
|
|
Pool.shutdown pool;
|
|
|
|
assert (
|
|
res
|
|
= Ok
|
|
[|
|
|
1;
|
|
1;
|
|
2;
|
|
3;
|
|
5;
|
|
8;
|
|
13;
|
|
21;
|
|
34;
|
|
55;
|
|
89;
|
|
144;
|
|
233;
|
|
377;
|
|
610;
|
|
987;
|
|
1597;
|
|
2584;
|
|
4181;
|
|
6765;
|
|
10946;
|
|
17711;
|
|
28657;
|
|
46368;
|
|
75025;
|
|
121393;
|
|
196418;
|
|
317811;
|
|
514229;
|
|
832040;
|
|
|])
|
|
|
|
let () =
|
|
for _i = 1 to 4 do
|
|
run_test ()
|
|
done;
|
|
|
|
(* now make sure we can do this with multiple pools in parallel *)
|
|
let jobs = Array.init 4 (fun _ -> Thread.create run_test ()) in
|
|
Array.iter Thread.join jobs
|