Files
Hyungi Ahn 99672292d3 fix(policy): use container-compatible imports (drop app. prefix)
프로덕션 컨테이너는 /app 을 cwd 로 실행하고 import 는 `from api...`,
`from core...`, `from workers...` 처럼 무접두 스타일을 사용한다.
PR-A 내부 import 가 `from app.policy...`, `from app.ai.envelope` 로
되어 있어서 컨테이너에서 ModuleNotFoundError 발생.

변경:
- app/policy/*.py: `from app.policy.X` → `from policy.X`
- app/services/prompt_versions.py: lazy import 도 `from policy.prompt_render`
- app/ai/envelope.py: 영향 없음 (내부 import 없음)
- tests/policy/*.py: 모두 `from policy.X` / `from ai.envelope` 로 통일
- tests/policy/conftest.py: 로컬 pytest 용 sys.path.insert(app/) 추가
  (MacBook 에서 repo-root 기준 실행 시 app/ 를 package root 로 취급)

CI: pytest tests/policy/ -q → 98 passed (로컬, 동일 결과)
프로덕션: docker exec fastapi python -c "from policy.loader import load_policy" → OK

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-04-24 09:42:24 +09:00

48 lines
1.2 KiB
Python

"""Policy 테스트 fixture.
실제 repo root 의 domain_policy.yaml 을 그대로 로드. 테스트가 캐시를 쓰지 않도록
각 테스트 시작 시 lru_cache 클리어.
Import path: 프로덕션 컨테이너 (/app cwd) 와 동일하게 무접두 스타일 사용
(`from policy.loader` 등). 로컬 pytest 는 아래 sys.path 추가로 app/ 를 root 처리.
"""
from __future__ import annotations
import sys
from pathlib import Path
REPO_ROOT = Path(__file__).resolve().parent.parent.parent
APP_DIR = REPO_ROOT / "app"
if str(APP_DIR) not in sys.path:
sys.path.insert(0, str(APP_DIR))
import pytest
from policy import loader as policy_loader
from policy import prompt_render
DEFAULT_YAML = REPO_ROOT / "domain_policy.yaml"
@pytest.fixture(autouse=True)
def _clear_policy_cache():
"""매 테스트마다 loader + prompt_render 캐시 초기화."""
policy_loader.clear_cache()
prompt_render.clear_cache()
yield
policy_loader.clear_cache()
prompt_render.clear_cache()
@pytest.fixture
def policy():
"""기본 domain_policy.yaml 로드한 DomainPolicy 인스턴스."""
return policy_loader.load_policy(str(DEFAULT_YAML))
@pytest.fixture
def policy_yaml_path() -> str:
return str(DEFAULT_YAML)