package tezt-tezos

  1. Overview
  2. Docs
Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source

Module Tezt_tezos.Sc_rollup_nodeSource

Spawn smart-contract rollup nodes and control them.

This module follows the same conventions as in Node. We write sc node to refer to smart-contract rollup node.

Sourcetype t

Smart contract rollup node states.

Sourcetype purpose =
  1. | Operating
  2. | Batching
  3. | Cementing
  4. | Recovering
Sourcetype operation_kind =
  1. | Publish
  2. | Add_messages
  3. | Cement
  4. | Timeout
  5. | Refute
  6. | Recover
  7. | Execute_outbox_message
Sourcetype mode =
  1. | Batcher
  2. | Custom of operation_kind list
  3. | Maintenance
  4. | Observer
  5. | Operator
  6. | Accuser
  7. | Bailout
Sourcetype history_mode =
  1. | Archive
  2. | Full
Sourcetype event = {
  1. name : string;
  2. value : Tezt_wrapper.JSON.t;
  3. timestamp : float;
}
Sourceval mode_of_string : string -> mode

Returns the associated mode, fails if the mode is not valid.

Sourceval string_of_history_mode : history_mode -> string

Returns the string representation of an history mode.

Sourceval create : ?runner:Tezt_wrapper.Runner.t -> ?path:string -> ?name:string -> ?color:Tezt_wrapper.Log.Color.t -> ?data_dir:string -> base_dir:string -> ?event_pipe:string -> ?rpc_host:string -> ?rpc_port:int -> ?operators:(purpose * string) list -> ?default_operator:string -> ?dal_node:Dal_node.t -> mode -> Node.t -> t

Create a smart contract rollup node.

A smart contract rollup node is associated to a tezos node passed as argument.

The standard output and standard error output of the sc node will be logged with prefix name and color color.

Default data_dir is a temporary directory which is always the same for each name.

dal_node is a node node from the data availability layer the rollup should be connected to.

Default event_pipe is a temporary file whose name is derived from name. It will be created as a named pipe so that sc node events can be received.

Default values for net_port or rpc_port are chosen automatically with values starting from 17384 (configurable with `--starting-port`). They are used by config_init and by functions from the Client module. They are not used by run, so if you do not call config_init or generate the configuration file through some other means, your sc node will not listen.

Sourceval create_with_endpoint : ?runner:Tezt_wrapper.Runner.t -> ?path:string -> ?name:string -> ?color:Tezt_wrapper.Log.Color.t -> ?data_dir:string -> base_dir:string -> ?event_pipe:string -> ?rpc_host:string -> ?rpc_port:int -> ?operators:(purpose * string) list -> ?default_operator:string -> ?dal_node:Dal_node.t -> mode -> Client.endpoint -> t

Do not assume we are running the rollup node against a local octez node.

Sourceval write_in_stdin : t -> string -> unit Lwt.t

write_in_stdin rollup_node str write str into the stdin of the rollup node process.

Sourceval name : t -> string

Get the name of an sc node.

Sourceval color : t -> Tezt_wrapper.Log.Color.t

Get the color of the logs of a smart rollup node.

Sourceval rpc_host : t -> string

Get the RPC host given as --rpc-addr to an sc node.

Sourceval rpc_port : t -> int

Get the RPC port given as --rpc-addr to an sc node.

Sourceval endpoint : t -> string

Return the endpoint of the sc node, i.e., http://rpc_host:rpc_port.

Sourceval data_dir : t -> string

Get the data-dir of an sc node.

Sourceval base_dir : t -> string

Get the base-dir of an sc node

Sourceval string_of_purpose : purpose -> string
Sourceval check_error : ?exit_code:int -> ?msg:Tezt_wrapper.Base.rex -> t -> unit Lwt.t

Wait until an sc node terminates and check its status.

If the sc node is not running, or if the process returns an exit code which is not exit_code, or if msg does not match the stderr output, fail the test.

If exit_code is not specified, any non-zero code is accepted. If no msg is given, the stderr is ignored.

Sourceval run : ?legacy:bool -> ?restart:bool -> ?mode:mode -> ?event_level:Daemon.Level.default_level -> ?event_sections_levels:(string * Daemon.Level.level) list -> ?loser_mode:string -> ?allow_degraded:bool -> ?gc_frequency:int -> ?history_mode:history_mode -> ?wait_ready:bool -> ?password_file:string -> t -> string -> string list -> unit Lwt.t

