mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-07-02 15:38:19 -04:00
fixing testing
This commit is contained in:
@@ -126,18 +126,12 @@ def test_service_navigation_for_org_user(
|
||||
[
|
||||
(
|
||||
[],
|
||||
(
|
||||
"Send messages",
|
||||
"Sent messages",
|
||||
),
|
||||
("Send messages",),
|
||||
403,
|
||||
),
|
||||
(
|
||||
[ORGANISATION_ID],
|
||||
(
|
||||
"Send messages",
|
||||
"Sent messages",
|
||||
),
|
||||
("Send messages",),
|
||||
200,
|
||||
),
|
||||
],
|
||||
|
||||
@@ -1,865 +0,0 @@
|
||||
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
|
||||
@@ -80,7 +80,7 @@ def test_missing_s3_file_redirects_gracefully(
|
||||
service_id=SERVICE_ONE_ID,
|
||||
number_of_days="five_day",
|
||||
message_type="sms",
|
||||
_expected_redirect=f"/services/{SERVICE_ONE_ID}/notifications/sms?status=sending,delivered,failed",
|
||||
_expected_redirect=f"/activity/services/{SERVICE_ONE_ID}",
|
||||
)
|
||||
|
||||
# The redirect happens, which means no 500 error occurred
|
||||
|
||||
@@ -254,3 +254,119 @@ def test_all_activity_filters(client_request, mocker, filter_type, expected_limi
|
||||
)
|
||||
else:
|
||||
mock_get_page_of_jobs.assert_any_call(SERVICE_ONE_ID, page=current_page)
|
||||
|
||||
|
||||
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,
|
||||
)
|
||||
|
||||
@@ -177,9 +177,7 @@ def test_notification_status_page_respects_redaction(
|
||||
{},
|
||||
partial(
|
||||
url_for,
|
||||
"main.view_notifications",
|
||||
message_type="sms",
|
||||
status="sending,delivered,failed",
|
||||
"main.all_jobs_activity",
|
||||
),
|
||||
),
|
||||
(
|
||||
|
||||
@@ -104,7 +104,6 @@ EXCLUDED_ENDPOINTS = tuple(
|
||||
"get_daily_stats_by_user",
|
||||
"get_volumes_by_service",
|
||||
"get_example_csv",
|
||||
"get_notifications_as_json",
|
||||
"get_redis_report",
|
||||
"get_started",
|
||||
"get_started_old",
|
||||
@@ -243,8 +242,6 @@ EXCLUDED_ENDPOINTS = tuple(
|
||||
"view_jobs",
|
||||
"view_notification",
|
||||
"view_notification_updates",
|
||||
"view_notifications",
|
||||
"view_notifications_csv",
|
||||
"view_template",
|
||||
"view_template_version",
|
||||
"view_template_versions",
|
||||
|
||||
@@ -22,10 +22,8 @@ def test_generate_next_dict(client_request):
|
||||
|
||||
|
||||
def test_generate_previous_next_dict_adds_other_url_args(client_request):
|
||||
result = generate_next_dict(
|
||||
"main.view_notifications", "foo", 2, {"message_type": "blah"}
|
||||
)
|
||||
assert "notifications/blah" in result["url"]
|
||||
result = generate_next_dict("main.view_jobs", "foo", 2, {"status": "pending"})
|
||||
assert "status=pending" in result["url"]
|
||||
|
||||
|
||||
@pytest.mark.parametrize(
|
||||
|
||||
Reference in New Issue
Block a user