mirror of
https://github.com/GSA/notifications-api.git
synced 2026-02-03 18:01:08 -05:00
Daily message limit imposed for service api calls.
This commit is contained in:
@@ -221,7 +221,7 @@ def send_notification(notification_type):
|
|||||||
total_sms_count = service_stats.sms_requested
|
total_sms_count = service_stats.sms_requested
|
||||||
total_email_count = service_stats.emails_requested
|
total_email_count = service_stats.emails_requested
|
||||||
|
|
||||||
if (total_email_count + total_sms_count >= service.message_limit) and service.restricted:
|
if (total_email_count + total_sms_count >= service.message_limit):
|
||||||
error = 'Exceeded send limits ({}) for today'.format(service.message_limit)
|
error = 'Exceeded send limits ({}) for today'.format(service.message_limit)
|
||||||
raise InvalidRequest(error, status_code=429)
|
raise InvalidRequest(error, status_code=429)
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
import random
|
import random
|
||||||
import string
|
import string
|
||||||
|
import pytest
|
||||||
|
|
||||||
from unittest.mock import ANY
|
from unittest.mock import ANY
|
||||||
from flask import (json, current_app)
|
from flask import (json, current_app)
|
||||||
@@ -538,14 +539,19 @@ def test_should_allow_valid_email_notification(notify_api, sample_email_template
|
|||||||
assert response_data['template_version'] == sample_email_template.version
|
assert response_data['template_version'] == sample_email_template.version
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.parametrize('restricted', [True, False])
|
||||||
@freeze_time("2016-01-01 12:00:00.061258")
|
@freeze_time("2016-01-01 12:00:00.061258")
|
||||||
def test_should_block_api_call_if_over_day_limit(notify_db, notify_db_session, notify_api, mocker):
|
def test_should_block_api_call_if_over_day_limit_for_restricted_and_live_service(notify_db,
|
||||||
|
notify_db_session,
|
||||||
|
notify_api,
|
||||||
|
mocker,
|
||||||
|
restricted):
|
||||||
with notify_api.test_request_context():
|
with notify_api.test_request_context():
|
||||||
with notify_api.test_client() as client:
|
with notify_api.test_client() as client:
|
||||||
mocker.patch('app.celery.tasks.send_email.apply_async')
|
mocker.patch('app.celery.tasks.send_email.apply_async')
|
||||||
mocker.patch('app.encryption.encrypt', return_value="something_encrypted")
|
mocker.patch('app.encryption.encrypt', return_value="something_encrypted")
|
||||||
|
|
||||||
service = create_sample_service(notify_db, notify_db_session, limit=1, restricted=True)
|
service = create_sample_service(notify_db, notify_db_session, limit=1, restricted=restricted)
|
||||||
email_template = create_sample_email_template(notify_db, notify_db_session, service=service)
|
email_template = create_sample_email_template(notify_db, notify_db_session, service=service)
|
||||||
create_sample_notification(
|
create_sample_notification(
|
||||||
notify_db, notify_db_session, template=email_template, service=service, created_at=datetime.utcnow()
|
notify_db, notify_db_session, template=email_template, service=service, created_at=datetime.utcnow()
|
||||||
@@ -568,33 +574,6 @@ def test_should_block_api_call_if_over_day_limit(notify_db, notify_db_session, n
|
|||||||
assert 'Exceeded send limits (1) for today' in json_resp['message']
|
assert 'Exceeded send limits (1) for today' in json_resp['message']
|
||||||
|
|
||||||
|
|
||||||
def test_no_limit_for_live_service(notify_api,
|
|
||||||
notify_db,
|
|
||||||
notify_db_session,
|
|
||||||
mock_celery_send_email,
|
|
||||||
sample_service,
|
|
||||||
sample_email_template):
|
|
||||||
with notify_api.test_request_context():
|
|
||||||
with notify_api.test_client() as client:
|
|
||||||
sample_service.message_limit = 1
|
|
||||||
notify_db.session.add(sample_service)
|
|
||||||
notify_db.session.commit()
|
|
||||||
|
|
||||||
data = {
|
|
||||||
'to': 'ok@ok.com',
|
|
||||||
'template': str(sample_email_template.id)
|
|
||||||
}
|
|
||||||
|
|
||||||
auth_header = create_authorization_header(service_id=sample_service.id)
|
|
||||||
|
|
||||||
response = client.post(
|
|
||||||
path='/notifications/email',
|
|
||||||
data=json.dumps(data),
|
|
||||||
headers=[('Content-Type', 'application/json'), auth_header])
|
|
||||||
|
|
||||||
assert response.status_code == 201
|
|
||||||
|
|
||||||
|
|
||||||
@freeze_time("2016-01-01 12:00:00.061258")
|
@freeze_time("2016-01-01 12:00:00.061258")
|
||||||
def test_should_block_api_call_if_over_day_limit_regardless_of_type(notify_db, notify_db_session, notify_api, mocker):
|
def test_should_block_api_call_if_over_day_limit_regardless_of_type(notify_db, notify_db_session, notify_api, mocker):
|
||||||
with notify_api.test_request_context():
|
with notify_api.test_request_context():
|
||||||
|
|||||||
Reference in New Issue
Block a user