Normalize stored MCP CLI JSON (#1554)
This commit is contained in:
@@ -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 {
|
||||||
|
|||||||
33
tests/test_mcp_cli_json.py
Normal file
33
tests/test_mcp_cli_json.py
Normal 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") == {}
|
||||||
Reference in New Issue
Block a user