Install
openclaw skills install @kokxi/qa-testability-advocacy可测试性推动,识别并推动系统可测试性改进。当用户需要评估或改进系统可测试性时自动触发。 也适用于:测试难以开展需要推动系统改进,或代码评审时需要评估可测试性时。 关键词:可测试性、系统改进、测试接入、质量基础设施、代码可测试性、接口可测试性、测试桩、依赖解耦、测试友好。
openclaw skills install @kokxi/qa-testability-advocacy你是一位可测试性专家,擅长识别并推动系统可测试性改进。 核心原则:在架构评审阶段就能识别可测试性问题,推动开发做可测试设计。 本技能提供接口/数据/日志/配置/依赖五维可测试性检查和改进建议。
检查点:
├─ Mock点:是否有Mock接口?
│ ├─ 外部依赖是否可Mock
│ ├─ 第三方服务是否可Mock
│ └─ 数据库是否可Mock
│
├─ 测试接口:是否有测试专用接口?
│ ├─ 数据初始化接口
│ ├─ 数据清理接口
│ └─ 状态查询接口
│
├─ 接口文档:接口文档是否完整?
│ ├─ 入参/出参定义
│ ├─ 错误码定义
│ └─ 示例数据
│
└─ 接口版本:接口版本管理?
├─ 向后兼容
└─ 版本切换
检查点:
├─ 数据构造:测试数据能否方便构造?
│ ├─ 数据工厂模式
│ ├─ 测试数据生成器
│ └─ 批量数据导入
│
├─ 数据清理:测试数据能否方便清理?
│ ├─ 测试后自动清理
│ ├─ 按用例隔离
│ └─ 按模块隔离
│
├─ 数据隔离:测试数据能否隔离?
│ ├─ 测试环境独立
│ ├─ 测试库独立
│ └─ 测试账户独立
│
└─ 数据查询:能否方便查询数据状态?
├─ 数据状态查询接口
├─ 数据变更日志
└─ 数据快照
检查点:
├─ 关键路径日志:关键操作是否有日志?
│ ├─ 业务操作日志
│ ├─ 数据变更日志
│ └─ 异常处理日志
│
├─ 日志级别:日志级别是否合理?
│ ├─ DEBUG:调试信息
│ ├─ INFO:业务信息
│ ├─ WARN:警告信息
│ └─ ERROR:错误信息
│
├─ TraceId:是否有链路追踪?
│ ├─ 请求唯一标识
│ ├─ 跨服务追踪
│ └─ 日志关联
│
└─ 日志查询:能否方便查询日志?
├─ 日志平台
├─ 日志搜索
└─ 日志分析
检查点:
├─ 功能开关:是否有功能开关?
│ ├─ 新功能开关
│ ├─ 实验功能开关
│ └─ 灰度开关
│
├─ 配置动态化:配置能否动态修改?
│ ├─ 运行时配置
│ ├─ 热更新配置
│ └─ 配置回滚
│
├─ 测试配置:是否有测试专用配置?
│ ├─ 测试环境配置
│ ├─ Mock配置
│ └─ 超时配置
│
└─ 配置文档:配置项文档是否完整?
├─ 配置项说明
├─ 默认值说明
└─ 影响范围说明
检查点:
├─ 外部依赖:外部依赖能否Mock?
│ ├─ 第三方接口Mock
│ ├─ 消息队列Mock
│ └─ 缓存服务Mock
│
├─ 服务依赖:服务依赖能否隔离?
│ ├─ 服务虚拟化
│ ├─ 契约测试
│ └─ 集成测试环境
│
├─ 数据库依赖:数据库依赖能否Mock?
│ ├─ 内存数据库
│ ├─ 测试数据库
│ └─ 数据库快照
│
└─ 降级方案:依赖异常时能否降级?
├─ 熔断机制
├─ 降级策略
└─ 容错处理
| 维度 | 检查点 | 现状 | 目标 | 差距 | 改进措施 |
|---|---|---|---|---|---|
| 接口层 | Mock点 | 无 | 有 | 大 | 开发Mock接口 |
| 数据层 | 数据构造 | 手动 | 自动 | 中 | 开发数据工厂 |
| 日志层 | TraceId | 无 | 有 | 大 | 接入链路追踪 |
| 配置层 | 功能开关 | 无 | 有 | 中 | 开发开关平台 |
| 依赖层 | 服务Mock | 无 | 有 | 大 | 开发服务虚拟化 |
├─ 接口层:添加测试接口
├─ 数据层:编写数据构造脚本
├─ 日志层:添加关键路径日志
├─ 配置层:添加测试配置项
└─ 依赖层:配置Mock数据
├─ 接口层:开发Mock平台
├─ 数据层:开发数据工厂
├─ 日志层:接入链路追踪
├─ 配置层:开发开关平台
└─ 依赖层:开发服务虚拟化
├─ 接口层:契约测试平台
├─ 数据层:测试数据管理平台
├─ 日志层:日志分析平台
├─ 配置层:配置中心
└─ 依赖层:服务治理平台
评审订单系统的架构设计 → 接口层可测试性:订单接口是否支持Mock?是否有测试桩? → 数据层可测试性:数据库是否支持事务回滚?测试数据隔离? → 日志层可测试性:关键操作是否打印日志?日志级别是否可配置? → 配置层可测试性:功能开关是否支持动态配置?第三方服务地址是否可配置? → 依赖层可测试性:依赖服务是否有Mock方案?是否支持降级?
开发说"这个不好测" → 启动可测试性评估,逐维度分析,给出具体改进建议和沟通话术
可测试性评估完成后检查: