unofficial mirror of notmuch@notmuchmail.org
 help / color / mirror / code / Atom feed
blob 7b67d03ca95d8df94146ae4ab96ef5429110aafd 6864 bytes (raw)
name: test/dump-restore 	 # note: path name is non-authoritative(*)

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
 
#!/usr/bin/env bash
test_description="\"notmuch dump\" and \"notmuch restore\""
. ./test-lib.sh

add_email_corpus

test_expect_success 'Dumping all tags' \
  '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' \
  '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' \
  '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' \
  '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' \
  'notmuch restore --input=dump.expected &&
  notmuch dump > dump.actual &&
  test_cmp dump.expected dump.actual'

test_expect_success 'Restore with nothing to do' \
  'notmuch restore < dump.expected &&
  notmuch dump > dump.actual &&
  test_cmp dump.expected dump.actual'

test_expect_success 'Accumulate with existing tags' \
  'notmuch restore --accumulate --input=dump.expected &&
  notmuch dump > dump.actual &&
  test_cmp dump.expected dump.actual'

test_expect_success 'Accumulate with no tags' \
  'notmuch restore --accumulate < clear.expected &&
  notmuch dump > dump.actual &&
  test_cmp dump.expected dump.actual'

test_expect_success 'Accumulate with new tags' \
  'notmuch restore --input=dump.expected &&
  notmuch restore --accumulate --input=dump-ABC_DEF.expected &&
  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_must_fail notmuch restore --input=dump.expected another_one'

test_begin_subtest "dump --output=outfile"
notmuch dump --output=dump-outfile.actual
test_expect_equal_file dump.expected dump-outfile.actual

test_begin_subtest "dump --output=outfile --"
notmuch dump --output=dump-1-arg-dash.actual --
test_expect_equal_file dump.expected dump-1-arg-dash.actual

# Note, we assume all messages from cworth have a message-id
# containing cworth.org

grep 'cworth[.]org' dump.expected > dump-cworth.expected

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

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

test_begin_subtest "dump --output=outfile -- from:cworth"
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"
notmuch search --output=messages from:cworth > EXPECTED.$test_count
notmuch search --output=messages from:cworth |\
	$TEST_DIRECTORY/hex-xcode --direction=encode > OUTPUT.$test_count
test_expect_equal_file OUTPUT.$test_count EXPECTED.$test_count

test_begin_subtest "format=batch-tag, # round-trip"
notmuch dump --format=sup | sort > EXPECTED.$test_count
notmuch dump --format=batch-tag | notmuch restore --format=batch-tag
notmuch dump --format=sup | sort > OUTPUT.$test_count
test_expect_equal_file EXPECTED.$test_count OUTPUT.$test_count

tag1='comic_swear=$&^%$^%\\//-+$^%$'
enc1=$($TEST_DIRECTORY/hex-xcode --direction=encode "$tag1")

tag2=$(printf 'this\n tag\t has\n spaces')
enc2=$($TEST_DIRECTORY/hex-xcode --direction=encode "$tag2")

enc3='%c3%91%c3%a5%c3%b0%c3%a3%c3%a5%c3%a9-%c3%8f%c3%8a'
tag3=$($TEST_DIRECTORY/hex-xcode --direction=decode $enc3)

notmuch dump --format=batch-tag > BACKUP

notmuch tag +"$tag1" +"$tag2" +"$tag3" -inbox -unread "*"

test_begin_subtest 'format=batch-tag, round trip with strange tags'
    notmuch dump --format=batch-tag > EXPECTED.$test_count
    notmuch dump --format=batch-tag | notmuch restore --format=batch-tag
    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'
    cp /dev/null EXPECTED.$test_count
    notmuch dump --format=batch-tag -- from:cworth |\
	 awk "{ print \"+$enc1 +$enc2 +$enc3 -- \" \$5 }" > EXPECTED.$test_count

    notmuch dump --format=batch-tag -- from:cworth  > OUTPUT.$test_count
test_expect_equal_file EXPECTED.$test_count OUTPUT.$test_count

test_begin_subtest 'restoring sane tags'
    notmuch restore --format=batch-tag < BACKUP
    notmuch dump --format=batch-tag > OUTPUT.$test_count
test_expect_equal_file BACKUP OUTPUT.$test_count

test_begin_subtest 'format=batch-tag, restore=auto'
    notmuch dump --format=batch-tag > EXPECTED.$test_count
    notmuch tag -inbox -unread "*"
    notmuch restore --format=auto < EXPECTED.$test_count
    notmuch dump --format=batch-tag > OUTPUT.$test_count
