#!/bin/bash ## Coloring style Text shell script COLOR='\033[0;35m' NOCOLOR='\033[0m' BOLD="$(tput bold)" NORM="$(tput sgr0)" set -eu # Exit, with status code "skip" (no 'real' failure) function exit_skip() { echo " SKIP: $1" exit 77 } # Exit, with error message (hard failure) function exit_fail() { echo " FAIL: $1" exit 1 } # Cleanup to run whenever we exit function cleanup() { for n in `jobs -p` do kill $n 2> /dev/null || true done rm -rf $CONF $WALLET_DB $TFILE $UFILE $TMP_DIR wait } CONF_1="test_anastasis_reducer_1.conf" CONF_2="test_anastasis_reducer_2.conf" CONF_3="test_anastasis_reducer_3.conf" CONF_4="test_anastasis_reducer_4.conf" # Exchange configuration file will be edited, so we create one # from the template. CONF=`mktemp test_reducerXXXXXX.conf` cp test_reducer.conf $CONF TMP_DIR=`mktemp -d keys-tmp-XXXXXX` WALLET_DB=`mktemp test_reducer_walletXXXXXX.json` TFILE=`mktemp test_reducer_statePPXXXXXX` UFILE=`mktemp test_reducer_stateBFXXXXXX` # Install cleanup handler (except for kill -9) trap cleanup EXIT # Check we can actually run echo -n "Testing for jq" jq -h > /dev/null || exit_skip "jq required" echo " FOUND" echo -n "Testing for anastasis-reducer ..." anastasis-reducer -h > /dev/null || exit_skip "anastasis-reducer required" echo " FOUND" echo -n "Testing for taler" taler-exchange-httpd -h > /dev/null || exit_skip " taler-exchange required" taler-merchant-httpd -h > /dev/null || exit_skip " taler-merchant required" echo " FOUND" echo -n "Testing for taler-bank-manage" taler-bank-manage --help >/dev/null /dev/null /dev/null /dev/null 2>/dev/null || true createdb $TARGET_DB_1 || exit_skip "Could not create database $TARGET_DB_1" anastasis-dbinit -c $CONF_1 2> anastasis-dbinit_1.log dropdb $TARGET_DB_2 >/dev/null 2>/dev/null || true createdb $TARGET_DB_2 || exit_skip "Could not create database $TARGET_DB_2" anastasis-dbinit -c $CONF_2 2> anastasis-dbinit_2.log dropdb $TARGET_DB_3 >/dev/null 2>/dev/null || true createdb $TARGET_DB_3 || exit_skip "Could not create database $TARGET_DB_3" anastasis-dbinit -c $CONF_3 2> anastasis-dbinit_3.log dropdb $TARGET_DB_4 >/dev/null 2>/dev/null || true createdb $TARGET_DB_4 || exit_skip "Could not create database $TARGET_DB_4" anastasis-dbinit -c $CONF_4 2> anastasis-dbinit_4.log echo " OK" echo -n "Generating Taler auditor, exchange and merchant configurations ..." DATA_DIR=`taler-config -f -c $CONF -s PATHS -o TALER_HOME` rm -rf $DATA_DIR # obtain key configuration data MASTER_PRIV_FILE=`taler-config -f -c $CONF -s "EXCHANGE-OFFLINE" -o "MASTER_PRIV_FILE"` MASTER_PRIV_DIR=`dirname $MASTER_PRIV_FILE` mkdir -p $MASTER_PRIV_DIR gnunet-ecc -g1 $MASTER_PRIV_FILE > /dev/null 2> /dev/null MASTER_PUB=`gnunet-ecc -p $MASTER_PRIV_FILE` EXCHANGE_URL=`taler-config -c $CONF -s EXCHANGE -o BASE_URL` MERCHANT_PORT=`taler-config -c $CONF -s MERCHANT -o PORT` MERCHANT_URL=http://localhost:${MERCHANT_PORT}/ BANK_PORT=`taler-config -c $CONF -s BANK -o HTTP_PORT` BANK_URL=http://localhost:${BANK_PORT}/ AUDITOR_URL=http://localhost:8083/ AUDITOR_PRIV_FILE=`taler-config -f -c $CONF -s AUDITOR -o AUDITOR_PRIV_FILE` AUDITOR_PRIV_DIR=`dirname $AUDITOR_PRIV_FILE` mkdir -p $AUDITOR_PRIV_DIR gnunet-ecc -g1 $AUDITOR_PRIV_FILE > /dev/null 2> /dev/null AUDITOR_PUB=`gnunet-ecc -p $AUDITOR_PRIV_FILE` # patch configuration TALER_DB=talercheck taler-config -c $CONF -s exchange -o MASTER_PUBLIC_KEY -V $MASTER_PUB taler-config -c $CONF -s merchant-exchange-default -o MASTER_KEY -V $MASTER_PUB taler-config -c $CONF -s exchangedb-postgres -o CONFIG -V postgres:///$TALER_DB taler-config -c $CONF -s auditordb-postgres -o CONFIG -V postgres:///$TALER_DB taler-config -c $CONF -s merchantdb-postgres -o CONFIG -V postgres:///$TALER_DB taler-config -c $CONF -s bank -o database -V postgres:///$TALER_DB taler-config -c $CONF -s exchange -o KEYDIR -V "${TMP_DIR}/keydir/" taler-config -c $CONF -s exchange -o REVOCATION_DIR -V "${TMP_DIR}/revdir/" echo " OK" echo -n "Setting up exchange ..." # reset database dropdb $TALER_DB >/dev/null 2>/dev/null || true createdb $TALER_DB || exit_skip "Could not create database $TALER_DB" taler-exchange-dbinit -c $CONF taler-merchant-dbinit -c $CONF taler-auditor-dbinit -c $CONF taler-auditor-exchange -c $CONF -m $MASTER_PUB -u $EXCHANGE_URL echo " OK" # Launch services echo -n "Launching taler services ..." taler-bank-manage-testing $CONF postgres:///$TALER_DB serve > taler-bank.log 2> taler-bank.err & taler-exchange-secmod-eddsa -c $CONF 2> taler-exchange-secmod-eddsa.log & taler-exchange-secmod-rsa -c $CONF 2> taler-exchange-secmod-rsa.log & taler-exchange-httpd -c $CONF 2> taler-exchange-httpd.log & taler-merchant-httpd -c $CONF -L INFO 2> taler-merchant-httpd.log & taler-exchange-wirewatch -c $CONF 2> taler-exchange-wirewatch.log & taler-auditor-httpd -L INFO -c $CONF 2> taler-auditor-httpd.log & echo " OK" echo -n "Launching anastasis services ..." PREFIX="" #valgrind $PREFIX anastasis-httpd -c $CONF_1 2> anastasis-httpd_1.log & $PREFIX anastasis-httpd -c $CONF_2 2> anastasis-httpd_2.log & $PREFIX anastasis-httpd -c $CONF_3 2> anastasis-httpd_3.log & $PREFIX anastasis-httpd -c $CONF_4 2> anastasis-httpd_4.log & # Wait for bank to be available (usually the slowest) for n in `seq 1 50` do echo -n "." sleep 0.2 OK=0 # bank wget --tries=1 --timeout=1 http://localhost:8082/ -o /dev/null -O /dev/null >/dev/null || continue OK=1 break done if [ 1 != $OK ] then exit_skip "Failed to launch services (bank)" fi # Wait for all other taler services to be available for n in `seq 1 50` do echo -n "." sleep 0.1 OK=0 # exchange wget --tries=1 --timeout=1 http://localhost:8081/seed -o /dev/null -O /dev/null >/dev/null || continue # merchant wget --tries=1 --timeout=1 http://localhost:9966/ -o /dev/null -O /dev/null >/dev/null || continue # auditor wget --tries=1 --timeout=1 http://localhost:8083/ -o /dev/null -O /dev/null >/dev/null || continue OK=1 break done if [ 1 != $OK ] then exit_skip "Failed to launch taler services" fi echo "OK" echo -n "Setting up keys ..." taler-exchange-offline -c $CONF \ download \ sign \ enable-account payto://x-taler-bank/localhost/Exchange \ enable-auditor $AUDITOR_PUB $AUDITOR_URL "TESTKUDOS Auditor" \ wire-fee now x-taler-bank TESTKUDOS:0.01 TESTKUDOS:0.01 \ upload &> taler-exchange-offline.log echo -n "." for n in `seq 1 3` do echo -n "." OK=0 wget --tries=1 --timeout=1 http://localhost:8081/keys -o /dev/null -O /dev/null >/dev/null || continue OK=1 break done if [ 1 != $OK ] then exit_skip "Failed to setup keys" fi echo " OK" echo -n "Setting up auditor signatures ..." taler-auditor-offline -c $CONF \ download sign upload &> taler-auditor-offline.log echo " OK" echo -n "Waiting for anastasis services ..." # Wait for anastasis services to be available for n in `seq 1 50` do echo -n "." sleep 0.1 OK=0 # anastasis_01 wget --tries=1 --timeout=1 http://localhost:8086/ -o /dev/null -O /dev/null >/dev/null || continue # anastasis_02 wget --tries=1 --timeout=1 http://localhost:8087/ -o /dev/null -O /dev/null >/dev/null || continue # anastasis_03 wget --tries=1 --timeout=1 http://localhost:8088/ -o /dev/null -O /dev/null >/dev/null || continue # anastasis_04 wget --tries=1 --timeout=1 http://localhost:8089/ -o /dev/null -O /dev/null >/dev/null || continue OK=1 break done if [ 1 != $OK ] then exit_skip "Failed to launch anastasis services" fi echo "OK" echo -n "Configuring merchant instance ..." # Setup merchant curl -H "Content-Type: application/json" -X POST -d '{"auth":{"method":"external"},"payto_uris":["payto://x-taler-bank/localhost/43"],"id":"default","name":"default","address":{},"jurisdiction":{},"default_max_wire_fee":"TESTKUDOS:1", "default_max_deposit_fee":"TESTKUDOS:1","default_wire_fee_amortization":1,"default_wire_transfer_delay":{"d_ms" : 3600000},"default_pay_delay":{"d_ms": 3600000}}' http://localhost:9966/management/instances echo " DONE" echo -en $COLOR$BOLD"Test enter secret in a backup state ..."$NORM$NOCOLOR $PREFIX anastasis-reducer -a \ '{"secret": { "value" : "veryhardtoguesssecret", "mime" : "text/plain" } }' \ enter_secret resources/06-backup.json $TFILE STATE=`jq -r -e .backup_state < $TFILE` if test "$STATE" != "SECRET_EDITING" then jq -e . $TFILE exit_fail "Expected new state to be 'SECRET_EDITING', got '$STATE'" fi echo " DONE" echo -en $COLOR$BOLD"Test expiration change ..."$NORM$NOCOLOR MILLIS=`date '+%s'`000 # Use 156 days into the future to get 1 year MILLIS=`expr $MILLIS + 13478400000` $PREFIX anastasis-reducer -a \ "$(jq -n ' {"expiration": { "t_ms" : $MSEC } }' \ --argjson MSEC $MILLIS )" \ update_expiration $TFILE $UFILE STATE=`jq -r -e .backup_state < $UFILE` if test "$STATE" != "SECRET_EDITING" then jq -e . $UFILE exit_fail "Expected new state to be 'SECRET_EDITING', got '$STATE'" fi FEES=`jq -r -e '.upload_fees[0].fee' < $UFILE` # 4x 4.99 for annual fees, plus 4x0.01 for truth uploads if test "$FEES" != "TESTKUDOS:20" then jq -e . $TFILE exit_fail "Expected upload fees to be 'TESTKUDOS:20', got '$FEES'" fi echo " DONE" echo -en $COLOR$BOLD"Test advance to payment ..."$NORM$NOCOLOR $PREFIX anastasis-reducer next $UFILE $TFILE STATE=`jq -r -e .backup_state < $TFILE` if test "$STATE" != "TRUTHS_PAYING" then jq -e . $TFILE exit_fail "Expected new state to be 'TRUTHS_PAYING', got '$STATE'" fi TMETHOD=`jq -r -e '.policies[0].methods[0].truth.type' < $TFILE` if test $TMETHOD != "question" then exit_fail "Expected method to be >='question', got $TMETHOD" fi echo " OK" #Pay echo -en $COLOR$BOLD"Withdrawing amount to wallet ..."$NORM$NOCOLOR rm $WALLET_DB taler-wallet-cli --no-throttle --wallet-db=$WALLET_DB api 'withdrawTestBalance' \ "$(jq -n ' { amount: "TESTKUDOS:40", bankBaseUrl: $BANK_URL, exchangeBaseUrl: $EXCHANGE_URL }' \ --arg BANK_URL "$BANK_URL" \ --arg EXCHANGE_URL "$EXCHANGE_URL" )" 2>wallet.err >wallet.log taler-wallet-cli --wallet-db=$WALLET_DB run-until-done 2>wallet.err >wallet.log echo " OK" echo -en $COLOR$BOLD"Making payments for truth uploads ... "$NORM$NOCOLOR OBJECT_SIZE=`jq -r -e '.payments | length' < $TFILE` for ((INDEX=0; INDEX < $OBJECT_SIZE; INDEX++)) do PAY_URI=`jq --argjson INDEX $INDEX -r -e '.payments[$INDEX]' < $TFILE` # run wallet CLI echo -n "$INDEX" taler-wallet-cli --wallet-db=$WALLET_DB handle-uri $PAY_URI -y 2>wallet.err >wallet.log echo -n "," done echo " OK" echo -e $COLOR$BOLD"Running wallet run-pending..."$NORM$NOCOLOR taler-wallet-cli --wallet-db=$WALLET_DB run-pending 2>wallet.err >wallet.log echo -e $COLOR$BOLD"Payments done"$NORM$NOCOLOR echo -en $COLOR$BOLD"Try to upload again ..."$NORM$NOCOLOR $PREFIX anastasis-reducer pay $TFILE $UFILE mv $UFILE $TFILE echo " OK" STATE=`jq -r -e .backup_state < $TFILE` if test "$STATE" != "POLICIES_PAYING" then exit_fail "Expected new state to be 'POLICIES_PAYING', got '$STATE'" fi export TFILE export UFILE echo -en $COLOR$BOLD"Making payments for policy uploads ... "$NORM$NOCOLOR OBJECT_SIZE=`jq -r -e '.policy_payment_requests | length' < $TFILE` for ((INDEX=0; INDEX < $OBJECT_SIZE; INDEX++)) do PAY_URI=`jq --argjson INDEX $INDEX -r -e '.policy_payment_requests[$INDEX].payto' < $TFILE` # run wallet CLI export PAY_URI echo -n "$INDEX" taler-wallet-cli --wallet-db=$WALLET_DB handle-uri $PAY_URI -y 2>wallet.err >wallet.log echo -n "," done echo " OK" echo -e $COLOR$BOLD"Running wallet run-pending..."$NORM$NOCOLOR taler-wallet-cli --wallet-db=$WALLET_DB run-pending 2>wallet.err >wallet.log echo -e $COLOR$BOLD"Payments done"$NORM$NOCOLOR echo -en $COLOR$BOLD"Try to upload again ..."$NORM$NOCOLOR $PREFIX anastasis-reducer pay $TFILE $UFILE echo " OK" echo -n "Final checks ..." STATE=`jq -r -e .backup_state < $UFILE` if test "$STATE" != "BACKUP_FINISHED" then exit_fail "Expected new state to be BACKUP_FINISHED, got $STATE" fi jq -r -e .core_secret < $UFILE > /dev/null && exit_fail "'core_secret' was not cleared upon success" echo " OK" exit 0