unofficial mirror of notmuch@notmuchmail.org
 help / color / mirror / code / Atom feed
blob 3d18f5afb7f864a9bc4ff4a2a8f6f8a97fa0089d 4431 bytes (raw)
name: test/T357-index-decryption.sh 	 # 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
 
#!/usr/bin/env bash

# TODO: test index-decryption-failed

test_description='indexing decrypted mail'
. ./test-lib.sh || exit 1

##################################################

add_gnupg_home
# get key fingerprint
FINGERPRINT=$(gpg --no-tty --list-secret-keys --with-colons --fingerprint | grep '^fpr:' | cut -d: -f10)

# create a test encrypted message
test_begin_subtest 'emacs delivery of encrypted message'
test_expect_success \
'emacs_fcc_message \
    "test encrypted message for cleartext index 001" \
    "This is a test encrypted message with a wumpus.\n" \
    "(mml-secure-message-encrypt)"'

test_begin_subtest "search for unindexed cleartext"
output=$(notmuch search wumpus)
expected=''
test_expect_equal \
    "$output" \
    "$expected"

# create a test encrypted message that is indexed in the clear
test_begin_subtest 'emacs delivery of encrypted message'
test_expect_success \
'emacs_fcc_message --try-decrypt=true \
    "test encrypted message for cleartext index 002" \
    "This is a test encrypted message with a wumpus.\n" \
    "(mml-secure-message-encrypt)"'

test_begin_subtest "emacs delivery of encrypted message, indexed cleartext"
output=$(notmuch search wumpus)
expected='thread:0000000000000002   2000-01-01 [1/1] Notmuch Test Suite; test encrypted message for cleartext index 002 (encrypted inbox)'
test_expect_equal \
    "$output" \
    "$expected"

# and the same search, but by property ($expected is untouched):
test_begin_subtest "emacs search by property for one message"
output=$(notmuch search property:index-decryption=success)
test_expect_equal \
    "$output" \
    "$expected"

# add a tag to all messages to ensure that it stays after reindexing
test_begin_subtest 'tagging all messages'
test_expect_success 'notmuch tag +blarney "encrypted message"'
test_begin_subtest "verify that tags have not changed"
output=$(notmuch search tag:blarney)
expected='thread:0000000000000001   2000-01-01 [1/1] Notmuch Test Suite; test encrypted message for cleartext index 001 (blarney encrypted inbox)
thread:0000000000000002   2000-01-01 [1/1] Notmuch Test Suite; test encrypted message for cleartext index 002 (blarney encrypted inbox)'
test_expect_equal \
    "$output" \
    "$expected"

# see if first message shows up after reindexing with --try-decrypt=true (same $expected, untouched):
test_begin_subtest 'reindex old messages'
test_expect_success 'notmuch reindex --try-decrypt=true tag:encrypted and not property:index-decryption=success'
test_begin_subtest "reindexed encrypted message, including cleartext"
output=$(notmuch search wumpus)
test_expect_equal \
    "$output" \
    "$expected"

# and the same search, but by property ($expected is untouched):
test_begin_subtest "emacs search by property for both messages"
output=$(notmuch search property:index-decryption=success)
test_expect_equal \
    "$output" \
    "$expected"


# try to remove cleartext indexing
test_begin_subtest 'reindex without cleartext'
test_expect_success 'notmuch reindex tag:encrypted and property:index-decryption=success'
test_begin_subtest "reindexed encrypted messages, without cleartext"
output=$(notmuch search wumpus)
expected=''
test_expect_equal \
    "$output" \
    "$expected"

# and the same search, but by property ($expected is untouched):
test_begin_subtest "emacs search by property with both messages unindexed"
output=$(notmuch search property:index-decryption=success)
test_expect_equal \
    "$output" \
    "$expected"

# ensure that the tags remain even when we are dropping the cleartext.
test_begin_subtest "verify that tags remain without cleartext"
output=$(notmuch search tag:blarney)
expected='thread:0000000000000001   2000-01-01 [1/1] Notmuch Test Suite; test encrypted message for cleartext index 001 (blarney encrypted inbox)
thread:0000000000000002   2000-01-01 [1/1] Notmuch Test Suite; test encrypted message for cleartext index 002 (blarney encrypted inbox)'
test_expect_equal \
    "$output" \
    "$expected"


# TODO: test removal of a message from the message store between
# indexing and reindexing.

# TODO: insert the same message into the message store twice, index,
# remove one of them from the message store, and then reindex.
# reindexing should return a failure but the message should still be
# present? -- or what should the semantics be if you ask to reindex a
# message whose underlying files have been renamed or moved or
# removed?

test_done

debug log:

solving 3d18f5af ...
found 3d18f5af in https://yhetil.org/notmuch/20171010054916.23925-16-dkg@fifthhorseman.net/ ||
	https://yhetil.org/notmuch/20170915055359.24123-11-dkg@fifthhorseman.net/ ||
	https://yhetil.org/notmuch/20170912230153.4175-10-dkg@fifthhorseman.net/
found 7bbd81f6 in https://yhetil.org/notmuch/20171010054916.23925-14-dkg@fifthhorseman.net/ ||
	https://yhetil.org/notmuch/20170915055359.24123-9-dkg@fifthhorseman.net/ ||
	https://yhetil.org/notmuch/20170912230153.4175-8-dkg@fifthhorseman.net/

applying [1/2] https://yhetil.org/notmuch/20171010054916.23925-14-dkg@fifthhorseman.net/
diff --git a/test/T357-index-decryption.sh b/test/T357-index-decryption.sh
new file mode 100755
index 00000000..7bbd81f6

Checking patch test/T357-index-decryption.sh...
Applied patch test/T357-index-decryption.sh cleanly.

skipping https://yhetil.org/notmuch/20170915055359.24123-9-dkg@fifthhorseman.net/ for 7bbd81f6
skipping https://yhetil.org/notmuch/20170912230153.4175-8-dkg@fifthhorseman.net/ for 7bbd81f6
index at:
100755 7bbd81f6ef2daea0739fd722523210a745a847c1	test/T357-index-decryption.sh

applying [2/2] https://yhetil.org/notmuch/20171010054916.23925-16-dkg@fifthhorseman.net/
diff --git a/test/T357-index-decryption.sh b/test/T357-index-decryption.sh
index 7bbd81f6..3d18f5af 100755

Checking patch test/T357-index-decryption.sh...
Applied patch test/T357-index-decryption.sh cleanly.

skipping https://yhetil.org/notmuch/20170915055359.24123-11-dkg@fifthhorseman.net/ for 3d18f5af
skipping https://yhetil.org/notmuch/20170912230153.4175-10-dkg@fifthhorseman.net/ for 3d18f5af
index at:
100755 3d18f5afb7f864a9bc4ff4a2a8f6f8a97fa0089d	test/T357-index-decryption.sh

(*) 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).