mirror of
https://github.com/NousResearch/hermes-agent.git
synced 2026-04-30 01:41:43 +00:00
Rewrite all import statements, patch() targets, sys.modules keys, importlib.import_module() strings, and subprocess -m references to use hermes_agent.* paths. Strip sys.path.insert hacks from production code (rely on editable install). Update COMPONENT_PREFIXES for logger filtering. Fix 3 hardcoded getLogger() calls to use __name__. Update transport and tool registry discovery paths. Update plugin module path strings. Add legacy process-name patterns for gateway PID detection. Add main() to skills_sync for console_script entry point. Fix _get_bundled_dir() path traversal after move. Part of #14182, #14183
62 lines
2.4 KiB
Python
62 lines
2.4 KiB
Python
"""Tests for feishu_doc_tool and feishu_drive_tool — registration and schema validation."""
|
|
|
|
import importlib
|
|
import unittest
|
|
|
|
from hermes_agent.tools.registry import registry
|
|
|
|
# Trigger tool discovery so feishu tools get registered
|
|
importlib.import_module("hermes_agent.tools.feishu_doc")
|
|
importlib.import_module("hermes_agent.tools.feishu_drive")
|
|
|
|
|
|
class TestFeishuToolRegistration(unittest.TestCase):
|
|
"""Verify feishu tools are registered and have valid schemas."""
|
|
|
|
EXPECTED_TOOLS = {
|
|
"feishu_doc_read": "feishu_doc",
|
|
"feishu_drive_list_comments": "feishu_drive",
|
|
"feishu_drive_list_comment_replies": "feishu_drive",
|
|
"feishu_drive_reply_comment": "feishu_drive",
|
|
"feishu_drive_add_comment": "feishu_drive",
|
|
}
|
|
|
|
def test_all_tools_registered(self):
|
|
for tool_name, toolset in self.EXPECTED_TOOLS.items():
|
|
entry = registry.get_entry(tool_name)
|
|
self.assertIsNotNone(entry, f"{tool_name} not registered")
|
|
self.assertEqual(entry.toolset, toolset)
|
|
|
|
def test_schemas_have_required_fields(self):
|
|
for tool_name in self.EXPECTED_TOOLS:
|
|
entry = registry.get_entry(tool_name)
|
|
schema = entry.schema
|
|
self.assertIn("name", schema)
|
|
self.assertEqual(schema["name"], tool_name)
|
|
self.assertIn("description", schema)
|
|
self.assertIn("parameters", schema)
|
|
self.assertIn("type", schema["parameters"])
|
|
self.assertEqual(schema["parameters"]["type"], "object")
|
|
|
|
def test_handlers_are_callable(self):
|
|
for tool_name in self.EXPECTED_TOOLS:
|
|
entry = registry.get_entry(tool_name)
|
|
self.assertTrue(callable(entry.handler))
|
|
|
|
def test_doc_read_schema_params(self):
|
|
entry = registry.get_entry("feishu_doc_read")
|
|
props = entry.schema["parameters"].get("properties", {})
|
|
self.assertIn("doc_token", props)
|
|
|
|
def test_drive_tools_require_file_token(self):
|
|
for tool_name in self.EXPECTED_TOOLS:
|
|
if tool_name == "feishu_doc_read":
|
|
continue
|
|
entry = registry.get_entry(tool_name)
|
|
props = entry.schema["parameters"].get("properties", {})
|
|
self.assertIn("file_token", props, f"{tool_name} missing file_token param")
|
|
self.assertIn("file_type", props, f"{tool_name} missing file_type param")
|
|
|
|
|
|
if __name__ == "__main__":
|
|
unittest.main()
|