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:
Leo Hemsted
2016-07-26 12:34:39 +01:00
parent 95af32f289
commit b28e7efd14
6 changed files with 23 additions and 14 deletions

View File

@@ -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(

View File

@@ -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(

View File

@@ -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()

View File

@@ -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(

View File

@@ -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"
} }
} }
}) })

View File

@@ -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",