(
items: list[TResponseInputItem],
approval_item: Any,
step: ScenarioStep,
)
| 316 | |
| 317 | |
| 318 | def assert_step_output( |
| 319 | items: list[TResponseInputItem], |
| 320 | approval_item: Any, |
| 321 | step: ScenarioStep, |
| 322 | ) -> None: |
| 323 | last_user = get_last_user_text(items) |
| 324 | assert last_user == step.message |
| 325 | |
| 326 | last_call = find_last_function_call(items) |
| 327 | last_result = find_last_function_output(items) |
| 328 | |
| 329 | approval_call_id = extract_call_id(approval_item.raw_item) |
| 330 | assert last_call is not None |
| 331 | assert last_call.get("name") == step.tool_name |
| 332 | assert last_call.get("call_id") == approval_call_id |
| 333 | |
| 334 | assert last_result is not None |
| 335 | assert last_result.get("call_id") == approval_call_id |
| 336 | assert extract_output_text(last_result) == step.expected_output |
| 337 | |
| 338 | |
| 339 | def assert_step_items( |
no test coverage detected