389e6de0c7
CI / detect-changes (push) Successful in 8s
CI / branch-name (push) Has been skipped
CI / guardrail-integrity (push) Has been skipped
CI / secret-scan (push) Has been skipped
CI / sbom-scan (push) Has been skipped
CI / build-sha-integrity (push) Failing after 4s
CI / iace-gt-coverage (push) Has been skipped
CI / test-python-backend (push) Successful in 30s
CI / test-python-document-crawler (push) Has been skipped
CI / test-python-dsms-gateway (push) Has been skipped
CI / dep-audit (push) Has been skipped
CI / validate-canonical-controls (push) Successful in 11s
CI / loc-budget (push) Successful in 14s
CI / go-lint (push) Has been skipped
CI / python-lint (push) Has been skipped
CI / nodejs-lint (push) Has been skipped
CI / nodejs-build (push) Has been skipped
CI / test-go (push) Has been skipped
Regression: Der v3-Agent-Pfad baute eine parallele MC-Pipeline (_load_impressum_mcs / _load_cookie_mcs, Roh-SELECT) und lief damit an allen Schutzmechanismen der Engine vorbei → GOV/Branchen-MCs als HIGH bei OEM/Zulieferer, fremde MCs (Bestellbestätigung), und action=check_question (Fragen statt Maßnahmen im Frontend). - Agent delegiert MC-Laden an rag_document_checker._load_controls (P72-Scope, check_type='text', fits_doc_type/scope_requires). - Subtraktives Sektor-Gate (SECTOR_PREFIXES) + Themen-Gate am Agent-Rand. - action = konkrete Maßnahme (Imperativ) statt check_question. - rag_document_checker: from __future__ import annotations (3.9-Import). - mcs: Name-Pattern erkennt "Aktiengesellschaft" (OEM-Impressums). - Tote GT-/Semantic-/Routes-Tests wiederbelebt (v3-Mismatch + agent.cascade-Patch-Target). Alle 72 Specialist-Tests grün. Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
70 lines
2.4 KiB
Python
70 lines
2.4 KiB
Python
"""Tests für Cookie-Policy-Agent v3 — Delegation an die Main-Tool-Engine,
|
|
Sektor-Filter und Maßnahmen statt Fragen."""
|
|
|
|
from __future__ import annotations
|
|
|
|
import asyncio
|
|
|
|
from compliance.services.specialist_agents.cookie_policy import v3_engine
|
|
from compliance.services.specialist_agents.cookie_policy.agent import (
|
|
_build_measure,
|
|
)
|
|
|
|
|
|
def _run(coro):
|
|
return asyncio.get_event_loop().run_until_complete(coro)
|
|
|
|
|
|
def test_build_measure_is_imperative_not_question():
|
|
m = _build_measure("Speicherdauer der Cookies", "TDDDG § 25")
|
|
assert "?" not in m
|
|
assert "ergänzen" in m.lower()
|
|
assert "Rechtsgrundlage" in m
|
|
|
|
|
|
def test_build_measure_handles_empty_label():
|
|
m = _build_measure("", "")
|
|
assert "?" not in m
|
|
assert m.strip() != ""
|
|
|
|
|
|
def test_cookie_v3_delegates_and_sector_filters(monkeypatch):
|
|
"""run_v3_pipeline lädt über die Main-Tool-Engine (cookie) und das
|
|
Sektor-Gate entfernt GOV-MCs out-of-scope."""
|
|
async def _fake_load(doc_type, db_url, limit, business_scope=None):
|
|
assert doc_type == "cookie"
|
|
return [
|
|
{"control_id": "COOKIE-1-A1", "title": "Cookie-Kategorien",
|
|
"regulation": "TDDDG", "article": "§ 25", "severity": "HIGH",
|
|
"check_question": "Kategorien genannt?",
|
|
"pass_criteria": '["Cookie Kategorien essentiell"]',
|
|
"fail_criteria": "[]"},
|
|
{"control_id": "GOV-9-A1", "title": "Behörden-Cookie",
|
|
"regulation": "X", "article": "", "severity": "HIGH",
|
|
"check_question": "Behörde?",
|
|
"pass_criteria": '["Behörde Aufsicht"]',
|
|
"fail_criteria": "[]"},
|
|
]
|
|
monkeypatch.setattr(
|
|
"compliance.services.rag_document_checker._load_controls",
|
|
_fake_load,
|
|
)
|
|
|
|
async def _no_match(*a, **kw):
|
|
return set()
|
|
monkeypatch.setattr(
|
|
"compliance.services.mc_embedding_matcher.embedding_match",
|
|
_no_match, raising=False,
|
|
)
|
|
|
|
text = ("Diese Website verwendet Cookies. Cookie-Kategorien: "
|
|
"essentiell, funktional. Speicherdauer und Zweck beschrieben. "
|
|
) * 4 # > 100 Zeichen
|
|
results, telem = _run(
|
|
v3_engine.run_v3_pipeline(text, business_scope=set()),
|
|
)
|
|
cids = {r["control_id"] for r in results}
|
|
assert "GOV-9-A1" not in cids # Sektor out-of-scope entfernt
|
|
assert "COOKIE-1-A1" in cids # cookie-MC bleibt
|
|
assert telem["sector_dropped"] == 1
|