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
64 lines
2.5 KiB
Python
64 lines
2.5 KiB
Python
"""Tests for warn_deprecated_cwd_env_vars() migration warning."""
|
|
|
|
import os
|
|
import pytest
|
|
|
|
|
|
class TestDeprecatedCwdWarning:
|
|
"""Warn when MESSAGING_CWD or TERMINAL_CWD is set in .env."""
|
|
|
|
def test_messaging_cwd_triggers_warning(self, monkeypatch, capsys):
|
|
monkeypatch.setenv("MESSAGING_CWD", "/some/path")
|
|
monkeypatch.delenv("TERMINAL_CWD", raising=False)
|
|
|
|
from hermes_agent.cli.config import warn_deprecated_cwd_env_vars
|
|
warn_deprecated_cwd_env_vars(config={})
|
|
|
|
captured = capsys.readouterr()
|
|
assert "MESSAGING_CWD" in captured.err
|
|
assert "deprecated" in captured.err.lower()
|
|
assert "config.yaml" in captured.err
|
|
|
|
def test_terminal_cwd_triggers_warning_when_config_placeholder(self, monkeypatch, capsys):
|
|
monkeypatch.setenv("TERMINAL_CWD", "/project")
|
|
monkeypatch.delenv("MESSAGING_CWD", raising=False)
|
|
|
|
from hermes_agent.cli.config import warn_deprecated_cwd_env_vars
|
|
# config has placeholder cwd → TERMINAL_CWD likely from .env
|
|
warn_deprecated_cwd_env_vars(config={"terminal": {"cwd": "."}})
|
|
|
|
captured = capsys.readouterr()
|
|
assert "TERMINAL_CWD" in captured.err
|
|
assert "deprecated" in captured.err.lower()
|
|
|
|
def test_no_warning_when_config_has_explicit_cwd(self, monkeypatch, capsys):
|
|
monkeypatch.setenv("TERMINAL_CWD", "/project")
|
|
monkeypatch.delenv("MESSAGING_CWD", raising=False)
|
|
|
|
from hermes_agent.cli.config import warn_deprecated_cwd_env_vars
|
|
# config has explicit cwd → TERMINAL_CWD could be from config bridge
|
|
warn_deprecated_cwd_env_vars(config={"terminal": {"cwd": "/project"}})
|
|
|
|
captured = capsys.readouterr()
|
|
assert "TERMINAL_CWD" not in captured.err
|
|
|
|
def test_no_warning_when_env_clean(self, monkeypatch, capsys):
|
|
monkeypatch.delenv("MESSAGING_CWD", raising=False)
|
|
monkeypatch.delenv("TERMINAL_CWD", raising=False)
|
|
|
|
from hermes_agent.cli.config import warn_deprecated_cwd_env_vars
|
|
warn_deprecated_cwd_env_vars(config={})
|
|
|
|
captured = capsys.readouterr()
|
|
assert captured.err == ""
|
|
|
|
def test_both_deprecated_vars_warn(self, monkeypatch, capsys):
|
|
monkeypatch.setenv("MESSAGING_CWD", "/msg/path")
|
|
monkeypatch.setenv("TERMINAL_CWD", "/term/path")
|
|
|
|
from hermes_agent.cli.config import warn_deprecated_cwd_env_vars
|
|
warn_deprecated_cwd_env_vars(config={})
|
|
|
|
captured = capsys.readouterr()
|
|
assert "MESSAGING_CWD" in captured.err
|
|
assert "TERMINAL_CWD" in captured.err
|