mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-02-05 10:53:28 -05:00
866 lines
24 KiB
Python
866 lines
24 KiB
Python
import json
|
||
import uuid
|
||
from functools import partial
|
||
from urllib.parse import parse_qs, urlparse
|
||
|
||
import pytest
|
||
from flask import url_for
|
||
from freezegun import freeze_time
|
||
|
||
from app.main.views.jobs import get_status_filters
|
||
from app.models.service import Service
|
||
from tests import notification_json
|
||
from tests.conftest import (
|
||
SERVICE_ONE_ID,
|
||
create_active_caseworking_user,
|
||
create_active_user_view_permissions,
|
||
create_active_user_with_permissions,
|
||
create_notifications,
|
||
normalize_spaces,
|
||
)
|
||
|
||
|
||
@pytest.mark.parametrize(
|
||
(
|
||
"user",
|
||
"extra_args",
|
||
"expected_update_endpoint",
|
||
"expected_limit_days",
|
||
"page_title",
|
||
),
|
||
[
|
||
(
|
||
create_active_user_view_permissions(),
|
||
{"message_type": "email"},
|
||
"/email.json",
|
||
7,
|
||
"Emails",
|
||
),
|
||
(
|
||
create_active_user_view_permissions(),
|
||
{"message_type": "sms"},
|
||
"/sms.json",
|
||
7,
|
||
"Text message",
|
||
),
|
||
(
|
||
create_active_caseworking_user(),
|
||
{},
|
||
".json",
|
||
None,
|
||
"Sent messages",
|
||
),
|
||
],
|
||
)
|
||
@pytest.mark.parametrize(
|
||
("status_argument", "expected_api_call"),
|
||
[
|
||
(
|
||
"",
|
||
[
|
||
"created",
|
||
"pending",
|
||
"sending",
|
||
"delivered",
|
||
"sent",
|
||
"failed",
|
||
"temporary-failure",
|
||
"permanent-failure",
|
||
"technical-failure",
|
||
"validation-failed",
|
||
],
|
||
),
|
||
("sending", ["sending", "created", "pending"]),
|
||
("delivered", ["delivered", "sent"]),
|
||
(
|
||
"failed",
|
||
[
|
||
"failed",
|
||
"temporary-failure",
|
||
"permanent-failure",
|
||
"technical-failure",
|
||
"validation-failed",
|
||
],
|
||
),
|
||
],
|
||
)
|
||
@pytest.mark.parametrize(
|
||
("page_argument", "expected_page_argument"), [(1, 1), (22, 22), (None, 1)]
|
||
)
|
||
@pytest.mark.parametrize(
|
||
("to_argument", "expected_to_argument"),
|
||
[
|
||
("", ""),
|
||
("+12029000123", "+12029000123"),
|
||
("test@example.com", "test@example.com"),
|
||
],
|
||
)
|
||
@freeze_time("2020-01-01 06:00")
|
||
def test_can_show_notifications(
|
||
client_request,
|
||
service_one,
|
||
mock_get_notifications,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
mock_has_no_jobs,
|
||
mock_get_no_api_keys,
|
||
user,
|
||
extra_args,
|
||
expected_update_endpoint,
|
||
expected_limit_days,
|
||
page_title,
|
||
status_argument,
|
||
expected_api_call,
|
||
page_argument,
|
||
expected_page_argument,
|
||
to_argument,
|
||
expected_to_argument,
|
||
mocker,
|
||
):
|
||
client_request.login(user)
|
||
if expected_to_argument:
|
||
page = client_request.post(
|
||
"main.view_notifications",
|
||
service_id=SERVICE_ONE_ID,
|
||
status=status_argument,
|
||
page=page_argument,
|
||
_data={"to": to_argument},
|
||
_expected_status=200,
|
||
**extra_args
|
||
)
|
||
else:
|
||
page = client_request.get(
|
||
"main.view_notifications",
|
||
service_id=SERVICE_ONE_ID,
|
||
status=status_argument,
|
||
page=page_argument,
|
||
**extra_args
|
||
)
|
||
first_row = page.select_one("tbody tr")
|
||
assert normalize_spaces(
|
||
first_row.select_one("a.file-list-filename.usa-link").text
|
||
) == (
|
||
# Comes from
|
||
# https://github.com/alphagov/notifications-admin/blob/8faffad508f9a087b0006989c197741c693cc2e2/tests/__init__.py#L436
|
||
"2021234567"
|
||
)
|
||
assert normalize_spaces(
|
||
# We’re doing str() here not .text to make sure there’s no extra
|
||
# HTML sneaking in
|
||
str(first_row.select_one(".file-list-hint"))
|
||
) == (
|
||
# Comes from
|
||
# https://github.com/alphagov/notifications-admin/blob/8faffad508f9a087b0006989c197741c693cc2e2/tests/__init__.py#L271
|
||
"template content"
|
||
) or (
|
||
# Comes from
|
||
# https://github.com/alphagov/notifications-admin/blob/8faffad508f9a087b0006989c197741c693cc2e2/tests/__init__.py#L273
|
||
"template subject"
|
||
)
|
||
|
||
assert normalize_spaces(
|
||
first_row.select_one(".table-field-right-aligned .align-with-message-body").text
|
||
) in [
|
||
"Delivered 01-01-2020 at 01:00 AM",
|
||
"Delivered 01-01-2020 at 01:00 AM",
|
||
]
|
||
|
||
assert page_title in page.h1.text.strip()
|
||
|
||
json_response = client_request.get_response(
|
||
"main.get_notifications_as_json",
|
||
service_id=SERVICE_ONE_ID,
|
||
status=status_argument,
|
||
page=expected_page_argument,
|
||
to=expected_to_argument,
|
||
**extra_args
|
||
)
|
||
json_content = json.loads(json_response.get_data(as_text=True))
|
||
assert json_content.keys() == {
|
||
"counts",
|
||
"notifications",
|
||
"service_data_retention_days",
|
||
}
|
||
|
||
mock_get_notifications.assert_called()
|
||
|
||
|
||
def test_can_show_notifications_if_data_retention_not_available(
|
||
client_request,
|
||
mock_get_notifications,
|
||
mock_get_service_statistics,
|
||
mock_has_no_jobs,
|
||
mock_get_no_api_keys,
|
||
):
|
||
page = client_request.get(
|
||
"main.view_notifications",
|
||
service_id=SERVICE_ONE_ID,
|
||
status="sending,delivered,failed",
|
||
)
|
||
assert page.h1.text.strip() == "Messages"
|
||
|
||
|
||
@pytest.mark.parametrize(
|
||
("user", "query_parameters", "expected_download_link"),
|
||
[
|
||
(
|
||
create_active_user_with_permissions(),
|
||
{},
|
||
partial(
|
||
url_for,
|
||
".download_notifications_csv",
|
||
message_type=None,
|
||
number_of_days="seven_day",
|
||
),
|
||
),
|
||
(
|
||
create_active_user_with_permissions(),
|
||
{"status": "failed"},
|
||
partial(
|
||
url_for,
|
||
".download_notifications_csv",
|
||
status="failed",
|
||
number_of_days="seven_day",
|
||
),
|
||
),
|
||
(
|
||
create_active_user_with_permissions(),
|
||
{"message_type": "sms"},
|
||
partial(
|
||
url_for,
|
||
".download_notifications_csv",
|
||
message_type="sms",
|
||
number_of_days="seven_day",
|
||
),
|
||
),
|
||
(
|
||
create_active_user_view_permissions(),
|
||
{},
|
||
partial(url_for, ".download_notifications_csv", number_of_days="seven_day"),
|
||
),
|
||
(
|
||
create_active_caseworking_user(),
|
||
{},
|
||
lambda service_id: None,
|
||
),
|
||
],
|
||
)
|
||
def test_link_to_download_notifications(
|
||
client_request,
|
||
mock_get_notifications,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
mock_has_no_jobs,
|
||
mock_get_no_api_keys,
|
||
user,
|
||
query_parameters,
|
||
expected_download_link,
|
||
):
|
||
client_request.login(user)
|
||
page = client_request.get(
|
||
"main.view_notifications", service_id=SERVICE_ONE_ID, **query_parameters
|
||
)
|
||
download_link = page.select_one("a[download=download]")
|
||
assert (download_link["href"] if download_link else None) == expected_download_link(
|
||
service_id=SERVICE_ONE_ID
|
||
)
|
||
|
||
|
||
def test_download_links_show_when_data_available(
|
||
client_request,
|
||
service_one,
|
||
active_user_with_permissions,
|
||
mocker,
|
||
):
|
||
|
||
mock_jobs_with_data = {
|
||
"data": [{"id": "job1", "created_at": "2020-01-01T00:00:00.000000+00:00"}],
|
||
"total": 1,
|
||
"page_size": 50,
|
||
}
|
||
|
||
mocker.patch(
|
||
"app.job_api_client.get_page_of_jobs", return_value=mock_jobs_with_data
|
||
)
|
||
mocker.patch("app.job_api_client.get_immediate_jobs", return_value=[{"id": "job1"}])
|
||
mocker.patch("app.s3_client.check_s3_file_exists", return_value=True)
|
||
mock_obj = mocker.Mock()
|
||
mock_obj.content_length = 1024
|
||
mocker.patch("app.s3_client.get_s3_object", return_value=mock_obj)
|
||
mocker.patch("app.s3_client.s3_csv_client.get_csv_upload", return_value=mock_obj)
|
||
|
||
page = client_request.get(
|
||
"main.all_jobs_activity",
|
||
service_id=service_one["id"],
|
||
)
|
||
|
||
assert "Download recent reports" in page.text
|
||
assert "Yesterday" in page.text
|
||
assert "Last 3 days" in page.text
|
||
assert "Last 5 days" in page.text
|
||
assert "Last 7 days" in page.text
|
||
|
||
|
||
def test_download_links_partial_data_available(
|
||
client_request,
|
||
service_one,
|
||
active_user_with_permissions,
|
||
mocker,
|
||
):
|
||
mock_jobs_with_data = {
|
||
"data": [{"id": "job1", "created_at": "2020-01-01T00:00:00.000000+00:00"}],
|
||
"total": 1,
|
||
"page_size": 50,
|
||
}
|
||
mock_jobs_empty = {"data": [], "total": 0, "page_size": 50}
|
||
|
||
def mock_get_page_of_jobs(service_id, page=1, limit_days=None):
|
||
if limit_days in [1, 5]:
|
||
return mock_jobs_with_data
|
||
return mock_jobs_empty
|
||
|
||
mocker.patch(
|
||
"app.job_api_client.get_page_of_jobs", side_effect=mock_get_page_of_jobs
|
||
)
|
||
mocker.patch("app.job_api_client.get_immediate_jobs", return_value=[])
|
||
mocker.patch("app.s3_client.check_s3_file_exists", return_value=True)
|
||
mock_obj = mocker.Mock()
|
||
mock_obj.content_length = 2048
|
||
mocker.patch("app.s3_client.s3_csv_client.get_csv_upload", return_value=mock_obj)
|
||
mocker.patch("app.s3_client.get_s3_object", return_value=mock_obj)
|
||
|
||
page = client_request.get(
|
||
"main.all_jobs_activity",
|
||
service_id=service_one["id"],
|
||
)
|
||
|
||
assert "Download recent reports" in page.text
|
||
assert "Yesterday" in page.text
|
||
assert "Last 3 days" in page.text
|
||
assert "Last 5 days" in page.text
|
||
assert "Last 7 days" in page.text
|
||
assert "No recent activity to download" not in page.text
|
||
|
||
|
||
def test_download_links_no_data_available(
|
||
client_request,
|
||
service_one,
|
||
active_user_with_permissions,
|
||
mocker,
|
||
):
|
||
mock_jobs_empty = {"data": [], "total": 0, "page_size": 50}
|
||
|
||
mocker.patch("app.job_api_client.get_page_of_jobs", return_value=mock_jobs_empty)
|
||
mocker.patch("app.job_api_client.get_immediate_jobs", return_value=[])
|
||
mocker.patch("app.s3_client.check_s3_file_exists", return_value=False)
|
||
mock_obj = mocker.Mock()
|
||
mock_obj.content_length = 0
|
||
mocker.patch("app.s3_client.get_s3_object", return_value=mock_obj)
|
||
|
||
page = client_request.get(
|
||
"main.all_jobs_activity",
|
||
service_id=service_one["id"],
|
||
)
|
||
|
||
assert "Download recent reports" in page.text
|
||
assert "Yesterday" in page.text
|
||
assert "No messages sent" in page.text
|
||
assert "Last 3 days - No messages sent" in page.text
|
||
assert "Last 5 days - No messages sent" in page.text
|
||
assert "Last 7 days - No messages sent" in page.text
|
||
|
||
|
||
def test_download_not_available_to_users_without_dashboard(
|
||
client_request,
|
||
active_caseworking_user,
|
||
):
|
||
client_request.login(active_caseworking_user)
|
||
client_request.get(
|
||
"main.download_notifications_csv",
|
||
service_id=SERVICE_ONE_ID,
|
||
_expected_status=403,
|
||
)
|
||
|
||
|
||
def test_shows_message_when_no_notifications(
|
||
client_request,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
mock_get_notifications_with_no_notifications,
|
||
mock_get_no_api_keys,
|
||
):
|
||
page = client_request.get(
|
||
"main.view_notifications",
|
||
service_id=SERVICE_ONE_ID,
|
||
message_type="sms",
|
||
)
|
||
|
||
assert normalize_spaces(page.select("tbody tr")[0].text) == (
|
||
"No messages found (messages are kept for 7 days)"
|
||
)
|
||
|
||
|
||
@pytest.mark.parametrize(
|
||
(
|
||
"initial_query_arguments",
|
||
"form_post_data",
|
||
"expected_search_box_label",
|
||
"expected_search_box_contents",
|
||
),
|
||
[
|
||
(
|
||
{},
|
||
{},
|
||
"Search by recipient",
|
||
None,
|
||
),
|
||
(
|
||
{
|
||
"message_type": "sms",
|
||
},
|
||
{},
|
||
"Search by phone number",
|
||
None,
|
||
),
|
||
(
|
||
{
|
||
"message_type": "sms",
|
||
},
|
||
{
|
||
"to": "+33(0)5-12-34-56-78",
|
||
},
|
||
"Search by phone number",
|
||
"+33(0)5-12-34-56-78",
|
||
),
|
||
(
|
||
{
|
||
"status": "failed",
|
||
"message_type": "email",
|
||
"page": "99",
|
||
},
|
||
{
|
||
"to": "test@example.com",
|
||
},
|
||
"Search by email address",
|
||
"test@example.com",
|
||
),
|
||
],
|
||
)
|
||
def test_search_recipient_form(
|
||
client_request,
|
||
mock_get_notifications,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
mock_get_no_api_keys,
|
||
initial_query_arguments,
|
||
form_post_data,
|
||
expected_search_box_label,
|
||
expected_search_box_contents,
|
||
):
|
||
page = client_request.post(
|
||
"main.view_notifications",
|
||
service_id=SERVICE_ONE_ID,
|
||
_data=form_post_data,
|
||
_expected_status=200,
|
||
**initial_query_arguments
|
||
)
|
||
|
||
assert page.find("form")["method"] == "post"
|
||
action_url = page.find("form")["action"]
|
||
url = urlparse(action_url)
|
||
assert url.path == "/services/{}/notifications/{}".format(
|
||
SERVICE_ONE_ID, initial_query_arguments.get("message_type", "")
|
||
).rstrip("/")
|
||
query_dict = parse_qs(url.query)
|
||
assert query_dict == {}
|
||
|
||
assert (
|
||
page.select_one("label:contains('Search by')").text.strip()
|
||
== expected_search_box_label
|
||
)
|
||
|
||
recipient_inputs = page.select("input[name=to]")
|
||
assert len(recipient_inputs) == 2
|
||
|
||
for field in recipient_inputs:
|
||
assert field.get("value") == expected_search_box_contents
|
||
|
||
|
||
@pytest.mark.parametrize(
|
||
("message_type", "expected_search_box_label"),
|
||
[
|
||
(None, "Search by recipient or reference"),
|
||
("sms", "Search by phone number or reference"),
|
||
("email", "Search by email address or reference"),
|
||
],
|
||
)
|
||
def test_api_users_are_told_they_can_search_by_reference_when_service_has_api_keys(
|
||
client_request,
|
||
mocker,
|
||
fake_uuid,
|
||
mock_get_notifications,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
message_type,
|
||
expected_search_box_label,
|
||
mock_get_api_keys,
|
||
):
|
||
page = client_request.get(
|
||
"main.view_notifications",
|
||
service_id=SERVICE_ONE_ID,
|
||
message_type=message_type,
|
||
)
|
||
assert (
|
||
page.select_one("label:contains('Search by')").text.strip()
|
||
== expected_search_box_label
|
||
)
|
||
|
||
|
||
@pytest.mark.parametrize(
|
||
("message_type", "expected_search_box_label"),
|
||
[
|
||
(None, "Search by recipient"),
|
||
("sms", "Search by phone number"),
|
||
("email", "Search by email address"),
|
||
],
|
||
)
|
||
def test_api_users_are_not_told_they_can_search_by_reference_when_service_has_no_api_keys(
|
||
client_request,
|
||
mocker,
|
||
fake_uuid,
|
||
mock_get_notifications,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
message_type,
|
||
expected_search_box_label,
|
||
mock_get_no_api_keys,
|
||
):
|
||
page = client_request.get(
|
||
"main.view_notifications",
|
||
service_id=SERVICE_ONE_ID,
|
||
message_type=message_type,
|
||
)
|
||
|
||
assert (
|
||
page.select_one("label:contains('Search by')").text.strip()
|
||
== expected_search_box_label
|
||
)
|
||
|
||
|
||
def test_should_show_notifications_for_a_service_with_next_previous(
|
||
client_request,
|
||
service_one,
|
||
active_user_with_permissions,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
mock_get_no_api_keys,
|
||
mocker,
|
||
):
|
||
mocker.patch(
|
||
"app.notification_api_client.get_notifications_for_service",
|
||
return_value=notification_json(service_one["id"], rows=50, with_links=True)
|
||
| {"total": 150},
|
||
)
|
||
page = client_request.get(
|
||
"main.view_notifications",
|
||
service_id=service_one["id"],
|
||
message_type="sms",
|
||
page=2,
|
||
)
|
||
|
||
next_page_link = page.find("a", {"rel": "next"})
|
||
prev_page_link = page.find("a", {"rel": "previous"})
|
||
assert (
|
||
url_for(
|
||
"main.view_notifications",
|
||
service_id=service_one["id"],
|
||
message_type="sms",
|
||
page=3,
|
||
)
|
||
in next_page_link["href"]
|
||
)
|
||
assert "Next page" in next_page_link.text.strip()
|
||
assert "page 3" in next_page_link.text.strip()
|
||
assert (
|
||
url_for(
|
||
"main.view_notifications",
|
||
service_id=service_one["id"],
|
||
message_type="sms",
|
||
page=1,
|
||
)
|
||
in prev_page_link["href"]
|
||
)
|
||
assert "Previous page" in prev_page_link.text.strip()
|
||
assert "page 1" in prev_page_link.text.strip()
|
||
|
||
|
||
def test_doesnt_show_next_button_on_last_page(
|
||
client_request,
|
||
service_one,
|
||
active_user_with_permissions,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
mock_get_no_api_keys,
|
||
mocker,
|
||
):
|
||
mocker.patch(
|
||
"app.notification_api_client.get_notifications_for_service",
|
||
return_value=notification_json(service_one["id"], rows=50, with_links=True)
|
||
| {"total": 100},
|
||
)
|
||
page = client_request.get(
|
||
"main.view_notifications",
|
||
service_id=service_one["id"],
|
||
message_type="sms",
|
||
page=2,
|
||
)
|
||
|
||
next_page_link = page.find("a", {"rel": "next"})
|
||
prev_page_link = page.find("a", {"rel": "previous"})
|
||
|
||
assert next_page_link is None
|
||
assert prev_page_link is not None
|
||
|
||
|
||
def test_doesnt_show_pagination_when_50_or_fewer_items(
|
||
client_request,
|
||
service_one,
|
||
active_user_with_permissions,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
mock_get_no_api_keys,
|
||
mocker,
|
||
):
|
||
mocker.patch(
|
||
"app.notification_api_client.get_notifications_for_service",
|
||
return_value=notification_json(service_one["id"], rows=50, with_links=False),
|
||
)
|
||
page = client_request.get(
|
||
"main.view_notifications",
|
||
service_id=service_one["id"],
|
||
message_type="sms",
|
||
)
|
||
|
||
assert not page.find("a", {"rel": "next"})
|
||
assert not page.find("a", {"rel": "previous"})
|
||
assert not page.select_one(".table-show-more-link")
|
||
|
||
|
||
def test_doesnt_show_pagination_with_search_term(
|
||
client_request,
|
||
service_one,
|
||
active_user_with_permissions,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
mock_get_no_api_keys,
|
||
mocker,
|
||
):
|
||
mocker.patch(
|
||
"app.notification_api_client.get_notifications_for_service",
|
||
return_value=notification_json(service_one["id"], rows=50, with_links=True)
|
||
| {"total": 100},
|
||
)
|
||
page = client_request.post(
|
||
"main.view_notifications",
|
||
service_id=service_one["id"],
|
||
message_type="sms",
|
||
_data={
|
||
"to": "test@example.com",
|
||
},
|
||
_expected_status=200,
|
||
)
|
||
assert len(page.select("tbody tr")) == 50
|
||
assert not page.find("a", {"rel": "next"})
|
||
assert not page.find("a", {"rel": "previous"})
|
||
assert normalize_spaces(page.select_one(".table-show-more-link").text) == (
|
||
"Only showing the first 50 messages"
|
||
)
|
||
|
||
|
||
STATISTICS = {"sms": {"requested": 6, "failed": 2, "delivered": 1}}
|
||
|
||
|
||
def test_get_status_filters_calculates_stats(client_request):
|
||
ret = get_status_filters(Service({"id": "foo"}), "sms", STATISTICS)
|
||
|
||
assert {label: count for label, _option, _link, count in ret} == {
|
||
"total": 6,
|
||
"pending": 3,
|
||
"failed": 2,
|
||
"delivered": 1,
|
||
}
|
||
|
||
|
||
def test_get_status_filters_in_right_order(client_request):
|
||
ret = get_status_filters(Service({"id": "foo"}), "sms", STATISTICS)
|
||
|
||
assert [label for label, _option, _link, _count in ret] == [
|
||
"total",
|
||
"pending",
|
||
"delivered",
|
||
"failed",
|
||
]
|
||
|
||
|
||
def test_get_status_filters_constructs_links(client_request):
|
||
ret = get_status_filters(Service({"id": "foo"}), "sms", STATISTICS)
|
||
|
||
link = ret[0][2]
|
||
assert link == "/services/foo/notifications/sms?status={}".format(
|
||
"sending,delivered,failed"
|
||
)
|
||
|
||
|
||
def test_html_contains_notification_id(
|
||
client_request,
|
||
service_one,
|
||
active_user_with_permissions,
|
||
mock_get_notifications,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
mock_get_no_api_keys,
|
||
mocker,
|
||
):
|
||
page = client_request.get(
|
||
"main.view_notifications",
|
||
service_id=service_one["id"],
|
||
message_type="sms",
|
||
status="",
|
||
)
|
||
|
||
notifications = page.tbody.find_all("tr")
|
||
for tr in notifications:
|
||
assert uuid.UUID(tr.attrs["id"])
|
||
|
||
|
||
def test_html_contains_links_for_failed_notifications(
|
||
client_request,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
mock_get_no_api_keys,
|
||
mocker,
|
||
):
|
||
notifications = create_notifications(status="technical-failure")
|
||
mocker.patch(
|
||
"app.notification_api_client.get_notifications_for_service",
|
||
return_value=notifications,
|
||
)
|
||
|
||
response = client_request.get(
|
||
"main.view_notifications",
|
||
service_id=SERVICE_ONE_ID,
|
||
message_type="sms",
|
||
status="sending%2Cdelivered%2Cfailed",
|
||
)
|
||
notifications = response.tbody.find_all("tr")
|
||
for tr in notifications:
|
||
link_text = tr.find("div", class_="table-field-status-error").find("a").text
|
||
assert normalize_spaces(link_text) == "Technical failure"
|
||
|
||
|
||
@pytest.mark.parametrize(
|
||
("notification_type", "expected_row_contents"),
|
||
[
|
||
("sms", ("2021234567 hello & welcome hidden")),
|
||
("email", ("example@gsa.gov hidden, hello & welcome")),
|
||
],
|
||
)
|
||
def test_redacts_templates_that_should_be_redacted(
|
||
client_request,
|
||
mocker,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
mock_get_no_api_keys,
|
||
notification_type,
|
||
expected_row_contents,
|
||
):
|
||
notifications = create_notifications(
|
||
status="technical-failure",
|
||
content="hello & welcome ((name))",
|
||
subject="((name)), hello & welcome",
|
||
personalisation={"name": "Jo"},
|
||
redact_personalisation=True,
|
||
template_type=notification_type,
|
||
)
|
||
mocker.patch(
|
||
"app.notification_api_client.get_notifications_for_service",
|
||
return_value=notifications,
|
||
)
|
||
|
||
page = client_request.get(
|
||
"main.view_notifications",
|
||
service_id=SERVICE_ONE_ID,
|
||
message_type=notification_type,
|
||
)
|
||
|
||
assert normalize_spaces(page.select("tbody tr td")[0].text) == (
|
||
expected_row_contents
|
||
)
|
||
|
||
|
||
@freeze_time("2017-09-27 12:30:00.000000")
|
||
@pytest.mark.parametrize(
|
||
("message_type", "status", "expected_hint_status", "single_line"),
|
||
[
|
||
("email", "created", "Sending since 09-27-2017 at 08:30 AM", True),
|
||
("email", "sending", "Sending since 09-27-2017 at 08:30 AM", True),
|
||
(
|
||
"email",
|
||
"temporary-failure",
|
||
"Inbox not accepting messages right now 09-27-2017 at 08:30 AM",
|
||
False,
|
||
),
|
||
(
|
||
"email",
|
||
"permanent-failure",
|
||
"Email address does not exist 09-27-2017 at 08:30 AM",
|
||
False,
|
||
),
|
||
("email", "delivered", "Delivered 09-27-2017 at 08:30 AM", True),
|
||
("sms", "created", "Sending since 09-27-2017 at 08:30 AM", True),
|
||
("sms", "sending", "Sending since 09-27-2017 at 08:30 AM", True),
|
||
(
|
||
"sms",
|
||
"temporary-failure",
|
||
"Phone not accepting messages right now 09-27-2017 at 08:30 AM",
|
||
False,
|
||
),
|
||
(
|
||
"sms",
|
||
"permanent-failure",
|
||
"Not delivered 09-27-2017 at 08:30 AM",
|
||
False,
|
||
),
|
||
("sms", "delivered", "Delivered 09-27-2017 at 08:30 AM", True),
|
||
],
|
||
)
|
||
def test_sending_status_hint_displays_correctly_on_notifications_page(
|
||
client_request,
|
||
service_one,
|
||
mock_get_service_statistics,
|
||
mock_get_service_data_retention,
|
||
mock_get_no_api_keys,
|
||
message_type,
|
||
status,
|
||
expected_hint_status,
|
||
single_line,
|
||
mocker,
|
||
):
|
||
notifications = create_notifications(template_type=message_type, status=status)
|
||
mocker.patch(
|
||
"app.notification_api_client.get_notifications_for_service",
|
||
return_value=notifications,
|
||
)
|
||
|
||
page = client_request.get(
|
||
"main.view_notifications",
|
||
service_id=service_one["id"],
|
||
message_type=message_type,
|
||
)
|
||
|
||
assert (
|
||
normalize_spaces(page.select(".table-field-right-aligned")[0].text)
|
||
== expected_hint_status
|
||
)
|
||
assert bool(page.select(".align-with-message-body")) is single_line
|