From 473a3c8d4f545e5eef76ab439a586f31eb16b93a Mon Sep 17 00:00:00 2001 From: Peter Zhang <18501667167@qq.com> Date: Tue, 2 Jun 2026 17:37:47 +0800 Subject: [PATCH] =?UTF-8?q?test:=20conftest=20ir=5Fdata=20=E9=98=B2?= =?UTF-8?q?=E5=BE=A1=20list-type=20section=20+=20normalize=20=E5=BC=82?= =?UTF-8?q?=E5=B8=B8=E5=9B=9E=E9=80=80=20-=20Closes=20#70?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- tests/acceptance/conftest.py | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/tests/acceptance/conftest.py b/tests/acceptance/conftest.py index 45662aa..f3d3dc0 100644 --- a/tests/acceptance/conftest.py +++ b/tests/acceptance/conftest.py @@ -150,7 +150,20 @@ def ir_data(ir_path: str) -> dict: from step3_merge_and_audit import _normalize_rule rules = data.get("rules", []) if rules: - data["rules"] = [_normalize_rule(r) for r in rules] + normalized = [] + for i, r in enumerate(rules): + if not isinstance(r, dict): + continue # Skip non-dict entries defensively + # Defensive: flatten list-type section fields (LLM produces these sometimes) + for src in r.get("sources", []): + sec = src.get("section") + if isinstance(sec, list): + src["section"] = sec[0] if sec else "" + try: + normalized.append(_normalize_rule(r)) + except Exception: + normalized.append(r) # Fallback: use raw rule if normalize crashes + data["rules"] = normalized return data