fix: handle whitespace-only content in structured output parsing#2216
Open
valenradovich wants to merge 3 commits intoopenai:mainfrom
Open
fix: handle whitespace-only content in structured output parsing#2216valenradovich wants to merge 3 commits intoopenai:mainfrom
valenradovich wants to merge 3 commits intoopenai:mainfrom
Conversation
This commit fixes an issue where the API client would crash with JSON parsing errors when a model returns whitespace-only content (spaces, newlines, etc.) during structured output parsing. Changes: - Add a check in _parse_content to detect and gracefully handle empty or whitespace-only content before attempting JSON parsing - Improve streaming parser to skip JSON parsing for whitespace-only content - Update maybe_parse_content to catch and log parsing errors instead of letting them propagate - Add similar checks for tool argument parsing This fixes cases where users were getting "EOF while parsing a value" errors when using client.beta.chat.completions.parse with models that occasionally return only whitespace instead of structured JSON. With this change, parsing whitespace-only content now returns None for the parsed field instead of raising an exception, with an appropriate warning logged.
|
I'm also having this issue, great work! |
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.
This commit fixes an issue where the API client would crash with JSON parsing errors when a model returns whitespace-only content (spaces, newlines, etc.) during structured output parsing.
Changes being requested
Changes:
This fixes cases where users were getting "EOF while parsing a value" errors when using client.beta.chat.completions.parse with models that occasionally return only whitespace instead of structured JSON.
With this change, parsing whitespace-only content now returns None for the parsed field instead of raising an exception, with an appropriate warning logged.
Additional context & links
Fixes this Issue entirely:
#1763