mirror of
https://github.com/GSA/notifications-api.git
synced 2026-02-05 02:41:14 -05:00
reformat
This commit is contained in:
@@ -43,139 +43,150 @@ def setup_function(_function):
|
||||
send_to_providers.provider_cache.clear()
|
||||
|
||||
|
||||
@pytest.mark.parametrize('international_provider_priority', (
|
||||
# Since there’s only one international provider it should always
|
||||
# be used, no matter what its priority is set to
|
||||
0, 50, 100,
|
||||
))
|
||||
@pytest.mark.parametrize(
|
||||
"international_provider_priority",
|
||||
(
|
||||
# Since there’s only one international provider it should always
|
||||
# be used, no matter what its priority is set to
|
||||
0,
|
||||
50,
|
||||
100,
|
||||
),
|
||||
)
|
||||
def test_provider_to_use_should_only_return_sns_for_international(
|
||||
mocker,
|
||||
notify_db_session,
|
||||
international_provider_priority,
|
||||
):
|
||||
sns = get_provider_details_by_identifier('sns')
|
||||
sns = get_provider_details_by_identifier("sns")
|
||||
sns.priority = international_provider_priority
|
||||
|
||||
ret = send_to_providers.provider_to_use('sms', international=True)
|
||||
ret = send_to_providers.provider_to_use("sms", international=True)
|
||||
|
||||
assert ret.name == 'sns'
|
||||
assert ret.name == "sns"
|
||||
|
||||
|
||||
def test_provider_to_use_raises_if_no_active_providers(mocker, restore_provider_details):
|
||||
sns = get_provider_details_by_identifier('sns')
|
||||
def test_provider_to_use_raises_if_no_active_providers(
|
||||
mocker, restore_provider_details
|
||||
):
|
||||
sns = get_provider_details_by_identifier("sns")
|
||||
sns.active = False
|
||||
|
||||
# flake8 doesn't like raises with a generic exception
|
||||
try:
|
||||
send_to_providers.provider_to_use('sms')
|
||||
send_to_providers.provider_to_use("sms")
|
||||
assert 1 == 0
|
||||
except Exception:
|
||||
assert 1 == 1
|
||||
|
||||
|
||||
def test_should_send_personalised_template_to_correct_sms_provider_and_persist(
|
||||
sample_sms_template_with_html,
|
||||
mocker
|
||||
sample_sms_template_with_html, mocker
|
||||
):
|
||||
db_notification = create_notification(template=sample_sms_template_with_html,
|
||||
to_field="2028675309", personalisation={"name": "Jo"},
|
||||
status='created',
|
||||
reply_to_text=sample_sms_template_with_html.service.get_default_sms_sender(),
|
||||
normalised_to="2028675309"
|
||||
)
|
||||
|
||||
mocker.patch('app.aws_sns_client.send_sms')
|
||||
|
||||
send_to_providers.send_sms_to_provider(
|
||||
db_notification
|
||||
db_notification = create_notification(
|
||||
template=sample_sms_template_with_html,
|
||||
to_field="2028675309",
|
||||
personalisation={"name": "Jo"},
|
||||
status="created",
|
||||
reply_to_text=sample_sms_template_with_html.service.get_default_sms_sender(),
|
||||
normalised_to="2028675309",
|
||||
)
|
||||
|
||||
mocker.patch("app.aws_sns_client.send_sms")
|
||||
|
||||
send_to_providers.send_sms_to_provider(db_notification)
|
||||
|
||||
aws_sns_client.send_sms.assert_called_once_with(
|
||||
to="2028675309",
|
||||
content="Sample service: Hello Jo\nHere is <em>some HTML</em> & entities",
|
||||
reference=str(db_notification.id),
|
||||
sender=current_app.config['FROM_NUMBER'],
|
||||
international=False
|
||||
sender=current_app.config["FROM_NUMBER"],
|
||||
international=False,
|
||||
)
|
||||
|
||||
notification = Notification.query.filter_by(id=db_notification.id).one()
|
||||
|
||||
assert notification.status == 'sending'
|
||||
assert notification.status == "sending"
|
||||
assert notification.sent_at <= datetime.utcnow()
|
||||
assert notification.sent_by == 'sns'
|
||||
assert notification.sent_by == "sns"
|
||||
assert notification.billable_units == 1
|
||||
assert notification.personalisation == {"name": "Jo"}
|
||||
|
||||
|
||||
def test_should_send_personalised_template_to_correct_email_provider_and_persist(
|
||||
sample_email_template_with_html,
|
||||
mocker
|
||||
sample_email_template_with_html, mocker
|
||||
):
|
||||
db_notification = create_notification(
|
||||
template=sample_email_template_with_html,
|
||||
to_field="jo.smith@example.com",
|
||||
personalisation={'name': 'Jo'},
|
||||
personalisation={"name": "Jo"},
|
||||
normalised_to="jo.smith@example.com",
|
||||
)
|
||||
|
||||
mocker.patch('app.aws_ses_client.send_email', return_value='reference')
|
||||
mocker.patch("app.aws_ses_client.send_email", return_value="reference")
|
||||
|
||||
send_to_providers.send_email_to_provider(
|
||||
db_notification
|
||||
)
|
||||
send_to_providers.send_email_to_provider(db_notification)
|
||||
|
||||
app.aws_ses_client.send_email.assert_called_once_with(
|
||||
f"\"Sample service\" <sample.service@{cloud_config.ses_email_domain}>",
|
||||
'jo.smith@example.com',
|
||||
'Jo <em>some HTML</em>',
|
||||
body='Hello Jo\nThis is an email from GOV.\u200bUK with <em>some HTML</em>\n',
|
||||
f'"Sample service" <sample.service@{cloud_config.ses_email_domain}>',
|
||||
"jo.smith@example.com",
|
||||
"Jo <em>some HTML</em>",
|
||||
body="Hello Jo\nThis is an email from GOV.\u200bUK with <em>some HTML</em>\n",
|
||||
html_body=ANY,
|
||||
reply_to_address=None,
|
||||
)
|
||||
|
||||
assert '<!DOCTYPE html' in app.aws_ses_client.send_email.call_args[1]['html_body']
|
||||
assert '<em>some HTML</em>' in app.aws_ses_client.send_email.call_args[1]['html_body']
|
||||
assert "<!DOCTYPE html" in app.aws_ses_client.send_email.call_args[1]["html_body"]
|
||||
assert (
|
||||
"<em>some HTML</em>"
|
||||
in app.aws_ses_client.send_email.call_args[1]["html_body"]
|
||||
)
|
||||
|
||||
notification = Notification.query.filter_by(id=db_notification.id).one()
|
||||
assert notification.status == 'sending'
|
||||
assert notification.status == "sending"
|
||||
assert notification.sent_at <= datetime.utcnow()
|
||||
assert notification.sent_by == 'ses'
|
||||
assert notification.sent_by == "ses"
|
||||
assert notification.personalisation == {"name": "Jo"}
|
||||
|
||||
|
||||
def test_should_not_send_email_message_when_service_is_inactive_notifcation_is_in_tech_failure(
|
||||
sample_service, sample_notification, mocker
|
||||
sample_service, sample_notification, mocker
|
||||
):
|
||||
sample_service.active = False
|
||||
send_mock = mocker.patch("app.aws_ses_client.send_email", return_value='reference')
|
||||
send_mock = mocker.patch("app.aws_ses_client.send_email", return_value="reference")
|
||||
|
||||
with pytest.raises(NotificationTechnicalFailureException) as e:
|
||||
send_to_providers.send_email_to_provider(sample_notification)
|
||||
assert str(sample_notification.id) in str(e.value)
|
||||
send_mock.assert_not_called()
|
||||
assert Notification.query.get(sample_notification.id).status == 'technical-failure'
|
||||
assert Notification.query.get(sample_notification.id).status == "technical-failure"
|
||||
|
||||
|
||||
def test_should_not_send_sms_message_when_service_is_inactive_notification_is_in_tech_failure(
|
||||
sample_service, sample_notification, mocker):
|
||||
sample_service, sample_notification, mocker
|
||||
):
|
||||
sample_service.active = False
|
||||
send_mock = mocker.patch("app.aws_sns_client.send_sms", return_value='reference')
|
||||
send_mock = mocker.patch("app.aws_sns_client.send_sms", return_value="reference")
|
||||
|
||||
with pytest.raises(NotificationTechnicalFailureException) as e:
|
||||
send_to_providers.send_sms_to_provider(sample_notification)
|
||||
assert str(sample_notification.id) in str(e.value)
|
||||
send_mock.assert_not_called()
|
||||
assert Notification.query.get(sample_notification.id).status == 'technical-failure'
|
||||
assert Notification.query.get(sample_notification.id).status == "technical-failure"
|
||||
|
||||
|
||||
def test_send_sms_should_use_template_version_from_notification_not_latest(
|
||||
sample_template,
|
||||
mocker):
|
||||
db_notification = create_notification(template=sample_template, to_field='2028675309', status='created',
|
||||
reply_to_text=sample_template.service.get_default_sms_sender(),
|
||||
normalised_to='2028675309')
|
||||
sample_template, mocker
|
||||
):
|
||||
db_notification = create_notification(
|
||||
template=sample_template,
|
||||
to_field="2028675309",
|
||||
status="created",
|
||||
reply_to_text=sample_template.service.get_default_sms_sender(),
|
||||
normalised_to="2028675309",
|
||||
)
|
||||
|
||||
mocker.patch('app.aws_sns_client.send_sms')
|
||||
mocker.patch("app.aws_sns_client.send_sms")
|
||||
|
||||
version_on_notification = sample_template.version
|
||||
expected_template_id = sample_template.id
|
||||
@@ -185,57 +196,59 @@ def test_send_sms_should_use_template_version_from_notification_not_latest(
|
||||
dao_get_template_by_id,
|
||||
dao_update_template,
|
||||
)
|
||||
sample_template.content = sample_template.content + " another version of the template"
|
||||
|
||||
sample_template.content = (
|
||||
sample_template.content + " another version of the template"
|
||||
)
|
||||
dao_update_template(sample_template)
|
||||
t = dao_get_template_by_id(sample_template.id)
|
||||
assert t.version > version_on_notification
|
||||
|
||||
send_to_providers.send_sms_to_provider(
|
||||
db_notification
|
||||
)
|
||||
send_to_providers.send_sms_to_provider(db_notification)
|
||||
|
||||
aws_sns_client.send_sms.assert_called_once_with(
|
||||
to="2028675309",
|
||||
content="Sample service: This is a template:\nwith a newline",
|
||||
reference=str(db_notification.id),
|
||||
sender=current_app.config['FROM_NUMBER'],
|
||||
international=False
|
||||
sender=current_app.config["FROM_NUMBER"],
|
||||
international=False,
|
||||
)
|
||||
|
||||
t = dao_get_template_by_id(expected_template_id)
|
||||
|
||||
persisted_notification = notifications_dao.get_notification_by_id(db_notification.id)
|
||||
persisted_notification = notifications_dao.get_notification_by_id(
|
||||
db_notification.id
|
||||
)
|
||||
assert persisted_notification.to == db_notification.to
|
||||
assert persisted_notification.template_id == expected_template_id
|
||||
assert persisted_notification.template_version == version_on_notification
|
||||
assert persisted_notification.template_version != t.version
|
||||
assert persisted_notification.status == 'sending'
|
||||
assert persisted_notification.status == "sending"
|
||||
assert not persisted_notification.personalisation
|
||||
|
||||
|
||||
def test_should_have_sending_status_if_fake_callback_function_fails(sample_notification, mocker):
|
||||
mocker.patch('app.delivery.send_to_providers.send_sms_response', side_effect=HTTPError)
|
||||
def test_should_have_sending_status_if_fake_callback_function_fails(
|
||||
sample_notification, mocker
|
||||
):
|
||||
mocker.patch(
|
||||
"app.delivery.send_to_providers.send_sms_response", side_effect=HTTPError
|
||||
)
|
||||
|
||||
sample_notification.key_type = KEY_TYPE_TEST
|
||||
with pytest.raises(HTTPError):
|
||||
send_to_providers.send_sms_to_provider(
|
||||
sample_notification
|
||||
)
|
||||
assert sample_notification.status == 'sending'
|
||||
assert sample_notification.sent_by == 'sns'
|
||||
send_to_providers.send_sms_to_provider(sample_notification)
|
||||
assert sample_notification.status == "sending"
|
||||
assert sample_notification.sent_by == "sns"
|
||||
|
||||
|
||||
def test_should_not_send_to_provider_when_status_is_not_created(
|
||||
sample_template,
|
||||
mocker
|
||||
sample_template, mocker
|
||||
):
|
||||
notification = create_notification(template=sample_template, status='sending')
|
||||
mocker.patch('app.aws_sns_client.send_sms')
|
||||
response_mock = mocker.patch('app.delivery.send_to_providers.send_sms_response')
|
||||
notification = create_notification(template=sample_template, status="sending")
|
||||
mocker.patch("app.aws_sns_client.send_sms")
|
||||
response_mock = mocker.patch("app.delivery.send_to_providers.send_sms_response")
|
||||
|
||||
send_to_providers.send_sms_to_provider(
|
||||
notification
|
||||
)
|
||||
send_to_providers.send_sms_to_provider(notification)
|
||||
|
||||
app.aws_sns_client.send_sms.assert_not_called()
|
||||
response_mock.assert_not_called()
|
||||
@@ -246,36 +259,34 @@ def test_should_send_sms_with_downgraded_content(notify_db_session, mocker):
|
||||
# ī, grapes, tabs, zero width space and ellipsis are not
|
||||
# ó isn't in GSM, but it is in the welsh alphabet so will still be sent
|
||||
msg = "a é ī o u 🍇 foo\tbar\u200bbaz((misc))…"
|
||||
placeholder = '∆∆∆abc'
|
||||
placeholder = "∆∆∆abc"
|
||||
gsm_message = "?ódz Housing Service: a é i o u ? foo barbaz???abc..."
|
||||
service = create_service(service_name='Łódź Housing Service')
|
||||
service = create_service(service_name="Łódź Housing Service")
|
||||
template = create_template(service, content=msg)
|
||||
db_notification = create_notification(
|
||||
template=template,
|
||||
personalisation={'misc': placeholder}
|
||||
template=template, personalisation={"misc": placeholder}
|
||||
)
|
||||
|
||||
mocker.patch('app.aws_sns_client.send_sms')
|
||||
mocker.patch("app.aws_sns_client.send_sms")
|
||||
|
||||
send_to_providers.send_sms_to_provider(db_notification)
|
||||
|
||||
aws_sns_client.send_sms.assert_called_once_with(
|
||||
to=ANY,
|
||||
content=gsm_message,
|
||||
reference=ANY,
|
||||
sender=ANY,
|
||||
international=False
|
||||
to=ANY, content=gsm_message, reference=ANY, sender=ANY, international=False
|
||||
)
|
||||
|
||||
|
||||
def test_send_sms_should_use_service_sms_sender(
|
||||
sample_service,
|
||||
sample_template,
|
||||
mocker):
|
||||
mocker.patch('app.aws_sns_client.send_sms')
|
||||
sample_service, sample_template, mocker
|
||||
):
|
||||
mocker.patch("app.aws_sns_client.send_sms")
|
||||
|
||||
sms_sender = create_service_sms_sender(service=sample_service, sms_sender='123456', is_default=False)
|
||||
db_notification = create_notification(template=sample_template, reply_to_text=sms_sender.sms_sender)
|
||||
sms_sender = create_service_sms_sender(
|
||||
service=sample_service, sms_sender="123456", is_default=False
|
||||
)
|
||||
db_notification = create_notification(
|
||||
template=sample_template, reply_to_text=sms_sender.sms_sender
|
||||
)
|
||||
expected_sender_name = sms_sender.sms_sender
|
||||
|
||||
send_to_providers.send_sms_to_provider(
|
||||
@@ -287,70 +298,63 @@ def test_send_sms_should_use_service_sms_sender(
|
||||
content=ANY,
|
||||
reference=ANY,
|
||||
sender=expected_sender_name,
|
||||
international=False
|
||||
international=False,
|
||||
)
|
||||
|
||||
|
||||
def test_send_email_to_provider_should_not_send_to_provider_when_status_is_not_created(
|
||||
sample_email_template,
|
||||
mocker
|
||||
sample_email_template, mocker
|
||||
):
|
||||
notification = create_notification(template=sample_email_template, status='sending')
|
||||
mocker.patch('app.aws_ses_client.send_email')
|
||||
mocker.patch('app.delivery.send_to_providers.send_email_response')
|
||||
notification = create_notification(template=sample_email_template, status="sending")
|
||||
mocker.patch("app.aws_ses_client.send_email")
|
||||
mocker.patch("app.delivery.send_to_providers.send_email_response")
|
||||
|
||||
send_to_providers.send_sms_to_provider(
|
||||
notification
|
||||
)
|
||||
send_to_providers.send_sms_to_provider(notification)
|
||||
app.aws_ses_client.send_email.assert_not_called()
|
||||
app.delivery.send_to_providers.send_email_response.assert_not_called()
|
||||
|
||||
|
||||
def test_send_email_should_use_service_reply_to_email(
|
||||
sample_service,
|
||||
sample_email_template,
|
||||
mocker):
|
||||
mocker.patch('app.aws_ses_client.send_email', return_value='reference')
|
||||
sample_service, sample_email_template, mocker
|
||||
):
|
||||
mocker.patch("app.aws_ses_client.send_email", return_value="reference")
|
||||
|
||||
db_notification = create_notification(template=sample_email_template, reply_to_text='foo@bar.com')
|
||||
create_reply_to_email(service=sample_service, email_address='foo@bar.com')
|
||||
db_notification = create_notification(
|
||||
template=sample_email_template, reply_to_text="foo@bar.com"
|
||||
)
|
||||
create_reply_to_email(service=sample_service, email_address="foo@bar.com")
|
||||
|
||||
send_to_providers.send_email_to_provider(
|
||||
db_notification,
|
||||
)
|
||||
|
||||
app.aws_ses_client.send_email.assert_called_once_with(
|
||||
ANY,
|
||||
ANY,
|
||||
ANY,
|
||||
body=ANY,
|
||||
html_body=ANY,
|
||||
reply_to_address='foo@bar.com'
|
||||
ANY, ANY, ANY, body=ANY, html_body=ANY, reply_to_address="foo@bar.com"
|
||||
)
|
||||
|
||||
|
||||
def test_get_html_email_renderer_should_return_for_normal_service(sample_service):
|
||||
options = send_to_providers.get_html_email_options(sample_service)
|
||||
assert options['govuk_banner'] is True
|
||||
assert 'brand_colour' not in options.keys()
|
||||
assert 'brand_logo' not in options.keys()
|
||||
assert 'brand_text' not in options.keys()
|
||||
assert 'brand_name' not in options.keys()
|
||||
assert options["govuk_banner"] is True
|
||||
assert "brand_colour" not in options.keys()
|
||||
assert "brand_logo" not in options.keys()
|
||||
assert "brand_text" not in options.keys()
|
||||
assert "brand_name" not in options.keys()
|
||||
|
||||
|
||||
@pytest.mark.parametrize('branding_type, govuk_banner', [
|
||||
(BRANDING_ORG, False),
|
||||
(BRANDING_BOTH, True),
|
||||
(BRANDING_ORG_BANNER, False)
|
||||
])
|
||||
def test_get_html_email_renderer_with_branding_details(branding_type, govuk_banner, notify_db_session, sample_service):
|
||||
|
||||
@pytest.mark.parametrize(
|
||||
"branding_type, govuk_banner",
|
||||
[(BRANDING_ORG, False), (BRANDING_BOTH, True), (BRANDING_ORG_BANNER, False)],
|
||||
)
|
||||
def test_get_html_email_renderer_with_branding_details(
|
||||
branding_type, govuk_banner, notify_db_session, sample_service
|
||||
):
|
||||
email_branding = EmailBranding(
|
||||
brand_type=branding_type,
|
||||
colour='#000000',
|
||||
logo='justice-league.png',
|
||||
name='Justice League',
|
||||
text='League of Justice',
|
||||
colour="#000000",
|
||||
logo="justice-league.png",
|
||||
name="Justice League",
|
||||
text="League of Justice",
|
||||
)
|
||||
sample_service.email_branding = email_branding
|
||||
notify_db_session.add_all([sample_service, email_branding])
|
||||
@@ -358,37 +362,41 @@ def test_get_html_email_renderer_with_branding_details(branding_type, govuk_bann
|
||||
|
||||
options = send_to_providers.get_html_email_options(sample_service)
|
||||
|
||||
assert options['govuk_banner'] == govuk_banner
|
||||
assert options['brand_colour'] == '#000000'
|
||||
assert options['brand_text'] == 'League of Justice'
|
||||
assert options['brand_name'] == 'Justice League'
|
||||
assert options["govuk_banner"] == govuk_banner
|
||||
assert options["brand_colour"] == "#000000"
|
||||
assert options["brand_text"] == "League of Justice"
|
||||
assert options["brand_name"] == "Justice League"
|
||||
|
||||
if branding_type == BRANDING_ORG_BANNER:
|
||||
assert options['brand_banner'] is True
|
||||
assert options["brand_banner"] is True
|
||||
else:
|
||||
assert options['brand_banner'] is False
|
||||
assert options["brand_banner"] is False
|
||||
|
||||
|
||||
def test_get_html_email_renderer_with_branding_details_and_render_govuk_banner_only(notify_db_session, sample_service):
|
||||
def test_get_html_email_renderer_with_branding_details_and_render_govuk_banner_only(
|
||||
notify_db_session, sample_service
|
||||
):
|
||||
sample_service.email_branding = None
|
||||
notify_db_session.add_all([sample_service])
|
||||
notify_db_session.commit()
|
||||
|
||||
options = send_to_providers.get_html_email_options(sample_service)
|
||||
|
||||
assert options == {'govuk_banner': True, 'brand_banner': False}
|
||||
assert options == {"govuk_banner": True, "brand_banner": False}
|
||||
|
||||
|
||||
def test_get_html_email_renderer_prepends_logo_path(notify_api):
|
||||
Service = namedtuple('Service', ['email_branding'])
|
||||
EmailBranding = namedtuple('EmailBranding', ['brand_type', 'colour', 'name', 'logo', 'text'])
|
||||
Service = namedtuple("Service", ["email_branding"])
|
||||
EmailBranding = namedtuple(
|
||||
"EmailBranding", ["brand_type", "colour", "name", "logo", "text"]
|
||||
)
|
||||
|
||||
email_branding = EmailBranding(
|
||||
brand_type=BRANDING_ORG,
|
||||
colour='#000000',
|
||||
logo='justice-league.png',
|
||||
name='Justice League',
|
||||
text='League of Justice',
|
||||
colour="#000000",
|
||||
logo="justice-league.png",
|
||||
name="Justice League",
|
||||
text="League of Justice",
|
||||
)
|
||||
service = Service(
|
||||
email_branding=email_branding,
|
||||
@@ -396,19 +404,23 @@ def test_get_html_email_renderer_prepends_logo_path(notify_api):
|
||||
|
||||
renderer = send_to_providers.get_html_email_options(service)
|
||||
|
||||
assert renderer['brand_logo'] == 'http://static-logos.notify.tools/justice-league.png'
|
||||
assert (
|
||||
renderer["brand_logo"] == "http://static-logos.notify.tools/justice-league.png"
|
||||
)
|
||||
|
||||
|
||||
def test_get_html_email_renderer_handles_email_branding_without_logo(notify_api):
|
||||
Service = namedtuple('Service', ['email_branding'])
|
||||
EmailBranding = namedtuple('EmailBranding', ['brand_type', 'colour', 'name', 'logo', 'text'])
|
||||
Service = namedtuple("Service", ["email_branding"])
|
||||
EmailBranding = namedtuple(
|
||||
"EmailBranding", ["brand_type", "colour", "name", "logo", "text"]
|
||||
)
|
||||
|
||||
email_branding = EmailBranding(
|
||||
brand_type=BRANDING_ORG_BANNER,
|
||||
colour='#000000',
|
||||
colour="#000000",
|
||||
logo=None,
|
||||
name='Justice League',
|
||||
text='League of Justice',
|
||||
name="Justice League",
|
||||
text="League of Justice",
|
||||
)
|
||||
service = Service(
|
||||
email_branding=email_branding,
|
||||
@@ -416,36 +428,51 @@ def test_get_html_email_renderer_handles_email_branding_without_logo(notify_api)
|
||||
|
||||
renderer = send_to_providers.get_html_email_options(service)
|
||||
|
||||
assert renderer['govuk_banner'] is False
|
||||
assert renderer['brand_banner'] is True
|
||||
assert renderer['brand_logo'] is None
|
||||
assert renderer['brand_text'] == 'League of Justice'
|
||||
assert renderer['brand_colour'] == '#000000'
|
||||
assert renderer['brand_name'] == 'Justice League'
|
||||
assert renderer["govuk_banner"] is False
|
||||
assert renderer["brand_banner"] is True
|
||||
assert renderer["brand_logo"] is None
|
||||
assert renderer["brand_text"] == "League of Justice"
|
||||
assert renderer["brand_colour"] == "#000000"
|
||||
assert renderer["brand_name"] == "Justice League"
|
||||
|
||||
|
||||
@pytest.mark.parametrize('base_url, expected_url', [
|
||||
# don't change localhost to prevent errors when testing locally
|
||||
('http://localhost:6012', 'http://static-logos.notify.tools/filename.png'),
|
||||
('https://www.notifications.service.gov.uk', 'https://static-logos.notifications.service.gov.uk/filename.png'),
|
||||
('https://notify.works', 'https://static-logos.notify.works/filename.png'),
|
||||
('https://staging-notify.works', 'https://static-logos.staging-notify.works/filename.png'),
|
||||
('https://www.notify.works', 'https://static-logos.notify.works/filename.png'),
|
||||
('https://www.staging-notify.works', 'https://static-logos.staging-notify.works/filename.png'),
|
||||
])
|
||||
@pytest.mark.parametrize(
|
||||
"base_url, expected_url",
|
||||
[
|
||||
# don't change localhost to prevent errors when testing locally
|
||||
("http://localhost:6012", "http://static-logos.notify.tools/filename.png"),
|
||||
(
|
||||
"https://www.notifications.service.gov.uk",
|
||||
"https://static-logos.notifications.service.gov.uk/filename.png",
|
||||
),
|
||||
("https://notify.works", "https://static-logos.notify.works/filename.png"),
|
||||
(
|
||||
"https://staging-notify.works",
|
||||
"https://static-logos.staging-notify.works/filename.png",
|
||||
),
|
||||
("https://www.notify.works", "https://static-logos.notify.works/filename.png"),
|
||||
(
|
||||
"https://www.staging-notify.works",
|
||||
"https://static-logos.staging-notify.works/filename.png",
|
||||
),
|
||||
],
|
||||
)
|
||||
def test_get_logo_url_works_for_different_environments(base_url, expected_url):
|
||||
logo_file = 'filename.png'
|
||||
logo_file = "filename.png"
|
||||
|
||||
logo_url = send_to_providers.get_logo_url(base_url, logo_file)
|
||||
|
||||
assert logo_url == expected_url
|
||||
|
||||
|
||||
@pytest.mark.parametrize("starting_status, expected_status", [
|
||||
("delivered", "delivered"),
|
||||
("created", "sending"),
|
||||
("technical-failure", "technical-failure"),
|
||||
])
|
||||
@pytest.mark.parametrize(
|
||||
"starting_status, expected_status",
|
||||
[
|
||||
("delivered", "delivered"),
|
||||
("created", "sending"),
|
||||
("technical-failure", "technical-failure"),
|
||||
],
|
||||
)
|
||||
def test_update_notification_to_sending_does_not_update_status_from_a_final_status(
|
||||
sample_service, notify_db_session, starting_status, expected_status
|
||||
):
|
||||
@@ -453,7 +480,7 @@ def test_update_notification_to_sending_does_not_update_status_from_a_final_stat
|
||||
notification = create_notification(template=template, status=starting_status)
|
||||
send_to_providers.update_notification_to_sending(
|
||||
notification,
|
||||
notification_provider_clients.get_client_by_name_and_type("sns", "sms")
|
||||
notification_provider_clients.get_client_by_name_and_type("sns", "sms"),
|
||||
)
|
||||
assert notification.status == expected_status
|
||||
|
||||
@@ -463,33 +490,33 @@ def __update_notification(notification_to_update, research_mode, expected_status
|
||||
notification_to_update.status = expected_status
|
||||
|
||||
|
||||
@pytest.mark.parametrize('research_mode,key_type, billable_units, expected_status', [
|
||||
(True, KEY_TYPE_NORMAL, 0, 'delivered'),
|
||||
(False, KEY_TYPE_NORMAL, 1, 'sending'),
|
||||
(False, KEY_TYPE_TEST, 0, 'sending'),
|
||||
(True, KEY_TYPE_TEST, 0, 'sending'),
|
||||
(True, KEY_TYPE_TEAM, 0, 'delivered'),
|
||||
(False, KEY_TYPE_TEAM, 1, 'sending')
|
||||
])
|
||||
@pytest.mark.parametrize(
|
||||
"research_mode,key_type, billable_units, expected_status",
|
||||
[
|
||||
(True, KEY_TYPE_NORMAL, 0, "delivered"),
|
||||
(False, KEY_TYPE_NORMAL, 1, "sending"),
|
||||
(False, KEY_TYPE_TEST, 0, "sending"),
|
||||
(True, KEY_TYPE_TEST, 0, "sending"),
|
||||
(True, KEY_TYPE_TEAM, 0, "delivered"),
|
||||
(False, KEY_TYPE_TEAM, 1, "sending"),
|
||||
],
|
||||
)
|
||||
def test_should_update_billable_units_and_status_according_to_research_mode_and_key_type(
|
||||
sample_template,
|
||||
mocker,
|
||||
research_mode,
|
||||
key_type,
|
||||
billable_units,
|
||||
expected_status
|
||||
sample_template, mocker, research_mode, key_type, billable_units, expected_status
|
||||
):
|
||||
notification = create_notification(template=sample_template, billable_units=0, status='created', key_type=key_type)
|
||||
mocker.patch('app.aws_sns_client.send_sms')
|
||||
mocker.patch('app.delivery.send_to_providers.send_sms_response',
|
||||
side_effect=__update_notification(notification, research_mode, expected_status))
|
||||
notification = create_notification(
|
||||
template=sample_template, billable_units=0, status="created", key_type=key_type
|
||||
)
|
||||
mocker.patch("app.aws_sns_client.send_sms")
|
||||
mocker.patch(
|
||||
"app.delivery.send_to_providers.send_sms_response",
|
||||
side_effect=__update_notification(notification, research_mode, expected_status),
|
||||
)
|
||||
|
||||
if research_mode:
|
||||
sample_template.service.research_mode = True
|
||||
|
||||
send_to_providers.send_sms_to_provider(
|
||||
notification
|
||||
)
|
||||
send_to_providers.send_sms_to_provider(notification)
|
||||
assert notification.billable_units == billable_units
|
||||
assert notification.status == expected_status
|
||||
|
||||
@@ -498,7 +525,7 @@ def test_should_set_notification_billable_units_and_reduces_provider_priority_if
|
||||
sample_notification,
|
||||
mocker,
|
||||
):
|
||||
mocker.patch('app.aws_sns_client.send_sms', side_effect=Exception())
|
||||
mocker.patch("app.aws_sns_client.send_sms", side_effect=Exception())
|
||||
|
||||
sample_notification.billable_units = 0
|
||||
assert sample_notification.sent_by is None
|
||||
@@ -514,58 +541,54 @@ def test_should_set_notification_billable_units_and_reduces_provider_priority_if
|
||||
|
||||
|
||||
def test_should_send_sms_to_international_providers(
|
||||
sample_template,
|
||||
sample_user,
|
||||
mocker
|
||||
sample_template, sample_user, mocker
|
||||
):
|
||||
mocker.patch('app.aws_sns_client.send_sms')
|
||||
mocker.patch("app.aws_sns_client.send_sms")
|
||||
|
||||
notification_international = create_notification(
|
||||
template=sample_template,
|
||||
to_field="+6011-17224412",
|
||||
personalisation={"name": "Jo"},
|
||||
status='created',
|
||||
status="created",
|
||||
international=True,
|
||||
reply_to_text=sample_template.service.get_default_sms_sender(),
|
||||
normalised_to='601117224412'
|
||||
normalised_to="601117224412",
|
||||
)
|
||||
|
||||
send_to_providers.send_sms_to_provider(
|
||||
notification_international
|
||||
)
|
||||
send_to_providers.send_sms_to_provider(notification_international)
|
||||
|
||||
aws_sns_client.send_sms.assert_called_once_with(
|
||||
to="601117224412",
|
||||
content=ANY,
|
||||
reference=str(notification_international.id),
|
||||
sender=current_app.config['FROM_NUMBER'],
|
||||
international=True
|
||||
sender=current_app.config["FROM_NUMBER"],
|
||||
international=True,
|
||||
)
|
||||
|
||||
assert notification_international.status == 'sending'
|
||||
assert notification_international.sent_by == 'sns'
|
||||
assert notification_international.status == "sending"
|
||||
assert notification_international.sent_by == "sns"
|
||||
|
||||
|
||||
@pytest.mark.parametrize('sms_sender, expected_sender, prefix_sms, expected_content', [
|
||||
('foo', 'foo', False, 'bar'),
|
||||
('foo', 'foo', True, 'Sample service: bar'),
|
||||
# if 40604 is actually in DB then treat that as if entered manually
|
||||
('40604', '40604', False, 'bar'),
|
||||
# 'testing' is the FROM_NUMBER during unit tests
|
||||
('testing', 'testing', True, 'Sample service: bar'),
|
||||
('testing', 'testing', False, 'bar'),
|
||||
])
|
||||
@pytest.mark.parametrize(
|
||||
"sms_sender, expected_sender, prefix_sms, expected_content",
|
||||
[
|
||||
("foo", "foo", False, "bar"),
|
||||
("foo", "foo", True, "Sample service: bar"),
|
||||
# if 40604 is actually in DB then treat that as if entered manually
|
||||
("40604", "40604", False, "bar"),
|
||||
# 'testing' is the FROM_NUMBER during unit tests
|
||||
("testing", "testing", True, "Sample service: bar"),
|
||||
("testing", "testing", False, "bar"),
|
||||
],
|
||||
)
|
||||
def test_should_handle_sms_sender_and_prefix_message(
|
||||
mocker,
|
||||
sms_sender,
|
||||
prefix_sms,
|
||||
expected_sender,
|
||||
expected_content,
|
||||
notify_db_session
|
||||
mocker, sms_sender, prefix_sms, expected_sender, expected_content, notify_db_session
|
||||
):
|
||||
mocker.patch('app.aws_sns_client.send_sms')
|
||||
service = create_service_with_defined_sms_sender(sms_sender_value=sms_sender, prefix_sms=prefix_sms)
|
||||
template = create_template(service, content='bar')
|
||||
mocker.patch("app.aws_sns_client.send_sms")
|
||||
service = create_service_with_defined_sms_sender(
|
||||
sms_sender_value=sms_sender, prefix_sms=prefix_sms
|
||||
)
|
||||
template = create_template(service, content="bar")
|
||||
notification = create_notification(template, reply_to_text=sms_sender)
|
||||
|
||||
send_to_providers.send_sms_to_provider(notification)
|
||||
@@ -575,149 +598,155 @@ def test_should_handle_sms_sender_and_prefix_message(
|
||||
sender=expected_sender,
|
||||
to=ANY,
|
||||
reference=ANY,
|
||||
international=False
|
||||
international=False,
|
||||
)
|
||||
|
||||
|
||||
def test_send_email_to_provider_uses_reply_to_from_notification(
|
||||
sample_email_template,
|
||||
mocker):
|
||||
mocker.patch('app.aws_ses_client.send_email', return_value='reference')
|
||||
sample_email_template, mocker
|
||||
):
|
||||
mocker.patch("app.aws_ses_client.send_email", return_value="reference")
|
||||
|
||||
db_notification = create_notification(template=sample_email_template, reply_to_text="test@test.com")
|
||||
db_notification = create_notification(
|
||||
template=sample_email_template, reply_to_text="test@test.com"
|
||||
)
|
||||
|
||||
send_to_providers.send_email_to_provider(
|
||||
db_notification,
|
||||
)
|
||||
|
||||
app.aws_ses_client.send_email.assert_called_once_with(
|
||||
ANY,
|
||||
ANY,
|
||||
ANY,
|
||||
body=ANY,
|
||||
html_body=ANY,
|
||||
reply_to_address="test@test.com"
|
||||
ANY, ANY, ANY, body=ANY, html_body=ANY, reply_to_address="test@test.com"
|
||||
)
|
||||
|
||||
|
||||
def test_send_sms_to_provider_should_use_normalised_to(
|
||||
mocker, client, sample_template
|
||||
):
|
||||
send_mock = mocker.patch('app.aws_sns_client.send_sms')
|
||||
notification = create_notification(template=sample_template,
|
||||
to_field='+12028675309',
|
||||
normalised_to='2028675309')
|
||||
def test_send_sms_to_provider_should_use_normalised_to(mocker, client, sample_template):
|
||||
send_mock = mocker.patch("app.aws_sns_client.send_sms")
|
||||
notification = create_notification(
|
||||
template=sample_template, to_field="+12028675309", normalised_to="2028675309"
|
||||
)
|
||||
send_to_providers.send_sms_to_provider(notification)
|
||||
send_mock.assert_called_once_with(to=notification.normalised_to,
|
||||
content=ANY,
|
||||
reference=str(notification.id),
|
||||
sender=notification.reply_to_text,
|
||||
international=False)
|
||||
send_mock.assert_called_once_with(
|
||||
to=notification.normalised_to,
|
||||
content=ANY,
|
||||
reference=str(notification.id),
|
||||
sender=notification.reply_to_text,
|
||||
international=False,
|
||||
)
|
||||
|
||||
|
||||
def test_send_email_to_provider_should_user_normalised_to(
|
||||
mocker, client, sample_email_template
|
||||
mocker, client, sample_email_template
|
||||
):
|
||||
send_mock = mocker.patch('app.aws_ses_client.send_email', return_value='reference')
|
||||
notification = create_notification(template=sample_email_template,
|
||||
to_field='TEST@example.com',
|
||||
normalised_to='test@example.com')
|
||||
send_mock = mocker.patch("app.aws_ses_client.send_email", return_value="reference")
|
||||
notification = create_notification(
|
||||
template=sample_email_template,
|
||||
to_field="TEST@example.com",
|
||||
normalised_to="test@example.com",
|
||||
)
|
||||
|
||||
send_to_providers.send_email_to_provider(notification)
|
||||
send_mock.assert_called_once_with(ANY,
|
||||
notification.normalised_to,
|
||||
ANY,
|
||||
body=ANY,
|
||||
html_body=ANY,
|
||||
reply_to_address=notification.reply_to_text)
|
||||
send_mock.assert_called_once_with(
|
||||
ANY,
|
||||
notification.normalised_to,
|
||||
ANY,
|
||||
body=ANY,
|
||||
html_body=ANY,
|
||||
reply_to_address=notification.reply_to_text,
|
||||
)
|
||||
|
||||
|
||||
def test_send_sms_to_provider_should_return_template_if_found_in_redis(
|
||||
mocker, client, sample_template
|
||||
mocker, client, sample_template
|
||||
):
|
||||
from app.schemas import service_schema, template_schema
|
||||
|
||||
service_dict = service_schema.dump(sample_template.service)
|
||||
template_dict = template_schema.dump(sample_template)
|
||||
|
||||
mocker.patch(
|
||||
'app.redis_store.get',
|
||||
"app.redis_store.get",
|
||||
side_effect=[
|
||||
json.dumps({'data': service_dict}).encode('utf-8'),
|
||||
json.dumps({'data': template_dict}).encode('utf-8'),
|
||||
json.dumps({"data": service_dict}).encode("utf-8"),
|
||||
json.dumps({"data": template_dict}).encode("utf-8"),
|
||||
],
|
||||
)
|
||||
mock_get_template = mocker.patch(
|
||||
'app.dao.templates_dao.dao_get_template_by_id_and_service_id'
|
||||
)
|
||||
mock_get_service = mocker.patch(
|
||||
'app.dao.services_dao.dao_fetch_service_by_id'
|
||||
"app.dao.templates_dao.dao_get_template_by_id_and_service_id"
|
||||
)
|
||||
mock_get_service = mocker.patch("app.dao.services_dao.dao_fetch_service_by_id")
|
||||
|
||||
send_mock = mocker.patch('app.aws_sns_client.send_sms')
|
||||
notification = create_notification(template=sample_template,
|
||||
to_field='+447700900855',
|
||||
normalised_to='447700900855')
|
||||
send_mock = mocker.patch("app.aws_sns_client.send_sms")
|
||||
notification = create_notification(
|
||||
template=sample_template, to_field="+447700900855", normalised_to="447700900855"
|
||||
)
|
||||
send_to_providers.send_sms_to_provider(notification)
|
||||
assert mock_get_template.called is False
|
||||
assert mock_get_service.called is False
|
||||
send_mock.assert_called_once_with(to=notification.normalised_to,
|
||||
content=ANY,
|
||||
reference=str(notification.id),
|
||||
sender=notification.reply_to_text,
|
||||
international=False)
|
||||
send_mock.assert_called_once_with(
|
||||
to=notification.normalised_to,
|
||||
content=ANY,
|
||||
reference=str(notification.id),
|
||||
sender=notification.reply_to_text,
|
||||
international=False,
|
||||
)
|
||||
|
||||
|
||||
def test_send_email_to_provider_should_return_template_if_found_in_redis(
|
||||
mocker, client, sample_email_template
|
||||
mocker, client, sample_email_template
|
||||
):
|
||||
from app.schemas import service_schema, template_schema
|
||||
|
||||
service_dict = service_schema.dump(sample_email_template.service)
|
||||
template_dict = template_schema.dump(sample_email_template)
|
||||
|
||||
mocker.patch(
|
||||
'app.redis_store.get',
|
||||
"app.redis_store.get",
|
||||
side_effect=[
|
||||
json.dumps({'data': service_dict}).encode('utf-8'),
|
||||
json.dumps({'data': template_dict}).encode('utf-8'),
|
||||
json.dumps({"data": service_dict}).encode("utf-8"),
|
||||
json.dumps({"data": template_dict}).encode("utf-8"),
|
||||
],
|
||||
)
|
||||
mock_get_template = mocker.patch(
|
||||
'app.dao.templates_dao.dao_get_template_by_id_and_service_id'
|
||||
"app.dao.templates_dao.dao_get_template_by_id_and_service_id"
|
||||
)
|
||||
mock_get_service = mocker.patch(
|
||||
'app.dao.services_dao.dao_fetch_service_by_id'
|
||||
mock_get_service = mocker.patch("app.dao.services_dao.dao_fetch_service_by_id")
|
||||
send_mock = mocker.patch("app.aws_ses_client.send_email", return_value="reference")
|
||||
notification = create_notification(
|
||||
template=sample_email_template,
|
||||
to_field="TEST@example.com",
|
||||
normalised_to="test@example.com",
|
||||
)
|
||||
send_mock = mocker.patch('app.aws_ses_client.send_email', return_value='reference')
|
||||
notification = create_notification(template=sample_email_template,
|
||||
to_field='TEST@example.com',
|
||||
normalised_to='test@example.com')
|
||||
|
||||
send_to_providers.send_email_to_provider(notification)
|
||||
assert mock_get_template.called is False
|
||||
assert mock_get_service.called is False
|
||||
send_mock.assert_called_once_with(ANY,
|
||||
notification.normalised_to,
|
||||
ANY,
|
||||
body=ANY,
|
||||
html_body=ANY,
|
||||
reply_to_address=notification.reply_to_text)
|
||||
send_mock.assert_called_once_with(
|
||||
ANY,
|
||||
notification.normalised_to,
|
||||
ANY,
|
||||
body=ANY,
|
||||
html_body=ANY,
|
||||
reply_to_address=notification.reply_to_text,
|
||||
)
|
||||
|
||||
|
||||
def test_get_html_email_options_return_email_branding_from_serialised_service(
|
||||
sample_service
|
||||
sample_service,
|
||||
):
|
||||
branding = create_email_branding()
|
||||
sample_service.email_branding = branding
|
||||
service = SerialisedService.from_id(sample_service.id)
|
||||
email_options = get_html_email_options(service)
|
||||
assert email_options is not None
|
||||
assert email_options == {'govuk_banner': branding.brand_type == BRANDING_BOTH,
|
||||
'brand_banner': branding.brand_type == BRANDING_ORG_BANNER,
|
||||
'brand_colour': branding.colour,
|
||||
'brand_logo': get_logo_url(current_app.config['ADMIN_BASE_URL'], branding.logo),
|
||||
'brand_text': branding.text,
|
||||
'brand_name': branding.name,
|
||||
}
|
||||
assert email_options == {
|
||||
"govuk_banner": branding.brand_type == BRANDING_BOTH,
|
||||
"brand_banner": branding.brand_type == BRANDING_ORG_BANNER,
|
||||
"brand_colour": branding.colour,
|
||||
"brand_logo": get_logo_url(current_app.config["ADMIN_BASE_URL"], branding.logo),
|
||||
"brand_text": branding.text,
|
||||
"brand_name": branding.name,
|
||||
}
|
||||
|
||||
|
||||
def test_get_html_email_options_add_email_branding_from_service(sample_service):
|
||||
@@ -725,10 +754,11 @@ def test_get_html_email_options_add_email_branding_from_service(sample_service):
|
||||
sample_service.email_branding = branding
|
||||
email_options = get_html_email_options(sample_service)
|
||||
assert email_options is not None
|
||||
assert email_options == {'govuk_banner': branding.brand_type == BRANDING_BOTH,
|
||||
'brand_banner': branding.brand_type == BRANDING_ORG_BANNER,
|
||||
'brand_colour': branding.colour,
|
||||
'brand_logo': get_logo_url(current_app.config['ADMIN_BASE_URL'], branding.logo),
|
||||
'brand_text': branding.text,
|
||||
'brand_name': branding.name,
|
||||
}
|
||||
assert email_options == {
|
||||
"govuk_banner": branding.brand_type == BRANDING_BOTH,
|
||||
"brand_banner": branding.brand_type == BRANDING_ORG_BANNER,
|
||||
"brand_colour": branding.colour,
|
||||
"brand_logo": get_logo_url(current_app.config["ADMIN_BASE_URL"], branding.logo),
|
||||
"brand_text": branding.text,
|
||||
"brand_name": branding.name,
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user