test_expect_equal_file EXPECTED.$test_count OUTPUT.$test_count

test_begin_subtest 'format=sup, restore=auto'
    notmuch dump --format=sup > EXPECTED.$test_count
    notmuch tag -inbox -unread "*"
    notmuch restore --format=auto < EXPECTED.$test_count
    notmuch dump --format=sup > OUTPUT.$test_count
test_expect_equal_file EXPECTED.$test_count OUTPUT.$test_count

test_begin_subtest 'format=batch-tag, restore=default'
    notmuch dump --format=batch-tag > EXPECTED.$test_count
    notmuch tag -inbox -unread "*"
    notmuch restore < EXPECTED.$test_count
    notmuch dump --format=batch-tag > OUTPUT.$test_count
test_expect_equal_file EXPECTED.$test_count OUTPUT.$test_count

test_begin_subtest 'format=sup, restore=default'
    notmuch dump --format=sup > EXPECTED.$test_count
    notmuch tag -inbox -unread "*"
    notmuch restore < EXPECTED.$test_count
    notmuch dump --format=sup > OUTPUT.$test_count
test_expect_equal_file EXPECTED.$test_count OUTPUT.$test_count

notmuch dump --format=batch-tag --output=save.tags

test_expect_success 'roundtripping random message-ids and tags' \
    '${TEST_DIRECTORY}/random-corpus --num-messages=100 --config-path=${NOTMUCH_CONFIG} &&
     notmuch dump --format=batch-tag | sort > EXPECTED.$test_count &&
     notmuch tag -random-corpus tag:random-corpus &&
     notmuch restore --format=batch-tag --input=EXPECTED.$test_count &&
     notmuch dump --format=batch-tag | sort > OUTPUT.$test_count &&
     test_cmp EXPECTED.$test_count OUTPUT.$test_count'
test_done

# Note the database is "poisoned" for sup format at this point.

debug log:

solving 7b67d03 ...
found 7b67d03 in https://yhetil.org/notmuch/1353265498-3839-14-git-send-email-david@tethera.net/
found e08b656 in https://yhetil.org/notmuch/1353265498-3839-13-git-send-email-david@tethera.net/ ||
	https://yhetil.org/notmuch/1353792017-31459-15-git-send-email-david@tethera.net/
found a2204fb in https://yhetil.org/notmuch/1353265498-3839-7-git-send-email-david@tethera.net/ ||
	https://yhetil.org/notmuch/1353792017-31459-7-git-send-email-david@tethera.net/
found b05399c in https://yhetil.org/notmuch.git/
preparing index
index prepared:
100755 b05399ca4c0d70c07416a52296d6a7a8eb745324	test/dump-restore

applying [1/3] https://yhetil.org/notmuch/1353265498-3839-7-git-send-email-david@tethera.net/
diff --git a/test/dump-restore b/test/dump-restore
index b05399c..a2204fb 100755

Checking patch test/dump-restore...
Applied patch test/dump-restore cleanly.

skipping https://yhetil.org/notmuch/1353792017-31459-7-git-send-email-david@tethera.net/ for a2204fb
index at:
100755 a2204fb7c966f8d8cedb7ef52a40c0cceaa1b5ee	test/dump-restore

applying [2/3] https://yhetil.org/notmuch/1353265498-3839-13-git-send-email-david@tethera.net/
diff --git a/test/dump-restore b/test/dump-restore
index a2204fb..e08b656 100755

Checking patch test/dump-restore...
Applied patch test/dump-restore cleanly.

skipping https://yhetil.org/notmuch/1353792017-31459-15-git-send-email-david@tethera.net/ for e08b656
index at:
100755 e08b656cf4d96fb7aad5401cbc7b1d37c328da1b	test/dump-restore

applying [3/3] https://yhetil.org/notmuch/1353265498-3839-14-git-send-email-david@tethera.net/
diff --git a/test/dump-restore b/test/dump-restore
index e08b656..7b67d03 100755

Checking patch test/dump-restore...
Applied patch test/dump-restore cleanly.

index at:
100755 7b67d03ca95d8df94146ae4ab96ef5429110aafd	test/dump-restore

(*) Git path names are given by the tree(s) the blob belongs to.
    Blobs themselves have no identifier aside from the hash of its contents.^

Code repositories for project(s) associated with this public inbox

	https://yhetil.org/notmuch.git/

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).