Upload precompiled letter pdfs to letters-scan bucket

This commit is contained in:
Ken Tsang
2018-03-13 14:08:34 +00:00
parent 30e371fa4c
commit 8733d84e75
3 changed files with 43 additions and 1 deletions

View File

@@ -451,7 +451,7 @@ class Sandbox(CloudFoundryConfig):
TEST_LETTERS_BUCKET_NAME = 'cf-sandbox-test-letters' TEST_LETTERS_BUCKET_NAME = 'cf-sandbox-test-letters'
DVLA_RESPONSE_BUCKET_NAME = 'notify.works-ftp' DVLA_RESPONSE_BUCKET_NAME = 'notify.works-ftp'
LETTERS_PDF_BUCKET_NAME = 'cf-sandbox-letters-pdf' LETTERS_PDF_BUCKET_NAME = 'cf-sandbox-letters-pdf'
LETTERS_SCAN_BUCKET_NAME = 'cf-sandbox-virus-check-pdf' LETTERS_SCAN_BUCKET_NAME = 'cf-sandbox-letters-scan'
FROM_NUMBER = 'sandbox' FROM_NUMBER = 'sandbox'
REDIS_ENABLED = False REDIS_ENABLED = False

View File

@@ -64,6 +64,11 @@ def upload_letter_pdf(notification, pdf_data, is_test_letter=False):
else: else:
bucket_name = current_app.config['LETTERS_PDF_BUCKET_NAME'] bucket_name = current_app.config['LETTERS_PDF_BUCKET_NAME']
if notification.template.is_precompiled_letter:
bucket_name = current_app.config['LETTERS_SCAN_BUCKET_NAME']
else:
bucket_name = current_app.config['LETTERS_PDF_BUCKET_NAME']
s3upload( s3upload(
filedata=pdf_data, filedata=pdf_data,
region=current_app.config['AWS_REGION'], region=current_app.config['AWS_REGION'],

View File

@@ -1,3 +1,4 @@
from flask import current_app
import pytest import pytest
from datetime import datetime from datetime import datetime
@@ -21,6 +22,13 @@ def sample_precompiled_letter_notification_using_test_key(sample_letter_notifica
sample_letter_notification.reference = 'foo' sample_letter_notification.reference = 'foo'
sample_letter_notification.created_at = datetime.utcnow() sample_letter_notification.created_at = datetime.utcnow()
return sample_letter_notification return sample_letter_notification
from app.letters.utils import (
get_bucket_prefix_for_notification,
get_letter_pdf_filename,
upload_letter_pdf
)
from app.models import PRECOMPILED_TEMPLATE_NAME
from app.variables import Retention
def test_get_bucket_prefix_for_notification_valid_notification(sample_notification): def test_get_bucket_prefix_for_notification_valid_notification(sample_notification):
@@ -100,3 +108,32 @@ def test_get_letter_pdf_gets_pdf_from_correct_bucket(
ret = get_letter_pdf(sample_precompiled_letter_notification_using_test_key) ret = get_letter_pdf(sample_precompiled_letter_notification_using_test_key)
assert ret == b'pdf_content' assert ret == b'pdf_content'
@pytest.mark.parametrize('is_precompiled_letter,bucket_config_name', [
(False, 'LETTERS_PDF_BUCKET_NAME'),
(True, 'LETTERS_SCAN_BUCKET_NAME')
])
def test_upload_letter_pdf_to_correct_bucket(
sample_letter_notification, mocker, is_precompiled_letter, bucket_config_name
):
if is_precompiled_letter:
sample_letter_notification.template.hidden = True
sample_letter_notification.template.name = PRECOMPILED_TEMPLATE_NAME
mock_s3 = mocker.patch('app.letters.utils.s3upload')
filename = get_letter_pdf_filename(
reference=sample_letter_notification.reference,
crown=sample_letter_notification.service.crown
)
upload_letter_pdf(sample_letter_notification, b'\x00\x01')
mock_s3.assert_called_once_with(
bucket_name=current_app.config[bucket_config_name],
file_location=filename,
filedata=b'\x00\x01',
region=current_app.config['AWS_REGION'],
tags={Retention.KEY: Retention.ONE_WEEK}
)