Let services have no default letter contact blocks

If they delete the default we’ll treat ‘Blank’ as the default on the
frontend.
This commit is contained in:
Chris Hill-Scott
2019-07-18 13:11:27 +01:00
parent dd225fbc6e
commit da1219fadf
3 changed files with 40 additions and 62 deletions

View File

@@ -9,8 +9,6 @@ from app.dao.service_letter_contact_dao import (
dao_get_letter_contact_by_id,
update_letter_contact
)
from app.errors import InvalidRequest
from app.exceptions import ArchiveValidationError
from app.models import ServiceLetterContact
from tests.app.db import create_letter_contact, create_service, create_template
@@ -99,14 +97,14 @@ def test_add_letter_contact_does_not_override_default(notify_db_session):
assert not results[1].is_default
def test_add_letter_contact_with_no_default_raises_exception(notify_db_session):
def test_add_letter_contact_with_no_default_is_fine(notify_db_session):
service = create_service()
with pytest.raises(expected_exception=InvalidRequest):
add_letter_contact_for_service(
service_id=service.id,
contact_block='Swansea, SN1 3CC',
is_default=False
)
letter_contact = add_letter_contact_for_service(
service_id=service.id,
contact_block='Swansea, SN1 3CC',
is_default=False
)
assert service.letter_contacts == [letter_contact]
def test_add_letter_contact_when_multiple_defaults_exist_raises_exception(notify_db_session):
@@ -159,17 +157,16 @@ def test_update_letter_contact_as_default_overides_existing_default(notify_db_se
assert not results[1].is_default
def test_update_letter_contact_unset_default_for_only_letter_contact_raises_exception(notify_db_session):
def test_update_letter_contact_unset_default_for_only_letter_contact_is_fine(notify_db_session):
service = create_service()
only_letter_contact = create_letter_contact(service=service, contact_block='Aberdeen, AB12 23X')
with pytest.raises(expected_exception=InvalidRequest):
update_letter_contact(
service_id=service.id,
letter_contact_id=only_letter_contact.id,
contact_block='Warwick, W14 TSR',
is_default=False
)
update_letter_contact(
service_id=service.id,
letter_contact_id=only_letter_contact.id,
contact_block='Warwick, W14 TSR',
is_default=False
)
assert only_letter_contact.is_default is False
def test_archive_letter_contact(notify_db_session):
@@ -199,14 +196,11 @@ def test_archive_letter_contact_does_not_archive_a_letter_contact_for_a_differen
assert not letter_contact.archived
def test_archive_letter_contact_does_not_archive_a_service_default_letter_contact(notify_db_session):
def test_archive_letter_contact_can_archive_a_service_default_letter_contact(notify_db_session):
service = create_service()
letter_contact = create_letter_contact(service=service, contact_block='Edinburgh, ED1 1AA')
with pytest.raises(ArchiveValidationError) as e:
archive_letter_contact(service.id, letter_contact.id)
assert 'You cannot delete a default letter contact block' in str(e.value)
archive_letter_contact(service.id, letter_contact.id)
assert letter_contact.archived is True
def test_archive_letter_contact_does_dissociates_template_defaults_before_archiving(notify_db_session):