mailinabox/test/test_mail.py

206 lines
5.3 KiB
Python
Raw Normal View History

2016-12-11 15:00:04 +00:00
from time import sleep
import requests
import os
import pytest
import imaplib
import poplib
import smtplib
from email.mime.text import MIMEText
from settings import *
2016-12-15 22:50:08 +00:00
from common import random_id
2016-12-11 15:00:04 +00:00
def new_message(from_email, to_email):
"""Creates an email (headers & body) with a random subject"""
msg = MIMEText('Testing')
2016-12-15 22:50:08 +00:00
msg['Subject'] = random_id()
2016-12-11 15:00:04 +00:00
msg['From'] = from_email
msg['To'] = to_email
return msg.as_string(), msg['subject']
2016-12-11 15:00:04 +00:00
def check_imap_received(subject):
2016-12-11 15:00:04 +00:00
"""Connects with IMAP and asserts the existence of an email, then deletes it"""
sleep(3)
# Login to IMAP
m = imaplib.IMAP4_SSL(TEST_DOMAIN, 993)
m.login(TEST_ADDRESS, TEST_PASSWORD)
m.select()
# check the message exists
2016-12-11 15:00:04 +00:00
typ, data = m.search(None, '(SUBJECT \"{}\")'.format(subject))
res = len(data[0].split()) == 1
if res:
m.store(data[0].strip(), '+FLAGS', '\\Deleted')
m.expunge()
2016-12-11 15:00:04 +00:00
m.close()
m.logout()
return res
2016-12-11 15:00:04 +00:00
def assert_pop3_received(subject):
"""Connects with POP3S and asserts the existence of an email, then deletes it"""
sleep(3)
# Login to POP3
mail = poplib.POP3_SSL(TEST_DOMAIN, 995)
mail.user(TEST_ADDRESS)
mail.pass_(TEST_PASSWORD)
# Assert the message exists
num = len(mail.list()[1])
resp, text, octets = mail.retr(num)
assert "Subject: " + subject in text
# Delete it and log out
mail.dele(num)
mail.quit()
def test_imap_requires_ssl():
"""IMAP without SSL is NOT available"""
with pytest.raises(socket.timeout):
imaplib.IMAP4(TEST_DOMAIN, 143)
def test_pop3_requires_ssl():
"""POP3 without SSL is NOT available"""
with pytest.raises(socket.timeout):
poplib.POP3(TEST_DOMAIN, 110)
def test_smtps():
"""Email sent from an MUA via SMTPS is delivered"""
msg, subject = new_message(TEST_ADDRESS, TEST_ADDRESS)
s = smtplib.SMTP(TEST_DOMAIN, 587)
s.starttls()
s.login(TEST_ADDRESS, TEST_PASSWORD)
s.sendmail(TEST_ADDRESS, [TEST_ADDRESS], msg)
s.quit()
assert check_imap_received(subject)
2016-12-11 15:00:04 +00:00
def test_smtps_tag():
"""Email sent to address with tag is delivered"""
mail_address = TEST_ADDRESS.replace("@", "+sometag@")
msg, subject = new_message(TEST_ADDRESS, mail_address)
s = smtplib.SMTP(TEST_DOMAIN, 587)
s.starttls()
s.login(TEST_ADDRESS, TEST_PASSWORD)
s.sendmail(TEST_ADDRESS, [mail_address], msg)
s.quit()
assert check_imap_received(subject)
2016-12-11 15:00:04 +00:00
def test_smtps_requires_auth():
"""SMTPS with no authentication is rejected"""
import smtplib
s = smtplib.SMTP(TEST_DOMAIN, 587)
s.starttls()
#FIXME why does this work without login?
with pytest.raises(smtplib.SMTPRecipientsRefused):
s.sendmail(TEST_ADDRESS, [TEST_ADDRESS], 'Test')
s.quit()
def test_smtp():
"""Email sent from an MTA is delivered"""
import smtplib
msg, subject = new_message(TEST_SENDER, TEST_ADDRESS)
s = smtplib.SMTP(TEST_DOMAIN, 25)
s.sendmail(TEST_SENDER, [TEST_ADDRESS], msg)
s.quit()
assert check_imap_received(subject)
2016-12-11 15:00:04 +00:00
def test_smtp_tls():
"""Email sent from an MTA via SMTP+TLS is delivered"""
msg, subject = new_message(TEST_SENDER, TEST_ADDRESS)
s = smtplib.SMTP(TEST_DOMAIN, 25)
s.starttls()
s.sendmail(TEST_SENDER, [TEST_ADDRESS], msg)
s.quit()
assert check_imap_received(subject)
2016-12-11 15:00:04 +00:00
# FIXME
#def test_smtps_headers():
# """Email sent from an MUA has DKIM and TLS headers"""
# import smtplib
# import imaplib
#
# # Send a message to admin
# mail_address = "admin@" + TEST_DOMAIN
# msg, subject = new_message(TEST_ADDRESS, mail_address)
# s = smtplib.SMTP(TEST_DOMAIN, 587)
# s.starttls()
# s.login(TEST_ADDRESS, TEST_PASSWORD)
# s.sendmail(TEST_ADDRESS, [mail_address], msg)
# s.quit()
#
# sleep(3)
#
# # Get the message
# m = imaplib.IMAP4_SSL(TEST_DOMAIN, 993)
# m.login(TEST_ADDRESS, TEST_PASSWORD)
# m.select()
# _, res = m.search(None, '(SUBJECT \"{}\")'.format(subject))
# _, data = m.fetch(res[0], '(RFC822)')
#
# assert 'DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=mailinabox.lan;' in data[0][1]
#
# assert 'ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)' in data[0][1]
#
# # Clean up
# m.store(res[0].strip(), '+FLAGS', '\\Deleted')
# m.expunge()
# m.close()
# m.logout()
def test_smtp_headers():
"""Email sent from an MTA via SMTP+TLS has TLS headers"""
# Send a message to root
msg, subject = new_message(TEST_SENDER, TEST_ADDRESS)
s = smtplib.SMTP(TEST_DOMAIN, 25)
s.starttls()
s.sendmail(TEST_SENDER, [TEST_ADDRESS], msg)
s.quit()
sleep(3)
# Get the message
m = imaplib.IMAP4_SSL(TEST_DOMAIN, 993)
m.login(TEST_ADDRESS, TEST_PASSWORD)
m.select()
_, res = m.search(None, '(SUBJECT \"{}\")'.format(subject))
_, data = m.fetch(res[0], '(RFC822)')
assert 'ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)' in data[0][1]
# Clean up
m.store(res[0].strip(), '+FLAGS', '\\Deleted')
m.expunge()
m.close()
m.logout()
def test_pop3s():
"""Connects with POP3S and asserts the existance of an email"""
2016-12-11 15:00:04 +00:00
msg, subject = new_message(TEST_ADDRESS, TEST_ADDRESS)
s = smtplib.SMTP(TEST_DOMAIN, 587)
s.starttls()
s.login(TEST_ADDRESS, TEST_PASSWORD)
s.sendmail(TEST_ADDRESS, [TEST_ADDRESS], msg)
s.quit()
assert_pop3_received(subject)