refactor: harden master-agent prompt assembly
This commit is contained in:
@@ -9,6 +9,7 @@ let saveAiAccount: (typeof import("../src/lib/boss-data"))["saveAiAccount"];
|
||||
let updateProjectAgentControls: (typeof import("../src/lib/boss-data"))["updateProjectAgentControls"];
|
||||
let updateMasterAgentPromptPolicy: (typeof import("../src/lib/boss-data"))["updateMasterAgentPromptPolicy"];
|
||||
let updateUserMasterPrompt: (typeof import("../src/lib/boss-data"))["updateUserMasterPrompt"];
|
||||
let createUserMasterMemory: (typeof import("../src/lib/boss-data"))["createUserMasterMemory"];
|
||||
let resolveMasterAgentExecutionConfig: (typeof import("../src/lib/boss-master-agent"))["resolveMasterAgentExecutionConfig"];
|
||||
|
||||
async function setup() {
|
||||
@@ -27,6 +28,7 @@ async function setup() {
|
||||
updateProjectAgentControls = data.updateProjectAgentControls;
|
||||
updateMasterAgentPromptPolicy = data.updateMasterAgentPromptPolicy;
|
||||
updateUserMasterPrompt = data.updateUserMasterPrompt;
|
||||
createUserMasterMemory = data.createUserMasterMemory;
|
||||
resolveMasterAgentExecutionConfig = masterAgent.resolveMasterAgentExecutionConfig;
|
||||
}
|
||||
|
||||
@@ -103,3 +105,60 @@ test("主 Agent 执行配置会合成管理员提示词、用户提示词和当
|
||||
assert.equal(resolved.projectPromptOverride, "当前对话提示词");
|
||||
assert.equal(resolved.promptPolicy?.updatedBy, "17600003315");
|
||||
});
|
||||
|
||||
test("主 Agent 执行 prompt 会明确声明管理员全局提示词不可覆盖,并带出项目记忆来源", async () => {
|
||||
await setup();
|
||||
|
||||
await saveAiAccount({
|
||||
accountId: "master-codex-primary",
|
||||
label: "主 GPT",
|
||||
role: "primary",
|
||||
provider: "master_codex_node",
|
||||
displayName: "Mac 上的 Master Codex Node",
|
||||
nodeId: "local-codex-node",
|
||||
nodeLabel: "本机 Codex",
|
||||
model: "gpt-4.1-mini",
|
||||
enabled: true,
|
||||
setActive: true,
|
||||
loginStatusNote: "通过绑定的 Master Codex Node 对话。",
|
||||
});
|
||||
|
||||
await updateMasterAgentPromptPolicy({
|
||||
globalPrompt: "系统级主提示词",
|
||||
updatedBy: "17600003315",
|
||||
});
|
||||
await updateUserMasterPrompt("17600003315", "用户私有主提示词");
|
||||
await createUserMasterMemory({
|
||||
account: "17600003315",
|
||||
scope: "project",
|
||||
projectId: "boss-console",
|
||||
title: "boss 项目进度",
|
||||
content: "boss 项目当前按项目聚合加线程下钻展示。",
|
||||
memoryType: "project_progress",
|
||||
tags: ["boss", "会话"],
|
||||
});
|
||||
await createUserMasterMemory({
|
||||
account: "17600003315",
|
||||
scope: "project",
|
||||
projectId: "project-wenshenapp",
|
||||
title: "wenshenapp 项目进度",
|
||||
content: "wenshenapp 当前只有一个主线程。",
|
||||
memoryType: "project_progress",
|
||||
tags: ["wenshenapp"],
|
||||
});
|
||||
|
||||
const resolved = await resolveMasterAgentExecutionConfig(
|
||||
"master-agent",
|
||||
"17600003315",
|
||||
"继续推进 boss 项目的会话归档逻辑",
|
||||
);
|
||||
|
||||
assert.match(
|
||||
resolved.executionPrompt,
|
||||
/管理员全局主提示词.*不可被.*覆盖|不可覆盖管理员全局主提示词/,
|
||||
);
|
||||
assert.match(
|
||||
resolved.executionPrompt,
|
||||
/projectId=boss-console/,
|
||||
);
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user