mirror of
https://github.com/HKUDS/nanobot.git
synced 2026-05-20 08:32:25 +00:00
Channel lazy load: discover_enabled() only imports enabled channel modules instead of all 18 modules with heavy SDKs (telegram, discord, slack, etc). discover_all() now delegates to discover_enabled(). Lazy OpenAI client: defer AsyncOpenAI() + httpx construction to _ensure_client() with asyncio.Lock double-checked locking. openai and httpx imports moved from module-level into _ensure_client(). Minor: lazy Nanobot/RunResult and CronService exports via __getattr__. Benchmark: 6910ms → 460ms (-93.3%)
54 lines
1.9 KiB
Python
54 lines
1.9 KiB
Python
from unittest.mock import patch, sentinel
|
|
|
|
from nanobot.providers.openai_compat_provider import OpenAICompatProvider
|
|
from nanobot.providers.registry import ProviderSpec
|
|
|
|
|
|
def _assert_openai_compat_timeout(timeout) -> None:
|
|
assert timeout == 120.0
|
|
|
|
|
|
def test_openai_compat_provider_sets_sdk_timeout() -> None:
|
|
with patch("nanobot.providers.openai_compat_provider.AsyncOpenAI") as mock_async_openai:
|
|
OpenAICompatProvider(api_key="test-key", api_base="https://example.com/v1")
|
|
|
|
kwargs = mock_async_openai.call_args.kwargs
|
|
_assert_openai_compat_timeout(kwargs["timeout"])
|
|
assert kwargs["http_client"] is None
|
|
|
|
|
|
def test_openai_compat_provider_sets_timeout_on_local_http_client() -> None:
|
|
spec = ProviderSpec(
|
|
name="local",
|
|
keywords=(),
|
|
env_key="",
|
|
is_local=True,
|
|
default_api_base="http://127.0.0.1:11434/v1",
|
|
)
|
|
|
|
with (
|
|
patch("nanobot.providers.openai_compat_provider.AsyncOpenAI") as mock_async_openai,
|
|
patch(
|
|
"httpx.AsyncClient",
|
|
return_value=sentinel.http_client,
|
|
) as mock_http_client,
|
|
):
|
|
OpenAICompatProvider(spec=spec)
|
|
|
|
client_kwargs = mock_http_client.call_args.kwargs
|
|
_assert_openai_compat_timeout(client_kwargs["timeout"])
|
|
assert client_kwargs["limits"].keepalive_expiry == 0
|
|
|
|
openai_kwargs = mock_async_openai.call_args.kwargs
|
|
_assert_openai_compat_timeout(openai_kwargs["timeout"])
|
|
assert openai_kwargs["http_client"] is sentinel.http_client
|
|
|
|
|
|
def test_openai_compat_provider_timeout_can_be_overridden_by_env(monkeypatch) -> None:
|
|
monkeypatch.setenv("NANOBOT_OPENAI_COMPAT_TIMEOUT_S", "45")
|
|
|
|
with patch("nanobot.providers.openai_compat_provider.AsyncOpenAI") as mock_async_openai:
|
|
OpenAICompatProvider(api_key="test-key", api_base="https://example.com/v1")
|
|
|
|
assert mock_async_openai.call_args.kwargs["timeout"] == 45.0
|