mirror of
https://github.com/GSA/notifications-api.git
synced 2026-01-31 23:26:23 -05:00
Extract tests for conditionally creating callback
This will help ensure the function doesn't change arbitrarily, now that it's used in multiple other places.
This commit is contained in:
@@ -10,9 +10,6 @@ from app.celery.research_mode_tasks import (
|
||||
ses_notification_callback,
|
||||
ses_soft_bounce_callback,
|
||||
)
|
||||
from app.celery.service_callback_tasks import (
|
||||
create_delivery_status_callback_data,
|
||||
)
|
||||
from app.dao.notifications_dao import get_notification_by_id
|
||||
from app.models import Complaint, Notification
|
||||
from app.notifications.notifications_ses_callback import (
|
||||
@@ -72,15 +69,13 @@ def test_ses_callback_should_update_notification_status(
|
||||
mocker.patch('app.statsd_client.incr')
|
||||
mocker.patch('app.statsd_client.timing_with_dates')
|
||||
send_mock = mocker.patch(
|
||||
'app.celery.service_callback_tasks.send_delivery_status_to_service.apply_async'
|
||||
'app.celery.process_ses_receipts_tasks.check_and_queue_callback_task'
|
||||
)
|
||||
notification = create_notification(
|
||||
template=sample_email_template,
|
||||
status='sending',
|
||||
reference='ref',
|
||||
)
|
||||
callback_api = create_service_callback_api(service=sample_email_template.service,
|
||||
url="https://original_url.com")
|
||||
assert get_notification_by_id(notification.id).status == 'sending'
|
||||
|
||||
assert process_ses_results(ses_notification_callback(reference='ref'))
|
||||
@@ -90,8 +85,7 @@ def test_ses_callback_should_update_notification_status(
|
||||
)
|
||||
statsd_client.incr.assert_any_call("callback.ses.delivered")
|
||||
updated_notification = Notification.query.get(notification.id)
|
||||
encrypted_data = create_delivery_status_callback_data(updated_notification, callback_api)
|
||||
send_mock.assert_called_once_with([str(notification.id), encrypted_data], queue="service-callbacks")
|
||||
send_mock.assert_called_once_with(updated_notification)
|
||||
|
||||
|
||||
def test_ses_callback_should_not_update_notification_status_if_already_delivered(sample_email_template, mocker):
|
||||
@@ -138,30 +132,6 @@ def test_ses_callback_should_not_retry_if_notification_is_old(client, notify_db,
|
||||
assert mock_retry.call_count == 0
|
||||
|
||||
|
||||
def test_ses_callback_does_not_call_send_delivery_status_if_no_db_entry(
|
||||
client,
|
||||
notify_db_session,
|
||||
sample_email_template,
|
||||
mocker):
|
||||
with freeze_time('2001-01-01T12:00:00'):
|
||||
|
||||
send_mock = mocker.patch(
|
||||
'app.celery.service_callback_tasks.send_delivery_status_to_service.apply_async'
|
||||
)
|
||||
notification = create_notification(
|
||||
template=sample_email_template,
|
||||
status='sending',
|
||||
reference='ref',
|
||||
)
|
||||
|
||||
assert get_notification_by_id(notification.id).status == 'sending'
|
||||
|
||||
assert process_ses_results(ses_notification_callback(reference='ref'))
|
||||
assert get_notification_by_id(notification.id).status == 'delivered'
|
||||
|
||||
send_mock.assert_not_called()
|
||||
|
||||
|
||||
def test_ses_callback_should_update_multiple_notification_status_sent(
|
||||
client,
|
||||
notify_db_session,
|
||||
@@ -169,7 +139,7 @@ def test_ses_callback_should_update_multiple_notification_status_sent(
|
||||
mocker):
|
||||
|
||||
send_mock = mocker.patch(
|
||||
'app.celery.service_callback_tasks.send_delivery_status_to_service.apply_async'
|
||||
'app.celery.process_ses_receipts_tasks.check_and_queue_callback_task'
|
||||
)
|
||||
create_notification(
|
||||
template=sample_email_template,
|
||||
@@ -186,7 +156,6 @@ def test_ses_callback_should_update_multiple_notification_status_sent(
|
||||
status='sending',
|
||||
reference='ref3',
|
||||
)
|
||||
create_service_callback_api(service=sample_email_template.service, url="https://original_url.com")
|
||||
assert process_ses_results(ses_notification_callback(reference='ref1'))
|
||||
assert process_ses_results(ses_notification_callback(reference='ref2'))
|
||||
assert process_ses_results(ses_notification_callback(reference='ref3'))
|
||||
@@ -198,7 +167,7 @@ def test_ses_callback_should_set_status_to_temporary_failure(client,
|
||||
sample_email_template,
|
||||
mocker):
|
||||
send_mock = mocker.patch(
|
||||
'app.celery.service_callback_tasks.send_delivery_status_to_service.apply_async'
|
||||
'app.celery.process_ses_receipts_tasks.check_and_queue_callback_task'
|
||||
)
|
||||
mock_logger = mocker.patch('app.celery.process_ses_receipts_tasks.current_app.logger.info')
|
||||
notification = create_notification(
|
||||
@@ -206,7 +175,6 @@ def test_ses_callback_should_set_status_to_temporary_failure(client,
|
||||
status='sending',
|
||||
reference='ref',
|
||||
)
|
||||
create_service_callback_api(service=notification.service, url="https://original_url.com")
|
||||
assert get_notification_by_id(notification.id).status == 'sending'
|
||||
assert process_ses_results(ses_soft_bounce_callback(reference='ref'))
|
||||
assert get_notification_by_id(notification.id).status == 'temporary-failure'
|
||||
@@ -219,7 +187,7 @@ def test_ses_callback_should_set_status_to_permanent_failure(client,
|
||||
sample_email_template,
|
||||
mocker):
|
||||
send_mock = mocker.patch(
|
||||
'app.celery.service_callback_tasks.send_delivery_status_to_service.apply_async'
|
||||
'app.celery.process_ses_receipts_tasks.check_and_queue_callback_task'
|
||||
)
|
||||
mock_logger = mocker.patch('app.celery.process_ses_receipts_tasks.current_app.logger.info')
|
||||
notification = create_notification(
|
||||
@@ -227,7 +195,6 @@ def test_ses_callback_should_set_status_to_permanent_failure(client,
|
||||
status='sending',
|
||||
reference='ref',
|
||||
)
|
||||
create_service_callback_api(service=sample_email_template.service, url="https://original_url.com")
|
||||
|
||||
assert get_notification_by_id(notification.id).status == 'sending'
|
||||
assert process_ses_results(ses_hard_bounce_callback(reference='ref'))
|
||||
|
||||
@@ -4,10 +4,14 @@ from sqlalchemy.exc import SQLAlchemyError
|
||||
|
||||
from app.dao.notifications_dao import get_notification_by_id
|
||||
from app.models import Complaint
|
||||
from app.notifications.notifications_ses_callback import handle_complaint
|
||||
from app.notifications.notifications_ses_callback import (
|
||||
check_and_queue_callback_task,
|
||||
handle_complaint,
|
||||
)
|
||||
from tests.app.db import (
|
||||
create_notification,
|
||||
create_notification_history,
|
||||
create_service_callback_api,
|
||||
ses_complaint_callback,
|
||||
ses_complaint_callback_malformed_message_id,
|
||||
ses_complaint_callback_with_missing_complaint_type,
|
||||
@@ -64,3 +68,37 @@ def test_process_ses_results_in_complaint_save_complaint_with_null_complaint_typ
|
||||
assert len(complaints) == 1
|
||||
assert complaints[0].notification_id == notification.id
|
||||
assert not complaints[0].complaint_type
|
||||
|
||||
|
||||
def test_check_and_queue_callback_task(mocker, sample_notification):
|
||||
mock_create = mocker.patch(
|
||||
'app.notifications.notifications_ses_callback.create_delivery_status_callback_data'
|
||||
)
|
||||
|
||||
mock_send = mocker.patch(
|
||||
'app.celery.service_callback_tasks.send_delivery_status_to_service.apply_async'
|
||||
)
|
||||
|
||||
callback_api = create_service_callback_api(service=sample_notification.service)
|
||||
mock_create.return_value = 'encrypted_status_update'
|
||||
|
||||
check_and_queue_callback_task(sample_notification)
|
||||
|
||||
# callback_api doesn't match by equality for some
|
||||
# reason, so we need to take this approach instead
|
||||
mock_create_args = mock_create.mock_calls[0][1]
|
||||
assert mock_create_args[0] == sample_notification
|
||||
assert mock_create_args[1].id == callback_api.id
|
||||
|
||||
mock_send.assert_called_once_with(
|
||||
[str(sample_notification.id), mock_create.return_value], queue="service-callbacks"
|
||||
)
|
||||
|
||||
|
||||
def test_check_and_queue_callback_task_no_callback_api(mocker, sample_notification):
|
||||
mock_send = mocker.patch(
|
||||
'app.celery.service_callback_tasks.send_delivery_status_to_service.apply_async'
|
||||
)
|
||||
|
||||
check_and_queue_callback_task(sample_notification)
|
||||
mock_send.assert_not_called()
|
||||
|
||||
Reference in New Issue
Block a user