2016-10-31 12:22:26 +00:00
|
|
|
import uuid
|
2017-05-23 10:35:13 +01:00
|
|
|
|
2016-11-14 13:56:09 +00:00
|
|
|
import pytest
|
2017-05-22 14:39:30 +01:00
|
|
|
from freezegun import freeze_time
|
2017-05-16 09:57:58 +01:00
|
|
|
|
2017-06-28 12:14:36 +01:00
|
|
|
from app.models import (
|
|
|
|
|
Notification, ScheduledNotification, SCHEDULE_NOTIFICATIONS,
|
|
|
|
|
EMAIL_TYPE, INTERNATIONAL_SMS_TYPE, SMS_TYPE
|
|
|
|
|
)
|
2017-05-23 10:35:13 +01:00
|
|
|
from flask import json, current_app
|
|
|
|
|
|
2016-11-01 10:33:34 +00:00
|
|
|
from app.models import Notification
|
2017-04-24 14:15:08 +01:00
|
|
|
from app.v2.errors import RateLimitError
|
2016-10-27 11:46:37 +01:00
|
|
|
from tests import create_authorization_header
|
2017-06-29 11:13:32 +01:00
|
|
|
from tests.app.conftest import (
|
|
|
|
|
sample_template as create_sample_template, sample_service,
|
|
|
|
|
sample_template_without_sms_permission, sample_template_without_email_permission
|
|
|
|
|
)
|
|
|
|
|
|
2017-05-26 15:41:14 +01:00
|
|
|
from tests.app.db import create_service, create_template
|
2016-10-27 11:46:37 +01:00
|
|
|
|
|
|
|
|
|
2016-11-21 17:32:36 +00:00
|
|
|
@pytest.mark.parametrize("reference", [None, "reference_from_client"])
|
2017-05-25 11:41:07 +01:00
|
|
|
def test_post_sms_notification_returns_201(client, sample_template_with_placeholders, mocker, reference):
|
|
|
|
|
mocked = mocker.patch('app.celery.provider_tasks.deliver_sms.apply_async')
|
|
|
|
|
data = {
|
|
|
|
|
'phone_number': '+447700900855',
|
|
|
|
|
'template_id': str(sample_template_with_placeholders.id),
|
|
|
|
|
'personalisation': {' Name': 'Jo'}
|
|
|
|
|
}
|
|
|
|
|
if reference:
|
|
|
|
|
data.update({"reference": reference})
|
|
|
|
|
auth_header = create_authorization_header(service_id=sample_template_with_placeholders.service_id)
|
2016-10-27 11:46:37 +01:00
|
|
|
|
2017-05-25 11:41:07 +01:00
|
|
|
response = client.post(
|
|
|
|
|
path='/v2/notifications/sms',
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
|
|
|
|
assert response.status_code == 201
|
|
|
|
|
resp_json = json.loads(response.get_data(as_text=True))
|
|
|
|
|
notifications = Notification.query.all()
|
|
|
|
|
assert len(notifications) == 1
|
|
|
|
|
notification_id = notifications[0].id
|
|
|
|
|
assert resp_json['id'] == str(notification_id)
|
|
|
|
|
assert resp_json['reference'] == reference
|
|
|
|
|
assert resp_json['content']['body'] == sample_template_with_placeholders.content.replace("(( Name))", "Jo")
|
|
|
|
|
assert resp_json['content']['from_number'] == current_app.config['FROM_NUMBER']
|
|
|
|
|
assert 'v2/notifications/{}'.format(notification_id) in resp_json['uri']
|
|
|
|
|
assert resp_json['template']['id'] == str(sample_template_with_placeholders.id)
|
|
|
|
|
assert resp_json['template']['version'] == sample_template_with_placeholders.version
|
|
|
|
|
assert 'services/{}/templates/{}'.format(sample_template_with_placeholders.service_id,
|
|
|
|
|
sample_template_with_placeholders.id) \
|
|
|
|
|
in resp_json['template']['uri']
|
|
|
|
|
assert not resp_json["scheduled_for"]
|
|
|
|
|
assert mocked.called
|
2016-10-27 11:46:37 +01:00
|
|
|
|
|
|
|
|
|
2017-01-17 13:16:26 +00:00
|
|
|
@pytest.mark.parametrize("notification_type, key_send_to, send_to",
|
|
|
|
|
[("sms", "phone_number", "+447700900855"),
|
|
|
|
|
("email", "email_address", "sample@email.com")])
|
2017-06-29 11:13:32 +01:00
|
|
|
def test_post_sms_notification_returns_400_and_missing_template(client, sample_service,
|
2017-01-17 13:16:26 +00:00
|
|
|
notification_type, key_send_to, send_to):
|
|
|
|
|
data = {
|
|
|
|
|
key_send_to: send_to,
|
|
|
|
|
'template_id': str(uuid.uuid4())
|
|
|
|
|
}
|
|
|
|
|
auth_header = create_authorization_header(service_id=sample_service.id)
|
2016-10-27 11:46:37 +01:00
|
|
|
|
2017-01-17 13:16:26 +00:00
|
|
|
response = client.post(
|
|
|
|
|
path='/v2/notifications/{}'.format(notification_type),
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
2016-10-27 11:46:37 +01:00
|
|
|
|
2017-01-17 13:16:26 +00:00
|
|
|
assert response.status_code == 400
|
|
|
|
|
assert response.headers['Content-type'] == 'application/json'
|
2016-10-31 12:22:26 +00:00
|
|
|
|
2017-01-17 13:16:26 +00:00
|
|
|
error_json = json.loads(response.get_data(as_text=True))
|
|
|
|
|
assert error_json['status_code'] == 400
|
|
|
|
|
assert error_json['errors'] == [{"error": "BadRequestError",
|
|
|
|
|
"message": 'Template not found'}]
|
2016-10-31 12:22:26 +00:00
|
|
|
|
|
|
|
|
|
2017-01-17 13:16:26 +00:00
|
|
|
@pytest.mark.parametrize("notification_type, key_send_to, send_to",
|
|
|
|
|
[("sms", "phone_number", "+447700900855"),
|
|
|
|
|
("email", "email_address", "sample@email.com")])
|
|
|
|
|
def test_post_notification_returns_403_and_well_formed_auth_error(client, sample_template,
|
|
|
|
|
notification_type, key_send_to, send_to):
|
|
|
|
|
data = {
|
|
|
|
|
key_send_to: send_to,
|
|
|
|
|
'template_id': str(sample_template.id)
|
|
|
|
|
}
|
2016-10-31 12:22:26 +00:00
|
|
|
|
2017-01-17 13:16:26 +00:00
|
|
|
response = client.post(
|
|
|
|
|
path='/v2/notifications/{}'.format(notification_type),
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json')])
|
2016-10-31 12:22:26 +00:00
|
|
|
|
2017-01-17 13:16:26 +00:00
|
|
|
assert response.status_code == 401
|
|
|
|
|
assert response.headers['Content-type'] == 'application/json'
|
|
|
|
|
error_resp = json.loads(response.get_data(as_text=True))
|
|
|
|
|
assert error_resp['status_code'] == 401
|
|
|
|
|
assert error_resp['errors'] == [{'error': "AuthError",
|
|
|
|
|
'message': 'Unauthorized, authentication token must be provided'}]
|
2016-10-31 15:43:11 +00:00
|
|
|
|
|
|
|
|
|
2017-01-17 13:16:26 +00:00
|
|
|
@pytest.mark.parametrize("notification_type, key_send_to, send_to",
|
|
|
|
|
[("sms", "phone_number", "+447700900855"),
|
|
|
|
|
("email", "email_address", "sample@email.com")])
|
|
|
|
|
def test_notification_returns_400_and_for_schema_problems(client, sample_template, notification_type, key_send_to,
|
|
|
|
|
send_to):
|
|
|
|
|
data = {
|
|
|
|
|
key_send_to: send_to,
|
|
|
|
|
'template': str(sample_template.id)
|
|
|
|
|
}
|
|
|
|
|
auth_header = create_authorization_header(service_id=sample_template.service_id)
|
2016-10-31 15:43:11 +00:00
|
|
|
|
2017-01-17 13:16:26 +00:00
|
|
|
response = client.post(
|
|
|
|
|
path='/v2/notifications/{}'.format(notification_type),
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
2016-10-31 15:43:11 +00:00
|
|
|
|
2017-01-17 13:16:26 +00:00
|
|
|
assert response.status_code == 400
|
|
|
|
|
assert response.headers['Content-type'] == 'application/json'
|
|
|
|
|
error_resp = json.loads(response.get_data(as_text=True))
|
|
|
|
|
assert error_resp['status_code'] == 400
|
|
|
|
|
assert error_resp['errors'] == [{'error': 'ValidationError',
|
|
|
|
|
'message': "template_id is a required property"
|
|
|
|
|
}]
|
2016-11-14 13:56:09 +00:00
|
|
|
|
|
|
|
|
|
2016-11-21 17:32:36 +00:00
|
|
|
@pytest.mark.parametrize("reference", [None, "reference_from_client"])
|
2016-11-28 15:49:29 +00:00
|
|
|
def test_post_email_notification_returns_201(client, sample_email_template_with_placeholders, mocker, reference):
|
2017-03-30 10:46:23 +01:00
|
|
|
mocked = mocker.patch('app.celery.provider_tasks.deliver_email.apply_async')
|
2016-11-14 13:56:09 +00:00
|
|
|
data = {
|
2016-11-28 15:49:29 +00:00
|
|
|
"email_address": sample_email_template_with_placeholders.service.users[0].email_address,
|
|
|
|
|
"template_id": sample_email_template_with_placeholders.id,
|
|
|
|
|
"personalisation": {"name": "Bob"}
|
2016-11-14 13:56:09 +00:00
|
|
|
}
|
2016-11-21 17:32:36 +00:00
|
|
|
if reference:
|
|
|
|
|
data.update({"reference": reference})
|
2016-11-28 15:49:29 +00:00
|
|
|
auth_header = create_authorization_header(service_id=sample_email_template_with_placeholders.service_id)
|
2016-11-14 13:56:09 +00:00
|
|
|
response = client.post(
|
|
|
|
|
path="v2/notifications/email",
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
|
|
|
|
assert response.status_code == 201
|
|
|
|
|
resp_json = json.loads(response.get_data(as_text=True))
|
2017-03-30 10:46:23 +01:00
|
|
|
notification = Notification.query.first()
|
|
|
|
|
assert resp_json['id'] == str(notification.id)
|
|
|
|
|
assert resp_json['reference'] == reference
|
|
|
|
|
assert notification.reference is None
|
2017-01-17 13:16:26 +00:00
|
|
|
assert resp_json['content']['body'] == sample_email_template_with_placeholders.content \
|
2016-12-09 15:56:25 +00:00
|
|
|
.replace('((name))', 'Bob').replace('GOV.UK', u'GOV.\u200bUK')
|
2017-01-17 13:16:26 +00:00
|
|
|
assert resp_json['content']['subject'] == sample_email_template_with_placeholders.subject \
|
2016-12-09 15:56:25 +00:00
|
|
|
.replace('((name))', 'Bob')
|
2016-11-28 15:49:29 +00:00
|
|
|
assert resp_json['content']['from_email'] == sample_email_template_with_placeholders.service.email_from
|
2017-03-30 10:46:23 +01:00
|
|
|
assert 'v2/notifications/{}'.format(notification.id) in resp_json['uri']
|
2016-11-28 15:49:29 +00:00
|
|
|
assert resp_json['template']['id'] == str(sample_email_template_with_placeholders.id)
|
|
|
|
|
assert resp_json['template']['version'] == sample_email_template_with_placeholders.version
|
2017-01-04 11:22:50 +00:00
|
|
|
assert 'services/{}/templates/{}'.format(str(sample_email_template_with_placeholders.service_id),
|
|
|
|
|
str(sample_email_template_with_placeholders.id)) \
|
|
|
|
|
in resp_json['template']['uri']
|
2017-05-15 17:27:38 +01:00
|
|
|
assert not resp_json["scheduled_for"]
|
2016-11-14 13:56:09 +00:00
|
|
|
assert mocked.called
|
|
|
|
|
|
|
|
|
|
|
2017-01-17 12:08:24 +00:00
|
|
|
@pytest.mark.parametrize('recipient, notification_type', [
|
2017-06-28 12:14:36 +01:00
|
|
|
('simulate-delivered@notifications.service.gov.uk', EMAIL_TYPE),
|
|
|
|
|
('simulate-delivered-2@notifications.service.gov.uk', EMAIL_TYPE),
|
|
|
|
|
('simulate-delivered-3@notifications.service.gov.uk', EMAIL_TYPE),
|
2017-01-17 12:08:24 +00:00
|
|
|
('07700 900000', 'sms'),
|
|
|
|
|
('07700 900111', 'sms'),
|
|
|
|
|
('07700 900222', 'sms')
|
|
|
|
|
])
|
2017-01-18 09:56:26 +00:00
|
|
|
def test_should_not_persist_or_send_notification_if_simulated_recipient(
|
2017-01-17 12:08:24 +00:00
|
|
|
client,
|
|
|
|
|
recipient,
|
|
|
|
|
notification_type,
|
|
|
|
|
sample_email_template,
|
|
|
|
|
sample_template,
|
|
|
|
|
mocker):
|
|
|
|
|
apply_async = mocker.patch('app.celery.provider_tasks.deliver_{}.apply_async'.format(notification_type))
|
|
|
|
|
|
|
|
|
|
if notification_type == 'sms':
|
|
|
|
|
data = {
|
|
|
|
|
'phone_number': recipient,
|
|
|
|
|
'template_id': str(sample_template.id)
|
|
|
|
|
}
|
|
|
|
|
else:
|
|
|
|
|
data = {
|
|
|
|
|
'email_address': recipient,
|
|
|
|
|
'template_id': str(sample_email_template.id)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
auth_header = create_authorization_header(service_id=sample_email_template.service_id)
|
|
|
|
|
|
|
|
|
|
response = client.post(
|
|
|
|
|
path='/v2/notifications/{}'.format(notification_type),
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
|
|
|
|
|
|
|
|
|
assert response.status_code == 201
|
|
|
|
|
apply_async.assert_not_called()
|
|
|
|
|
assert Notification.query.count() == 0
|
2017-01-17 13:16:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize("notification_type, key_send_to, send_to",
|
|
|
|
|
[("sms", "phone_number", "07700 900 855"),
|
|
|
|
|
("email", "email_address", "sample@email.com")])
|
|
|
|
|
def test_send_notification_uses_priority_queue_when_template_is_marked_as_priority(client, notify_db,
|
|
|
|
|
notify_db_session,
|
|
|
|
|
mocker,
|
|
|
|
|
notification_type,
|
|
|
|
|
key_send_to,
|
|
|
|
|
send_to):
|
2017-04-27 12:47:08 +01:00
|
|
|
|
|
|
|
|
mocker.patch('app.celery.provider_tasks.deliver_{}.apply_async'.format(notification_type))
|
|
|
|
|
|
2017-01-17 13:16:26 +00:00
|
|
|
sample = create_sample_template(
|
|
|
|
|
notify_db,
|
|
|
|
|
notify_db_session,
|
|
|
|
|
template_type=notification_type,
|
|
|
|
|
process_type='priority'
|
|
|
|
|
)
|
2017-03-30 10:46:23 +01:00
|
|
|
mocked = mocker.patch('app.celery.provider_tasks.deliver_{}.apply_async'.format(notification_type))
|
2017-01-17 13:16:26 +00:00
|
|
|
|
|
|
|
|
data = {
|
|
|
|
|
key_send_to: send_to,
|
|
|
|
|
'template_id': str(sample.id)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
auth_header = create_authorization_header(service_id=sample.service_id)
|
|
|
|
|
|
|
|
|
|
response = client.post(
|
|
|
|
|
path='/v2/notifications/{}'.format(notification_type),
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
|
|
|
|
|
|
|
|
|
notification_id = json.loads(response.data)['id']
|
2017-03-30 10:46:23 +01:00
|
|
|
|
2017-01-17 13:16:26 +00:00
|
|
|
assert response.status_code == 201
|
2017-05-25 10:51:49 +01:00
|
|
|
mocked.assert_called_once_with([notification_id], queue='priority-tasks')
|
2017-04-24 14:15:08 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
|
"notification_type, key_send_to, send_to",
|
|
|
|
|
[("sms", "phone_number", "07700 900 855"), ("email", "email_address", "sample@email.com")]
|
|
|
|
|
)
|
|
|
|
|
def test_returns_a_429_limit_exceeded_if_rate_limit_exceeded(
|
|
|
|
|
client,
|
|
|
|
|
notify_db,
|
|
|
|
|
notify_db_session,
|
|
|
|
|
mocker,
|
|
|
|
|
notification_type,
|
|
|
|
|
key_send_to,
|
|
|
|
|
send_to
|
|
|
|
|
):
|
|
|
|
|
sample = create_sample_template(
|
|
|
|
|
notify_db,
|
|
|
|
|
notify_db_session,
|
|
|
|
|
template_type=notification_type
|
|
|
|
|
)
|
|
|
|
|
persist_mock = mocker.patch('app.v2.notifications.post_notifications.persist_notification')
|
|
|
|
|
deliver_mock = mocker.patch('app.v2.notifications.post_notifications.send_notification_to_queue')
|
|
|
|
|
mocker.patch(
|
|
|
|
|
'app.v2.notifications.post_notifications.check_rate_limiting',
|
|
|
|
|
side_effect=RateLimitError("LIMIT", "INTERVAL", "TYPE"))
|
|
|
|
|
|
|
|
|
|
data = {
|
|
|
|
|
key_send_to: send_to,
|
|
|
|
|
'template_id': str(sample.id)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
auth_header = create_authorization_header(service_id=sample.service_id)
|
|
|
|
|
|
|
|
|
|
response = client.post(
|
|
|
|
|
path='/v2/notifications/{}'.format(notification_type),
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
|
|
|
|
|
|
|
|
|
error = json.loads(response.data)['errors'][0]['error']
|
|
|
|
|
message = json.loads(response.data)['errors'][0]['message']
|
|
|
|
|
status_code = json.loads(response.data)['status_code']
|
|
|
|
|
assert response.status_code == 429
|
|
|
|
|
assert error == 'RateLimitError'
|
|
|
|
|
assert message == 'Exceeded rate limit for key type TYPE of LIMIT requests per INTERVAL seconds'
|
|
|
|
|
assert status_code == 429
|
|
|
|
|
|
|
|
|
|
assert not persist_mock.called
|
|
|
|
|
assert not deliver_mock.called
|
2017-05-02 10:56:56 +01:00
|
|
|
|
|
|
|
|
|
2017-04-26 15:56:45 +01:00
|
|
|
def test_post_sms_notification_returns_400_if_not_allowed_to_send_int_sms(client, sample_service, sample_template):
|
|
|
|
|
data = {
|
|
|
|
|
'phone_number': '20-12-1234-1234',
|
|
|
|
|
'template_id': sample_template.id
|
|
|
|
|
}
|
|
|
|
|
auth_header = create_authorization_header(service_id=sample_service.id)
|
|
|
|
|
|
|
|
|
|
response = client.post(
|
|
|
|
|
path='/v2/notifications/sms',
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
|
|
|
|
|
|
|
|
|
assert response.status_code == 400
|
|
|
|
|
assert response.headers['Content-type'] == 'application/json'
|
|
|
|
|
|
|
|
|
|
error_json = json.loads(response.get_data(as_text=True))
|
|
|
|
|
assert error_json['status_code'] == 400
|
|
|
|
|
assert error_json['errors'] == [
|
|
|
|
|
{"error": "BadRequestError", "message": 'Cannot send to international mobile numbers'}
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
2017-06-29 11:13:32 +01:00
|
|
|
@pytest.mark.parametrize('template_factory,expected_error', [
|
|
|
|
|
(sample_template_without_sms_permission, 'Cannot send text messages'),
|
|
|
|
|
(sample_template_without_email_permission, 'Cannot send emails')])
|
|
|
|
|
def test_post_sms_notification_returns_400_if_not_allowed_to_send_notification(
|
|
|
|
|
client, template_factory, expected_error, notify_db, notify_db_session):
|
|
|
|
|
sample_template_without_permission = template_factory(notify_db, notify_db_session)
|
|
|
|
|
data = {
|
|
|
|
|
'phone_number': '07700 900000',
|
|
|
|
|
'email_address': 'someone@test.com',
|
|
|
|
|
'template_id': sample_template_without_permission.id
|
|
|
|
|
}
|
|
|
|
|
auth_header = create_authorization_header(service_id=sample_template_without_permission.service.id)
|
|
|
|
|
|
|
|
|
|
response = client.post(
|
|
|
|
|
path='/v2/notifications/{}'.format(sample_template_without_permission.template_type),
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
|
|
|
|
|
|
|
|
|
assert response.status_code == 400
|
|
|
|
|
assert response.headers['Content-type'] == 'application/json'
|
|
|
|
|
|
|
|
|
|
error_json = json.loads(response.get_data(as_text=True))
|
|
|
|
|
assert error_json['status_code'] == 400
|
|
|
|
|
assert error_json['errors'] == [
|
|
|
|
|
{"error": "BadRequestError", "message": expected_error}
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
2017-04-27 12:47:08 +01:00
|
|
|
def test_post_sms_notification_returns_201_if_allowed_to_send_int_sms(notify_db, notify_db_session, client, mocker):
|
2017-04-26 15:56:45 +01:00
|
|
|
|
2017-06-29 11:13:32 +01:00
|
|
|
service = sample_service(notify_db, notify_db_session, permissions=[SMS_TYPE, INTERNATIONAL_SMS_TYPE])
|
2017-04-26 15:56:45 +01:00
|
|
|
template = create_sample_template(notify_db, notify_db_session, service=service)
|
|
|
|
|
|
2017-04-27 12:47:08 +01:00
|
|
|
mocker.patch('app.celery.provider_tasks.deliver_sms.apply_async')
|
|
|
|
|
|
2017-04-26 15:56:45 +01:00
|
|
|
data = {
|
|
|
|
|
'phone_number': '20-12-1234-1234',
|
|
|
|
|
'template_id': template.id
|
|
|
|
|
}
|
|
|
|
|
auth_header = create_authorization_header(service_id=service.id)
|
|
|
|
|
|
|
|
|
|
response = client.post(
|
|
|
|
|
path='/v2/notifications/sms',
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
|
|
|
|
|
|
|
|
|
assert response.status_code == 201
|
|
|
|
|
assert response.headers['Content-type'] == 'application/json'
|
|
|
|
|
|
|
|
|
|
|
2017-05-15 17:27:38 +01:00
|
|
|
def test_post_sms_should_persist_supplied_sms_number(client, sample_template_with_placeholders, mocker):
|
|
|
|
|
mocked = mocker.patch('app.celery.provider_tasks.deliver_sms.apply_async')
|
|
|
|
|
data = {
|
|
|
|
|
'phone_number': '+(44) 77009-00855',
|
|
|
|
|
'template_id': str(sample_template_with_placeholders.id),
|
|
|
|
|
'personalisation': {' Name': 'Jo'}
|
|
|
|
|
}
|
2017-04-26 15:56:45 +01:00
|
|
|
|
2017-05-15 17:27:38 +01:00
|
|
|
auth_header = create_authorization_header(service_id=sample_template_with_placeholders.service_id)
|
2017-04-26 15:56:45 +01:00
|
|
|
|
2017-05-15 17:27:38 +01:00
|
|
|
response = client.post(
|
|
|
|
|
path='/v2/notifications/sms',
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
|
|
|
|
assert response.status_code == 201
|
|
|
|
|
resp_json = json.loads(response.get_data(as_text=True))
|
|
|
|
|
notifications = Notification.query.all()
|
|
|
|
|
assert len(notifications) == 1
|
|
|
|
|
notification_id = notifications[0].id
|
|
|
|
|
assert '+(44) 77009-00855' == notifications[0].to
|
|
|
|
|
assert resp_json['id'] == str(notification_id)
|
|
|
|
|
assert mocked.called
|
|
|
|
|
|
|
|
|
|
|
2017-05-16 09:57:58 +01:00
|
|
|
@pytest.mark.parametrize("notification_type, key_send_to, send_to",
|
|
|
|
|
[("sms", "phone_number", "07700 900 855"),
|
|
|
|
|
("email", "email_address", "sample@email.com")])
|
2017-05-22 14:39:30 +01:00
|
|
|
@freeze_time("2017-05-14 14:00:00")
|
2017-05-26 15:41:14 +01:00
|
|
|
def test_post_notification_with_scheduled_for(client, notify_db, notify_db_session,
|
2017-05-16 09:57:58 +01:00
|
|
|
notification_type, key_send_to, send_to):
|
2017-05-26 15:41:14 +01:00
|
|
|
service = create_service(service_name=str(uuid.uuid4()),
|
|
|
|
|
service_permissions=[EMAIL_TYPE, SMS_TYPE, SCHEDULE_NOTIFICATIONS])
|
|
|
|
|
template = create_template(service=service, template_type=notification_type)
|
2017-05-16 09:57:58 +01:00
|
|
|
data = {
|
|
|
|
|
key_send_to: send_to,
|
2017-06-28 12:14:36 +01:00
|
|
|
'template_id': str(template.id) if notification_type == EMAIL_TYPE else str(template.id),
|
2017-05-22 14:15:35 +01:00
|
|
|
'scheduled_for': '2017-05-14 14:15'
|
2017-05-16 09:57:58 +01:00
|
|
|
}
|
2017-05-26 15:41:14 +01:00
|
|
|
auth_header = create_authorization_header(service_id=service.id)
|
2017-05-15 17:27:38 +01:00
|
|
|
|
2017-05-16 09:57:58 +01:00
|
|
|
response = client.post('/v2/notifications/{}'.format(notification_type),
|
2017-05-15 17:27:38 +01:00
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
|
|
|
|
assert response.status_code == 201
|
|
|
|
|
resp_json = json.loads(response.get_data(as_text=True))
|
2017-05-26 15:41:14 +01:00
|
|
|
scheduled_notification = ScheduledNotification.query.filter_by(notification_id=resp_json["id"]).all()
|
2017-05-15 17:27:38 +01:00
|
|
|
assert len(scheduled_notification) == 1
|
|
|
|
|
assert resp_json["id"] == str(scheduled_notification[0].notification_id)
|
2017-05-22 14:15:35 +01:00
|
|
|
assert resp_json["scheduled_for"] == '2017-05-14 14:15'
|
2017-05-24 16:27:15 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize("notification_type, key_send_to, send_to",
|
|
|
|
|
[("sms", "phone_number", "07700 900 855"),
|
|
|
|
|
("email", "email_address", "sample@email.com")])
|
|
|
|
|
@freeze_time("2017-05-14 14:00:00")
|
2017-05-26 15:41:14 +01:00
|
|
|
def test_post_notification_raises_bad_request_if_service_not_invited_to_schedule(
|
|
|
|
|
client, sample_template, sample_email_template, notification_type, key_send_to, send_to):
|
2017-05-24 16:27:15 +01:00
|
|
|
data = {
|
|
|
|
|
key_send_to: send_to,
|
2017-06-28 12:14:36 +01:00
|
|
|
'template_id': str(sample_email_template.id) if notification_type == EMAIL_TYPE else str(sample_template.id),
|
2017-05-24 16:27:15 +01:00
|
|
|
'scheduled_for': '2017-05-14 14:15'
|
|
|
|
|
}
|
|
|
|
|
auth_header = create_authorization_header(service_id=sample_template.service_id)
|
|
|
|
|
|
|
|
|
|
response = client.post('/v2/notifications/{}'.format(notification_type),
|
|
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers=[('Content-Type', 'application/json'), auth_header])
|
|
|
|
|
assert response.status_code == 400
|
|
|
|
|
error_json = json.loads(response.get_data(as_text=True))
|
|
|
|
|
assert error_json['errors'] == [
|
2017-05-31 16:22:56 +01:00
|
|
|
{"error": "BadRequestError", "message": 'Cannot schedule notifications (this feature is invite-only)'}]
|