tendermint/test/persist/test_failure_indices.sh

121 lines
2.4 KiB
Bash
Raw Normal View History

2016-09-11 15:32:33 -04:00
#! /bin/bash
export TMROOT=$HOME/.tendermint_persist
2017-02-20 18:51:00 -05:00
rm -rf "$TMROOT"
2016-09-11 15:32:33 -04:00
tendermint init
TM_CMD="tendermint node --log_level=debug" # &> tendermint_${name}.log"
DUMMY_CMD="dummy --persist $TMROOT/dummy" # &> dummy_${name}.log"
2016-09-11 15:32:33 -04:00
function start_procs(){
name=$1
indexToFail=$2
echo "Starting persistent dummy and tendermint"
if [[ "$CIRCLECI" == true ]]; then
$DUMMY_CMD &
else
$DUMMY_CMD &> "dummy_${name}.log" &
fi
2016-09-11 15:32:33 -04:00
PID_DUMMY=$!
if [[ "$indexToFail" == "" ]]; then
# run in background, dont fail
if [[ "$CIRCLECI" == true ]]; then
$TM_CMD &
else
$TM_CMD &> "tendermint_${name}.log" &
fi
2016-09-11 15:32:33 -04:00
PID_TENDERMINT=$!
else
# run in foreground, fail
if [[ "$CIRCLECI" == true ]]; then
FAIL_TEST_INDEX=$indexToFail $TM_CMD
else
FAIL_TEST_INDEX=$indexToFail $TM_CMD &> "tendermint_${name}.log"
fi
2016-09-11 15:32:33 -04:00
PID_TENDERMINT=$!
fi
}
function kill_procs(){
2017-02-20 18:51:00 -05:00
kill -9 "$PID_DUMMY" "$PID_TENDERMINT"
wait "$PID_DUMMY"
wait "$PID_TENDERMINT"
2016-09-11 15:32:33 -04:00
}
# wait till node is up, send txs
function send_txs(){
addr="127.0.0.1:46657"
curl -s $addr/status > /dev/null
ERR=$?
while [ "$ERR" != 0 ]; do
sleep 1
curl -s $addr/status > /dev/null
ERR=$?
done
# send a bunch of txs over a few blocks
echo "Node is up, sending txs"
2017-02-20 18:51:00 -05:00
for i in $(seq 1 5); do
for _ in $(seq 1 100); do
tx=$(head -c 8 /dev/urandom | hexdump -ve '1/1 "%.2X"')
curl -s "$addr/broadcast_tx_async?tx=0x$tx" &> /dev/null
2016-09-11 15:32:33 -04:00
done
sleep 1
done
}
failsStart=0
2017-02-20 18:51:00 -05:00
fails=$(grep -r "fail.Fail" --include \*.go . | wc -l)
failsEnd=$((fails-1))
2016-09-11 15:32:33 -04:00
2017-02-20 18:51:00 -05:00
for failIndex in $(seq $failsStart $failsEnd); do
2016-09-11 15:32:33 -04:00
echo ""
echo "* Test FailIndex $failIndex"
# test failure at failIndex
send_txs &
2017-02-20 18:51:00 -05:00
start_procs 1 "$failIndex"
2016-09-11 15:32:33 -04:00
# tendermint should fail when it hits the fail index
2017-02-20 18:51:00 -05:00
kill -9 "$PID_DUMMY"
wait "$PID_DUMMY"
2016-09-11 15:32:33 -04:00
start_procs 2
# wait for node to handshake and make a new block
addr="localhost:46657"
2017-02-20 18:51:00 -05:00
curl -s "$addr/status" > /dev/null
2016-09-11 15:32:33 -04:00
ERR=$?
i=0
while [ "$ERR" != 0 ]; do
sleep 1
2017-02-20 18:51:00 -05:00
curl -s "$addr/status" > /dev/null
2016-09-11 15:32:33 -04:00
ERR=$?
2017-02-20 18:51:00 -05:00
i=$((i + 1))
2016-09-11 15:32:33 -04:00
if [[ $i == 10 ]]; then
echo "Timed out waiting for tendermint to start"
exit 1
fi
done
# wait for a new block
2017-02-20 18:51:00 -05:00
h1=$(curl -s $addr/status | jq .result[1].latest_block_height)
2016-09-11 15:32:33 -04:00
h2=$h1
while [ "$h2" == "$h1" ]; do
sleep 1
2017-02-20 18:51:00 -05:00
h2=$(curl -s $addr/status | jq .result[1].latest_block_height)
2016-09-11 15:32:33 -04:00
done
kill_procs
echo "* Passed Test for FailIndex $failIndex"
echo ""
done
echo "Passed Test: Persistence"