2 test_description='"notmuch new" in several variations'
5 test_begin_subtest "No new messages"
7 test_expect_equal "$output" "No new mail."
10 test_begin_subtest "Single new message"
13 test_expect_equal "$output" "Added 1 new message to the database."
16 test_begin_subtest "Multiple new messages"
20 test_expect_equal "$output" "Added 2 new messages to the database."
23 test_begin_subtest "No new messages (non-empty DB)"
25 test_expect_equal "$output" "No new mail."
28 test_begin_subtest "New directories"
29 rm -rf "${MAIL_DIR}"/* "${MAIL_DIR}"/.notmuch
30 mkdir "${MAIL_DIR}"/def
31 mkdir "${MAIL_DIR}"/ghi
32 generate_message [dir]=def
35 test_expect_equal "$output" "Added 1 new message to the database."
38 test_begin_subtest "Alternate inode order"
40 rm -rf "${MAIL_DIR}"/.notmuch
41 mv "${MAIL_DIR}"/ghi "${MAIL_DIR}"/abc
42 rm "${MAIL_DIR}"/def/*
43 generate_message [dir]=abc
46 test_expect_equal "$output" "Added 1 new message to the database."
49 test_begin_subtest "Message moved in"
50 rm -rf "${MAIL_DIR}"/* "${MAIL_DIR}"/.notmuch
52 tmp_msg_filename=tmp/"$gen_msg_filename"
53 mkdir -p "$(dirname "$tmp_msg_filename")"
54 mv "$gen_msg_filename" "$tmp_msg_filename"
55 notmuch new > /dev/null
56 mv "$tmp_msg_filename" "$gen_msg_filename"
58 test_expect_equal "$output" "Added 1 new message to the database."
61 test_begin_subtest "Renamed message"
64 notmuch new > /dev/null
65 mv "$gen_msg_filename" "${gen_msg_filename}"-renamed
67 test_expect_equal "$output" "No new mail. Detected 1 file rename."
70 test_begin_subtest "Deleted message"
72 rm "${gen_msg_filename}"-renamed
74 test_expect_equal "$output" "No new mail. Removed 1 message."
77 test_begin_subtest "Renamed directory"
79 generate_message [dir]=dir
80 generate_message [dir]=dir
81 generate_message [dir]=dir
83 notmuch new > /dev/null
85 mv "${MAIL_DIR}"/dir "${MAIL_DIR}"/dir-renamed
88 test_expect_equal "$output" "No new mail. Detected 3 file renames."
91 test_begin_subtest "Deleted directory"
93 rm -rf "${MAIL_DIR}"/dir-renamed
96 test_expect_equal "$output" "No new mail. Removed 3 messages."
99 test_begin_subtest "New directory (at end of list)"
101 generate_message [dir]=zzz
102 generate_message [dir]=zzz
103 generate_message [dir]=zzz
105 output=$(NOTMUCH_NEW)
106 test_expect_equal "$output" "Added 3 new messages to the database."
109 test_begin_subtest "Deleted directory (end of list)"
111 rm -rf "${MAIL_DIR}"/zzz
113 output=$(NOTMUCH_NEW)
114 test_expect_equal "$output" "No new mail. Removed 3 messages."
117 test_begin_subtest "New symlink to directory"
119 rm -rf "${MAIL_DIR}"/.notmuch
120 mv "${MAIL_DIR}" "${TMP_DIRECTORY}"/actual_maildir
123 ln -s "${TMP_DIRECTORY}"/actual_maildir "${MAIL_DIR}"/symlink
125 output=$(NOTMUCH_NEW)
126 test_expect_equal "$output" "Added 1 new message to the database."
129 test_begin_subtest "New symlink to a file"
131 external_msg_filename="${TMP_DIRECTORY}"/external/"$(basename "$gen_msg_filename")"
132 mkdir -p "$(dirname "$external_msg_filename")"
133 mv "$gen_msg_filename" "$external_msg_filename"
134 ln -s "$external_msg_filename" "$gen_msg_filename"
135 output=$(NOTMUCH_NEW)
136 test_expect_equal "$output" "Added 1 new message to the database."
139 test_begin_subtest "Broken symlink aborts"
140 ln -s does-not-exist "${MAIL_DIR}/broken"
141 output=$(NOTMUCH_NEW 2>&1)
142 test_expect_equal "$output" \
143 "Error reading file ${MAIL_DIR}/broken: No such file or directory
144 Note: A fatal error was encountered: Something went wrong trying to read or write a file
146 rm "${MAIL_DIR}/broken"
149 test_begin_subtest "New two-level directory"
151 generate_message [dir]=two/levels
152 generate_message [dir]=two/levels
153 generate_message [dir]=two/levels
155 output=$(NOTMUCH_NEW)
156 test_expect_equal "$output" "Added 3 new messages to the database."
159 test_begin_subtest "Deleted two-level directory"
161 rm -rf "${MAIL_DIR}"/two
163 output=$(NOTMUCH_NEW)
164 test_expect_equal "$output" "No new mail. Removed 3 messages."
166 test_begin_subtest "Support single-message mbox (deprecated)"
167 cat > "${MAIL_DIR}"/mbox_file1 <<EOF
168 From test_suite@notmuchmail.org Fri Jan 5 15:43:57 2001
169 From: Notmuch Test Suite <test_suite@notmuchmail.org>
170 To: Notmuch Test Suite <test_suite@notmuchmail.org>
171 Subject: Test mbox message 1
175 output=$(NOTMUCH_NEW 2>&1)
176 test_expect_equal "$output" "Added 1 new message to the database."
178 # This test requires that notmuch new has been run at least once.
179 test_begin_subtest "Skip and report non-mail files"
181 mkdir -p "${MAIL_DIR}"/.git && touch "${MAIL_DIR}"/.git/config
182 touch "${MAIL_DIR}"/ignored_file
183 touch "${MAIL_DIR}"/.ignored_hidden_file
184 cat > "${MAIL_DIR}"/mbox_file <<EOF
185 From test_suite@notmuchmail.org Fri Jan 5 15:43:57 2001
186 From: Notmuch Test Suite <test_suite@notmuchmail.org>
187 To: Notmuch Test Suite <test_suite@notmuchmail.org>
188 Subject: Test mbox message 1
192 From test_suite@notmuchmail.org Fri Jan 5 15:43:57 2001
193 From: Notmuch Test Suite <test_suite@notmuchmail.org>
194 To: Notmuch Test Suite <test_suite@notmuchmail.org>
195 Subject: Test mbox message 2
199 output=$(NOTMUCH_NEW 2>&1)
200 test_expect_equal "$output" \
201 "Note: Ignoring non-mail file: ${MAIL_DIR}/.git/config
202 Note: Ignoring non-mail file: ${MAIL_DIR}/.ignored_hidden_file
203 Note: Ignoring non-mail file: ${MAIL_DIR}/ignored_file
204 Note: Ignoring non-mail file: ${MAIL_DIR}/mbox_file
205 Added 1 new message to the database."
206 rm "${MAIL_DIR}"/mbox_file
208 test_begin_subtest "Ignore files and directories specified in new.ignore"
210 notmuch config set new.ignore .git ignored_file .ignored_hidden_file
211 touch "${MAIL_DIR}"/.git # change .git's mtime for notmuch new to rescan.
212 output=$(NOTMUCH_NEW 2>&1)
213 test_expect_equal "$output" "Added 1 new message to the database."
215 test_begin_subtest "Ignore files and directories specified in new.ignore (multiple occurrences)"
216 notmuch config set new.ignore .git ignored_file .ignored_hidden_file
217 notmuch new > /dev/null # ensure that files/folders will be printed in ASCII order.
218 touch "${MAIL_DIR}"/.git # change .git's mtime for notmuch new to rescan.
219 touch "${MAIL_DIR}" # likewise for MAIL_DIR
220 mkdir -p "${MAIL_DIR}"/one/two/three/.git
221 touch "${MAIL_DIR}"/{one,one/two,one/two/three}/ignored_file
222 output=$(NOTMUCH_NEW --debug 2>&1 | sort)
223 test_expect_equal "$output" \
224 "(D) add_files_recursive, pass 1: explicitly ignoring ${MAIL_DIR}/.git
225 (D) add_files_recursive, pass 1: explicitly ignoring ${MAIL_DIR}/.ignored_hidden_file
226 (D) add_files_recursive, pass 1: explicitly ignoring ${MAIL_DIR}/ignored_file
227 (D) add_files_recursive, pass 1: explicitly ignoring ${MAIL_DIR}/one/ignored_file
228 (D) add_files_recursive, pass 1: explicitly ignoring ${MAIL_DIR}/one/two/ignored_file
229 (D) add_files_recursive, pass 1: explicitly ignoring ${MAIL_DIR}/one/two/three/.git
230 (D) add_files_recursive, pass 1: explicitly ignoring ${MAIL_DIR}/one/two/three/ignored_file
231 (D) add_files_recursive, pass 2: explicitly ignoring ${MAIL_DIR}/.git
232 (D) add_files_recursive, pass 2: explicitly ignoring ${MAIL_DIR}/.ignored_hidden_file
233 (D) add_files_recursive, pass 2: explicitly ignoring ${MAIL_DIR}/ignored_file
234 (D) add_files_recursive, pass 2: explicitly ignoring ${MAIL_DIR}/one/ignored_file
235 (D) add_files_recursive, pass 2: explicitly ignoring ${MAIL_DIR}/one/two/ignored_file
236 (D) add_files_recursive, pass 2: explicitly ignoring ${MAIL_DIR}/one/two/three/.git
237 (D) add_files_recursive, pass 2: explicitly ignoring ${MAIL_DIR}/one/two/three/ignored_file
241 test_begin_subtest "Don't stop for ignored broken symlinks"
242 notmuch config set new.ignore .git ignored_file .ignored_hidden_file broken_link
243 ln -s i_do_not_exist "${MAIL_DIR}"/broken_link
244 output=$(NOTMUCH_NEW 2>&1)
245 test_expect_equal "$output" "No new mail."
247 test_begin_subtest "Quiet: No new mail."
248 output=$(NOTMUCH_NEW --quiet)
249 test_expect_equal "$output" ""
251 test_begin_subtest "Quiet: new, removed and renamed messages."
255 notmuch search --format=text0 --output=files --limit=1 '*' | xargs -0 rm
257 mkdir "${MAIL_DIR}"/moved_messages
258 notmuch search --format=text0 --output=files --offset=1 --limit=1 '*' | xargs -0 -I {} mv {} "${MAIL_DIR}"/moved_messages
259 output=$(NOTMUCH_NEW --quiet)
260 test_expect_equal "$output" ""
262 OLDCONFIG=$(notmuch config get new.tags)
264 test_begin_subtest "Empty tags in new.tags are forbidden"
265 notmuch config set new.tags "foo;;bar"
266 output=$(NOTMUCH_NEW 2>&1)
267 test_expect_equal "$output" "Error: tag '' in new.tags: empty tag forbidden"
269 test_begin_subtest "Tags starting with '-' in new.tags are forbidden"
270 notmuch config set new.tags "-foo;bar"
271 output=$(NOTMUCH_NEW 2>&1)
272 test_expect_equal "$output" "Error: tag '-foo' in new.tags: tag starting with '-' forbidden"
274 test_expect_code 1 "Invalid tags set exit code" \
277 notmuch config set new.tags $OLDCONFIG
280 test_begin_subtest "Xapian exception: read only files"
281 chmod u-w ${MAIL_DIR}/.notmuch/xapian/*.DB
282 output=$(NOTMUCH_NEW 2>&1 | sed 's/: .*$//' )
283 chmod u+w ${MAIL_DIR}/.notmuch/xapian/*.DB
284 test_expect_equal "$output" "A Xapian exception occurred opening database"