Refactored to put logic into API

This commit is contained in:
Ken Tsang
2017-08-14 12:17:14 +01:00
parent f0e9b93136
commit 7f1de19592
2 changed files with 69 additions and 70 deletions

View File

@@ -1,16 +1,13 @@
from flask import Blueprint, jsonify, request from flask import Blueprint, jsonify
from app.dao.inbound_numbers_dao import ( from app.dao.inbound_numbers_dao import (
dao_get_inbound_numbers, dao_get_inbound_numbers,
dao_get_inbound_number,
dao_get_inbound_number_for_service, dao_get_inbound_number_for_service,
dao_get_available_inbound_numbers, dao_get_available_inbound_numbers,
dao_set_inbound_number_to_service, dao_set_inbound_number_to_service,
dao_set_inbound_number_active_flag dao_set_inbound_number_active_flag
) )
from app.errors import InvalidRequest, register_errors from app.errors import InvalidRequest, register_errors
from app.models import InboundNumber
from app.schema_validation import validate
inbound_number_blueprint = Blueprint('inbound_number', __name__) inbound_number_blueprint = Blueprint('inbound_number', __name__)
register_errors(inbound_number_blueprint) register_errors(inbound_number_blueprint)
@@ -20,42 +17,34 @@ register_errors(inbound_number_blueprint)
def get_inbound_numbers(): def get_inbound_numbers():
inbound_numbers = [i.serialize() for i in dao_get_inbound_numbers()] inbound_numbers = [i.serialize() for i in dao_get_inbound_numbers()]
return jsonify(data=inbound_numbers if inbound_numbers else None) return jsonify(data=inbound_numbers if inbound_numbers else [])
@inbound_number_blueprint.route('/available', methods=['GET'])
def get_next_available_inbound_numbers():
inbound_numbers = [i.serialize() for i in dao_get_available_inbound_numbers()]
return jsonify(data=inbound_numbers[0] if len(inbound_numbers) else [])
@inbound_number_blueprint.route('/service/<uuid:service_id>', methods=['GET']) @inbound_number_blueprint.route('/service/<uuid:service_id>', methods=['GET'])
def get_inbound_number_for_service(service_id): def get_inbound_number_for_service(service_id):
inbound_number = dao_get_inbound_number_for_service(service_id) inbound_number = dao_get_inbound_number_for_service(service_id)
return jsonify(data=inbound_number.serialize() if inbound_number else None) return jsonify(data=inbound_number.serialize() if inbound_number else {})
@inbound_number_blueprint.route('/<uuid:inbound_number_id>/service/<uuid:service_id>', methods=['POST']) @inbound_number_blueprint.route('/service/<uuid:service_id>', methods=['POST'])
def post_set_inbound_number_for_service(inbound_number_id, service_id): def post_allocate_inbound_number(service_id):
inbound_number = dao_get_inbound_number_for_service(service_id) inbound_number = dao_get_inbound_number_for_service(service_id)
if inbound_number: if inbound_number:
raise InvalidRequest('Service already has an inbound number', status_code=400) if not inbound_number.active:
dao_set_inbound_number_active_flag(inbound_number.id, active=True)
return '', 204
else:
return '', 200
inbound_number = dao_get_inbound_number(inbound_number_id) available_numbers = dao_get_available_inbound_numbers()
if inbound_number.service_id:
raise InvalidRequest('Inbound number already assigned', status_code=400)
dao_set_inbound_number_to_service(service_id, inbound_number) if len(available_numbers) > 0:
dao_set_inbound_number_to_service(service_id, available_numbers[0])
return '', 204 return '', 204
else:
raise InvalidRequest('No available inbound numbers', status_code=400)
@inbound_number_blueprint.route('/<uuid:inbound_number_id>/on', methods=['POST'])
def post_set_inbound_number_on(inbound_number_id):
dao_set_inbound_number_active_flag(inbound_number_id, active=True)
return '', 204
@inbound_number_blueprint.route('/<uuid:inbound_number_id>/off', methods=['POST']) @inbound_number_blueprint.route('/<uuid:inbound_number_id>/off', methods=['POST'])

View File

