name: bkn-review description: 网络质量评审、评分与调整分发。闭环关键。
网络评审
公约:../_shared/contract.md
做什么
分析测试结果,计算质量评分,判定通过或需要调整,分发调整任务到对应 skill。
插件降级说明:当 plugin_availability.rules == unavailable 或 plugin_availability.test == unavailable 时,评分维度自动降级。
输入
- 测试执行结果(
bkn-test输出;若 test 插件不可用则为空) - 当前网络状态(对象/关系/绑定/映射汇总)
- 业务规则清单(如有;若 rules 插件不可用则为空)
plugin_availability:来自pipeline_state.yaml
质量评分
| 维度 | 检查内容 | 权重 |
|---|---|---|
| 结构完整性 | 每个对象有主键、有描述、属性非空 | 20% |
| 关系健全性 | 关系两端对象存在、方向一致、无悬空引用、属性引用存在(Source/Target Property 存在于对应对象 Data Properties) | 20% |
| 绑定率 | bound_objects / total_platform_objects | 20% |
| 映射覆盖率 | (mapped + waived) / total_platform_properties | 20% |
| 规则覆盖率 | 有规则的对象数 / 总对象数;拆分为子项(见下方) | 10% |
| 测试通过率 | passed_cases / total_cases | 10% |
规则覆盖率子项
规则覆盖率维度由两个子项组成:
| 子项 | 检查内容 | 占规则覆盖率权重 |
|---|---|---|
| 规则覆盖广度 | 有规则的对象数 / 总对象数 | 60% |
| Skill 文件质量 | 读取 bkn-rules 的 skill_self_check,5 项自检全部 pass 为 100%,每项 fail 扣 20% | 40% |
skill_self_check来自bkn-rules输出的skill_self_check字段- 若
bkn-rules未输出skill_self_check(旧版本或插件不可用),Skill 文件质量子项记为 0
插件降级评分逻辑
当 plugin_availability.rules == unavailable 时:
- 规则覆盖率维度:Skill 文件质量子项权重降为 0,仅保留规则覆盖广度子项(权重 10%)
- 若 rules 插件完全不可用导致无规则数据,规则覆盖率维度标记为 N/A,不参与评分
- 剩余维度权重等比放大:结构 22.2%、关系 22.2%、绑定 22.2%、映射 22.2%、测试 11.1%
当 plugin_availability.test == unavailable 时:
- 测试通过率维度:标记为 N/A,不参与评分
- 剩余维度权重等比放大:结构 22.2%、关系 22.2%、绑定 22.2%、映射 22.2%、规则 11.1%
双重降级(rules 和 test 都不可用):
- 规则覆盖率 + 测试通过率均标记为 N/A
- 剩余维度权重等比放大:结构 25%、关系 25%、绑定 25%、映射 25%
存储位置过滤
-
存储位置: local的对象 不参与绑定率和映射覆盖率计算 -
绑定率分母只计算
platform对象数量 -
映射覆盖率分母只计算
platform对象的属性数量 -
local 对象仍需通过结构完整性检查(有主键、有描述、属性非空)
-
综合分 >= 80 → 通过,可推送
-
60-80 → 有风险,需用户确认
-
< 60 → 建议修复
bind_mode == deferred 时的评分调整
当 bkn-env 判定 bind_mode: deferred(无可用数据视图)时:
- 绑定率(20%)和映射覆盖率(20%)标记为 N/A,不参与评分
- 剩余维度权重等比放大:结构完整性 33%、关系健全性 33%、规则覆盖率 17%、测试通过率 17%
一票否决
以下情况无论综合分如何,verdict 强制为 fail:
bind_mode == full且绑定率 < 30%(有视图但几乎没绑上),且 platform 对象数量 >= 3- 结构完整性维度 < 50%(基础质量不达标)
外部校验锚点
以下维度必须包含外部验证数据,不可纯粹依赖 Agent 自评:
- 结构完整性:
kweaver bkn validate通过 → 该维度底线 60%;未通过 → 上限 40% - 绑定率:来自
bkn-bind的binding_summary实际数值 - 映射覆盖率:来自
bkn-map的mapping_gate_summary实际数值 - 关系健全性-属性引用:
_shared/prepush-validation.md预检结果,有错误则该维度分数减半
调整分发
不达标时,按失败根因分发到对应 skill:
| 根因 | 调整 skill |
|---|---|
| 对象/关系问题 | bkn-doctor → bkn-draft |
| 绑定问题 | bkn-bind → bkn-map → bkn-backfill |
| 规则缺失 | ../_plugins/bkn-rules/SKILL.md(仅当 plugin_availability.rules == available 时) |
| 属性映射不足 | bkn-map |
插件不可用时的分发调整:
- 若
plugin_availability.rules == unavailable且根因涉及"规则缺失":- 不分发到 bkn-rules,改为输出提示"规则插件不可用,请手动补充业务规则或安装插件"
- 在
adjustment_plan中标记target_skill: none(plugin_unavailable)
每轮调整必须有 diff(改了什么)。最多自动循环 3 轮,超过则暂停让用户介入。
输出
quality_score: 0
score_breakdown: {structure, relations, binding, mapping, rules, tests}
plugin_degraded_dimensions: [] # 记录因插件不可用而降级的维度,如 ["rules", "tests"]
verdict: pass | warn | fail
adjustment_plan:
- target_skill: ""
reason: ""
suggested_action: ""
iteration: {current_round, max_rounds, score_history}
约束
- 评分必须基于实际测试数据,不编造
- 不替代具体 skill 做修复,只做诊断和分发
- 插件不可用时在输出中明确标注降级原因