unofficial mirror of notmuch@notmuchmail.org
 help / color / mirror / code / Atom feed
blob e3a6cef17dbe647d81ebf46cc7fce3a2931f5f7e 3084 bytes (raw)
name: test/basic 	 # 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
 
#!/usr/bin/env bash
#
# Copyright (c) 2005 Junio C Hamano
#

test_description='the test framework itself.'

################################################################
# It appears that people try to run tests without building...

if ! test -x ../notmuch
then
	echo >&2 'You do not seem to have built notmuch yet.'
	exit 1
fi

. ./test-lib.sh

################################################################
# Test harness
test_expect_success 'success is reported like this' '
    :
'
test_set_prereq HAVEIT
haveit=no
test_expect_success HAVEIT 'test runs if prerequisite is satisfied' '
    test_have_prereq HAVEIT &&
    haveit=yes
'

clean=no
test_expect_success 'tests clean up after themselves' '
    test_when_finished clean=yes
'

cleaner=no
test_expect_code 1 'tests clean up even after a failure' '
    test_when_finished cleaner=yes &&
    (exit 1)
'

if test $clean$cleaner != yesyes
then
	say "bug in test framework: cleanup commands do not work reliably"
	exit 1
fi

test_expect_code 2 'failure to clean up causes the test to fail' '
    test_when_finished "(exit 2)"
'

# Ensure that all tests are being run
test_begin_subtest 'Ensure that all available tests will be run by notmuch-test'
eval $(sed -n -e '/^TESTS="$/,/^"$/p' $TEST_DIRECTORY/notmuch-test)
tests_in_suite=$(for i in $TESTS; do echo $i; done | sort)
available=$(find "$TEST_DIRECTORY" -maxdepth 1 -type f -executable -printf '%f\n' | \
    sed -r -e "/^(aggregate-results.sh|notmuch-test|smtp-dummy|test-verbose|symbol-test|arg-test|hex-xcode|random-dump)$/d" | \
    sort)
test_expect_equal "$tests_in_suite" "$available"

EXPECTED=$TEST_DIRECTORY/test.expected-output
suppress_diff_date() {
    sed -e 's/\(.*\-\-\- test-verbose\.4\.\expected\).*/\1/' \
	-e 's/\(.*\+\+\+ test-verbose\.4\.\output\).*/\1/'
}

test_begin_subtest "Ensure that test output is suppressed unless the test fails"
output=$(cd $TEST_DIRECTORY; ./test-verbose 2>&1 | suppress_diff_date)
expected=$(cat $EXPECTED/test-verbose-no | suppress_diff_date)
test_expect_equal "$output" "$expected"

test_begin_subtest "Ensure that -v does not suppress test output"
output=$(cd $TEST_DIRECTORY; ./test-verbose -v 2>&1 | suppress_diff_date)
expected=$(cat $EXPECTED/test-verbose-yes | suppress_diff_date)
# Do not include the results of test-verbose in totals
rm $TEST_DIRECTORY/test-results/test-verbose-*
rm -r $TEST_DIRECTORY/tmp.test-verbose
test_expect_equal "$output" "$expected"


################################################################
# Test mail store prepared in test-lib.sh

test_expect_success \
    'test that mail store was created' \
    'test -d "${MAIL_DIR}"'


find "${MAIL_DIR}" -type f -print >should-be-empty
test_expect_success \
    'mail store should be empty' \
    'cmp -s /dev/null should-be-empty'

test_expect_success \
    'NOTMUCH_CONFIG is set and points to an existing file' \
    'test -f "${NOTMUCH_CONFIG}"'

test_expect_success \
    'PATH is set to this repository' \
    'test "`echo $PATH|cut -f1 -d: | sed -e 's,/test/valgrind/bin$,,'`" = "`dirname ${TEST_DIRECTORY}`"'

test_done

debug log:

solving e3a6cef ...
found e3a6cef in https://yhetil.org/notmuch/1326591624-15493-10-git-send-email-david@tethera.net/
found af57026 in https://yhetil.org/notmuch/1324214111-32079-3-git-send-email-david@tethera.net/ ||
	https://yhetil.org/notmuch/1323808075-7417-3-git-send-email-david@tethera.net/ ||
	https://yhetil.org/notmuch/a984626045b59100ec7f2d9f9b14a9a48252d8d0.1333231401.git.jani@nikula.org/ ||
	https://yhetil.org/notmuch/e40d095e6a5208d8e720d1f681bd172e28f3f112.1334404979.git.jani@nikula.org/ ||
	https://yhetil.org/notmuch/1326591624-15493-3-git-send-email-david@tethera.net/ ||
	https://yhetil.org/notmuch/1345382314-5330-3-git-send-email-david@tethera.net/
found d6aed24 in https://yhetil.org/notmuch.git/
preparing index
index prepared:
100755 d6aed24c0e292135b35b8b938a374311838c257f	test/basic

applying [1/2] https://yhetil.org/notmuch/1324214111-32079-3-git-send-email-david@tethera.net/
diff --git a/test/basic b/test/basic
index d6aed24..af57026 100755

Checking patch test/basic...
Applied patch test/basic cleanly.

skipping https://yhetil.org/notmuch/1323808075-7417-3-git-send-email-david@tethera.net/ for af57026
skipping https://yhetil.org/notmuch/a984626045b59100ec7f2d9f9b14a9a48252d8d0.1333231401.git.jani@nikula.org/ for af57026
skipping https://yhetil.org/notmuch/e40d095e6a5208d8e720d1f681bd172e28f3f112.1334404979.git.jani@nikula.org/ for af57026
skipping https://yhetil.org/notmuch/1326591624-15493-3-git-send-email-david@tethera.net/ for af57026
skipping https://yhetil.org/notmuch/1345382314-5330-3-git-send-email-david@tethera.net/ for af57026
index at:
100755 af570263ec7b5de757feca3ac77d479059385d83	test/basic

applying [2/2] https://yhetil.org/notmuch/1326591624-15493-10-git-send-email-david@tethera.net/
diff --git a/test/basic b/test/basic
index af57026..e3a6cef 100755

Checking patch test/basic...
Applied patch test/basic cleanly.

index at:
100755 e3a6cef17dbe647d81ebf46cc7fce3a2931f5f7e	test/basic

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