mirror of
https://github.com/GSA/notifications-api.git
synced 2025-12-24 01:11:38 -05:00
- Only rebuild current month for monthly_billing if today is in the current year.
- Change the usage queries to a union so that billing_units is correct for all notification types. Removing the business logic from the schema. - Added tests for different fragment counts, rates and sheet counts.
This commit is contained in:
@@ -522,6 +522,7 @@ def set_up_yearly_data():
|
||||
service=service,
|
||||
template=email_template,
|
||||
notification_type='email',
|
||||
billable_unit=0,
|
||||
rate=0)
|
||||
create_ft_billing(bst_date='2016-{}-{}'.format(mon, d),
|
||||
service=service,
|
||||
@@ -559,7 +560,7 @@ def set_up_yearly_data():
|
||||
return service
|
||||
|
||||
|
||||
def test_get_yearly_billing_usage_summary_from_ft_billing_comapre_to_monthyl_billing(
|
||||
def test_get_yearly_billing_usage_summary_from_ft_billing_compare_to_monthly_billing(
|
||||
client, notify_db_session
|
||||
):
|
||||
service = set_up_yearly_data()
|
||||
@@ -621,3 +622,147 @@ def test_get_yearly_billing_usage_summary_from_ft_billing(client, notify_db_sess
|
||||
assert json_response[2]['billing_units'] == 825
|
||||
assert json_response[2]['rate'] == 0.0162
|
||||
assert json_response[2]['letter_total'] == 0
|
||||
|
||||
|
||||
def test_get_yearly_usage_by_monthly_from_ft_billing_all_cases(client, notify_db_session):
|
||||
service = set_up_data_for_all_cases()
|
||||
response = client.get('service/{}/billing/ft-monthly-usage?year=2018'.format(service.id),
|
||||
headers=[('Content-Type', 'application/json'), create_authorization_header()])
|
||||
|
||||
assert response.status_code == 200
|
||||
json_response = json.loads(response.get_data(as_text=True))
|
||||
assert len(json_response) == 5
|
||||
assert json_response[0]['month'] == 'May'
|
||||
assert json_response[0]['notification_type'] == 'letter'
|
||||
assert json_response[0]['rate'] == 0.33
|
||||
assert json_response[0]['billing_units'] == 1
|
||||
|
||||
assert json_response[1]['month'] == 'May'
|
||||
assert json_response[1]['notification_type'] == 'letter'
|
||||
assert json_response[1]['rate'] == 0.36
|
||||
assert json_response[1]['billing_units'] == 1
|
||||
|
||||
assert json_response[2]['month'] == 'May'
|
||||
assert json_response[2]['notification_type'] == 'letter'
|
||||
assert json_response[2]['rate'] == 0.39
|
||||
assert json_response[2]['billing_units'] == 1
|
||||
|
||||
assert json_response[3]['month'] == 'May'
|
||||
assert json_response[3]['notification_type'] == 'sms'
|
||||
assert json_response[3]['rate'] == 0.0150
|
||||
assert json_response[3]['billing_units'] == 4
|
||||
|
||||
assert json_response[4]['month'] == 'May'
|
||||
assert json_response[4]['notification_type'] == 'sms'
|
||||
assert json_response[4]['rate'] == 0.162
|
||||
assert json_response[4]['billing_units'] == 5
|
||||
|
||||
|
||||
def test_get_yearly_billing_usage_summary_from_ft_billing_all_cases(client, notify_db_session):
|
||||
service = set_up_data_for_all_cases()
|
||||
response = client.get('/service/{}/billing/ft-yearly-usage-summary?year=2018'.format(service.id),
|
||||
headers=[create_authorization_header()])
|
||||
assert response.status_code == 200
|
||||
json_response = json.loads(response.get_data(as_text=True))
|
||||
|
||||
assert len(json_response) == 6
|
||||
assert json_response[0]["notification_type"] == 'email'
|
||||
assert json_response[0]["billing_units"] == 1
|
||||
assert json_response[0]["rate"] == 0
|
||||
assert json_response[0]["letter_total"] == 0
|
||||
|
||||
assert json_response[1]["notification_type"] == 'letter'
|
||||
assert json_response[1]["billing_units"] == 1
|
||||
assert json_response[1]["rate"] == 0.33
|
||||
assert json_response[1]["letter_total"] == 0.33
|
||||
|
||||
assert json_response[2]["notification_type"] == 'letter'
|
||||
assert json_response[2]["billing_units"] == 1
|
||||
assert json_response[2]["rate"] == 0.36
|
||||
assert json_response[2]["letter_total"] == 0.36
|
||||
|
||||
assert json_response[3]["notification_type"] == 'letter'
|
||||
assert json_response[3]["billing_units"] == 1
|
||||
assert json_response[3]["rate"] == 0.39
|
||||
assert json_response[3]["letter_total"] == 0.39
|
||||
|
||||
assert json_response[4]["notification_type"] == 'sms'
|
||||
assert json_response[4]["billing_units"] == 4
|
||||
assert json_response[4]["rate"] == 0.0150
|
||||
assert json_response[4]["letter_total"] == 0
|
||||
|
||||
assert json_response[5]["notification_type"] == 'sms'
|
||||
assert json_response[5]["billing_units"] == 5
|
||||
assert json_response[5]["rate"] == 0.162
|
||||
assert json_response[5]["letter_total"] == 0
|
||||
|
||||
|
||||
def set_up_data_for_all_cases():
|
||||
service = create_service()
|
||||
sms_template = create_template(service=service, template_type="sms")
|
||||
email_template = create_template(service=service, template_type="email")
|
||||
letter_template = create_template(service=service, template_type="letter")
|
||||
create_ft_billing(bst_date='2018-05-16',
|
||||
notification_type='sms',
|
||||
template=sms_template,
|
||||
service=service,
|
||||
rate_multiplier=1,
|
||||
international=False,
|
||||
rate=0.162,
|
||||
billable_unit=1,
|
||||
notifications_sent=1)
|
||||
create_ft_billing(bst_date='2018-05-17',
|
||||
notification_type='sms',
|
||||
template=sms_template,
|
||||
service=service,
|
||||
rate_multiplier=2,
|
||||
international=False,
|
||||
rate=0.162,
|
||||
billable_unit=2,
|
||||
notifications_sent=1)
|
||||
create_ft_billing(bst_date='2018-05-16',
|
||||
notification_type='sms',
|
||||
template=sms_template,
|
||||
service=service,
|
||||
rate_multiplier=2,
|
||||
international=False,
|
||||
rate=0.0150,
|
||||
billable_unit=2,
|
||||
notifications_sent=1)
|
||||
create_ft_billing(bst_date='2018-05-16',
|
||||
notification_type='email',
|
||||
template=email_template,
|
||||
service=service,
|
||||
rate_multiplier=1,
|
||||
international=False,
|
||||
rate=0,
|
||||
billable_unit=0,
|
||||
notifications_sent=1)
|
||||
create_ft_billing(bst_date='2018-05-16',
|
||||
notification_type='letter',
|
||||
template=letter_template,
|
||||
service=service,
|
||||
rate_multiplier=1,
|
||||
international=False,
|
||||
rate=0.33,
|
||||
billable_unit=1,
|
||||
notifications_sent=1)
|
||||
create_ft_billing(bst_date='2018-05-17',
|
||||
notification_type='letter',
|
||||
template=letter_template,
|
||||
service=service,
|
||||
rate_multiplier=1,
|
||||
international=False,
|
||||
rate=0.36,
|
||||
billable_unit=2,
|
||||
notifications_sent=1)
|
||||
create_ft_billing(bst_date='2018-05-18',
|
||||
notification_type='letter',
|
||||
template=letter_template,
|
||||
service=service,
|
||||
rate_multiplier=1,
|
||||
international=False,
|
||||
rate=0.39,
|
||||
billable_unit=3,
|
||||
notifications_sent=1)
|
||||
return service
|
||||
|
||||
@@ -266,14 +266,12 @@ def test_fetch_monthly_billing_for_year(notify_db_session):
|
||||
assert str(results[0].month) == "2018-06-01"
|
||||
assert results[0].notifications_sent == 30
|
||||
assert results[0].billable_units == Decimal('60')
|
||||
assert results[0].service_id == service.id
|
||||
assert results[0].rate == Decimal('0.162')
|
||||
assert results[0].notification_type == 'sms'
|
||||
|
||||
assert str(results[1].month) == "2018-07-01"
|
||||
assert results[1].notifications_sent == 31
|
||||
assert results[1].billable_units == Decimal('31')
|
||||
assert results[1].service_id == service.id
|
||||
assert results[1].rate == Decimal('0.158')
|
||||
assert results[1].notification_type == 'sms'
|
||||
|
||||
@@ -330,19 +328,16 @@ def test_fetch_billing_totals_for_year(notify_db_session):
|
||||
|
||||
assert len(results) == 3
|
||||
assert results[0].notification_type == 'email'
|
||||
assert results[0].service_id == service.id
|
||||
assert results[0].notifications_sent == 365
|
||||
assert results[0].billable_units == 365
|
||||
assert results[0].rate == Decimal('0')
|
||||
|
||||
assert results[1].notification_type == 'letter'
|
||||
assert results[1].service_id == service.id
|
||||
assert results[1].notifications_sent == 365
|
||||
assert results[1].billable_units == 365
|
||||
assert results[1].rate == Decimal('0.33')
|
||||
|
||||
assert results[2].notification_type == 'sms'
|
||||
assert results[2].service_id == service.id
|
||||
assert results[2].notifications_sent == 365
|
||||
assert results[2].billable_units == 365
|
||||
assert results[2].rate == Decimal('0.162')
|
||||
|
||||
@@ -511,3 +511,13 @@ def test_get_yearly_billing_data_for_year_includes_current_day_totals(sample_tem
|
||||
)
|
||||
|
||||
assert billing_data[0].monthly_totals[0]['billing_units'] == 3
|
||||
|
||||
|
||||
@freeze_time("2017-06-16 13:00:00")
|
||||
def test_get_billing_data_for_financial_year_updated_monthly_billing_if_today_is_in_current_year(
|
||||
sample_service,
|
||||
mocker
|
||||
):
|
||||
mock = mocker.patch("app.dao.monthly_billing_dao.create_or_update_monthly_billing")
|
||||
get_billing_data_for_financial_year(sample_service.id, 2016)
|
||||
mock.assert_not_called()
|
||||
|
||||
Reference in New Issue
Block a user