fix: Skip empty AI messages in output_langchain to prevent API rejection#980
Merged
frdel merged 1 commit intoagent0ai:developmentfrom Feb 1, 2026
Merged
Conversation
Empty or whitespace-only AI messages cause API validation errors with strict providers (OpenAI, Z.ai, GLM): "Assistant messages must have either content or tool_calls" This is a companion fix to PR agent0ai#927 (response.py KeyError fix). When that fix returns an empty string instead of crashing, the empty string can become an empty AIMessage that fails API validation. Changes: - Pre-compute content before creating message objects - Skip AI messages where content is None, empty, or whitespace-only - Human messages are not filtered (they can be empty per spec) Tested on 4 production A0 instances.
Contributor
Author
|
To add to the above, I found this to be true when using Venice, A0-Venice, Opus, Grok 4.1 Fast. So, definitely not just GLM. |
Collaborator
|
Thank you! |
ky3mu4lp
pushed a commit
to ky3mu4lp/agent-zero
that referenced
this pull request
Feb 24, 2026
…ages fix: Skip empty AI messages in output_langchain to prevent API rejection
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Problem
Empty or whitespace-only AI messages cause API validation errors with strict providers (OpenAI, Z.ai, GLM):
Root Cause
This is a companion fix to PR #927 (response.py KeyError fix). When that fix returns an empty string instead of crashing, the empty string can become an empty
AIMessagethat fails API validation.The
output_langchain()function createsAIMessageobjects without validating that content exists.Solution
Testing
Deployed and validated on 4 production A0 instances running Z.ai/GLM providers.
Changes
python/helpers/history.py: Modifiedoutput_langchain()function (lines 519-533)