Skip to content

Commit

Permalink
test: adds test case to check the cached
Browse files Browse the repository at this point in the history
  • Loading branch information
tkzt committed Nov 30, 2023
1 parent 829b12c commit 291fce2
Showing 1 changed file with 29 additions and 13 deletions.
42 changes: 29 additions & 13 deletions tests/test_backend.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import socket
from ssl import SSLError
import tempfile
from unittest import mock
import pytest

from pathlib import Path
Expand Down Expand Up @@ -343,21 +344,36 @@ def test_email_tls_attempts_starttls(self):
pass

def test_email_ssl_attempts_ssl_connection(self):
with SmtpdContext(self.app.extensions['mailman']):
_, tmpKey = tempfile.mkstemp()
_, tmpCert = tempfile.mkstemp()
self.app.extensions['mailman'].use_ssl = True
self.app.extensions['mailman'].ssl_keyfile = tmpKey
self.app.extensions['mailman'].ssl_certfile = tmpCert
with tempfile.NamedTemporaryFile() as tmpFile:
with SmtpdContext(self.app.extensions['mailman']):
self.app.extensions['mailman'].use_ssl = True
self.app.extensions['mailman'].ssl_keyfile = tmpFile.name
self.app.extensions['mailman'].ssl_certfile = tmpFile.name

backend = smtp.EmailBackend()
self.assertTrue(backend.use_ssl)
with self.assertRaises(SSLError):
with backend:
pass
backend = smtp.EmailBackend()
self.assertTrue(backend.use_ssl)
with self.assertRaises(SSLError):
with backend:
pass

@mock.patch("ssl.SSLContext.load_cert_chain", return_value="")
def test_email_ssl_cached_context(self, result_mocked):
with tempfile.NamedTemporaryFile() as tmpFile:
with SmtpdContext(self.app.extensions['mailman']):
self.app.extensions['mailman'].use_ssl = True

backend_one = smtp.EmailBackend()
backend_another = smtp.EmailBackend()

self.assertTrue(backend_one.ssl_context, backend_another.ssl_context)

self.app.extensions['mailman'].ssl_keyfile = tmpFile.name
self.app.extensions['mailman'].ssl_certfile = tmpFile.name

backend_one = smtp.EmailBackend()
backend_another = smtp.EmailBackend()

Path(tmpKey).unlink()
Path(tmpCert).unlink()
self.assertTrue(backend_one.ssl_context, backend_another.ssl_context)

def test_connection_timeout_default(self):
"""The connection's timeout value is None by default."""
Expand Down

0 comments on commit 291fce2

Please sign in to comment.