mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-05-05 08:31:00 -04:00
Update get_notifications_for_service to make POST requests
This updates the `get_notifications_for_service` of the `NotificationApiClient` to make POST request to the api when the `to` field is provided. This is done so that we avoid logging personal details such as email addreses. If the `to` field is not present, the method will make a GET reqeust and there will be no change to how it works.
This commit is contained in:
committed by
Katie Smith
parent
444d844dfb
commit
04fa99b3dc
@@ -23,6 +23,10 @@ from tests import notification_json, single_notification_json
|
||||
{'include_from_test_key': True},
|
||||
{'url': '/service/abcd1234/notifications', 'params': {'include_from_test_key': True}}
|
||||
),
|
||||
(
|
||||
{'page': 48, 'limit_days': 3},
|
||||
{'url': '/service/abcd1234/notifications', 'params': {'page': 48, 'limit_days': 3}}
|
||||
),
|
||||
(
|
||||
{'job_id': 'efgh5678'},
|
||||
{'url': '/service/abcd1234/job/efgh5678/notifications', 'params': {}}
|
||||
@@ -30,7 +34,11 @@ from tests import notification_json, single_notification_json
|
||||
(
|
||||
{'job_id': 'efgh5678', 'page': 48},
|
||||
{'url': '/service/abcd1234/job/efgh5678/notifications', 'params': {'page': 48}}
|
||||
)
|
||||
),
|
||||
(
|
||||
{'job_id': 'efgh5678', 'page': 48, 'limit_days': 3},
|
||||
{'url': '/service/abcd1234/job/efgh5678/notifications', 'params': {'page': 48}}
|
||||
),
|
||||
])
|
||||
def test_client_gets_notifications_for_service_and_job_by_page(mocker, arguments, expected_call):
|
||||
|
||||
@@ -39,6 +47,35 @@ def test_client_gets_notifications_for_service_and_job_by_page(mocker, arguments
|
||||
mock_get.assert_called_once_with(**expected_call)
|
||||
|
||||
|
||||
@pytest.mark.parametrize("arguments,expected_call", [
|
||||
(
|
||||
{'to': "0793433"},
|
||||
{'url': '/service/abcd1234/notifications', 'data': {'to': "0793433"}}
|
||||
),
|
||||
(
|
||||
{'to': "0793433", 'job_id': 'efgh5678'},
|
||||
{'url': '/service/abcd1234/job/efgh5678/notifications', 'data': {'to': "0793433"}}
|
||||
),
|
||||
(
|
||||
{'to': "0793433", 'page': 99},
|
||||
{'url': '/service/abcd1234/notifications', 'data': {'to': "0793433", 'page': 99}}
|
||||
),
|
||||
(
|
||||
{'to': "0793433", 'limit_days': 3},
|
||||
{'url': '/service/abcd1234/notifications', 'data': {'to': "0793433", 'limit_days': 3}}
|
||||
),
|
||||
(
|
||||
{'to': "0793433", 'job_id': 'efgh5678', 'limit_days': 3},
|
||||
{'url': '/service/abcd1234/job/efgh5678/notifications', 'data': {'to': "0793433"}}
|
||||
),
|
||||
])
|
||||
def test_client_gets_notifications_for_service_and_job_by_page_posts_for_to(mocker, arguments, expected_call):
|
||||
|
||||
mock_post = mocker.patch('app.notify_client.notification_api_client.NotificationApiClient.post')
|
||||
NotificationApiClient().get_notifications_for_service('abcd1234', **arguments)
|
||||
mock_post.assert_called_once_with(**expected_call)
|
||||
|
||||
|
||||
def test_send_notification(mocker, logged_in_client, active_user_with_permissions):
|
||||
mock_post = mocker.patch('app.notify_client.notification_api_client.NotificationApiClient.post')
|
||||
NotificationApiClient().send_notification(
|
||||
|
||||
Reference in New Issue
Block a user