2012-11-17 17:28:15 +01:00
|
|
|
. ./version.sh
|
|
|
|
|
2012-12-04 00:56:20 +01:00
|
|
|
corpus_size=large
|
|
|
|
|
|
|
|
while test "$#" -ne 0
|
|
|
|
do
|
|
|
|
case "$1" in
|
|
|
|
-d|--debug)
|
|
|
|
debug=t;
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
-s|--small)
|
|
|
|
corpus_size=small;
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
-m|--medium)
|
|
|
|
corpus_size=medium;
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
-l|--large)
|
|
|
|
corpus_size=large;
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "error: unknown performance test option '$1'" >&2; exit 1 ;;
|
|
|
|
esac
|
|
|
|
done
|
2012-11-17 17:28:15 +01:00
|
|
|
. ../test/test-lib-common.sh
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
if ! test -x ../notmuch
|
|
|
|
then
|
|
|
|
echo >&2 'You do not seem to have built notmuch yet.'
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
add_email_corpus ()
|
|
|
|
{
|
|
|
|
rm -rf ${MAIL_DIR}
|
|
|
|
|
2012-12-03 13:13:31 +01:00
|
|
|
case "$corpus_size" in
|
|
|
|
small)
|
|
|
|
mail_subdir="mail/enron/bailey-s"
|
|
|
|
check_for="${TEST_DIRECTORY}/corpus/$mail_subdir"
|
2012-11-17 17:28:15 +01:00
|
|
|
;;
|
2012-12-03 13:13:31 +01:00
|
|
|
medium)
|
|
|
|
mail_subdir="mail/notmuch-archive"
|
|
|
|
check_for="${TEST_DIRECTORY}/corpus/$mail_subdir"
|
2012-11-17 17:28:15 +01:00
|
|
|
;;
|
|
|
|
*)
|
2012-12-03 13:13:31 +01:00
|
|
|
mail_subdir=mail
|
|
|
|
check_for="${TEST_DIRECTORY}/corpus/$mail_subdir/enron/wolfe-j"
|
2012-11-17 17:28:15 +01:00
|
|
|
esac
|
|
|
|
|
2012-12-03 13:13:31 +01:00
|
|
|
MAIL_CORPUS="${TEST_DIRECTORY}/corpus/$mail_subdir"
|
|
|
|
args=()
|
|
|
|
if [ ! -d "$check_for" ] ; then
|
|
|
|
args+=("notmuch-email-corpus/$mail_subdir")
|
2012-11-17 17:28:15 +01:00
|
|
|
fi
|
|
|
|
|
2012-12-03 13:13:31 +01:00
|
|
|
if [[ ${#args[@]} > 0 ]]; then
|
|
|
|
if command -v pixz > /dev/null; then
|
|
|
|
XZ=pixz
|
|
|
|
else
|
|
|
|
XZ=xz
|
|
|
|
fi
|
|
|
|
|
|
|
|
printf "Unpacking corpus\n"
|
|
|
|
mkdir -p "${TEST_DIRECTORY}/corpus"
|
|
|
|
|
|
|
|
tar --checkpoint=.5000 --extract --strip-components=1 \
|
|
|
|
--directory ${TEST_DIRECTORY}/corpus \
|
|
|
|
--use-compress-program ${XZ} \
|
|
|
|
--file ../download/notmuch-email-corpus-${PERFTEST_VERSION}.tar.xz \
|
|
|
|
"${args[@]}"
|
|
|
|
|
|
|
|
printf "\n"
|
2012-11-17 17:28:15 +01:00
|
|
|
|
2012-12-03 13:13:31 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
cp -lr $MAIL_CORPUS $MAIL_DIR
|
2012-11-17 17:28:15 +01:00
|
|
|
}
|
|
|
|
|
2012-12-03 13:13:31 +01:00
|
|
|
|
2012-11-17 17:28:15 +01:00
|
|
|
print_header () {
|
2012-12-06 02:41:44 +01:00
|
|
|
printf "[v%4s %6s] Wall(s)\tUsr(s)\tSys(s)\tRes(K)\tIn/Out(512B)\n" \
|
2012-12-04 03:51:14 +01:00
|
|
|
${PERFTEST_VERSION} ${corpus_size}
|
2012-11-17 17:28:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
time_run () {
|
2012-12-06 02:41:44 +01:00
|
|
|
printf " %-22s" "$1"
|
2012-11-17 17:28:15 +01:00
|
|
|
if test "$verbose" != "t"; then exec 4>test.output 3>&4; fi
|
2012-12-04 03:51:14 +01:00
|
|
|
if ! eval >&3 "/usr/bin/time -f '%e\t%U\t%S\t%M\t%I/%O' $2" ; then
|
2012-11-17 17:28:15 +01:00
|
|
|
test_failure=$(($test_failure + 1))
|
2012-12-06 02:37:29 +01:00
|
|
|
return 1
|
2012-11-17 17:28:15 +01:00
|
|
|
fi
|
2012-12-06 02:37:29 +01:00
|
|
|
return 0
|
2012-11-17 17:28:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
time_done () {
|
|
|
|
if [ "$test_failure" = "0" ]; then
|
|
|
|
rm -rf "$remove_tmp"
|
|
|
|
exit 0
|
|
|
|
else
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
cd -P "$test" || error "Cannot setup test environment"
|
|
|
|
test_failure=0
|
2012-12-06 02:41:44 +01:00
|
|
|
|
|
|
|
echo
|
|
|
|
echo $(basename "$0"): "Testing ${test_description:-notmuch performance}"
|