Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -480,13 +480,15 @@ def _convert_event_to_streaming_chunk(
reasoning_content = delta["reasoningContent"]
if "redactedContent" in reasoning_content:
reasoning_content["redacted_content"] = reasoning_content.pop("redactedContent")
reasoning_text = reasoning_content.get("text", "")
streaming_chunk = StreamingChunk(
content="",
index=block_idx,
meta={
**base_meta,
"reasoning_contents": [{"index": block_idx, "reasoning_content": reasoning_content}],
},
reasoning=ReasoningContent(
reasoning_text=reasoning_text,
extra={"reasoning_contents": [{"index": block_idx, "reasoning_content": reasoning_content}]},
),
meta=base_meta,
)

elif "messageStop" in event:
Expand Down Expand Up @@ -537,7 +539,10 @@ def _process_reasoning_contents(chunks: list[StreamingChunk]) -> ReasoningConten
reasoning_signature = None
redacted_content = None
for chunk in chunks:
reasoning_contents = chunk.meta.get("reasoning_contents", [])
if chunk.reasoning and chunk.reasoning.extra:
reasoning_contents = chunk.reasoning.extra.get("reasoning_contents", [])
else:
reasoning_contents = []

for reasoning_content in reasoning_contents:
content_block_index = reasoning_content["index"]
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1102,6 +1102,12 @@ def test_callback(chunk: StreamingChunk):
]
assert replies == expected_messages

# Verify streaming chunks carry reasoning in the reasoning field, not in meta
reasoning_chunks = [c for c in streaming_chunks if c.reasoning is not None]
assert len(reasoning_chunks) > 0
for chunk in reasoning_chunks:
assert "reasoning_contents" not in chunk.meta

def test_process_streaming_response_with_one_tool_call_with_redacted_thinking(self, mock_boto3_session):
model = "arn:aws:bedrock:us-east-1::inference-profile/us.anthropic.claude-sonnet-3-7-20250219-v1:0"
type_ = (
Expand Down