mirror of
https://github.com/caronc/apprise.git
synced 2025-01-22 13:59:03 +01:00
bulletproof added to socket handling of email; refs #15
This commit is contained in:
parent
96b2344bac
commit
83200d6e58
@ -253,6 +253,8 @@ class NotifyEmail(NotifyBase):
|
|||||||
.strftime("%a, %d %b %Y %H:%M:%S +0000")
|
.strftime("%a, %d %b %Y %H:%M:%S +0000")
|
||||||
email['X-Application'] = self.app_id
|
email['X-Application'] = self.app_id
|
||||||
|
|
||||||
|
# bind the socket variable to the current namespace
|
||||||
|
socket = None
|
||||||
try:
|
try:
|
||||||
self.logger.debug('Connecting to remote SMTP server...')
|
self.logger.debug('Connecting to remote SMTP server...')
|
||||||
socket = smtplib.SMTP(
|
socket = smtplib.SMTP(
|
||||||
@ -289,6 +291,7 @@ class NotifyEmail(NotifyBase):
|
|||||||
|
|
||||||
finally:
|
finally:
|
||||||
# Gracefully terminate the connection with the server
|
# Gracefully terminate the connection with the server
|
||||||
|
if socket is not None: # pragma: no branch
|
||||||
socket.quit()
|
socket.quit()
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
@ -290,3 +290,57 @@ def test_webbase_lookup(mock_smtp):
|
|||||||
assert obj.secure is True
|
assert obj.secure is True
|
||||||
assert obj.port == 123
|
assert obj.port == 123
|
||||||
assert obj.smtp_host == 'smtp.l2g.com'
|
assert obj.smtp_host == 'smtp.l2g.com'
|
||||||
|
|
||||||
|
@mock.patch('smtplib.SMTP')
|
||||||
|
def test_smtplib_init_fail(mock_smtplib):
|
||||||
|
"""
|
||||||
|
API: Test exception handling when calling smtplib.SMTP()
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
from apprise.plugins import NotifyEmailBase
|
||||||
|
|
||||||
|
obj = Apprise.instantiate(
|
||||||
|
'mailto://user:pass@gmail.com', suppress_exceptions=False)
|
||||||
|
assert(isinstance(obj, plugins.NotifyEmail))
|
||||||
|
|
||||||
|
# Support Exception handling of smtplib.SMTP
|
||||||
|
mock_smtplib.side_effect = TypeError('Test')
|
||||||
|
|
||||||
|
try:
|
||||||
|
obj.notify(
|
||||||
|
title='test', body='body',
|
||||||
|
notify_type=NotifyType.INFO)
|
||||||
|
|
||||||
|
# We should have thrown an exception
|
||||||
|
assert False
|
||||||
|
|
||||||
|
except TypeError:
|
||||||
|
# Exception thrown as expected
|
||||||
|
assert True
|
||||||
|
|
||||||
|
except Exception:
|
||||||
|
# Un-Expected
|
||||||
|
assert False
|
||||||
|
|
||||||
|
|
||||||
|
@mock.patch('smtplib.SMTP')
|
||||||
|
def test_smtplib_send_okay(mock_smtplib):
|
||||||
|
"""
|
||||||
|
API: Test a successfully sent email
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
from apprise.plugins import NotifyEmailBase
|
||||||
|
|
||||||
|
obj = Apprise.instantiate(
|
||||||
|
'mailto://user:pass@gmail.com', suppress_exceptions=False)
|
||||||
|
assert(isinstance(obj, plugins.NotifyEmail))
|
||||||
|
|
||||||
|
# Support an email simulation where we can correctly quit
|
||||||
|
mock_smtplib.starttls.return_value = True
|
||||||
|
mock_smtplib.login.return_value = True
|
||||||
|
mock_smtplib.sendmail.return_value = True
|
||||||
|
mock_smtplib.quit.return_value = True
|
||||||
|
|
||||||
|
obj.notify(title='test', body='body', notify_type=NotifyType.INFO)
|
||||||
|
Loading…
Reference in New Issue
Block a user