mirror of
https://github.com/NousResearch/hermes-agent.git
synced 2026-06-17 09:41:58 +00:00
85 lines
3.6 KiB
Python
85 lines
3.6 KiB
Python
"""Tests for docker container_config key propagation in file_tools."""
|
|
|
|
from unittest.mock import patch, MagicMock
|
|
import tools.file_tools as file_tools
|
|
|
|
|
|
def _make_env_config(**overrides):
|
|
base = {
|
|
"env_type": "docker",
|
|
"docker_image": "test-image:latest",
|
|
"singularity_image": "docker://test",
|
|
"modal_image": "test",
|
|
"daytona_image": "test",
|
|
"cwd": "/workspace",
|
|
"host_cwd": None,
|
|
"timeout": 180,
|
|
"container_cpu": 2,
|
|
"container_memory": 4096,
|
|
"container_disk": 20480,
|
|
"container_persistent": False,
|
|
"docker_volumes": [],
|
|
"docker_mount_cwd_to_workspace": True,
|
|
"docker_forward_env": ["MY_SECRET", "API_KEY"],
|
|
}
|
|
base.update(overrides)
|
|
return base
|
|
|
|
|
|
class TestFileToolsContainerConfig:
|
|
def _run(self, env_config, task_id, task_env_overrides=None):
|
|
captured = {}
|
|
mock_env = MagicMock()
|
|
|
|
def fake_create_env(**kwargs):
|
|
captured.update(kwargs)
|
|
return mock_env
|
|
|
|
with patch("tools.terminal_tool._get_env_config", return_value=env_config), \
|
|
patch("tools.terminal_tool._task_env_overrides", task_env_overrides or {}), \
|
|
patch("tools.terminal_tool._active_environments", {}), \
|
|
patch("tools.terminal_tool._creation_locks", {}), \
|
|
patch("tools.terminal_tool._creation_locks_lock", __import__("threading").Lock()), \
|
|
patch("tools.terminal_tool._create_environment", side_effect=fake_create_env), \
|
|
patch("tools.terminal_tool._start_cleanup_thread"), \
|
|
patch("tools.terminal_tool._check_disk_usage_warning"), \
|
|
patch("tools.file_tools._file_ops_cache", {}), \
|
|
patch("tools.file_tools._file_ops_lock", __import__("threading").Lock()):
|
|
file_tools._get_file_ops(task_id)
|
|
|
|
return captured
|
|
|
|
def test_docker_mount_cwd_to_workspace_passed(self):
|
|
"""docker_mount_cwd_to_workspace is forwarded to container_config."""
|
|
cc = self._run(_make_env_config(docker_mount_cwd_to_workspace=True), "t1").get("container_config", {})
|
|
assert cc.get("docker_mount_cwd_to_workspace") is True
|
|
|
|
def test_docker_forward_env_passed(self):
|
|
"""docker_forward_env is forwarded to container_config."""
|
|
cc = self._run(_make_env_config(docker_forward_env=["MY_SECRET"]), "t2").get("container_config", {})
|
|
assert cc.get("docker_forward_env") == ["MY_SECRET"]
|
|
|
|
def test_docker_mount_cwd_defaults_to_false(self):
|
|
"""docker_mount_cwd_to_workspace defaults to False when absent from config."""
|
|
cfg = _make_env_config()
|
|
del cfg["docker_mount_cwd_to_workspace"]
|
|
cc = self._run(cfg, "t3").get("container_config", {})
|
|
assert cc.get("docker_mount_cwd_to_workspace") is False
|
|
|
|
def test_docker_forward_env_defaults_to_empty_list(self):
|
|
"""docker_forward_env defaults to [] when absent from config."""
|
|
cfg = _make_env_config()
|
|
del cfg["docker_forward_env"]
|
|
cc = self._run(cfg, "t4").get("container_config", {})
|
|
assert cc.get("docker_forward_env") == []
|
|
|
|
def test_cwd_only_raw_task_override_reaches_file_environment(self):
|
|
"""CWD-only task overrides collapse to default but must keep their cwd."""
|
|
captured = self._run(
|
|
_make_env_config(env_type="local", cwd="/config-cwd"),
|
|
"desktop-session-cwd",
|
|
task_env_overrides={"desktop-session-cwd": {"cwd": "/workspace/session"}},
|
|
)
|
|
|
|
assert captured["task_id"] == "default"
|
|
assert captured["cwd"] == "/workspace/session"
|