diff options
author | maxim-yurchuk <[email protected]> | 2024-10-09 12:29:46 +0300 |
---|---|---|
committer | maxim-yurchuk <[email protected]> | 2024-10-09 13:14:22 +0300 |
commit | 9731d8a4bb7ee2cc8554eaf133bb85498a4c7d80 (patch) | |
tree | a8fb3181d5947c0d78cf402aa56e686130179049 /contrib/python/pytest-localserver/py3/tests/test_smtp.py | |
parent | a44b779cd359f06c3ebbef4ec98c6b38609d9d85 (diff) |
publishFullContrib: true for ydb
<HIDDEN_URL>
commit_hash:c82a80ac4594723cebf2c7387dec9c60217f603e
Diffstat (limited to 'contrib/python/pytest-localserver/py3/tests/test_smtp.py')
-rw-r--r-- | contrib/python/pytest-localserver/py3/tests/test_smtp.py | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/contrib/python/pytest-localserver/py3/tests/test_smtp.py b/contrib/python/pytest-localserver/py3/tests/test_smtp.py new file mode 100644 index 00000000000..7fc3882819d --- /dev/null +++ b/contrib/python/pytest-localserver/py3/tests/test_smtp.py @@ -0,0 +1,102 @@ +import smtplib + +import pytest + +try: # python 3 + from email.mime.text import MIMEText +except ImportError: # python 2? + from email.MIMEText import MIMEText + +from pytest_localserver import plugin + + +smtp = pytest.importorskip("pytest_localserver.smtp") + + +def send_plain_email(to, from_, subject, txt, server=("localhost", 25)): + """ + Sends a simple plain text message via SMTP. + """ + if type(to) in (tuple, list): + to = ", ".join(to) + + # Create a text/plain message + msg = MIMEText(txt) + msg["Subject"] = subject + msg["From"] = from_ + msg["To"] = to + + host, port = server[:2] + server = smtplib.SMTP(host, port) + server.set_debuglevel(1) + server.sendmail(from_, to, msg.as_string()) + server.quit() + + +# define test fixture here again in order to run tests without having to +# install the plugin anew every single time +smtpserver = plugin.smtpserver + + +def test_smtpserver_funcarg(smtpserver): + assert isinstance(smtpserver, smtp.Server) + assert smtpserver.is_alive() + assert smtpserver.accepting and smtpserver.addr + + +def test_smtpserver_addr(smtpserver): + host, port = smtpserver.addr + assert isinstance(host, str) + assert isinstance(port, int) + assert port > 0 + + +def test_server_is_killed(smtpserver): + assert smtpserver.is_alive() + smtpserver.stop() + assert not smtpserver.is_alive() + + +def test_server_is_deleted(smtpserver): + assert smtpserver.is_alive() + smtpserver.__del__() # need to call magic method here! + assert not smtpserver.is_alive() + + +def test_smtpserver_has_empty_outbox_at_startup(smtpserver): + assert len(smtpserver.outbox) == 0 + + +def test_send_email(smtpserver): + # send one e-mail + send_plain_email( + "[email protected]", + "[email protected]", + "Your e-mail is getting there", + "Seems like this test actually works!", + smtpserver.addr, + ) + msg = smtpserver.outbox[-1] + assert msg["To"] == "[email protected]" + assert msg["From"] == "[email protected]" + assert msg["Subject"] == "Your e-mail is getting there" + assert msg.details.rcpttos == ["[email protected]"] + assert msg.details.peer + assert msg.details.mailfrom + + # send another e-mail + send_plain_email( + "[email protected]", + "[email protected]", + "His e-mail too", + "Seems like this test actually works!", + smtpserver.addr, + ) + + msg = smtpserver.outbox[-1] + assert msg["To"] == "[email protected]" + assert msg["From"] == "[email protected]" + assert msg["Subject"] == "His e-mail too" + + # two mails are now in outbox + assert len(smtpserver.outbox) == 2 |