Reject invalid preset CLI entries (#1579)

* Reject invalid preset CLI entries

* Use modern preset CLI test loader
This commit is contained in:
red person
2026-06-03 02:57:35 +03:00
committed by GitHub
parent a6b7a7bc60
commit ffeb7d8c97
2 changed files with 41 additions and 6 deletions

View File

@@ -49,6 +49,15 @@ def _save(data: dict) -> None:
tmp.replace(_PATH)
def _entry_or_fail(presets: dict, name: str) -> dict:
if name not in presets:
fail(f"no preset named {name!r}")
entry = presets[name]
if not isinstance(entry, dict):
fail(f"preset {name!r} is corrupt: expected an object")
return entry
def cmd_list(args):
presets = _load()
rows = []
@@ -66,9 +75,7 @@ def cmd_list(args):
def cmd_get(args):
presets = _load()
if args.name not in presets:
fail(f"no preset named {args.name!r}")
emit({"id": args.name, **presets[args.name]}, args)
emit({"id": args.name, **_entry_or_fail(presets, args.name)}, args)
def cmd_set(args):
@@ -93,9 +100,8 @@ def cmd_set(args):
def cmd_delete(args):
presets = _load()
if args.name not in presets:
fail(f"no preset named {args.name!r}")
snap = presets.pop(args.name)
snap = _entry_or_fail(presets, args.name)
presets.pop(args.name)
_save(presets)
emit({"ok": True, "deleted": {"id": args.name, **snap}}, args)

View File

@@ -0,0 +1,29 @@
import importlib.machinery
import importlib.util
from pathlib import Path
def _load_preset_cli():
path = Path(__file__).resolve().parent.parent / "scripts" / "odysseus-preset"
loader = importlib.machinery.SourceFileLoader("odysseus_preset_invalid_entries", 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_entry_or_fail_rejects_non_object_entries():
cli = _load_preset_cli()
try:
cli._entry_or_fail({"broken": "raw prompt"}, "broken")
except SystemExit as exc:
assert exc.code == 1
else:
raise AssertionError("expected invalid preset entry to exit")
def test_entry_or_fail_returns_valid_entry():
cli = _load_preset_cli()
assert cli._entry_or_fail({"ok": {"name": "ok"}}, "ok") == {"name": "ok"}