253 lines
10 KiB
TOML
253 lines
10 KiB
TOML
name = "lotus-soup"
|
|
|
|
[defaults]
|
|
builder = "docker:go"
|
|
runner = "local:docker"
|
|
|
|
[builders."exec:go"]
|
|
enabled = true
|
|
|
|
[builders."docker:go"]
|
|
enabled = true
|
|
# build_base_image = "iptestground/oni-buildbase:v15-lotus"
|
|
# runtime_image = "iptestground/oni-runtime:v10-debug"
|
|
|
|
[runners."local:exec"]
|
|
enabled = true
|
|
|
|
[runners."local:docker"]
|
|
enabled = true
|
|
|
|
[runners."cluster:k8s"]
|
|
enabled = true
|
|
|
|
######################
|
|
##
|
|
## Testcases
|
|
##
|
|
######################
|
|
|
|
[[testcases]]
|
|
name = "deals-e2e"
|
|
instances = { min = 1, max = 100, default = 5 }
|
|
|
|
[testcases.params]
|
|
clients = { type = "int", default = 1 }
|
|
miners = { type = "int", default = 1 }
|
|
balance = { type = "float", default = 1 }
|
|
sectors = { type = "int", default = 1 }
|
|
role = { type = "string" }
|
|
|
|
genesis_timestamp_offset = { type = "int", default = 0 }
|
|
|
|
random_beacon_type = { type = "enum", default = "mock", options = ["mock", "local-drand", "external-drand"] }
|
|
|
|
# Params relevant to drand nodes. drand nodes should have role="drand", and must all be
|
|
# in the same composition group. There must be at least threshold drand nodes.
|
|
# To get lotus nodes to actually use the drand nodes, you must set random_beacon_type="local-drand"
|
|
# for the lotus node groups.
|
|
drand_period = { type = "duration", default="10s" }
|
|
drand_threshold = { type = "int", default = 2 }
|
|
drand_gossip_relay = { type = "bool", default = true }
|
|
drand_log_level = { type = "string", default="info" }
|
|
|
|
# Params relevant to pubsub tracing
|
|
enable_pubsub_tracer = { type = "bool", default = false }
|
|
mining_mode = { type = "enum", default = "synchronized", options = ["synchronized", "natural"] }
|
|
|
|
# Fast retrieval
|
|
fast_retrieval = { type = "bool", default = false }
|
|
|
|
# Bounce connection during push and pull data transfers
|
|
bounce_conn_data_transfers = { type = "bool", default = false }
|
|
|
|
[[testcases]]
|
|
name = "epoch-boundary"
|
|
instances = { min = 1, max = 100, default = 5 }
|
|
|
|
[testcases.params]
|
|
clients = { type = "int", default = 1 }
|
|
miners = { type = "int", default = 1 }
|
|
attackers = { type = "int", default = 1 }
|
|
balance = { type = "float", default = 1 }
|
|
sectors = { type = "int", default = 1 }
|
|
role = { type = "string" }
|
|
|
|
genesis_timestamp_offset = { type = "int", default = 0 }
|
|
|
|
random_beacon_type = { type = "enum", default = "mock", options = ["mock", "local-drand", "external-drand"] }
|
|
|
|
# Params relevant to drand nodes. drand nodes should have role="drand", and must all be
|
|
# in the same composition group. There must be at least threshold drand nodes.
|
|
# To get lotus nodes to actually use the drand nodes, you must set random_beacon_type="local-drand"
|
|
# for the lotus node groups.
|
|
drand_period = { type = "duration", default="10s" }
|
|
drand_threshold = { type = "int", default = 2 }
|
|
drand_gossip_relay = { type = "bool", default = true }
|
|
drand_log_level = { type = "string", default="info" }
|
|
|
|
# Params relevant to pubsub tracing
|
|
enable_pubsub_tracer = { type = "bool", default = false }
|
|
mining_mode = { type = "enum", default = "synchronized", options = ["synchronized", "natural"] }
|
|
|
|
# Fast retrieval
|
|
fast_retrieval = { type = "bool", default = false }
|
|
|
|
# Bounce connection during push and pull data transfers
|
|
bounce_conn_data_transfers = { type = "bool", default = false }
|
|
|
|
[[testcases]]
|
|
name = "drand-halting"
|
|
instances = { min = 1, max = 100, default = 5 }
|
|
|
|
[testcases.params]
|
|
clients = { type = "int", default = 1 }
|
|
miners = { type = "int", default = 1 }
|
|
balance = { type = "float", default = 1 }
|
|
sectors = { type = "int", default = 1 }
|
|
role = { type = "string" }
|
|
genesis_timestamp_offset = { type = "int", default = 0 }
|
|
|
|
|
|
random_beacon_type = { type = "enum", default = "local-drand", options = ["mock", "local-drand", "external-drand"] }
|
|
|
|
# Params relevant to drand nodes. drand nodes should have role="drand", and must all be
|
|
# in the same composition group. There must be at least threshold drand nodes.
|
|
# To get lotus nodes to actually use the drand nodes, you must set random_beacon_type="local-drand"
|
|
# for the lotus node groups.
|
|
drand_period = { type = "duration", default="10s" }
|
|
drand_threshold = { type = "int", default = 2 }
|
|
drand_gossip_relay = { type = "bool", default = true }
|
|
drand_log_level = { type = "string", default="info" }
|
|
suspend_events = { type = "string", default="", desc = "a sequence of halt/resume/wait events separated by '->'" }
|
|
|
|
# Params relevant to pubsub tracing
|
|
enable_pubsub_tracer = { type = "bool", default = false } # Mining Mode: synchronized -vs- natural time
|
|
mining_mode = { type = "enum", default = "synchronized", options = ["synchronized", "natural"] }
|
|
|
|
|
|
[[testcases]]
|
|
name = "drand-outage"
|
|
instances = { min = 1, max = 100, default = 5 }
|
|
|
|
[testcases.params]
|
|
clients = { type = "int", default = 0 }
|
|
miners = { type = "int", default = 3 }
|
|
balance = { type = "float", default = 1 }
|
|
sectors = { type = "int", default = 1 }
|
|
role = { type = "string" }
|
|
genesis_timestamp_offset = { type = "int", default = 0 }
|
|
|
|
|
|
random_beacon_type = { type = "enum", default = "local-drand", options = ["mock", "local-drand", "external-drand"] }
|
|
|
|
# Params relevant to drand nodes. drand nodes should have role="drand", and must all be
|
|
# in the same composition group. There must be at least threshold drand nodes.
|
|
# To get lotus nodes to actually use the drand nodes, you must set random_beacon_type="local-drand"
|
|
# for the lotus node groups.
|
|
drand_period = { type = "duration", default="30s" }
|
|
drand_catchup_period = { type = "duration", default="10s" }
|
|
drand_threshold = { type = "int", default = 2 }
|
|
drand_gossip_relay = { type = "bool", default = true }
|
|
drand_log_level = { type = "string", default="info" }
|
|
suspend_events = { type = "string", default="", desc = "a sequence of halt/resume/wait events separated by '->'" }
|
|
|
|
# Params relevant to pubsub tracing
|
|
enable_pubsub_tracer = { type = "bool", default = false } # Mining Mode: synchronized -vs- natural time
|
|
mining_mode = { type = "enum", default = "synchronized", options = ["synchronized", "natural"] }
|
|
|
|
|
|
[[testcases]]
|
|
name = "deals-stress"
|
|
instances = { min = 1, max = 100, default = 5 }
|
|
|
|
[testcases.params]
|
|
clients = { type = "int", default = 1 }
|
|
miners = { type = "int", default = 1 }
|
|
balance = { type = "float", default = 1 }
|
|
sectors = { type = "int", default = 1 }
|
|
role = { type = "string" }
|
|
|
|
genesis_timestamp_offset = { type = "int", default = 0 }
|
|
|
|
random_beacon_type = { type = "enum", default = "mock", options = ["mock", "local-drand", "external-drand"] }
|
|
|
|
# Params relevant to drand nodes. drand nodes should have role="drand", and must all be
|
|
# in the same composition group. There must be at least threshold drand nodes.
|
|
# To get lotus nodes to actually use the drand nodes, you must set random_beacon_type="local-drand"
|
|
# for the lotus node groups.
|
|
drand_period = { type = "duration", default="10s" }
|
|
drand_threshold = { type = "int", default = 2 }
|
|
drand_gossip_relay = { type = "bool", default = true }
|
|
|
|
# Params relevant to pubsub tracing
|
|
enable_pubsub_tracer = { type = "bool", default = false }
|
|
|
|
# Mining Mode: synchronized -vs- natural time
|
|
mining_mode = { type = "enum", default = "synchronized", options = ["synchronized", "natural"] }
|
|
|
|
deals = { type = "int", default = 1 }
|
|
deal_mode = { type = "enum", default = "serial", options = ["serial", "concurrent"] }
|
|
|
|
|
|
[[testcases]]
|
|
name = "paych-stress"
|
|
instances = { min = 1, max = 100, default = 5 }
|
|
|
|
[testcases.params]
|
|
clients = { type = "int", default = 1 }
|
|
miners = { type = "int", default = 1 }
|
|
balance = { type = "float", default = 1 }
|
|
sectors = { type = "int", default = 1 }
|
|
role = { type = "string" }
|
|
genesis_timestamp_offset = { type = "int", default = 0 }
|
|
|
|
random_beacon_type = { type = "enum", default = "local-drand", options = ["mock", "local-drand", "external-drand"] }
|
|
|
|
# Params relevant to drand nodes. drand nodes should have role="drand", and must all be
|
|
# in the same composition group. There must be at least threshold drand nodes.
|
|
# To get lotus nodes to actually use the drand nodes, you must set random_beacon_type="local-drand"
|
|
# for the lotus node groups.
|
|
drand_period = { type = "duration", default="10s" }
|
|
drand_threshold = { type = "int", default = 2 }
|
|
drand_gossip_relay = { type = "bool", default = true }
|
|
drand_log_level = { type = "string", default="info" }
|
|
suspend_events = { type = "string", default="", desc = "a sequence of halt/resume/wait events separated by '->'" }
|
|
|
|
# Params relevant to pubsub tracing
|
|
enable_pubsub_tracer = { type = "bool", default = false } # Mining Mode: synchronized -vs- natural time
|
|
mining_mode = { type = "enum", default = "synchronized", options = ["synchronized", "natural"] }
|
|
|
|
# ********** Test-case specific **********
|
|
increments = { type = "int", default = "100", desc = "increments in which to send payment vouchers" }
|
|
lane_count = { type = "int", default = "256", desc = "lanes to open; vouchers will be distributed across these lanes in round-robin fashion" }
|
|
|
|
|
|
[[testcases]]
|
|
name = "recovery-failed-windowed-post"
|
|
instances = { min = 1, max = 100, default = 5 }
|
|
|
|
[testcases.params]
|
|
clients = { type = "int", default = 1 }
|
|
miners = { type = "int", default = 1 }
|
|
balance = { type = "int", default = 1 }
|
|
sectors = { type = "int", default = 1 }
|
|
role = { type = "string" }
|
|
|
|
genesis_timestamp_offset = { type = "int", default = 0 }
|
|
|
|
random_beacon_type = { type = "enum", default = "mock", options = ["mock", "local-drand", "external-drand"] }
|
|
|
|
# Params relevant to drand nodes. drand nodes should have role="drand", and must all be
|
|
# in the same composition group. There must be at least threshold drand nodes.
|
|
# To get lotus nodes to actually use the drand nodes, you must set random_beacon_type="local-drand"
|
|
# for the lotus node groups.
|
|
drand_period = { type = "duration", default="10s" }
|
|
drand_threshold = { type = "int", default = 2 }
|
|
drand_gossip_relay = { type = "bool", default = true }
|
|
drand_log_level = { type = "string", default="info" }
|
|
|
|
# Params relevant to pubsub tracing
|
|
enable_pubsub_tracer = { type = "bool", default = false }
|
|
mining_mode = { type = "enum", default = "synchronized", options = ["synchronized", "natural"] }
|