unofficial mirror of notmuch@notmuchmail.org
 help / color / mirror / code / Atom feed
blob 1789a8be54adb19d12a188a4c8555301b3c8c215 1653 bytes (raw)
name: test/T355-smime.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
 
#!/usr/bin/env bash

test_description='S/MIME signature verification and decryption'
. ./test-lib.sh

test_require_external_prereq openssl

test_begin_subtest "Generate CA Cert"
openssl genpkey -algorithm RSA -out ca.key -pass pass:test -des3 1024
openssl req -new -x509 -key ca.key -passin pass:test \
	-config $TEST_DIRECTORY/smime/openssl-ca-req.conf -out ca.crt
test_expect_equal "$(openssl verify ca.crt | tail -1)" "OK"

test_begin_subtest "Generate User Cert"
openssl genpkey -algorithm RSA  -out smime.key 1024
openssl req -config $TEST_DIRECTORY/smime/openssl-req.conf \
	-new -key smime.key -passin pass:test -nodes \
	-out smime.csr
openssl x509 -req -in smime.csr -passin pass:test -CA ca.crt -CAkey ca.key -set_serial 1 -out test_suite.crt -setalias "Self Signed SMIME" -addtrust emailProtection -addreject clientAuth -addreject serverAuth -trustout
# we need one file with the cert and private key
cat test_suite.crt smime.key > test_suite.pem
test_expect_equal "$(openssl verify -purpose smimesign -CAfile ca.crt test_suite.pem)" "test_suite.pem: OK"

test_expect_success 'emacs delivery of S/MIME signed message' \
     'emacs_fcc_message \
     "test signed message 001" \
     "This is a test signed message." \
     "(mml-secure-message-sign \"smime\")"'

test_begin_subtest "Signature verification (openssl)"
notmuch show --format=raw subject:"test signed message 001" |\
    openssl smime -verify -CAfile ca.crt 1>STDOUT 2>STDERR
cat <<EOF > EXPECTED
Verification successful
Content-Type: text/plain

This is a test signed message.
EOF
tr -d '\015' < STDOUT | cat STDERR - > OUTPUT
test_expect_equal_file OUTPUT EXPECTED

test_done

debug log:

solving 1789a8b ...
found 1789a8b in https://yhetil.org/notmuch/1421530691-14060-1-git-send-email-david@tethera.net/

applying [1/1] https://yhetil.org/notmuch/1421530691-14060-1-git-send-email-david@tethera.net/
diff --git a/test/T355-smime.sh b/test/T355-smime.sh
new file mode 100755
index 0000000..1789a8b

Checking patch test/T355-smime.sh...
Applied patch test/T355-smime.sh cleanly.

index at:
100755 1789a8be54adb19d12a188a4c8555301b3c8c215	test/T355-smime.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).