2017-06-24 15:51:49 +02:00
|
|
|
#!/bin/bash -eu
|
|
|
|
|
|
|
|
cd "$(dirname "$0")"
|
|
|
|
|
|
|
|
T=$(mktemp -d)
|
2021-08-31 17:01:47 +00:00
|
|
|
mkdir "$T/a" "$T/b"
|
2017-06-24 15:51:49 +02:00
|
|
|
|
2021-09-10 11:51:41 +02:00
|
|
|
set -x
|
|
|
|
../gocryptfs -init -quiet -scryptn 10 -extpass "echo test" "$@" "$T/a"
|
|
|
|
{ set +x ; } 2> /dev/null
|
|
|
|
../gocryptfs -quiet -extpass "echo test" "$@" "$T/a" "$T/b"
|
2017-06-24 15:51:49 +02:00
|
|
|
|
|
|
|
# Cleanup trap
|
|
|
|
trap "cd /; fusermount -u -z $T/b; rm -Rf $T/a" EXIT
|
|
|
|
|
|
|
|
# Write 100MB test file
|
2021-08-31 17:01:47 +00:00
|
|
|
dd if=/dev/zero of="$T/b/zero" bs=1M count=100 status=none
|
2017-06-24 15:51:49 +02:00
|
|
|
|
|
|
|
# Remount with profiling
|
2021-08-31 17:01:47 +00:00
|
|
|
fusermount -u "$T/b"
|
2021-09-10 11:51:41 +02:00
|
|
|
set -x
|
2021-08-31 17:01:47 +00:00
|
|
|
../gocryptfs -quiet -extpass "echo test" -cpuprofile "$T/cprof" -memprofile "$T/mprof" \
|
2021-09-10 11:51:41 +02:00
|
|
|
"$@" "$T/a" "$T/b"
|
|
|
|
{ set +x ; } 2> /dev/null
|
2017-06-24 15:51:49 +02:00
|
|
|
|
|
|
|
# Read 10 x 100MB instead of 1 x 1GB to keep the used disk space low
|
|
|
|
for i in $(seq 1 10); do
|
2021-08-31 17:01:47 +00:00
|
|
|
dd if="$T/b/zero" of=/dev/null bs=1M count=100
|
2017-06-24 15:51:49 +02:00
|
|
|
done
|
|
|
|
|
|
|
|
echo
|
|
|
|
echo "Hint: go tool pprof ../gocryptfs $T/cprof"
|
2017-06-29 19:20:34 +02:00
|
|
|
echo " go tool pprof -alloc_space ../gocryptfs $T/mprof"
|