Files
notifications-api/tests/app/dao/test_inbound_numbers_dao.py
Kenneth Kehl 1ecb747c6d reformat
2023-08-29 14:54:30 -07:00

119 lines
3.9 KiB
Python

import pytest
from sqlalchemy.exc import IntegrityError
from app.dao.inbound_numbers_dao import (
dao_allocate_number_for_service,
dao_get_available_inbound_numbers,
dao_get_inbound_number_for_service,
dao_get_inbound_numbers,
dao_set_inbound_number_active_flag,
dao_set_inbound_number_to_service,
)
from app.models import InboundNumber
from tests.app.db import create_inbound_number, create_service
def test_get_inbound_numbers(notify_db_session, sample_inbound_numbers):
res = dao_get_inbound_numbers()
assert len(res) == len(sample_inbound_numbers)
assert res == sample_inbound_numbers
def test_get_available_inbound_numbers(notify_db_session):
inbound_number = create_inbound_number(number="1")
res = dao_get_available_inbound_numbers()
assert len(res) == 1
assert res[0] == inbound_number
def test_set_service_id_on_inbound_number(notify_db_session, sample_inbound_numbers):
service = create_service(service_name="test service")
numbers = dao_get_available_inbound_numbers()
dao_set_inbound_number_to_service(service.id, numbers[0])
res = InboundNumber.query.filter(InboundNumber.service_id == service.id).all()
assert len(res) == 1
assert res[0].service_id == service.id
def test_after_setting_service_id_that_inbound_number_is_unavailable(
notify_db_session, sample_inbound_numbers
):
service = create_service(service_name="test service")
numbers = dao_get_available_inbound_numbers()
assert len(numbers) == 1
dao_set_inbound_number_to_service(service.id, numbers[0])
res = dao_get_available_inbound_numbers()
assert len(res) == 0
def test_setting_a_service_twice_will_raise_an_error(notify_db_session):
create_inbound_number(number="1")
create_inbound_number(number="2")
service = create_service(service_name="test service")
numbers = dao_get_available_inbound_numbers()
dao_set_inbound_number_to_service(service.id, numbers[0])
with pytest.raises(IntegrityError) as e:
dao_set_inbound_number_to_service(service.id, numbers[1])
assert "duplicate key value violates unique constraint" in str(e.value)
@pytest.mark.parametrize("active", [True, False])
def test_set_inbound_number_active_flag(notify_db_session, sample_service, active):
inbound_number = create_inbound_number(number="1")
dao_set_inbound_number_to_service(sample_service.id, inbound_number)
dao_set_inbound_number_active_flag(sample_service.id, active=active)
inbound_number = dao_get_inbound_number_for_service(sample_service.id)
assert inbound_number.active is active
def test_dao_allocate_number_for_service(notify_db_session):
number = "078945612"
inbound_number = create_inbound_number(number=number)
service = create_service()
updated_inbound_number = dao_allocate_number_for_service(
service_id=service.id, inbound_number_id=inbound_number.id
)
assert service.get_inbound_number() == number
assert updated_inbound_number.service_id == service.id
def test_dao_allocate_number_for_service_raises_if_inbound_number_already_taken(
notify_db_session, sample_service
):
number = "078945612"
inbound_number = create_inbound_number(number=number, service_id=sample_service.id)
service = create_service(service_name="Service needs an inbound number")
with pytest.raises(expected_exception=Exception) as exc:
dao_allocate_number_for_service(
service_id=service.id, inbound_number_id=inbound_number.id
)
assert "is not available" in str(exc.value)
def test_dao_allocate_number_for_service_raises_if_invalid_inbound_number(
notify_db_session, fake_uuid
):
service = create_service(service_name="Service needs an inbound number")
with pytest.raises(expected_exception=Exception) as exc:
dao_allocate_number_for_service(
service_id=service.id, inbound_number_id=fake_uuid
)
assert "is not available" in str(exc.value)