Files
QuantEngineByItz/tools/test_api_components.py
T
kjh2064 4c8c879302 WBS-9 진행: API 에러 수정 및 DB 스키마 정규화
- snapshot_admin_store_v1.py: summarize_workspace에서 account_snapshot의 captured_at 사용 (updated_at 대신)
- account_snapshot 테이블: 올바른 스키마 재정의 (ordinal PK, row_json, 핵심필드, updated_at)
- settings 테이블: 올바른 스키마 재정의 (ordinal PK, key, value_json, note, updated_at)
- initialize_snapshot_admin_db.py: XLSX에서 settings, account_snapshot을 올바른 스키마로 로드
- load_from_xlsx_correct.py: account_snapshot을 특별 처리해서 스키마 보존
- /api/settings/save: 정상 작동 (200 응답)
- build_ui_state: load_collection_dashboard_state 예외 처리 추가 (진행 중)

데이터 현황:
- kis_data_collection.db: 1 테이블 (data_feed), 25행
- snapshot_admin.db: 27 테이블, 7,501행
  * settings: 32행 (올바른 스키마)
  * account_snapshot: 44행 (올바른 스키마)

남은 작업:
- /api/state 크래시 원인 진단 및 수정
- /api/export 데이터 검증
- 웹 UI 개선 (백오피스 수준)
- T+20 모니터링 활성화
- CI/CD 백업 기능

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
2026-06-23 01:21:30 +09:00

63 lines
1.4 KiB
Python

#!/usr/bin/env python3
"""
API 핸들러의 각 컴포넌트 테스트
"""
import sys
sys.path.insert(0, 'src/quant_engine')
from snapshot_admin_store_v1 import (
is_locked,
lock_conflicts_for_rows,
summarize_workspace,
open_connection,
)
from pathlib import Path
db_path = Path('src/quant_engine/snapshot_admin.db')
print("="*80)
print("API 컴포넌트 테스트")
print("="*80)
# 1. is_locked 테스트
print("\n[1] is_locked 테스트")
try:
locked = is_locked(db_path, "settings")
print(f" [OK] is_locked result: {locked}")
except Exception as e:
print(f" [ERROR] {e}")
# 2. lock_conflicts_for_rows 테스트
print("\n[2] lock_conflicts_for_rows 테스트")
try:
test_rows = [
{
"ordinal": 5,
"key": "total_asset_krw",
"value": "450000000",
"note": "test"
}
]
conflicts = lock_conflicts_for_rows(db_path, "settings", test_rows)
print(f" [OK] conflicts: {conflicts}")
except Exception as e:
print(f" [ERROR] {e}")
# 3. summarize_workspace 테스트
print("\n[3] summarize_workspace 테스트")
try:
import time
start = time.time()
summary = summarize_workspace(db_path)
elapsed = time.time() - start
print(f" [OK] summarize_workspace completed in {elapsed:.2f}s")
print(f" Keys: {list(summary.keys())[:5]}")
except Exception as e:
print(f" [ERROR] {e}")
import traceback
traceback.print_exc()
print("\n[완료]")