Merge pull request #1813 from GyuminJack/fix/custom-agent-empty-response

fix: resolve empty response when custom agents end with tool calls
This commit is contained in:
YeonGyu-Kim
2026-02-20 11:54:04 +09:00
committed by GitHub
2 changed files with 20 additions and 4 deletions

View File

@@ -44,8 +44,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

@@ -152,8 +152,15 @@ session_id: ${sessionID}
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