Files
notifications-api/tests/notifications_utils/test_base_template.py
2024-05-17 17:14:46 -04:00

120 lines
3.7 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
from unittest.mock import patch
import pytest
from notifications_utils.template import SubjectMixin, Template
class ConcreteImplementation:
template_type = None
# Cant instantiate and test templates unless they implement __str__
def __str__(self):
pass
class ConcreteTemplate(ConcreteImplementation, Template):
pass
class ConcreteTemplateWithSubject(SubjectMixin, ConcreteTemplate):
pass
def test_class():
assert (
repr(ConcreteTemplate({"content": "hello ((name))"}))
== 'ConcreteTemplate("hello ((name))", {})'
)
def test_passes_through_template_attributes():
assert ConcreteTemplate({"content": ""}).name is None
assert (
ConcreteTemplate({"content": "", "name": "Two week reminder"}).name
== "Two week reminder"
)
assert ConcreteTemplate({"content": ""}).id is None
assert ConcreteTemplate({"content": "", "id": "1234"}).id == "1234"
assert ConcreteTemplate({"content": ""}).template_type is None
def test_passes_through_subject():
assert (
ConcreteTemplateWithSubject(
{"content": "", "subject": "Your tax is due"}
).subject
== "Your tax is due"
)
def test_errors_for_missing_template_content():
with pytest.raises(KeyError):
ConcreteTemplate({})
@pytest.mark.parametrize("template", [0, 1, 2, True, False, None])
def test_errors_for_invalid_template_types(template):
with pytest.raises(TypeError):
ConcreteTemplate(template)
@pytest.mark.parametrize("values", [[], False])
def test_errors_for_invalid_values(values):
with pytest.raises(TypeError):
ConcreteTemplate({"content": ""}, values)
def test_matches_keys_to_placeholder_names():
template = ConcreteTemplate({"content": "hello ((name))"})
template.values = {"NAME": "Chris"}
assert template.values == {"name": "Chris"}
template.values = {"NAME": "Chris", "Town": "London"}
assert template.values == {"name": "Chris", "Town": "London"}
assert template.additional_data == {"Town"}
template.values = None
assert template.missing_data == ["name"]
@pytest.mark.parametrize(
("template_content", "template_subject", "expected"),
[
("the quick brown fox", "jumps", []),
("the quick ((colour)) fox", "jumps", ["colour"]),
("the quick ((colour)) ((animal))", "jumps", ["colour", "animal"]),
("((colour)) ((animal)) ((colour)) ((animal))", "jumps", ["colour", "animal"]),
("the quick brown fox", "((colour))", ["colour"]),
("the quick ((colour)) ", "((animal))", ["animal", "colour"]),
("((colour)) ((animal)) ", "((colour)) ((animal))", ["colour", "animal"]),
("Dear ((name)), ((warning?? This is a warning))", "", ["name", "warning"]),
("((warning? one question mark))", "", ["warning? one question mark"]),
],
)
def test_extracting_placeholders(template_content, template_subject, expected):
assert (
ConcreteTemplateWithSubject(
{"content": template_content, "subject": template_subject}
).placeholders
== expected
)
def test_random_variable_retrieve():
template = ConcreteTemplate({"content": "content", "created_by": "now"})
assert template.get_raw("created_by") == "now"
assert template.get_raw("missing", default="random") == "random"
assert template.get_raw("missing") is None
def test_compare_template():
with patch(
"notifications_utils.template_change.TemplateChange.__init__", return_value=None
) as mocked:
old_template = ConcreteTemplate({"content": "faked"})
new_template = ConcreteTemplate({"content": "faked"})
old_template.compare_to(new_template)
mocked.assert_called_once_with(old_template, new_template)