4751440e94a1acf7ef552fd0503be3d4264dbaf7
[notmuch] / test / T060-count.sh
1 #!/usr/bin/env bash
2 test_description='"notmuch count" for messages and threads'
3 . ./test-lib.sh || exit 1
4
5 add_email_corpus
6
7 # Note: The 'wc -l' results below are wrapped in arithmetic evaluation
8 # $((...)) to strip whitespace. This is for portability, as 'wc -l'
9 # emits whitespace on some BSD variants.
10
11 test_begin_subtest "message count is the default for notmuch count"
12 test_expect_equal \
13     "$((`notmuch search --output=messages '*' | wc -l`))" \
14     "`notmuch count '*'`"
15
16 test_begin_subtest "message count with --output=messages"
17 test_expect_equal \
18     "$((`notmuch search --output=messages '*' | wc -l`))" \
19     "`notmuch count --output=messages '*'`"
20
21 test_begin_subtest "thread count with --output=threads"
22 test_expect_equal \
23     "$((`notmuch search --output=threads '*' | wc -l`))" \
24     "`notmuch count --output=threads '*'`"
25
26 test_begin_subtest "thread count is the default for notmuch search"
27 test_expect_equal \
28     "$((`notmuch search '*' | wc -l`))" \
29     "`notmuch count --output=threads '*'`"
30
31 test_begin_subtest "files count"
32 test_expect_equal \
33     "$((`notmuch search --output=files '*' | wc -l`))" \
34     "`notmuch count --output=files '*'`"
35
36 test_begin_subtest "files count for a duplicate message-id"
37 test_expect_equal \
38     "2" \
39     "`notmuch count --output=files id:20091117232137.GA7669@griffis1.net`"
40
41 test_begin_subtest "count with no matching messages"
42 test_expect_equal \
43     "0" \
44     "`notmuch count --output=messages from:cworth and not from:cworth`"
45
46 test_begin_subtest "count with no matching threads"
47 test_expect_equal \
48     "0" \
49     "`notmuch count --output=threads from:cworth and not from:cworth`"
50
51 test_begin_subtest "message count is the default for batch count"
52 notmuch count --batch >OUTPUT <<EOF
53
54 from:cworth
55 EOF
56 notmuch count --output=messages >EXPECTED
57 notmuch count --output=messages from:cworth >>EXPECTED
58 test_expect_equal_file EXPECTED OUTPUT
59
60 test_begin_subtest "batch message count"
61 notmuch count --batch --output=messages >OUTPUT <<EOF
62 from:cworth
63
64 tag:inbox
65 EOF
66 notmuch count --output=messages from:cworth >EXPECTED
67 notmuch count --output=messages >>EXPECTED
68 notmuch count --output=messages tag:inbox >>EXPECTED
69 test_expect_equal_file EXPECTED OUTPUT
70
71 test_begin_subtest "batch thread count"
72 notmuch count --batch --output=threads >OUTPUT <<EOF
73
74 from:cworth
75 from:cworth and not from:cworth
76 foo
77 EOF
78 notmuch count --output=threads >EXPECTED
79 notmuch count --output=threads from:cworth >>EXPECTED
80 notmuch count --output=threads from:cworth and not from:cworth >>EXPECTED
81 notmuch count --output=threads foo >>EXPECTED
82 test_expect_equal_file EXPECTED OUTPUT
83
84 test_begin_subtest "batch message count with input file"
85 cat >INPUT <<EOF
86 from:cworth
87
88 tag:inbox
89 EOF
90 notmuch count --input=INPUT --output=messages >OUTPUT
91 notmuch count --output=messages from:cworth >EXPECTED
92 notmuch count --output=messages >>EXPECTED
93 notmuch count --output=messages tag:inbox >>EXPECTED
94 test_expect_equal_file EXPECTED OUTPUT
95
96 backup_database
97 test_begin_subtest "error message for database open"
98 dd if=/dev/zero of="${MAIL_DIR}/.notmuch/xapian/postlist.${db_ending}" count=3
99 notmuch count '*' 2>OUTPUT 1>/dev/null
100 output=$(sed 's/^\(A Xapian exception [^:]*\):.*$/\1/' OUTPUT)
101 test_expect_equal "${output}" "A Xapian exception occurred opening database"
102 restore_database
103
104 cat <<EOF > count-files.gdb
105 set breakpoint pending on
106 set logging file count-files-gdb.log
107 set logging on
108 break count_files
109 commands
110 shell cp /dev/null ${MAIL_DIR}/.notmuch/xapian/postlist.${db_ending}
111 continue
112 end
113 run
114 EOF
115
116 backup_database
117 test_begin_subtest "error message from query_search_messages"
118 ${TEST_GDB} --batch-silent --return-child-result -x count-files.gdb \
119     --args notmuch count --output=files '*' 2>OUTPUT 1>/dev/null
120 cat <<EOF > EXPECTED
121 notmuch count: A Xapian exception occurred
122 A Xapian exception occurred performing query
123 Query string was: *
124 EOF
125 sed 's/^\(A Xapian exception [^:]*\):.*$/\1/' < OUTPUT > OUTPUT.clean
126 test_expect_equal_file EXPECTED OUTPUT.clean
127 restore_database
128
129 test_begin_subtest "count library function is non-destructive"
130 cat<<EOF > EXPECTED
131 1: 52 messages
132 2: 52 messages
133 Exclude 'spam'
134 3: 52 messages
135 4: 52 messages
136 EOF
137 test_python <<EOF
138 import sys
139 import notmuch
140
141 query_string = 'tag:inbox or tag:spam'
142 tag_string = 'spam'
143
144 database = notmuch.Database(mode=notmuch.Database.MODE.READ_ONLY)
145 query = notmuch.Query(database, query_string)
146
147 print("1: {} messages".format(query.count_messages()))
148 print("2: {} messages".format(query.count_messages()))
149 print("Exclude '{}'".format(tag_string))
150 query.exclude_tag(tag_string)
151 print("3: {} messages".format(query.count_messages()))
152 print("4: {} messages".format(query.count_messages()))
153 EOF
154 test_expect_equal_file EXPECTED OUTPUT
155
156 test_done