5.2 KiB
5.2 KiB
Pytest 全链路验收说明
目标
把“不同租户 + 不同角色权限”的发布前验收,固化成可重复执行的黑盒测试,而不是继续依赖手工点接口。
当前套件覆盖两层:
G1-G3发布门禁- 多租户、多角色矩阵基础链路
G4文档跨租户读写边界G5RAG 可见性与管理边界G6规则集/评查组只读矩阵与交叉评查建单边界
执行方式
先安装测试依赖:
.venv/bin/pip install -e .[test]
执行全部发布验收:
.venv/bin/python -m pytest tests/release -m release
只执行门禁链路:
.venv/bin/python -m pytest tests/release/test_g1_rbac_context.py tests/release/test_g2_g3_tenant_entry_chain.py -m release
默认环境变量
测试默认打正在运行的本地后端:
LEAUDIT_TEST_BASE_URL=http://127.0.0.1:8096LEAUDIT_TEST_ADMIN_USERNAME=000LEAUDIT_TEST_ADMIN_PASSWORD=admin06111LEAUDIT_TEST_TENANT_A_CODE=PTA01LEAUDIT_TEST_TENANT_B_CODE=PTB01
如需切换:
LEAUDIT_TEST_BASE_URL=http://127.0.0.1:8096 .venv/bin/python -m pytest tests/release -m release
当前测试矩阵
角色
- 全局管理用户:直接复用现有管理员账号
- 租户管理员:自动创建
admin角色测试用户 - 租户普通用户:自动创建
common角色测试用户
租户
PTA01 / Pytest租户APTB01 / Pytest租户B
链路
- 登录 ->
/api/auth/me - 路由树 ->
/api/rbac/user/routes - 用户列表 ->
/api/v3/rbac/users - 组织树 ->
/api/admin/users/organizations/tree - 租户主数据 ->
/api/v3/tenants/* - 用户租户切换 ->
/api/v3/rbac/users/{id}/tenant - 首页入口 ->
/api/home/entry-modules - 入口模块租户分配 ->
/api/v3/entry-modules/* - 文档上传/列表/详情/更新/附件/删除 ->
/api/documents/* - RAG 应用/数据集详情边界 ->
/api/v3/rag/* - 规则集/评查组/交叉评查 ->
/api/rule-sets、/api/v3/evaluation-point-groups/*、/api/v3/cross-review/*
测试数据策略
用户
测试用户通过 OAuth 登录自动建号 方式创建,再由管理员接口补齐:
- 角色绑定
- 租户绑定
这样可以避免直连数据库造数据,保持整套测试为 HTTP 黑盒。
租户
测试租户采用“存在则更新,不存在则创建”的策略,保证可重复运行。
入口模块
测试入口模块采用独立名称:
Pytest发布验收入口模块
该模块默认落到 /documents,避免被当前“首页入口还要求命中路由树”的逻辑误过滤。
该模块在用例内动态切换租户分配,用来验证首页入口是否随租户边界正确显隐。
当前已固化断言
G1
- 管理员可正常登录
/api/auth/me返回角色与权限上下文/api/rbac/user/routes返回管理路由/api/v3/rbac/users可访问/api/admin/users/organizations/tree可访问
G2
- 测试租户可创建/更新并保持启用
- 用户租户切换成功后,重新登录可看到正确
tenant_code
G3
- 入口模块仅分配给租户 B 时,租户 A 首页不可见、租户 B 可见
- 入口模块同时分配给租户 A/B 时,两边首页都可见
角色/租户矩阵
- 全局管理员可以按不同租户查询用户
- 租户管理员只能看到本租户用户
- 租户管理员查询其他租户用户返回
403 - 租户管理员不能修改其他租户用户
- 普通用户不能访问系统设置管理接口
- 普通用户仍可看到本租户业务入口
G4 文档
- 租户 A 创建文档后,租户 A 可见、租户 B 不可见
- 本租户管理员可更新本租户文档
- 跨租户更新、附件追加、删除返回拒绝
- 普通用户只能看到自己创建的文档
- 附件追加
mergeMode=new当前行为是生成新版本,并保留previousVersionId
G5 RAG
- 全局管理员可创建/更新不同租户数据集
- 租户管理员可读取本租户数据集详情
- 租户管理员当前不能访问
/api/v3/rag/datasets/admin - 租户管理员当前不能创建或修改数据集
- 本租户私有应用仅本租户可见
- 挂载公共数据集的应用可跨租户可见
G6 规则集 / 评查组 / 交叉评查
- 规则集元数据列表当前为全局可读
- 规则绑定列表按入口模块租户映射过滤
- 评查组树按入口模块租户映射过滤
- 交叉评查同租户建单成功
- 交叉评查混入跨租户文档返回
403 - 交叉评查混入跨租户成员返回
403
当前执行结果
最近一次完整执行结果:
tests/release -m release- 结果:
16 passed
这 16 条通过表达的是“当前真实系统行为已经被固定下来”,不等于所有目标设计都已经完成。
其中需要特别注意:
RAG当前仍保留“管理接口偏全局管理员”的现实权限模型- 规则集元数据目前是全局可读,不应误读为已经完成规则资产完全租户化
- 交叉评查当前是单任务单租户模型
下一步扩展建议
下一批优先补:
RAG数据集文档上传、重处理、删除链路RAG 会话创建、重命名、删除、消息反馈链路规则版本创建、发布、回滚、内容读取矩阵交叉评查补传、提案、投票、归档深链路