Your Name e0bd3f2911 feat: 添加核心流程测试 + 审计日志 + 修复 task_service 嵌套加载 bug
- 新增 test_auth_api.py (48 tests): 注册/登录/刷新/退出全流程覆盖
- 新增 test_tasks_api.py (38 tests): 任务 CRUD/审核/申诉/权限控制
- 新增 AuditLog 模型 + log_action 审计服务
- 新增 logging_config.py 结构化日志配置
- 修复 task_service.py 缺少 Project.brand 嵌套加载导致的 MissingGreenlet 错误
- 修复 conftest.py 添加限流清理 fixture 防止测试间干扰
- 修复 TDD 红色阶段测试文件的 import 错误 (skip)
- auth.py 集成审计日志 (注册/登录/退出)
- 全部 211 tests passed, 2 skipped

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-09 17:39:18 +08:00

109 lines
2.0 KiB
Python

"""数据库配置"""
from sqlalchemy.ext.asyncio import create_async_engine, AsyncSession
from sqlalchemy.orm import sessionmaker
from app.config import settings
# 导入所有模型,确保在创建表时被注册
from app.models.base import Base
from app.models import (
# 用户与组织
User,
UserRole,
Brand,
Agency,
Creator,
# 项目与任务
Project,
Task,
TaskStage,
TaskStatus,
Brief,
# AI 配置
AIConfig,
# 审核
ReviewTask,
# 规则
ForbiddenWord,
WhitelistItem,
Competitor,
# 审计日志
AuditLog,
# 兼容
Tenant,
)
# 创建异步引擎
engine = create_async_engine(
settings.DATABASE_URL,
echo=settings.DEBUG,
future=True,
)
# 创建异步会话工厂
AsyncSessionLocal = sessionmaker(
engine,
class_=AsyncSession,
expire_on_commit=False,
)
async def get_db():
"""获取数据库会话依赖"""
async with AsyncSessionLocal() as session:
try:
yield session
await session.commit()
except Exception:
await session.rollback()
raise
finally:
await session.close()
async def init_db():
"""初始化数据库(创建所有表)"""
async with engine.begin() as conn:
await conn.run_sync(Base.metadata.create_all)
async def drop_db():
"""删除所有表(仅用于测试)"""
async with engine.begin() as conn:
await conn.run_sync(Base.metadata.drop_all)
# 导出所有模型,供其他模块使用
__all__ = [
"Base",
"engine",
"AsyncSessionLocal",
"get_db",
"init_db",
"drop_db",
# 用户与组织
"User",
"UserRole",
"Brand",
"Agency",
"Creator",
# 项目与任务
"Project",
"Task",
"TaskStage",
"TaskStatus",
"Brief",
# AI 配置
"AIConfig",
# 审核
"ReviewTask",
# 规则
"ForbiddenWord",
"WhitelistItem",
"Competitor",
# 审计日志
"AuditLog",
# 兼容
"Tenant",
]