2010-12-01 21:27:52 +01:00
|
|
|
#!/usr/bin/env bash
|
2010-09-17 15:25:39 -07:00
|
|
|
test_description='"notmuch new" in several variations'
|
2017-09-25 23:38:19 +03:00
|
|
|
. $(dirname "$0")/test-lib.sh || exit 1
|
2010-06-10 08:48:03 +02:00
|
|
|
|
2010-09-17 15:25:39 -07:00
|
|
|
test_begin_subtest "No new messages"
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2010-09-17 15:25:39 -07:00
|
|
|
test_expect_equal "$output" "No new mail."
|
2010-06-10 08:48:03 +02:00
|
|
|
|
|
|
|
|
2010-09-17 15:25:39 -07:00
|
|
|
test_begin_subtest "Single new message"
|
|
|
|
generate_message
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2010-09-17 15:25:39 -07:00
|
|
|
test_expect_equal "$output" "Added 1 new message to the database."
|
2010-06-10 08:48:03 +02:00
|
|
|
|
2018-04-29 20:19:41 -03:00
|
|
|
test_begin_subtest "Single message (full-scan)"
|
|
|
|
generate_message
|
|
|
|
output=$(NOTMUCH_NEW --debug --full-scan 2>&1)
|
|
|
|
test_expect_equal "$output" "Added 1 new message to the database."
|
2010-06-10 08:48:03 +02:00
|
|
|
|
2010-09-17 15:25:39 -07:00
|
|
|
test_begin_subtest "Multiple new messages"
|
|
|
|
generate_message
|
|
|
|
generate_message
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2010-09-17 15:25:39 -07:00
|
|
|
test_expect_equal "$output" "Added 2 new messages to the database."
|
2010-06-10 08:48:03 +02:00
|
|
|
|
2018-04-29 20:19:41 -03:00
|
|
|
test_begin_subtest "Multiple new messages (full-scan)"
|
|
|
|
generate_message
|
|
|
|
generate_message
|
|
|
|
output=$(NOTMUCH_NEW --debug --full-scan 2>&1)
|
|
|
|
test_expect_equal "$output" "Added 2 new messages to the database."
|
2010-06-10 08:48:03 +02:00
|
|
|
|
2010-09-17 15:25:39 -07:00
|
|
|
test_begin_subtest "No new messages (non-empty DB)"
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2010-09-17 15:25:39 -07:00
|
|
|
test_expect_equal "$output" "No new mail."
|
2010-06-10 08:48:03 +02:00
|
|
|
|
2018-04-29 20:19:41 -03:00
|
|
|
test_begin_subtest "No new messages (full-scan)"
|
|
|
|
output=$(NOTMUCH_NEW --debug --full-scan 2>&1)
|
|
|
|
test_expect_equal "$output" "No new mail."
|
2010-06-10 08:48:03 +02:00
|
|
|
|
2010-09-17 15:25:39 -07:00
|
|
|
test_begin_subtest "New directories"
|
|
|
|
rm -rf "${MAIL_DIR}"/* "${MAIL_DIR}"/.notmuch
|
|
|
|
mkdir "${MAIL_DIR}"/def
|
|
|
|
mkdir "${MAIL_DIR}"/ghi
|
|
|
|
generate_message [dir]=def
|
2010-06-10 08:48:03 +02:00
|
|
|
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2010-09-17 15:25:39 -07:00
|
|
|
test_expect_equal "$output" "Added 1 new message to the database."
|
2010-06-10 08:48:03 +02:00
|
|
|
|
|
|
|
|
2010-09-17 15:25:39 -07:00
|
|
|
test_begin_subtest "Alternate inode order"
|
|
|
|
|
|
|
|
rm -rf "${MAIL_DIR}"/.notmuch
|
|
|
|
mv "${MAIL_DIR}"/ghi "${MAIL_DIR}"/abc
|
|
|
|
rm "${MAIL_DIR}"/def/*
|
|
|
|
generate_message [dir]=abc
|
|
|
|
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2010-09-17 15:25:39 -07:00
|
|
|
test_expect_equal "$output" "Added 1 new message to the database."
|
|
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "Message moved in"
|
|
|
|
rm -rf "${MAIL_DIR}"/* "${MAIL_DIR}"/.notmuch
|
|
|
|
generate_message
|
|
|
|
tmp_msg_filename=tmp/"$gen_msg_filename"
|
|
|
|
mkdir -p "$(dirname "$tmp_msg_filename")"
|
|
|
|
mv "$gen_msg_filename" "$tmp_msg_filename"
|
2010-09-20 16:13:15 -07:00
|
|
|
notmuch new > /dev/null
|
2010-09-17 15:25:39 -07:00
|
|
|
mv "$tmp_msg_filename" "$gen_msg_filename"
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2010-09-17 15:25:39 -07:00
|
|
|
test_expect_equal "$output" "Added 1 new message to the database."
|
|
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "Renamed message"
|
|
|
|
|
|
|
|
generate_message
|
2010-09-20 16:13:15 -07:00
|
|
|
notmuch new > /dev/null
|
2010-09-17 15:25:39 -07:00
|
|
|
mv "$gen_msg_filename" "${gen_msg_filename}"-renamed
|
2015-08-04 08:48:32 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2015-11-03 21:49:29 +02:00
|
|
|
test_expect_equal "$output" "(D) add_files, pass 2: queuing passed file ${gen_msg_filename} for deletion from database
|
2015-08-04 08:48:32 +02:00
|
|
|
No new mail. Detected 1 file rename."
|
2010-09-17 15:25:39 -07:00
|
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "Deleted message"
|
|
|
|
|
|
|
|
rm "${gen_msg_filename}"-renamed
|
2015-08-04 08:48:32 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2015-11-03 21:49:29 +02:00
|
|
|
test_expect_equal "$output" "(D) add_files, pass 3: queuing leftover file ${gen_msg_filename}-renamed for deletion from database
|
2015-08-04 08:48:32 +02:00
|
|
|
No new mail. Removed 1 message."
|
|
|
|
|
2010-09-17 15:25:39 -07:00
|
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "Renamed directory"
|
|
|
|
|
|
|
|
generate_message [dir]=dir
|
|
|
|
generate_message [dir]=dir
|
|
|
|
generate_message [dir]=dir
|
|
|
|
|
2010-09-20 16:13:15 -07:00
|
|
|
notmuch new > /dev/null
|
2010-09-17 15:25:39 -07:00
|
|
|
|
|
|
|
mv "${MAIL_DIR}"/dir "${MAIL_DIR}"/dir-renamed
|
|
|
|
|
2018-04-29 20:19:42 -03:00
|
|
|
output=$(NOTMUCH_NEW --debug --full-scan)
|
2015-11-03 21:49:29 +02:00
|
|
|
test_expect_equal "$output" "(D) add_files, pass 2: queuing passed directory ${MAIL_DIR}/dir for deletion from database
|
2015-08-04 08:48:34 +02:00
|
|
|
No new mail. Detected 3 file renames."
|
2010-09-17 15:25:39 -07:00
|
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "Deleted directory"
|
|
|
|
rm -rf "${MAIL_DIR}"/dir-renamed
|
|
|
|
|
2018-04-29 20:19:42 -03:00
|
|
|
output=$(NOTMUCH_NEW --debug --full-scan)
|
2015-11-03 21:49:29 +02:00
|
|
|
test_expect_equal "$output" "(D) add_files, pass 2: queuing passed directory ${MAIL_DIR}/dir-renamed for deletion from database
|
2015-08-04 08:48:34 +02:00
|
|
|
No new mail. Removed 3 messages."
|
2010-09-17 15:25:39 -07:00
|
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "New directory (at end of list)"
|
|
|
|
|
|
|
|
generate_message [dir]=zzz
|
|
|
|
generate_message [dir]=zzz
|
|
|
|
generate_message [dir]=zzz
|
|
|
|
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2010-09-17 15:25:39 -07:00
|
|
|
test_expect_equal "$output" "Added 3 new messages to the database."
|
|
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "Deleted directory (end of list)"
|
|
|
|
|
|
|
|
rm -rf "${MAIL_DIR}"/zzz
|
|
|
|
|
2018-04-29 20:19:42 -03:00
|
|
|
output=$(NOTMUCH_NEW --debug --full-scan)
|
2015-11-03 21:49:29 +02:00
|
|
|
test_expect_equal "$output" "(D) add_files, pass 3: queuing leftover directory ${MAIL_DIR}/zzz for deletion from database
|
2015-08-04 08:48:34 +02:00
|
|
|
No new mail. Removed 3 messages."
|
2010-09-17 15:25:39 -07:00
|
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "New symlink to directory"
|
|
|
|
|
|
|
|
rm -rf "${MAIL_DIR}"/.notmuch
|
2012-02-01 21:37:21 +01:00
|
|
|
mv "${MAIL_DIR}" "${TMP_DIRECTORY}"/actual_maildir
|
2010-09-17 15:25:39 -07:00
|
|
|
|
|
|
|
mkdir "${MAIL_DIR}"
|
2012-02-01 21:37:21 +01:00
|
|
|
ln -s "${TMP_DIRECTORY}"/actual_maildir "${MAIL_DIR}"/symlink
|
2010-09-17 15:25:39 -07:00
|
|
|
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2010-09-17 15:25:39 -07:00
|
|
|
test_expect_equal "$output" "Added 1 new message to the database."
|
|
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "New symlink to a file"
|
|
|
|
generate_message
|
2012-02-01 21:37:21 +01:00
|
|
|
external_msg_filename="${TMP_DIRECTORY}"/external/"$(basename "$gen_msg_filename")"
|
2010-09-17 15:25:39 -07:00
|
|
|
mkdir -p "$(dirname "$external_msg_filename")"
|
|
|
|
mv "$gen_msg_filename" "$external_msg_filename"
|
|
|
|
ln -s "$external_msg_filename" "$gen_msg_filename"
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2010-09-17 15:25:39 -07:00
|
|
|
test_expect_equal "$output" "Added 1 new message to the database."
|
|
|
|
|
|
|
|
|
2012-05-24 18:01:10 -04:00
|
|
|
test_begin_subtest "Broken symlink aborts"
|
|
|
|
ln -s does-not-exist "${MAIL_DIR}/broken"
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug 2>&1)
|
2012-05-24 18:01:10 -04:00
|
|
|
test_expect_equal "$output" \
|
2012-05-24 18:01:11 -04:00
|
|
|
"Error reading file ${MAIL_DIR}/broken: No such file or directory
|
2012-05-24 18:01:10 -04:00
|
|
|
Note: A fatal error was encountered: Something went wrong trying to read or write a file
|
|
|
|
No new mail."
|
|
|
|
rm "${MAIL_DIR}/broken"
|
|
|
|
|
|
|
|
|
2010-09-17 15:25:39 -07:00
|
|
|
test_begin_subtest "New two-level directory"
|
|
|
|
|
|
|
|
generate_message [dir]=two/levels
|
|
|
|
generate_message [dir]=two/levels
|
|
|
|
generate_message [dir]=two/levels
|
|
|
|
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug)
|
2010-09-17 15:25:39 -07:00
|
|
|
test_expect_equal "$output" "Added 3 new messages to the database."
|
|
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "Deleted two-level directory"
|
|
|
|
|
|
|
|
rm -rf "${MAIL_DIR}"/two
|
|
|
|
|
2018-04-29 20:19:42 -03:00
|
|
|
output=$(NOTMUCH_NEW --debug --full-scan)
|
2015-11-03 21:49:29 +02:00
|
|
|
test_expect_equal "$output" "(D) add_files, pass 3: queuing leftover directory ${MAIL_DIR}/two for deletion from database
|
2015-08-04 08:48:34 +02:00
|
|
|
No new mail. Removed 3 messages."
|
2010-09-17 15:25:39 -07:00
|
|
|
|
2016-04-10 22:43:21 +03:00
|
|
|
test_begin_subtest "One character directory at top level"
|
|
|
|
|
|
|
|
generate_message [dir]=A
|
|
|
|
generate_message [dir]=A/B
|
|
|
|
generate_message [dir]=A/B/C
|
|
|
|
|
|
|
|
output=$(NOTMUCH_NEW --debug)
|
|
|
|
test_expect_equal "$output" "Added 3 new messages to the database."
|
|
|
|
|
2015-08-04 08:48:32 +02:00
|
|
|
test_begin_subtest "Support single-message mbox"
|
2014-06-05 08:34:09 +02:00
|
|
|
cat > "${MAIL_DIR}"/mbox_file1 <<EOF
|
|
|
|
From test_suite@notmuchmail.org Fri Jan 5 15:43:57 2001
|
|
|
|
From: Notmuch Test Suite <test_suite@notmuchmail.org>
|
|
|
|
To: Notmuch Test Suite <test_suite@notmuchmail.org>
|
|
|
|
Subject: Test mbox message 1
|
|
|
|
|
|
|
|
Body.
|
|
|
|
EOF
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug 2>&1)
|
2014-11-23 13:15:12 +02:00
|
|
|
test_expect_equal "$output" "Added 1 new message to the database."
|
2014-06-05 08:34:09 +02:00
|
|
|
|
2012-02-15 11:17:30 +02:00
|
|
|
# This test requires that notmuch new has been run at least once.
|
|
|
|
test_begin_subtest "Skip and report non-mail files"
|
|
|
|
generate_message
|
|
|
|
mkdir -p "${MAIL_DIR}"/.git && touch "${MAIL_DIR}"/.git/config
|
|
|
|
touch "${MAIL_DIR}"/ignored_file
|
|
|
|
touch "${MAIL_DIR}"/.ignored_hidden_file
|
2012-11-25 01:16:00 -05:00
|
|
|
cat > "${MAIL_DIR}"/mbox_file <<EOF
|
|
|
|
From test_suite@notmuchmail.org Fri Jan 5 15:43:57 2001
|
|
|
|
From: Notmuch Test Suite <test_suite@notmuchmail.org>
|
|
|
|
To: Notmuch Test Suite <test_suite@notmuchmail.org>
|
|
|
|
Subject: Test mbox message 1
|
|
|
|
|
|
|
|
Body.
|
|
|
|
|
|
|
|
From test_suite@notmuchmail.org Fri Jan 5 15:43:57 2001
|
|
|
|
From: Notmuch Test Suite <test_suite@notmuchmail.org>
|
|
|
|
To: Notmuch Test Suite <test_suite@notmuchmail.org>
|
|
|
|
Subject: Test mbox message 2
|
|
|
|
|
|
|
|
Body 2.
|
|
|
|
EOF
|
2018-04-29 20:19:42 -03:00
|
|
|
output=$(NOTMUCH_NEW --debug --full-scan 2>&1)
|
2012-02-15 11:17:30 +02:00
|
|
|
test_expect_equal "$output" \
|
|
|
|
"Note: Ignoring non-mail file: ${MAIL_DIR}/.git/config
|
|
|
|
Note: Ignoring non-mail file: ${MAIL_DIR}/.ignored_hidden_file
|
|
|
|
Note: Ignoring non-mail file: ${MAIL_DIR}/ignored_file
|
2012-11-25 01:16:00 -05:00
|
|
|
Note: Ignoring non-mail file: ${MAIL_DIR}/mbox_file
|
2012-02-15 11:17:30 +02:00
|
|
|
Added 1 new message to the database."
|
2012-11-25 01:16:00 -05:00
|
|
|
rm "${MAIL_DIR}"/mbox_file
|
2012-02-15 11:17:30 +02:00
|
|
|
|
|
|
|
test_begin_subtest "Ignore files and directories specified in new.ignore"
|
|
|
|
generate_message
|
|
|
|
notmuch config set new.ignore .git ignored_file .ignored_hidden_file
|
|
|
|
touch "${MAIL_DIR}"/.git # change .git's mtime for notmuch new to rescan.
|
2018-04-29 20:19:41 -03:00
|
|
|
NOTMUCH_NEW --debug 2>&1 | sort > OUTPUT
|
|
|
|
cat <<EOF > EXPECTED
|
2018-05-26 16:46:44 -07:00
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/.git
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/.ignored_hidden_file
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/ignored_file
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/.git
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/.ignored_hidden_file
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/ignored_file
|
2018-04-29 20:19:41 -03:00
|
|
|
Added 1 new message to the database.
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
|
|
|
test_begin_subtest "Ignore files and directories specified in new.ignore (full-scan)"
|
|
|
|
generate_message
|
|
|
|
notmuch config set new.ignore .git ignored_file .ignored_hidden_file
|
|
|
|
NOTMUCH_NEW --debug --full-scan 2>&1 | sort > OUTPUT
|
|
|
|
# reuse EXPECTED from previous test
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
2012-02-15 11:17:30 +02:00
|
|
|
|
2012-10-12 15:32:38 -04:00
|
|
|
test_begin_subtest "Ignore files and directories specified in new.ignore (multiple occurrences)"
|
|
|
|
notmuch config set new.ignore .git ignored_file .ignored_hidden_file
|
2013-12-23 15:20:36 -05:00
|
|
|
notmuch new > /dev/null # ensure that files/folders will be printed in ASCII order.
|
2012-10-12 15:32:38 -04:00
|
|
|
mkdir -p "${MAIL_DIR}"/one/two/three/.git
|
|
|
|
touch "${MAIL_DIR}"/{one,one/two,one/two/three}/ignored_file
|
2018-04-29 20:19:42 -03:00
|
|
|
output=$(NOTMUCH_NEW --debug --full-scan 2>&1 | sort)
|
2012-10-12 15:32:38 -04:00
|
|
|
test_expect_equal "$output" \
|
2015-11-03 21:49:29 +02:00
|
|
|
"(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/.git
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/.ignored_hidden_file
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/ignored_file
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/one/ignored_file
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/one/two/ignored_file
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/one/two/three/.git
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/one/two/three/ignored_file
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/.git
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/.ignored_hidden_file
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/ignored_file
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/one/ignored_file
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/one/two/ignored_file
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/one/two/three/.git
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/one/two/three/ignored_file
|
2012-10-12 15:32:38 -04:00
|
|
|
No new mail."
|
|
|
|
|
2012-02-15 11:17:30 +02:00
|
|
|
|
2012-11-25 00:25:44 -05:00
|
|
|
test_begin_subtest "Don't stop for ignored broken symlinks"
|
|
|
|
notmuch config set new.ignore .git ignored_file .ignored_hidden_file broken_link
|
|
|
|
ln -s i_do_not_exist "${MAIL_DIR}"/broken_link
|
|
|
|
output=$(NOTMUCH_NEW 2>&1)
|
|
|
|
test_expect_equal "$output" "No new mail."
|
|
|
|
|
2017-10-14 16:16:28 +03:00
|
|
|
test_begin_subtest "Ignore files and directories specified in new.ignore (regexp)"
|
|
|
|
notmuch config set new.ignore ".git" "/^bro.*ink\$/" "/ignored.*file/"
|
2018-04-29 20:19:42 -03:00
|
|
|
output=$(NOTMUCH_NEW --debug --full-scan 2>&1 | sort)
|
2017-10-14 16:16:28 +03:00
|
|
|
test_expect_equal "$output" \
|
|
|
|
"(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/.git
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/.ignored_hidden_file
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/broken_link
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/ignored_file
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/one/ignored_file
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/one/two/ignored_file
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/one/two/three/.git
|
|
|
|
(D) add_files, pass 1: explicitly ignoring ${MAIL_DIR}/one/two/three/ignored_file
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/.git
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/.ignored_hidden_file
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/broken_link
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/ignored_file
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/one/ignored_file
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/one/two/ignored_file
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/one/two/three/.git
|
|
|
|
(D) add_files, pass 2: explicitly ignoring ${MAIL_DIR}/one/two/three/ignored_file
|
|
|
|
No new mail."
|
|
|
|
|
2014-01-26 20:58:46 +02:00
|
|
|
test_begin_subtest "Quiet: No new mail."
|
|
|
|
output=$(NOTMUCH_NEW --quiet)
|
|
|
|
test_expect_equal "$output" ""
|
|
|
|
|
|
|
|
test_begin_subtest "Quiet: new, removed and renamed messages."
|
|
|
|
# new
|
|
|
|
generate_message
|
|
|
|
# deleted
|
|
|
|
notmuch search --format=text0 --output=files --limit=1 '*' | xargs -0 rm
|
|
|
|
# moved
|
|
|
|
mkdir "${MAIL_DIR}"/moved_messages
|
|
|
|
notmuch search --format=text0 --output=files --offset=1 --limit=1 '*' | xargs -0 -I {} mv {} "${MAIL_DIR}"/moved_messages
|
|
|
|
output=$(NOTMUCH_NEW --quiet)
|
|
|
|
test_expect_equal "$output" ""
|
|
|
|
|
2014-02-23 18:55:23 +02:00
|
|
|
OLDCONFIG=$(notmuch config get new.tags)
|
|
|
|
|
2021-01-02 13:10:39 -04:00
|
|
|
test_begin_subtest "Empty tags in new.tags are ignored"
|
2014-02-23 18:55:23 +02:00
|
|
|
notmuch config set new.tags "foo;;bar"
|
2021-01-02 13:10:39 -04:00
|
|
|
output=$(NOTMUCH_NEW --quiet 2>&1)
|
|
|
|
test_expect_equal "$output" ""
|
2014-02-23 18:55:23 +02:00
|
|
|
|
2021-09-30 14:17:47 -03:00
|
|
|
test_begin_subtest "leading/trailing whitespace in new.tags is ignored"
|
|
|
|
# avoid complications with leading spaces and "notmuch config"
|
|
|
|
sed -i 's/^tags=.*$/tags= fu bar ; ; bar /' notmuch-config
|
|
|
|
add_message
|
|
|
|
NOTMUCH_NEW --quiet
|
|
|
|
notmuch dump id:$gen_msg_id | sed 's/ --.*$//' > OUTPUT
|
|
|
|
cat <<EOF >EXPECTED
|
|
|
|
#notmuch-dump batch-tag:3 config,properties,tags
|
|
|
|
+bar +fu%20bar
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2014-02-23 18:55:23 +02:00
|
|
|
test_begin_subtest "Tags starting with '-' in new.tags are forbidden"
|
|
|
|
notmuch config set new.tags "-foo;bar"
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug 2>&1)
|
2014-02-23 18:55:23 +02:00
|
|
|
test_expect_equal "$output" "Error: tag '-foo' in new.tags: tag starting with '-' forbidden"
|
|
|
|
|
2017-02-26 15:43:01 +02:00
|
|
|
test_begin_subtest "Invalid tags set exit code"
|
|
|
|
test_expect_code 1 "NOTMUCH_NEW --debug 2>&1"
|
2014-02-23 18:55:23 +02:00
|
|
|
|
|
|
|
notmuch config set new.tags $OLDCONFIG
|
|
|
|
|
2021-12-26 08:24:09 -04:00
|
|
|
test_begin_subtest ".notmuch only ignored at top level"
|
|
|
|
generate_message '[dir]=foo/bar/.notmuch/cur' '[subject]="Do not ignore, very important"'
|
|
|
|
NOTMUCH_NEW > OUTPUT
|
|
|
|
notmuch search subject:Do-not-ignore | notmuch_search_sanitize >> OUTPUT
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
Added 1 new message to the database.
|
|
|
|
thread:XXX 2001-01-05 [1/1] Notmuch Test Suite; Do not ignore, very important (inbox unread)
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2021-03-23 21:24:05 -03:00
|
|
|
test_begin_subtest "RFC822 group names are indexed"
|
|
|
|
test_subtest_known_broken
|
|
|
|
generate_message [to]="undisclosed-recipients:"
|
|
|
|
NOTMUCH_NEW > OUTPUT
|
|
|
|
output=$(notmuch search --output=messages to:undisclosed-recipients)
|
|
|
|
test_expect_equal "${output}" "${gen_msg_id}"
|
|
|
|
|
2021-03-17 22:20:35 -03:00
|
|
|
test_begin_subtest "Long directory names don't cause rescan"
|
|
|
|
test_subtest_known_broken
|
|
|
|
printf -v name 'z%.0s' {1..234}
|
|
|
|
generate_message [dir]=$name
|
|
|
|
NOTMUCH_NEW > OUTPUT
|
|
|
|
notmuch new >> OUTPUT
|
|
|
|
rm -r ${MAIL_DIR}/${name}
|
|
|
|
notmuch new >> OUTPUT
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
Added 1 new message to the database.
|
|
|
|
No new mail.
|
|
|
|
No new mail. Removed 1 message.
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
2015-03-14 08:32:22 +01:00
|
|
|
|
2022-12-27 13:08:46 -04:00
|
|
|
test_begin_subtest "Long file names have reasonable diagnostics"
|
|
|
|
printf -v name 'f%.0s' {1..234}
|
|
|
|
generate_message "[filename]=$name"
|
|
|
|
notmuch new 2>&1 | notmuch_dir_sanitize >OUTPUT
|
|
|
|
rm ${MAIL_DIR}/${name}
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
Note: Ignoring non-indexable path: MAIL_DIR/$name
|
|
|
|
add_file: Path supplied is illegal for this function
|
|
|
|
filename too long for file-direntry term: MAIL_DIR/$name
|
|
|
|
Processed 1 file in almost no time.
|
|
|
|
No new mail.
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2015-03-14 08:32:22 +01:00
|
|
|
test_begin_subtest "Xapian exception: read only files"
|
2023-01-04 08:41:42 -04:00
|
|
|
test_subtest_broken_for_root
|
2021-01-15 21:29:17 -04:00
|
|
|
chmod u-w ${MAIL_DIR}/.notmuch/xapian/*.*
|
2015-08-04 08:48:34 +02:00
|
|
|
output=$(NOTMUCH_NEW --debug 2>&1 | sed 's/: .*$//' )
|
2021-01-15 21:29:17 -04:00
|
|
|
chmod u+w ${MAIL_DIR}/.notmuch/xapian/*.*
|
2015-03-14 08:32:22 +01:00
|
|
|
test_expect_equal "$output" "A Xapian exception occurred opening database"
|
|
|
|
|
2016-11-27 11:59:34 +02:00
|
|
|
|
2021-10-24 22:15:15 -03:00
|
|
|
make_shim dif-shim<<EOF
|
|
|
|
#include <notmuch-test.h>
|
|
|
|
|
|
|
|
WRAP_DLFUNC(notmuch_status_t, notmuch_database_index_file, \
|
|
|
|
(notmuch_database_t *database, const char *filename, notmuch_indexopts_t *indexopts, notmuch_message_t **message))
|
|
|
|
|
|
|
|
if (unlink ("${MAIL_DIR}/vanish")) {
|
|
|
|
fprintf (stderr, "unlink failed\n");
|
|
|
|
exit (42);
|
|
|
|
}
|
|
|
|
return notmuch_database_index_file_orig (database, filename, indexopts, message);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
|
2016-11-27 11:59:34 +02:00
|
|
|
test_begin_subtest "Handle files vanishing between scandir and add_file"
|
|
|
|
|
|
|
|
# A file for scandir to find. It won't get indexed, so can be empty.
|
|
|
|
touch ${MAIL_DIR}/vanish
|
2021-10-24 22:15:15 -03:00
|
|
|
notmuch_with_shim dif-shim new 2>OUTPUT 1>/dev/null
|
2016-11-27 11:59:34 +02:00
|
|
|
echo "exit status: $?" >> OUTPUT
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
Unexpected error with file ${MAIL_DIR}/vanish
|
|
|
|
add_file: Something went wrong trying to read or write a file
|
|
|
|
Error opening ${MAIL_DIR}/vanish: No such file or directory
|
|
|
|
exit status: 75
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2021-05-06 19:55:07 -03:00
|
|
|
test_begin_subtest "Relative database path expanded in new"
|
|
|
|
ln -s "$PWD/mail" home/Maildir
|
|
|
|
notmuch config set database.path Maildir
|
|
|
|
generate_message
|
|
|
|
NOTMUCH_NEW > OUTPUT
|
|
|
|
cat <<EOF >EXPECTED
|
|
|
|
Added 1 new message to the database.
|
|
|
|
EOF
|
|
|
|
notmuch config set database.path ${MAIL_DIR}
|
|
|
|
rm home/Maildir
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2021-05-07 07:17:43 -03:00
|
|
|
test_begin_subtest "Relative mail root (in db) expanded in new"
|
|
|
|
ln -s "$PWD/mail" home/Maildir
|
|
|
|
notmuch config set --database database.mail_root Maildir
|
|
|
|
generate_message
|
|
|
|
NOTMUCH_NEW > OUTPUT
|
|
|
|
cat <<EOF >EXPECTED
|
|
|
|
Added 1 new message to the database.
|
|
|
|
EOF
|
|
|
|
notmuch config set database.mail_root
|
|
|
|
rm home/Maildir
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2018-03-20 18:22:35 -03:00
|
|
|
add_email_corpus broken
|
|
|
|
test_begin_subtest "reference loop does not crash"
|
|
|
|
test_expect_code 0 "notmuch show --format=json id:mid-loop-12@example.org id:mid-loop-21@example.org > OUTPUT"
|
|
|
|
|
2018-04-13 22:46:09 -03:00
|
|
|
test_begin_subtest "reference loop ordered by date"
|
2021-01-15 21:29:17 -04:00
|
|
|
threadid=$(notmuch search --output=threads id:mid-loop-12@example.org)
|
|
|
|
notmuch show --format=mbox $threadid | grep '^Date' > OUTPUT
|
2018-04-13 22:46:09 -03:00
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
Date: Thu, 16 Jun 2016 22:14:41 -0400
|
|
|
|
Date: Fri, 17 Jun 2016 22:14:41 -0400
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2010-06-10 08:48:03 +02:00
|
|
|
test_done
|