Files
expense_monitor/tests/test_auth.py
Mateusz Gruszczyński 986ffb200a first commit
2026-03-13 15:17:32 +01:00

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!')