solana/net/remote/remote-sanity.sh

123 lines
2.3 KiB
Bash
Raw Normal View History

2018-09-03 22:33:40 -07:00
#!/bin/bash -e
2018-09-04 09:21:03 -07:00
cd "$(dirname "$0")"/../..
2018-09-03 22:33:40 -07:00
2018-09-04 09:21:03 -07:00
deployMethod=
leaderIp=
numNodes=
# shellcheck source=/dev/null # deployConfig is written by remote_sanity.sh
source deployConfig
2018-09-03 22:33:40 -07:00
2018-09-04 09:21:03 -07:00
[[ -n $deployMethod ]] || {
echo "deployMethod empty"
exit 1
}
[[ -n $leaderIp ]] || {
echo "leaderIp empty"
exit 1
}
[[ -n $numNodes ]] || {
echo "numNodes empty"
exit 1
}
2018-09-03 22:33:40 -07:00
ledgerVerify=true
validatorSanity=true
while [[ $1 = "-o" ]]; do
opt="$2"
shift 2
case $opt in
noLedgerVerify)
ledgerVerify=false
;;
noValidatorSanity)
validatorSanity=false
;;
*)
echo "Error: unknown option: $opt"
exit 1
;;
esac
done
source net/common.sh
loadConfigFile
case $deployMethod in
snap)
2018-09-04 09:21:03 -07:00
PATH="/snap/bin:$PATH"
2018-09-03 22:33:40 -07:00
export USE_SNAP=1
2018-09-04 09:21:03 -07:00
solana_bench_tps=solana.bench-tps
solana_ledger_tool=solana.ledger-tool
2018-09-03 22:33:40 -07:00
ledger=/var/snap/solana/current/config/ledger
;;
local)
PATH="$HOME"/.cargo/bin:"$PATH"
export USE_INSTALL=1
2018-09-04 09:21:03 -07:00
solana_bench_tps="multinode-demo/client.sh $leaderIp:~/solana"
2018-09-03 22:33:40 -07:00
solana_ledger_tool=solana-ledger-tool
ledger=config/ledger
;;
*)
echo "Unknown deployment method: $deployMethod"
exit 1
esac
2018-09-04 09:21:03 -07:00
echo "--- $leaderIp: wallet sanity"
2018-09-03 22:33:40 -07:00
(
set -x
2018-09-04 09:21:03 -07:00
multinode-demo/test/wallet-sanity.sh "$leaderIp"
2018-09-03 22:33:40 -07:00
)
2018-09-04 09:21:03 -07:00
echo "--- $leaderIp: node count"
2018-09-03 22:33:40 -07:00
(
set -x
2018-09-04 09:21:03 -07:00
$solana_bench_tps --num-nodes "$numNodes" --converge-only
2018-09-03 22:33:40 -07:00
)
2018-09-04 09:21:03 -07:00
echo "--- $leaderIp: verify ledger"
2018-09-03 22:33:40 -07:00
if $ledgerVerify; then
if [[ -d $ledger ]]; then
(
set -x
rm -rf /var/tmp/ledger-verify
cp -r $ledger /var/tmp/ledger-verify
$solana_ledger_tool --ledger /var/tmp/ledger-verify verify
)
else
echo "^^^ +++"
echo "Ledger verify skipped"
fi
else
echo "^^^ +++"
echo "Ledger verify skipped (NO_LEDGER_VERIFY defined)"
fi
2018-09-04 09:21:03 -07:00
echo "--- $leaderIp: validator sanity"
2018-09-03 22:33:40 -07:00
if $validatorSanity; then
(
2018-09-04 15:16:25 -07:00
set -ex -o pipefail
2018-09-03 22:33:40 -07:00
./multinode-demo/setup.sh -t validator
2018-09-04 15:16:25 -07:00
timeout 10s ./multinode-demo/validator.sh "$leaderIp" "$leaderIp:8001" 2>&1 | tee validator.log
) || {
exitcode=$?
[[ $exitcode -eq 124 ]] || exit $exitcode
}
2018-09-03 22:33:40 -07:00
wc -l validator.log
if grep -C100 panic validator.log; then
echo "^^^ +++"
echo "Panic observed"
exit 1
else
echo "Validator log looks ok"
fi
else
echo "^^^ +++"
echo "Validator sanity disabled (NO_VALIDATOR_SANITY defined)"
fi