Files
sam-docs/dev/dev_plans/qms-checklist-template-plan.md

574 lines
24 KiB
Markdown

# QMS 점검표 템플릿 관리 기능 구현 계획
> **작성일**: 2026-03-11
> **목적**: QMS 설정 모달 내 점검표 CRUD + 파일 업로드를 Mock → 실제 API 연동으로 전환
> **기준 커밋**: `e9ac2470` (프론트 Mock 구현 완료)
> **관련 문서**: `docs/dev/dev_plans/qms-api-integration-plan.md` (상위 QMS 계획)
> **상태**: ✅ 구현 완료
---
## 📍 현재 진행 상태
| 항목 | 내용 |
|------|------|
| **마지막 완료 작업** | Phase 3: 프론트엔드 API 연동 + 버전 UI 제거 |
| **다음 작업** | 검증 (마이그레이션 실행 + 동작 확인) |
| **진행률** | 12/12 (100%) |
| **마지막 업데이트** | 2026-03-11 |
---
## 1. 개요
### 1.1 배경
QMS 페이지(`/quality/qms`)의 설정 모달에 점검표 관리 탭이 커밋 `e9ac2470`으로 추가되었다.
현재 `USE_MOCK = true` 상태로 프론트 UI만 동작하며, 백엔드 API 연동이 필요하다.
추가로 프론트엔드 개선이 필요:
1. **점검표 항목 섹션 기본 전체 펼침**: `expandAllCategories` 설정값과 `Day1ChecklistPanel` 연동
2. **점검표 항목별 파일 업로드**: `Day1DocumentSection`의 파일 업로드 실제 서버 전송
### 1.2 버전 관리 정책
```
┌─────────────────────────────────────────────────────────────────┐
│ ⚠️ 버전 관리 제외 │
├─────────────────────────────────────────────────────────────────┤
│ - 이번 구현에서 버전 관리는 하지 않음 │
│ - 버전은 항상 V1 고정 │
│ - 저장 시 토스트: "저장 완료" (버전 번호 없음) │
│ - VersionSelectBox, 버전 복원 기능 제거 │
│ - checklist_template_versions 테이블 생성하지 않음 │
└─────────────────────────────────────────────────────────────────┘
```
### 1.3 현재 구현 상태 (커밋 e9ac2470 기준)
| 파일 | 역할 | 상태 |
|------|------|------|
| `ChecklistTemplateEditor.tsx` (605줄) | 카테고리/항목 CRUD, 순서변경, 인라인 편집, 버전 셀렉트박스 | ✅ UI 완성 (Mock) → ⚠️ 버전 UI 제거 필요 |
| `useChecklistTemplate.ts` (218줄) | 상태관리, CRUD 로직, 저장/초기화/복원 | ✅ Mock 로직 완성 → ⚠️ 버전/복원 로직 제거 필요 |
| `AuditSettingsPanel.tsx` (314줄) | 화면설정 + 점검표관리 2탭 구조 | ✅ 탭 구조 완성 |
| `Day1DocumentSection.tsx` (+155줄) | 파일 업로드 드래그&드롭 + 검증 | ✅ UI 완성 (Mock) |
| `types.ts` (+19줄) | ChecklistTemplateVersion, ChecklistTemplate 타입 | ✅ → ⚠️ 버전 타입 제거 필요 |
| `page.tsx` (+24줄) | useChecklistTemplate 훅 연결 | ✅ → ⚠️ 버전 관련 props 제거 필요 |
### 1.4 미구현 항목 (이번 계획 범위)
| # | 항목 | 설명 |
|---|------|------|
| 1 | 백엔드 테이블 | `checklist_templates` + `qms_documents` 2개 (categories JSON 포함) |
| 2 | 백엔드 API | GET + PUT + 파일 업로드 엔드포인트 |
| 3 | Server Actions | `quality/qms/actions.ts` 신규 생성 |
| 4 | useChecklistTemplate → API 전환 | `USE_MOCK = false`, 실제 API 호출 |
| 5 | 파일 업로드 서버 전송 | `Day1DocumentSection.onFileUpload` 실제 구현 |
| 6 | 점검표 편집 → 심사화면 반영 | `editCategories` 저장 후 `categories` 갱신 연결 |
| 7 | `expandAllCategories` 설정 연동 | 설정값 변경 시 Day1ChecklistPanel 반영 |
| 8 | 프론트 버전 UI 제거 | VersionSelectBox 제거, 버전 관련 props/타입 정리 |
### 1.5 기준 원칙
```
┌─────────────────────────────────────────────────────────────────┐
│ 🎯 핵심 원칙 │
├─────────────────────────────────────────────────────────────────┤
│ - Service-First: 비즈니스 로직은 Service에 구현 │
│ - Multi-tenancy: BelongsToTenant 필수 │
│ - options JSON: 점검표 카테고리 데이터는 JSON 컬럼에 저장 │
│ - 파일 업로드: 기존 files 테이블 + tenant disk 활용 │
│ - Mock→API: USE_MOCK 플래그 OFF로 점진적 전환 │
│ - 단순 저장: 버전 관리 없이 현재 상태만 덮어쓰기 │
└─────────────────────────────────────────────────────────────────┘
```
### 1.6 변경 승인 정책
| 분류 | 예시 | 승인 |
|------|------|------|
| ✅ 즉시 가능 | 프론트 props 추가, 타입 확장, actions.ts 생성, 버전 UI 제거 | 불필요 |
| ⚠️ 컨펌 필요 | 마이그레이션 생성, 새 서비스/컨트롤러, API 엔드포인트 | **필수** |
| 🔴 금지 | 기존 테이블 구조 변경, 기존 API 동작 변경 | 별도 협의 |
### 1.7 준수 규칙
- `docs/dev/standards/api-rules.md` — API 개발 규칙
- `docs/dev/standards/quality-checklist.md` — 품질 체크리스트
- `docs/dev/guides/file-storage-guide.md` — 파일 업로드 가이드
- `docs/dev/standards/options-column-policy.md` — JSON options 정책
---
## 2. 대상 범위
### 2.1 Phase 1: 백엔드 — 테이블 설계 + 마이그레이션 (api/)
| # | 작업 항목 | 상태 | 비고 |
|---|----------|:----:|------|
| 1.1 | `checklist_templates` 테이블 마이그레이션 | ⏳ | categories JSON 포함 + 초기 데이터 시딩 |
| 1.2 | Model 생성 (ChecklistTemplate) | ⏳ | BelongsToTenant |
### 2.2 Phase 2: 백엔드 — Service + Controller + API (api/)
| # | 작업 항목 | 상태 | 비고 |
|---|----------|:----:|------|
| 2.1 | `ChecklistTemplateService` 생성 | ⏳ | 조회 + 저장 + 항목삭제 시 파일 처리 |
| 2.2 | `ChecklistTemplateController` 생성 | ⏳ | |
| 2.3 | `SaveChecklistTemplateRequest` FormRequest 생성 | ⏳ | 중첩 JSON 검증 규칙 포함 |
| 2.4 | 파일 업로드 API (기존 files 시스템 polymorphic 활용) | ⏳ | document_type + field_key + 서버 측 검증 |
| 2.5 | 라우트 등록 | ⏳ | |
| 2.6 | Swagger 문서 | ⏳ | |
### 2.3 Phase 3: 프론트엔드 — API 연동 + 버전 UI 제거 (react/)
| # | 작업 항목 | 상태 | 비고 |
|---|----------|:----:|------|
| 3.1 | 버전 관련 UI/타입/로직 제거 | ⏳ | VersionSelectBox, 버전 props 등 |
| 3.2 | `quality/qms/actions.ts` Server Actions 생성 | ⏳ | |
| 3.3 | `useChecklistTemplate.ts` API 전환 | ⏳ | USE_MOCK = false, isLoading/error 상태 추가 |
| 3.4 | 파일 업로드 실제 연동 | ⏳ | Day1DocumentSection |
| 3.5 | `expandAllCategories` 설정 ↔ Day1ChecklistPanel 연동 | ⏳ | props 전달 |
---
## 3. 작업 절차
### 3.1 단계별 절차
```
Phase 1: 백엔드 테이블 (api/)
├── 1.1 checklist_templates 마이그레이션 (categories JSON 포함)
├── 1.2 qms_documents 마이그레이션 (파일-항목 연결)
├── 1.3 ChecklistTemplate 모델 생성
└── 1.4 QmsDocument 모델 생성
Phase 2: 백엔드 API (api/)
├── 2.1 ChecklistTemplateService (getOrCreate + 저장 + 항목삭제 시 파일 처리)
├── 2.2 ChecklistTemplateController + SaveChecklistTemplateRequest
├── 2.3 QmsDocumentService + QmsDocumentController (서버 측 파일 검증)
├── 2.4 라우트 등록 (/api/v1/quality/checklist-templates/*, /api/v1/quality/qms-documents/*)
└── 2.5 Swagger 문서
Phase 3: 프론트엔드 (react/)
├── 3.1 버전 관련 UI/타입/로직 제거
├── 3.2 actions.ts 생성 (Server Actions)
├── 3.3 useChecklistTemplate → API 전환 (isLoading/error 상태 추가)
├── 3.4 파일 업로드 연동
└── 3.5 expandAllCategories 설정 연동
```
---
## 4. 상세 설계
### 4.1 테이블 설계
#### `checklist_templates` (점검표 템플릿)
```sql
CREATE TABLE checklist_templates (
id BIGINT PRIMARY KEY AUTO_INCREMENT,
tenant_id BIGINT NOT NULL,
name VARCHAR(255) NOT NULL DEFAULT '품질인정심사 점검표',
type VARCHAR(50) NOT NULL DEFAULT 'day1_audit', -- 심사 유형 구분
categories JSON NOT NULL, -- [{ id, title, subItems: [{ id, name }] }]
options JSON NULL, -- 확장 속성
created_by BIGINT NULL,
updated_by BIGINT NULL,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
deleted_at TIMESTAMP NULL,
FOREIGN KEY (tenant_id) REFERENCES tenants(id),
FOREIGN KEY (created_by) REFERENCES users(id),
FOREIGN KEY (updated_by) REFERENCES users(id),
INDEX idx_tenant_type (tenant_id, type),
UNIQUE KEY unique_tenant_type (tenant_id, type)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
```
> ⚠️ UNIQUE KEY에 `deleted_at` 미포함: MySQL에서 NULL은 UNIQUE 제약에서 제외되므로,
> `deleted_at` 포함 시 active 레코드 중복 방지 불가. soft delete는 글로벌 스코프로 처리.
#### 파일-항목 연결 (files 테이블 polymorphic 활용)
```
기존 files 테이블의 컬럼을 활용하여 점검항목별 파일을 연결:
- document_type = 'checklist_template'
- document_id = checklist_templates.id
- field_key = sub_item_id (e.g. "sub-1-1")
```
> 별도 `qms_documents` 테이블 불필요 — files 테이블의 `document_type` + `document_id` + `field_key` 조합으로 연결.
> 항목 삭제 시: Service에서 삭제된 sub_item_id의 파일을 soft delete.
> 문서 교체 시: 기존 파일 즉시 삭제 (hard delete).
**설계 결정 사항**:
- `checklist_templates` 1개 테이블만 신규 생성
- `categories`는 **JSON 컬럼**에 저장 — 카테고리/하위항목을 별도 테이블로 분리하지 않음
- 이유: 점검표는 항상 전체 로드, 개별 카테고리 쿼리 불필요
- 파일 연결: files 테이블 polymorphic (`document_type` + `document_id` + `field_key`)
- `type` 컬럼으로 향후 다른 심사 유형(day2 등) 확장 가능
- 저장 = `categories` JSON 덮어쓰기 (PUT)
- `updated_by`로 마지막 수정자 추적
- 항목 삭제 시: files soft delete → 휴지통에서 최종 삭제
- 문서 교체 시: 기존 파일 즉시 삭제 (hard delete)
### 4.2 API 엔드포인트
**점검표 CRUD**:
| Method | Path | 설명 |
|--------|------|------|
| `GET` | `/api/v1/quality/checklist-templates?type=day1_audit` | 템플릿 조회 |
| `PUT` | `/api/v1/quality/checklist-templates/{id}` | 템플릿 저장 (덮어쓰기) |
**파일 업로드** (기존 파일 시스템 활용):
| Method | Path | 설명 |
|--------|------|------|
| `POST` | `/api/v1/quality/qms-documents` | 점검항목별 문서 업로드 |
| `GET` | `/api/v1/quality/qms-documents?sub_item_id={id}` | 항목별 문서 조회 |
| `DELETE` | `/api/v1/quality/qms-documents/{id}` | 문서 삭제 |
### 4.3 API 요청/응답 구조
#### GET 템플릿 조회
```json
// Response
{
"success": true,
"data": {
"id": 1,
"name": "품질인정심사 점검표",
"type": "day1_audit",
"categories": [
{
"id": "cat-1",
"title": "1. 품질경영 일반",
"subItems": [
{ "id": "sub-1-1", "name": "품질방침 및 품질목표 수립" },
{ "id": "sub-1-2", "name": "조직도 및 업무분장" }
]
}
],
"updated_at": "2026-03-10T15:30:00",
"updated_by_name": "홍길동"
}
}
```
#### PUT 템플릿 저장
```json
// Request
{
"categories": [
{
"id": "cat-1",
"title": "1. 품질경영 일반",
"subItems": [
{ "id": "sub-1-1", "name": "품질방침 및 품질목표 수립" },
{ "id": "sub-1-2", "name": "조직도 및 업무분장" }
]
}
]
}
// Response
{
"success": true,
"message": "저장 완료"
}
```
### 4.4 FormRequest 검증 규칙
#### `SaveChecklistTemplateRequest`
```php
public function rules(): array
{
return [
'categories' => 'required|array|min:1',
'categories.*.id' => 'required|string|max:50',
'categories.*.title' => 'required|string|max:255',
'categories.*.subItems' => 'required|array',
'categories.*.subItems.*.id' => 'required|string|max:50',
'categories.*.subItems.*.name' => 'required|string|max:255',
];
}
```
> XSS 방지: `title`, `name` 필드에 HTML 태그 삽입 방지 (`strip_tags` 또는 커스텀 Rule)
#### `UploadQmsDocumentRequest`
```php
public function rules(): array
{
return [
'template_id' => 'required|integer|exists:checklist_templates,id',
'sub_item_id' => 'required|string|max:50',
'file' => 'required|file|max:20480|mimes:pdf,xlsx,xls,docx,doc,hwp',
];
}
```
> 서버 측 파일 타입 + 크기 검증 필수 (프론트 검증만으로 불충분)
### 4.5 항목 삭제 시 파일 처리 정책
```
┌─────────────────────────────────────────────────────────────────┐
│ 📄 항목 삭제 시 파일 처리 │
├─────────────────────────────────────────────────────────────────┤
│ 1. 점검표 저장(PUT) 시 Service에서 이전 categories와 비교 │
│ 2. 삭제된 sub_item_id 목록 추출 │
│ 3. 해당 sub_item_id의 qms_documents를 soft delete │
│ 4. 실제 파일은 삭제하지 않음 (복구 가능성 유지) │
│ 5. 향후 정리: 배치 작업으로 soft deleted 파일 물리 삭제 가능 │
└─────────────────────────────────────────────────────────────────┘
```
### 4.6 프론트엔드 변경 사항
#### 버전 관련 제거 대상
```
제거 대상:
1. ChecklistTemplateEditor.tsx
- VersionSelectBox 컴포넌트 전체 제거
- versions, currentVersion, onRestoreVersion props 제거
2. useChecklistTemplate.ts
- versions, currentVersion 상태 제거
- restoreVersion() 함수 제거
- MOCK_VERSIONS 데이터 제거
- 저장 토스트: toast.success('저장 완료')
3. AuditSettingsPanel.tsx
- ChecklistManagementProps에서 versions, currentVersion, onRestoreVersion 제거
4. types.ts
- ChecklistTemplateVersion 인터페이스 제거
- ChecklistTemplate에서 currentVersion, versions 제거
5. page.tsx
- checklistManagement 객체에서 versions, currentVersion, onRestoreVersion 제거
```
#### `actions.ts` (신규)
```typescript
// Server Actions 목록
export async function getChecklistTemplate(type?: string)
export async function saveChecklistTemplate(templateId: number, data: { categories })
export async function uploadQmsDocument(subItemId: string, file: File)
export async function getQmsDocuments(subItemId: string)
export async function deleteQmsDocument(documentId: number)
```
#### `useChecklistTemplate.ts` 변경 요약
```
변경 포인트:
1. USE_MOCK = false
2. 초기 로드: useEffect → getChecklistTemplate('day1_audit')
3. saveTemplate() → saveChecklistTemplate() API 호출
4. 토스트: toast.success('저장 완료')
5. 버전 관련 상태/로직 전부 제거
6. 저장 성공 후 categories 상태 갱신 → Day1ChecklistPanel 반영
7. isLoading, error 상태 추가 (API 전환 필수)
8. 에러 시 toast.error('저장 실패') + 에러 메시지 표시
9. 로딩 중 저장 버튼 비활성화
```
#### `Day1ChecklistPanel.tsx` 변경 요약
```
변경 포인트:
1. expandAllCategories prop 추가 (AuditDisplaySettings에서 전달)
2. useEffect로 expandAllCategories 변경 감지 → expandedCategories 업데이트
```
#### `Day1DocumentSection.tsx` 변경 요약
```
변경 포인트:
1. onFileUpload prop → 실제 uploadQmsDocument() 호출
2. 업로드 완료 후 문서 목록 갱신
```
### 4.7 초기 데이터 전략 (마이그레이션 시딩)
```
┌─────────────────────────────────────────────────────────────────┐
│ 🌱 마이그레이션 시딩 │
├─────────────────────────────────────────────────────────────────┤
│ - 마이그레이션 실행 시 기존 테넌트에 기본 템플릿 자동 생성 │
│ - 기본 categories: mockData.ts의 MOCK_DAY1_CATEGORIES 기반 │
│ - 새 테넌트 가입 시: TenantCreated 이벤트 또는 수동 생성 │
└─────────────────────────────────────────────────────────────────┘
```
---
## 5. 컨펌 대기 목록
| # | 항목 | 변경 내용 | 영향 범위 | 상태 |
|---|------|----------|----------|------|
| 1 | 테이블 설계 | `checklist_templates` + `qms_documents` 2개 신규 | api/ DB | ⚠️ 컨펌 필요 |
| 2 | API 엔드포인트 | 2개 (GET/PUT) + 파일 3개 (POST/GET/DELETE) | api/ 라우트 | ⚠️ 컨펌 필요 |
| 3 | 파일 연결 | `qms_documents` 전용 중간 테이블로 파일-항목 연결 관리 | api/ | ⚠️ 컨펌 필요 |
| 4 | 초기 데이터 | getOrCreate 패턴 (마이그레이션 시딩 없음) | api/ Service | ⚠️ 컨펌 필요 |
| 5 | 항목 삭제 시 | 삭제된 sub_item_id의 qms_documents soft delete | api/ Service | ⚠️ 컨펌 필요 |
---
## 6. 변경 이력
| 날짜 | 항목 | 변경 내용 | 파일 | 승인 |
|------|------|----------|------|------|
| 2026-03-11 | - | 문서 초안 작성 | - | - |
| 2026-03-11 | 설계 | 버전 관리 제거 (V1 고정, 단순 덮어쓰기) | 전체 | 사용자 요청 |
| 2026-03-11 | 설계 | 페르소나 분석 반영: UNIQUE KEY 수정, qms_documents 테이블 추가, FormRequest 검증 규칙, getOrCreate 패턴, 항목 삭제 시 파일 처리, 로딩/에러 상태 | 전체 | 분석 결과 |
---
## 7. 참고 문서
- **상위 QMS 계획**: `docs/dev/dev_plans/qms-api-integration-plan.md`
- **품질관리 기능**: `docs/features/quality-management/README.md`
- **파일 업로드 가이드**: `docs/dev/guides/file-storage-guide.md`
- **API 규칙**: `docs/dev/standards/api-rules.md`
- **options 정책**: `docs/dev/standards/options-column-policy.md`
- **품질 체크리스트**: `docs/dev/standards/quality-checklist.md`
### 7.1 관련 파일 경로
**프론트엔드 (react/)**:
```
src/app/[locale]/(protected)/quality/qms/
├── page.tsx # 메인 페이지
├── types.ts # 타입 정의
├── mockData.ts # Mock 데이터 (전환 후 삭제 대상)
├── actions.ts # ❌ 신규 생성 필요
├── components/
│ ├── AuditSettingsPanel.tsx # 설정 패널 (탭 2개)
│ ├── ChecklistTemplateEditor.tsx # 점검표 편집기 (버전 UI 제거 필요)
│ ├── Day1ChecklistPanel.tsx # 점검표 항목 표시
│ └── Day1DocumentSection.tsx # 문서 섹션 + 파일 업로드
└── hooks/
├── useDay1Audit.ts # 1일차 심사 로직
└── useChecklistTemplate.ts # 점검표 템플릿 관리 (Mock→API 전환)
```
**백엔드 (api/) — 신규 생성 대상**:
```
app/
├── Http/Controllers/Api/V1/
│ └── ChecklistTemplateController.php # 신규
├── Http/Requests/Quality/
│ └── SaveChecklistTemplateRequest.php # 신규 (중첩 JSON 검증)
├── Services/
│ └── ChecklistTemplateService.php # 신규 (조회 + 저장 + 파일 처리)
├── Models/Qualitys/
│ └── ChecklistTemplate.php # 신규 (기존 Quality 모델과 같은 위치)
database/migrations/
└── XXXX_create_checklist_templates_table.php # 신규 (시딩 포함)
```
---
## 8. 세션 및 메모리 관리 정책
### 8.1 세션 시작 시
```
1. 이 계획 문서 읽기
2. qms-api-integration-plan.md 참조 (아키텍처 결정사항)
3. 현재 진행 상태 확인 → 다음 작업 파악
```
### 8.2 작업 중 관리
```
- Phase/항목별 상태 업데이트 (⏳ → 🔄 → ✅)
- 변경 이력 섹션에 실시간 기록
- 컨펌 필요사항 → 컨펌 대기 목록에 추가
```
---
## 9. 검증 결과
> 작업 완료 후 이 섹션에 검증 결과 추가
### 9.1 테스트 케이스
| 시나리오 | 예상 결과 | 실제 결과 | 상태 |
|---------|----------|----------|------|
| 점검표 템플릿 조회 | categories JSON 반환 | | ⏳ |
| 카테고리 추가 → 저장 | "저장 완료" 토스트, DB 반영 | | ⏳ |
| 하위 항목 편집 → 저장 | 기존 ID 유지, 이름만 변경 | | ⏳ |
| 파일 업로드 (PDF 5MB) | 성공, files 테이블에 기록 | | ⏳ |
| 파일 업로드 (EXE) | 거부, 오류 메시지 표시 | | ⏳ |
| expandAllCategories ON | 모든 카테고리 펼침 | | ⏳ |
| expandAllCategories OFF | 모든 카테고리 접힘 | | ⏳ |
| 점검표 저장 후 심사화면 | 즉시 반영 (새로고침 불필요) | | ⏳ |
| 초기화(Reset) | 마지막 저장 상태로 복원 | | ⏳ |
| 빈 카테고리 저장 시도 | FormRequest 검증 실패, 오류 메시지 | | ⏳ |
| 카테고리 이름에 HTML 태그 | 태그 제거 또는 거부 | | ⏳ |
| 항목 삭제 후 저장 | 삭제된 항목의 qms_documents soft delete | | ⏳ |
| 새 테넌트 최초 조회 | getOrCreate로 기본 템플릿 자동 생성 | | ⏳ |
| 서버 측 파일 검증 (EXE 확장자) | 서버에서 거부 (mimes 검증) | | ⏳ |
| API 에러 시 프론트 처리 | 에러 토스트 + 로딩 해제 | | ⏳ |
### 9.2 성공 기준
| 기준 | 달성 | 비고 |
|------|------|------|
| USE_MOCK = false로 전환 완료 | ⏳ | |
| 점검표 CRUD 전체 동작 | ⏳ | |
| 저장 시 "저장 완료" 토스트 | ⏳ | 버전 번호 없음 |
| 파일 업로드/조회/삭제 동작 | ⏳ | |
| expandAllCategories 설정 연동 | ⏳ | |
| 점검표 편집 → 심사화면 즉시 반영 | ⏳ | |
| 버전 UI 완전 제거 | ⏳ | VersionSelectBox 등 |
---
## 10. 자기완결성 점검 결과
### 10.1 체크리스트 검증
| # | 검증 항목 | 상태 | 비고 |
|---|----------|:----:|------|
| 1 | 작업 목적이 명확한가? | ✅ | Mock → API 전환 + 버전 제거 |
| 2 | 성공 기준이 정의되어 있는가? | ✅ | 9.2 참조 |
| 3 | 작업 범위가 구체적인가? | ✅ | Phase 1~3, 10개 세부 항목 |
| 4 | 의존성이 명시되어 있는가? | ✅ | Phase 순서, 테이블→모델→서비스→컨트롤러 |
| 5 | 참고 파일 경로가 정확한가? | ✅ | 7.1 관련 파일 경로 |
| 6 | 단계별 절차가 실행 가능한가? | ✅ | SQL, API 스펙, 제거 대상 명시 |
| 7 | 검증 방법이 명시되어 있는가? | ✅ | 9.1 테스트 케이스 |
| 8 | 모호한 표현이 없는가? | ✅ | 구체적 파일명, 컬럼명, 엔드포인트 명시 |
### 10.2 새 세션 시뮬레이션 테스트
| 질문 | 답변 가능 | 참조 섹션 |
|------|:--------:|----------|
| Q1. 이 작업의 목적은 무엇인가? | ✅ | 1.1 배경 |
| Q2. 어디서부터 시작해야 하는가? | ✅ | 2.1 Phase 1 |
| Q3. 어떤 파일을 수정해야 하는가? | ✅ | 7.1 관련 파일 경로 |
| Q4. 작업 완료 확인 방법은? | ✅ | 9.1 테스트 케이스 |
| Q5. 막혔을 때 참고 문서는? | ✅ | 7. 참고 문서 |
---
*이 문서는 /plan 스킬로 생성되었습니다.*