mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-06-30 12:18:19 -04:00
Fixed the is_active() method on the Users model, if the user was pending they would come back as active, allowing a user to sign in before being active. There is still a problem with the validate_sms_code and validate_email_code method.
107 lines
5.5 KiB
Python
107 lines
5.5 KiB
Python
from app.main.dao import verify_codes_dao, users_dao
|
|
from tests.app.main import create_test_user
|
|
|
|
|
|
def test_should_render_email_code_not_received_template_and_populate_email_address(notifications_admin,
|
|
notifications_admin_db,
|
|
notify_db_session):
|
|
with notifications_admin.test_client() as client:
|
|
with client.session_transaction() as session:
|
|
user = create_test_user('pending')
|
|
session['user_id'] = user.id
|
|
response = client.get('/email-not-received')
|
|
assert response.status_code == 200
|
|
assert 'Check your email address is correct and then resend the confirmation code' \
|
|
in response.get_data(as_text=True)
|
|
assert 'value="test@user.gov.uk"' in response.get_data(as_text=True)
|
|
|
|
|
|
def test_should_check_and_resend_email_code_redirect_to_verify(notifications_admin,
|
|
notifications_admin_db,
|
|
notify_db_session,
|
|
mocker):
|
|
with notifications_admin.test_client() as client:
|
|
with client.session_transaction() as session:
|
|
_set_up_mocker(mocker)
|
|
user = create_test_user('pending')
|
|
session['user_id'] = user.id
|
|
verify_codes_dao.add_code(user.id, code='12345', code_type='email')
|
|
response = client.post('/email-not-received',
|
|
data={'email_address': 'test@user.gov.uk'})
|
|
assert response.status_code == 302
|
|
assert response.location == 'http://localhost/verify'
|
|
|
|
|
|
def test_should_render_text_code_not_received_template(notifications_admin,
|
|
notifications_admin_db,
|
|
notify_db_session,
|
|
mocker):
|
|
with notifications_admin.test_client() as client:
|
|
with client.session_transaction() as session:
|
|
_set_up_mocker(mocker)
|
|
user = create_test_user('pending')
|
|
session['user_id'] = user.id
|
|
verify_codes_dao.add_code(user.id, code='12345', code_type='email')
|
|
response = client.get('/text-not-received')
|
|
assert response.status_code == 200
|
|
assert 'Check your mobile phone number is correct and then resend the confirmation code.' \
|
|
in response.get_data(as_text=True)
|
|
assert 'value="+441234123412"'
|
|
|
|
|
|
def test_should_check_and_redirect_to_verify(notifications_admin,
|
|
notifications_admin_db,
|
|
notify_db_session,
|
|
mocker):
|
|
with notifications_admin.test_client() as client:
|
|
with client.session_transaction() as session:
|
|
_set_up_mocker(mocker)
|
|
user = create_test_user('pending')
|
|
session['user_id'] = user.id
|
|
verify_codes_dao.add_code(user.id, code='12345', code_type='sms')
|
|
response = client.post('/text-not-received',
|
|
data={'mobile_number': '+441234123412'})
|
|
assert response.status_code == 302
|
|
assert response.location == 'http://localhost/verify'
|
|
|
|
|
|
def test_should_update_email_address_resend_code(notifications_admin,
|
|
notifications_admin_db,
|
|
notify_db_session,
|
|
mocker):
|
|
with notifications_admin.test_client() as client:
|
|
with client.session_transaction() as session:
|
|
_set_up_mocker(mocker)
|
|
user = create_test_user('pending')
|
|
session['user_id'] = user.id
|
|
verify_codes_dao.add_code(user_id=user.id, code='12345', code_type='email')
|
|
response = client.post('/email-not-received',
|
|
data={'email_address': 'new@address.gov.uk'})
|
|
assert response.status_code == 302
|
|
assert response.location == 'http://localhost/verify'
|
|
updated_user = users_dao.get_user_by_id(user.id)
|
|
assert updated_user.email_address == 'new@address.gov.uk'
|
|
|
|
|
|
def test_should_update_mobile_number_resend_code(notifications_admin,
|
|
notifications_admin_db,
|
|
notify_db_session,
|
|
mocker):
|
|
with notifications_admin.test_client() as client:
|
|
with client.session_transaction() as session:
|
|
_set_up_mocker(mocker)
|
|
user = create_test_user('pending')
|
|
session['user_id'] = user.id
|
|
verify_codes_dao.add_code(user_id=user.id, code='12345', code_type='sms')
|
|
response = client.post('/text-not-received',
|
|
data={'mobile_number': '+443456789012'})
|
|
assert response.status_code == 302
|
|
assert response.location == 'http://localhost/verify'
|
|
updated_user = users_dao.get_user_by_id(user.id)
|
|
assert updated_user.mobile_number == '+443456789012'
|
|
|
|
|
|
def _set_up_mocker(mocker):
|
|
mocker.patch("app.admin_api_client.send_sms")
|
|
mocker.patch("app.admin_api_client.send_email")
|