diff --git a/app/main/views/jobs.py b/app/main/views/jobs.py index 749fbfa31..f26203d75 100644 --- a/app/main/views/jobs.py +++ b/app/main/views/jobs.py @@ -78,13 +78,14 @@ def view_job(service_id, job_id): filter_args = _parse_filter_args(request.args) filter_args['status'] = _set_status_filters(filter_args) + finished = ( + bool(job.get('notification_count', 0) and (( + job.get('notifications_delivered', 0) + + job.get('notifications_failed', 0) + ) == job.get('notification_count', 0)))) return render_template( 'views/jobs/job.html', - finished=job.get('notifications_sent', 0) and (( - job.get('notifications_sent', 0) - - job.get('notifications_delivered', 0) - - job.get('notifications_failed', 0) - ) == 0), + finished=finished, uploaded_file_name=job['original_file_name'], template=Template( service_api_client.get_service_template( diff --git a/app/notify_client/job_api_client.py b/app/notify_client/job_api_client.py index 9225d7b69..4cd4eadf4 100644 --- a/app/notify_client/job_api_client.py +++ b/app/notify_client/job_api_client.py @@ -21,8 +21,8 @@ class JobApiClient(BaseAPIClient): 'delivered': 0, 'failed': 0 } - if 'statistics' in job: - for outcome in job['statistics']: + if 'statistics' in job['data']: + for outcome in job['data']['statistics']: if outcome['status'] in ['failed', 'technical-failure', 'temporary-failure', 'permanent-failure']: results['failed'] += outcome['count'] if outcome['status'] in ['sending', 'pending', 'created']: @@ -37,10 +37,9 @@ class JobApiClient(BaseAPIClient): if status is not None: params['status'] = status job = self.get(url='/service/{}/job/{}'.format(service_id, job_id), params=params) - if 'notifications_sent' not in job['data']: stats = self.__convert_statistics(job) - job['data']['notifications_sent'] = stats['sending'] + job['data']['notifications_sent'] = stats['delivered'] + stats['failed'] job['data']['notifications_delivered'] = stats['delivered'] job['data']['notifications_failed'] = stats['failed'] return job @@ -59,12 +58,12 @@ class JobApiClient(BaseAPIClient): "notification_count": notification_count } data = _attach_current_user(data) - resp = self.post(url='/service/{}/job'.format(service_id), data=data) + job = self.post(url='/service/{}/job'.format(service_id), data=data) - if 'notifications_sent' not in resp['data']: - stats = self.__convert_statistics(resp) - resp['data']['notifications_sent'] = stats['sending'] - resp['data']['notifications_delivered'] = stats['delivered'] - resp['data']['notifications_failed'] = stats['failed'] + if 'notifications_sent' not in job['data']: + stats = self.__convert_statistics(job) + job['data']['notifications_sent'] = stats['delivered'] + stats['failed'] + job['data']['notifications_delivered'] = stats['delivered'] + job['data']['notifications_failed'] = stats['failed'] - return resp + return job diff --git a/tests/app/notify_client/test_job_client.py b/tests/app/notify_client/test_job_client.py index 442997135..154732d55 100644 --- a/tests/app/notify_client/test_job_client.py +++ b/tests/app/notify_client/test_job_client.py @@ -25,3 +25,96 @@ def test_client_creates_job_data_correctly(mocker, fake_uuid): client.create_job(job_id, service_id, template_id, original_file_name, notification_count) mock_post.assert_called_once_with(url=expected_url, data=expected_data) + + +def test_client_gets_job_by_service_and_job(mocker): + mocker.patch('app.notify_client.current_user', id='1') + + service_id = 'service_id' + job_id = 'job_id' + + expected_url = '/service/{}/job/{}'.format(service_id, job_id) + + client = JobApiClient() + mock_get = mocker.patch('app.notify_client.job_api_client.JobApiClient.get') + + client.get_job(service_id, job_id) + + mock_get.assert_called_once_with(url=expected_url, params={}) + + +def test_client_gets_job_by_service_and_job_filtered_by_status(mocker): + mocker.patch('app.notify_client.current_user', id='1') + + service_id = 'service_id' + job_id = 'job_id' + + expected_url = '/service/{}/job/{}'.format(service_id, job_id) + + client = JobApiClient() + mock_get = mocker.patch('app.notify_client.job_api_client.JobApiClient.get') + + client.get_job(service_id, job_id, limit_days=1, status='failed') + + mock_get.assert_called_once_with(url=expected_url, params={'status': 'failed'}) + + +def test_client_gets_job_by_service_filtered_by_status(mocker): + mocker.patch('app.notify_client.current_user', id='1') + + service_id = 'service_id' + + expected_url = '/service/{}/job'.format(service_id) + + client = JobApiClient() + mock_get = mocker.patch('app.notify_client.job_api_client.JobApiClient.get') + + client.get_job(service_id, limit_days=1, status='failed') + + mock_get.assert_called_once_with(url=expected_url, params={'limit_days': 1}) + + +def test_client_parses_job_stats(mocker): + mocker.patch('app.notify_client.current_user', id='1') + + service_id = 'service_id' + job_id = 'job_id' + expected_data = {'data': { + 'status': 'finished', + 'template_version': 3, + 'id': job_id, + 'updated_at': '2016-08-24T08:29:28.332972+00:00', + 'service': service_id, + 'processing_finished': '2016-08-24T08:11:48.676365+00:00', + 'statistics': [ + {'status': 'failed', 'count': 10}, + {'status': 'technical-failure', 'count': 10}, + {'status': 'temporary-failure', 'count': 10}, + {'status': 'permanent-failure', 'count': 10}, + {'status': 'created', 'count': 10}, + {'status': 'sending', 'count': 10}, + {'status': 'pending', 'count': 10}, + {'status': 'delivered', 'count': 10} + ], + 'original_file_name': 'test-notify-email.csv', + 'created_by': { + 'name': 'test-user@digital.cabinet-office.gov.uk', + 'id': '3571f2ae-7a39-4fb4-9ad7-8453f5257072' + }, + 'created_at': '2016-08-24T08:09:56.371073+00:00', + 'template': 'c0309261-9c9e-4530-8fed-5f67b02260d2', + 'notification_count': 80, + 'processing_started': '2016-08-24T08:09:57.661246+00:00' + }} + + expected_url = '/service/{}/job/{}'.format(service_id, job_id) + + client = JobApiClient() + mock_get = mocker.patch('app.notify_client.job_api_client.JobApiClient.get', return_value=expected_data) + + result = client.get_job(service_id, job_id) + + mock_get.assert_called_once_with(url=expected_url, params={}) + assert result['data']['notifications_sent'] == 50 + assert result['data']['notification_count'] == 80 + assert result['data']['notifications_failed'] == 40