From c1952e410993d157a04513f34dfdd973dee954ec Mon Sep 17 00:00:00 2001 From: Kazuhiro Sera Date: Sat, 12 Jul 2025 07:56:49 +0900 Subject: [PATCH 1/5] Change test coverage fail-under from 95 to 90 --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index 9a88f93a1..92850d25b 100644 --- a/Makefile +++ b/Makefile @@ -28,7 +28,7 @@ coverage: uv run coverage run -m pytest uv run coverage xml -o coverage.xml - uv run coverage report -m --fail-under=95 + uv run coverage report -m --fail-under=90 .PHONY: snapshots-fix snapshots-fix: From a274711bdbe56cc89812de89a71a88e6c0c14151 Mon Sep 17 00:00:00 2001 From: Kazuhiro Sera Date: Sat, 12 Jul 2025 08:11:52 +0900 Subject: [PATCH 2/5] fix --- src/agents/realtime/config.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/agents/realtime/config.py b/src/agents/realtime/config.py index aa15c837d..7923c9877 100644 --- a/src/agents/realtime/config.py +++ b/src/agents/realtime/config.py @@ -71,8 +71,10 @@ class RealtimeSessionConfig(TypedDict): tools: NotRequired[list[FunctionTool]] -APIKeyOrKeyFunc = str | Callable[[], MaybeAwaitable[str]] -"""Either an API key or a function that returns an API key.""" +# Using typing.Union for 3.9 compatibility +APIKeyOrKeyFunc: TypeAlias = Union[str, Callable[[], MaybeAwaitable[str]]] +"""Either an API key string or a zero-argument callable that returns one +(sync or async).""" async def get_api_key(key: APIKeyOrKeyFunc | None) -> str | None: From 9af8e49c21945c2c866ad3f359aeb6194e996501 Mon Sep 17 00:00:00 2001 From: Kazuhiro Sera Date: Sat, 12 Jul 2025 08:14:56 +0900 Subject: [PATCH 3/5] fix --- src/agents/realtime/transport.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/agents/realtime/transport.py b/src/agents/realtime/transport.py index 18290d128..811eaf8c7 100644 --- a/src/agents/realtime/transport.py +++ b/src/agents/realtime/transport.py @@ -1,3 +1,5 @@ +from __future__ import annotations + import abc from typing import Any, Literal, Union From 06420abd1673ec851bb5dd0dde457c7a9678251d Mon Sep 17 00:00:00 2001 From: Kazuhiro Sera Date: Sat, 12 Jul 2025 08:16:50 +0900 Subject: [PATCH 4/5] fix --- src/agents/realtime/transport.py | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/src/agents/realtime/transport.py b/src/agents/realtime/transport.py index 811eaf8c7..22f7612fa 100644 --- a/src/agents/realtime/transport.py +++ b/src/agents/realtime/transport.py @@ -1,7 +1,5 @@ -from __future__ import annotations - import abc -from typing import Any, Literal, Union +from typing import Any, Literal, Optional, Union from typing_extensions import NotRequired, TypeAlias, TypedDict @@ -75,7 +73,7 @@ async def send_event(self, event: RealtimeClientMessage) -> None: @abc.abstractmethod async def send_message( - self, message: RealtimeUserInput, other_event_data: dict[str, Any] | None = None + self, message: RealtimeUserInput, other_event_data: Optional[dict[str, Any]] = None ) -> None: """Send a message to the model.""" pass From 1220ac76e52672b570b9b02031ae8ebfe2b69885 Mon Sep 17 00:00:00 2001 From: Kazuhiro Sera Date: Sat, 12 Jul 2025 08:18:29 +0900 Subject: [PATCH 5/5] fix --- src/agents/realtime/openai_realtime.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/agents/realtime/openai_realtime.py b/src/agents/realtime/openai_realtime.py index 6dc34bcf1..72ed554ac 100644 --- a/src/agents/realtime/openai_realtime.py +++ b/src/agents/realtime/openai_realtime.py @@ -3,7 +3,7 @@ import json import os from datetime import datetime -from typing import Any +from typing import Any, Optional import websockets from openai.types.beta.realtime.realtime_server_event import ( @@ -110,7 +110,7 @@ async def send_event(self, event: RealtimeClientMessage) -> None: await self._websocket.send(json.dumps(converted_event)) async def send_message( - self, message: RealtimeUserInput, other_event_data: dict[str, Any] | None = None + self, message: RealtimeUserInput, other_event_data: Optional[dict[str, Any]] = None ) -> None: """Send a message to the model.""" message = (