#!/usr/bin/env bash test_description='"notmuch count" for messages and threads' . $(dirname "$0")/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 <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 <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 <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 <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" target=(${MAIL_DIR}/.notmuch/xapian/postlist.*) dd if=/dev/zero of="$target" 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 < count-files.gdb set breakpoint pending on set logging file count-files-gdb.log set logging on break count_files commands shell cp /dev/null ${MAIL_DIR}/.notmuch/xapian/postlist.* continue end run EOF backup_database test_begin_subtest "error message from query_search_messages" ${TEST_GDB} --batch-silent --return-child-result -x count-files.gdb \ --args notmuch count --output=files '*' 2>OUTPUT 1>/dev/null cat < 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_begin_subtest "count library function is non-destructive" cat< EXPECTED 1: 52 messages 2: 52 messages Exclude 'spam' 3: 52 messages 4: 52 messages EOF test_python <