run ?event_level ?event_sections_levels ?loser_mode ?allow_degraded ?gc_frequency ?history_mode ?wait_ready node rollup_address arguments launches the given smart contract rollup node for the rollup at rollup_address with the given extra arguments. event_level and event_sections_levels allow to select which events we want the node to emit (see Daemon). legacy (by default false) must be set if we want to use the legacy run command of the node (which requires a config file to exist). If wait_ready is false, tezt does not wait for the node to be ready. If restart is true, it will stop and restart the node if it is already running. gc_frequency is 1 by default to make the rollup GC on every occasion during tests.

Sourceval spawn_run : ?loser_mode:string -> ?allow_degraded:bool -> ?gc_frequency:int -> ?history_mode:history_mode -> t -> string -> string list -> Tezt_wrapper.Process.t

spawn_run ?loser_mode ?allow_degraded node ?gc_frequency ?history_mode rollup_address arguments is a lightweight version of run that spawns a process.

Sourceval wait : t -> Unix.process_status Lwt.t

Wait until a node terminates and return its status. If the node is not running, make the test fail.

Sourceval process : t -> Tezt_wrapper.Process.t option

Returns None if node is already terminated or returns the node process if it still running.

Sourceval terminate : ?timeout:float -> t -> unit Lwt.t

Send SIGTERM and wait for the process to terminate.

Default timeout is 30 seconds, after which SIGKILL is sent.

Sourceval kill : t -> unit Lwt.t

Send SIGKILL and wait for the process to terminate.

Sourceval config_init : t -> ?force:bool -> ?loser_mode:string -> ?gc_frequency:int -> ?history_mode:history_mode -> string -> string Lwt.t

Initialize the rollup node configuration file with octez-sc-rollup-node-alpha config init. Returns the name of the resulting configuration file.

Sourceval spawn_config_init : t -> ?force:bool -> ?loser_mode:string -> ?gc_frequency:int -> ?history_mode:history_mode -> string -> Tezt_wrapper.Process.t

Initialize the rollup node configuration file with octez-sc-rollup-node-alpha config init and return the corresponding process.

Sourcemodule Config_file : sig ... end

Sc node configuration files.

Sourceval wait_for_ready : t -> unit Lwt.t

Wait until the sc node is ready.

More precisely, wait until a node_is_ready event occurs. If such an event already occurred, return immediately.

Sourceval wait_for_level : ?timeout:float -> t -> int -> int Lwt.t

Wait until the layer 1 of the sc node is synchronized with some given tezos level.

More precisely, wait until a new_head event with a large enough level occurs. If such an event already occurred, return immediately.

If timeout is provided, stop waiting if timeout seconds have passed.

Sourceval unsafe_wait_sync : ?path_client:string -> ?timeout:float -> t -> int Lwt.t

Unbounded variant of wait_for_sync. Do not use in a Tezt tests, as it has been proven time and again that it is a source of waste of CI time when a test is buggy or flaky.

This variant of wait_for_sync should not be used in sandboxes, as it has been witnessed time and time again that these tests are more subject to race conditions when setting up rollup infrastructure. On open testnets like weeklynet and dailynet, this does not happen because of the large block time.

Sourceval wait_sync : ?path_client:string -> t -> timeout:float -> int Lwt.t

Wait until the layer 1 of the sc node is synchronized with its underlying l1 node.

Sourceval wait_for : ?where:string -> t -> string -> (Tezt_wrapper.JSON.t -> 'a option) -> 'a Lwt.t

wait_for ?where sc_node event_name filter waits for the SCORU node sc_node to emit an event named name (usually this is the name the event is declared with, concatenated with ".v0"). wait_for continues to wait until an event which satisfies the filter (i.e. for which the function returns Some _) is produced, in which case the result of the filter is returned. where, if present, should describe the constraint that filter applies.

Sourceval on_event : t -> (event -> unit) -> unit

Add a callback to be called whenever the daemon emits an event.

Sourceval change_node_and_restart : ?event_level:Daemon.Level.default_level -> t -> string -> Node.t -> unit Lwt.t

Stops the rollup node and restart it, connected to another Tezos Layer 1 node.

Sourceval change_node_mode : t -> mode -> t

Change the rollup mode. This does not terminate nor restart the node. Change will take effect when the node is run/restart.

Sourceval dump_durable_storage : sc_rollup_node:t -> dump:string -> ?block:string -> unit -> unit Lwt.t

dump_durable_storage ~sc_rollup_node ~dump ?string () writes to dump the current state of the WASM PVM from sc_rollup_node.

Sourceval export_snapshot : t -> string -> string Runnable.process

export_snapshot rollup_node dir creates a snapshot of the rollup node in directory dir.

Sourceval as_rpc_endpoint : t -> Endpoint.t

Expose the RPC server address of this node as a foreign endpoint.