node: optional chains in tilt

This commit is contained in:
Evan Gray 2022-07-10 20:47:10 -04:00 committed by Evan Gray
parent 83499fcda0
commit 59fd0d36c7
7 changed files with 338 additions and 248 deletions

View File

@ -33,12 +33,11 @@ to avoid having to specify `-n wormhole` for all commands:
After installing all dependencies, just run `tilt up`. After installing all dependencies, just run `tilt up`.
Whenever you modify a file, the devnet is automatically rebuilt and a rolling update is done. Whenever you modify a file, the devnet is automatically rebuilt and a rolling update is done.
Launch the devnet while specifying the number of guardians nodes to run (default is five): Launch the devnet:
tilt up -- --num=1 tilt up
If you want to work on non-consensus parts of the code, running with a single guardian is easiest since By default this runs a network consisting of one guardian, two ganache (Eth) chains, a Solana test validator, an Algorand sandbox, and LocalTerra for both Terra Classic and Terra 2. If you want to work on non-consensus parts of the code, running with a single guardian is easiest since you won't have to wait for k8s to restart all pods. See the usage guide below for arguments to customize the tilt network.
you won't have to wait for k8s to restart all pods.
## Usage ## Usage
@ -59,6 +58,10 @@ of nodes diverges from the guardian set - otherwise, `tilt down --delete-namespa
tilt args -- --num=2 tilt args -- --num=2
Run without all optional networks:
tilt up -- --algorand=false --evm2=false --solana=false --terra_classic=false --terra2=false
Tear down cluster: Tear down cluster:
tilt down --delete-namespaces tilt down --delete-namespaces
@ -161,7 +164,6 @@ Set the include path:
![](https://i.imgur.com/bDij6Cu.png) ![](https://i.imgur.com/bDij6Cu.png)
### BigTable event persistence ### BigTable event persistence
Guardian events can be persisted to a cloud BigTable instance by passing a GCP project and service account key to Tilt. Guardian events can be persisted to a cloud BigTable instance by passing a GCP project and service account key to Tilt.

View File

@ -39,7 +39,10 @@ config.define_string("webHost", False, "Public hostname for port forwards")
# Components # Components
config.define_bool("algorand", False, "Enable Algorand component") config.define_bool("algorand", False, "Enable Algorand component")
config.define_bool("evm2", False, "Enable second Eth component")
config.define_bool("solana", False, "Enable Solana component") config.define_bool("solana", False, "Enable Solana component")
config.define_bool("terra_classic", False, "Enable Terra Classic component")
config.define_bool("terra2", False, "Enable Terra 2 component")
config.define_bool("explorer", False, "Enable explorer component") config.define_bool("explorer", False, "Enable explorer component")
config.define_bool("bridge_ui", False, "Enable bridge UI component") config.define_bool("bridge_ui", False, "Enable bridge UI component")
config.define_bool("spy_relayer", False, "Enable spy relayer") config.define_bool("spy_relayer", False, "Enable spy relayer")
@ -55,7 +58,10 @@ gcpProject = cfg.get("gcpProject", "local-dev")
bigTableKeyPath = cfg.get("bigTableKeyPath", "./event_database/devnet_key.json") bigTableKeyPath = cfg.get("bigTableKeyPath", "./event_database/devnet_key.json")
webHost = cfg.get("webHost", "localhost") webHost = cfg.get("webHost", "localhost")
algorand = cfg.get("algorand", True) algorand = cfg.get("algorand", True)
evm2 = cfg.get("evm2", True)
solana = cfg.get("solana", True) solana = cfg.get("solana", True)
terra_classic = cfg.get("terra_classic", True)
terra2 = cfg.get("terra2", True)
ci = cfg.get("ci", False) ci = cfg.get("ci", False)
explorer = cfg.get("explorer", ci) explorer = cfg.get("explorer", ci)
bridge_ui = cfg.get("bridge_ui", ci) bridge_ui = cfg.get("bridge_ui", ci)
@ -188,13 +194,72 @@ def build_node_yaml():
gcpProject, gcpProject,
] ]
if evm2:
container["command"] += [
"--bscRPC",
"ws://eth-devnet2:8545",
]
else:
container["command"] += [
"--bscRPC",
"ws://eth-devnet:8545",
]
if solana:
container["command"] += [
"--solanaWS",
"ws://solana-devnet:8900",
"--solanaRPC",
"http://solana-devnet:8899",
]
if terra_classic:
container["command"] += [
"--terraWS",
"ws://terra-terrad:26657/websocket",
"--terraLCD",
"http://terra-terrad:1317",
"--terraContract",
"terra18vd8fpwxzck93qlwghaj6arh4p7c5n896xzem5",
]
if terra2:
container["command"] += [
"--terra2WS",
"ws://terra2-terrad:26657/websocket",
"--terra2LCD",
"http://terra2-terrad:1317",
"--terra2Contract",
"terra14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9ssrc8au",
]
if algorand:
container["command"] += [
"--algorandAppID",
"4",
"--algorandIndexerRPC",
"http://algorand:8980",
"--algorandIndexerToken",
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
"--algorandAlgodRPC",
"http://algorand:4001",
"--algorandAlgodToken",
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
]
return encode_yaml_stream(node_yaml) return encode_yaml_stream(node_yaml)
k8s_yaml_with_ns(build_node_yaml()) k8s_yaml_with_ns(build_node_yaml())
guardian_resource_deps = ["proto-gen", "eth-devnet", "eth-devnet2", "terra-terrad", "terra2-terrad"] guardian_resource_deps = ["proto-gen", "eth-devnet"]
if evm2:
guardian_resource_deps = guardian_resource_deps + ["eth-devnet2"]
if solana: if solana:
guardian_resource_deps = guardian_resource_deps + ["solana-devnet"] guardian_resource_deps = guardian_resource_deps + ["solana-devnet"]
if terra_classic:
guardian_resource_deps = guardian_resource_deps + ["terra-terrad"]
if terra2:
guardian_resource_deps = guardian_resource_deps + ["terra2-terrad"]
k8s_resource( k8s_resource(
"guardian", "guardian",
@ -369,6 +434,9 @@ k8s_resource(
trigger_mode = trigger_mode, trigger_mode = trigger_mode,
) )
if evm2:
k8s_yaml_with_ns("devnet/eth-devnet2.yaml")
k8s_resource( k8s_resource(
"eth-devnet2", "eth-devnet2",
port_forwards = [ port_forwards = [
@ -465,7 +533,6 @@ if e2e:
) )
# bigtable # bigtable
if explorer: if explorer:
k8s_yaml_with_ns("devnet/bigtable.yaml") k8s_yaml_with_ns("devnet/bigtable.yaml")
@ -498,8 +565,7 @@ if explorer:
trigger_mode = trigger_mode, trigger_mode = trigger_mode,
) )
# terra devnet if terra_classic:
docker_build( docker_build(
ref = "terra-image", ref = "terra-image",
context = "./terra/devnet", context = "./terra/devnet",
@ -539,8 +605,7 @@ k8s_resource(
trigger_mode = trigger_mode, trigger_mode = trigger_mode,
) )
# terra 2 devnet if terra2:
docker_build( docker_build(
ref = "terra2-image", ref = "terra2-image",
context = "./cosmwasm/devnet", context = "./cosmwasm/devnet",

View File

@ -14,22 +14,6 @@ spec:
selector: selector:
app: eth-devnet app: eth-devnet
--- ---
apiVersion: v1
kind: Service
metadata:
name: eth-devnet2
labels:
app: eth-devnet2
spec:
ports:
- port: 8546
targetPort: 8545
name: rpc
protocol: TCP
clusterIP: None
selector:
app: eth-devnet2
---
apiVersion: apps/v1 apiVersion: apps/v1
kind: StatefulSet kind: StatefulSet
metadata: metadata:
@ -82,55 +66,4 @@ spec:
- -c - -c
- "npx truffle exec mine.js" - "npx truffle exec mine.js"
--- ---
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: eth-devnet2
spec:
selector:
matchLabels:
app: eth-devnet2
serviceName: eth-devnet2
replicas: 1
template:
metadata:
labels:
app: eth-devnet2
spec:
terminationGracePeriodSeconds: 1
containers:
- name: ganache
image: eth-node
command:
- npx
- ganache-cli
- -e 10000
- --deterministic
- --time="1970-01-01T00:00:00+00:00"
- --host=0.0.0.0
- --chainId=1397
ports:
- containerPort: 8545
name: rpc
protocol: TCP
readinessProbe:
tcpSocket:
port: rpc
- name: tests
image: eth-node
stdin: true
command:
- /bin/sh
- -c
- "sed -i 's/CHAIN_ID=0x2/CHAIN_ID=0x4/g' .env && npm run migrate && npx truffle exec scripts/deploy_test_token.js && npx truffle exec scripts/register_solana_chain.js && npx truffle exec scripts/register_terra_chain.js && npx truffle exec scripts/register_terra2_chain.js && npx truffle exec scripts/register_eth_chain.js && npx truffle exec scripts/register_algo_chain.js && nc -lkp 2000 0.0.0.0"
readinessProbe:
periodSeconds: 1
failureThreshold: 300
tcpSocket:
port: 2000
- name: mine
image: eth-node
command:
- /bin/sh
- -c
- "npx truffle exec mine.js"

69
devnet/eth-devnet2.yaml Normal file
View File

@ -0,0 +1,69 @@
---
apiVersion: v1
kind: Service
metadata:
name: eth-devnet2
labels:
app: eth-devnet2
spec:
ports:
- port: 8546
targetPort: 8545
name: rpc
protocol: TCP
clusterIP: None
selector:
app: eth-devnet2
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: eth-devnet2
spec:
selector:
matchLabels:
app: eth-devnet2
serviceName: eth-devnet2
replicas: 1
template:
metadata:
labels:
app: eth-devnet2
spec:
terminationGracePeriodSeconds: 1
containers:
- name: ganache
image: eth-node
command:
- npx
- ganache-cli
- -e 10000
- --deterministic
- --time="1970-01-01T00:00:00+00:00"
- --host=0.0.0.0
- --chainId=1397
ports:
- containerPort: 8545
name: rpc
protocol: TCP
readinessProbe:
tcpSocket:
port: rpc
- name: tests
image: eth-node
stdin: true
command:
- /bin/sh
- -c
- "sed -i 's/CHAIN_ID=0x2/CHAIN_ID=0x4/g' .env && npm run migrate && npx truffle exec scripts/deploy_test_token.js && npx truffle exec scripts/register_solana_chain.js && npx truffle exec scripts/register_terra_chain.js && npx truffle exec scripts/register_terra2_chain.js && npx truffle exec scripts/register_eth_chain.js && npx truffle exec scripts/register_algo_chain.js && nc -lkp 2000 0.0.0.0"
readinessProbe:
periodSeconds: 1
failureThreshold: 300
tcpSocket:
port: 2000
- name: mine
image: eth-node
command:
- /bin/sh
- -c
- "npx truffle exec mine.js"

View File

@ -69,8 +69,8 @@ spec:
- node - node
- --ethRPC - --ethRPC
- ws://eth-devnet:8545 - ws://eth-devnet:8545
- --bscRPC # - --bscRPC
- ws://eth-devnet2:8545 # - ws://eth-devnet2:8545
- --polygonRPC - --polygonRPC
- ws://eth-devnet:8545 - ws://eth-devnet:8545
- --avalancheRPC - --avalancheRPC
@ -93,34 +93,34 @@ spec:
- ws://eth-devnet:8545 - ws://eth-devnet:8545
- --neonRPC - --neonRPC
- ws://eth-devnet:8545 - ws://eth-devnet:8545
- --terraWS # - --terraWS
- ws://terra-terrad:26657/websocket # - ws://terra-terrad:26657/websocket
- --terraLCD # - --terraLCD
- http://terra-terrad:1317 # - http://terra-terrad:1317
- --terraContract # - --terraContract
- terra18vd8fpwxzck93qlwghaj6arh4p7c5n896xzem5 # - terra18vd8fpwxzck93qlwghaj6arh4p7c5n896xzem5
- --terra2WS # - --terra2WS
- ws://terra2-terrad:26657/websocket # - ws://terra2-terrad:26657/websocket
- --terra2LCD # - --terra2LCD
- http://terra2-terrad:1317 # - http://terra2-terrad:1317
- --terra2Contract # - --terra2Contract
- terra14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9ssrc8au # - terra14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9ssrc8au
- --algorandAppID # - --algorandAppID
- "4" # - "4"
- --algorandIndexerRPC # - --algorandIndexerRPC
- http://algorand:8980 # - http://algorand:8980
- --algorandIndexerToken # - --algorandIndexerToken
- "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" # - "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
- --algorandAlgodRPC # - --algorandAlgodRPC
- http://algorand:4001 # - http://algorand:4001
- --algorandAlgodToken # - --algorandAlgodToken
- "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" # - "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
- --solanaContract - --solanaContract
- Bridge1p5gheXUvJ6jGWGeCsgPKgnE3YgdGKRVCMY9o - Bridge1p5gheXUvJ6jGWGeCsgPKgnE3YgdGKRVCMY9o
- --solanaWS # - --solanaWS
- ws://solana-devnet:8900 # - ws://solana-devnet:8900
- --solanaRPC # - --solanaRPC
- http://solana-devnet:8899 # - http://solana-devnet:8899
- --unsafeDevMode - --unsafeDevMode
- --guardianKey - --guardianKey
- /tmp/bridge.key - /tmp/bridge.key

View File

@ -1,5 +1,6 @@
# syntax=docker.io/docker/dockerfile:1.3@sha256:42399d4635eddd7a9b8a24be879d2f9a930d0ed040a61324cfdf59ef1357b3b2 # syntax=docker.io/docker/dockerfile:1.3@sha256:42399d4635eddd7a9b8a24be879d2f9a930d0ed040a61324cfdf59ef1357b3b2
FROM docker.io/golang:1.17.5@sha256:90d1ab81f3d157ca649a9ff8d251691b810d95ea6023a03cdca139df58bca599 AS build FROM --platform=linux/amd64 docker.io/golang:1.17.5@sha256:90d1ab81f3d157ca649a9ff8d251691b810d95ea6023a03cdca139df58bca599 AS build
# libwasmvm.so is not compatible with arm
# Support additional root CAs # Support additional root CAs
COPY go.mod cert.pem* /certs/ COPY go.mod cert.pem* /certs/

View File

@ -350,10 +350,16 @@ func runNode(cmd *cobra.Command, args []string) {
// Register components for readiness checks. // Register components for readiness checks.
readiness.RegisterComponent(common.ReadinessEthSyncing) readiness.RegisterComponent(common.ReadinessEthSyncing)
if *solanaWsRPC != "" {
readiness.RegisterComponent(common.ReadinessSolanaSyncing) readiness.RegisterComponent(common.ReadinessSolanaSyncing)
}
if *terraWS != "" {
readiness.RegisterComponent(common.ReadinessTerraSyncing) readiness.RegisterComponent(common.ReadinessTerraSyncing)
}
if *terra2WS != "" {
readiness.RegisterComponent(common.ReadinessTerra2Syncing) readiness.RegisterComponent(common.ReadinessTerra2Syncing)
if *testnetMode || *unsafeDevMode { }
if *algorandIndexerRPC != "" {
readiness.RegisterComponent(common.ReadinessAlgorandSyncing) readiness.RegisterComponent(common.ReadinessAlgorandSyncing)
} }
readiness.RegisterComponent(common.ReadinessBSCSyncing) readiness.RegisterComponent(common.ReadinessBSCSyncing)
@ -561,6 +567,9 @@ func runNode(cmd *cobra.Command, args []string) {
logger.Fatal("Please specify --nodeName") logger.Fatal("Please specify --nodeName")
} }
// Solana, Terra Classic, Terra 2, and Algorand are optional in devnet
if !*unsafeDevMode {
if *solanaContract == "" { if *solanaContract == "" {
logger.Fatal("Please specify --solanaContract") logger.Fatal("Please specify --solanaContract")
} }
@ -580,6 +589,7 @@ func runNode(cmd *cobra.Command, args []string) {
if *terraContract == "" { if *terraContract == "" {
logger.Fatal("Please specify --terraContract") logger.Fatal("Please specify --terraContract")
} }
if *terra2WS == "" { if *terra2WS == "" {
logger.Fatal("Please specify --terra2WS") logger.Fatal("Please specify --terra2WS")
} }
@ -589,7 +599,8 @@ func runNode(cmd *cobra.Command, args []string) {
if *terra2Contract == "" { if *terra2Contract == "" {
logger.Fatal("Please specify --terra2Contract") logger.Fatal("Please specify --terra2Contract")
} }
if *testnetMode || *unsafeDevMode {
if *testnetMode {
if *algorandIndexerRPC == "" { if *algorandIndexerRPC == "" {
logger.Fatal("Please specify --algorandIndexerRPC") logger.Fatal("Please specify --algorandIndexerRPC")
} }
@ -606,6 +617,9 @@ func runNode(cmd *cobra.Command, args []string) {
logger.Fatal("Please specify --algorandAppID") logger.Fatal("Please specify --algorandAppID")
} }
} }
}
if *bigTablePersistenceEnabled { if *bigTablePersistenceEnabled {
if *bigTableGCPProject == "" { if *bigTableGCPProject == "" {
logger.Fatal("Please specify --bigTableGCPProject") logger.Fatal("Please specify --bigTableGCPProject")
@ -941,17 +955,21 @@ func runNode(cmd *cobra.Command, args []string) {
} }
} }
if *terraWS != "" {
logger.Info("Starting Terra watcher") logger.Info("Starting Terra watcher")
if err := supervisor.Run(ctx, "terrawatch", if err := supervisor.Run(ctx, "terrawatch",
cosmwasm.NewWatcher(*terraWS, *terraLCD, *terraContract, lockC, setC, chainObsvReqC[vaa.ChainIDTerra], common.ReadinessTerraSyncing, vaa.ChainIDTerra).Run); err != nil { cosmwasm.NewWatcher(*terraWS, *terraLCD, *terraContract, lockC, setC, chainObsvReqC[vaa.ChainIDTerra], common.ReadinessTerraSyncing, vaa.ChainIDTerra).Run); err != nil {
return err return err
} }
}
if *terra2WS != "" {
logger.Info("Starting Terra 2 watcher") logger.Info("Starting Terra 2 watcher")
if err := supervisor.Run(ctx, "terra2watch", if err := supervisor.Run(ctx, "terra2watch",
cosmwasm.NewWatcher(*terra2WS, *terra2LCD, *terra2Contract, lockC, setC, chainObsvReqC[vaa.ChainIDTerra2], common.ReadinessTerra2Syncing, vaa.ChainIDTerra2).Run); err != nil { cosmwasm.NewWatcher(*terra2WS, *terra2LCD, *terra2Contract, lockC, setC, chainObsvReqC[vaa.ChainIDTerra2], common.ReadinessTerra2Syncing, vaa.ChainIDTerra2).Run); err != nil {
return err return err
} }
}
if *testnetMode { if *testnetMode {
logger.Info("Starting Injective watcher") logger.Info("Starting Injective watcher")
@ -961,13 +979,14 @@ func runNode(cmd *cobra.Command, args []string) {
} }
} }
if *testnetMode || *unsafeDevMode { if *algorandIndexerRPC != "" {
if err := supervisor.Run(ctx, "algorandwatch", if err := supervisor.Run(ctx, "algorandwatch",
algorand.NewWatcher(*algorandIndexerRPC, *algorandIndexerToken, *algorandAlgodRPC, *algorandAlgodToken, *algorandAppID, lockC, setC, chainObsvReqC[vaa.ChainIDAlgorand]).Run); err != nil { algorand.NewWatcher(*algorandIndexerRPC, *algorandIndexerToken, *algorandAlgodRPC, *algorandAlgodToken, *algorandAppID, lockC, setC, chainObsvReqC[vaa.ChainIDAlgorand]).Run); err != nil {
return err return err
} }
} }
if *solanaWsRPC != "" {
if err := supervisor.Run(ctx, "solwatch-confirmed", if err := supervisor.Run(ctx, "solwatch-confirmed",
solana.NewSolanaWatcher(*solanaWsRPC, *solanaRPC, solAddress, lockC, nil, rpc.CommitmentConfirmed).Run); err != nil { solana.NewSolanaWatcher(*solanaWsRPC, *solanaRPC, solAddress, lockC, nil, rpc.CommitmentConfirmed).Run); err != nil {
return err return err
@ -977,6 +996,7 @@ func runNode(cmd *cobra.Command, args []string) {
solana.NewSolanaWatcher(*solanaWsRPC, *solanaRPC, solAddress, lockC, chainObsvReqC[vaa.ChainIDSolana], rpc.CommitmentFinalized).Run); err != nil { solana.NewSolanaWatcher(*solanaWsRPC, *solanaRPC, solAddress, lockC, chainObsvReqC[vaa.ChainIDSolana], rpc.CommitmentFinalized).Run); err != nil {
return err return err
} }
}
p := processor.NewProcessor(ctx, p := processor.NewProcessor(ctx,
db, db,