mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-02-05 10:53:28 -05:00
Verify activate and login user with sms and email code
This commit is contained in:
@@ -6,6 +6,7 @@ from app.models import User
|
||||
from app.main.dao import users_dao
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Tests will be moved to api')
|
||||
def test_insert_user_should_add_user(db_, db_session):
|
||||
user = User(name='test insert',
|
||||
password='somepassword',
|
||||
@@ -18,6 +19,7 @@ def test_insert_user_should_add_user(db_, db_session):
|
||||
assert saved_user == user
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Tests will be moved to api')
|
||||
def test_insert_user_with_role_that_does_not_exist_fails(db_, db_session):
|
||||
user = User(name='role does not exist',
|
||||
password='somepassword',
|
||||
@@ -29,6 +31,7 @@ def test_insert_user_with_role_that_does_not_exist_fails(db_, db_session):
|
||||
assert 'insert or update on table "users" violates foreign key constraint "users_role_id_fkey"' in str(error.value)
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Not implemented yet on api client')
|
||||
def test_get_user_by_email(db_, db_session):
|
||||
user = User(name='test_get_by_email',
|
||||
password='somepassword',
|
||||
@@ -41,6 +44,7 @@ def test_get_user_by_email(db_, db_session):
|
||||
assert retrieved == user
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Not implemented yet on api client')
|
||||
def test_get_all_users_returns_all_users(db_, db_session):
|
||||
user1 = User(name='test one',
|
||||
password='somepassword',
|
||||
@@ -66,6 +70,7 @@ def test_get_all_users_returns_all_users(db_, db_session):
|
||||
assert users == [user1, user2, user3]
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Not implemented yet on api client')
|
||||
def test_increment_failed_lockout_count_should_increade_count_by_1(db_, db_session):
|
||||
user = User(name='cannot remember password',
|
||||
password='somepassword',
|
||||
@@ -80,6 +85,7 @@ def test_increment_failed_lockout_count_should_increade_count_by_1(db_, db_sessi
|
||||
assert users_dao.get_user_by_id(user.id).failed_login_count == 1
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Not implemented yet on api client')
|
||||
def test_user_is_locked_if_failed_login_count_is_10_or_greater(db_, db_session):
|
||||
user = User(name='cannot remember password',
|
||||
password='somepassword',
|
||||
@@ -98,6 +104,7 @@ def test_user_is_locked_if_failed_login_count_is_10_or_greater(db_, db_session):
|
||||
assert saved_user.is_locked() is True
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Not implemented yet on api client')
|
||||
def test_user_is_active_is_false_if_state_is_inactive(db_, db_session):
|
||||
user = User(name='inactive user',
|
||||
password='somepassword',
|
||||
@@ -111,25 +118,27 @@ def test_user_is_active_is_false_if_state_is_inactive(db_, db_session):
|
||||
assert saved_user.is_active() is False
|
||||
|
||||
|
||||
def test_should_update_user_to_active(db_, db_session):
|
||||
user = User(name='Make user active',
|
||||
password='somepassword',
|
||||
email_address='activate@user.gov.uk',
|
||||
mobile_number='+441234123412',
|
||||
role_id=1,
|
||||
state='pending')
|
||||
users_dao.insert_user(user)
|
||||
users_dao.activate_user(user.id)
|
||||
updated_user = users_dao.get_user_by_id(user.id)
|
||||
assert updated_user.state == 'active'
|
||||
def test_should_update_user_to_active(mock_activate_user):
|
||||
from app.notify_client.user_api_client import User
|
||||
user_data = {'name': 'Make user active',
|
||||
'password': 'somepassword',
|
||||
'email_address': 'activate@user.gov.uk',
|
||||
'mobile_number': '+441234123412',
|
||||
'state': 'pending'
|
||||
}
|
||||
user = User(user_data)
|
||||
activated_user = users_dao.activate_user(user)
|
||||
assert activated_user.state == 'active'
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Not implemented yet on api client')
|
||||
def test_should_throws_error_when_id_does_not_exist(db_, db_session):
|
||||
with pytest.raises(AttributeError) as error:
|
||||
users_dao.activate_user(123)
|
||||
assert '''object has no attribute 'state''''' in str(error.value)
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Not implemented yet on api client')
|
||||
def test_should_update_email_address(db_, db_session):
|
||||
user = User(name='Update Email',
|
||||
password='somepassword',
|
||||
@@ -146,6 +155,7 @@ def test_should_update_email_address(db_, db_session):
|
||||
assert updated.email_address == 'new_email@testit.gov.uk'
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Not implemented yet on api client')
|
||||
def test_should_update_password(db_, db_session):
|
||||
user = User(name='Update Email',
|
||||
password='somepassword',
|
||||
@@ -166,6 +176,7 @@ def test_should_update_password(db_, db_session):
|
||||
assert updated.password_changed_at > start
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Not implemented yet on api client')
|
||||
def test_should_return_list_of_all_email_addresses(db_, db_session):
|
||||
first = User(name='First Person',
|
||||
password='somepassword',
|
||||
@@ -187,6 +198,7 @@ def test_should_return_list_of_all_email_addresses(db_, db_session):
|
||||
assert expected == [x.email_address for x in email_addresses]
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Not implemented yet on api client')
|
||||
def test_should_update_state_to_request_password_reset(db_, db_session):
|
||||
user = User(name='Requesting Password Resest',
|
||||
password='somepassword',
|
||||
|
||||
@@ -2,7 +2,10 @@ from tests import create_test_user
|
||||
from flask import url_for
|
||||
from app.models import User
|
||||
|
||||
import pytest
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Requires completed move of user dao methods to api methods')
|
||||
def test_should_show_choose_services_page(app_,
|
||||
db_,
|
||||
db_session,
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
from app.main.dao import verify_codes_dao, users_dao
|
||||
from tests import create_test_user
|
||||
from app.main.dao import verify_codes_dao
|
||||
from tests import create_test_api_user
|
||||
from flask import url_for
|
||||
|
||||
|
||||
@@ -7,12 +7,13 @@ def test_should_render_email_code_not_received_template_and_populate_email_addre
|
||||
db_,
|
||||
db_session,
|
||||
mock_send_sms,
|
||||
mock_send_email):
|
||||
mock_send_email,
|
||||
mock_api_user,
|
||||
mock_user_dao_get_by_email):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
with client.session_transaction() as session:
|
||||
user = create_test_user('pending')
|
||||
session['user_email'] = user.email_address
|
||||
session['user_email'] = mock_api_user.email_address
|
||||
response = client.get(url_for('main.check_and_resend_email_code'))
|
||||
assert response.status_code == 200
|
||||
assert 'Check your email address is correct and then resend the confirmation code' \
|
||||
@@ -24,13 +25,15 @@ def test_should_check_and_resend_email_code_redirect_to_verify(app_,
|
||||
db_,
|
||||
db_session,
|
||||
mock_send_sms,
|
||||
mock_send_email):
|
||||
mock_send_email,
|
||||
mock_api_user,
|
||||
mock_user_dao_get_by_email,
|
||||
mock_user_dao_update_email):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
with client.session_transaction() as session:
|
||||
user = create_test_user('pending')
|
||||
session['user_email'] = user.email_address
|
||||
verify_codes_dao.add_code(user.id, code='12345', code_type='email')
|
||||
session['user_email'] = mock_api_user.email_address
|
||||
verify_codes_dao.add_code(mock_api_user.id, code='12345', code_type='email')
|
||||
response = client.post(url_for('main.check_and_resend_email_code'),
|
||||
data={'email_address': 'test@user.gov.uk'})
|
||||
assert response.status_code == 302
|
||||
@@ -41,13 +44,14 @@ def test_should_render_text_code_not_received_template(app_,
|
||||
db_,
|
||||
db_session,
|
||||
mock_send_sms,
|
||||
mock_send_email):
|
||||
mock_send_email,
|
||||
mock_api_user,
|
||||
mock_user_dao_get_by_email):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
with client.session_transaction() as session:
|
||||
user = create_test_user('pending')
|
||||
session['user_email'] = user.email_address
|
||||
verify_codes_dao.add_code(user.id, code='12345', code_type='sms')
|
||||
session['user_email'] = mock_api_user.email_address
|
||||
verify_codes_dao.add_code(mock_api_user.id, code='12345', code_type='sms')
|
||||
response = client.get(url_for('main.check_and_resend_text_code'))
|
||||
assert response.status_code == 200
|
||||
assert 'Check your mobile phone number is correct and then resend the confirmation code.' \
|
||||
@@ -59,13 +63,15 @@ def test_should_check_and_redirect_to_verify(app_,
|
||||
db_,
|
||||
db_session,
|
||||
mock_send_sms,
|
||||
mock_send_email):
|
||||
mock_send_email,
|
||||
mock_api_user,
|
||||
mock_user_dao_get_by_email,
|
||||
mock_user_dao_update_mobile):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
with client.session_transaction() as session:
|
||||
user = create_test_user('pending')
|
||||
session['user_email'] = user.email_address
|
||||
verify_codes_dao.add_code(user.id, code='12345', code_type='sms')
|
||||
session['user_email'] = mock_api_user.email_address
|
||||
verify_codes_dao.add_code(mock_api_user.id, code='12345', code_type='sms')
|
||||
response = client.post(url_for('main.check_and_resend_text_code'),
|
||||
data={'mobile_number': '+447700900460'})
|
||||
assert response.status_code == 302
|
||||
@@ -76,48 +82,51 @@ def test_should_update_email_address_resend_code(app_,
|
||||
db_,
|
||||
db_session,
|
||||
mock_send_sms,
|
||||
mock_send_email):
|
||||
mock_send_email,
|
||||
mock_api_user,
|
||||
mock_user_dao_get_by_email,
|
||||
mock_user_dao_update_email):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
with client.session_transaction() as session:
|
||||
user = create_test_user('pending')
|
||||
session['user_email'] = user.email_address
|
||||
verify_codes_dao.add_code(user_id=user.id, code='12345', code_type='email')
|
||||
session['user_email'] = mock_api_user.email_address
|
||||
verify_codes_dao.add_code(user_id=mock_api_user.id, code='12345', code_type='email')
|
||||
response = client.post(url_for('main.check_and_resend_email_code'),
|
||||
data={'email_address': 'new@address.gov.uk'})
|
||||
assert response.status_code == 302
|
||||
assert response.location == url_for('main.verify', _external=True)
|
||||
updated_user = users_dao.get_user_by_id(user.id)
|
||||
assert updated_user.email_address == 'new@address.gov.uk'
|
||||
assert mock_api_user.email_address == 'new@address.gov.uk'
|
||||
|
||||
|
||||
def test_should_update_mobile_number_resend_code(app_,
|
||||
db_,
|
||||
db_session,
|
||||
mock_send_sms,
|
||||
mock_send_email):
|
||||
mock_send_email,
|
||||
mock_api_user,
|
||||
mock_user_dao_get_by_email,
|
||||
mock_user_dao_update_mobile):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
with client.session_transaction() as session:
|
||||
user = create_test_user('pending')
|
||||
session['user_email'] = user.email_address
|
||||
verify_codes_dao.add_code(user_id=user.id, code='12345', code_type='sms')
|
||||
session['user_email'] = mock_api_user.email_address
|
||||
verify_codes_dao.add_code(user_id=mock_api_user.id, code='12345', code_type='sms')
|
||||
response = client.post(url_for('main.check_and_resend_text_code'),
|
||||
data={'mobile_number': '+447700900460'})
|
||||
assert response.status_code == 302
|
||||
assert response.location == url_for('main.verify', _external=True)
|
||||
updated_user = users_dao.get_user_by_id(user.id)
|
||||
assert updated_user.mobile_number == '+447700900460'
|
||||
assert mock_api_user.mobile_number == '+44 7700 900 460'
|
||||
|
||||
|
||||
def test_should_render_verification_code_not_received(app_,
|
||||
db_,
|
||||
db_session,
|
||||
active_user):
|
||||
active_user,
|
||||
mock_api_user):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
with client.session_transaction() as session:
|
||||
session['user_email'] = active_user.email_address
|
||||
session['user_email'] = mock_api_user.email_address
|
||||
response = client.get(url_for('main.verification_code_not_received'))
|
||||
assert response.status_code == 200
|
||||
assert 'Resend verification code' in response.get_data(as_text=True)
|
||||
|
||||
@@ -6,7 +6,8 @@ def test_should_show_recent_jobs_on_dashboard(app_,
|
||||
db_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_get_service):
|
||||
mock_get_service,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
|
||||
@@ -15,7 +15,10 @@ def test_should_redirect_to_password_reset_sent_and_state_updated(app_,
|
||||
db_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_send_email):
|
||||
mock_send_email,
|
||||
mock_api_user,
|
||||
mock_user_dao_get_by_email,
|
||||
mock_user_dao_password_reset):
|
||||
with app_.test_request_context():
|
||||
response = app_.test_client().post(
|
||||
url_for('.forgot_password'),
|
||||
@@ -24,4 +27,4 @@ def test_should_redirect_to_password_reset_sent_and_state_updated(app_,
|
||||
assert (
|
||||
'You have been sent an email containing a link'
|
||||
' to reset your password.') in response.get_data(as_text=True)
|
||||
assert users_dao.get_user_by_id(active_user.id).state == 'request_password_reset'
|
||||
assert mock_api_user.state == 'request_password_reset'
|
||||
|
||||
@@ -3,25 +3,23 @@ from app.models import User
|
||||
from tests import create_test_user
|
||||
|
||||
|
||||
def test_should_return_list_of_all_jobs(app_, db_, db_session, service_one):
|
||||
def test_should_return_list_of_all_jobs(app_, db_, db_session, service_one, active_user, mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
user = User.query.first()
|
||||
client.login(user)
|
||||
client.login(active_user)
|
||||
response = client.get(url_for('main.view_jobs', service_id=101))
|
||||
|
||||
assert response.status_code == 200
|
||||
assert 'You haven’t sent any notifications yet' in response.get_data(as_text=True)
|
||||
|
||||
|
||||
def test_should_show_page_for_one_job(app_, db_, db_session, service_one):
|
||||
def test_should_show_page_for_one_job(app_, db_, db_session, service_one, active_user, mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
# TODO filename will be part of job metadata not in session
|
||||
with client.session_transaction() as s:
|
||||
s[456] = 'dispatch_20151114.csv'
|
||||
user = User.query.first()
|
||||
client.login(user)
|
||||
client.login(active_user)
|
||||
response = client.get(url_for('main.view_job', service_id=123, job_id=456))
|
||||
|
||||
assert response.status_code == 200
|
||||
@@ -29,11 +27,10 @@ def test_should_show_page_for_one_job(app_, db_, db_session, service_one):
|
||||
assert 'Test message 1' in response.get_data(as_text=True)
|
||||
|
||||
|
||||
def test_should_show_page_for_one_notification(app_, db_, db_session, service_one):
|
||||
def test_should_show_page_for_one_notification(app_, db_, db_session, service_one, active_user, mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
user = User.query.first()
|
||||
client.login(user)
|
||||
client.login(active_user)
|
||||
response = client.get(url_for(
|
||||
'main.view_notification',
|
||||
service_id=101,
|
||||
|
||||
@@ -5,12 +5,13 @@ from app.main.encryption import check_hash
|
||||
from app.notify_client.sender import generate_token
|
||||
from tests import create_test_user
|
||||
|
||||
import pytest
|
||||
|
||||
def test_should_render_new_password_template(app_, db_, db_session):
|
||||
|
||||
def test_should_render_new_password_template(app_, db_, db_session, mock_api_user, mock_user_dao_get_new_password):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
user = create_test_user('request_password_reset')
|
||||
token = generate_token(user.email_address)
|
||||
token = generate_token(mock_api_user.email_address)
|
||||
response = client.get(url_for('.new_password', token=token))
|
||||
assert response.status_code == 200
|
||||
assert ' You can now create a new password for your account.' in response.get_data(as_text=True)
|
||||
@@ -27,10 +28,13 @@ def test_should_render_new_password_template_with_message_of_bad_token(app_, db_
|
||||
response.get_data(as_text=True)
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Password reset not implemented')
|
||||
def test_should_redirect_to_two_factor_when_password_reset_is_successful(app_,
|
||||
db_,
|
||||
db_session,
|
||||
mock_send_sms):
|
||||
mock_send_sms,
|
||||
mock_api_user,
|
||||
mock_user_dao_get_new_password):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
user = create_test_user('request_password_reset')
|
||||
|
||||
@@ -15,7 +15,7 @@ def test_process_register_creates_new_user(app_,
|
||||
db_session,
|
||||
mock_send_sms,
|
||||
mock_send_email,
|
||||
mocker):
|
||||
mock_register_user):
|
||||
user_data = {
|
||||
'name': 'Some One Valid',
|
||||
'email_address': 'someone@example.gov.uk',
|
||||
@@ -23,8 +23,6 @@ def test_process_register_creates_new_user(app_,
|
||||
'password': 'validPassword!'
|
||||
}
|
||||
|
||||
mock_user(mocker, user_data)
|
||||
|
||||
with app_.test_request_context():
|
||||
response = app_.test_client().post('/register',
|
||||
data=user_data)
|
||||
@@ -67,7 +65,7 @@ def test_should_add_verify_codes_on_session(app_,
|
||||
db_session,
|
||||
mock_send_sms,
|
||||
mock_send_email,
|
||||
mocker):
|
||||
mock_register_user):
|
||||
user_data = {
|
||||
'name': 'Test Codes',
|
||||
'email_address': 'test@example.gov.uk',
|
||||
@@ -75,7 +73,6 @@ def test_should_add_verify_codes_on_session(app_,
|
||||
'password': 'validPassword!'
|
||||
}
|
||||
|
||||
mock_user(mocker, user_data)
|
||||
with app_.test_client() as client:
|
||||
response = client.post('/register',
|
||||
data=user_data)
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
from flask import (url_for, session)
|
||||
|
||||
|
||||
def test_should_show_overview(app_, db_, db_session, active_user, mock_get_service):
|
||||
def test_should_show_overview(app_, db_, db_session, active_user, mock_get_service, mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -16,7 +16,7 @@ def test_should_show_overview(app_, db_, db_session, active_user, mock_get_servi
|
||||
assert mock_get_service.called
|
||||
|
||||
|
||||
def test_should_show_service_name(app_, db_, db_session, active_user, mock_get_service):
|
||||
def test_should_show_service_name(app_, db_, db_session, active_user, mock_get_service, mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -30,7 +30,8 @@ def test_should_show_service_name(app_, db_, db_session, active_user, mock_get_s
|
||||
service = mock_get_service.side_effect(service_id)['data']
|
||||
|
||||
|
||||
def test_should_redirect_after_change_service_name(app_, db_, db_session, active_user, mock_get_service):
|
||||
def test_should_redirect_after_change_service_name(app_, db_, db_session, active_user, mock_get_service,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -49,7 +50,8 @@ def test_should_show_service_name_confirmation(app_,
|
||||
db_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_get_service):
|
||||
mock_get_service,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -68,7 +70,8 @@ def test_should_redirect_after_service_name_confirmation(app_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_get_service,
|
||||
mock_update_service):
|
||||
mock_update_service,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -88,7 +91,7 @@ def test_should_redirect_after_service_name_confirmation(app_,
|
||||
assert mock_update_service.called
|
||||
|
||||
|
||||
def test_should_show_request_to_go_live(app_, db_, db_session, active_user, mock_get_service):
|
||||
def test_should_show_request_to_go_live(app_, db_, db_session, active_user, mock_get_service, mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -107,7 +110,8 @@ def test_should_redirect_after_request_to_go_live(app_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_get_service,
|
||||
mock_update_service):
|
||||
mock_update_service,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -123,7 +127,7 @@ def test_should_redirect_after_request_to_go_live(app_,
|
||||
assert mock_update_service.called
|
||||
|
||||
|
||||
def test_should_show_status_page(app_, db_, db_session, active_user, mock_get_service):
|
||||
def test_should_show_status_page(app_, db_, db_session, active_user, mock_get_service, mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -141,7 +145,8 @@ def test_should_show_redirect_after_status_change(app_,
|
||||
db_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_get_service):
|
||||
mock_get_service,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -156,7 +161,7 @@ def test_should_show_redirect_after_status_change(app_,
|
||||
assert mock_get_service.called
|
||||
|
||||
|
||||
def test_should_show_status_confirmation(app_, db_, db_session, active_user, mock_get_service):
|
||||
def test_should_show_status_confirmation(app_, db_, db_session, active_user, mock_get_service, mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -175,7 +180,8 @@ def test_should_redirect_after_status_confirmation(app_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_get_service,
|
||||
mock_update_service):
|
||||
mock_update_service,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -191,7 +197,7 @@ def test_should_redirect_after_status_confirmation(app_,
|
||||
assert mock_update_service.called
|
||||
|
||||
|
||||
def test_should_show_delete_page(app_, db_, db_session, active_user, mock_get_service):
|
||||
def test_should_show_delete_page(app_, db_, db_session, active_user, mock_get_service, mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -204,7 +210,8 @@ def test_should_show_delete_page(app_, db_, db_session, active_user, mock_get_se
|
||||
assert mock_get_service.called
|
||||
|
||||
|
||||
def test_should_show_redirect_after_deleting_service(app_, db_, db_session, active_user, mock_get_service):
|
||||
def test_should_show_redirect_after_deleting_service(app_, db_, db_session, active_user, mock_get_service,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -218,7 +225,7 @@ def test_should_show_redirect_after_deleting_service(app_, db_, db_session, acti
|
||||
assert delete_url == response.location
|
||||
|
||||
|
||||
def test_should_show_delete_confirmation(app_, db_, db_session, active_user, mock_get_service):
|
||||
def test_should_show_delete_confirmation(app_, db_, db_session, active_user, mock_get_service, mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -236,7 +243,8 @@ def test_should_redirect_delete_confirmation(app_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_get_service,
|
||||
mock_delete_service):
|
||||
mock_delete_service,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
|
||||
@@ -18,7 +18,8 @@ def test_sign_out_user(app_,
|
||||
db_session,
|
||||
mock_send_sms,
|
||||
mock_send_email,
|
||||
mock_get_service):
|
||||
mock_get_service,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
email = 'valid@example.gov.uk'
|
||||
password = 'val1dPassw0rd!'
|
||||
|
||||
@@ -4,7 +4,8 @@ from flask import url_for
|
||||
import moto
|
||||
|
||||
|
||||
def test_upload_empty_csvfile_returns_to_upload_page(app_, db_, db_session, active_user):
|
||||
def test_upload_empty_csvfile_returns_to_upload_page(app_, db_, db_session, active_user,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -22,7 +23,8 @@ def test_upload_csvfile_with_invalid_phone_shows_check_page_with_errors(app_,
|
||||
db_,
|
||||
db_session,
|
||||
mocker,
|
||||
active_user):
|
||||
active_user,
|
||||
mock_user_loader):
|
||||
|
||||
contents = 'phone\n+44 123\n+44 456'
|
||||
file_data = (BytesIO(contents.encode('utf-8')), 'invalid.csv')
|
||||
@@ -47,7 +49,8 @@ def test_upload_csvfile_with_valid_phone_shows_first3_and_last3_numbers(app_,
|
||||
db_,
|
||||
db_session,
|
||||
mocker,
|
||||
active_user):
|
||||
active_user,
|
||||
mock_user_loader):
|
||||
|
||||
contents = 'phone\n+44 7700 900981\n+44 7700 900982\n+44 7700 900983\n+44 7700 900984\n+44 7700 900985\n+44 7700 900986\n+44 7700 900987\n+44 7700 900988\n+44 7700 900989' # noqa
|
||||
|
||||
@@ -83,7 +86,8 @@ def test_upload_csvfile_with_valid_phone_shows_all_if_6_or_less_numbers(app_,
|
||||
db_,
|
||||
db_session,
|
||||
mocker,
|
||||
active_user):
|
||||
active_user,
|
||||
mock_user_loader):
|
||||
|
||||
contents = 'phone\n+44 7700 900981\n+44 7700 900982\n+44 7700 900983\n+44 7700 900984\n+44 7700 900985\n+44 7700 900986' # noqa
|
||||
|
||||
@@ -111,7 +115,7 @@ def test_upload_csvfile_with_valid_phone_shows_all_if_6_or_less_numbers(app_,
|
||||
|
||||
|
||||
@moto.mock_s3
|
||||
def test_should_redirect_to_job(app_, db_, db_session, mocker, active_user):
|
||||
def test_should_redirect_to_job(app_, db_, db_session, mocker, active_user, mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
|
||||
@@ -6,7 +6,8 @@ def test_should_return_list_of_all_templates(app_,
|
||||
db_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_get_service_templates):
|
||||
mock_get_service_templates,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -22,7 +23,8 @@ def test_should_show_page_for_one_templates(app_,
|
||||
db_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_get_service_template):
|
||||
mock_get_service_template,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -43,7 +45,8 @@ def test_should_redirect_when_saving_a_template(app_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_get_service_template,
|
||||
mock_update_service_template):
|
||||
mock_update_service_template,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -75,7 +78,8 @@ def test_should_show_delete_template_page(app_,
|
||||
db_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_get_service_template):
|
||||
mock_get_service_template,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
@@ -97,7 +101,8 @@ def test_should_redirect_when_deleting_a_template(app_,
|
||||
db_session,
|
||||
active_user,
|
||||
mock_get_service_template,
|
||||
mock_delete_service_template):
|
||||
mock_delete_service_template,
|
||||
mock_user_loader):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
client.login(active_user)
|
||||
|
||||
@@ -5,14 +5,13 @@ from tests import create_test_api_user
|
||||
import pytest
|
||||
|
||||
|
||||
def test_should_return_verify_template(app_, db_, db_session):
|
||||
def test_should_return_verify_template(app_, db_, db_session, mock_api_user):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
# TODO this lives here until we work out how to
|
||||
# reassign the session after it is lost mid register process
|
||||
with client.session_transaction() as session:
|
||||
user = create_test_api_user('pending')
|
||||
session['user_details'] = {'email_address': user.email_address, 'id': user.id}
|
||||
session['user_details'] = {'email_address': mock_api_user.email_address, 'id': mock_api_user.id}
|
||||
response = client.get(url_for('main.verify'))
|
||||
assert response.status_code == 200
|
||||
assert (
|
||||
@@ -20,16 +19,17 @@ def test_should_return_verify_template(app_, db_, db_session):
|
||||
" You need to enter both codes here.") in response.get_data(as_text=True)
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Activation refactor to use api not completed')
|
||||
def test_should_redirect_to_add_service_when_code_are_correct(app_,
|
||||
db_,
|
||||
db_session):
|
||||
db_session,
|
||||
mock_api_user):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
with client.session_transaction() as session:
|
||||
user = create_test_api_user('pending')
|
||||
session['user_details'] = {'email_address': user.email_address, 'id': user.id}
|
||||
verify_codes_dao.add_code(user_id=user.id, code='12345', code_type='sms')
|
||||
verify_codes_dao.add_code(user_id=user.id, code='23456', code_type='email')
|
||||
session['user_details'] = {'email_address': mock_api_user.email_address, 'id': mock_api_user.id}
|
||||
verify_codes_dao.add_code(user_id=mock_api_user.id, code='12345', code_type='sms')
|
||||
verify_codes_dao.add_code(user_id=mock_api_user.id, code='23456', code_type='email')
|
||||
response = client.post(url_for('main.verify'),
|
||||
data={'sms_code': '12345',
|
||||
'email_code': '23456'})
|
||||
@@ -38,14 +38,13 @@ def test_should_redirect_to_add_service_when_code_are_correct(app_,
|
||||
|
||||
|
||||
@pytest.mark.xfail(reason='Activation refactor to use api not completed')
|
||||
def test_should_activate_user_after_verify(app_, db_, db_session):
|
||||
def test_should_activate_user_after_verify(app_, db_, db_session, mock_api_user):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
with client.session_transaction() as session:
|
||||
user = create_test_api_user('pending')
|
||||
session['user_details'] = {'email_address': user.email_address, 'id': user.id}
|
||||
verify_codes_dao.add_code(user_id=user.id, code='12345', code_type='sms')
|
||||
verify_codes_dao.add_code(user_id=user.id, code='23456', code_type='email')
|
||||
session['user_details'] = {'email_address': mock_api_user.email_address, 'id': mock_api_user.id}
|
||||
verify_codes_dao.add_code(user_id=mock_api_user.id, code='12345', code_type='sms')
|
||||
verify_codes_dao.add_code(user_id=mock_api_user.id, code='23456', code_type='email')
|
||||
client.post(url_for('main.verify'),
|
||||
data={'sms_code': '12345',
|
||||
'email_code': '23456'})
|
||||
@@ -74,12 +73,12 @@ def test_should_return_200_when_codes_are_wrong(app_, db_, db_session):
|
||||
@pytest.mark.xfail(reason='Activation refactor to use api not completed')
|
||||
def test_should_mark_all_codes_as_used_when_many_codes_exist(app_,
|
||||
db_,
|
||||
db_session):
|
||||
db_session,
|
||||
mock_api_user):
|
||||
with app_.test_request_context():
|
||||
with app_.test_client() as client:
|
||||
with client.session_transaction() as session:
|
||||
user = create_test_api_user('pending')
|
||||
session['user_details'] = {'email_address': user.email_address, 'id': user.id}
|
||||
session['user_details'] = {'email_address': mock_api_user.email_address, 'id': mock_api_user.id}
|
||||
code1 = verify_codes_dao.add_code(user_id=user.id, code='23345', code_type='sms')
|
||||
code2 = verify_codes_dao.add_code(user_id=user.id, code='98456', code_type='email')
|
||||
code3 = verify_codes_dao.add_code(user_id=user.id, code='12345', code_type='sms')
|
||||
|
||||
@@ -203,10 +203,80 @@ def mock_delete_service_template(mocker):
|
||||
'app.notifications_api_client.delete_service_template', side_effect=_delete)
|
||||
|
||||
|
||||
def mock_register_user(mocker, user_data):
|
||||
user_data['id'] = 1
|
||||
@pytest.fixture(scope='function')
|
||||
def mock_api_user(mocker):
|
||||
from app.notify_client.user_api_client import User
|
||||
user_data = {'id': 1,
|
||||
'name': 'Test User',
|
||||
'password': 'somepassword',
|
||||
'email_address': 'test@user.gov.uk',
|
||||
'mobile_number': '+441234123412',
|
||||
'state': 'pending'
|
||||
}
|
||||
user = User(user_data)
|
||||
return user
|
||||
|
||||
|
||||
@pytest.fixture(scope='function')
|
||||
def mock_register_user(mocker, mock_api_user):
|
||||
mock_class = mocker.patch('app.user_api_client.register_user')
|
||||
mock_class.return_value = user
|
||||
mock_class.return_value = mock_api_user
|
||||
return mock_class
|
||||
|
||||
|
||||
@pytest.fixture(scope='function')
|
||||
def mock_user_loader(mocker, mock_api_user):
|
||||
mock_class = mocker.patch('app.main.dao.users_dao.get_user_by_id')
|
||||
mock_class.return_value = mock_api_user
|
||||
return mock_class
|
||||
|
||||
|
||||
@pytest.fixture(scope='function')
|
||||
def mock_activate_user(mocker, mock_api_user):
|
||||
def _activate(mock_api_user):
|
||||
mock_api_user.state = 'active'
|
||||
return mock_api_user
|
||||
return mocker.patch('app.user_api_client.update_user', side_effect=_activate)
|
||||
|
||||
|
||||
@pytest.fixture(scope='function')
|
||||
def mock_user_dao_get_user(mocker):
|
||||
mock_class = mocker.patch('app.main.dao.users_dao.get_user_by_email')
|
||||
mock_class.return_value = mock_api_user
|
||||
return mock_class
|
||||
|
||||
|
||||
@pytest.fixture(scope='function')
|
||||
def mock_user_dao_get_by_email(mocker, mock_api_user):
|
||||
mock_class = mocker.patch('app.main.dao.users_dao.get_user_by_email')
|
||||
mock_class.return_value = mock_api_user
|
||||
return mock_class
|
||||
|
||||
|
||||
@pytest.fixture(scope='function')
|
||||
def mock_user_dao_update_email(mocker, mock_api_user):
|
||||
def _update(id, email_address):
|
||||
mock_api_user.fields['email_address'] = email_address
|
||||
return mocker.patch('app.main.dao.users_dao.update_email_address', side_effect=_update)
|
||||
|
||||
|
||||
@pytest.fixture(scope='function')
|
||||
def mock_user_dao_update_mobile(mocker, mock_api_user):
|
||||
def _update(id, mobile_number):
|
||||
mock_api_user.fields['mobile_number'] = mobile_number
|
||||
return mocker.patch('app.main.dao.users_dao.update_mobile_number', side_effect=_update)
|
||||
|
||||
|
||||
@pytest.fixture(scope='function')
|
||||
def mock_user_dao_password_reset(mocker, mock_api_user):
|
||||
def _reset(email):
|
||||
mock_api_user.state = 'request_password_reset'
|
||||
return mocker.patch('app.main.dao.users_dao.request_password_reset', side_effect=_reset)
|
||||
|
||||
|
||||
@pytest.fixture(scope='function')
|
||||
def mock_user_dao_get_new_password(mocker, mock_api_user):
|
||||
mock_api_user.state = 'request_password_reset'
|
||||
mock_class = mocker.patch('app.main.dao.users_dao.get_user_by_email')
|
||||
mock_class.return_value = mock_api_user
|
||||
return mock_class
|
||||
|
||||
Reference in New Issue
Block a user