mirror of
https://github.com/HKUDS/nanobot.git
synced 2026-05-19 16:12:30 +00:00
This commit implements a progressive refactoring of the tool system to support plugin discovery, scoped loading, and protocol-driven runtime context injection. Key changes: - Add Tool ABC metadata (tool_name, _scopes) and ToolContext dataclass for dependency injection. - Introduce ToolLoader with pkgutil-based builtin discovery and entry_points-based third-party plugin loading. - Add scope filtering (core/subagent/memory) so different contexts load appropriate tool sets. - Introduce ContextAware protocol and RequestContext dataclass to replace hardcoded per-tool context injection in AgentLoop. - Add RuntimeState / MutableRuntimeState protocols to decouple MyTool from AgentLoop. - Migrate all built-in tools to declare scopes and implement create()/enabled() hooks. - Migrate MessageTool, SpawnTool, CronTool, and MyTool to ContextAware. - Refactor AgentLoop to use ToolLoader and protocol-driven context injection. - Refactor SubagentManager to use ToolLoader(scope="subagent") with per-run FileStates isolation. - Register all built-in tools via pyproject.toml entry_points. - Add comprehensive tests for loader scopes, entry_points, ContextAware, subagent tools, and runtime state sync.
20 lines
663 B
Python
20 lines
663 B
Python
from nanobot.config.schema import Config
|
|
from nanobot.agent.tools.loader import ToolLoader
|
|
from nanobot.agent.tools.context import ToolContext
|
|
from nanobot.agent.tools.registry import ToolRegistry
|
|
|
|
|
|
def test_tool_loader_scope_memory_only_returns_memory_tools():
|
|
loader = ToolLoader()
|
|
registry = ToolRegistry()
|
|
ctx = ToolContext(config=Config().tools, workspace="/tmp")
|
|
loader.load(ctx, registry, scope="memory")
|
|
|
|
names = set(registry.tool_names)
|
|
assert "read_file" in names
|
|
assert "edit_file" in names
|
|
assert "write_file" in names
|
|
assert "list_dir" not in names
|
|
assert "exec" not in names
|
|
assert "message" not in names
|