2018-06-28 08:39:25 +01:00
|
|
|
from datetime import date, datetime
|
|
|
|
|
|
2019-08-22 17:48:24 +01:00
|
|
|
import pytest
|
2018-06-28 08:39:25 +01:00
|
|
|
from freezegun import freeze_time
|
|
|
|
|
|
2019-08-22 17:48:24 +01:00
|
|
|
from app.errors import InvalidRequest
|
2021-03-10 13:55:06 +00:00
|
|
|
from app.models import EMAIL_TYPE, SMS_TYPE
|
|
|
|
|
from app.platform_stats.rest import (
|
|
|
|
|
validate_date_range_is_within_a_financial_year,
|
|
|
|
|
)
|
2019-08-22 17:48:24 +01:00
|
|
|
from tests.app.db import (
|
2021-03-10 13:55:06 +00:00
|
|
|
create_ft_notification_status,
|
|
|
|
|
create_notification,
|
|
|
|
|
create_service,
|
|
|
|
|
create_template,
|
|
|
|
|
set_up_usage_data,
|
2019-08-22 17:48:24 +01:00
|
|
|
)
|
2018-12-04 13:55:56 +00:00
|
|
|
|
2018-06-28 08:39:25 +01:00
|
|
|
|
|
|
|
|
@freeze_time('2018-06-01')
|
2018-06-29 15:54:32 +01:00
|
|
|
def test_get_platform_stats_uses_todays_date_if_no_start_or_end_date_is_provided(admin_request, mocker):
|
2018-06-28 08:39:25 +01:00
|
|
|
today = datetime.now().date()
|
2018-12-03 13:59:25 +00:00
|
|
|
dao_mock = mocker.patch('app.platform_stats.rest.fetch_notification_status_totals_for_all_services')
|
2018-06-28 08:39:25 +01:00
|
|
|
mocker.patch('app.service.rest.statistics.format_statistics')
|
|
|
|
|
|
2018-06-29 15:54:32 +01:00
|
|
|
admin_request.get('platform_stats.get_platform_stats')
|
2018-06-28 08:39:25 +01:00
|
|
|
|
|
|
|
|
dao_mock.assert_called_once_with(start_date=today, end_date=today)
|
|
|
|
|
|
|
|
|
|
|
2018-06-29 15:54:32 +01:00
|
|
|
def test_get_platform_stats_can_filter_by_date(admin_request, mocker):
|
2018-06-28 08:39:25 +01:00
|
|
|
start_date = date(2017, 1, 1)
|
|
|
|
|
end_date = date(2018, 1, 1)
|
2018-12-03 13:59:25 +00:00
|
|
|
dao_mock = mocker.patch('app.platform_stats.rest.fetch_notification_status_totals_for_all_services')
|
2018-06-28 08:39:25 +01:00
|
|
|
mocker.patch('app.service.rest.statistics.format_statistics')
|
|
|
|
|
|
2018-06-29 15:54:32 +01:00
|
|
|
admin_request.get('platform_stats.get_platform_stats', start_date=start_date, end_date=end_date)
|
2018-06-28 08:39:25 +01:00
|
|
|
|
|
|
|
|
dao_mock.assert_called_once_with(start_date=start_date, end_date=end_date)
|
2018-06-29 15:54:32 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_get_platform_stats_validates_the_date(admin_request):
|
|
|
|
|
start_date = '1234-56-78'
|
|
|
|
|
|
|
|
|
|
response = admin_request.get(
|
|
|
|
|
'platform_stats.get_platform_stats', start_date=start_date,
|
|
|
|
|
_expected_status=400
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
assert response['errors'][0]['message'] == 'start_date time data {} does not match format %Y-%m-%d'.format(
|
|
|
|
|
start_date)
|
2018-12-04 13:55:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@freeze_time('2018-10-31 14:00')
|
|
|
|
|
def test_get_platform_stats_with_real_query(admin_request, notify_db_session):
|
|
|
|
|
service_1 = create_service(service_name='service_1')
|
|
|
|
|
sms_template = create_template(service=service_1, template_type=SMS_TYPE)
|
|
|
|
|
email_template = create_template(service=service_1, template_type=EMAIL_TYPE)
|
|
|
|
|
create_ft_notification_status(date(2018, 10, 29), 'sms', service_1, count=10)
|
|
|
|
|
create_ft_notification_status(date(2018, 10, 29), 'email', service_1, count=3)
|
|
|
|
|
|
|
|
|
|
create_notification(sms_template, created_at=datetime(2018, 10, 31, 11, 0, 0), key_type='test')
|
|
|
|
|
create_notification(sms_template, created_at=datetime(2018, 10, 31, 12, 0, 0), status='delivered')
|
|
|
|
|
create_notification(email_template, created_at=datetime(2018, 10, 31, 13, 0, 0), status='delivered')
|
|
|
|
|
|
|
|
|
|
response = admin_request.get(
|
|
|
|
|
'platform_stats.get_platform_stats', start_date=date(2018, 10, 29),
|
|
|
|
|
)
|
|
|
|
|
assert response == {
|
|
|
|
|
'email': {
|
|
|
|
|
'failures': {
|
|
|
|
|
'virus-scan-failed': 0, 'temporary-failure': 0, 'permanent-failure': 0, 'technical-failure': 0},
|
|
|
|
|
'total': 4, 'test-key': 0
|
|
|
|
|
},
|
|
|
|
|
'letter': {
|
|
|
|
|
'failures': {
|
|
|
|
|
'virus-scan-failed': 0, 'temporary-failure': 0, 'permanent-failure': 0, 'technical-failure': 0},
|
|
|
|
|
'total': 0, 'test-key': 0
|
|
|
|
|
},
|
|
|
|
|
'sms': {
|
|
|
|
|
'failures': {
|
|
|
|
|
'virus-scan-failed': 0, 'temporary-failure': 0, 'permanent-failure': 0, 'technical-failure': 0},
|
|
|
|
|
'total': 11, 'test-key': 1
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-08-22 17:48:24 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('start_date, end_date',
|
|
|
|
|
[('2019-04-01', '2019-06-30'),
|
|
|
|
|
('2019-08-01', '2019-09-30'),
|
|
|
|
|
('2019-01-01', '2019-03-31'),
|
|
|
|
|
('2019-12-01', '2020-02-28')])
|
2019-08-28 15:24:16 +01:00
|
|
|
def test_validate_date_range_is_within_a_financial_year(start_date, end_date):
|
|
|
|
|
validate_date_range_is_within_a_financial_year(start_date, end_date)
|
2019-08-22 17:48:24 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('start_date, end_date',
|
|
|
|
|
[('2019-04-01', '2020-06-30'),
|
|
|
|
|
('2019-01-01', '2019-04-30'),
|
|
|
|
|
('2019-12-01', '2020-04-30'),
|
|
|
|
|
('2019-03-31', '2019-04-01')])
|
2019-08-28 15:24:16 +01:00
|
|
|
def test_validate_date_range_is_within_a_financial_year_raises(start_date, end_date):
|
2019-08-22 17:48:24 +01:00
|
|
|
with pytest.raises(expected_exception=InvalidRequest) as e:
|
|
|
|
|
validate_date_range_is_within_a_financial_year(start_date, end_date)
|
2019-09-13 11:40:05 +01:00
|
|
|
assert e.value.message == 'Date must be in a single financial year.'
|
|
|
|
|
assert e.value.status_code == 400
|
2019-08-22 17:48:24 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_validate_date_is_within_a_financial_year_raises_validation_error():
|
|
|
|
|
start_date = '2019-08-01'
|
|
|
|
|
end_date = '2019-06-01'
|
|
|
|
|
|
|
|
|
|
with pytest.raises(expected_exception=InvalidRequest) as e:
|
|
|
|
|
validate_date_range_is_within_a_financial_year(start_date, end_date)
|
2019-09-13 11:40:05 +01:00
|
|
|
assert e.value.message == 'Start date must be before end date'
|
|
|
|
|
assert e.value.status_code == 400
|
2019-08-22 17:48:24 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('start_date, end_date',
|
|
|
|
|
[('22-01-2019', '2019-08-01'),
|
|
|
|
|
('2019-07-01', 'not-date')])
|
|
|
|
|
def test_validate_date_is_within_a_financial_year_when_input_is_not_a_date(start_date, end_date):
|
|
|
|
|
with pytest.raises(expected_exception=InvalidRequest) as e:
|
2019-09-13 11:40:05 +01:00
|
|
|
validate_date_range_is_within_a_financial_year(start_date, end_date)
|
|
|
|
|
assert e.value.message == 'Input must be a date in the format: YYYY-MM-DD'
|
|
|
|
|
assert e.value.status_code == 400
|
2019-08-22 17:48:24 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_get_usage_for_all_services(notify_db_session, admin_request):
|
2020-02-24 17:02:25 +00:00
|
|
|
org, org_2, service, service_2, service_3, service_sms_only, \
|
|
|
|
|
org_with_emails, service_with_emails = set_up_usage_data(datetime(2019, 5, 1))
|
2019-08-22 17:48:24 +01:00
|
|
|
response = admin_request.get("platform_stats.get_usage_for_all_services",
|
|
|
|
|
start_date='2019-05-01',
|
|
|
|
|
end_date='2019-06-30')
|
2019-08-23 17:02:44 +01:00
|
|
|
assert len(response) == 4
|
|
|
|
|
assert response[0]["organisation_id"] == str(org.id)
|
|
|
|
|
assert response[0]["service_id"] == str(service.id)
|
|
|
|
|
assert response[0]["sms_cost"] == 0
|
|
|
|
|
assert response[0]["sms_fragments"] == 0
|
|
|
|
|
assert response[0]["letter_cost"] == 3.40
|
|
|
|
|
assert response[0]["letter_breakdown"] == "6 second class letters at 45p\n2 first class letters at 35p\n"
|
2019-08-29 15:45:50 +01:00
|
|
|
|
|
|
|
|
assert response[1]["organisation_id"] == str(org_2.id)
|
|
|
|
|
assert response[1]["service_id"] == str(service_2.id)
|
|
|
|
|
assert response[1]["sms_cost"] == 0
|
|
|
|
|
assert response[1]["sms_fragments"] == 0
|
|
|
|
|
assert response[1]["letter_cost"] == 14
|
|
|
|
|
assert response[1]["letter_breakdown"] == "20 second class letters at 65p\n2 first class letters at 50p\n"
|
|
|
|
|
|
|
|
|
|
assert response[2]["organisation_id"] == ""
|
|
|
|
|
assert response[2]["service_id"] == str(service_sms_only.id)
|
|
|
|
|
assert response[2]["sms_cost"] == 0.33
|
|
|
|
|
assert response[2]["sms_fragments"] == 3
|
|
|
|
|
assert response[2]["letter_cost"] == 0
|
|
|
|
|
assert response[2]["letter_breakdown"] == ""
|
2019-08-23 17:02:44 +01:00
|
|
|
|
|
|
|
|
assert response[3]["organisation_id"] == ""
|
|
|
|
|
assert response[3]["service_id"] == str(service_3.id)
|
|
|
|
|
assert response[3]["sms_cost"] == 0
|
|
|
|
|
assert response[3]["sms_fragments"] == 0
|
2020-07-10 17:43:40 +01:00
|
|
|
assert response[3]["letter_cost"] == 24.45
|
|
|
|
|
assert response[3]["letter_breakdown"] == (
|
|
|
|
|
"2 second class letters at 35p\n1 first class letters at 50p\n15 international letters at £1.55\n"
|
|
|
|
|
)
|