cosmos-sdk/tests/cli/common.sh

261 lines
9.3 KiB
Bash
Raw Normal View History

2017-06-20 04:21:06 -07:00
# This is not executable, but helper functions for the other scripts
2017-06-20 04:21:06 -07:00
# XXX XXX XXX XXX XXX
# The following global variables must be defined before calling common functions:
2017-06-20 04:21:06 -07:00
# SERVER_EXE=foobar # Server binary name
# CLIENT_EXE=foobarcli # Client binary name
# ACCOUNTS=(foo bar) # List of accounts for initialization
2017-06-20 04:21:06 -07:00
# RICH=${ACCOUNTS[0]} # Account to assign genesis balance
2017-06-15 11:56:59 -07:00
2017-06-28 22:29:10 -07:00
# XXX Ex Usage: quickSetup $WORK_NAME $CHAIN_ID
2017-06-21 02:46:37 -07:00
# Desc: Start the program, use with shunit2 OneTimeSetUp()
quickSetup() {
2017-06-28 22:29:10 -07:00
# These are passed in as args
BASE_DIR=$HOME/$1
CHAIN_ID=$2
2017-06-21 02:46:37 -07:00
2017-06-28 22:29:10 -07:00
rm -rf $BASE_DIR 2>/dev/null
mkdir -p $BASE_DIR
2017-06-21 02:46:37 -07:00
2017-06-28 22:29:10 -07:00
# Set up client - make sure you use the proper prefix if you set
# a custom CLIENT_EXE
export BC_HOME=${BASE_DIR}/client
prepareClient
2017-06-21 02:46:37 -07:00
2017-06-28 22:29:10 -07:00
# start basecoin server (with counter)
initServer $BASE_DIR $CHAIN_ID
if [ $? != 0 ]; then return 1; fi
2017-06-21 02:46:37 -07:00
2017-06-28 22:29:10 -07:00
initClient $CHAIN_ID
if [ $? != 0 ]; then return 1; fi
2017-06-21 02:46:37 -07:00
2017-06-28 22:29:10 -07:00
printf "...Testing may begin!\n\n\n"
2017-06-21 02:46:37 -07:00
}
# XXX Ex Usage: quickTearDown
# Desc: close the test server, use with shunit2 OneTimeTearDown()
quickTearDown() {
2017-06-28 22:29:10 -07:00
printf "\n\nstopping $SERVER_EXE test server..."
kill -9 $PID_SERVER >/dev/null 2>&1
sleep 1
2017-06-21 02:46:37 -07:00
}
############################################################
prepareClient() {
2017-06-28 22:29:10 -07:00
echo "Preparing client keys..."
${CLIENT_EXE} reset_all
2017-07-13 16:29:53 -07:00
assertTrue "line=${LINENO}, prepare client" $?
2017-06-28 22:29:10 -07:00
for i in "${!ACCOUNTS[@]}"; do
newKey ${ACCOUNTS[$i]}
done
}
2017-06-20 04:21:06 -07:00
# XXX Ex Usage1: initServer $ROOTDIR $CHAINID
# XXX Ex Usage2: initServer $ROOTDIR $CHAINID $PORTPREFIX
# Desc: Grabs the Rich account and gives it all genesis money
# port-prefix default is 4665{6,7,8}
initServer() {
2017-06-28 22:29:10 -07:00
echo "Setting up genesis..."
SERVE_DIR=$1/server
2017-07-13 16:29:53 -07:00
assertNotNull "line=${LINENO}, no chain" $2
2017-06-28 22:29:10 -07:00
CHAIN=$2
SERVER_LOG=$1/${SERVER_EXE}.log
GENKEY=$(${CLIENT_EXE} keys get ${RICH} | awk '{print $2}')
${SERVER_EXE} init --chain-id $CHAIN $GENKEY --home=$SERVE_DIR >>$SERVER_LOG
# optionally set the port
if [ -n "$3" ]; then
echo "setting port $3"
sed -ie "s/4665/$3/" $SERVE_DIR/config.toml
fi
echo "Starting ${SERVER_EXE} server..."
startServer $SERVE_DIR $SERVER_LOG
return $?
}
2017-06-21 09:50:36 -07:00
# XXX Ex Usage: startServer $SERVE_DIR $SERVER_LOG
startServer() {
2017-06-28 22:29:10 -07:00
${SERVER_EXE} start --home=$1 >>$2 2>&1 &
sleep 5
PID_SERVER=$!
disown
if ! ps $PID_SERVER >/dev/null; then
echo "**FAILED**"
cat $SERVER_LOG
return 1
fi
}
2017-06-20 04:21:06 -07:00
# XXX Ex Usage1: initClient $CHAINID
# XXX Ex Usage2: initClient $CHAINID $PORTPREFIX
# Desc: Initialize the client program
# port-prefix default is 46657
initClient() {
2017-06-28 22:29:10 -07:00
echo "Attaching ${CLIENT_EXE} client..."
PORT=${2:-46657}
# hard-code the expected validator hash
${CLIENT_EXE} init --chain-id=$1 --node=tcp://localhost:${PORT} --valhash=EB168E17E45BAEB194D4C79067FFECF345C64DE6
2017-07-13 16:29:53 -07:00
assertTrue "line=${LINENO}, initialized light-client" $?
}
2017-06-20 04:21:06 -07:00
# XXX Ex Usage1: newKey $NAME
# XXX Ex Usage2: newKey $NAME $PASSWORD
# Desc: Generates key for given username and password
newKey(){
2017-07-13 16:29:53 -07:00
assertNotNull "line=${LINENO}, keyname required" "$1"
2017-06-28 22:29:10 -07:00
KEYPASS=${2:-qwertyuiop}
(echo $KEYPASS; echo $KEYPASS) | ${CLIENT_EXE} keys new $1 >/dev/null 2>/dev/null
2017-07-13 16:29:53 -07:00
assertTrue "line=${LINENO}, created $1" $?
assertTrue "line=${LINENO}, $1 doesn't exist" "${CLIENT_EXE} keys get $1"
}
2017-06-20 04:21:06 -07:00
# XXX Ex Usage: getAddr $NAME
# Desc: Gets the address for a key name
getAddr() {
2017-07-13 16:29:53 -07:00
assertNotNull "line=${LINENO}, keyname required" "$1"
2017-06-28 22:29:10 -07:00
RAW=$(${CLIENT_EXE} keys get $1)
2017-07-13 16:29:53 -07:00
assertTrue "line=${LINENO}, no key for $1" $?
2017-06-28 22:29:10 -07:00
# print the addr
echo $RAW | cut -d' ' -f2
}
2017-06-16 05:26:35 -07:00
# XXX Ex Usage: checkAccount $ADDR $AMOUNT
2017-06-20 04:21:06 -07:00
# Desc: Assumes just one coin, checks the balance of first coin in any case
2017-06-16 05:26:35 -07:00
checkAccount() {
2017-06-28 22:29:10 -07:00
# make sure sender goes down
ACCT=$(${CLIENT_EXE} query account $1)
2017-07-13 16:29:53 -07:00
if ! assertTrue "line=${LINENO}, account must exist" $?; then
2017-06-28 22:29:10 -07:00
return 1
fi
if [ -n "$DEBUG" ]; then echo $ACCT; echo; fi
2017-07-13 16:29:53 -07:00
assertEquals "line=${LINENO}, proper money" "$2" $(echo $ACCT | jq .data.coins[0].amount)
2017-06-28 22:29:10 -07:00
return $?
2017-06-16 05:26:35 -07:00
}
# XXX Ex Usage: checkRole $ROLE $SIGS $NUM_SIGNERS
# Desc: Ensures this named role exists, and has the number of members and required signatures as above
checkRole() {
# make sure sender goes down
ROLE=$(${CLIENT_EXE} query role $1)
if ! assertTrue "line=${LINENO}, role must exist" $?; then
return 1
fi
if [ -n "$DEBUG" ]; then echo $ROLE; echo; fi
assertEquals "line=${LINENO}, proper sigs" "$2" $(echo $ROLE | jq .data.min_sigs)
assertEquals "line=${LINENO}, proper app" '"sigs"' $(echo $ROLE | jq '.data.signers[0].app' )
assertEquals "line=${LINENO}, proper signers" "$3" $(echo $ROLE | jq '.data.signers | length')
return $?
}
# XXX Ex Usage: txSucceeded $? "$TX" "$RECIEVER"
2017-06-20 04:21:06 -07:00
# Desc: Must be called right after the `tx` command, makes sure it got a success response
2017-06-16 05:26:35 -07:00
txSucceeded() {
2017-07-18 21:13:39 -07:00
if (assertTrue "line=${LINENO}, sent tx ($3): $2" $1); then
2017-06-28 22:29:10 -07:00
TX=$2
2017-07-13 16:29:53 -07:00
assertEquals "line=${LINENO}, good check ($3): $TX" "0" $(echo $TX | jq .check_tx.code)
assertEquals "line=${LINENO}, good deliver ($3): $TX" "0" $(echo $TX | jq .deliver_tx.code)
2017-06-28 22:29:10 -07:00
else
return 1
fi
2017-06-16 05:26:35 -07:00
}
2017-06-20 04:21:06 -07:00
# XXX Ex Usage: checkSendTx $HASH $HEIGHT $SENDER $AMOUNT
# Desc: This looks up the tx by hash, and makes sure the height and type match
# and that the first input was from this sender for this amount
2017-06-16 05:26:35 -07:00
checkSendTx() {
2017-06-28 22:29:10 -07:00
TX=$(${CLIENT_EXE} query tx $1)
2017-07-13 16:29:53 -07:00
assertTrue "line=${LINENO}, found tx" $?
2017-06-28 22:29:10 -07:00
if [ -n "$DEBUG" ]; then echo $TX; echo; fi
2017-07-13 16:29:53 -07:00
assertEquals "line=${LINENO}, proper height" $2 $(echo $TX | jq .height)
assertEquals "line=${LINENO}, type=sigs/one" '"sigs/one"' $(echo $TX | jq .data.type)
2017-07-14 13:29:43 -07:00
CTX=$(echo $TX | jq .data.data.tx)
2017-07-13 16:29:53 -07:00
assertEquals "line=${LINENO}, type=chain/tx" '"chain/tx"' $(echo $CTX | jq .type)
2017-07-14 13:29:43 -07:00
NTX=$(echo $CTX | jq .data.tx)
assertEquals "line=${LINENO}, type=nonce" '"nonce"' $(echo $NTX | jq .type)
STX=$(echo $NTX | jq .data.tx)
2017-07-13 16:29:53 -07:00
assertEquals "line=${LINENO}, type=coin/send" '"coin/send"' $(echo $STX | jq .type)
assertEquals "line=${LINENO}, proper sender" "\"$3\"" $(echo $STX | jq .data.inputs[0].address.addr)
assertEquals "line=${LINENO}, proper out amount" "$4" $(echo $STX | jq .data.outputs[0].coins[0].amount)
2017-06-28 22:29:10 -07:00
return $?
2017-06-16 05:26:35 -07:00
}
# XXX Ex Usage: toHex "my-name"
# converts the string into the hex representation of the bytes
toHex() {
echo -n $1 | od -A n -t x1 | sed 's/ //g' | tr 'a-f' 'A-F'
}
# XXX Ex Usage: checkRoleTx $HASH $HEIGHT $NAME $NUM_SIGNERS
# Desc: This looks up the tx by hash, and makes sure the height and type match
# and that the it refers to the proper role
checkRoleTx() {
TX=$(${CLIENT_EXE} query tx $1)
assertTrue "line=${LINENO}, found tx" $?
if [ -n "$DEBUG" ]; then echo $TX; echo; fi
assertEquals "line=${LINENO}, proper height" $2 $(echo $TX | jq .height)
assertEquals "line=${LINENO}, type=sigs/one" '"sigs/one"' $(echo $TX | jq .data.type)
CTX=$(echo $TX | jq .data.data.tx)
assertEquals "line=${LINENO}, type=chain/tx" '"chain/tx"' $(echo $CTX | jq .type)
NTX=$(echo $CTX | jq .data.tx)
assertEquals "line=${LINENO}, type=nonce" '"nonce"' $(echo $NTX | jq .type)
RTX=$(echo $NTX | jq .data.tx)
assertEquals "line=${LINENO}, type=role/create" '"role/create"' $(echo $RTX | jq .type)
HEXNAME=$(toHex $3)
assertEquals "line=${LINENO}, proper name" "\"$HEXNAME\"" $(echo $RTX | jq .data.role)
assertEquals "line=${LINENO}, proper num signers" "$4" $(echo $RTX | jq '.data.signers | length')
return $?
}
2017-07-12 12:04:34 -07:00
# XXX Ex Usage: checkSendFeeTx $HASH $HEIGHT $SENDER $AMOUNT $FEE
# Desc: This is like checkSendTx, but asserts a feetx wrapper with $FEE value.
# This looks up the tx by hash, and makes sure the height and type match
# and that the first input was from this sender for this amount
checkSendFeeTx() {
TX=$(${CLIENT_EXE} query tx $1)
2017-07-18 21:13:39 -07:00
assertTrue "line=${LINENO}, found tx" $?
2017-07-12 12:04:34 -07:00
if [ -n "$DEBUG" ]; then echo $TX; echo; fi
2017-07-13 16:29:53 -07:00
assertEquals "line=${LINENO}, proper height" $2 $(echo $TX | jq .height)
assertEquals "line=${LINENO}, type=sigs/one" '"sigs/one"' $(echo $TX | jq .data.type)
2017-07-14 13:29:43 -07:00
CTX=$(echo $TX | jq .data.data.tx)
2017-07-13 16:29:53 -07:00
assertEquals "line=${LINENO}, type=chain/tx" '"chain/tx"' $(echo $CTX | jq .type)
2017-07-14 13:29:43 -07:00
NTX=$(echo $CTX | jq .data.tx)
assertEquals "line=${LINENO}, type=nonce" '"nonce"' $(echo $NTX | jq .type)
FTX=$(echo $NTX | jq .data.tx)
2017-07-13 16:29:53 -07:00
assertEquals "line=${LINENO}, type=fee/tx" '"fee/tx"' $(echo $FTX | jq .type)
assertEquals "line=${LINENO}, proper fee" "$5" $(echo $FTX | jq .data.fee.amount)
2017-07-12 12:04:34 -07:00
STX=$(echo $FTX | jq .data.tx)
2017-07-13 16:29:53 -07:00
assertEquals "line=${LINENO}, type=coin/send" '"coin/send"' $(echo $STX | jq .type)
assertEquals "line=${LINENO}, proper sender" "\"$3\"" $(echo $STX | jq .data.inputs[0].address.addr)
assertEquals "line=${LINENO}, proper out amount" "$4" $(echo $STX | jq .data.outputs[0].coins[0].amount)
2017-07-12 12:04:34 -07:00
return $?
}
2017-06-20 04:21:06 -07:00
# XXX Ex Usage: waitForBlock $port
# Desc: Waits until the block height on that node increases by one
2017-06-16 06:33:37 -07:00
waitForBlock() {
2017-06-28 22:29:10 -07:00
addr=http://localhost:$1
b1=`curl -s $addr/status | jq .result.latest_block_height`
b2=$b1
while [ "$b2" == "$b1" ]; do
echo "Waiting for node $addr to commit a block ..."
sleep 1
b2=`curl -s $addr/status | jq .result.latest_block_height`
done
2017-06-16 06:33:37 -07:00
}