mirror of
https://github.com/GSA/notifications-api.git
synced 2025-12-20 15:31:15 -05:00
fixed object persistence problem
This commit is contained in:
@@ -13,8 +13,7 @@ from app.models import SMS_TYPE, EMAIL_TYPE
|
|||||||
from app.utils import convert_utc_to_bst
|
from app.utils import convert_utc_to_bst
|
||||||
from app.dao.annual_billing_dao import (dao_get_free_sms_fragment_limit_for_year,
|
from app.dao.annual_billing_dao import (dao_get_free_sms_fragment_limit_for_year,
|
||||||
dao_get_all_free_sms_fragment_limit,
|
dao_get_all_free_sms_fragment_limit,
|
||||||
dao_create_new_annual_billing_for_year,
|
dao_create_or_update_annual_billing_for_year)
|
||||||
dao_update_new_free_sms_fragment_limit_for_year)
|
|
||||||
from app.billing.billing_schemas import create_or_update_free_sms_fragment_limit_schema
|
from app.billing.billing_schemas import create_or_update_free_sms_fragment_limit_schema
|
||||||
from app.errors import InvalidRequest
|
from app.errors import InvalidRequest
|
||||||
from app.schema_validation import validate
|
from app.schema_validation import validate
|
||||||
@@ -96,17 +95,6 @@ def _transform_billing_for_month(billing_for_month):
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
# @billing_blueprint.route('/annual-billing', methods=["GET"])
|
|
||||||
# def get_annual_billing(service_id):
|
|
||||||
#
|
|
||||||
# results = dao_get_annual_billing(service_id)
|
|
||||||
#
|
|
||||||
# if len(results)==0:
|
|
||||||
# raise InvalidRequest('no annual billing information for this service', status_code=404)
|
|
||||||
#
|
|
||||||
# return jsonify(data=[row.serialize() for row in results]), 200
|
|
||||||
|
|
||||||
|
|
||||||
@billing_blueprint.route('/free-sms-fragment-limit', methods=["GET"])
|
@billing_blueprint.route('/free-sms-fragment-limit', methods=["GET"])
|
||||||
def get_free_sms_fragment_limit(service_id):
|
def get_free_sms_fragment_limit(service_id):
|
||||||
|
|
||||||
@@ -136,13 +124,13 @@ def create_or_update_free_sms_fragment_limit(service_id):
|
|||||||
|
|
||||||
result = dao_get_free_sms_fragment_limit_for_year(service_id, financial_year_start)
|
result = dao_get_free_sms_fragment_limit_for_year(service_id, financial_year_start)
|
||||||
|
|
||||||
annual_billing = AnnualBilling(service_id=service_id, financial_year_start=financial_year_start,
|
if result:
|
||||||
free_sms_fragment_limit=free_sms_fragment_limit)
|
result.free_sms_fragment_limit = free_sms_fragment_limit
|
||||||
|
dao_create_or_update_annual_billing_for_year(result)
|
||||||
if result is None:
|
|
||||||
dao_create_new_annual_billing_for_year(annual_billing)
|
|
||||||
|
|
||||||
else:
|
else:
|
||||||
dao_update_new_free_sms_fragment_limit_for_year(annual_billing)
|
annual_billing = AnnualBilling(service_id=service_id, financial_year_start=financial_year_start,
|
||||||
|
free_sms_fragment_limit=free_sms_fragment_limit)
|
||||||
|
dao_create_or_update_annual_billing_for_year(annual_billing)
|
||||||
|
|
||||||
return jsonify(data=form), 201
|
return jsonify(data=form), 201
|
||||||
|
|||||||
@@ -13,8 +13,9 @@ def dao_get_annual_billing(service_id):
|
|||||||
).all()
|
).all()
|
||||||
|
|
||||||
|
|
||||||
def dao_create_new_annual_billing_for_year(annual_billing):
|
def dao_create_or_update_annual_billing_for_year(annual_billing):
|
||||||
annual_billing.id = create_uuid()
|
if annual_billing.id is None:
|
||||||
|
annual_billing.id = create_uuid()
|
||||||
db.session.add(annual_billing)
|
db.session.add(annual_billing)
|
||||||
db.session.commit()
|
db.session.commit()
|
||||||
|
|
||||||
@@ -32,8 +33,3 @@ def dao_get_all_free_sms_fragment_limit(service_id):
|
|||||||
return AnnualBilling.query.filter_by(
|
return AnnualBilling.query.filter_by(
|
||||||
service_id=service_id,
|
service_id=service_id,
|
||||||
).all()
|
).all()
|
||||||
|
|
||||||
|
|
||||||
def dao_update_new_free_sms_fragment_limit_for_year(annual_billing):
|
|
||||||
db.session.add(annual_billing)
|
|
||||||
db.session.commit()
|
|
||||||
|
|||||||
@@ -14,7 +14,8 @@ from tests.app.db import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
from tests import create_authorization_header
|
from tests import create_authorization_header
|
||||||
from app.dao.annual_billing_dao import dao_get_free_sms_fragment_limit_for_year, dao_create_new_annual_billing_for_year
|
from app.dao.annual_billing_dao import (dao_get_free_sms_fragment_limit_for_year,
|
||||||
|
dao_create_or_update_annual_billing_for_year)
|
||||||
from app.models import AnnualBilling
|
from app.models import AnnualBilling
|
||||||
|
|
||||||
APR_2016_MONTH_START = datetime(2016, 3, 31, 23, 00, 00)
|
APR_2016_MONTH_START = datetime(2016, 3, 31, 23, 00, 00)
|
||||||
@@ -255,36 +256,6 @@ def test_transform_billing_calculates_with_different_rate_multipliers(sample_ser
|
|||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
# def test_get_annual_billing(client, sample_service):
|
|
||||||
#
|
|
||||||
# years = [2016, 2017, 2018]
|
|
||||||
# for y in years:
|
|
||||||
# data = AnnualBilling(
|
|
||||||
# free_sms_fragment_limit=250000,
|
|
||||||
# financial_year_start=y,
|
|
||||||
# service_id=sample_service.id,
|
|
||||||
# )
|
|
||||||
# dao_create_new_free_sms_fragment_limit_for_year(data)
|
|
||||||
#
|
|
||||||
# response = client.get('service/{}/annual-billing'.format(sample_service.id),
|
|
||||||
# headers=[('Content-Type', 'application/json'), create_authorization_header()])
|
|
||||||
#
|
|
||||||
# json_resp = json.loads(response.get_data(as_text=True))
|
|
||||||
#
|
|
||||||
# assert len(json_resp['data']) == 3
|
|
||||||
# assert response.status_code == 200
|
|
||||||
#
|
|
||||||
#
|
|
||||||
# def test_get_annual_billing_no_data_throws_error(client, sample_service):
|
|
||||||
#
|
|
||||||
# response = client.get('service/{}/annual-billing'.format(sample_service.id),
|
|
||||||
# headers=[('Content-Type', 'application/json'), create_authorization_header()])
|
|
||||||
#
|
|
||||||
# json_resp = json.loads(response.get_data(as_text=True))
|
|
||||||
#
|
|
||||||
# assert response.status_code == 404
|
|
||||||
|
|
||||||
|
|
||||||
def test_get_free_sms_fragment_limit(client, sample_service):
|
def test_get_free_sms_fragment_limit(client, sample_service):
|
||||||
years = [2016, 2017, 2018]
|
years = [2016, 2017, 2018]
|
||||||
sms_allowance = [1000, 2000, 3000]
|
sms_allowance = [1000, 2000, 3000]
|
||||||
@@ -296,7 +267,7 @@ def test_get_free_sms_fragment_limit(client, sample_service):
|
|||||||
financial_year_start=y,
|
financial_year_start=y,
|
||||||
service_id=sample_service.id,
|
service_id=sample_service.id,
|
||||||
)
|
)
|
||||||
dao_create_new_annual_billing_for_year(data)
|
dao_create_or_update_annual_billing_for_year(data)
|
||||||
|
|
||||||
response = client.get('service/{}/billing/free-sms-fragment-limit?financial_year_start=2017'
|
response = client.get('service/{}/billing/free-sms-fragment-limit?financial_year_start=2017'
|
||||||
.format(sample_service.id),
|
.format(sample_service.id),
|
||||||
@@ -367,9 +338,51 @@ def test_update_free_sms_fragment_limit(client, sample_service):
|
|||||||
headers=[('Content-Type', 'application/json'), create_authorization_header()])
|
headers=[('Content-Type', 'application/json'), create_authorization_header()])
|
||||||
|
|
||||||
json_resp = json.loads(response_get.get_data(as_text=True))
|
json_resp = json.loads(response_get.get_data(as_text=True))
|
||||||
new_free_limit = dao_get_free_sms_fragment_limit_for_year(sample_service.id, 2015)
|
|
||||||
|
|
||||||
assert response.status_code == 201
|
assert response.status_code == 201
|
||||||
assert response_get.status_code == 200
|
assert response_get.status_code == 200
|
||||||
assert json_resp['data']['financial_year_start'] == 2015
|
assert json_resp['data']['financial_year_start'] == 2015
|
||||||
assert json_resp['data']['free_sms_fragment_limit'] == 9999
|
assert json_resp['data']['free_sms_fragment_limit'] == 9999
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_free_sms_fragment_limit_year_return_correct_data(client, sample_service):
|
||||||
|
years = [2015, 2016, 2017]
|
||||||
|
limits = [1000, 2000, 3000]
|
||||||
|
for i in range(0, len(years)):
|
||||||
|
data = AnnualBilling(
|
||||||
|
free_sms_fragment_limit=limits[i],
|
||||||
|
financial_year_start=years[i],
|
||||||
|
service_id=sample_service.id,
|
||||||
|
)
|
||||||
|
dao_create_or_update_annual_billing_for_year(data)
|
||||||
|
|
||||||
|
for i in range(0, len(years)):
|
||||||
|
response_get = client.get(
|
||||||
|
'service/{}/billing/free-sms-fragment-limit?financial_year_start={}'.format(sample_service.id, years[i]),
|
||||||
|
headers=[('Content-Type', 'application/json'), create_authorization_header()])
|
||||||
|
json_resp = json.loads(response_get.get_data(as_text=True))
|
||||||
|
assert response_get.status_code == 200
|
||||||
|
assert json_resp['data']['free_sms_fragment_limit'] == limits[i]
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_free_sms_fragment_limit_for_all_year(client, sample_service):
|
||||||
|
years = [2015, 2016, 2017]
|
||||||
|
limits = [1000, 2000, 3000]
|
||||||
|
for i in range(0, len(years)):
|
||||||
|
data = AnnualBilling(
|
||||||
|
free_sms_fragment_limit=limits[i],
|
||||||
|
financial_year_start=years[i],
|
||||||
|
service_id=sample_service.id,
|
||||||
|
)
|
||||||
|
dao_create_or_update_annual_billing_for_year(data)
|
||||||
|
|
||||||
|
response_get = client.get(
|
||||||
|
# Not specify a particular year to return all data for that service
|
||||||
|
'service/{}/billing/free-sms-fragment-limit'.format(sample_service.id),
|
||||||
|
headers=[('Content-Type', 'application/json'), create_authorization_header()])
|
||||||
|
json_resp = json.loads(response_get.get_data(as_text=True))
|
||||||
|
assert response_get.status_code == 200
|
||||||
|
assert len(json_resp['data']) == 3
|
||||||
|
for i in [0, 1, 2]:
|
||||||
|
assert json_resp['data'][i]['free_sms_fragment_limit'] == limits[i]
|
||||||
|
assert json_resp['data'][i]['financial_year_start'] == years[i]
|
||||||
|
|||||||
@@ -5,26 +5,28 @@
|
|||||||
|
|
||||||
from app.models import AnnualBilling
|
from app.models import AnnualBilling
|
||||||
from app.dao.annual_billing_dao import (
|
from app.dao.annual_billing_dao import (
|
||||||
dao_create_new_annual_billing_for_year,
|
dao_create_or_update_annual_billing_for_year,
|
||||||
dao_get_free_sms_fragment_limit_for_year,
|
dao_get_free_sms_fragment_limit_for_year
|
||||||
dao_update_new_free_sms_fragment_limit_for_year
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def test_dao_create_get_free_sms_fragment_limit(notify_db_session, sample_service):
|
def test_dao_create_get_free_sms_fragment_limit(notify_db_session, sample_service):
|
||||||
year = 2016
|
years = [2015, 2016, 2017]
|
||||||
data = AnnualBilling(
|
free_limit_data = [1000, 2000, 3000]
|
||||||
free_sms_fragment_limit=250000,
|
for i in range(0, len(years)):
|
||||||
financial_year_start=year,
|
data = AnnualBilling(
|
||||||
service_id=sample_service.id,
|
free_sms_fragment_limit=free_limit_data[i],
|
||||||
)
|
financial_year_start=years[i],
|
||||||
dao_create_new_annual_billing_for_year(data)
|
service_id=sample_service.id,
|
||||||
|
)
|
||||||
|
dao_create_or_update_annual_billing_for_year(data)
|
||||||
|
|
||||||
free_limit = dao_get_free_sms_fragment_limit_for_year(sample_service.id, year)
|
for i in range(0, len(years)):
|
||||||
|
free_limit = dao_get_free_sms_fragment_limit_for_year(sample_service.id, years[i])
|
||||||
|
|
||||||
assert free_limit.free_sms_fragment_limit == 250000
|
assert free_limit.free_sms_fragment_limit == free_limit_data[i]
|
||||||
assert free_limit.financial_year_start == year
|
assert free_limit.financial_year_start == years[i]
|
||||||
assert free_limit.service_id == sample_service.id
|
assert free_limit.service_id == sample_service.id
|
||||||
|
|
||||||
|
|
||||||
def test_dao_update_free_sms_fragment_limit(notify_db_session, sample_service):
|
def test_dao_update_free_sms_fragment_limit(notify_db_session, sample_service):
|
||||||
@@ -38,9 +40,9 @@ def test_dao_update_free_sms_fragment_limit(notify_db_session, sample_service):
|
|||||||
service_id=sample_service.id,
|
service_id=sample_service.id,
|
||||||
)
|
)
|
||||||
|
|
||||||
dao_create_new_annual_billing_for_year(data)
|
dao_create_or_update_annual_billing_for_year(data)
|
||||||
data.free_sms_fragment_limit = new_limit
|
data.free_sms_fragment_limit = new_limit
|
||||||
dao_update_new_free_sms_fragment_limit_for_year(data)
|
dao_create_or_update_annual_billing_for_year(data)
|
||||||
new_free_limit = dao_get_free_sms_fragment_limit_for_year(sample_service.id, year)
|
new_free_limit = dao_get_free_sms_fragment_limit_for_year(sample_service.id, year)
|
||||||
|
|
||||||
assert new_free_limit.free_sms_fragment_limit == new_limit
|
assert new_free_limit.free_sms_fragment_limit == new_limit
|
||||||
|
|||||||
Reference in New Issue
Block a user