mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-11-21 18:38:08 +01:00
67f535332c
This duplicates one of the bugs reported by Gregor in [1]. [1]: id:87edxw8jp4.fsf@no.workgroup
395 lines
14 KiB
Bash
Executable file
395 lines
14 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
|
|
test_description="emacs notmuch-show view"
|
|
. $(dirname "$0")/test-lib.sh || exit 1
|
|
. $NOTMUCH_SRCDIR/test/test-lib-emacs.sh || exit 1
|
|
|
|
EXPECTED=$NOTMUCH_SRCDIR/test/emacs-show.expected-output
|
|
|
|
test_require_emacs
|
|
add_email_corpus
|
|
|
|
test_begin_subtest "Hiding Original Message region at beginning of a message"
|
|
message_id='OriginalMessageHiding.1@notmuchmail.org'
|
|
add_message \
|
|
[id]="$message_id" \
|
|
'[subject]="Hiding Original Message region at beginning of a message"' \
|
|
'[body]="-----Original Message-----
|
|
Text here."'
|
|
|
|
cat <<EOF >EXPECTED
|
|
Notmuch Test Suite <test_suite@notmuchmail.org> (2001-01-05) (inbox)
|
|
Subject: Hiding Original Message region at beginning of a message
|
|
To: Notmuch Test Suite <test_suite@notmuchmail.org>
|
|
Date: GENERATED_DATE
|
|
|
|
[ 2-line hidden original message. Click/Enter to show. ]
|
|
EOF
|
|
|
|
test_emacs "(notmuch-show \"id:$message_id\")
|
|
(test-visible-output \"OUTPUT.raw\")"
|
|
notmuch_date_sanitize < OUTPUT.raw > OUTPUT
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
test_begin_subtest "Bare subject #1"
|
|
output=$(test_emacs '(notmuch-show-strip-re "Re: subject")')
|
|
test_expect_equal "$output" '"subject"'
|
|
|
|
test_begin_subtest "Bare subject #2"
|
|
output=$(test_emacs '(notmuch-show-strip-re "re:Re: re: Re: re:subject")')
|
|
test_expect_equal "$output" '"subject"'
|
|
|
|
test_begin_subtest "Bare subject #3"
|
|
output=$(test_emacs '(notmuch-show-strip-re "the cure: fix the regexp")')
|
|
test_expect_equal "$output" '"the cure: fix the regexp"'
|
|
|
|
test_begin_subtest "don't process cryptographic MIME parts"
|
|
test_emacs '(let ((notmuch-crypto-process-mime nil))
|
|
(notmuch-show "id:20091117203301.GV3165@dottiness.seas.harvard.edu")
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-process-crypto-mime-parts-off OUTPUT
|
|
|
|
test_begin_subtest "process cryptographic MIME parts"
|
|
test_emacs '(let ((notmuch-crypto-process-mime t))
|
|
(notmuch-show "id:20091117203301.GV3165@dottiness.seas.harvard.edu")
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-process-crypto-mime-parts-on OUTPUT
|
|
|
|
test_begin_subtest "process cryptographic MIME parts (w/ notmuch-show-toggle-process-crypto)"
|
|
test_emacs '(let ((notmuch-crypto-process-mime nil))
|
|
(notmuch-show "id:20091117203301.GV3165@dottiness.seas.harvard.edu")
|
|
(notmuch-show-toggle-process-crypto)
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-process-crypto-mime-parts-on OUTPUT
|
|
|
|
test_begin_subtest "notmuch-search-show-thread returns non-nil on success"
|
|
test_emacs_expect_t '(notmuch-search "id:20091117203301.GV3165@dottiness.seas.harvard.edu")
|
|
(notmuch-test-wait)
|
|
(and (notmuch-search-show-thread)
|
|
(not (notmuch-show-next-thread)))'
|
|
|
|
test_begin_subtest "notmuch-search-show-thread returns nil when there are no messages"
|
|
test_emacs_expect_t '(notmuch-search "id:non-existing-id")
|
|
(notmuch-test-wait)
|
|
(not (notmuch-search-show-thread))'
|
|
|
|
test_begin_subtest "notmuch-show: don't elide non-matching messages"
|
|
test_emacs '(let ((notmuch-show-only-matching-messages nil))
|
|
(notmuch-search "from:lars@seas.harvard.edu and subject:\"Maildir storage\"")
|
|
(notmuch-test-wait)
|
|
(notmuch-search-show-thread)
|
|
(notmuch-test-wait)
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-elide-non-matching-messages-off OUTPUT
|
|
|
|
test_begin_subtest "notmuch-show: elide non-matching messages"
|
|
test_emacs '(let ((notmuch-show-only-matching-messages t))
|
|
(notmuch-search "from:lars@seas.harvard.edu and subject:\"Maildir storage\"")
|
|
(notmuch-test-wait)
|
|
(notmuch-search-show-thread)
|
|
(notmuch-test-wait)
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-elide-non-matching-messages-on OUTPUT
|
|
|
|
test_begin_subtest "Hide bodies of messages by depth"
|
|
test_emacs '(let ((notmuch-show-depth-limit -1))
|
|
(notmuch-search "thread:{id:87ocn0qh6d.fsf@yoom.home.cworth.org}")
|
|
(notmuch-test-wait)
|
|
(notmuch-search-show-thread)
|
|
(notmuch-test-wait)
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-depth OUTPUT
|
|
|
|
|
|
test_begin_subtest "Hide bodies of messages by height"
|
|
test_emacs '(let ((notmuch-show-height-limit -1))
|
|
(notmuch-search "thread:{id:87ocn0qh6d.fsf@yoom.home.cworth.org}")
|
|
(notmuch-test-wait)
|
|
(notmuch-search-show-thread)
|
|
(notmuch-test-wait)
|
|
(test-visible-output))'
|
|
# folding all messages by height or depth should look the same
|
|
test_expect_equal_file $EXPECTED/notmuch-show-depth OUTPUT
|
|
|
|
test_begin_subtest "Hide bodies of messages; show only leaves."
|
|
test_emacs '(let ((notmuch-show-height-limit 0))
|
|
(notmuch-search "thread:{id:87ocn0qh6d.fsf@yoom.home.cworth.org}")
|
|
(notmuch-test-wait)
|
|
(notmuch-search-show-thread)
|
|
(notmuch-test-wait)
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-height-0 OUTPUT
|
|
|
|
test_begin_subtest "Hide bodies of messages (depth > 1)"
|
|
test_emacs '(let ((notmuch-show-depth-limit 1))
|
|
(notmuch-search "thread:{id:87ocn0qh6d.fsf@yoom.home.cworth.org}")
|
|
(notmuch-test-wait)
|
|
(notmuch-search-show-thread)
|
|
(notmuch-test-wait)
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-depth-1 OUTPUT
|
|
|
|
test_begin_subtest "Hide bodies of messages by size"
|
|
test_emacs '(let ((notmuch-show-max-text-part-size 1))
|
|
(notmuch-search "thread:{id:87ocn0qh6d.fsf@yoom.home.cworth.org}")
|
|
(notmuch-test-wait)
|
|
(notmuch-search-show-thread)
|
|
(notmuch-test-wait)
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-size OUTPUT
|
|
|
|
test_begin_subtest "Hide bodies of messages by size > 450"
|
|
test_emacs '(let ((notmuch-show-max-text-part-size 450))
|
|
(notmuch-search "thread:{id:87ocn0qh6d.fsf@yoom.home.cworth.org}")
|
|
(notmuch-test-wait)
|
|
(notmuch-search-show-thread)
|
|
(notmuch-test-wait)
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-size-450 OUTPUT
|
|
|
|
test_begin_subtest "notmuch-show: elide non-matching messages (w/ notmuch-show-toggle-elide-non-matching)"
|
|
test_emacs '(let ((notmuch-show-only-matching-messages nil))
|
|
(notmuch-search "from:lars@seas.harvard.edu and subject:\"Maildir storage\"")
|
|
(notmuch-test-wait)
|
|
(notmuch-search-show-thread)
|
|
(notmuch-test-wait)
|
|
(notmuch-show-toggle-elide-non-matching)
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-elide-non-matching-messages-on OUTPUT
|
|
|
|
test_begin_subtest "notmuch-show: elide non-matching messages (w/ prefix arg to notmuch-show)"
|
|
test_emacs '(let ((notmuch-show-only-matching-messages nil))
|
|
(notmuch-search "from:lars@seas.harvard.edu and subject:\"Maildir storage\"")
|
|
(notmuch-test-wait)
|
|
(notmuch-search-show-thread t)
|
|
(notmuch-test-wait)
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-elide-non-matching-messages-on OUTPUT
|
|
|
|
test_begin_subtest "notmuch-show: disable indentation of thread content (w/ notmuch-show-toggle-thread-indentation)"
|
|
test_emacs '(notmuch-search "from:lars@seas.harvard.edu and subject:\"Maildir storage\"")
|
|
(notmuch-test-wait)
|
|
(notmuch-search-show-thread)
|
|
(notmuch-test-wait)
|
|
(notmuch-show-toggle-thread-indentation)
|
|
(test-visible-output)'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-indent-thread-content-off OUTPUT
|
|
|
|
test_begin_subtest "id buttonization"
|
|
add_message '[body]="
|
|
id:abc
|
|
id:abc.def. id:abc,def, id:abc;def; id:abc:def:
|
|
id:foo@bar.?baz? id:foo@bar!.baz!
|
|
(id:foo@bar.baz) [id:foo@bar.baz]
|
|
id:foo@bar.baz...
|
|
id:2+2=5
|
|
id:=_-:/.[]@$%+
|
|
id:abc)def
|
|
id:ab\"c def
|
|
id:\"abc\"def
|
|
id:\"ab\"\"c\"def
|
|
id:\"ab c\"def
|
|
id:\"abc\".def
|
|
id:\"abc
|
|
\"
|
|
id:)
|
|
id:
|
|
cid:xxx
|
|
mid:abc mid:abc/def
|
|
mid:abc%20def
|
|
mid:abc. mid:abc, mid:abc;"'
|
|
test_emacs '(notmuch-show "id:'$gen_msg_id'")
|
|
(notmuch-test-mark-links)
|
|
(test-visible-output "OUTPUT.raw")'
|
|
cat <<EOF >EXPECTED
|
|
Notmuch Test Suite <test_suite@notmuchmail.org> (2001-01-05) (inbox)
|
|
Subject: id buttonization
|
|
To: Notmuch Test Suite <test_suite@notmuchmail.org>
|
|
Date: GENERATED_DATE
|
|
|
|
<<id:abc>>
|
|
<<id:abc.def>>. <<id:abc,def>>, <<id:abc;def>>; <<id:abc:def>>:
|
|
<<id:foo@bar.?baz>>? <<id:foo@bar!.baz>>!
|
|
(<<id:foo@bar.baz>>) [<<id:foo@bar.baz>>]
|
|
<<id:foo@bar.baz>>...
|
|
<<id:2+2=5>>
|
|
<<id:=_-:/.[]@$%+>>
|
|
<<id:abc>>)def
|
|
<<id:ab"c>> def
|
|
<<id:"abc">>def
|
|
<<id:"ab""c">>def
|
|
<<id:"ab c">>def
|
|
<<id:"abc">>.def
|
|
id:"abc
|
|
"
|
|
id:)
|
|
id:
|
|
cid:xxx
|
|
<<mid:abc>> <<mid:abc/def>>
|
|
<<mid:abc%20def>>
|
|
<<mid:abc>>. <<mid:abc>>, <<mid:abc>>;
|
|
EOF
|
|
notmuch_date_sanitize < OUTPUT.raw > OUTPUT
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
|
test_begin_subtest "Show handles subprocess errors"
|
|
cat > notmuch_fail <<EOF
|
|
#!/bin/sh
|
|
echo This is output
|
|
echo This is an error >&2
|
|
exit 1
|
|
EOF
|
|
chmod a+x notmuch_fail
|
|
test_emacs "(let ((notmuch-command \"$PWD/notmuch_fail\"))
|
|
(with-current-buffer \"*Messages*\"
|
|
(let ((inhibit-read-only t)) (erase-buffer)))
|
|
(condition-case err
|
|
(notmuch-show \"*\")
|
|
(error (message \"%s\" (cadr err))))
|
|
(notmuch-test-wait)
|
|
(with-current-buffer \"*Messages*\"
|
|
(test-output \"MESSAGES\"))
|
|
(with-current-buffer \"*Notmuch errors*\"
|
|
(test-output \"ERROR\"))
|
|
(test-output))"
|
|
test_expect_equal "$(notmuch_emacs_error_sanitize notmuch_fail OUTPUT MESSAGES ERROR)" "\
|
|
=== OUTPUT ===
|
|
=== MESSAGES ===
|
|
This is an error (see *Notmuch errors* for more details)
|
|
=== ERROR ===
|
|
This is an error
|
|
command: YYY/notmuch_fail show --format\\=sexp --format-version\\=5 --decrypt\\=true --exclude\\=false \\' \\* \\'
|
|
exit status: 1
|
|
stderr:
|
|
This is an error
|
|
stdout:
|
|
This is output"
|
|
|
|
test_begin_subtest "text/enriched exploit mitigation"
|
|
add_message '[content-type]="text/enriched"
|
|
[body]="
|
|
<x-display><param>(when (progn (read-only-mode -1) (insert ?p ?0 ?w ?n ?e ?d)) nil)</param>test</x-display>
|
|
"'
|
|
test_emacs '(notmuch-show "id:'$gen_msg_id'")
|
|
(test-visible-output "OUTPUT.raw")'
|
|
output=$(head -1 OUTPUT.raw|cut -f1-4 -d' ')
|
|
test_expect_equal "$output" "Notmuch Test Suite <test_suite@notmuchmail.org>"
|
|
|
|
test_begin_subtest "multipart/alternative hides html by default"
|
|
test_emacs '(notmuch-show "id:cf0c4d610911171136h1713aa59w9cf9aa31f052ad0a@mail.gmail.com")
|
|
(test-visible-output)'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-multipart-alternative OUTPUT
|
|
|
|
# switching to the crypto corpus, using gpg from here on:
|
|
add_gnupg_home
|
|
add_email_corpus crypto
|
|
|
|
test_begin_subtest "show decrypted message"
|
|
test_emacs '(notmuch-show "id:basic-encrypted@crypto.notmuchmail.org")
|
|
(test-visible-output)'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-decrypted-message OUTPUT
|
|
|
|
test_begin_subtest "show encrypted rfc822 message"
|
|
if ${TEST_EMACS} --quick --batch --eval '(kill-emacs (if (version< emacs-version "28") 0 1))'; then
|
|
test_subtest_known_broken
|
|
fi
|
|
test_emacs '(notmuch-show "id:encrypted-rfc822-attachment@crypto.notmuchmail.org")
|
|
(test-visible-output)'
|
|
test_expect_code 1 'fgrep "!!!" OUTPUT'
|
|
|
|
test_begin_subtest "show undecryptable message"
|
|
test_emacs '(notmuch-show "id:simple-encrypted@crypto.notmuchmail.org")
|
|
(test-visible-output)'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-undecryptable-message OUTPUT
|
|
|
|
test_begin_subtest "show encrypted message when not processing crypto"
|
|
test_emacs '(let ((notmuch-crypto-process-mime nil))
|
|
(notmuch-show "id:basic-encrypted@crypto.notmuchmail.org")
|
|
(test-visible-output))'
|
|
test_expect_equal_file $EXPECTED/notmuch-show-decrypted-message-no-crypto OUTPUT
|
|
|
|
test_begin_subtest "notmuch-show with nonexistent CWD"
|
|
tid=$(notmuch search --limit=1 --output=threads '*' | sed s/thread://)
|
|
test_emacs "(test-log-error
|
|
(let ((default-directory \"/nonexistent\"))
|
|
(notmuch-show \"$tid\")))"
|
|
test_expect_equal "$(cat MESSAGES)" "COMPLETE"
|
|
|
|
add_email_corpus attachment
|
|
|
|
test_begin_subtest "tar not inlined by default"
|
|
test_emacs '(notmuch-show "id:874llc2bkp.fsf@curie.anarc.at")
|
|
(test-visible-output "OUTPUT")'
|
|
cat <<EOF > EXPECTED
|
|
Antoine Beaupré <anarcat@orangeseeds.org> (2018-03-19) (attachment inbox)
|
|
Subject: Re: bug: "no top level messages" crash on Zen email loops
|
|
To: David Bremner <david@tethera.net>, notmuch@notmuchmail.org
|
|
Date: Mon, 19 Mar 2018 13:56:54 -0400
|
|
|
|
[ multipart/mixed ]
|
|
[ text/plain ]
|
|
And obviously I forget the frigging attachment.
|
|
[ zendesk-email-loop2.tgz: application/x-gtar-compressed ]
|
|
[ text/plain ]
|
|
|
|
PS: don't we have a "you forgot to actually attach the damn file" plugin
|
|
when we detect the word "attachment" and there's no attach? :p
|
|
EOF
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
add_email_corpus duplicate
|
|
|
|
ID3=87r2ecrr6x.fsf@zephyr.silentflame.com
|
|
test_begin_subtest "duplicate=3, subject"
|
|
test_emacs "(notmuch-show \"id:${ID3}\")
|
|
(notmuch-show-choose-duplicate 3)
|
|
(test-visible-output \"OUTPUT\")"
|
|
output=$(grep "Subject:" OUTPUT)
|
|
file=$(notmuch search --output=files id:${ID3} | head -n 3 | tail -n 1)
|
|
subject=$(grep '^Subject:' $file)
|
|
test_expect_equal "$output" "$subject"
|
|
|
|
FILE3=$(notmuch search --output=files --duplicate=3 "id:${ID3}")
|
|
test_begin_subtest "duplicate=3, stash"
|
|
test_emacs_expect_t \
|
|
"(notmuch-show \"id:${ID3}\")
|
|
(notmuch-show-choose-duplicate 3)
|
|
(notmuch-show-stash-filename)
|
|
(notmuch-test-expect-equal (list (car kill-ring)) (list \"${FILE3}\"))"
|
|
|
|
test_begin_subtest "duplicate=0"
|
|
test_emacs "(test-log-error
|
|
(notmuch-show \"id:${ID3}\")
|
|
(notmuch-show-choose-duplicate 0))"
|
|
cat <<EOF > EXPECTED
|
|
(error Duplicate 0 out of range [1,5])
|
|
EOF
|
|
test_expect_equal_file EXPECTED MESSAGES
|
|
|
|
test_begin_subtest "duplicate=1000"
|
|
test_emacs "(test-log-error
|
|
(notmuch-show \"id:${ID3}\")
|
|
(notmuch-show-choose-duplicate 1000))"
|
|
cat <<EOF > EXPECTED
|
|
(error Duplicate 1000 out of range [1,5])
|
|
EOF
|
|
test_expect_equal_file EXPECTED MESSAGES
|
|
test_begin_subtest "duplicate=4"
|
|
test_emacs "(notmuch-show \"id:${ID3}\")
|
|
(notmuch-show-choose-duplicate 4)
|
|
(test-visible-output \"OUTPUT\")"
|
|
test_expect_equal_file_nonempty $EXPECTED/notmuch-show-duplicate-4 OUTPUT
|
|
|
|
FILE4=$(notmuch search --output=files --duplicate=4 "id:${ID3}")
|
|
test_begin_subtest "duplicate=4, raw"
|
|
test_subtest_known_broken
|
|
test_emacs "(notmuch-show \"id:${ID3}\")
|
|
(notmuch-show-choose-duplicate 4)
|
|
(notmuch-show-view-raw-message)
|
|
(test-visible-output \"OUTPUT\")"
|
|
subject4=$(grep '^Subject:' $FILE4)
|
|
subject=$(grep '^Subject:' OUTPUT)
|
|
test_expect_equal "$subject4" "$subject"
|
|
|
|
test_done
|