X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=test%2FT240-dump-restore.sh;h=105de130bf240c69a1f232159c23f6b7902e3811;hp=d45c9f87d17aca17aa0040ec8cd2e214acda21c1;hb=HEAD;hpb=a34f30888e7874fba2032a066a7babce1dd3f69f diff --git a/test/T240-dump-restore.sh b/test/T240-dump-restore.sh index d45c9f87..c3f18839 100755 --- a/test/T240-dump-restore.sh +++ b/test/T240-dump-restore.sh @@ -1,6 +1,6 @@ #!/usr/bin/env bash test_description="\"notmuch dump\" and \"notmuch restore\"" -. ./test-lib.sh || exit 1 +. $(dirname "$0")/test-lib.sh || exit 1 NOTMUCH_NEW > /dev/null test_begin_subtest "dump header" @@ -11,60 +11,67 @@ notmuch dump > OUTPUT test_expect_equal_file EXPECTED OUTPUT add_email_corpus -test_expect_success 'Dumping all tags' \ - 'generate_message && - notmuch new && - notmuch dump > dump.expected' +test_begin_subtest "Dumping all tags" +test_expect_success 'generate_message && notmuch new && notmuch dump > dump.expected' # The use of from:cworth is rather arbitrary: it matches some of the # email corpus' messages, but not all of them. -test_expect_success 'Dumping all tags II' \ +test_begin_subtest "Dumping all tags II" +test_expect_success \ 'notmuch tag +ABC +DEF -- from:cworth && notmuch dump > dump-ABC_DEF.expected && ! cmp dump.expected dump-ABC_DEF.expected' -test_expect_success 'Clearing all tags' \ +test_begin_subtest "Clearing all tags" +test_expect_success \ 'sed -e "s/(\([^(]*\))$/()/" < dump.expected > clear.expected && notmuch restore --input=clear.expected && notmuch dump > clear.actual && test_cmp clear.expected clear.actual' -test_expect_success 'Accumulate original tags' \ +test_begin_subtest "Clearing all tags" +test_expect_success \ 'notmuch tag +ABC +DEF -- from:cworth && notmuch restore --accumulate < dump.expected && notmuch dump > dump.actual && test_cmp dump-ABC_DEF.expected dump.actual' -test_expect_success 'Restoring original tags' \ +test_begin_subtest "Restoring original tags" +test_expect_success \ 'notmuch restore --input=dump.expected && notmuch dump > dump.actual && test_cmp dump.expected dump.actual' -test_expect_success 'Restore with nothing to do' \ +test_begin_subtest "Restore with nothing to do" +test_expect_success \ 'notmuch restore < dump.expected && notmuch dump > dump.actual && test_cmp dump.expected dump.actual' -test_expect_success 'Accumulate with existing tags' \ +test_begin_subtest "Accumulate with existing tags" +test_expect_success \ 'notmuch restore --accumulate --input=dump.expected && notmuch dump > dump.actual && test_cmp dump.expected dump.actual' -test_expect_success 'Accumulate with no tags' \ +test_begin_subtest "Accumulate with no tags" +test_expect_success \ 'notmuch restore --accumulate < clear.expected && notmuch dump > dump.actual && test_cmp dump.expected dump.actual' -test_expect_success 'Accumulate with new tags' \ +test_begin_subtest "Accumulate with new tags" +test_expect_success \ 'notmuch restore --input=dump.expected && notmuch restore --accumulate --input=dump-ABC_DEF.expected && - notmuch dump > OUTPUT.$test_count && + notmuch dump > OUTPUT.$test_count && notmuch restore --input=dump.expected && test_cmp dump-ABC_DEF.expected OUTPUT.$test_count' # notmuch restore currently only considers the first argument. -test_expect_success 'Invalid restore invocation' \ +test_begin_subtest "Invalid restore invocation" +test_expect_success \ 'test_must_fail notmuch restore --input=dump.expected another_one' test_begin_subtest "dump --output=outfile" @@ -110,6 +117,19 @@ test_begin_subtest "dump -- from:cworth" notmuch dump -- from:cworth > dump-dash-cworth.actual test_expect_equal_file dump-cworth.expected dump-dash-cworth.actual + +if [ "${NOTMUCH_HAVE_SFSEXP-0}" = "1" ]; then + + test_begin_subtest "dump --query=sexp -- '(from cworth)'" + notmuch dump --query=sexp -- '(from cworth)' > dump-dash-cworth.actual2 + test_expect_equal_file_nonempty dump-cworth.expected dump-dash-cworth.actual2 + + test_begin_subtest "dump --query=sexp --output=outfile '(from cworth)'" + notmuch dump --output=dump-outfile-cworth.actual2 --query=sexp '(from cworth)' + test_expect_equal_file dump-cworth.expected dump-outfile-cworth.actual2 + +fi + test_begin_subtest "dump --output=outfile from:cworth" notmuch dump --output=dump-outfile-cworth.actual from:cworth test_expect_equal_file dump-cworth.expected dump-outfile-cworth.actual @@ -119,10 +139,11 @@ notmuch dump --output=dump-outfile-dash-inbox.actual -- from:cworth test_expect_equal_file dump-cworth.expected dump-outfile-dash-inbox.actual test_begin_subtest "Check for a safe set of message-ids" +test_subtest_broken_for_installed notmuch search --output=messages from:cworth | sed s/^id:// > EXPECTED notmuch search --output=messages from:cworth | sed s/^id:// |\ $TEST_DIRECTORY/hex-xcode --direction=encode > OUTPUT -test_expect_equal_file OUTPUT EXPECTED +test_expect_equal_file EXPECTED OUTPUT test_begin_subtest "format=batch-tag, dump sanity check." NOTMUCH_DUMP_TAGS --format=sup from:cworth | cut -f1 -d' ' | \ @@ -226,9 +247,10 @@ notmuch dump --format=batch-tag > OUTPUT.$test_count test_expect_equal_file EXPECTED.$test_count OUTPUT.$test_count test_begin_subtest 'format=batch-tag, checking encoded output' +test_subtest_broken_for_installed NOTMUCH_DUMP_TAGS --format=batch-tag -- from:cworth |\ awk "{ print \"+$enc1 +$enc2 +$enc3 -- \" \$5 }" > EXPECTED.$test_count -NOTMUCH_DUMP_TAGS --format=batch-tag -- from:cworth > OUTPUT.$test_count +NOTMUCH_DUMP_TAGS --format=batch-tag -- from:cworth > OUTPUT.$test_count test_expect_equal_file EXPECTED.$test_count OUTPUT.$test_count test_begin_subtest 'restoring sane tags' @@ -315,6 +337,7 @@ EOF test_expect_equal_file EXPECTED OUTPUT +backup_database test_begin_subtest 'roundtripping random message-ids and tags' ${TEST_DIRECTORY}/random-corpus --config-path=${NOTMUCH_CONFIG} \ @@ -331,7 +354,7 @@ test_begin_subtest 'roundtripping random message-ids and tags' sort > OUTPUT.$test_count test_expect_equal_file EXPECTED.$test_count OUTPUT.$test_count +restore_database test_done -# Note the database is "poisoned" for sup format at this point.