X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=test%2FT070-insert.sh;h=f1650e623e351475d1a0d17b7075f8673e9b3d0b;hp=7e04a23d93e2b0817f8c847bc7840bc0dbfb1b2a;hb=a863de1e43ee34f6f5794a2759fdceb287e851aa;hpb=32065e79090ce27c609db6a2fc07e134f1d3d4df diff --git a/test/T070-insert.sh b/test/T070-insert.sh index 7e04a23d..f1650e62 100755 --- a/test/T070-insert.sh +++ b/test/T070-insert.sh @@ -1,6 +1,6 @@ #!/usr/bin/env bash test_description='"notmuch insert"' -. ./test-lib.sh || exit 1 +. $(dirname "$0")/test-lib.sh || exit 1 test_require_external_prereq gdb @@ -20,13 +20,13 @@ gen_insert_msg() { "[body]=\"insert-message\"" } -test_expect_code 1 "Insert zero-length file" \ - "notmuch insert < /dev/null" +test_begin_subtest "Insert zero-length file" +test_expect_code 1 "notmuch insert < /dev/null" # This test is a proxy for other errors that may occur while trying to # add a message to the notmuch database, e.g. database locked. -test_expect_code 1 "Insert non-message" \ - "echo bad_message | notmuch insert" +test_begin_subtest "Insert non-message" +test_expect_code 1 "echo bad_message | notmuch insert" test_begin_subtest "Database empty so far" test_expect_equal "0" "`notmuch count --output=messages '*'`" @@ -43,7 +43,7 @@ expected='[[[{ "id": "'"${gen_msg_id}"'", "match": true, "excluded": false, - "filename": "'"${cur_msg_filename}"'", + "filename": ["'"${cur_msg_filename}"'"], "timestamp": 946728000, "date_relative": "2000-01-01", "tags": ["inbox","unread"], @@ -60,7 +60,7 @@ test_expect_equal_json "$output" "$expected" test_begin_subtest "Insert duplicate message" notmuch insert +duptag -unread < "$gen_msg_filename" -output=$(notmuch search --output=files "subject:insert-subject" | wc -l) +output=$((`notmuch search --output=files "subject:insert-subject" | wc -l`)) test_expect_equal "$output" 2 test_begin_subtest "Duplicate message does not change tags" @@ -132,15 +132,22 @@ output=$(notmuch search --output=files path:Drafts/new) dirname=$(dirname "$output") test_expect_equal "$dirname" "$MAIL_DIR/Drafts/new" +test_begin_subtest "Insert message into folder with trailing /" +gen_insert_msg +notmuch insert --folder=Drafts/ < "$gen_msg_filename" +output=$(notmuch search --output=files id:${gen_msg_id}) +dirname=$(dirname "$output") +test_expect_equal "$dirname" "$MAIL_DIR/Drafts/new" + test_begin_subtest "Insert message into folder, add/remove tags" gen_insert_msg notmuch insert --folder=Drafts +draft -unread < "$gen_msg_filename" output=$(notmuch search --output=messages path:Drafts/cur tag:draft NOT tag:unread) test_expect_equal "$output" "id:$gen_msg_id" +test_begin_subtest "Insert message into non-existent folder" gen_insert_msg -test_expect_code 1 "Insert message into non-existent folder" \ - "notmuch insert --folder=nonesuch < $gen_msg_filename" +test_expect_code 1 "notmuch insert --folder=nonesuch < $gen_msg_filename" test_begin_subtest "Insert message, create folder" gen_insert_msg @@ -162,9 +169,9 @@ notmuch insert --folder=F/G/H/I/J --create-folder +folder < "$gen_msg_filename" output=$(notmuch count path:F/G/H/I/J/new tag:folder) test_expect_equal "$output" "2" +test_begin_subtest "Insert message, create invalid subfolder" gen_insert_msg -test_expect_code 1 "Insert message, create invalid subfolder" \ - "notmuch insert --folder=../G --create-folder $gen_msg_filename" +test_expect_code 1 "notmuch insert --folder=../G --create-folder $gen_msg_filename" OLDCONFIG=$(notmuch config get new.tags) @@ -180,8 +187,8 @@ gen_insert_msg output=$(notmuch insert $gen_msg_filename 2>&1) test_expect_equal "$output" "Error: tag '-foo' in new.tags: tag starting with '-' forbidden" -test_expect_code 1 "Invalid tags set exit code" \ - "notmuch insert $gen_msg_filename 2>&1" +test_begin_subtest "Invalid tags set exit code" +test_expect_code 1 "notmuch insert $gen_msg_filename 2>&1" notmuch config set new.tags $OLDCONFIG @@ -193,7 +200,7 @@ cat < index-file-$code.gdb set breakpoint pending on set logging file index-file-$code.log set logging on -break notmuch_database_add_message +break notmuch_database_index_file commands return NOTMUCH_STATUS_$code continue @@ -205,22 +212,28 @@ done gen_insert_msg for code in FILE_NOT_EMAIL READ_ONLY_DATABASE UPGRADE_REQUIRED PATH_ERROR; do - test_expect_code 1 "EXIT_FAILURE when add_message returns $code" \ + test_begin_subtest "EXIT_FAILURE when index_file returns $code" + test_expect_code 1 \ "${TEST_GDB} --batch-silent --return-child-result \ -ex 'set args insert < $gen_msg_filename' \ -x index-file-$code.gdb notmuch" - test_expect_code 0 "success exit with --keep when add_message returns $code" \ + + test_begin_subtest "success exit with --keep when index_file returns $code" + test_expect_code 0 \ "${TEST_GDB} --batch-silent --return-child-result \ -ex 'set args insert --keep < $gen_msg_filename' \ -x index-file-$code.gdb notmuch" done for code in OUT_OF_MEMORY XAPIAN_EXCEPTION ; do - test_expect_code 75 "EX_TEMPFAIL when add_message returns $code" \ + test_begin_subtest "EX_TEMPFAIL when index_file returns $code" + test_expect_code 75 \ "${TEST_GDB} --batch-silent --return-child-result \ -ex 'set args insert < $gen_msg_filename' \ -x index-file-$code.gdb notmuch" - test_expect_code 0 "success exit with --keep when add_message returns $code" \ + + test_begin_subtest "success exit with --keep when index_file returns $code" + test_expect_code 0 \ "${TEST_GDB} --batch-silent --return-child-result \ -ex 'set args insert --keep < $gen_msg_filename' \ -x index-file-$code.gdb notmuch"