25 lines
1.2 KiB
Python
25 lines
1.2 KiB
Python
from app.models import PasswordResetToken, User
|
|
|
|
|
|
def test_login_success(client):
|
|
response = client.post('/login', data={'email': 'user@test.com', 'password': 'Password123!'}, follow_redirects=True)
|
|
assert response.status_code == 200
|
|
assert b'Dashboard' in response.data or b'Panel' in response.data
|
|
|
|
|
|
def test_honeypot_blocks_login(client):
|
|
response = client.post('/login', data={'email': 'user@test.com', 'password': 'Password123!', 'website': 'spam'}, follow_redirects=True)
|
|
assert response.status_code == 200
|
|
|
|
|
|
def test_password_reset_flow(client, app):
|
|
client.post('/forgot-password', data={'email': 'user@test.com'}, follow_redirects=True)
|
|
with app.app_context():
|
|
token = PasswordResetToken.query.join(User).filter(User.email == 'user@test.com').first()
|
|
assert token is not None
|
|
response = client.post(f'/reset-password/{token.token}', data={'password': 'NewPassword123!', 'confirm_password': 'NewPassword123!'}, follow_redirects=True)
|
|
assert response.status_code == 200
|
|
with app.app_context():
|
|
user = User.query.filter_by(email='user@test.com').first()
|
|
assert user.check_password('NewPassword123!')
|