unofficial mirror of notmuch@notmuchmail.org
 help / color / mirror / code / Atom feed
blob c9b131a5cddcbebe8e0902178dda18cd80479e31 2051 bytes (raw)
name: performance-test/perf-test-lib.sh 	 # note: path name is non-authoritative(*)

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
 
. ./version.sh

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
. ../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

CORPUS_DIR=${TEST_DIRECTORY}/corpus.mail.$corpus_size
DB_CACHE_DIR=${TEST_DIRECTORY}/notmuch.cache.$corpus_size

add_email_corpus ()
{
    rm -rf ${MAIL_DIR}
    if [ ! -d $CORPUS_DIR ]; then
	case "$corpus_size" in
	    small)
		arg="mail/enron/bailey-s"
		;;
	    medium)
		arg="mail/notmuch-archive"
		;;
	    *)
		arg=mail
	esac

	if command -v pixz > /dev/null; then
	    XZ=pixz
	else
	    XZ=xz
	fi

	printf "Unpacking corpus\n"
	mkdir $CORPUS_DIR

	tar --checkpoint=.5000 --extract --strip-components=2 \
	    --directory $CORPUS_DIR \
	    --use-compress-program ${XZ} \
	    --file ../download/notmuch-email-corpus-${PERFTEST_VERSION}.tar.xz \
	    notmuch-email-corpus/"$arg"

	printf "\n"

    fi

    cp -lr $CORPUS_DIR $MAIL_DIR

    if [ -d $DB_CACHE_DIR ]; then
	cp -r $DB_CACHE_DIR ${MAIL_DIR}/.notmuch
    fi
}

cache_database () {
    if [ -d $MAIL_DIR/.notmuch ]; then
	cp -r $MAIL_DIR/.notmuch $DB_CACHE_DIR
    else
	echo "Warning: No database found to cache"
    fi
}

uncache_database () {
    rm -rf $DB_CACHE_DIR
}

print_header () {
    printf "[v%4s]               Wall(s)\tUsr(s)\tSys(s)\tRes(K)\tIn(512B)\tOut(512B)\n" \
	   ${PERFTEST_VERSION}
}

time_run () {
    printf "%-22s" "$1"
    if test "$verbose" != "t"; then exec 4>test.output 3>&4; fi
    if ! eval >&3 "/usr/bin/time -f '%e\t%U\t%S\t%M\t%I\t%O' $2" ; then
	test_failure=$(($test_failure + 1))
    fi
}

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

debug log:

solving c9b131a ...
found c9b131a in https://yhetil.org/notmuch/1354583824-10520-3-git-send-email-david@tethera.net/
found 9fbf874 in https://yhetil.org/notmuch/1354583824-10520-2-git-send-email-david@tethera.net/
found bba793d in https://yhetil.org/notmuch/1354583824-10520-1-git-send-email-david@tethera.net/
found 1399d05 in https://yhetil.org/notmuch.git/
preparing index
index prepared:
100644 1399d0598060b82a3beb5be3679c4f4dba2ec1bf	performance-test/perf-test-lib.sh

applying [1/3] https://yhetil.org/notmuch/1354583824-10520-1-git-send-email-david@tethera.net/
diff --git a/performance-test/perf-test-lib.sh b/performance-test/perf-test-lib.sh
index 1399d05..bba793d 100644


applying [2/3] https://yhetil.org/notmuch/1354583824-10520-2-git-send-email-david@tethera.net/
diff --git a/performance-test/perf-test-lib.sh b/performance-test/perf-test-lib.sh
index bba793d..9fbf874 100644


applying [3/3] https://yhetil.org/notmuch/1354583824-10520-3-git-send-email-david@tethera.net/
diff --git a/performance-test/perf-test-lib.sh b/performance-test/perf-test-lib.sh
index 9fbf874..c9b131a 100644

Checking patch performance-test/perf-test-lib.sh...
Applied patch performance-test/perf-test-lib.sh cleanly.
Checking patch performance-test/perf-test-lib.sh...
Applied patch performance-test/perf-test-lib.sh cleanly.
Checking patch performance-test/perf-test-lib.sh...
Applied patch performance-test/perf-test-lib.sh cleanly.

index at:
100644 c9b131a5cddcbebe8e0902178dda18cd80479e31	performance-test/perf-test-lib.sh

(*) Git path names are given by the tree(s) the blob belongs to.
    Blobs themselves have no identifier aside from the hash of its contents.^

Code repositories for project(s) associated with this public inbox

	https://yhetil.org/notmuch.git/

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).