benchmark.bash: add proper argument handling
This commit is contained in:
parent
2bacbdf99d
commit
15d6da6c48
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user