feat(hermes): add cron output settings

This commit is contained in:
晴天
2026-05-25 03:01:14 +08:00
parent e74df5f288
commit 92d64efd8e
8 changed files with 411 additions and 22 deletions

View File

@@ -205,6 +205,16 @@ test('Hermes 配置页会暴露审批安全结构化配置字段', () => {
}
})
test('Hermes 配置页会暴露定时任务结构化配置字段', () => {
for (const id of [
'hm-cron-save',
'hm-cron-wrap-response',
'hm-cron-max-parallel-jobs',
]) {
assert.match(source, new RegExp(`id="${id}"`), `缺少 ${id}`)
}
})
test('Hermes 配置页会暴露隐私脱敏结构化配置字段', () => {
for (const id of [
'hm-privacy-save',
@@ -266,7 +276,8 @@ test('Hermes 配置页新增结构化配置不会暴露翻译 key', () => {
key.includes('BrowserConfig') ||
key.includes('TerminalConfig') ||
key.includes('CheckpointsConfig') ||
key.includes('ApprovalsConfig')
key.includes('ApprovalsConfig') ||
key.includes('CronConfig')
)))
assert.ok(keys.size > 0, '应能提取新增结构化配置用到的 engine 翻译 key')

View File

@@ -0,0 +1,69 @@
import test from 'node:test'
import assert from 'node:assert/strict'
import {
buildHermesCronConfigValues,
mergeHermesCronConfig,
} from '../scripts/dev-api.js'
test('Hermes 定时任务配置读取会提供上游默认值', () => {
const values = buildHermesCronConfigValues({})
assert.deepEqual(values, {
cronWrapResponse: true,
cronMaxParallelJobs: 0,
})
})
test('Hermes 定时任务配置读取会回显 YAML 字段', () => {
const values = buildHermesCronConfigValues({
cron: {
wrap_response: false,
max_parallel_jobs: 4,
},
})
assert.equal(values.cronWrapResponse, false)
assert.equal(values.cronMaxParallelJobs, 4)
})
test('Hermes 定时任务配置保存会保留未知字段并写入 cron', () => {
const next = mergeHermesCronConfig({
cron: {
wrap_response: true,
custom_flag: 'keep-cron',
},
approvals: { cron_mode: 'deny' },
streaming: { enabled: true },
}, {
cronWrapResponse: false,
cronMaxParallelJobs: '3',
})
assert.deepEqual(next.approvals, { cron_mode: 'deny' })
assert.deepEqual(next.streaming, { enabled: true })
assert.equal(next.cron.wrap_response, false)
assert.equal(next.cron.max_parallel_jobs, 3)
assert.equal(next.cron.custom_flag, 'keep-cron')
})
test('Hermes 定时任务配置保存 0 会写回不限制并拒绝越界值', () => {
const next = mergeHermesCronConfig({
cron: {
max_parallel_jobs: 8,
},
}, {
cronMaxParallelJobs: '0',
})
assert.equal(next.cron.max_parallel_jobs, null)
assert.throws(
() => mergeHermesCronConfig({}, { cronMaxParallelJobs: '-1' }),
/cron\.max_parallel_jobs/,
)
assert.throws(
() => mergeHermesCronConfig({}, { cronMaxParallelJobs: '10001' }),
/cron\.max_parallel_jobs/,
)
})