2011-05-25 18:01:16 -07:00
|
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
|
|
# TODO:
|
|
|
|
|
# - decryption/verification with signer key not available
|
|
|
|
|
# - verification of signatures from expired/revoked keys
|
|
|
|
|
|
|
|
|
|
test_description='PGP/MIME signature verification and decryption'
|
|
|
|
|
. ./test-lib.sh
|
|
|
|
|
|
|
|
|
|
add_gnupg_home ()
|
|
|
|
|
{
|
|
|
|
|
local output
|
|
|
|
|
[ -d ${GNUPGHOME} ] && return
|
|
|
|
|
mkdir -m 0700 "$GNUPGHOME"
|
2011-06-28 16:11:32 -06:00
|
|
|
|
gpg --no-tty --import <$TEST_DIRECTORY/gnupg-secret-key.asc >"$GNUPGHOME"/import.log 2>&1
|
2011-05-25 18:01:16 -07:00
|
|
|
|
test_debug "cat $GNUPGHOME/import.log"
|
|
|
|
|
if (gpg --quick-random --version >/dev/null 2>&1) ; then
|
|
|
|
|
echo quick-random >> "$GNUPGHOME"/gpg.conf
|
|
|
|
|
elif (gpg --debug-quick-random --version >/dev/null 2>&1) ; then
|
|
|
|
|
echo debug-quick-random >> "$GNUPGHOME"/gpg.conf
|
|
|
|
|
fi
|
2013-11-27 11:35:46 -04:00
|
|
|
|
echo no-emit-version >> "$GNUPGHOME"/gpg.conf
|
2011-05-25 18:01:16 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
##################################################
|
|
|
|
|
|
|
|
|
|
add_gnupg_home
|
|
|
|
|
# get key fingerprint
|
|
|
|
|
FINGERPRINT=$(gpg --no-tty --list-secret-keys --with-colons --fingerprint | grep '^fpr:' | cut -d: -f10)
|
|
|
|
|
|
|
|
|
|
test_expect_success 'emacs delivery of signed message' \
|
2013-12-14 22:39:54 +08:00
|
|
|
|
'emacs_fcc_message \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"test signed message 001" \
|
|
|
|
|
"This is a test signed message." \
|
|
|
|
|
"(mml-secure-message-sign)"'
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "signature verification"
|
|
|
|
|
output=$(notmuch show --format=json --verify subject:"test signed message 001" \
|
|
|
|
|
| notmuch_json_show_sanitize \
|
|
|
|
|
| sed -e 's|"created": [1234567890]*|"created": 946728000|')
|
|
|
|
|
expected='[[[{"id": "XXXXX",
|
|
|
|
|
"match": true,
|
2012-03-01 22:30:41 +00:00
|
|
|
|
"excluded": false,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"filename": "YYYYY",
|
|
|
|
|
"timestamp": 946728000,
|
|
|
|
|
"date_relative": "2000-01-01",
|
2011-05-25 18:01:20 -07:00
|
|
|
|
"tags": ["inbox","signed"],
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"headers": {"Subject": "test signed message 001",
|
|
|
|
|
"From": "Notmuch Test Suite <test_suite@notmuchmail.org>",
|
|
|
|
|
"To": "test_suite@notmuchmail.org",
|
2012-08-02 21:14:47 -04:00
|
|
|
|
"Date": "Sat, 01 Jan 2000 12:00:00 +0000"},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"body": [{"id": 1,
|
|
|
|
|
"sigstatus": [{"status": "good",
|
|
|
|
|
"fingerprint": "'$FINGERPRINT'",
|
|
|
|
|
"created": 946728000}],
|
2011-05-27 03:27:36 -07:00
|
|
|
|
"content-type": "multipart/signed",
|
|
|
|
|
"content": [{"id": 2,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"content-type": "text/plain",
|
2011-05-27 03:27:36 -07:00
|
|
|
|
"content": "This is a test signed message.\n"},
|
|
|
|
|
{"id": 3,
|
2012-12-15 14:06:45 +11:00
|
|
|
|
"content-type": "application/pgp-signature",
|
2013-11-27 11:35:46 -04:00
|
|
|
|
"content-length": 280}]}]},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
[]]]]'
|
2012-08-02 21:14:47 -04:00
|
|
|
|
test_expect_equal_json \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"$output" \
|
|
|
|
|
"$expected"
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "signature verification with full owner trust"
|
|
|
|
|
# give the key full owner trust
|
|
|
|
|
echo "${FINGERPRINT}:6:" | gpg --no-tty --import-ownertrust >>"$GNUPGHOME"/trust.log 2>&1
|
|
|
|
|
gpg --no-tty --check-trustdb >>"$GNUPGHOME"/trust.log 2>&1
|
|
|
|
|
output=$(notmuch show --format=json --verify subject:"test signed message 001" \
|
|
|
|
|
| notmuch_json_show_sanitize \
|
|
|
|
|
| sed -e 's|"created": [1234567890]*|"created": 946728000|')
|
|
|
|
|
expected='[[[{"id": "XXXXX",
|
|
|
|
|
"match": true,
|
2012-03-01 22:30:41 +00:00
|
|
|
|
"excluded": false,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"filename": "YYYYY",
|
|
|
|
|
"timestamp": 946728000,
|
|
|
|
|
"date_relative": "2000-01-01",
|
2011-05-25 18:01:20 -07:00
|
|
|
|
"tags": ["inbox","signed"],
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"headers": {"Subject": "test signed message 001",
|
|
|
|
|
"From": "Notmuch Test Suite <test_suite@notmuchmail.org>",
|
|
|
|
|
"To": "test_suite@notmuchmail.org",
|
2012-08-02 21:14:47 -04:00
|
|
|
|
"Date": "Sat, 01 Jan 2000 12:00:00 +0000"},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"body": [{"id": 1,
|
|
|
|
|
"sigstatus": [{"status": "good",
|
|
|
|
|
"fingerprint": "'$FINGERPRINT'",
|
|
|
|
|
"created": 946728000,
|
|
|
|
|
"userid": " Notmuch Test Suite <test_suite@notmuchmail.org> (INSECURE!)"}],
|
2011-05-27 03:27:36 -07:00
|
|
|
|
"content-type": "multipart/signed",
|
|
|
|
|
"content": [{"id": 2,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"content-type": "text/plain",
|
2011-05-27 03:27:36 -07:00
|
|
|
|
"content": "This is a test signed message.\n"},
|
|
|
|
|
{"id": 3,
|
2012-12-15 14:06:45 +11:00
|
|
|
|
"content-type": "application/pgp-signature",
|
2013-11-27 11:35:46 -04:00
|
|
|
|
"content-length": 280}]}]},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
[]]]]'
|
2012-08-02 21:14:47 -04:00
|
|
|
|
test_expect_equal_json \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"$output" \
|
|
|
|
|
"$expected"
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "signature verification with signer key unavailable"
|
|
|
|
|
# move the gnupghome temporarily out of the way
|
|
|
|
|
mv "${GNUPGHOME}"{,.bak}
|
|
|
|
|
output=$(notmuch show --format=json --verify subject:"test signed message 001" \
|
|
|
|
|
| notmuch_json_show_sanitize \
|
|
|
|
|
| sed -e 's|"created": [1234567890]*|"created": 946728000|')
|
|
|
|
|
expected='[[[{"id": "XXXXX",
|
|
|
|
|
"match": true,
|
2012-03-01 22:30:41 +00:00
|
|
|
|
"excluded": false,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"filename": "YYYYY",
|
|
|
|
|
"timestamp": 946728000,
|
|
|
|
|
"date_relative": "2000-01-01",
|
2011-05-25 18:01:20 -07:00
|
|
|
|
"tags": ["inbox","signed"],
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"headers": {"Subject": "test signed message 001",
|
|
|
|
|
"From": "Notmuch Test Suite <test_suite@notmuchmail.org>",
|
|
|
|
|
"To": "test_suite@notmuchmail.org",
|
2012-08-02 21:14:47 -04:00
|
|
|
|
"Date": "Sat, 01 Jan 2000 12:00:00 +0000"},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"body": [{"id": 1,
|
|
|
|
|
"sigstatus": [{"status": "error",
|
|
|
|
|
"keyid": "'$(echo $FINGERPRINT | cut -c 25-)'",
|
|
|
|
|
"errors": 2}],
|
2011-05-27 03:27:36 -07:00
|
|
|
|
"content-type": "multipart/signed",
|
|
|
|
|
"content": [{"id": 2,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"content-type": "text/plain",
|
2011-05-27 03:27:36 -07:00
|
|
|
|
"content": "This is a test signed message.\n"},
|
|
|
|
|
{"id": 3,
|
2012-12-15 14:06:45 +11:00
|
|
|
|
"content-type": "application/pgp-signature",
|
2013-11-27 11:35:46 -04:00
|
|
|
|
"content-length": 280}]}]},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
[]]]]'
|
2012-08-02 21:14:47 -04:00
|
|
|
|
test_expect_equal_json \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"$output" \
|
|
|
|
|
"$expected"
|
|
|
|
|
mv "${GNUPGHOME}"{.bak,}
|
|
|
|
|
|
|
|
|
|
# create a test encrypted message with attachment
|
|
|
|
|
cat <<EOF >TESTATTACHMENT
|
|
|
|
|
This is a test file.
|
|
|
|
|
EOF
|
|
|
|
|
test_expect_success 'emacs delivery of encrypted message with attachment' \
|
2013-12-14 22:39:54 +08:00
|
|
|
|
'emacs_fcc_message \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"test encrypted message 001" \
|
|
|
|
|
"This is a test encrypted message.\n" \
|
|
|
|
|
"(mml-attach-file \"TESTATTACHMENT\") (mml-secure-message-encrypt)"'
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "decryption, --format=text"
|
|
|
|
|
output=$(notmuch show --format=text --decrypt subject:"test encrypted message 001" \
|
|
|
|
|
| notmuch_show_sanitize_all \
|
|
|
|
|
| sed -e 's|"created": [1234567890]*|"created": 946728000|')
|
2012-03-01 22:30:41 +00:00
|
|
|
|
expected='message{ id:XXXXX depth:0 match:1 excluded:0 filename:XXXXX
|
2011-05-25 18:01:16 -07:00
|
|
|
|
header{
|
2011-05-25 18:01:20 -07:00
|
|
|
|
Notmuch Test Suite <test_suite@notmuchmail.org> (2000-01-01) (encrypted inbox)
|
2011-05-25 18:01:16 -07:00
|
|
|
|
Subject: test encrypted message 001
|
|
|
|
|
From: Notmuch Test Suite <test_suite@notmuchmail.org>
|
|
|
|
|
To: test_suite@notmuchmail.org
|
2012-02-04 16:24:26 -05:00
|
|
|
|
Date: Sat, 01 Jan 2000 12:00:00 +0000
|
2011-05-25 18:01:16 -07:00
|
|
|
|
header}
|
|
|
|
|
body{
|
2011-05-27 03:27:37 -07:00
|
|
|
|
part{ ID: 1, Content-type: multipart/encrypted
|
|
|
|
|
part{ ID: 2, Content-type: application/pgp-encrypted
|
|
|
|
|
Non-text part: application/pgp-encrypted
|
|
|
|
|
part}
|
|
|
|
|
part{ ID: 3, Content-type: multipart/mixed
|
|
|
|
|
part{ ID: 4, Content-type: text/plain
|
2011-05-25 18:01:16 -07:00
|
|
|
|
This is a test encrypted message.
|
|
|
|
|
part}
|
2011-05-29 02:03:48 +04:00
|
|
|
|
attachment{ ID: 5, Filename: TESTATTACHMENT, Content-type: application/octet-stream
|
2011-05-25 18:01:16 -07:00
|
|
|
|
Non-text part: application/octet-stream
|
|
|
|
|
attachment}
|
|
|
|
|
part}
|
2011-05-27 03:27:37 -07:00
|
|
|
|
part}
|
2011-05-25 18:01:16 -07:00
|
|
|
|
body}
|
|
|
|
|
message}'
|
|
|
|
|
test_expect_equal \
|
|
|
|
|
"$output" \
|
|
|
|
|
"$expected"
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "decryption, --format=json"
|
|
|
|
|
output=$(notmuch show --format=json --decrypt subject:"test encrypted message 001" \
|
|
|
|
|
| notmuch_json_show_sanitize \
|
|
|
|
|
| sed -e 's|"created": [1234567890]*|"created": 946728000|')
|
|
|
|
|
expected='[[[{"id": "XXXXX",
|
|
|
|
|
"match": true,
|
2012-03-01 22:30:41 +00:00
|
|
|
|
"excluded": false,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"filename": "YYYYY",
|
|
|
|
|
"timestamp": 946728000,
|
|
|
|
|
"date_relative": "2000-01-01",
|
2011-05-25 18:01:20 -07:00
|
|
|
|
"tags": ["encrypted","inbox"],
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"headers": {"Subject": "test encrypted message 001",
|
|
|
|
|
"From": "Notmuch Test Suite <test_suite@notmuchmail.org>",
|
|
|
|
|
"To": "test_suite@notmuchmail.org",
|
2012-08-02 21:14:47 -04:00
|
|
|
|
"Date": "Sat, 01 Jan 2000 12:00:00 +0000"},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"body": [{"id": 1,
|
|
|
|
|
"encstatus": [{"status": "good"}],
|
|
|
|
|
"sigstatus": [],
|
2011-05-27 03:27:37 -07:00
|
|
|
|
"content-type": "multipart/encrypted",
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"content": [{"id": 2,
|
2012-12-15 14:06:45 +11:00
|
|
|
|
"content-type": "application/pgp-encrypted",
|
|
|
|
|
"content-length": 11},
|
2011-05-27 03:27:37 -07:00
|
|
|
|
{"id": 3,
|
|
|
|
|
"content-type": "multipart/mixed",
|
|
|
|
|
"content": [{"id": 4,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"content-type": "text/plain",
|
|
|
|
|
"content": "This is a test encrypted message.\n"},
|
2011-05-27 03:27:37 -07:00
|
|
|
|
{"id": 5,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"content-type": "application/octet-stream",
|
2012-12-15 14:06:45 +11:00
|
|
|
|
"content-length": 28,
|
|
|
|
|
"content-transfer-encoding": "base64",
|
2011-05-27 03:27:37 -07:00
|
|
|
|
"filename": "TESTATTACHMENT"}]}]}]},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
[]]]]'
|
2012-08-02 21:14:47 -04:00
|
|
|
|
test_expect_equal_json \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"$output" \
|
|
|
|
|
"$expected"
|
|
|
|
|
|
2011-05-27 03:27:37 -07:00
|
|
|
|
test_begin_subtest "decryption, --format=json, --part=4"
|
|
|
|
|
output=$(notmuch show --format=json --part=4 --decrypt subject:"test encrypted message 001" \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
| notmuch_json_show_sanitize \
|
|
|
|
|
| sed -e 's|"created": [1234567890]*|"created": 946728000|')
|
2011-05-27 03:27:37 -07:00
|
|
|
|
expected='{"id": 4,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"content-type": "text/plain",
|
|
|
|
|
"content": "This is a test encrypted message.\n"}'
|
2012-08-02 21:14:47 -04:00
|
|
|
|
test_expect_equal_json \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"$output" \
|
|
|
|
|
"$expected"
|
|
|
|
|
|
2011-05-27 03:27:37 -07:00
|
|
|
|
test_begin_subtest "decrypt attachment (--part=5 --format=raw)"
|
2011-05-25 18:01:16 -07:00
|
|
|
|
notmuch show \
|
|
|
|
|
--format=raw \
|
2011-05-27 03:27:37 -07:00
|
|
|
|
--part=5 \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
--decrypt \
|
|
|
|
|
subject:"test encrypted message 001" >OUTPUT
|
|
|
|
|
test_expect_equal_file OUTPUT TESTATTACHMENT
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "decryption failure with missing key"
|
|
|
|
|
mv "${GNUPGHOME}"{,.bak}
|
2012-12-15 14:06:45 +11:00
|
|
|
|
# The length of the encrypted attachment varies so must be normalized.
|
2011-05-25 18:01:16 -07:00
|
|
|
|
output=$(notmuch show --format=json --decrypt subject:"test encrypted message 001" \
|
|
|
|
|
| notmuch_json_show_sanitize \
|
2012-12-15 14:06:45 +11:00
|
|
|
|
| sed -e 's|"created": [1234567890]*|"created": 946728000|' \
|
|
|
|
|
| sed -e 's|"content-length": 6[1234567890]*|"content-length": 652|')
|
2011-05-25 18:01:16 -07:00
|
|
|
|
expected='[[[{"id": "XXXXX",
|
|
|
|
|
"match": true,
|
2012-03-01 22:30:41 +00:00
|
|
|
|
"excluded": false,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"filename": "YYYYY",
|
|
|
|
|
"timestamp": 946728000,
|
|
|
|
|
"date_relative": "2000-01-01",
|
2011-05-25 18:01:20 -07:00
|
|
|
|
"tags": ["encrypted","inbox"],
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"headers": {"Subject": "test encrypted message 001",
|
|
|
|
|
"From": "Notmuch Test Suite <test_suite@notmuchmail.org>",
|
|
|
|
|
"To": "test_suite@notmuchmail.org",
|
2012-08-02 21:14:47 -04:00
|
|
|
|
"Date": "Sat, 01 Jan 2000 12:00:00 +0000"},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"body": [{"id": 1,
|
|
|
|
|
"encstatus": [{"status": "bad"}],
|
|
|
|
|
"content-type": "multipart/encrypted",
|
|
|
|
|
"content": [{"id": 2,
|
2012-12-15 14:06:45 +11:00
|
|
|
|
"content-type": "application/pgp-encrypted",
|
|
|
|
|
"content-length": 11},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
{"id": 3,
|
2012-12-15 14:06:45 +11:00
|
|
|
|
"content-type": "application/octet-stream",
|
|
|
|
|
"content-length": 652}]}]},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
[]]]]'
|
2012-08-02 21:14:47 -04:00
|
|
|
|
test_expect_equal_json \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"$output" \
|
|
|
|
|
"$expected"
|
|
|
|
|
mv "${GNUPGHOME}"{.bak,}
|
|
|
|
|
|
|
|
|
|
test_expect_success 'emacs delivery of encrypted + signed message' \
|
2013-12-14 22:39:54 +08:00
|
|
|
|
'emacs_fcc_message \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"test encrypted message 002" \
|
|
|
|
|
"This is another test encrypted message.\n" \
|
|
|
|
|
"(mml-secure-message-sign-encrypt)"'
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "decryption + signature verification"
|
|
|
|
|
output=$(notmuch show --format=json --decrypt subject:"test encrypted message 002" \
|
|
|
|
|
| notmuch_json_show_sanitize \
|
|
|
|
|
| sed -e 's|"created": [1234567890]*|"created": 946728000|')
|
|
|
|
|
expected='[[[{"id": "XXXXX",
|
|
|
|
|
"match": true,
|
2012-03-01 22:30:41 +00:00
|
|
|
|
"excluded": false,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"filename": "YYYYY",
|
|
|
|
|
"timestamp": 946728000,
|
|
|
|
|
"date_relative": "2000-01-01",
|
2011-05-25 18:01:20 -07:00
|
|
|
|
"tags": ["encrypted","inbox"],
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"headers": {"Subject": "test encrypted message 002",
|
|
|
|
|
"From": "Notmuch Test Suite <test_suite@notmuchmail.org>",
|
|
|
|
|
"To": "test_suite@notmuchmail.org",
|
2012-08-02 21:14:47 -04:00
|
|
|
|
"Date": "Sat, 01 Jan 2000 12:00:00 +0000"},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"body": [{"id": 1,
|
|
|
|
|
"encstatus": [{"status": "good"}],
|
|
|
|
|
"sigstatus": [{"status": "good",
|
|
|
|
|
"fingerprint": "'$FINGERPRINT'",
|
|
|
|
|
"created": 946728000,
|
|
|
|
|
"userid": " Notmuch Test Suite <test_suite@notmuchmail.org> (INSECURE!)"}],
|
2011-05-27 03:27:37 -07:00
|
|
|
|
"content-type": "multipart/encrypted",
|
|
|
|
|
"content": [{"id": 2,
|
2012-12-15 14:06:45 +11:00
|
|
|
|
"content-type": "application/pgp-encrypted",
|
|
|
|
|
"content-length": 11},
|
2011-05-27 03:27:37 -07:00
|
|
|
|
{"id": 3,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"content-type": "text/plain",
|
2011-05-27 03:27:37 -07:00
|
|
|
|
"content": "This is another test encrypted message.\n"}]}]},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
[]]]]'
|
2012-08-02 21:14:47 -04:00
|
|
|
|
test_expect_equal_json \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"$output" \
|
|
|
|
|
"$expected"
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "reply to encrypted message"
|
|
|
|
|
output=$(notmuch reply --decrypt subject:"test encrypted message 002" \
|
|
|
|
|
| grep -v -e '^In-Reply-To:' -e '^References:')
|
|
|
|
|
expected='From: Notmuch Test Suite <test_suite@notmuchmail.org>
|
|
|
|
|
Subject: Re: test encrypted message 002
|
|
|
|
|
|
|
|
|
|
On 01 Jan 2000 12:00:00 -0000, Notmuch Test Suite <test_suite@notmuchmail.org> wrote:
|
|
|
|
|
> This is another test encrypted message.'
|
|
|
|
|
test_expect_equal \
|
|
|
|
|
"$output" \
|
|
|
|
|
"$expected"
|
|
|
|
|
|
|
|
|
|
test_begin_subtest "signature verification with revoked key"
|
2011-06-20 22:14:21 +02:00
|
|
|
|
# generate revocation certificate and load it to revoke key
|
2011-05-25 18:01:16 -07:00
|
|
|
|
echo "y
|
|
|
|
|
1
|
|
|
|
|
Notmuch Test Suite key revocation (automated) $(date '+%F_%T%z')
|
|
|
|
|
|
|
|
|
|
y
|
|
|
|
|
|
|
|
|
|
" \
|
|
|
|
|
| gpg --no-tty --quiet --command-fd 0 --armor --gen-revoke "0x${FINGERPRINT}!" 2>/dev/null \
|
|
|
|
|
| gpg --no-tty --quiet --import
|
|
|
|
|
output=$(notmuch show --format=json --verify subject:"test signed message 001" \
|
|
|
|
|
| notmuch_json_show_sanitize \
|
|
|
|
|
| sed -e 's|"created": [1234567890]*|"created": 946728000|')
|
|
|
|
|
expected='[[[{"id": "XXXXX",
|
|
|
|
|
"match": true,
|
2012-03-01 22:30:41 +00:00
|
|
|
|
"excluded": false,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"filename": "YYYYY",
|
|
|
|
|
"timestamp": 946728000,
|
|
|
|
|
"date_relative": "2000-01-01",
|
2011-05-25 18:01:20 -07:00
|
|
|
|
"tags": ["inbox","signed"],
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"headers": {"Subject": "test signed message 001",
|
|
|
|
|
"From": "Notmuch Test Suite <test_suite@notmuchmail.org>",
|
|
|
|
|
"To": "test_suite@notmuchmail.org",
|
2012-08-02 21:14:47 -04:00
|
|
|
|
"Date": "Sat, 01 Jan 2000 12:00:00 +0000"},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"body": [{"id": 1,
|
|
|
|
|
"sigstatus": [{"status": "error",
|
|
|
|
|
"keyid": "6D92612D94E46381",
|
|
|
|
|
"errors": 8}],
|
2011-05-27 03:27:36 -07:00
|
|
|
|
"content-type": "multipart/signed",
|
|
|
|
|
"content": [{"id": 2,
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"content-type": "text/plain",
|
2011-05-27 03:27:36 -07:00
|
|
|
|
"content": "This is a test signed message.\n"},
|
|
|
|
|
{"id": 3,
|
2012-12-15 14:06:45 +11:00
|
|
|
|
"content-type": "application/pgp-signature",
|
2013-11-27 11:35:46 -04:00
|
|
|
|
"content-length": 280}]}]},
|
2011-05-25 18:01:16 -07:00
|
|
|
|
[]]]]'
|
2012-08-02 21:14:47 -04:00
|
|
|
|
test_expect_equal_json \
|
2011-05-25 18:01:16 -07:00
|
|
|
|
"$output" \
|
|
|
|
|
"$expected"
|
|
|
|
|
|
|
|
|
|
test_done
|