X-Git-Url: https://git.cworth.org/git?p=notmuch;a=blobdiff_plain;f=test%2FT566-lib-message.sh;fp=test%2FT566-lib-message.sh;h=bac2be6617a06a86a314f956eb44fa885c5e642f;hp=bc9bfcb62fad36a513a62b186e03ccdcdaeb21f4;hb=a581755fbbf4149c33740779a85f3ee1f11cd7e9;hpb=f48d2e2ff89a7e0a413b29ca844b2c785063eb3d diff --git a/test/T566-lib-message.sh b/test/T566-lib-message.sh index bc9bfcb6..bac2be66 100755 --- a/test/T566-lib-message.sh +++ b/test/T566-lib-message.sh @@ -324,6 +324,24 @@ cat < EXPECTED EOF test_expect_equal_file EXPECTED OUTPUT +test_begin_subtest "_notmuch_message_remove_term catches exceptions" +cat c_head0 - c_tail <<'EOF' | test_private_C ${MAIL_DIR} + { + notmuch_private_status_t status; + /* Xapian throws the same exception for empty and non-existent terms; + * error string varies between Xapian versions. */ + status = _notmuch_message_remove_term (message, "tag", "nonexistent"); + printf("%d\n%d\n", message != NULL, status == NOTMUCH_STATUS_SUCCESS ); + } +EOF +cat < EXPECTED +== stdout == +1 +1 +== stderr == +EOF +test_expect_equal_file EXPECTED OUTPUT + test_begin_subtest "Handle removing all tags with closed db" cat c_head - c_tail <<'EOF' | test_C ${MAIL_DIR} {