mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-12-22 17:34:54 +01:00
dca72205ab
This brings back status information that may have been hidden by the great library logging conversion. Note the change of the internal API / return-value for count_files. The other count calls to the lib will also get error handling when that API is updated in the lib.
127 lines
3.8 KiB
Bash
Executable file
127 lines
3.8 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
test_description='"notmuch count" for messages and threads'
|
|
. ./test-lib.sh || exit 1
|
|
|
|
add_email_corpus
|
|
|
|
# Note: The 'wc -l' results below are wrapped in arithmetic evaluation
|
|
# $((...)) to strip whitespace. This is for portability, as 'wc -l'
|
|
# emits whitespace on some BSD variants.
|
|
|
|
test_begin_subtest "message count is the default for notmuch count"
|
|
test_expect_equal \
|
|
"$((`notmuch search --output=messages '*' | wc -l`))" \
|
|
"`notmuch count '*'`"
|
|
|
|
test_begin_subtest "message count with --output=messages"
|
|
test_expect_equal \
|
|
"$((`notmuch search --output=messages '*' | wc -l`))" \
|
|
"`notmuch count --output=messages '*'`"
|
|
|
|
test_begin_subtest "thread count with --output=threads"
|
|
test_expect_equal \
|
|
"$((`notmuch search --output=threads '*' | wc -l`))" \
|
|
"`notmuch count --output=threads '*'`"
|
|
|
|
test_begin_subtest "thread count is the default for notmuch search"
|
|
test_expect_equal \
|
|
"$((`notmuch search '*' | wc -l`))" \
|
|
"`notmuch count --output=threads '*'`"
|
|
|
|
test_begin_subtest "files count"
|
|
test_expect_equal \
|
|
"$((`notmuch search --output=files '*' | wc -l`))" \
|
|
"`notmuch count --output=files '*'`"
|
|
|
|
test_begin_subtest "files count for a duplicate message-id"
|
|
test_expect_equal \
|
|
"2" \
|
|
"`notmuch count --output=files id:20091117232137.GA7669@griffis1.net`"
|
|
|
|
test_begin_subtest "count with no matching messages"
|
|
test_expect_equal \
|
|
"0" \
|
|
"`notmuch count --output=messages from:cworth and not from:cworth`"
|
|
|
|
test_begin_subtest "count with no matching threads"
|
|
test_expect_equal \
|
|
"0" \
|
|
"`notmuch count --output=threads from:cworth and not from:cworth`"
|
|
|
|
test_begin_subtest "message count is the default for batch count"
|
|
notmuch count --batch >OUTPUT <<EOF
|
|
|
|
from:cworth
|
|
EOF
|
|
notmuch count --output=messages >EXPECTED
|
|
notmuch count --output=messages from:cworth >>EXPECTED
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
test_begin_subtest "batch message count"
|
|
notmuch count --batch --output=messages >OUTPUT <<EOF
|
|
from:cworth
|
|
|
|
tag:inbox
|
|
EOF
|
|
notmuch count --output=messages from:cworth >EXPECTED
|
|
notmuch count --output=messages >>EXPECTED
|
|
notmuch count --output=messages tag:inbox >>EXPECTED
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
test_begin_subtest "batch thread count"
|
|
notmuch count --batch --output=threads >OUTPUT <<EOF
|
|
|
|
from:cworth
|
|
from:cworth and not from:cworth
|
|
foo
|
|
EOF
|
|
notmuch count --output=threads >EXPECTED
|
|
notmuch count --output=threads from:cworth >>EXPECTED
|
|
notmuch count --output=threads from:cworth and not from:cworth >>EXPECTED
|
|
notmuch count --output=threads foo >>EXPECTED
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
test_begin_subtest "batch message count with input file"
|
|
cat >INPUT <<EOF
|
|
from:cworth
|
|
|
|
tag:inbox
|
|
EOF
|
|
notmuch count --input=INPUT --output=messages >OUTPUT
|
|
notmuch count --output=messages from:cworth >EXPECTED
|
|
notmuch count --output=messages >>EXPECTED
|
|
notmuch count --output=messages tag:inbox >>EXPECTED
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
backup_database
|
|
test_begin_subtest "error message for database open"
|
|
dd if=/dev/zero of="${MAIL_DIR}/.notmuch/xapian/postlist.DB" count=3
|
|
notmuch count '*' 2>OUTPUT 1>/dev/null
|
|
output=$(sed 's/^\(A Xapian exception [^:]*\):.*$/\1/' OUTPUT)
|
|
test_expect_equal "${output}" "A Xapian exception occurred opening database"
|
|
restore_database
|
|
|
|
cat <<EOF > count-files.gdb
|
|
set breakpoint pending on
|
|
break count_files
|
|
commands
|
|
shell cp /dev/null ${MAIL_DIR}/.notmuch/xapian/postlist.DB
|
|
continue
|
|
end
|
|
run
|
|
EOF
|
|
|
|
backup_database
|
|
test_begin_subtest "error message from query_search_messages"
|
|
gdb --batch-silent --return-child-result -x count-files.gdb \
|
|
--args notmuch count --output=files '*' 2>OUTPUT 1>/dev/null
|
|
cat <<EOF > EXPECTED
|
|
notmuch count: A Xapian exception occurred
|
|
A Xapian exception occurred performing query
|
|
Query string was: *
|
|
EOF
|
|
sed 's/^\(A Xapian exception [^:]*\):.*$/\1/' < OUTPUT > OUTPUT.clean
|
|
test_expect_equal_file EXPECTED OUTPUT.clean
|
|
restore_database
|
|
|
|
test_done
|