구현 검증
목적
프로젝트에 등록된 모든 verify-* 스킬을 순차적으로 실행하여 통합 검증을 수행합니다:
- •각 스킬의 Workflow에 정의된 검사를 실행
- •각 스킬의 Exceptions를 참조하여 false positive 방지
- •발견된 이슈에 대해 수정 방법을 제시
- •사용자 승인 후 수정 적용 및 재검증
실행 시점
- •새로운 기능을 구현한 후
- •Pull Request를 생성하기 전
- •코드 리뷰 중
- •코드베이스 규칙 준수 여부를 감사할 때
실행 대상 스킬
이 스킬이 순차 실행하는 검증 스킬 목록입니다. /manage-skills가 스킬을 생성/삭제할 때 이 목록을 자동 업데이트합니다.
| # | 스킬 | 설명 |
|---|---|---|
| 1 | verify-kb-indexing | KB 비동기 인덱싱 파이프라인 검증 |
| 2 | verify-flyway-migrations | Flyway DB 마이그레이션 일관성 검증 |
| 3 | verify-frontend-ui | 프론트엔드 UI 컴포넌트 품질 검증 |
| 4 | verify-rag-pipeline | RAG 파이프라인 (답변 작성 + 분석 + 다운로드) 검증 |
| 5 | verify-inquiry-ui | 문의 상세 페이지 UI 컴포넌트 검증 |
워크플로우
Step 1: 소개
위의 실행 대상 스킬 섹션에 나열된 스킬을 확인합니다.
선택적 인수가 제공된 경우, 해당 스킬만 필터링합니다.
등록된 스킬이 0개인 경우:
## 구현 검증 검증 스킬이 없습니다. `/manage-skills`를 실행하여 프로젝트에 맞는 검증 스킬을 생성하세요.
이 경우 워크플로우를 종료합니다.
등록된 스킬이 1개 이상인 경우:
실행 대상 스킬 테이블의 내용을 표시합니다:
## 구현 검증 다음 검증 스킬을 순차 실행합니다: | # | 스킬 | 설명 | |---|------|------| | 1 | verify-<name1> | <description1> | | 2 | verify-<name2> | <description2> | 검증 시작...
Step 2: 순차 실행
실행 대상 스킬 테이블에 나열된 각 스킬에 대해 다음을 수행합니다:
2a. 스킬 SKILL.md 읽기
해당 스킬의 .claude/skills/verify-<name>/SKILL.md를 읽고 다음 섹션을 파싱합니다:
- •Workflow — 실행할 검사 단계와 탐지 명령어
- •Exceptions — 위반이 아닌 것으로 간주되는 패턴
- •Related Files — 검사 대상 파일 목록
2b. 검사 실행
Workflow 섹션에 정의된 각 검사를 순서대로 실행합니다:
- •검사에 명시된 도구(Grep, Glob, Read, Bash)를 사용하여 패턴 탐지
- •탐지된 결과를 해당 스킬의 PASS/FAIL 기준에 대조
- •Exceptions 섹션에 해당하는 패턴은 면제 처리
- •FAIL인 경우 이슈를 기록:
- •파일 경로 및 라인 번호
- •문제 설명
- •수정 권장 사항 (코드 예시 포함)
2c. 스킬별 결과 기록
각 스킬 실행 완료 후 진행 상황을 표시합니다:
### verify-<name> 검증 완료 - 검사 항목: N개 - 통과: X개 - 이슈: Y개 - 면제: Z개 [다음 스킬로 이동...]
Step 3: 통합 보고서
모든 스킬 실행 완료 후, 결과를 하나의 보고서로 통합합니다:
## 구현 검증 보고서 ### 요약 | 검증 스킬 | 상태 | 이슈 수 | 상세 | |-----------|------|---------|------| | verify-<name1> | PASS / X개 이슈 | N | 상세... | | verify-<name2> | PASS / X개 이슈 | N | 상세... | **발견된 총 이슈: X개**
모든 검증 통과 시:
모든 검증을 통과했습니다! 구현이 프로젝트의 모든 규칙을 준수합니다: - verify-<name1>: <통과 내용 요약> - verify-<name2>: <통과 내용 요약> 코드 리뷰 준비가 완료되었습니다.
이슈 발견 시:
각 이슈를 파일 경로, 문제 설명, 수정 권장 사항과 함께 나열합니다:
### 발견된 이슈 | # | 스킬 | 파일 | 문제 | 수정 방법 | |---|------|------|------|-----------| | 1 | verify-<name1> | `path/to/file.ts:42` | 문제 설명 | 수정 코드 예시 | | 2 | verify-<name2> | `path/to/file.tsx:15` | 문제 설명 | 수정 코드 예시 |
Step 4: 사용자 액션 확인
이슈가 발견된 경우 AskUserQuestion을 사용하여 사용자에게 확인합니다:
--- ### 수정 옵션 **X개 이슈가 발견되었습니다. 어떻게 진행할까요?** 1. **전체 수정** - 모든 권장 수정사항을 자동으로 적용 2. **개별 수정** - 각 수정사항을 하나씩 검토 후 적용 3. **건너뛰기** - 변경 없이 종료
Step 5: 수정 적용
사용자 선택에 따라 수정을 적용합니다.
"전체 수정" 선택 시:
모든 수정을 순서대로 적용하며 진행 상황을 표시합니다:
## 수정 적용 중... - [1/X] verify-<name1>: `path/to/file.ts` 수정 완료 - [2/X] verify-<name2>: `path/to/file.tsx` 수정 완료 X개 수정 완료.
"개별 수정" 선택 시:
각 이슈마다 수정 내용을 보여주고 AskUserQuestion으로 승인 여부를 확인합니다.
Step 6: 수정 후 재검증
수정이 적용된 경우, 이슈가 있었던 스킬만 다시 실행하여 Before/After를 비교합니다:
## 수정 후 재검증 이슈가 있었던 스킬을 다시 실행합니다... | 검증 스킬 | 수정 전 | 수정 후 | |-----------|---------|---------| | verify-<name1> | X개 이슈 | PASS | | verify-<name2> | Y개 이슈 | PASS | 모든 검증을 통과했습니다!
여전히 이슈가 남은 경우:
### 잔여 이슈 | # | 스킬 | 파일 | 문제 | |---|------|------|------| | 1 | verify-<name> | `path/to/file.ts:42` | 자동 수정 불가 — 수동 확인 필요 | 수동으로 해결한 후 `/verify-implementation`을 다시 실행하세요.
예외사항
다음은 문제가 아닙니다:
- •등록된 스킬이 없는 프로젝트 — 오류가 아닌 안내 메시지를 표시하고 종료
- •스킬의 자체적 예외 — 각 verify 스킬의 Exceptions 섹션에 정의된 패턴은 이슈로 보고하지 않음
- •verify-implementation 자체 — 실행 대상 스킬 목록에 자기 자신을 포함하지 않음
- •manage-skills —
verify-로 시작하지 않으므로 실행 대상에 포함되지 않음
Related Files
| File | Purpose |
|---|---|
.claude/skills/manage-skills/SKILL.md | 스킬 유지보수 (이 파일의 실행 대상 스킬 목록을 관리) |
CLAUDE.md | 프로젝트 지침 |