2017-04-05 20:24:26 +04:00
|
|
|
(**************************************************************************)
|
|
|
|
(* *)
|
2018-02-06 00:17:03 +04:00
|
|
|
(* Copyright (c) 2014 - 2018. *)
|
2017-04-05 20:24:26 +04:00
|
|
|
(* Dynamic Ledger Solutions, Inc. <contact@tezos.com> *)
|
|
|
|
(* *)
|
|
|
|
(* All rights reserved. No warranty, explicit or implicit, provided. *)
|
|
|
|
(* *)
|
|
|
|
(**************************************************************************)
|
|
|
|
|
|
|
|
exception Node_exited_prematurely
|
|
|
|
|
|
|
|
let handle_error res log_file_name =
|
|
|
|
match res with
|
|
|
|
| 0, _ ->
|
|
|
|
()
|
|
|
|
| pid, Unix.WEXITED x ->
|
|
|
|
Printf.eprintf "Wait: %d, exit %d\n\nDumping log:\n\n%!" pid x ;
|
|
|
|
ignore (Sys.command (Printf.sprintf "cat %s" log_file_name) : int) ;
|
|
|
|
raise Node_exited_prematurely
|
|
|
|
| pid, Unix.WSIGNALED x ->
|
|
|
|
Printf.eprintf "Wait: %d, signaled %d\n\nDumping log:\n\n%!" pid x ;
|
|
|
|
ignore (Sys.command (Printf.sprintf "cat %s" log_file_name) : int) ;
|
|
|
|
raise Node_exited_prematurely
|
|
|
|
| pid, Unix.WSTOPPED x ->
|
|
|
|
Printf.eprintf "Wait: %d, stopped %d\n\nDumping log:\n\n%!" pid x ;
|
|
|
|
ignore (Sys.command (Printf.sprintf "cat %s" log_file_name) : int) ;
|
|
|
|
raise Node_exited_prematurely
|
|
|
|
|
2018-02-02 20:38:35 +04:00
|
|
|
let fork_node ?exe ?(timeout = 4) ?(port = 18732) ?sandbox () =
|
2017-04-05 20:24:26 +04:00
|
|
|
let data_dir =
|
|
|
|
Printf.sprintf
|
|
|
|
"%s/tezos_node_%6X"
|
|
|
|
(Filename.get_temp_dir_name ())
|
|
|
|
(Random.int 0xFF_FF_FF) in
|
|
|
|
let log_file_name, log_file =
|
|
|
|
Filename.open_temp_file "tezos_node_" ".log" in
|
2018-04-09 18:28:43 +04:00
|
|
|
let sandbox =
|
|
|
|
match sandbox with
|
|
|
|
| None -> None
|
|
|
|
| Some json ->
|
|
|
|
let file_name, ch =
|
|
|
|
Filename.open_temp_file "tezos_node_" ".log" in
|
|
|
|
Printf.fprintf ch "%s%!"
|
|
|
|
(Data_encoding.Json.to_string json) ;
|
|
|
|
close_out ch ;
|
|
|
|
Some file_name in
|
2017-04-05 20:24:26 +04:00
|
|
|
let log_fd = Unix.descr_of_out_channel log_file in
|
|
|
|
let null_fd = Unix.(openfile "/dev/null" [O_RDONLY] 0o644) in
|
2017-10-27 22:45:31 +04:00
|
|
|
let exe =
|
2018-02-02 20:38:35 +04:00
|
|
|
match exe with
|
|
|
|
| Some exe -> exe
|
|
|
|
| None ->
|
|
|
|
let (//) = Filename.concat in
|
|
|
|
try
|
|
|
|
let path = Sys.argv.(1) in
|
|
|
|
if Filename.is_relative path then
|
|
|
|
Sys.getcwd () // ".." // path
|
|
|
|
else
|
|
|
|
path
|
|
|
|
with _ -> Sys.getcwd () // ".." // "bin_node" // "main.exe" in
|
2017-04-05 20:24:26 +04:00
|
|
|
let pid =
|
2017-10-27 22:45:31 +04:00
|
|
|
Unix.create_process exe
|
2017-04-05 20:24:26 +04:00
|
|
|
[| "tezos-node" ;
|
|
|
|
"run" ;
|
|
|
|
"--data-dir"; data_dir ;
|
|
|
|
(match sandbox with
|
|
|
|
| None -> "--sandbox"
|
|
|
|
| Some path -> "--sandbox=" ^ path);
|
|
|
|
"--rpc-addr"; "[::]:" ^ string_of_int port |]
|
|
|
|
null_fd log_fd log_fd in
|
|
|
|
Printf.printf "Created node, pid: %d, log: %s\n%!" pid log_file_name ;
|
|
|
|
Printf.printf "Waiting %d seconds for its initialisation\n%!" timeout ;
|
|
|
|
Unix.sleep timeout ;
|
|
|
|
match Unix.waitpid [Unix.WNOHANG] pid with
|
|
|
|
| 0, _ ->
|
|
|
|
Pervasives.at_exit begin fun () ->
|
|
|
|
begin
|
|
|
|
match Unix.waitpid [Unix.WNOHANG] pid with
|
|
|
|
| 0, _ ->
|
|
|
|
Unix.kill pid Sys.sigkill ;
|
|
|
|
Unix.sleep 1
|
|
|
|
| res ->
|
|
|
|
handle_error res log_file_name
|
|
|
|
end ;
|
2018-04-09 18:28:43 +04:00
|
|
|
ignore (Sys.command (Printf.sprintf "rm -fr \"%s\"" data_dir)) ;
|
|
|
|
match sandbox with
|
|
|
|
| None -> ()
|
|
|
|
| Some file -> ignore (Sys.command (Printf.sprintf "rm -f \"%s\"" file))
|
2017-04-05 20:24:26 +04:00
|
|
|
end ;
|
|
|
|
pid
|
|
|
|
| res ->
|
|
|
|
handle_error res log_file_name ;
|
|
|
|
0
|