From d39df012fe5f129308765987e126d1f4fd0831f0 Mon Sep 17 00:00:00 2001 From: alex Date: Fri, 24 Jun 2022 17:58:51 -0700 Subject: [PATCH] ... --- cold-setup | 27 +++++- test/multisig_create.tests.sh | 24 ++++- test/network_off.tests.sh | 20 +++++ test/parse_arguments.tests.sh | 124 ++++++++++++++++++++++++++ test/usb_crypt_close.tests.sh | 28 ++++++ test/usb_crypt_open.tests.sh | 23 +++++ test/usb_detect.tests.sh | 15 ++++ test/usb_eject.tests.sh | 19 ++++ test/usb_encrypt.tests.sh | 19 ++++ test/usb_load.tests.sh | 26 ++++++ test/usb_mount.tests.sh | 34 +++++++ test/usb_setup.tests.sh | 52 +++++++++++ test/usb_unmount.tests.sh | 33 +++++++ test/usbs.tests.sh | 63 +++++++++++++ test/validate_parameters.tests.sh | 31 +++++++ test/wallet_dump_descriptors.tests.sh | 8 ++ 16 files changed, 542 insertions(+), 4 deletions(-) mode change 100644 => 100755 test/multisig_create.tests.sh create mode 100755 test/network_off.tests.sh create mode 100755 test/parse_arguments.tests.sh create mode 100755 test/usb_crypt_close.tests.sh create mode 100755 test/usb_crypt_open.tests.sh create mode 100755 test/usb_detect.tests.sh create mode 100755 test/usb_eject.tests.sh create mode 100755 test/usb_encrypt.tests.sh create mode 100755 test/usb_load.tests.sh create mode 100755 test/usb_mount.tests.sh create mode 100755 test/usb_setup.tests.sh create mode 100755 test/usb_unmount.tests.sh create mode 100755 test/usbs.tests.sh create mode 100755 test/validate_parameters.tests.sh diff --git a/cold-setup b/cold-setup index 559b83f..ce70753 100755 --- a/cold-setup +++ b/cold-setup @@ -7,6 +7,7 @@ M=3 N=7 MODE= ENCRYPTION="luks" +USB_PATH= USB_DIRECTORY="$DATA_DIRECTORY/.usb" USB_DECRYPT_NAME="cold-usb" USB_PATH_PRE_DECRYPT= @@ -209,6 +210,7 @@ usb_crypt_close() { log_info "closing encrypted usb..." cryptsetup luksClose "$USB_DECRYPT_NAME" USB_PATH="$USB_PATH_PRE_DECRYPT" + USB_PATH_PRE_DECRYPT="" } usb_detect() { @@ -256,15 +258,15 @@ usb_load() { cp "$DATA_DIRECTORY/wallet$1.descriptors" "$USB_DIRECTORY/" cp "$DATA_DIRECTORY/descriptors.txt" "$USB_DIRECTORY/" - local EXPECTED="`b2sum $DATA_DIRECTORY/wallet$1.descriptors $DATA_DIRECTORY/descriptors.txt`" - local RESULT="`b2sum $USB_DIRECTORY/wallet$1.descriptors $USB_DIRECTORY/descriptors.txt`" + local EXPECTED="`b2sum $DATA_DIRECTORY/wallet$1.descriptors $DATA_DIRECTORY/descriptors.txt | grep -o '^\S*'`" + local RESULT="`b2sum $USB_DIRECTORY/wallet$1.descriptors $USB_DIRECTORY/descriptors.txt| grep -o '^\S*'`" if [[ "$EXPECTED" != "$RESULT" ]]; then log_error "ERROR: failed to copy descriptors to usb correctly" exit 1 fi - shred "$DATA_DIRECTORY/wallet$1.descriptors" + shred -u "$DATA_DIRECTORY/wallet$1.descriptors" log_info "successfully copied descriptors to usb" } @@ -274,6 +276,7 @@ usb_mount() { usb_decrypt fi + mkdir -p "$USB_DIRECTORY" log_info "mounting $USB_PATH at $USB_DIRECTORY" mount "$USB_PATH" "$USB_DIRECTORY" } @@ -343,6 +346,8 @@ validate_parameters() { } wallet_change_descriptors() { + wallet_exists "$1" + local CMD="$BITCOIN_CLI -rpcwallet=wallet$1 listdescriptors | jq -j '.descriptors | map(select(.desc | startswith(\"wpkh(\"))) | map(select(.internal == true)) | map(.desc | ltrimstr(\"wpkh(\")) | .[] | split(\")\") | .[0]'" local DESCRIPTORS=$(eval "$CMD") echo "$DESCRIPTORS" @@ -361,12 +366,16 @@ wallet_create_blank() { } wallet_descriptors() { + wallet_exists "$1" + local CMD="$BITCOIN_CLI -rpcwallet=wallet$1 listdescriptors | jq -j '.descriptors | map(select(.desc | startswith(\"wpkh(\"))) | map(select(.internal == false)) | map(.desc | ltrimstr(\"wpkh(\")) | .[] | split(\")\") | .[0]'" local DESCRIPTORS=$(eval "$CMD") echo "$DESCRIPTORS" } wallet_dump_descriptors() { + wallet_exists "$1" + local DUMPFILE="$DATA_DIRECTORY/wallet$1.descriptors" umask 0077 local CMD="$BITCOIN_CLI -named -rpcwallet=wallet$1 listdescriptors private=true" @@ -374,6 +383,18 @@ wallet_dump_descriptors() { log_info "dumped descriptors for wallet$1 into $DUMPFILE" } +wallet_exists() { + local CMD="$BITCOIN_CLI -named -rpcwallet=wallet$1 getwalletinfo" + + set +e + eval "$CMD" >/dev/null 2>&1 + set -e + if [[ "$?" -ne 0 ]]; then + log_error "ERROR: wallet$1 doesn't exist" + exit 1 + fi +} + wallet_load() { if [[ ! -e "$2" ]]; then log_error "file not found: $2" diff --git a/test/multisig_create.tests.sh b/test/multisig_create.tests.sh old mode 100644 new mode 100755 index e4471f3..a6333f3 --- a/test/multisig_create.tests.sh +++ b/test/multisig_create.tests.sh @@ -6,7 +6,29 @@ source setup.sh setup_env -test_failed +setup_test_wallets + +multisig_create +EXPECTED="87faa7387bf537283ef62654bf897c4198e3e27c7c97868cdda2e9dcf1945685dfc00722272a97f690afdb6549aaf16fe3e05f78c5fef8447b798787dd092891 .data/descriptors.txt" +assert "$EXPECTED" "`b2sum $DATA_DIRECTORY/descriptors.txt`" + +M=1 +N=3 +multisig_create +EXPECTED="a4cfdcbe25bd990e66bd6f8f86597cbeca08fb38b5fa448f7d77e9bc8de24e52c6dabfd25e6ddd1e716c6fac695af5e5d830a43e654a84c1bb51db937599f37f .data/descriptors.txt" +assert "$EXPECTED" "`b2sum $DATA_DIRECTORY/descriptors.txt`" + +M=3 +N=5 +multisig_create +EXPECTED="702de574ece926314e6ffdc2cba809549eeea97e5e3de16dfed41c462dcc84ffeb9bcd2a5b95b7aa3747c336aa6ad7beaeb7376e607a35c7cd762db9bb6b2425 .data/descriptors.txt" +assert "$EXPECTED" "`b2sum $DATA_DIRECTORY/descriptors.txt`" + +M=6 +N=7 +multisig_create +EXPECTED="48513d041c3eeaa162dde91f252dee4925eb1a2ecb8099ca6d64a121e913ca49322fea7eaf00af8a80dfc59f6764033272f81bb369b3eebcfbd19d6054863410 .data/descriptors.txt" +assert "$EXPECTED" "`b2sum $DATA_DIRECTORY/descriptors.txt`" clean_env diff --git a/test/network_off.tests.sh b/test/network_off.tests.sh new file mode 100755 index 0000000..a62261e --- /dev/null +++ b/test/network_off.tests.sh @@ -0,0 +1,20 @@ +#!/usr/bin/env bash + +set -euo pipefail + +source setup.sh + +setup_env + +network_off() { + echo "interfaces all off..." +} + +(network_off > result) +EXPECTED="interfaces all off..." +RESULT=$(&1) +set -e + +set +e +(parse_arguments "--notanargumenthelp" > result 2>&1) +assert "1" "$?" +set -e +EXPECTED="${BASH_SOURCE[0]}: illegal option -- - +$USAGE" +assert "$EXPECTED" "$( result 2>&1) +assert "1" "$?" +set -e +assert "$USAGE" "$( result 2>&1) +assert "1" "$?" +set -e +assert "$USAGE" "$( result 2>&1) +assert "1" "$?" +set -e + +EXPECTED="${BASH_SOURCE[0]}: option requires an argument -- m +$USAGE" +assert "$EXPECTED" "$( result 2>&1) +assert "1" "$?" +set -e + +EXPECTED="ERROR: invalid threshold (-1)" +assert "$EXPECTED" "$( result 2>&1) +assert "1" "$?" +set -e + +EXPECTED="ERROR: invalid threshold (0)" +assert "$EXPECTED" "$( result 2>&1) +assert "1" "$?" +set -e + +EXPECTED="${BASH_SOURCE[0]}: option requires an argument -- n +$USAGE" +assert "$EXPECTED" "$( result 2>&1) +assert "1" "$?" +set -e + +EXPECTED="ERROR: invalid wallet count (-1)" +assert "$EXPECTED" "$( result 2>&1) +assert "1" "$?" +set -e + +EXPECTED="ERROR: invalid wallet count (0)" +assert "$EXPECTED" "$( /dev/null +} + +USB_PATH="/dev/sdzzzzz" +usb_crypt_open > /dev/null + +assert "/dev/sdzzzzz" "$USB_PATH_PRE_DECRYPT" +assert "/dev/mapper/$USB_DECRYPT_NAME" "$USB_PATH" + +usb_crypt_close > /dev/null + +assert "/dev/sdzzzzz" "$USB_PATH" +assert "" "$USB_PATH_PRE_DECRYPT" + +cd .. +rm -rf "$TEST_DIR" + +test_succeeded diff --git a/test/usb_crypt_open.tests.sh b/test/usb_crypt_open.tests.sh new file mode 100755 index 0000000..8727356 --- /dev/null +++ b/test/usb_crypt_open.tests.sh @@ -0,0 +1,23 @@ +#!/usr/bin/env bash + +set -euo pipefail + +source setup.sh + +mkdir "$TEST_DIR" +cd "$TEST_DIR" + +cryptsetup() { + echo "cryptsetup..." > /dev/null +} + +USB_PATH="/dev/sdzzzzz" +usb_crypt_open > /dev/null + +assert "/dev/sdzzzzz" "$USB_PATH_PRE_DECRYPT" +assert "/dev/mapper/$USB_DECRYPT_NAME" "$USB_PATH" + +cd .. +rm -rf "$TEST_DIR" + +test_succeeded diff --git a/test/usb_detect.tests.sh b/test/usb_detect.tests.sh new file mode 100755 index 0000000..252e259 --- /dev/null +++ b/test/usb_detect.tests.sh @@ -0,0 +1,15 @@ +#!/usr/bin/env bash + +set -euo pipefail + +source setup.sh + +mkdir "$TEST_DIR" +cd "$TEST_DIR" + +test_failed + +cd .. +rm -rf "$TEST_DIR" + +test_succeeded diff --git a/test/usb_eject.tests.sh b/test/usb_eject.tests.sh new file mode 100755 index 0000000..055df3a --- /dev/null +++ b/test/usb_eject.tests.sh @@ -0,0 +1,19 @@ +#!/usr/bin/env bash + +set -euo pipefail + +source setup.sh + +mkdir "$TEST_DIR" +cd "$TEST_DIR" + +eject() { + echo "eject..." +} + +usb_eject > /dev/null + +cd .. +rm -rf "$TEST_DIR" + +test_succeeded diff --git a/test/usb_encrypt.tests.sh b/test/usb_encrypt.tests.sh new file mode 100755 index 0000000..f60cd18 --- /dev/null +++ b/test/usb_encrypt.tests.sh @@ -0,0 +1,19 @@ +#!/usr/bin/env bash + +set -euo pipefail + +source setup.sh + +mkdir "$TEST_DIR" +cd "$TEST_DIR" + +cryptsetup() { + echo "cryptsetup..." +} + +usb_encrypt > /dev/null + +cd .. +rm -rf "$TEST_DIR" + +test_succeeded diff --git a/test/usb_load.tests.sh b/test/usb_load.tests.sh new file mode 100755 index 0000000..4876cc5 --- /dev/null +++ b/test/usb_load.tests.sh @@ -0,0 +1,26 @@ +#!/usr/bin/env bash + +set -euo pipefail + +source setup.sh + +setup_env + +setup_test_wallets + +multisig_create +mkdir -p "$USB_DIRECTORY" + +(usb_load 1 > result) +EXPECTED="copying descriptors to usb... +dumped descriptors for wallet1 into $DATA_DIRECTORY/wallet1.descriptors +successfully copied descriptors to usb" +assert "$EXPECTED" "$( result) +EXPECTED="usb_decrypt... +mounting $USB_PATH at $USB_DIRECTORY +mount..." +assert "$EXPECTED" "$( result) +EXPECTED="mounting $USB_PATH at $USB_DIRECTORY +mount..." +assert "$EXPECTED" "$( result) +EXPECTED="wipefs... +filesystem wiped from $USB_PATH +usb_encrypt... +zero'ing $USB_PATH +dd... +$USB_PATH filled with zeroes +mkfs.ext4... +created new filesystem on $USB_PATH" +assert "$EXPECTED" "$( result) +EXPECTED="wipefs... +filesystem wiped from $USB_PATH +zero'ing $USB_PATH +dd... +$USB_PATH filled with zeroes +mkfs.ext4... +created new filesystem on $USB_PATH" +assert "$EXPECTED" "$( result) +EXPECTED="unmounting $USB_DIRECTORY... +umount... +usb_crypt_close..." +assert "$EXPECTED" "$( result) +EXPECTED="unmounting $USB_DIRECTORY... +umount..." +assert "$EXPECTED" "$( result) +EXPECTED=$'creating primary usbs...\n' +for((i = 1; i <= "$N"; i++)); do + EXPECTED+="plug in usb stick for wallet $i... +found usb stick $USB_PATH +usb_setup... +usb_load... +usb_unmount... +usb_eject... +" +done + +EXPECTED+=$'creating backup usbs...\n' +for((i = 1; i <= "$N"; i++)); do + EXPECTED+="plug in usb stick for wallet $i... +found usb stick $USB_PATH +usb_setup... +usb_load... +usb_unmount... +usb_eject..." + if [[ "$i" -ne "$N" ]]; then + EXPECTED+=" +" + fi +done + +assert "$EXPECTED" "$( result 2>&1) +assert "1" "$?" +set -e +EXPECTED="ERROR: threshold>wallets (3>2)" +assert "$EXPECTED" "$( result 2>&1) +assert "1" "$?" +set -e +EXPECTED=$'ERROR: no multisignature to be created (1 of 1)\nexitting...' +assert "$EXPECTED" "$( result 2>&1) +assert "1" "$?" +set -e +EXPECTED="ERROR: wallet2 doesn't exist" +RESULT=$(