mirror of
https://github.com/GSA/notifications-api.git
synced 2026-02-04 10:21:14 -05:00
dont load template contents for job page
rename the notification_status_schema to make it apparent that it involves the template, and then don't use it on the job page - the job page doesn't do anything with the data. won't somebody think of the cpu cycles! (also means it ignores problems with template versions)
This commit is contained in:
@@ -18,7 +18,12 @@ from app.dao.services_dao import (
|
|||||||
from app.dao.templates_dao import (dao_get_template_by_id)
|
from app.dao.templates_dao import (dao_get_template_by_id)
|
||||||
from app.dao.notifications_dao import get_notifications_for_job
|
from app.dao.notifications_dao import get_notifications_for_job
|
||||||
|
|
||||||
from app.schemas import job_schema, unarchived_template_schema, notifications_filter_schema, notification_status_schema
|
from app.schemas import (
|
||||||
|
job_schema,
|
||||||
|
unarchived_template_schema,
|
||||||
|
notifications_filter_schema,
|
||||||
|
notification_schema
|
||||||
|
)
|
||||||
|
|
||||||
from app.celery.tasks import process_job
|
from app.celery.tasks import process_job
|
||||||
|
|
||||||
@@ -57,7 +62,7 @@ def get_all_notifications_for_service_job(service_id, job_id):
|
|||||||
kwargs['service_id'] = service_id
|
kwargs['service_id'] = service_id
|
||||||
kwargs['job_id'] = job_id
|
kwargs['job_id'] = job_id
|
||||||
return jsonify(
|
return jsonify(
|
||||||
notifications=notification_status_schema.dump(pagination.items, many=True).data,
|
notifications=notification_schema.dump(pagination.items, many=True).data,
|
||||||
page_size=page_size,
|
page_size=page_size,
|
||||||
total=pagination.total,
|
total=pagination.total,
|
||||||
links=pagination_links(
|
links=pagination_links(
|
||||||
|
|||||||
@@ -26,7 +26,7 @@ from app.notifications.process_client_response import (
|
|||||||
from app.schemas import (
|
from app.schemas import (
|
||||||
email_notification_schema,
|
email_notification_schema,
|
||||||
sms_template_notification_schema,
|
sms_template_notification_schema,
|
||||||
notification_status_schema,
|
notification_with_template_schema,
|
||||||
notifications_filter_schema,
|
notifications_filter_schema,
|
||||||
notifications_statistics_schema,
|
notifications_statistics_schema,
|
||||||
day_schema,
|
day_schema,
|
||||||
@@ -175,7 +175,7 @@ def get_notifications(notification_id):
|
|||||||
notification = notifications_dao.get_notification(str(api_user.service_id),
|
notification = notifications_dao.get_notification(str(api_user.service_id),
|
||||||
notification_id,
|
notification_id,
|
||||||
key_type=api_user.key_type)
|
key_type=api_user.key_type)
|
||||||
return jsonify(data={"notification": notification_status_schema.dump(notification).data}), 200
|
return jsonify(data={"notification": notification_with_template_schema.dump(notification).data}), 200
|
||||||
|
|
||||||
|
|
||||||
@notifications.route('/notifications', methods=['GET'])
|
@notifications.route('/notifications', methods=['GET'])
|
||||||
@@ -193,7 +193,7 @@ def get_all_notifications():
|
|||||||
limit_days=limit_days,
|
limit_days=limit_days,
|
||||||
key_type=api_user.key_type)
|
key_type=api_user.key_type)
|
||||||
return jsonify(
|
return jsonify(
|
||||||
notifications=notification_status_schema.dump(pagination.items, many=True).data,
|
notifications=notification_with_template_schema.dump(pagination.items, many=True).data,
|
||||||
page_size=page_size,
|
page_size=page_size,
|
||||||
total=pagination.total,
|
total=pagination.total,
|
||||||
links=pagination_links(
|
links=pagination_links(
|
||||||
|
|||||||
@@ -144,7 +144,7 @@ class NotificationModelSchema(BaseSchema):
|
|||||||
class Meta:
|
class Meta:
|
||||||
model = models.Notification
|
model = models.Notification
|
||||||
strict = True
|
strict = True
|
||||||
exclude = ("_personalisation",)
|
exclude = ('_personalisation', 'job', 'service', 'template', 'api_key', '')
|
||||||
|
|
||||||
|
|
||||||
class BaseTemplateSchema(BaseSchema):
|
class BaseTemplateSchema(BaseSchema):
|
||||||
@@ -280,7 +280,7 @@ class SmsAdminNotificationSchema(SmsNotificationSchema):
|
|||||||
content = fields.Str(required=True)
|
content = fields.Str(required=True)
|
||||||
|
|
||||||
|
|
||||||
class NotificationStatusSchema(BaseSchema):
|
class NotificationWithTemplateSchema(BaseSchema):
|
||||||
|
|
||||||
template = fields.Nested(TemplateSchema, only=["id", "name", "template_type", "content", "subject"], dump_only=True)
|
template = fields.Nested(TemplateSchema, only=["id", "name", "template_type", "content", "subject"], dump_only=True)
|
||||||
job = fields.Nested(JobSchema, only=["id", "original_file_name"], dump_only=True)
|
job = fields.Nested(JobSchema, only=["id", "original_file_name"], dump_only=True)
|
||||||
@@ -516,8 +516,9 @@ sms_template_notification_schema = SmsTemplateNotificationSchema()
|
|||||||
job_sms_template_notification_schema = JobSmsTemplateNotificationSchema()
|
job_sms_template_notification_schema = JobSmsTemplateNotificationSchema()
|
||||||
email_notification_schema = EmailNotificationSchema()
|
email_notification_schema = EmailNotificationSchema()
|
||||||
job_email_template_notification_schema = JobEmailTemplateNotificationSchema()
|
job_email_template_notification_schema = JobEmailTemplateNotificationSchema()
|
||||||
notification_status_schema = NotificationStatusSchema()
|
notification_schema = NotificationModelSchema()
|
||||||
notification_status_schema_load_json = NotificationStatusSchema(load_json=True)
|
notification_with_template_schema = NotificationWithTemplateSchema()
|
||||||
|
notification_with_template_schema_load_json = NotificationWithTemplateSchema(load_json=True)
|
||||||
invited_user_schema = InvitedUserSchema()
|
invited_user_schema = InvitedUserSchema()
|
||||||
permission_schema = PermissionSchema()
|
permission_schema = PermissionSchema()
|
||||||
email_data_request_schema = EmailDataSchema()
|
email_data_request_schema = EmailDataSchema()
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ from app.schemas import (
|
|||||||
user_schema,
|
user_schema,
|
||||||
from_to_date_schema,
|
from_to_date_schema,
|
||||||
permission_schema,
|
permission_schema,
|
||||||
notification_status_schema,
|
notification_with_template_schema,
|
||||||
notifications_filter_schema,
|
notifications_filter_schema,
|
||||||
detailed_service_schema
|
detailed_service_schema
|
||||||
)
|
)
|
||||||
@@ -224,7 +224,7 @@ def get_all_notifications_for_service(service_id):
|
|||||||
kwargs = request.args.to_dict()
|
kwargs = request.args.to_dict()
|
||||||
kwargs['service_id'] = service_id
|
kwargs['service_id'] = service_id
|
||||||
return jsonify(
|
return jsonify(
|
||||||
notifications=notification_status_schema.dump(pagination.items, many=True).data,
|
notifications=notification_with_template_schema.dump(pagination.items, many=True).data,
|
||||||
page_size=page_size,
|
page_size=page_size,
|
||||||
total=pagination.total,
|
total=pagination.total,
|
||||||
links=pagination_links(
|
links=pagination_links(
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ api_spec = APISpec(
|
|||||||
version='0.0.0'
|
version='0.0.0'
|
||||||
)
|
)
|
||||||
|
|
||||||
api_spec.definition('NotificationStatusSchema', properties={
|
api_spec.definition('NotificationWithTemplateSchema', properties={
|
||||||
"content_char_count": {
|
"content_char_count": {
|
||||||
"format": "int32",
|
"format": "int32",
|
||||||
"type": "integer"
|
"type": "integer"
|
||||||
@@ -106,14 +106,14 @@ api_spec.definition('NotificationStatusSchema', properties={
|
|||||||
})
|
})
|
||||||
api_spec.definition('NotificationSchema', properties={
|
api_spec.definition('NotificationSchema', properties={
|
||||||
"notification": {
|
"notification": {
|
||||||
"$ref": "#/definitions/NotificationStatusSchema"
|
"$ref": "#/definitions/NotificationWithTemplateSchema"
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
api_spec.definition('NotificationsSchema', properties={
|
api_spec.definition('NotificationsSchema', properties={
|
||||||
"notifications": {
|
"notifications": {
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": {
|
"items": {
|
||||||
"$ref": "#/definitions/NotificationStatusSchema"
|
"$ref": "#/definitions/NotificationWithTemplateSchema"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -296,6 +296,9 @@ def test_get_all_notifications_for_job_in_order_of_job_number(notify_api,
|
|||||||
assert resp['notifications'][2]['job_row_number'] == notification_3.job_row_number
|
assert resp['notifications'][2]['job_row_number'] == notification_3.job_row_number
|
||||||
assert response.status_code == 200
|
assert response.status_code == 200
|
||||||
|
|
||||||
|
# make sure we're not loading templates
|
||||||
|
assert 'template' not in resp['notifications'][0]
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
@pytest.mark.parametrize(
|
||||||
"expected_notification_count, status_args",
|
"expected_notification_count, status_args",
|
||||||
|
|||||||
Reference in New Issue
Block a user