eigent/backend/tests/app/agent/factory/test_browser.py
BitToby 1831d2a686
Some checks are pending
CodeQL Advanced / Analyze (actions) (push) Waiting to run
CodeQL Advanced / Analyze (javascript-typescript) (push) Waiting to run
CodeQL Advanced / Analyze (python) (push) Waiting to run
Pre-commit / pre-commit (push) Waiting to run
Test / Run Python Tests (push) Waiting to run
feat: add multi-modal attachment propagation to all worker agents thr… (#1196)
Co-authored-by: puzhen <1303385763@qq.com>
Co-authored-by: Wendong-Fan <w3ndong.fan@gmail.com>
Co-authored-by: Wendong-Fan <133094783+Wendong-Fan@users.noreply.github.com>
2026-02-22 01:18:49 +08:00

93 lines
3.7 KiB
Python

# ========= Copyright 2025-2026 @ Eigent.ai All Rights Reserved. =========
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ========= Copyright 2025-2026 @ Eigent.ai All Rights Reserved. =========
from unittest.mock import MagicMock, patch
import pytest
from app.agent.factory import browser_agent
from app.model.chat import Chat
from app.service.task import Agents
pytestmark = pytest.mark.unit
def test_browser_agent_creation(sample_chat_data):
"""Test browser_agent creates agent with search tools."""
options = Chat(**sample_chat_data)
# Setup task lock in the registry before calling agent function
from app.service.task import task_locks
mock_task_lock = MagicMock()
task_locks[options.task_id] = mock_task_lock
_mod = "app.agent.factory.browser"
with (
patch(f"{_mod}.agent_model") as mock_agent_model,
patch(
f"{_mod}.get_working_directory", return_value="/tmp/test_workdir"
),
patch("asyncio.create_task"),
patch(f"{_mod}.HumanToolkit") as mock_human_toolkit,
patch(f"{_mod}.HybridBrowserToolkit") as mock_browser_toolkit,
patch(f"{_mod}.TerminalToolkit") as mock_terminal_toolkit,
patch(f"{_mod}.NoteTakingToolkit") as mock_note_toolkit,
patch(f"{_mod}.ScreenshotToolkit") as mock_screenshot_toolkit,
patch(f"{_mod}.SearchToolkit") as mock_search_toolkit,
patch(f"{_mod}.ToolkitMessageIntegration"),
patch("uuid.uuid4") as mock_uuid,
):
# Mock all toolkit instances
mock_human_toolkit.get_can_use_tools.return_value = []
mock_browser_toolkit.return_value.get_tools.return_value = []
# Create a proper terminal toolkit mock
mock_terminal_instance = MagicMock()
mock_terminal_instance.shell_exec = MagicMock()
mock_terminal_toolkit.return_value = mock_terminal_instance
mock_note_toolkit.return_value.get_tools.return_value = []
mock_screenshot_toolkit.return_value.get_tools.return_value = []
mock_search_instance = MagicMock()
mock_search_instance.search_google = MagicMock()
mock_search_toolkit.return_value = mock_search_instance
mock_uuid.return_value.__getitem__ = lambda self, key: "test_session"
mock_agent = MagicMock()
mock_agent_model.return_value = mock_agent
result = browser_agent(options)
assert result is mock_agent
mock_agent_model.assert_called_once()
mock_screenshot_toolkit.assert_called_once_with(
options.project_id,
working_directory="/tmp/test_workdir",
agent_name=Agents.browser_agent,
)
# Check that it was called with browser agent configuration
call_args = mock_agent_model.call_args
assert "browser_agent" in str(
call_args[0][0]
) # agent_name (enum contains this value)
# The system_prompt is a BaseMessage, so check its content attribute
system_message = call_args[0][1]
if hasattr(system_message, "content"):
assert "search" in system_message.content.lower()
else:
assert (
"search" in str(system_message).lower()
) # system_prompt contains search