Files
TJWaterServerBinary/test_api_integration.py

153 lines
4.7 KiB
Python
Executable File

#!/usr/bin/env python
"""
测试新增 API 集成
验证新的认证、用户管理和审计日志接口是否正确集成
"""
import sys
import subprocess
import time
def check_imports():
"""检查关键模块是否可以导入"""
print("=" * 60)
print("步骤 1: 检查模块导入")
print("=" * 60)
modules = [
("app.core.encryption", "加密模块"),
("app.core.security", "安全模块"),
("app.core.audit", "审计模块"),
("app.domain.models.role", "角色模型"),
("app.domain.schemas.user", "用户Schema"),
("app.domain.schemas.audit", "审计Schema"),
("app.auth.permissions", "权限控制"),
("app.api.v1.endpoints.auth", "认证接口"),
("app.api.v1.endpoints.user_management", "用户管理接口"),
("app.api.v1.endpoints.audit", "审计日志接口"),
("app.infra.repositories.user_repository", "用户仓储"),
("app.infra.repositories.audit_repository", "审计仓储"),
("app.infra.audit.middleware", "审计中间件"),
]
success = 0
failed = 0
for module_name, desc in modules:
try:
__import__(module_name)
print(f"{desc:20s} ({module_name})")
success += 1
except Exception as e:
print(f"{desc:20s} ({module_name})")
print(f" 错误: {e}")
failed += 1
print(f"\n结果: {success} 成功, {failed} 失败")
print()
return failed == 0
def check_router():
"""检查路由配置"""
print("=" * 60)
print("步骤 2: 检查路由配置")
print("=" * 60)
try:
from app.api.v1 import router
from app.api.v1.endpoints import auth, user_management, audit
print("✓ router 模块已导入")
print("✓ auth 端点已导入")
print("✓ user_management 端点已导入")
print("✓ audit 端点已导入")
# 检查 router 中是否包含新增的路由
api_router = router.api_router
print(f"\n已注册的路由数量: {len(api_router.routes)}")
# 查找新增的路由
auth_routes = [r for r in api_router.routes if hasattr(r, 'path') and '/auth' in r.path]
user_routes = [r for r in api_router.routes if hasattr(r, 'path') and '/users' in r.path]
audit_routes = [r for r in api_router.routes if hasattr(r, 'path') and '/audit' in r.path]
print(f"认证相关路由: {len(auth_routes)}")
print(f"用户管理路由: {len(user_routes)}")
print(f"审计日志路由: {len(audit_routes)}")
return True
except Exception as e:
print(f"✗ 路由配置检查失败: {e}")
import traceback
traceback.print_exc()
return False
def check_main_app():
"""检查 main.py 配置"""
print("\n" + "=" * 60)
print("步骤 3: 检查 main.py 配置")
print("=" * 60)
try:
from app.main import app
print("✓ FastAPI app 已创建")
print(f" 标题: {app.title}")
print(f" 版本: {app.version}")
# 检查中间件
middleware_names = [m.__class__.__name__ for m in app.user_middleware]
print(f"\n已注册的中间件: {len(middleware_names)}")
for name in middleware_names:
print(f" - {name}")
# 检查路由
print(f"\n已注册的路由: {len(app.routes)}")
return True
except Exception as e:
print(f"✗ main.py 配置检查失败: {e}")
import traceback
traceback.print_exc()
return False
def main():
print("\n🔍 TJWater Server API 集成测试\n")
results = []
# 测试 1: 模块导入
results.append(("模块导入", check_imports()))
# 测试 2: 路由配置
results.append(("路由配置", check_router()))
# 测试 3: main.py
results.append(("main.py配置", check_main_app()))
# 总结
print("\n" + "=" * 60)
print("测试总结")
print("=" * 60)
for name, success in results:
status = "✓ 通过" if success else "✗ 失败"
print(f"{status:8s} - {name}")
all_passed = all(success for _, success in results)
if all_passed:
print("\n✅ 所有测试通过!")
print("\n下一步:")
print(" 1. 确保数据库迁移已执行")
print(" 2. 配置 .env 文件")
print(" 3. 启动服务: uvicorn app.main:app --reload")
print(" 4. 访问文档: http://localhost:8000/docs")
return 0
else:
print("\n❌ 部分测试失败,请检查错误信息")
return 1
if __name__ == "__main__":
sys.exit(main())