mirror of
https://github.com/bytedance/deer-flow.git
synced 2026-05-23 00:16:48 +00:00
fix(token-usage): enable stream usage for openai-compatible models (#2217)
* fix(token-usage): enable stream usage for openai-compatible models * fix(token-usage): narrow stream_usage default to ChatOpenAI
This commit is contained in:
@@ -597,6 +597,99 @@ def test_openai_compatible_provider_passes_base_url(monkeypatch):
|
||||
assert captured.get("api_key") == "test-key"
|
||||
assert captured.get("temperature") == 1.0
|
||||
assert captured.get("max_tokens") == 4096
|
||||
assert captured.get("stream_usage") is True
|
||||
|
||||
|
||||
def test_openai_compatible_provider_respects_explicit_stream_usage(monkeypatch):
|
||||
"""Explicit stream_usage should not be overwritten by the factory default."""
|
||||
model = ModelConfig(
|
||||
name="minimax-m2.5",
|
||||
display_name="MiniMax M2.5",
|
||||
description=None,
|
||||
use="langchain_openai:ChatOpenAI",
|
||||
model="MiniMax-M2.5",
|
||||
base_url="https://api.minimax.io/v1",
|
||||
api_key="test-key",
|
||||
stream_usage=False,
|
||||
supports_vision=True,
|
||||
supports_thinking=False,
|
||||
)
|
||||
cfg = _make_app_config([model])
|
||||
_patch_factory(monkeypatch, cfg)
|
||||
|
||||
captured: dict = {}
|
||||
|
||||
class CapturingModel(FakeChatModel):
|
||||
def __init__(self, **kwargs):
|
||||
captured.update(kwargs)
|
||||
BaseChatModel.__init__(self, **kwargs)
|
||||
|
||||
monkeypatch.setattr(factory_module, "resolve_class", lambda path, base: CapturingModel)
|
||||
|
||||
factory_module.create_chat_model(name="minimax-m2.5")
|
||||
|
||||
assert captured.get("stream_usage") is False
|
||||
|
||||
|
||||
def test_openai_compatible_provider_enables_stream_usage_for_openai_api_base(monkeypatch):
|
||||
"""openai_api_base should trigger stream_usage default for ChatOpenAI."""
|
||||
model = ModelConfig(
|
||||
name="openai-compatible",
|
||||
display_name="OpenAI-Compatible",
|
||||
description=None,
|
||||
use="langchain_openai:ChatOpenAI",
|
||||
model="example-model",
|
||||
openai_api_base="https://example.com/v1",
|
||||
api_key="test-key",
|
||||
supports_vision=False,
|
||||
supports_thinking=False,
|
||||
)
|
||||
cfg = _make_app_config([model])
|
||||
_patch_factory(monkeypatch, cfg)
|
||||
|
||||
captured: dict = {}
|
||||
|
||||
class CapturingModel(FakeChatModel):
|
||||
def __init__(self, **kwargs):
|
||||
captured.update(kwargs)
|
||||
BaseChatModel.__init__(self, **kwargs)
|
||||
|
||||
monkeypatch.setattr(factory_module, "resolve_class", lambda path, base: CapturingModel)
|
||||
|
||||
factory_module.create_chat_model(name="openai-compatible")
|
||||
|
||||
assert captured.get("openai_api_base") == "https://example.com/v1"
|
||||
assert captured.get("stream_usage") is True
|
||||
|
||||
|
||||
def test_non_openai_provider_does_not_receive_stream_usage_default(monkeypatch):
|
||||
"""Non-OpenAI providers with base_url should not receive stream_usage by default."""
|
||||
model = ModelConfig(
|
||||
name="ollama-local",
|
||||
display_name="Ollama Local",
|
||||
description=None,
|
||||
use="langchain_ollama:ChatOllama",
|
||||
model="qwen2.5",
|
||||
base_url="http://127.0.0.1:11434",
|
||||
supports_vision=False,
|
||||
supports_thinking=False,
|
||||
)
|
||||
cfg = _make_app_config([model])
|
||||
_patch_factory(monkeypatch, cfg)
|
||||
|
||||
captured: dict = {}
|
||||
|
||||
class CapturingModel(FakeChatModel):
|
||||
def __init__(self, **kwargs):
|
||||
captured.update(kwargs)
|
||||
BaseChatModel.__init__(self, **kwargs)
|
||||
|
||||
monkeypatch.setattr(factory_module, "resolve_class", lambda path, base: CapturingModel)
|
||||
|
||||
factory_module.create_chat_model(name="ollama-local")
|
||||
|
||||
assert captured.get("base_url") == "http://127.0.0.1:11434"
|
||||
assert "stream_usage" not in captured
|
||||
|
||||
|
||||
def test_openai_compatible_provider_multiple_models(monkeypatch):
|
||||
|
||||
Reference in New Issue
Block a user