fix: shared MCP truncate() crashes on None/non-string tool output (#1605)

This commit is contained in:
Afonso Coutinho
2026-06-03 00:35:54 +01:00
committed by GitHub
parent 6df0f5e6df
commit 0d25dfb5f4
2 changed files with 31 additions and 0 deletions
+27
View File
@@ -0,0 +1,27 @@
"""Regression: the shared MCP truncate() must tolerate non-string input."""
import importlib.machinery
import importlib.util
from pathlib import Path
_PATH = Path(__file__).resolve().parents[1] / "mcp_servers" / "_common.py"
def _load():
loader = importlib.machinery.SourceFileLoader("odysseus_mcp_common", 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_truncate_handles_none_and_nonstring():
c = _load()
assert c.truncate(None) == ""
assert c.truncate(12345) == "12345"
def test_truncate_string_behaviour_unchanged():
c = _load()
assert c.truncate("hello", limit=100) == "hello"
out = c.truncate("x" * 50, limit=10)
assert out.startswith("x" * 10) and "truncated" in out