unofficial mirror of notmuch@notmuchmail.org
 help / color / mirror / code / Atom feed
blob fb15028fbd6712285956aa2898f8e98234effc57 1251 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
 
. ./version.sh

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

    case "$1" 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"
    tar --checkpoint=.5000 --extract --strip-components=1 \
	--directory ${TMP_DIRECTORY} \
	--use-compress-program ${XZ} \
	--file ../download/notmuch-email-corpus-${PERFTEST_VERSION}.tar.xz \
	notmuch-email-corpus/"$arg"

    printf "\n"
}

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))
	return 1
    fi
    return 0
}

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 fb15028 ...
found fb15028 in https://yhetil.org/notmuch.git/

(*) 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).