fix: research CLI summary crashes on a non-string query (#1596)

This commit is contained in:
Afonso Coutinho
2026-06-03 00:36:57 +01:00
committed by GitHub
parent 667c663668
commit 258fe455eb
2 changed files with 43 additions and 1 deletions

View File

@@ -36,10 +36,18 @@ def _load(rp_id: str) -> dict | None:
return None
def _preview_text(value, limit: int = 200) -> str:
"""Truncated preview tolerant of non-string values. A stored research
record whose ``query`` is a non-string (legacy/corrupt JSON) would crash
``(value or "")[:200]`` with a TypeError; coerce non-strings to ""."""
text = value if isinstance(value, str) else ""
return text[:limit]
def _summarize(rp_id: str, data: dict) -> dict:
return {
"id": rp_id,
"query": (data.get("query") or "")[:200],
"query": _preview_text(data.get("query")),
"category": data.get("category") or "",
"status": data.get("status") or "",
"started_at": data.get("started_at") or "",

View File

@@ -0,0 +1,34 @@
"""Regression: research CLI summary must tolerate a non-string query.
`_summarize` did `(data.get("query") or "")[:200]`. A non-string query from a
legacy/corrupt research JSON is truthy, so `123[:200]` raised TypeError.
"""
import importlib.machinery
import importlib.util
from pathlib import Path
ROOT = Path(__file__).resolve().parents[1]
def _load_cli():
path = ROOT / "scripts" / "odysseus-research"
loader = importlib.machinery.SourceFileLoader("odysseus_research_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_preview_text_ignores_non_string():
cli = _load_cli()
assert cli._preview_text(None) == ""
assert cli._preview_text(123) == ""
assert cli._preview_text(["x"]) == ""
assert cli._preview_text("q" * 250) == "q" * 200
def test_summarize_does_not_crash_on_non_string_query():
cli = _load_cli()
out = cli._summarize("rp1", {"query": 123, "status": "done"})
assert out["query"] == ""
assert out["id"] == "rp1"