feat: email verification, merchant/store password reset, seed gap fix
Some checks failed
Some checks failed
- Add EmailVerificationToken and UserPasswordResetToken models with migration - Add email verification flow: verify-email page route, resend-verification API - Block login for unverified users (EmailNotVerifiedException in auth_service) - Add forgot-password/reset-password endpoints for merchant and store auth - Add "Forgot Password?" links to merchant and store login pages - Send welcome email with verification link on merchant creation - Seed email_verification and merchant_password_reset email templates - Fix db-reset Makefile to run all init-prod seed scripts - Add UserAuthService to satisfy architecture validation rules - Add 52 new tests (unit + integration) with full coverage Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
1
tests/fixtures/admin_platform_fixtures.py
vendored
1
tests/fixtures/admin_platform_fixtures.py
vendored
@@ -80,6 +80,7 @@ def platform_admin_with_platform(db, auth_manager, test_platform, test_super_adm
|
||||
hashed_password=hashed_password,
|
||||
role="admin",
|
||||
is_active=True,
|
||||
is_email_verified=True,
|
||||
is_super_admin=False,
|
||||
)
|
||||
db.add(admin)
|
||||
|
||||
7
tests/fixtures/auth_fixtures.py
vendored
7
tests/fixtures/auth_fixtures.py
vendored
@@ -31,6 +31,7 @@ def test_user(db, auth_manager):
|
||||
hashed_password=hashed_password,
|
||||
role="user",
|
||||
is_active=True,
|
||||
is_email_verified=True,
|
||||
)
|
||||
db.add(user)
|
||||
db.commit()
|
||||
@@ -49,6 +50,7 @@ def test_admin(db, auth_manager):
|
||||
hashed_password=hashed_password,
|
||||
role="admin",
|
||||
is_active=True,
|
||||
is_email_verified=True,
|
||||
is_super_admin=True, # Full platform access
|
||||
)
|
||||
db.add(admin)
|
||||
@@ -68,6 +70,7 @@ def test_super_admin(db, auth_manager):
|
||||
hashed_password=hashed_password,
|
||||
role="admin",
|
||||
is_active=True,
|
||||
is_email_verified=True,
|
||||
is_super_admin=True,
|
||||
)
|
||||
db.add(admin)
|
||||
@@ -87,6 +90,7 @@ def test_platform_admin(db, auth_manager):
|
||||
hashed_password=hashed_password,
|
||||
role="admin",
|
||||
is_active=True,
|
||||
is_email_verified=True,
|
||||
is_super_admin=False, # Platform admin, not super admin
|
||||
)
|
||||
db.add(admin)
|
||||
@@ -130,6 +134,7 @@ def another_admin(db, auth_manager):
|
||||
hashed_password=hashed_password,
|
||||
role="admin",
|
||||
is_active=True,
|
||||
is_email_verified=True,
|
||||
is_super_admin=True, # Full platform access
|
||||
)
|
||||
db.add(admin)
|
||||
@@ -149,6 +154,7 @@ def other_user(db, auth_manager):
|
||||
hashed_password=hashed_password,
|
||||
role="user",
|
||||
is_active=True,
|
||||
is_email_verified=True,
|
||||
)
|
||||
db.add(user)
|
||||
db.commit()
|
||||
@@ -190,6 +196,7 @@ def test_store_user(db, auth_manager):
|
||||
hashed_password=hashed_password,
|
||||
role="store",
|
||||
is_active=True,
|
||||
is_email_verified=True,
|
||||
)
|
||||
db.add(user)
|
||||
db.commit()
|
||||
|
||||
Reference in New Issue
Block a user