mirror of
https://github.com/GSA/notifications-api.git
synced 2025-12-14 09:12:06 -05:00
Don't send the SMS if we have failed to save in the database
This commit is contained in:
@@ -4,6 +4,7 @@ from app.dao.templates_dao import get_model_templates
|
|||||||
from app.dao.notifications_dao import save_notification
|
from app.dao.notifications_dao import save_notification
|
||||||
from app.models import Notification
|
from app.models import Notification
|
||||||
from flask import current_app
|
from flask import current_app
|
||||||
|
from sqlalchemy.exc import SQLAlchemyError
|
||||||
|
|
||||||
|
|
||||||
@notify_celery.task(name="send-sms")
|
@notify_celery.task(name="send-sms")
|
||||||
@@ -11,20 +12,21 @@ def send_sms(service_id, notification_id, encrypted_notification):
|
|||||||
notification = encryption.decrypt(encrypted_notification)
|
notification = encryption.decrypt(encrypted_notification)
|
||||||
template = get_model_templates(notification['template'])
|
template = get_model_templates(notification['template'])
|
||||||
|
|
||||||
status = 'sent'
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
twilio_client.send_sms(notification['to'], template.content)
|
notification_db_object = Notification(
|
||||||
except TwilioClientException as e:
|
id=notification_id,
|
||||||
current_app.logger.info(e)
|
template_id=notification['template'],
|
||||||
status = 'failed'
|
to=notification['to'],
|
||||||
|
service_id=service_id,
|
||||||
|
status='sent'
|
||||||
|
)
|
||||||
|
save_notification(notification_db_object)
|
||||||
|
|
||||||
notification_db_object = Notification(
|
try:
|
||||||
id=notification_id,
|
twilio_client.send_sms(notification['to'], template.content)
|
||||||
template_id=notification['template'],
|
except TwilioClientException as e:
|
||||||
to=notification['to'],
|
current_app.logger.debug(e)
|
||||||
service_id=service_id,
|
save_notification(notification_db_object, {"status": "failed"})
|
||||||
status=status
|
|
||||||
)
|
|
||||||
|
|
||||||
save_notification(notification_db_object)
|
except SQLAlchemyError as e:
|
||||||
|
current_app.logger.debug(e)
|
||||||
|
|||||||
@@ -4,14 +4,12 @@ from itsdangerous import URLSafeSerializer
|
|||||||
|
|
||||||
|
|
||||||
class Encryption:
|
class Encryption:
|
||||||
|
|
||||||
def init_app(self, app):
|
def init_app(self, app):
|
||||||
self.serializer = URLSafeSerializer(app.config.get('SECRET_KEY'))
|
self.serializer = URLSafeSerializer(app.config.get('SECRET_KEY'))
|
||||||
self.salt = app.config.get('DANGEROUS_SALT')
|
self.salt = app.config.get('DANGEROUS_SALT')
|
||||||
|
|
||||||
def encrypt(self, thing_to_encrypt):
|
def encrypt(self, thing_to_encrypt):
|
||||||
return self.serializer.dumps(thing_to_encrypt, salt=
|
return self.serializer.dumps(thing_to_encrypt, salt=self.salt)
|
||||||
self.salt)
|
|
||||||
|
|
||||||
def decrypt(self, thing_to_decrypt):
|
def decrypt(self, thing_to_decrypt):
|
||||||
return self.serializer.loads(thing_to_decrypt, salt=self.salt)
|
return self.serializer.loads(thing_to_decrypt, salt=self.salt)
|
||||||
|
|||||||
@@ -1,8 +1,11 @@
|
|||||||
import uuid
|
import uuid
|
||||||
|
import pytest
|
||||||
from app.celery.tasks import send_sms
|
from app.celery.tasks import send_sms
|
||||||
from app import twilio_client
|
from app import twilio_client
|
||||||
from app.clients.sms.twilio import TwilioClientException
|
from app.clients.sms.twilio import TwilioClientException
|
||||||
from app.dao import notifications_dao
|
from app.dao import notifications_dao
|
||||||
|
from sqlalchemy.exc import SQLAlchemyError
|
||||||
|
from sqlalchemy.orm.exc import NoResultFound
|
||||||
|
|
||||||
|
|
||||||
def test_should_send_template_to_correct_sms_provider_and_persist(sample_template, mocker):
|
def test_should_send_template_to_correct_sms_provider_and_persist(sample_template, mocker):
|
||||||
@@ -58,6 +61,7 @@ def test_should_not_send_sms_if_db_peristance_failed(sample_template, mocker):
|
|||||||
}
|
}
|
||||||
mocker.patch('app.encryption.decrypt', return_value=notification)
|
mocker.patch('app.encryption.decrypt', return_value=notification)
|
||||||
mocker.patch('app.twilio_client.send_sms', side_effect=TwilioClientException())
|
mocker.patch('app.twilio_client.send_sms', side_effect=TwilioClientException())
|
||||||
|
mocker.patch('app.db.session.add', side_effect=SQLAlchemyError())
|
||||||
|
|
||||||
notification_id = uuid.uuid4()
|
notification_id = uuid.uuid4()
|
||||||
|
|
||||||
@@ -66,9 +70,7 @@ def test_should_not_send_sms_if_db_peristance_failed(sample_template, mocker):
|
|||||||
notification_id,
|
notification_id,
|
||||||
"encrypted-in-reality")
|
"encrypted-in-reality")
|
||||||
|
|
||||||
twilio_client.send_sms.assert_called_once_with("+441234123123", sample_template.content)
|
twilio_client.send_sms.assert_not_called()
|
||||||
persisted_notification = notifications_dao.get_notification(sample_template.service_id, notification_id)
|
with pytest.raises(NoResultFound) as e:
|
||||||
assert persisted_notification.id == notification_id
|
notifications_dao.get_notification(sample_template.service_id, notification_id)
|
||||||
assert persisted_notification.to == '+441234123123'
|
assert 'No row was found for one' in str(e.value)
|
||||||
assert persisted_notification.template_id == sample_template.id
|
|
||||||
assert persisted_notification.status == 'failed'
|
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ from app.dao.jobs_dao import save_job
|
|||||||
from app.dao.notifications_dao import save_notification
|
from app.dao.notifications_dao import save_notification
|
||||||
import uuid
|
import uuid
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope='function')
|
@pytest.fixture(scope='function')
|
||||||
def service_factory(notify_db, notify_db_session):
|
def service_factory(notify_db, notify_db_session):
|
||||||
class ServiceFactory(object):
|
class ServiceFactory(object):
|
||||||
|
|||||||
Reference in New Issue
Block a user