mirror of
https://github.com/GSA/notifications-api.git
synced 2026-02-04 18:31:13 -05:00
Merge pull request #795 from alphagov/switch-providers-on-error
Auto-switch providers on error
This commit is contained in:
@@ -1,3 +1,5 @@
|
||||
import pytest
|
||||
|
||||
from datetime import datetime
|
||||
|
||||
from freezegun import freeze_time
|
||||
@@ -5,12 +7,28 @@ from freezegun import freeze_time
|
||||
from app.models import ProviderDetails, ProviderDetailsHistory
|
||||
from app import clients
|
||||
from app.dao.provider_details_dao import (
|
||||
get_alternative_sms_provider,
|
||||
get_current_provider,
|
||||
get_provider_details,
|
||||
get_provider_details_by_identifier,
|
||||
get_provider_details_by_notification_type,
|
||||
dao_switch_sms_provider_to_provider_with_identifier,
|
||||
dao_toggle_sms_provider,
|
||||
dao_update_provider_details
|
||||
)
|
||||
|
||||
|
||||
def set_primary_sms_provider(identifier='mmg'):
|
||||
primary_provider = get_provider_details_by_identifier(identifier)
|
||||
secondary_provider = get_alternative_sms_provider(identifier)
|
||||
|
||||
primary_provider.priority = 10
|
||||
secondary_provider.priority = 20
|
||||
|
||||
dao_update_provider_details(primary_provider)
|
||||
dao_update_provider_details(secondary_provider)
|
||||
|
||||
|
||||
def test_can_get_all_providers(restore_provider_details):
|
||||
assert len(get_provider_details()) == 4
|
||||
|
||||
@@ -21,15 +39,13 @@ def test_can_get_sms_providers(restore_provider_details):
|
||||
assert all('sms' == prov.notification_type for prov in sms_providers)
|
||||
|
||||
|
||||
def test_can_get_sms_providers_in_order(restore_provider_details):
|
||||
def test_can_get_sms_providers_in_order_of_priority(restore_provider_details):
|
||||
providers = get_provider_details_by_notification_type('sms')
|
||||
|
||||
assert providers[0].identifier == "mmg"
|
||||
assert providers[1].identifier == "firetext"
|
||||
assert providers[2].identifier == "loadtesting"
|
||||
assert providers[0].priority < providers[1].priority < providers[2].priority
|
||||
|
||||
|
||||
def test_can_get_email_providers_in_order(restore_provider_details):
|
||||
def test_can_get_email_providers_in_order_of_priority(restore_provider_details):
|
||||
providers = get_provider_details_by_notification_type('email')
|
||||
|
||||
assert providers[0].identifier == "ses"
|
||||
@@ -78,3 +94,81 @@ def test_update_adds_history(restore_provider_details):
|
||||
assert not ses_history[1].active
|
||||
assert ses_history[1].version == 2
|
||||
assert ses_history[1].updated_at == datetime(2000, 1, 1, 0, 0, 0)
|
||||
|
||||
|
||||
def test_update_sms_provider_to_inactive_sets_inactive(restore_provider_details):
|
||||
set_primary_sms_provider('mmg')
|
||||
primary_provider = get_current_provider('sms')
|
||||
primary_provider.active = False
|
||||
|
||||
dao_update_provider_details(primary_provider)
|
||||
|
||||
assert not primary_provider.active
|
||||
|
||||
|
||||
def test_get_current_sms_provider_returns_correct_provider(restore_provider_details):
|
||||
set_primary_sms_provider('mmg')
|
||||
|
||||
provider = get_current_provider('sms')
|
||||
|
||||
assert provider.identifier == 'mmg'
|
||||
|
||||
|
||||
@pytest.mark.parametrize('provider_identifier', ['firetext', 'mmg'])
|
||||
def test_get_alternative_sms_provider_returns_expected_provider(notify_db, provider_identifier):
|
||||
provider = get_alternative_sms_provider(provider_identifier)
|
||||
assert provider.identifier != provider
|
||||
|
||||
|
||||
def test_switch_sms_provider_to_current_provider_does_not_switch(
|
||||
restore_provider_details,
|
||||
current_sms_provider,
|
||||
mocker
|
||||
):
|
||||
dao_switch_sms_provider_to_provider_with_identifier(current_sms_provider.identifier)
|
||||
new_provider = get_current_provider('sms')
|
||||
|
||||
assert current_sms_provider.id == new_provider.id
|
||||
assert current_sms_provider.identifier == new_provider.identifier
|
||||
|
||||
|
||||
def test_switch_sms_provider_to_inactive_provider_does_not_switch(
|
||||
restore_provider_details,
|
||||
current_sms_provider,
|
||||
mocker
|
||||
):
|
||||
alternative_sms_provider = get_alternative_sms_provider(current_sms_provider.identifier)
|
||||
alternative_sms_provider.active = False
|
||||
dao_update_provider_details(alternative_sms_provider)
|
||||
|
||||
dao_switch_sms_provider_to_provider_with_identifier(alternative_sms_provider.identifier)
|
||||
new_provider = get_current_provider('sms')
|
||||
|
||||
assert new_provider.id == current_sms_provider.id
|
||||
assert new_provider.identifier == current_sms_provider.identifier
|
||||
|
||||
|
||||
def test_toggle_sms_provider_switches_provider(
|
||||
restore_provider_details,
|
||||
current_sms_provider,
|
||||
mocker
|
||||
):
|
||||
dao_toggle_sms_provider(current_sms_provider.identifier)
|
||||
new_provider = get_current_provider('sms')
|
||||
assert new_provider.identifier != current_sms_provider.identifier
|
||||
assert new_provider.priority < current_sms_provider.priority
|
||||
|
||||
|
||||
def test_toggle_sms_provider_switches_when_provider_priorities_are_equal(
|
||||
restore_provider_details,
|
||||
current_sms_provider,
|
||||
mocker
|
||||
):
|
||||
new_provider = get_alternative_sms_provider(current_sms_provider.identifier)
|
||||
current_sms_provider.priority = new_provider.priority
|
||||
dao_update_provider_details(current_sms_provider)
|
||||
|
||||
dao_toggle_sms_provider(current_sms_provider.identifier)
|
||||
|
||||
assert new_provider.identifier != current_sms_provider.identifier
|
||||
assert new_provider.priority < current_sms_provider.priority
|
||||
|
||||
Reference in New Issue
Block a user