Merge pull request #4107 from alphagov/mark-letter-invalid-if-over-10-sheets-169209742

Show validation-failed status for templated letters over 10 pages
This commit is contained in:
Rebecca Law
2022-02-02 07:58:34 +00:00
committed by GitHub
2 changed files with 37 additions and 0 deletions

View File

@@ -18,6 +18,7 @@ from flask import (
url_for,
)
from notifications_python_client.errors import APIError, HTTPError
from notifications_utils import LETTER_MAX_PAGE_COUNT
from notifications_utils.letter_timings import (
get_letter_timings,
letter_can_be_cancelled,
@@ -79,6 +80,19 @@ def view_notification(service_id, notification_id):
)
else:
page_count = get_page_count_for_letter(notification['template'], values=personalisation)
if page_count and page_count > LETTER_MAX_PAGE_COUNT:
# We check page count here to show the right error message for a letter that is too long.
# Another way to do this would be to get the status and error message from letter metadata.
# This would be a significant amount of work though, out of scope for this bug fix.
# This is because currently we do not pull the letter from S3 when showing preview.
# Instead, we generate letter preview based on the letter template and personalisation.
# Additionally, when a templated letter is sent via the api and the personalisation pushes the
# page count over 10 pages, it takes a while for validation status to come through.
# Checking page count here will enable us to show the error message even if the letter is not
# fully processed yet.
error_message = get_letter_validation_error(
"letter-too-long", [1], page_count
)
if notification.get('postage'):
if notification["status"] == "validation-failed":

View File

@@ -675,6 +675,29 @@ def test_should_show_image_of_letter_notification_that_failed_validation(
assert response.get_data(as_text=True) == 'foo', metadata
def test_should_show_image_of_templated_letter_notification_that_failed_validation_because_letter_is_too_long(
client_request,
mocker,
fake_uuid,
):
notification = create_notification(
notification_status='validation-failed',
template_type='letter')
mocker.patch('app.notification_api_client.get_notification', return_value=notification)
mocker.patch('app.main.views.notifications.get_page_count_for_letter', return_value=11)
page = client_request.get(
'main.view_notification',
service_id=SERVICE_ONE_ID,
notification_id=fake_uuid,
)
error_message = page.find('p', class_='notification-status-cancelled').text
assert normalize_spaces(error_message) == \
"Validation failed because this letter is 11 pages long.Letters must be 10 pages or "\
"less (5 double-sided sheets of paper)."
def test_should_show_preview_error_image_letter_notification_on_preview_error(
client_request,
fake_uuid,