@@ -4,16 +4,17 @@ from flask import url_for
import json import json
from app.models import InboundNumber from app.models import InboundNumber
from app.dao.inbound_numbers_dao import ( from app.dao.inbound_numbers_dao import dao_get_inbound_number_for_service
dao_get_inbound_numbers,
dao_get_available_inbound_numbers,
dao_get_inbound_number_for_service,
dao_set_inbound_number_to_service
)
from tests.app.db import create_service, create_inbound_number from tests.app.db import create_service, create_inbound_number
def test_rest_get_inbound_numbers_when_none_set_returns_empty_list(admin_request):
result = admin_request.get('inbound_number.get_inbound_numbers')
assert result['data'] == []
def test_rest_get_inbound_numbers(admin_request, sample_inbound_numbers): def test_rest_get_inbound_numbers(admin_request, sample_inbound_numbers):
result = admin_request.get('inbound_number.get_inbound_numbers') result = admin_request.get('inbound_number.get_inbound_numbers')
@@ -21,16 +22,6 @@ def test_rest_get_inbound_numbers(admin_request, sample_inbound_numbers):
assert result['data'] == [i.serialize() for i in sample_inbound_numbers] assert result['data'] == [i.serialize() for i in sample_inbound_numbers]
def test_rest_get_next_available_inbound_numbers(admin_request, sample_service):
create_inbound_number(number='1', provider='mmg', active=False, service_id=sample_service.id)
next_available_inbound_number = create_inbound_number(number='2', provider='mmg', active=True)
create_inbound_number(number='3', provider='firetext', active=True)
result = admin_request.get('inbound_number.get_next_available_inbound_numbers')
assert result['data'] == next_available_inbound_number.serialize()
def test_rest_get_inbound_number(admin_request, notify_db_session, sample_service): def test_rest_get_inbound_number(admin_request, notify_db_session, sample_service):
inbound_number = create_inbound_number(number='1', provider='mmg', active=False, service_id=sample_service.id) inbound_number = create_inbound_number(number='1', provider='mmg', active=False, service_id=sample_service.id)
@@ -41,15 +32,23 @@ def test_rest_get_inbound_number(admin_request, notify_db_session, sample_servic
assert result['data'] == inbound_number.serialize() assert result['data'] == inbound_number.serialize()
def test_rest_set_number_to_service( def test_rest_get_inbound_number_when_service_is_not_assigned_returns_empty_dict(
admin_request, notify_db_session, sample_service):
result = admin_request.get(
'inbound_number.get_inbound_number_for_service',
service_id=sample_service.id
)
assert result['data'] == {}
def test_rest_allocate_inbound_number_to_service(
admin_request, notify_db_session, sample_service): admin_request, notify_db_session, sample_service):
service = create_service(service_name='test service 1') service = create_service(service_name='test service 1')
inbound_number = create_inbound_number(number='1', provider='mmg', active=True) inbound_number = create_inbound_number(number='1', provider='mmg', active=True)
result = admin_request.post( result = admin_request.post(
'inbound_number.post_set_inbound_number_for_service', 'inbound_number.post_allocate_inbound_number',
_expected_status=204, _expected_status=204,
inbound_number_id=inbound_number.id,
service_id=service.id service_id=service.id
) )
@@ -60,48 +59,59 @@ def test_rest_set_number_to_service(
assert inbound_number_from_db.number == inbound_number.number assert inbound_number_from_db.number == inbound_number.number
def test_rest_set_number_to_several_services_returns_400( def test_rest_allocate_inbound_number_to_service_raises_400_when_no_available_numbers(
admin_request, notify_db_session, sample_service): admin_request, notify_db_session, sample_service):
service_1 = create_service(service_name='test service 1') service = create_service(service_name='test service 1')
inbound_number = create_inbound_number(number='1', provider='mmg', active=True, service_id=sample_service.id) create_inbound_number(number='1', provider='mmg', active=False)
create_inbound_number(number='2', provider='mmg', active=True, service_id=None)
service_2 = create_service(service_name='test service 2')
result = admin_request.post( result = admin_request.post(
'inbound_number.post_set_inbound_number_for_service', 'inbound_number.post_allocate_inbound_number',
_expected_status=400, _expected_status=400,
inbound_number_id=inbound_number.id, service_id=service.id
service_id=service_2.id
) )
assert result['message'] == 'Inbound number already assigned'
assert result['message'] == 'No available inbound numbers'
def test_rest_set_multiple_numbers_to_a_service_returns_400( def test_rest_allocate_inbound_number_to_service_sets_active_flag_true_when_flag_is_false(
admin_request, notify_db_session, sample_service): admin_request, notify_db_session, sample_service):
create_inbound_number(number='1', provider='mmg', active=True, service_id=sample_service.id) service = create_service(service_name='test service 1')
inbound_number = create_inbound_number(number='2', provider='mmg', active=True, service_id=None) create_inbound_number(number='1', provider='mmg', active=False, service_id=service.id)
result = admin_request.post( result = admin_request.post(
'inbound_number.post_set_inbound_number_for_service', 'inbound_number.post_allocate_inbound_number',
_expected_status=400, _expected_status=204,
inbound_number_id=inbound_number.id, service_id=service.id
service_id=sample_service.id
) )
assert result['message'] == 'Service already has an inbound number'
inbound_number = dao_get_inbound_number_for_service(service.id)
assert inbound_number.active
@pytest.mark.parametrize("active_flag,expected_flag_state", [("on", True), ("off", False)]) def test_rest_allocate_inbound_number_to_service_sets_active_flag_true_when_flag_is_true(
def test_rest_set_inbound_number_active_flag( admin_request, notify_db_session, sample_service):
admin_request, notify_db_session, active_flag, expected_flag_state): service = create_service(service_name='test service 1')
create_inbound_number(number='1', provider='mmg', active=True, service_id=service.id)
result = admin_request.post(
'inbound_number.post_allocate_inbound_number',
_expected_status=200,
service_id=service.id
)
def test_rest_set_inbound_number_active_flag_off(
admin_request, notify_db_session):
service = create_service(service_name='test service 1') service = create_service(service_name='test service 1')
inbound_number = create_inbound_number( inbound_number = create_inbound_number(
number='1', provider='mmg', active=not expected_flag_state, service_id=service.id) number='1', provider='mmg', active=True, service_id=service.id)
admin_request.post( admin_request.post(
'inbound_number.post_set_inbound_number_{}'.format(active_flag), 'inbound_number.post_set_inbound_number_off',
_expected_status=204, _expected_status=204,
inbound_number_id=inbound_number.id inbound_number_id=inbound_number.id
) )
inbound_number_from_db = dao_get_inbound_number_for_service(service.id) inbound_number_from_db = dao_get_inbound_number_for_service(service.id)
assert inbound_number_from_db.active == expected_flag_state assert not inbound_number_from_db.active