2017-09-21 17:02:58 +01:00
|
|
|
import uuid
|
|
|
|
|
|
2017-09-14 12:23:52 +01:00
|
|
|
import pytest
|
2017-09-21 17:02:58 +01:00
|
|
|
from sqlalchemy.exc import SQLAlchemyError
|
2017-09-14 12:23:52 +01:00
|
|
|
|
2017-09-08 11:14:26 +01:00
|
|
|
from app.dao.service_email_reply_to_dao import (
|
2018-04-25 16:34:36 +01:00
|
|
|
add_reply_to_email_address_for_service,
|
|
|
|
|
archive_reply_to_email_address,
|
|
|
|
|
dao_get_reply_to_by_id,
|
2017-09-14 17:54:38 +01:00
|
|
|
dao_get_reply_to_by_service_id,
|
2021-03-10 13:55:06 +00:00
|
|
|
update_reply_to_email_address,
|
|
|
|
|
)
|
2017-09-14 12:23:52 +01:00
|
|
|
from app.errors import InvalidRequest
|
2018-04-25 16:34:36 +01:00
|
|
|
from app.exceptions import ArchiveValidationError
|
2017-09-08 11:14:26 +01:00
|
|
|
from app.models import ServiceEmailReplyTo
|
|
|
|
|
from tests.app.db import create_reply_to_email, create_service
|
|
|
|
|
|
|
|
|
|
|
2017-09-14 12:23:52 +01:00
|
|
|
def test_dao_get_reply_to_by_service_id(notify_db_session):
|
|
|
|
|
service = create_service()
|
2023-08-29 14:54:30 -07:00
|
|
|
default_reply_to = create_reply_to_email(
|
|
|
|
|
service=service, email_address="something@email.com"
|
|
|
|
|
)
|
|
|
|
|
second_reply_to = create_reply_to_email(
|
|
|
|
|
service=service, email_address="second@email.com", is_default=False
|
|
|
|
|
)
|
|
|
|
|
another_reply_to = create_reply_to_email(
|
|
|
|
|
service=service, email_address="another@email.com", is_default=False
|
|
|
|
|
)
|
2017-09-14 12:23:52 +01:00
|
|
|
|
|
|
|
|
results = dao_get_reply_to_by_service_id(service_id=service.id)
|
|
|
|
|
|
2017-09-22 10:02:59 +01:00
|
|
|
assert len(results) == 3
|
2024-05-23 13:59:51 -07:00
|
|
|
# TODO we had to change the order around, why?
|
2017-09-22 10:02:59 +01:00
|
|
|
assert default_reply_to == results[0]
|
2024-05-23 13:59:51 -07:00
|
|
|
assert another_reply_to == results[2]
|
|
|
|
|
assert second_reply_to == results[1]
|
2017-09-14 17:54:38 +01:00
|
|
|
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
def test_dao_get_reply_to_by_service_id_does_not_return_archived_reply_tos(
|
|
|
|
|
notify_db_session,
|
|
|
|
|
):
|
2018-04-25 12:19:12 +01:00
|
|
|
service = create_service()
|
2023-08-29 14:54:30 -07:00
|
|
|
create_reply_to_email(service=service, email_address="something@email.com")
|
|
|
|
|
create_reply_to_email(
|
|
|
|
|
service=service, email_address="another@email.com", is_default=False
|
|
|
|
|
)
|
2018-04-25 12:19:12 +01:00
|
|
|
archived_reply_to = create_reply_to_email(
|
|
|
|
|
service=service,
|
2023-08-29 14:54:30 -07:00
|
|
|
email_address="second@email.com",
|
2018-04-25 12:19:12 +01:00
|
|
|
is_default=False,
|
2023-08-29 14:54:30 -07:00
|
|
|
archived=True,
|
2018-04-25 12:19:12 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
results = dao_get_reply_to_by_service_id(service_id=service.id)
|
|
|
|
|
|
|
|
|
|
assert len(results) == 2
|
|
|
|
|
assert archived_reply_to not in results
|
|
|
|
|
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
def test_add_reply_to_email_address_for_service_creates_first_email_for_service(
|
|
|
|
|
notify_db_session,
|
|
|
|
|
):
|
2017-09-14 17:54:38 +01:00
|
|
|
service = create_service()
|
2023-08-29 14:54:30 -07:00
|
|
|
add_reply_to_email_address_for_service(
|
|
|
|
|
service_id=service.id, email_address="new@address.com", is_default=True
|
|
|
|
|
)
|
2017-09-14 17:54:38 +01:00
|
|
|
|
|
|
|
|
results = dao_get_reply_to_by_service_id(service_id=service.id)
|
|
|
|
|
assert len(results) == 1
|
2023-08-29 14:54:30 -07:00
|
|
|
assert results[0].email_address == "new@address.com"
|
2017-09-14 17:54:38 +01:00
|
|
|
assert results[0].is_default
|
2018-04-25 10:42:00 +01:00
|
|
|
assert not results[0].archived
|
2017-09-14 17:54:38 +01:00
|
|
|
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
def test_add_reply_to_email_address_for_service_creates_another_email_for_service(
|
|
|
|
|
notify_db_session,
|
|
|
|
|
):
|
2017-09-14 17:54:38 +01:00
|
|
|
service = create_service()
|
2017-11-28 17:21:21 +00:00
|
|
|
create_reply_to_email(service=service, email_address="first@address.com")
|
2017-09-14 17:54:38 +01:00
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
add_reply_to_email_address_for_service(
|
|
|
|
|
service_id=service.id, email_address="second@address.com", is_default=False
|
|
|
|
|
)
|
2017-09-14 17:54:38 +01:00
|
|
|
|
|
|
|
|
results = dao_get_reply_to_by_service_id(service_id=service.id)
|
|
|
|
|
assert len(results) == 2
|
|
|
|
|
for x in results:
|
2023-08-29 14:54:30 -07:00
|
|
|
if x.email_address == "first@address.com":
|
2017-09-14 17:54:38 +01:00
|
|
|
assert x.is_default
|
2023-08-29 14:54:30 -07:00
|
|
|
elif x.email_address == "second@address.com":
|
2017-09-14 17:54:38 +01:00
|
|
|
assert not x.is_default
|
|
|
|
|
else:
|
2020-12-22 15:46:31 +00:00
|
|
|
raise AssertionError()
|
2017-09-14 17:54:38 +01:00
|
|
|
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
def test_add_reply_to_email_address_new_reply_to_is_default_existing_reply_to_is_not(
|
|
|
|
|
notify_db_session,
|
|
|
|
|
):
|
2017-09-14 17:54:38 +01:00
|
|
|
service = create_service()
|
2023-08-29 14:54:30 -07:00
|
|
|
create_reply_to_email(
|
|
|
|
|
service=service, email_address="first@address.com", is_default=True
|
|
|
|
|
)
|
|
|
|
|
add_reply_to_email_address_for_service(
|
|
|
|
|
service_id=service.id, email_address="second@address.com", is_default=True
|
|
|
|
|
)
|
2017-09-14 17:54:38 +01:00
|
|
|
|
|
|
|
|
results = dao_get_reply_to_by_service_id(service_id=service.id)
|
|
|
|
|
assert len(results) == 2
|
|
|
|
|
for x in results:
|
2023-08-29 14:54:30 -07:00
|
|
|
if x.email_address == "first@address.com":
|
2017-09-14 17:54:38 +01:00
|
|
|
assert not x.is_default
|
2023-08-29 14:54:30 -07:00
|
|
|
elif x.email_address == "second@address.com":
|
2017-09-14 17:54:38 +01:00
|
|
|
assert x.is_default
|
|
|
|
|
else:
|
2020-12-22 15:46:31 +00:00
|
|
|
raise AssertionError()
|
2017-09-14 17:54:38 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_add_reply_to_email_address_can_add_a_third_reply_to_address(sample_service):
|
2023-08-29 14:54:30 -07:00
|
|
|
add_reply_to_email_address_for_service(
|
|
|
|
|
service_id=sample_service.id, email_address="first@address.com", is_default=True
|
|
|
|
|
)
|
|
|
|
|
add_reply_to_email_address_for_service(
|
|
|
|
|
service_id=sample_service.id,
|
|
|
|
|
email_address="second@address.com",
|
|
|
|
|
is_default=False,
|
|
|
|
|
)
|
|
|
|
|
add_reply_to_email_address_for_service(
|
|
|
|
|
service_id=sample_service.id,
|
|
|
|
|
email_address="third@address.com",
|
|
|
|
|
is_default=False,
|
|
|
|
|
)
|
2017-09-14 17:54:38 +01:00
|
|
|
|
|
|
|
|
results = dao_get_reply_to_by_service_id(service_id=sample_service.id)
|
|
|
|
|
assert len(results) == 3
|
|
|
|
|
|
|
|
|
|
for x in results:
|
2023-08-29 14:54:30 -07:00
|
|
|
if x.email_address == "first@address.com":
|
2017-09-14 17:54:38 +01:00
|
|
|
assert x.is_default
|
2023-08-29 14:54:30 -07:00
|
|
|
elif x.email_address == "second@address.com":
|
2017-09-14 17:54:38 +01:00
|
|
|
assert not x.is_default
|
2023-08-29 14:54:30 -07:00
|
|
|
elif x.email_address == "third@address.com":
|
2017-09-14 17:54:38 +01:00
|
|
|
assert not x.is_default
|
|
|
|
|
else:
|
2020-12-22 15:46:31 +00:00
|
|
|
raise AssertionError()
|
2017-09-14 17:54:38 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_add_reply_to_email_address_ensures_first_reply_to_is_default(sample_service):
|
|
|
|
|
with pytest.raises(expected_exception=InvalidRequest):
|
2023-08-29 14:54:30 -07:00
|
|
|
add_reply_to_email_address_for_service(
|
|
|
|
|
service_id=sample_service.id,
|
|
|
|
|
email_address="first@address.com",
|
|
|
|
|
is_default=False,
|
|
|
|
|
)
|
2017-09-14 17:54:38 +01:00
|
|
|
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
def test_add_reply_to_email_address_ensure_there_is_not_more_than_one_default(
|
|
|
|
|
sample_service,
|
|
|
|
|
):
|
|
|
|
|
create_reply_to_email(
|
|
|
|
|
service=sample_service, email_address="first@email.com", is_default=True
|
|
|
|
|
)
|
|
|
|
|
create_reply_to_email(
|
|
|
|
|
service=sample_service, email_address="second@email.com", is_default=True
|
|
|
|
|
)
|
2023-07-21 10:42:17 -07:00
|
|
|
|
2023-07-21 11:24:22 -07:00
|
|
|
try:
|
2023-07-21 11:32:31 -07:00
|
|
|
# flake8 doesn't like raise with a generic Exception
|
2023-07-21 11:24:22 -07:00
|
|
|
add_reply_to_email_address_for_service(
|
2023-08-29 14:54:30 -07:00
|
|
|
service_id=sample_service.id,
|
|
|
|
|
email_address="third_email@address.com",
|
|
|
|
|
is_default=False,
|
|
|
|
|
)
|
2023-07-21 11:24:22 -07:00
|
|
|
assert 1 == 0
|
2023-07-21 11:32:31 -07:00
|
|
|
except Exception:
|
2023-07-21 11:24:22 -07:00
|
|
|
assert 1 == 1
|
2017-09-20 11:58:18 +01:00
|
|
|
|
|
|
|
|
|
2017-09-14 17:54:38 +01:00
|
|
|
def test_update_reply_to_email_address(sample_service):
|
2023-08-29 14:54:30 -07:00
|
|
|
first_reply_to = create_reply_to_email(
|
|
|
|
|
service=sample_service, email_address="first@address.com"
|
|
|
|
|
)
|
|
|
|
|
update_reply_to_email_address(
|
|
|
|
|
service_id=sample_service.id,
|
|
|
|
|
reply_to_id=first_reply_to.id,
|
|
|
|
|
email_address="change_address@email.com",
|
|
|
|
|
is_default=True,
|
|
|
|
|
)
|
2017-09-14 17:54:38 +01:00
|
|
|
updated_reply_to = ServiceEmailReplyTo.query.get(first_reply_to.id)
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
assert updated_reply_to.email_address == "change_address@email.com"
|
2017-09-14 17:54:38 +01:00
|
|
|
assert updated_reply_to.updated_at
|
|
|
|
|
assert updated_reply_to.is_default
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_update_reply_to_email_address_set_updated_to_default(sample_service):
|
2017-11-28 17:21:21 +00:00
|
|
|
create_reply_to_email(service=sample_service, email_address="first@address.com")
|
2023-08-29 14:54:30 -07:00
|
|
|
second_reply_to = create_reply_to_email(
|
|
|
|
|
service=sample_service, email_address="second@address.com", is_default=False
|
|
|
|
|
)
|
2017-09-14 17:54:38 +01:00
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
update_reply_to_email_address(
|
|
|
|
|
service_id=sample_service.id,
|
|
|
|
|
reply_to_id=second_reply_to.id,
|
|
|
|
|
email_address="change_address@email.com",
|
|
|
|
|
is_default=True,
|
|
|
|
|
)
|
2017-09-14 17:54:38 +01:00
|
|
|
|
|
|
|
|
results = ServiceEmailReplyTo.query.all()
|
|
|
|
|
assert len(results) == 2
|
|
|
|
|
for x in results:
|
2023-08-29 14:54:30 -07:00
|
|
|
if x.email_address == "change_address@email.com":
|
2017-09-14 17:54:38 +01:00
|
|
|
assert x.is_default
|
2023-08-29 14:54:30 -07:00
|
|
|
elif x.email_address == "first@address.com":
|
2017-09-14 17:54:38 +01:00
|
|
|
assert not x.is_default
|
|
|
|
|
else:
|
2020-12-22 15:46:31 +00:00
|
|
|
raise AssertionError()
|
2017-09-14 17:54:38 +01:00
|
|
|
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
def test_update_reply_to_email_address_raises_exception_if_single_reply_to_and_setting_default_to_false(
|
|
|
|
|
sample_service,
|
|
|
|
|
):
|
|
|
|
|
first_reply_to = create_reply_to_email(
|
|
|
|
|
service=sample_service, email_address="first@address.com"
|
|
|
|
|
)
|
2017-09-14 17:54:38 +01:00
|
|
|
with pytest.raises(expected_exception=InvalidRequest):
|
2023-08-29 14:54:30 -07:00
|
|
|
update_reply_to_email_address(
|
|
|
|
|
service_id=sample_service.id,
|
|
|
|
|
reply_to_id=first_reply_to.id,
|
|
|
|
|
email_address="should@fail.com",
|
|
|
|
|
is_default=False,
|
|
|
|
|
)
|
2017-09-21 17:02:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_dao_get_reply_to_by_id(sample_service):
|
2023-08-29 14:54:30 -07:00
|
|
|
reply_to = create_reply_to_email(
|
|
|
|
|
service=sample_service, email_address="email@address.com"
|
|
|
|
|
)
|
|
|
|
|
result = dao_get_reply_to_by_id(
|
|
|
|
|
service_id=sample_service.id, reply_to_id=reply_to.id
|
|
|
|
|
)
|
2017-09-21 17:02:58 +01:00
|
|
|
assert result == reply_to
|
|
|
|
|
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
def test_dao_get_reply_to_by_id_raises_sqlalchemy_error_when_reply_to_does_not_exist(
|
|
|
|
|
sample_service,
|
|
|
|
|
):
|
2017-09-21 17:02:58 +01:00
|
|
|
with pytest.raises(SQLAlchemyError):
|
|
|
|
|
dao_get_reply_to_by_id(service_id=sample_service.id, reply_to_id=uuid.uuid4())
|
|
|
|
|
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
def test_dao_get_reply_to_by_id_raises_sqlalchemy_error_when_reply_to_is_archived(
|
|
|
|
|
sample_service,
|
|
|
|
|
):
|
|
|
|
|
create_reply_to_email(service=sample_service, email_address="email@address.com")
|
2018-04-25 12:19:12 +01:00
|
|
|
archived_reply_to = create_reply_to_email(
|
|
|
|
|
service=sample_service,
|
2023-08-29 14:54:30 -07:00
|
|
|
email_address="email_two@address.com",
|
2018-04-25 12:19:12 +01:00
|
|
|
is_default=False,
|
2023-08-29 14:54:30 -07:00
|
|
|
archived=True,
|
|
|
|
|
)
|
2018-04-25 12:19:12 +01:00
|
|
|
|
|
|
|
|
with pytest.raises(SQLAlchemyError):
|
2023-08-29 14:54:30 -07:00
|
|
|
dao_get_reply_to_by_id(
|
|
|
|
|
service_id=sample_service.id, reply_to_id=archived_reply_to.id
|
|
|
|
|
)
|
2018-04-25 12:19:12 +01:00
|
|
|
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
def test_dao_get_reply_to_by_id_raises_sqlalchemy_error_when_service_does_not_exist(
|
|
|
|
|
sample_service,
|
|
|
|
|
):
|
|
|
|
|
reply_to = create_reply_to_email(
|
|
|
|
|
service=sample_service, email_address="email@address.com"
|
|
|
|
|
)
|
2017-09-21 17:02:58 +01:00
|
|
|
with pytest.raises(SQLAlchemyError):
|
|
|
|
|
dao_get_reply_to_by_id(service_id=uuid.uuid4(), reply_to_id=reply_to.id)
|
2018-04-25 16:34:36 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_archive_reply_to_email_address(sample_service):
|
|
|
|
|
create_reply_to_email(service=sample_service, email_address="first@address.com")
|
|
|
|
|
second_reply_to = create_reply_to_email(
|
2023-08-29 14:54:30 -07:00
|
|
|
service=sample_service, email_address="second@address.com", is_default=False
|
|
|
|
|
)
|
2018-04-25 16:34:36 +01:00
|
|
|
|
|
|
|
|
archive_reply_to_email_address(sample_service.id, second_reply_to.id)
|
|
|
|
|
|
|
|
|
|
assert second_reply_to.archived is True
|
|
|
|
|
assert second_reply_to.updated_at is not None
|
|
|
|
|
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
def test_archive_reply_to_email_address_does_not_archive_a_reply_to_for_a_different_service(
|
|
|
|
|
sample_service,
|
|
|
|
|
):
|
2018-04-25 16:34:36 +01:00
|
|
|
service = create_service(service_name="First service")
|
2023-08-29 14:54:30 -07:00
|
|
|
reply_to = create_reply_to_email(
|
|
|
|
|
service=sample_service, email_address="first@address.com", is_default=False
|
|
|
|
|
)
|
2018-04-25 16:34:36 +01:00
|
|
|
|
|
|
|
|
with pytest.raises(SQLAlchemyError):
|
|
|
|
|
archive_reply_to_email_address(service.id, reply_to.id)
|
|
|
|
|
|
|
|
|
|
assert not reply_to.archived
|
|
|
|
|
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
def test_archive_reply_to_email_address_raises_an_error_if_attempting_to_archive_a_default(
|
|
|
|
|
sample_service,
|
|
|
|
|
):
|
2018-04-25 16:34:36 +01:00
|
|
|
create_reply_to_email(
|
2023-08-29 14:54:30 -07:00
|
|
|
service=sample_service, email_address="first@address.com", is_default=False
|
|
|
|
|
)
|
|
|
|
|
default_reply_to = create_reply_to_email(
|
|
|
|
|
service=sample_service, email_address="first@address.com"
|
|
|
|
|
)
|
2018-04-25 16:34:36 +01:00
|
|
|
|
|
|
|
|
with pytest.raises(ArchiveValidationError) as e:
|
|
|
|
|
archive_reply_to_email_address(sample_service.id, default_reply_to.id)
|
|
|
|
|
|
2023-08-29 14:54:30 -07:00
|
|
|
assert "You cannot delete a default email reply to address" in str(e.value)
|
2018-04-25 16:34:36 +01:00
|
|
|
assert not default_reply_to.archived
|