Merge pull request #1264 from alphagov/template-returns-placeholders

Return placeholders when getting a template
This commit is contained in:
Chris Hill-Scott
2017-10-02 11:21:46 +01:00
committed by GitHub
3 changed files with 108 additions and 2 deletions

View File

@@ -137,7 +137,8 @@ def sample_service(
limit=1000,
email_from=None,
permissions=[SMS_TYPE, EMAIL_TYPE],
research_mode=None
research_mode=None,
letter_contact_block='London,\nSW1A 1AA',
):
if user is None:
user = create_user()
@@ -150,7 +151,7 @@ def sample_service(
'restricted': restricted,
'email_from': email_from,
'created_by': user,
'letter_contact_block': 'London,\nSW1A 1AA'
'letter_contact_block': letter_contact_block,
}
service = Service.query.filter_by(name=service_name).first()
if not service:
@@ -181,6 +182,11 @@ def sample_service_full_permissions(notify_db, notify_db_session):
)
@pytest.fixture(scope='function')
def sample_service_custom_letter_contact_block(notify_db, notify_db_session):
return sample_service(notify_db, notify_db_session, letter_contact_block='((contact block))')
@pytest.fixture(scope='function')
def sample_template(
notify_db,

View File

@@ -40,11 +40,81 @@ def test_get_template_by_id_returns_200(client, sample_service, tmp_type, expect
'body': template.content,
"subject": expected_subject,
'name': expected_name,
'personalisation': {},
}
assert json_response == expected_response
@pytest.mark.parametrize("create_template_args, expected_personalisation", [
(
{
"template_type": SMS_TYPE,
"content": "Hello ((placeholder)) ((conditional??yes))",
},
{
"placeholder": {
"required": True
},
"conditional": {
"required": True
},
},
),
(
{
"template_type": EMAIL_TYPE,
"subject": "((subject))",
"content": "((content))",
},
{
"subject": {
"required": True
},
"content": {
"required": True
},
},
),
(
{
"template_type": LETTER_TYPE,
"subject": "((letterSubject))",
"content": "((letter_content))",
},
{
"letterSubject": {
"required": True,
},
"letter_content": {
"required": True,
},
"contact block": {
"required": True,
},
},
)
])
@pytest.mark.parametrize("version", valid_version_params)
def test_get_template_by_id_returns_placeholders(
client,
sample_service_custom_letter_contact_block,
version,
create_template_args,
expected_personalisation,
):
template = create_template(sample_service_custom_letter_contact_block, **create_template_args)
auth_header = create_authorization_header(service_id=sample_service_custom_letter_contact_block.id)
version_path = '/version/{}'.format(version) if version else ''
response = client.get(path='/v2/template/{}{}'.format(template.id, version_path),
headers=[('Content-Type', 'application/json'), auth_header])
json_response = json.loads(response.get_data(as_text=True))
assert json_response['personalisation'] == expected_personalisation
def test_get_template_with_non_existent_template_id_returns_404(client, fake_uuid, sample_service):
auth_header = create_authorization_header(service_id=sample_service.id)