feat: surface codex runtime status

This commit is contained in:
AI Bot
2026-05-31 03:59:53 +08:00
parent cee1e7938e
commit 591638f35f
12 changed files with 544 additions and 6 deletions

View File

@@ -218,3 +218,79 @@ test("POST task progress preserves Codex thread status and realtime summaries",
assert.equal(progress?.realtime?.transcriptPreview, "正在分析 Codex App Server 实时事件。");
assert.equal(progress?.realtime?.audioChunkCount, 1);
});
test("POST task progress preserves Codex runtime status summaries", async () => {
const task = await data.queueMasterAgentTask({
taskId: "route-progress-runtime-task",
projectId: "group-progress-test",
taskType: "dispatch_execution",
requestMessageId: "msg-route-progress-runtime",
requestText: "让目标线程继续开发并回写运行状态",
executionPrompt: "让目标线程继续开发并回写运行状态",
requestedBy: "krisolo",
requestedByAccount: "krisolo",
deviceId: "mac-studio",
targetProjectId: "master-agent",
targetThreadId: "master-agent-thread",
});
await data.claimNextMasterAgentTask("mac-studio");
const response = await postProgress(
new NextRequest(`http://127.0.0.1:3000/api/v1/master-agent/tasks/${task.taskId}/progress`, {
method: "POST",
headers: {
"content-type": "application/json",
"x-boss-device-token": "boss-mac-studio-token",
},
body: JSON.stringify({
deviceId: "mac-studio",
status: "running",
executionProgress: {
steps: [{ text: "同步 Codex 运行状态", status: "running" }],
modelRoute: {
fromModel: "gpt-5.4-mini",
toModel: "gpt-5.4",
reason: "highRiskCyberActivity",
},
tokenUsage: {
totalTokens: 3000,
inputTokens: 2200,
cachedInputTokens: 300,
outputTokens: 650,
reasoningOutputTokens: 150,
modelContextWindow: 200000,
contextPercent: 2,
},
mcpServers: [
{
name: "github",
status: "failed",
error: "token=[redacted] failed to start",
},
],
remoteControl: {
status: "connected",
serverName: "Mac Studio",
environmentId: "env-prod",
installationId: "install-secret-should-not-persist",
},
},
}),
}),
{ params: Promise.resolve({ taskId: task.taskId }) },
);
assert.equal(response.status, 200);
const state = await data.readState();
const progress = state.projects
.find((project) => project.id === "master-agent")
?.messages.find((message) => message.executionProgress?.taskId === task.taskId)
?.executionProgress;
assert.equal(progress?.modelRoute?.toModel, "gpt-5.4");
assert.equal(progress?.tokenUsage?.contextPercent, 2);
assert.equal(progress?.mcpServers?.[0]?.name, "github");
assert.equal(progress?.mcpServers?.[0]?.error, "token=[redacted] failed to start");
assert.equal(progress?.remoteControl?.status, "connected");
assert.equal(JSON.stringify(progress).includes("install-secret-should-not-persist"), false);
});