Files
web-page-backend/saju-lab/tests/test_monthly_flow.py
gahusb 030367da6c feat(saju-lab): monthly_flow.py — 12개월 운세 흐름 (4 tests)
월간(月干)과 월지(月支)의 일간 관계를 이용한 12개월 운세 점수 계산:
- 월간 상생(生) 관계: +5~10점
- 월간 상극(剋) 관계: -8점
- 월지 육합(六合) 관계: +10점
- 월지 육충(六衝) 관계: -12점
- 월지 상생/상극: ±4점

점수 범위 0~100, 5단계 레이블 (정체/도전/변동/안정/성장)
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-26 08:02:35 +09:00

39 lines
1.2 KiB
Python

import pytest
from app.calculator.core import calculate_saju
from app.calculator.monthly_flow import calculate_monthly_flow
def test_returns_12_entries():
saju = calculate_saju(1990, 5, 15, 14, "male")
flow = calculate_monthly_flow(saju, 2026)
assert len(flow) == 12
def test_entries_have_required_keys():
saju = calculate_saju(1990, 5, 15, 14, "male")
flow = calculate_monthly_flow(saju, 2026)
for i, entry in enumerate(flow):
assert entry["month"] == i + 1
for k in ("stem", "branch", "score", "label"):
assert k in entry, f"month {i+1} missing {k}"
assert 0 <= entry["score"] <= 100
def test_labels_are_valid():
saju = calculate_saju(1990, 5, 15, 14, "male")
flow = calculate_monthly_flow(saju, 2026)
valid_labels = {"변동", "성장", "안정", "도전", "정체"}
for entry in flow:
assert entry["label"] in valid_labels
def test_different_sajus_different_flows():
s1 = calculate_saju(1990, 5, 15, 14, "male")
s2 = calculate_saju(1985, 1, 1, 0, "female")
f1 = calculate_monthly_flow(s1, 2026)
f2 = calculate_monthly_flow(s2, 2026)
scores_1 = [e["score"] for e in f1]
scores_2 = [e["score"] for e in f2]
assert scores_1 != scores_2