Update ServiceWhitelist to conform to new data model

This commit is contained in:
Imdad Ahad
2016-09-27 13:44:29 +01:00
parent 005e8a9c3a
commit 8184eff15a
2 changed files with 42 additions and 28 deletions

View File

@@ -138,6 +138,11 @@ class Service(db.Model, Versioned):
default=BRANDING_GOVUK default=BRANDING_GOVUK
) )
MOBILE_TYPE = 'mobile'
EMAIL_TYPE = 'email'
WHITELIST_RECIPIENT_TYPE = [MOBILE_TYPE, EMAIL_TYPE]
whitelist_recipient_types = db.Enum(*WHITELIST_RECIPIENT_TYPE, name='recipient_type')
class ServiceWhitelist(db.Model): class ServiceWhitelist(db.Model):
__tablename__ = 'service_whitelist' __tablename__ = 'service_whitelist'
@@ -145,24 +150,33 @@ class ServiceWhitelist(db.Model):
id = db.Column(UUID(as_uuid=True), primary_key=True, default=uuid.uuid4) id = db.Column(UUID(as_uuid=True), primary_key=True, default=uuid.uuid4)
service_id = db.Column(UUID(as_uuid=True), db.ForeignKey('services.id'), index=True, nullable=False) service_id = db.Column(UUID(as_uuid=True), db.ForeignKey('services.id'), index=True, nullable=False)
service = db.relationship('Service', backref='whitelist') service = db.relationship('Service', backref='whitelist')
email_address = db.Column(db.String(255), nullable=True) recipient_type = db.Column(whitelist_recipient_types, nullable=False)
mobile_number = db.Column(db.String, nullable=True) recipient = db.Column(db.String(255), nullable=False)
created_at = db.Column(db.DateTime, default=datetime.datetime.utcnow) created_at = db.Column(db.DateTime, default=datetime.datetime.utcnow)
@classmethod @classmethod
def from_string(cls, service_id, contact): def from_string(cls, service_id, recipient_type, recipient):
instance = cls(service_id=service_id) instance = cls(service_id=service_id, recipient_type=recipient_type)
try:
validate_email_address(contact)
instance.email_address = contact
except InvalidEmailError:
try:
validate_phone_number(contact)
instance.mobile_number = contact
except InvalidPhoneError:
raise ValueError('Invalid whitelist: "{}"'.format(contact))
return instance try:
if recipient_type == MOBILE_TYPE:
validate_phone_number(recipient)
instance.recipient = recipient
elif recipient_type == EMAIL_TYPE:
validate_email_address(recipient)
instance.recipient = recipient
else:
raise ValueError('Invalid recipient type')
except InvalidPhoneError:
raise ValueError('Invalid whitelist: "{}"'.format(recipient))
except InvalidEmailError:
raise ValueError('Invalid whitelist: "{}"'.format(recipient))
else:
return instance
def __repr__(self):
return 'Recipient {} of type: {}'.format(self.recipient,
self.recipient_type)
class ApiKey(db.Model, Versioned): class ApiKey(db.Model, Versioned):
@@ -329,7 +343,6 @@ class ProviderDetails(db.Model):
priority = db.Column(db.Integer, nullable=False) priority = db.Column(db.Integer, nullable=False)
notification_type = db.Column(notification_types, nullable=False) notification_type = db.Column(notification_types, nullable=False)
active = db.Column(db.Boolean, default=False) active = db.Column(db.Boolean, default=False)
blah = db.Column
JOB_STATUS_PENDING = 'pending' JOB_STATUS_PENDING = 'pending'

View File

@@ -3,7 +3,10 @@ from datetime import datetime
import pytest import pytest
from app import DATETIME_FORMAT from app import DATETIME_FORMAT
from app.models import Notification, ServiceWhitelist from app.models import (
Notification,
ServiceWhitelist,
MOBILE_TYPE, EMAIL_TYPE)
def test_should_build_notification_from_minimal_set_of_api_derived_params(notify_api): def test_should_build_notification_from_minimal_set_of_api_derived_params(notify_api):
@@ -79,27 +82,25 @@ def test_should_build_notification_from_full_set_of_api_derived_params(notify_ap
'+44 7700 900678' '+44 7700 900678'
]) ])
def test_should_build_service_whitelist_from_mobile_number(mobile_number): def test_should_build_service_whitelist_from_mobile_number(mobile_number):
service_whitelist = ServiceWhitelist.from_string('service_id', mobile_number) service_whitelist = ServiceWhitelist.from_string('service_id', MOBILE_TYPE, mobile_number)
assert service_whitelist.mobile_number == mobile_number assert service_whitelist.recipient == mobile_number
assert service_whitelist.email_address is None
@pytest.mark.parametrize('email_address', [ @pytest.mark.parametrize('email_address', [
'test@example.com' 'test@example.com'
]) ])
def test_should_build_service_whitelist_from_email_address(email_address): def test_should_build_service_whitelist_from_email_address(email_address):
service_whitelist = ServiceWhitelist.from_string('service_id', email_address) service_whitelist = ServiceWhitelist.from_string('service_id', EMAIL_TYPE, email_address)
assert service_whitelist.email_address == email_address assert service_whitelist.recipient == email_address
assert service_whitelist.mobile_number is None
@pytest.mark.parametrize('contact', [ @pytest.mark.parametrize('contact, recipient_type', [
'', ('', None),
'07700dsadsad', ('07700dsadsad', MOBILE_TYPE),
'gmail.com' ('gmail.com', EMAIL_TYPE)
]) ])
def test_should_not_build_service_whitelist_from_invalid_contact(contact): def test_should_not_build_service_whitelist_from_invalid_contact(recipient_type, contact):
with pytest.raises(ValueError): with pytest.raises(ValueError):
ServiceWhitelist.from_string('service_id', contact) ServiceWhitelist.from_string('service_id', recipient_type, contact)