diff options
| author | Guilhem Moulin <guilhem@fripost.org> | 2019-11-13 06:24:07 +0100 | 
|---|---|---|
| committer | Guilhem Moulin <guilhem@fripost.org> | 2019-11-13 06:24:07 +0100 | 
| commit | c6bbdd8aa697b2d42be1ac0839189da32d437a8f (patch) | |
| tree | cd1b8d19d99557fbebe33344d0d23f6ac826da57 /tests/tls-pin-fingerprint/t | |
| parent | 87d947df1b837514a0f1efa3bc36b58088bd2564 (diff) | |
| parent | dac4ab1c9306bf2035bc1547d2ed27ab09850120 (diff) | |
Merge branch 'master' into debian
Diffstat (limited to 'tests/tls-pin-fingerprint/t')
| -rw-r--r-- | tests/tls-pin-fingerprint/t | 33 | 
1 files changed, 33 insertions, 0 deletions
| diff --git a/tests/tls-pin-fingerprint/t b/tests/tls-pin-fingerprint/t new file mode 100644 index 0000000..1b84390 --- /dev/null +++ b/tests/tls-pin-fingerprint/t @@ -0,0 +1,33 @@ +# backup config +install -m0600 "$XDG_CONFIG_HOME/interimap/config" "$XDG_CONFIG_HOME/interimap/config~" +with_remote_config() { +    install -m0600 "$XDG_CONFIG_HOME/interimap/config~" "$XDG_CONFIG_HOME/interimap/config" +    cat >>"$XDG_CONFIG_HOME/interimap/config" +} + +# pinned valid fingerprint +with_remote_config <<-EOF +	SSL_fingerprint = sha256\$e8fc8d03ffe75e03897136a2f1c5647bf8c36be7136a6883a732a8c4961c1614 +EOF + +for ((i = 0; i < 32; i++)); do +    u="$(shuf -n1 -e "local" "remote")" +    sample_message | deliver -u "$u" +done +interimap_init +check_mailbox_status "INBOX" + + +# and now an invalid one +with_remote_config <<-EOF +	SSL_fingerprint = sha256\$deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef +EOF +! interimap --debug || error + +grep -Fx "remote: ERROR: Can't initiate TLS/SSL handshake" <"$STDERR" || error +grep -Fx "remote: WARNING: Fingerprint doesn't match! MiTM in action?" <"$STDERR" || error +grep -Fx "remote: ERROR: Can't initiate TLS/SSL handshake" <"$STDERR" || error +# make sure we didn't send any credentials +! grep -E "^remote: C: .* (AUTHENTICATE|LOGIN) " <"$STDERR" || error + +# vim: set filetype=sh : | 
