solana/ci/run-sanity.sh

44 lines
1.3 KiB
Bash
Raw Normal View History

#!/usr/bin/env bash
set -e
cd "$(dirname "$0")/.."
# shellcheck source=multinode-demo/common.sh
source multinode-demo/common.sh
rm -rf config/run/init-completed config/ledger config/snapshot-ledger
SOLANA_RUN_SH_VALIDATOR_ARGS="--full-snapshot-interval-slots 200" timeout 120 ./scripts/run.sh &
pid=$!
attempts=20
while [[ ! -f config/run/init-completed ]]; do
sleep 1
if ((--attempts == 0)); then
echo "Error: validator failed to boot"
exit 1
2021-03-30 15:51:14 -07:00
else
echo "Checking init"
fi
done
2020-06-24 20:48:28 -07:00
snapshot_slot=1
latest_slot=0
2020-06-24 20:48:28 -07:00
# wait a bit longer than snapshot_slot
while [[ $latest_slot -le $((snapshot_slot + 1)) ]]; do
sleep 1
2021-03-30 15:51:14 -07:00
echo "Checking slot"
latest_slot=$($solana_cli --url http://localhost:8899 slot --commitment processed)
done
$solana_validator --ledger config/ledger exit --force || true
wait $pid
2020-06-24 20:48:28 -07:00
$solana_ledger_tool create-snapshot --ledger config/ledger "$snapshot_slot" config/snapshot-ledger
cp config/ledger/genesis.tar.bz2 config/snapshot-ledger
$solana_ledger_tool copy --ledger config/ledger \
--target-db config/snapshot-ledger --starting-slot "$snapshot_slot" --ending-slot "$latest_slot"
$solana_ledger_tool verify --ledger config/snapshot-ledger --block-verification-method blockstore-processor
$solana_ledger_tool verify --ledger config/snapshot-ledger --block-verification-method unified-scheduler