mirror of
https://github.com/GSA/notifications-api.git
synced 2025-12-20 23:41:17 -05:00
Add error handler for duplicate domain
This commit is contained in:
@@ -1,4 +1,5 @@
|
|||||||
from flask import Blueprint, jsonify, request
|
from flask import Blueprint, current_app, jsonify, request
|
||||||
|
from sqlalchemy.exc import IntegrityError
|
||||||
|
|
||||||
from app.dao.email_branding_dao import (
|
from app.dao.email_branding_dao import (
|
||||||
dao_create_email_branding,
|
dao_create_email_branding,
|
||||||
@@ -18,6 +19,22 @@ email_branding_blueprint = Blueprint('email_branding', __name__)
|
|||||||
register_errors(email_branding_blueprint)
|
register_errors(email_branding_blueprint)
|
||||||
|
|
||||||
|
|
||||||
|
@email_branding_blueprint.errorhandler(IntegrityError)
|
||||||
|
def handle_integrity_error(exc):
|
||||||
|
"""
|
||||||
|
Handle integrity errors caused by the unique constraint on domain
|
||||||
|
"""
|
||||||
|
if 'domain' in str(exc):
|
||||||
|
return jsonify(
|
||||||
|
result='error',
|
||||||
|
message={'name': ["Duplicate domain '{}'".format(
|
||||||
|
exc.params.get('domain')
|
||||||
|
)]}
|
||||||
|
), 400
|
||||||
|
current_app.logger.exception(exc)
|
||||||
|
return jsonify(result='error', message="Internal server error"), 500
|
||||||
|
|
||||||
|
|
||||||
@email_branding_blueprint.route('', methods=['GET'])
|
@email_branding_blueprint.route('', methods=['GET'])
|
||||||
def get_email_branding_options():
|
def get_email_branding_options():
|
||||||
email_branding_options = [o.serialize() for o in dao_get_email_branding_options()]
|
email_branding_options = [o.serialize() for o in dao_get_email_branding_options()]
|
||||||
|
|||||||
@@ -257,3 +257,30 @@ def test_update_email_branding_reject_invalid_brand_type(admin_request, notify_d
|
|||||||
)
|
)
|
||||||
|
|
||||||
assert response['errors'][0]['message'] == 'brand_type NOT A TYPE is not one of [org, both, org_banner]'
|
assert response['errors'][0]['message'] == 'brand_type NOT A TYPE is not one of [org, both, org_banner]'
|
||||||
|
|
||||||
|
|
||||||
|
def test_400_for_duplicate_domain(admin_request, notify_db_session):
|
||||||
|
branding_1 = create_email_branding()
|
||||||
|
branding_2 = create_email_branding()
|
||||||
|
admin_request.post(
|
||||||
|
'email_branding.update_email_branding',
|
||||||
|
_data={'domain': 'example.com'},
|
||||||
|
email_branding_id=branding_1.id,
|
||||||
|
)
|
||||||
|
|
||||||
|
response = admin_request.post(
|
||||||
|
'email_branding.update_email_branding',
|
||||||
|
_data={'domain': 'example.com'},
|
||||||
|
email_branding_id=branding_2.id,
|
||||||
|
_expected_status=400,
|
||||||
|
)
|
||||||
|
assert response['result'] == 'error'
|
||||||
|
assert response['message']['name'] == ["Duplicate domain 'example.com'"]
|
||||||
|
|
||||||
|
response = admin_request.post(
|
||||||
|
'email_branding.create_email_branding',
|
||||||
|
_data={'domain': 'example.com'},
|
||||||
|
_expected_status=400,
|
||||||
|
)
|
||||||
|
assert response['result'] == 'error'
|
||||||
|
assert response['message']['name'] == ["Duplicate domain 'example.com'"]
|
||||||
|
|||||||
Reference in New Issue
Block a user