feat(hermes): add global toolset disable settings

This commit is contained in:
晴天
2026-05-25 01:03:14 +08:00
parent 8d5d21f908
commit 4766a99d87
8 changed files with 441 additions and 17 deletions

View File

@@ -0,0 +1,70 @@
import test from 'node:test'
import assert from 'node:assert/strict'
import {
buildHermesAgentToolsetsConfigValues,
mergeHermesAgentToolsetsConfig,
} from '../scripts/dev-api.js'
test('Hermes Agent 工具集配置读取会提供上游默认值', () => {
const values = buildHermesAgentToolsetsConfigValues({})
assert.deepEqual(values, {
disabledToolsets: '',
})
})
test('Hermes Agent 工具集配置读取会回显全局禁用列表', () => {
const values = buildHermesAgentToolsetsConfigValues({
agent: {
disabled_toolsets: ['memory', 'web', 'browser'],
},
})
assert.equal(values.disabledToolsets, 'memory\nweb\nbrowser')
})
test('Hermes Agent 工具集配置保存会去重并保留未知字段', () => {
const next = mergeHermesAgentToolsetsConfig({
model: { provider: 'anthropic' },
agent: {
disabled_toolsets: ['memory'],
max_turns: 80,
custom_flag: 'keep-agent',
},
streaming: { enabled: true },
}, {
disabledToolsets: ' terminal \n browser \n\n memory\nbrowser ',
})
assert.deepEqual(next.model, { provider: 'anthropic' })
assert.deepEqual(next.streaming, { enabled: true })
assert.deepEqual(next.agent.disabled_toolsets, ['terminal', 'browser', 'memory'])
assert.equal(next.agent.max_turns, 80)
assert.equal(next.agent.custom_flag, 'keep-agent')
})
test('Hermes Agent 工具集配置保存空输入会写入空数组', () => {
const next = mergeHermesAgentToolsetsConfig({
agent: {
disabled_toolsets: ['memory'],
custom_flag: 'keep-agent',
},
}, {
disabledToolsets: ' \n ',
})
assert.deepEqual(next.agent.disabled_toolsets, [])
assert.equal(next.agent.custom_flag, 'keep-agent')
})
test('Hermes Agent 工具集配置保存会拒绝非法工具集名称', () => {
assert.throws(
() => mergeHermesAgentToolsetsConfig({}, { disabledToolsets: 'bad tool' }),
/agent\.disabled_toolsets/,
)
assert.throws(
() => mergeHermesAgentToolsetsConfig({}, { disabledToolsets: '../secret' }),
/agent\.disabled_toolsets/,
)
})

View File

@@ -58,6 +58,15 @@ test('Hermes 配置页会暴露快捷命令结构化配置字段', () => {
}
})
test('Hermes 配置页会暴露全局禁用工具集结构化配置字段', () => {
for (const id of [
'hm-agent-toolsets-save',
'hm-agent-disabled-toolsets',
]) {
assert.match(source, new RegExp(`id="${id}"`), `缺少 ${id}`)
}
})
test('Hermes 配置页会暴露未授权 DM 全局策略字段', () => {
for (const id of [
'hm-unauthorized-dm-save',
@@ -199,6 +208,7 @@ test('Hermes 配置页新增结构化配置不会暴露翻译 key', () => {
key.includes('MemoryConfig') ||
key.includes('SkillsConfig') ||
key.includes('QuickCommandsConfig') ||
key.includes('AgentToolsetsConfig') ||
key.includes('UnauthorizedDmConfig') ||
key.includes('SecurityConfig') ||
key.includes('HumanDelayConfig') ||