blob: 77ca16b0701688646a0a0615846681390ba2882f (
plain)
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
|
open Nock_lib
let rec find_project_root dir =
let pills_dir = Filename.concat dir "pills" in
if Sys.file_exists pills_dir && Sys.is_directory pills_dir then dir
else
let parent = Filename.dirname dir in
if String.equal parent dir then failwith "unable to locate project root containing pills/"
else find_project_root parent
let project_root =
match Sys.getenv_opt "NEOVERE_ROOT" with
| Some root -> root
| None ->
let exe_dir = Filename.dirname Sys.executable_name in
find_project_root exe_dir
let () =
Printf.printf "\n╔═══════════════════════════════════════════════════════╗\n";
Printf.printf "║ Lifecycle Formula Boot Test ║\n";
Printf.printf "╚═══════════════════════════════════════════════════════╝\n\n";
let pier_path = Filename.concat project_root "test-pier-lifecycle" in
Printf.printf "Creating test pier at: %s\n%!" pier_path;
if Sys.file_exists pier_path then begin
Printf.printf "Removing old test pier...\n%!";
let _ = Sys.command (Printf.sprintf "rm -rf '%s'" pier_path) in
()
end;
Unix.mkdir pier_path 0o755;
Printf.printf "\n[1] Creating state...\n%!";
let state = State.create ~pier_path () in
Printf.printf "\n[2] Booting ivory.pill...\n%!";
let ivory_path = Filename.concat project_root "pills/ivory.pill" in
begin match Boot.boot_ivory state ivory_path with
| Error (Boot.Invalid_pill msg) ->
Printf.printf "✗ Ivory boot failed: %s\n%!" msg;
exit 1
| Error (Boot.Unsupported msg) ->
Printf.printf "✗ Unsupported: %s\n%!" msg;
exit 1
| Ok () ->
Printf.printf "✓ Ivory kernel loaded\n\n%!";
end;
Printf.printf "[3] Booting solid.pill with lifecycle formula...\n%!";
let solid_path = Filename.concat project_root "pills/solid.pill" in
begin match Boot.boot_solid_lifecycle state solid_path with
| Error (Boot.Invalid_pill msg) ->
Printf.printf "✗ Solid boot failed: %s\n%!" msg;
exit 1
| Error (Boot.Unsupported msg) ->
Printf.printf "✗ Unsupported: %s\n%!" msg;
exit 1
| Ok () ->
let eve = State.event_number state in
Printf.printf "✓ Solid boot completed via lifecycle formula!\n%!";
Printf.printf " Events in state: %Ld\n\n%!" eve;
(* Get kernel and compute mug for verification *)
let kernel = State.arvo_core state in
Printf.printf " Kernel is_cell: %b\n" (Noun.is_cell kernel);
Printf.printf "\n╔═══════════════════════════════════════════════════════╗\n";
Printf.printf "║ Lifecycle Boot SUCCESS! 🎉 ║\n";
Printf.printf "╚═══════════════════════════════════════════════════════╝\n\n";
end;
State.close_eventlog state
|