2020-04-21 19:37:10 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# "stable" mode tests assume data is static
|
|
|
|
# "live" mode tests assume data dynamic
|
|
|
|
|
|
|
|
SCRIPT=$(basename ${BASH_SOURCE[0]})
|
|
|
|
TEST=""
|
|
|
|
QTD=1
|
|
|
|
SLEEP_TIMEOUT=5
|
|
|
|
TEST_QTD=1
|
|
|
|
|
2021-04-17 10:00:07 +00:00
|
|
|
## remove test data dir after
|
|
|
|
REMOVE_DATA_DIR=false
|
|
|
|
|
2020-04-21 19:37:10 +00:00
|
|
|
#PORT AND RPC_PORT 3 initial digits, to be concat with a suffix later when node is initialized
|
|
|
|
RPC_PORT="854"
|
|
|
|
IP_ADDR="0.0.0.0"
|
|
|
|
|
|
|
|
KEY="mykey"
|
2022-09-07 07:26:51 +00:00
|
|
|
CHAINID="laconic_9000-1"
|
2020-04-21 19:37:10 +00:00
|
|
|
MONIKER="mymoniker"
|
|
|
|
|
2022-09-07 07:26:51 +00:00
|
|
|
## default port prefixes for laconicd
|
2020-04-21 19:37:10 +00:00
|
|
|
NODE_P2P_PORT="2660"
|
|
|
|
NODE_PORT="2663"
|
|
|
|
NODE_RPC_PORT="2666"
|
|
|
|
|
|
|
|
usage() {
|
2020-09-24 17:50:47 +00:00
|
|
|
echo "Usage: $SCRIPT"
|
|
|
|
echo "Optional command line arguments"
|
|
|
|
echo "-t <string> -- Test to run. eg: rpc"
|
|
|
|
echo "-q <number> -- Quantity of nodes to run. eg: 3"
|
|
|
|
echo "-z <number> -- Quantity of nodes to run tests against eg: 3"
|
|
|
|
echo "-s <number> -- Sleep between operations in secs. eg: 5"
|
2022-05-12 12:26:04 +00:00
|
|
|
echo "-m <string> -- Mode for testing. eg: rpc"
|
2021-04-17 10:00:07 +00:00
|
|
|
echo "-r <string> -- Remove test dir after, eg: true, default is false"
|
2020-09-24 17:50:47 +00:00
|
|
|
exit 1
|
2020-04-21 19:37:10 +00:00
|
|
|
}
|
|
|
|
|
2021-04-17 10:00:07 +00:00
|
|
|
while getopts "h?t:q:z:s:m:r:" args; do
|
2020-09-24 17:50:47 +00:00
|
|
|
case $args in
|
|
|
|
h|\?)
|
|
|
|
usage;
|
|
|
|
exit;;
|
|
|
|
t ) TEST=${OPTARG};;
|
|
|
|
q ) QTD=${OPTARG};;
|
|
|
|
z ) TEST_QTD=${OPTARG};;
|
|
|
|
s ) SLEEP_TIMEOUT=${OPTARG};;
|
2020-12-15 19:52:09 +00:00
|
|
|
m ) MODE=${OPTARG};;
|
2021-04-17 10:00:07 +00:00
|
|
|
r ) REMOVE_DATA_DIR=${OPTARG};;
|
2020-09-24 17:50:47 +00:00
|
|
|
esac
|
2020-04-21 19:37:10 +00:00
|
|
|
done
|
|
|
|
|
|
|
|
set -euxo pipefail
|
|
|
|
|
|
|
|
|
2022-09-07 07:26:51 +00:00
|
|
|
DATA_DIR=$(mktemp -d -t laconic-datadir.XXXXX)
|
2020-04-21 19:37:10 +00:00
|
|
|
if [[ ! "$DATA_DIR" ]]; then
|
2020-09-24 17:50:47 +00:00
|
|
|
echo "Could not create $DATA_DIR"
|
|
|
|
exit 1
|
2020-04-21 19:37:10 +00:00
|
|
|
fi
|
|
|
|
|
2022-09-07 07:26:51 +00:00
|
|
|
# Compile laconic
|
|
|
|
echo "compiling laconic"
|
2021-07-12 12:26:33 +00:00
|
|
|
make build
|
2020-04-21 19:37:10 +00:00
|
|
|
|
|
|
|
# PID array declaration
|
|
|
|
arr=()
|
|
|
|
|
|
|
|
init_func() {
|
2022-09-07 07:26:51 +00:00
|
|
|
"$PWD"/build/laconicd keys add $KEY"$i" --keyring-backend test --home "$DATA_DIR$i" --no-backup --algo "eth_secp256k1"
|
|
|
|
"$PWD"/build/laconicd init $MONIKER --chain-id $CHAINID --home "$DATA_DIR$i"
|
|
|
|
"$PWD"/build/laconicd add-genesis-account \
|
|
|
|
"$("$PWD"/build/laconicd keys show "$KEY$i" --keyring-backend test -a --home "$DATA_DIR$i")" 1000000000000000000aphoton,1000000000000000000stake \
|
2021-04-17 10:00:07 +00:00
|
|
|
--keyring-backend test --home "$DATA_DIR$i"
|
2022-09-07 07:26:51 +00:00
|
|
|
"$PWD"/build/laconicd gentx "$KEY$i" 1000000000000000000stake --chain-id $CHAINID --keyring-backend test --home "$DATA_DIR$i"
|
|
|
|
"$PWD"/build/laconicd collect-gentxs --home "$DATA_DIR$i"
|
|
|
|
"$PWD"/build/laconicd validate-genesis --home "$DATA_DIR$i"
|
2020-12-15 19:52:09 +00:00
|
|
|
|
|
|
|
if [[ $MODE == "pending" ]]; then
|
2021-04-17 10:00:07 +00:00
|
|
|
ls $DATA_DIR$i
|
|
|
|
if [[ "$OSTYPE" == "darwin"* ]]; then
|
|
|
|
sed -i '' 's/create_empty_blocks_interval = "0s"/create_empty_blocks_interval = "30s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i '' 's/timeout_propose = "3s"/timeout_propose = "30s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i '' 's/timeout_propose_delta = "500ms"/timeout_propose_delta = "2s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i '' 's/timeout_prevote = "1s"/timeout_prevote = "120s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i '' 's/timeout_prevote_delta = "500ms"/timeout_prevote_delta = "2s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i '' 's/timeout_precommit = "1s"/timeout_precommit = "10s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i '' 's/timeout_precommit_delta = "500ms"/timeout_precommit_delta = "2s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i '' 's/timeout_commit = "5s"/timeout_commit = "150s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i '' 's/timeout_broadcast_tx_commit = "10s"/timeout_broadcast_tx_commit = "150s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
else
|
|
|
|
sed -i 's/create_empty_blocks_interval = "0s"/create_empty_blocks_interval = "30s"/g' $DATA_DIR$i/config/config.toml
|
2020-12-15 19:52:09 +00:00
|
|
|
sed -i 's/timeout_propose = "3s"/timeout_propose = "30s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i 's/timeout_propose_delta = "500ms"/timeout_propose_delta = "2s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i 's/timeout_prevote = "1s"/timeout_prevote = "120s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i 's/timeout_prevote_delta = "500ms"/timeout_prevote_delta = "2s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i 's/timeout_precommit = "1s"/timeout_precommit = "10s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i 's/timeout_precommit_delta = "500ms"/timeout_precommit_delta = "2s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
sed -i 's/timeout_commit = "5s"/timeout_commit = "150s"/g' $DATA_DIR$i/config/config.toml
|
2021-04-17 10:00:07 +00:00
|
|
|
sed -i 's/timeout_broadcast_tx_commit = "10s"/timeout_broadcast_tx_commit = "150s"/g' $DATA_DIR$i/config/config.toml
|
|
|
|
fi
|
2020-12-15 19:52:09 +00:00
|
|
|
fi
|
2020-04-21 19:37:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
start_func() {
|
2022-09-07 07:26:51 +00:00
|
|
|
echo "starting laconic node $i in background ..."
|
|
|
|
"$PWD"/build/laconicd start \
|
2022-05-13 09:53:31 +00:00
|
|
|
--pruning=nothing --rpc.unsafe \
|
|
|
|
--p2p.laddr tcp://$IP_ADDR:$NODE_P2P_PORT"$i" \
|
|
|
|
--address tcp://$IP_ADDR:$NODE_PORT"$i" \
|
|
|
|
--rpc.laddr tcp://$IP_ADDR:$NODE_RPC_PORT"$i" \
|
|
|
|
--json-rpc.address=$IP_ADDR:$RPC_PORT"$i" \
|
|
|
|
--json-rpc.api="eth,txpool,personal,net,debug,web3" \
|
|
|
|
--keyring-backend test --mode validator --home "$DATA_DIR$i" \
|
|
|
|
--log_level debug \
|
2020-09-24 17:50:47 +00:00
|
|
|
>"$DATA_DIR"/node"$i".log 2>&1 & disown
|
2021-04-17 10:00:07 +00:00
|
|
|
|
2022-09-07 07:26:51 +00:00
|
|
|
LACONIC_PID=$!
|
|
|
|
echo "started laconic node, pid=$LACONIC_PID"
|
2020-09-24 17:50:47 +00:00
|
|
|
# add PID to array
|
2022-09-07 07:26:51 +00:00
|
|
|
arr+=("$LACONIC_PID")
|
2020-04-21 19:37:10 +00:00
|
|
|
|
2021-04-17 10:00:07 +00:00
|
|
|
if [[ $MODE == "pending" ]]; then
|
|
|
|
echo "waiting for the first block..."
|
|
|
|
sleep 300
|
|
|
|
fi
|
2020-04-21 19:37:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# Run node with static blockchain database
|
|
|
|
# For loop N times
|
|
|
|
for i in $(seq 1 "$QTD"); do
|
2020-09-24 17:50:47 +00:00
|
|
|
init_func "$i"
|
|
|
|
start_func "$i"
|
|
|
|
sleep 1
|
|
|
|
echo "sleeping $SLEEP_TIMEOUT seconds for startup"
|
|
|
|
sleep "$SLEEP_TIMEOUT"
|
|
|
|
echo "done sleeping"
|
2020-04-21 19:37:10 +00:00
|
|
|
done
|
|
|
|
|
|
|
|
echo "sleeping $SLEEP_TIMEOUT seconds before running tests ... "
|
|
|
|
sleep "$SLEEP_TIMEOUT"
|
|
|
|
echo "done sleeping"
|
|
|
|
|
|
|
|
set +e
|
|
|
|
|
2022-02-09 13:56:12 +00:00
|
|
|
if [[ -z $TEST || $TEST == "integration" ]] ; then
|
|
|
|
time_out=300s
|
2021-04-17 10:00:07 +00:00
|
|
|
|
2022-02-09 13:56:12 +00:00
|
|
|
for i in $(seq 1 "$TEST_QTD"); do
|
|
|
|
HOST_RPC=http://$IP_ADDR:$RPC_PORT"$i"
|
2022-09-07 07:26:51 +00:00
|
|
|
echo "going to test laconic node $HOST_RPC ..."
|
2022-02-09 13:56:12 +00:00
|
|
|
MODE=$MODE HOST=$HOST_RPC go test ./tests/e2e/... -timeout=$time_out -v -short
|
|
|
|
TEST_FAIL=$?
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ -z $TEST || $TEST == "rpc" || $TEST == "pending" ]]; then
|
2021-04-17 10:00:07 +00:00
|
|
|
time_out=300s
|
|
|
|
if [[ $TEST == "pending" ]]; then
|
|
|
|
time_out=60m0s
|
|
|
|
fi
|
2020-12-15 19:52:09 +00:00
|
|
|
|
2020-09-24 17:50:47 +00:00
|
|
|
for i in $(seq 1 "$TEST_QTD"); do
|
|
|
|
HOST_RPC=http://$IP_ADDR:$RPC_PORT"$i"
|
2022-09-07 07:26:51 +00:00
|
|
|
echo "going to test laconic node $HOST_RPC ..."
|
2021-10-25 09:08:34 +00:00
|
|
|
MODE=$MODE HOST=$HOST_RPC go test ./tests/rpc/... -timeout=$time_out -v -short
|
2021-04-17 10:00:07 +00:00
|
|
|
|
2022-02-09 13:56:12 +00:00
|
|
|
TEST_FAIL=$?
|
2020-09-24 17:50:47 +00:00
|
|
|
done
|
2020-04-21 19:37:10 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
stop_func() {
|
2022-09-07 07:26:51 +00:00
|
|
|
LACONIC_PID=$i
|
|
|
|
echo "shutting down node, pid=$LACONIC_PID ..."
|
2021-04-17 10:00:07 +00:00
|
|
|
|
2022-09-07 07:26:51 +00:00
|
|
|
# Shutdown laconic node
|
|
|
|
kill -9 "$LACONIC_PID"
|
|
|
|
wait "$LACONIC_PID"
|
2020-04-21 19:37:10 +00:00
|
|
|
|
2021-04-17 10:00:07 +00:00
|
|
|
if [ $REMOVE_DATA_DIR == "true" ]
|
|
|
|
then
|
|
|
|
rm -rf $DATA_DIR*
|
|
|
|
fi
|
|
|
|
}
|
2020-04-21 19:37:10 +00:00
|
|
|
|
|
|
|
for i in "${arr[@]}"; do
|
2020-09-24 17:50:47 +00:00
|
|
|
stop_func "$i"
|
2020-04-21 19:37:10 +00:00
|
|
|
done
|
|
|
|
|
2022-02-09 13:56:12 +00:00
|
|
|
if [[ (-z $TEST || $TEST == "rpc" || $TEST == "integration" ) && $TEST_FAIL -ne 0 ]]; then
|
|
|
|
exit $TEST_FAIL
|
2020-04-21 19:37:10 +00:00
|
|
|
else
|
2020-09-24 17:50:47 +00:00
|
|
|
exit 0
|
2020-04-21 19:37:10 +00:00
|
|
|
fi
|