Normalize stored MCP CLI JSON (#1554)

This commit is contained in:
red person
2026-06-03 08:11:35 +03:00
committed by GitHub
parent 38bfa85ad0
commit f549058369
2 changed files with 51 additions and 8 deletions

View File

@@ -33,15 +33,25 @@ except ModuleNotFoundError as e:
sys.exit(2) sys.exit(2)
def _json_list(raw) -> list:
try:
value = json.loads(raw) if raw else []
except (TypeError, json.JSONDecodeError):
return []
return value if isinstance(value, list) else []
def _json_dict(raw) -> dict:
try:
value = json.loads(raw) if raw else {}
except (TypeError, json.JSONDecodeError):
return {}
return value if isinstance(value, dict) else {}
def _serialize(s: "McpServer", redact_env: bool = True) -> dict: def _serialize(s: "McpServer", redact_env: bool = True) -> dict:
try: args_arr = _json_list(s.args)
args_arr = json.loads(s.args) if s.args else [] env_obj = _json_dict(s.env)
except json.JSONDecodeError:
args_arr = []
try:
env_obj = json.loads(s.env) if s.env else {}
except json.JSONDecodeError:
env_obj = {}
if redact_env and isinstance(env_obj, dict): if redact_env and isinstance(env_obj, dict):
env_obj = {k: ("***" if v else "") for k, v in env_obj.items()} env_obj = {k: ("***" if v else "") for k, v in env_obj.items()}
return { return {

View File

@@ -0,0 +1,33 @@
import importlib.machinery
import importlib.util
import sys
import types
from pathlib import Path
from unittest.mock import MagicMock
ROOT = Path(__file__).resolve().parents[1]
def _load_cli(monkeypatch):
db = types.ModuleType("core.database")
db.SessionLocal = MagicMock()
db.McpServer = MagicMock()
monkeypatch.setitem(sys.modules, "core.database", db)
path = ROOT / "scripts" / "odysseus-mcp"
loader = importlib.machinery.SourceFileLoader("odysseus_mcp_cli", str(path))
spec = importlib.util.spec_from_loader(loader.name, loader)
module = importlib.util.module_from_spec(spec)
loader.exec_module(module)
return module
def test_mcp_json_helpers_reject_wrong_shapes(monkeypatch):
cli = _load_cli(monkeypatch)
assert cli._json_list('["a"]') == ["a"]
assert cli._json_list('{"not":"list"}') == []
assert cli._json_list("{bad") == []
assert cli._json_dict('{"A":"B"}') == {"A": "B"}
assert cli._json_dict('["bad"]') == {}
assert cli._json_dict("{bad") == {}