4.0 KiB
4.0 KiB
Purpose
定义 target 的 id/name 双字段标识体系:id 作为唯一标识符,name 作为可选展示名称。
Requirements
Requirement: target id 字段
每个 target SHALL 包含必填的 id 字段作为唯一标识符。id SHALL 符合 [a-zA-Z0-9][a-zA-Z0-9_-]* 命名规则。id 长度 MUST 为 1 到 30 个字符。id MUST 在所有 targets 中全局唯一。id MUST NOT 参与变量替换。
Scenario: 合法 id
- WHEN target 配置
id: "api-health" - THEN 系统 SHALL 使用该 id 作为 target 的唯一标识符
Scenario: id 包含下划线和连字符
- WHEN target 配置
id: "db_check-01" - THEN 系统 SHALL 使用该 id 作为 target 的唯一标识符
Scenario: id 缺失报错
- WHEN target 未配置
id字段 - THEN 系统 SHALL 以配置错误退出,提示该 target 缺少 id 字段
Scenario: id 为空字符串报错
- WHEN target 配置
id: "" - THEN 系统 SHALL 以配置错误退出,提示 id 不能为空
Scenario: id 超过最大长度报错
- WHEN target 配置超过 30 个字符的
id - THEN 系统 SHALL 以配置错误退出,提示 id 长度不合法
Scenario: id 不合法报错
- WHEN target 配置
id: "_invalid"或id: "-start"或id: "has space" - THEN 系统 SHALL 以配置错误退出,提示 id 不符合命名规则
Scenario: id 重复报错
- WHEN 两个 target 配置相同的
id: "api-health" - THEN 系统 SHALL 以配置错误退出,提示 id 重复
Requirement: target name 字段
每个 target SHALL 支持可选的 name 字段作为展示名称。name 缺省时 SHALL fallback 到 id 的值作为展示名称。显式配置的 name 长度 MUST 为 1 到 30 个字符。name SHALL 支持变量替换。name MUST NOT 要求全局唯一。
Scenario: 配置 name
- WHEN target 配置
id: "api-health"和name: "API 健康检查" - THEN 系统 SHALL 使用 "API 健康检查" 作为展示名称
Scenario: name 使用变量
- WHEN target 配置
name: "${env} API 健康检查"且 variables 中env: "生产" - THEN 系统 SHALL 将展示名称解析为 "生产 API 健康检查"
Scenario: name 缺省 fallback 到 id
- WHEN target 配置
id: "api-health"但未配置name - THEN 系统 SHALL 使用 "api-health" 作为展示名称
Scenario: name 为空字符串报错
- WHEN target 配置
name: "" - THEN 系统 SHALL 以配置错误退出,提示 name 长度不合法
Scenario: name 超过最大长度报错
- WHEN target 配置超过 30 个字符的
name - THEN 系统 SHALL 以配置错误退出,提示 name 长度不合法
Scenario: 多个 target 使用相同 name
- WHEN 两个 target 配置不同 id 但相同
name: "健康检查" - THEN 系统 SHALL 接受该配置,不报错(name 不要求全局唯一)
Requirement: target description 字段
每个 target SHALL 支持可选的 description 字段作为目标说明。description SHALL 支持变量替换。description 长度 MUST 不超过 500 个字符,且允许为空字符串。description MUST NOT 参与 target 唯一性判定。
Scenario: 配置 description
- WHEN target 配置
description: "检查生产 API 健康状态" - THEN 系统 SHALL 使用该值作为目标说明
Scenario: description 使用变量
- WHEN target 配置
description: "${env} 环境健康检查"且 variables 中env: "生产" - THEN 系统 SHALL 将目标说明解析为 "生产 环境健康检查"
Scenario: description 缺省
- WHEN target 未配置
description - THEN 系统 SHALL 接受该配置,且目标说明为 null
Scenario: description 为空字符串
- WHEN target 配置
description: "" - THEN 系统 SHALL 接受该配置,且目标说明为空字符串
Scenario: description 超过最大长度报错
- WHEN target 配置超过 500 个字符的
description - THEN 系统 SHALL 以配置错误退出,提示 description 长度不合法