fix: resolve empty response when custom agents end with tool calls

When a custom agent's last assistant message contains only tool calls (no text/reasoning parts), the sync result fetcher returned empty content. Walk assistant messages newest-first to find the first one with actual text content.
This commit is contained in:
GyuminJack
2026-02-13 14:53:22 +09:00
committed by aiml-gmlee
parent 0b1fdd508f
commit 0d1b6ebe2c
2 changed files with 20 additions and 4 deletions

View File

@@ -41,8 +41,17 @@ export async function fetchSyncResult(
return { ok: false, error: `No assistant response found.\n\nSession ID: ${sessionID}` }
}
const textParts = lastMessage?.parts?.filter((p) => p.type === "text" || p.type === "reasoning") ?? []
const textContent = textParts.map((p) => p.text ?? "").filter(Boolean).join("\n")
// Search assistant messages (newest first) for one with text/reasoning content.
// The last assistant message may only contain tool calls with no text.
let textContent = ""
for (const msg of assistantMessages) {
const textParts = msg.parts?.filter((p) => p.type === "text" || p.type === "reasoning") ?? []
const content = textParts.map((p) => p.text ?? "").filter(Boolean).join("\n")
if (content) {
textContent = content
break
}
}
return { ok: true, textContent }
}

View File

@@ -120,8 +120,15 @@ export async function executeUnstableAgentTask(
return `No assistant response found (task ran in background mode).\n\nSession ID: ${sessionID}`
}
const textParts = lastMessage?.parts?.filter((p) => p.type === "text" || p.type === "reasoning") ?? []
const textContent = textParts.map((p) => p.text ?? "").filter(Boolean).join("\n")
let textContent = ""
for (const msg of assistantMessages) {
const textParts = msg.parts?.filter((p) => p.type === "text" || p.type === "reasoning") ?? []
const content = textParts.map((p) => p.text ?? "").filter(Boolean).join("\n")
if (content) {
textContent = content
break
}
}
const duration = formatDuration(startTime)
return `SUPERVISED TASK COMPLETED SUCCESSFULLY