benchmark.bash: add proper argument handling

This commit is contained in:
Jakob Unterwurzacher 2016-12-13 22:13:54 +01:00
parent 2bacbdf99d
commit 15d6da6c48
1 changed files with 41 additions and 31 deletions

View File

@ -7,52 +7,62 @@ cd "$(dirname "$0")"
MYNAME=$(basename "$0") MYNAME=$(basename "$0")
function usage { function usage {
echo "Usage: $MYNAME [-encfs] [DIR]" echo "Usage: $MYNAME [-encfs] [-openssl=true] [-openssl=false] [DIR]"
exit 1
} }
# Print help text on too many arguments or "-h" OPT_ENCFS=0
if [[ $# -gt 2 ]]; then OPT_OPENSSL=""
usage OPT_DIR=""
elif [[ $# -ge 1 ]] && [[ $1 == "-h" ]]; then
usage
fi
# Set $DIR and $MODE while [[ $# -gt 0 ]] ; do
MODE=gocryptfs case $1 in
DIR=/tmp -h)
if [[ $# -eq 2 ]]; then usage
if [[ $1 != "-encfs" ]]; then exit 1
usage ;;
fi -encfs)
MODE=encfs OPT_ENCFS=1
DIR=$2 ;;
elif [[ $# -eq 1 ]]; then -openssl=true)
if [[ $1 == "-encfs" ]]; then OPT_OPENSSL="-openssl=true"
MODE=encfs ;;
else -openssl=false)
DIR=$1 OPT_OPENSSL="-openssl=false"
fi ;;
-*)
echo "Invalid option: $1"
usage
exit 2
;;
*)
if [[ ! -z $OPT_DIR ]] ; then
echo "Duplicate DIR argument: $1"
usage
exit 3
fi
OPT_DIR=$1
;;
esac
shift
done
if [[ -z $OPT_DIR ]] ; then
OPT_DIR=/tmp
fi fi
# Create directories # Create directories
CRYPT=$(mktemp -d "$DIR/$MYNAME.XXX") CRYPT=$(mktemp -d "$OPT_DIR/$MYNAME.XXX")
MNT=$CRYPT.mnt MNT=$CRYPT.mnt
mkdir $MNT mkdir $MNT
# Mount # Mount
if [[ $MODE == encfs ]]; then if [[ $OPT_ENCFS -eq 1 ]]; then
echo "Testing EncFS at $CRYPT" echo "Testing EncFS at $CRYPT"
encfs --extpass="echo test" --standard $CRYPT $MNT > /dev/null encfs --extpass="echo test" --standard $CRYPT $MNT > /dev/null
else else
echo "Testing gocryptfs at $CRYPT" echo "Testing gocryptfs at $CRYPT"
gocryptfs -q -init -extpass="echo test" -scryptn=10 $CRYPT gocryptfs -q -init -extpass="echo test" -scryptn=10 $CRYPT
# By default, gocryptfs decides between OpenSSL and Go GCM: gocryptfs -q -extpass="echo test" $OPT_OPENSSL $CRYPT $MNT
gocryptfs -q -extpass="echo test" $CRYPT $MNT
# Force use of OpenSSL:
#gocryptfs -q -extpass="echo test" -openssl=true $CRYPT $MNT
# Force use of Go GCM:
#gocryptfs -q -extpass="echo test" -openssl=false $CRYPT $MNT
fi fi
# Cleanup trap # Cleanup trap