peach-agent-team
SKILL.md
Peach Agent Team
Overview
PeachSolution 아키텍처에서 신규 기능 개발을 조율하는 통합 팀 스킬입니다.
기존 team-backend, team-ui, team-fullstack를 하나로 통합하며, 역할별 페르소나와 체크리스트를 이 문서 안에 포함합니다.
Modes
| mode | 용도 | 포함 역할 |
|---|---|---|
backend |
기존 UI에 API + Store 연결 | backend-dev, backend-qa, store-dev, frontend-qa |
ui |
Store 기반 UI만 구현 | ui-dev, frontend-qa |
fullstack |
DB 스키마 기반 전체 생성 | backend-dev, backend-qa, store-dev, ui-dev, frontend-qa |
Preconditions
- DB 스키마가 필요한 모드(
backend,fullstack)에서는api/db/schema/[도메인]/[테이블].sql이 존재해야 합니다. ui모드에서는front/src/modules/[모듈명]/store/[모듈명].store.ts가 존재해야 합니다.- Store가 없으면 먼저
peach-gen-store, UI가 없으면peach-gen-ui를 기준으로 생성합니다. - 기존 기능 수정 맥락에서 실행하는 경우
docs/기능별설명/{카테고리명}/{기능명}/가 있으면 개요 → 로직 → 명세 → TDD 순으로 먼저 읽고 컨텍스트를 주입합니다.
Inputs
/peach-agent-team [모듈명] mode=backend|ui|fullstack [옵션]
# 공통 옵션
# model=sonnet|opus|haiku (서브에이전트 모델 override, 기본값: sonnet)
# figma=[URL]
# ui=crud|page|two-depth|infinite-scroll|select-list
# file=Y
# excel=Y
# storeTdd=Y
Orchestration
0. 입력 검증
에이전트 팀 기능 활성화 확인
아래 명령으로 ~/.claude/settings.json에 에이전트 팀 플래그가 설정되어 있는지 확인합니다:
cat ~/.claude/settings.json | grep -i "CLAUDE_CODE_EXPERIMENTAL_AGENT_TEAMS"
설정이 없거나 "1"이 아니면 즉시 중단하고 다음 안내를 출력합니다:
⚠️ 에이전트 팀 기능이 비활성화되어 있습니다.
~/.claude/settings.json에 아래 내용을 추가한 후 Claude Code를 재시작하세요:
{
"env": {
"CLAUDE_CODE_EXPERIMENTAL_AGENT_TEAMS": "1"
}
}
설정 가이드: https://github.com/peachSolution/peach-harness/blob/main/docs/06-에이전트팀-설정.md
공식 문서: https://code.claude.com/docs/ko/agent-teams
mode와 모듈명이 모두 지정되어야 다음 단계로 진행합니다. 누락된 경우 반드시 개발자에게 질문합니다.
mode 미지정 시:
mode를 선택해주세요:
1. backend — 기존 UI에 API + Store 연결
2. ui — Store 기반 UI만 구현
3. fullstack — DB 스키마 기반 전체 생성
모듈명 미지정 시:
모듈명을 입력해주세요 (예: notice-board, product-manage):
model 옵션:
- 미지정: 기본값 sonnet으로 모든 서브에이전트 실행
- 지정 시: 모든 서브에이전트를 해당 모델로 override
- 허용 값: sonnet, opus, haiku
1. 환경 확인
# 스키마 / 타입 / 가이드 코드 확인
ls api/db/schema/
head -5 api/src/modules/test-data/dao/test-data.dao.ts
head -3 api/src/modules/test-data/controller/test-data.controller.ts
ls front/src/modules/test-data/
# DAO 라이브러리 감지
# from 'bunqldb' → 재할당 방식
# from 'sql-template-strings' → append 방식
2. 팀 구성 다이어그램
mode=backend
backend-dev ──→ backend-qa
│
└──→ store-dev ──→ frontend-qa
mode=ui
ui-dev ──→ frontend-qa
mode=fullstack
backend-dev ──→ backend-qa
│
└──→ store-dev ──→ ui-dev ──→ frontend-qa
3. 팀 생성 및 작업 등록
TeamCreate: team_name="[모듈명]-[mode]-team"
# mode=backend 작업 등록
TaskCreate:
1. "Backend API 개발" (owner: backend-dev)
2. "Backend QA 검증" (blockedBy: Task1, owner: backend-qa)
3. "Frontend Store 개발" (blockedBy: Task1, owner: store-dev)
4. "Frontend QA 검증" (blockedBy: Task3, owner: frontend-qa)
# mode=ui 작업 등록
TaskCreate:
1. "UI 컴포넌트 생성" (owner: ui-dev)
2. "Frontend QA 검증" (blockedBy: Task1, owner: frontend-qa)
# mode=fullstack 작업 등록
TaskCreate:
1. "Backend API 개발" (owner: backend-dev)
2. "Backend QA 검증" (blockedBy: Task1, owner: backend-qa)
3. "Frontend Store 개발" (blockedBy: Task1, owner: store-dev)
4. "Frontend UI 개발" (blockedBy: Task3, owner: ui-dev)
5. "Frontend QA 검증" (blockedBy: Task4, owner: frontend-qa)
4. 역할별 지시
각 역할의 전체 정의(페르소나, Bounded Autonomy, 워크플로우)는 references/에 있습니다.
서브에이전트 생성 시 해당 파일의 전체 내용을 프롬프트에 포함합니다.
model= 옵션이 지정된 경우, 각 에이전트 호출 시 model 파라미터로 전달하여 frontmatter 기본값을 override합니다.
| 역할 | 참조 파일 | 핵심 스킬 |
|---|---|---|
| backend-dev | references/backend-dev-agent.md | peach-gen-backend |
| backend-qa | references/backend-qa-agent.md | 검증 전용 (읽기전용, worktree) |
| store-dev | references/store-dev-agent.md | peach-gen-store |
| ui-dev | references/ui-dev-agent.md | peach-gen-ui + peach-gen-design |
| frontend-qa | references/frontend-qa-agent.md | 검증 전용 (읽기전용, worktree) |
backend-dev
peach-gen-backend기준으로 API 코드를 생성합니다.- Koa/Elysia 모드를 감지합니다.
- DAO 라이브러리(bunqldb/sql-template-strings)를 감지합니다.
- 완료 기준:
bun test,bun run lint:fixed,bun run build통과 - 산출물: API 파일 목록, 엔드포인트 스펙, 테스트 결과
- 상세:
references/backend-dev-agent.md참조
backend-qa
QA 체크리스트 (7항목):
type/,dao/,service/,controller/,test/파일 구조 존재- Service static 메서드 규칙 준수
- FK 제약조건 없음
bun test통과bun run lint:fixed통과bun run build성공- API 엔드포인트 스펙 일치
- 상세:
references/backend-qa-agent.md참조
store-dev
peach-gen-store기준으로 Pinia Store를 생성합니다.- Backend 타입과 인터페이스를 맞춥니다.
- 완료 기준:
bunx vue-tsc --noEmit - 상세:
references/store-dev-agent.md참조
ui-dev
peach-gen-ui, 필요 시peach-gen-design을 사용합니다.figma=[URL]가 있으면 FigmaRemote MCP를 로드하여 디자인을 분석합니다.- UI 패턴(
ui=)이 없으면 사용자에게 확인합니다. - 대상 프로젝트에
_common/components/가 존재하면 래퍼 컴포넌트를 우선 사용합니다. - 완료 기준:
bunx vue-tsc --noEmit,bun run lint:fix,bun run build - 상세:
references/ui-dev-agent.md참조
frontend-qa
QA 체크리스트 (8항목):
- 파일 구조 (pages/, modals/, store/, type/) 존재
- Composition API (
<script setup>) 패턴 준수 - Pinia Option API Store 패턴 준수
listAction,resetAction,listMovePage함수 구현- URL watch 패턴 적용 (
route → listParams,route → getList) bunx vue-tsc --noEmit통과bun run lint:fix통과bun run build성공 + AI Slop 디자인 패턴 없음
- 상세:
references/frontend-qa-agent.md참조
Ralph Loop (반복 검증 메커니즘)
QA 실패 시 단순 재시도가 아니라 Ralph Loop(Vercel Labs) 패턴으로 구조화된 피드백을 주입한다.
에스컬레이션 단계
| 반복 횟수 | 단계 | 행동 |
|---|---|---|
| 1~3회 | 자율 수정 | QA 피드백만으로 코드 수정 |
| 4~7회 | 가이드 재참조 | test-data 기준골격 전체 재읽기 후 수정 |
| 8~10회 | 최소 수정 | Must Follow 항목만 집중, 나머지 보류 |
| 11+ | 중단 | 사용자 에스컬레이션 |
적용 방식
- Backend QA 실패 → backend-dev 수정 → backend-qa 재검증 (SendMessage)
- Store 문제 → store-dev 수정 → frontend-qa 재검증
- UI 문제 → ui-dev 수정 → frontend-qa 재검증
에스컬레이션 보고
## Ralph Loop 에스컬레이션
- 모듈: [모듈명]
- 반복: N/10회
- 단계: [현재 단계]
- 미해결: [위반 항목]
- 권장: [수동 개입 사항]
Completion
모든 QA 통과 후:
1. 증거 수집
오케스트레이터가 /peach-qa-gate를 자동 실행 → 증거 보고서 생성
- 판정이 ❌이면 해당 항목 수정 후 재실행
- 판정이 ✅이면 다음 단계 진행
2. 팀 정리
SendMessage(shutdown_request) → 모든 팀원에게
TeamDelete → 팀 정리
완료 보고 형식
mode=backend
✅ Backend + Store 연결 팀 개발 완료
모듈: [모듈명]
mode: backend
결과:
✅ backend-dev: API 생성 완료
✅ backend-qa: TDD X개 통과
✅ store-dev: Store 생성 완료
✅ frontend-qa: vue-tsc + lint + build 통과
✅ qa-gate: 증거 보고서 생성 + 완료 가능 판정
생성된 파일:
Backend:
├── api/src/modules/[모듈명]/type/
├── api/src/modules/[모듈명]/dao/
├── api/src/modules/[모듈명]/service/
├── api/src/modules/[모듈명]/controller/
└── api/src/modules/[모듈명]/test/
Frontend:
├── front/src/modules/[모듈명]/type/[모듈명].type.ts
└── front/src/modules/[모듈명]/store/[모듈명].store.ts
다음 단계:
→ bun start (Backend 실행)
→ bun run dev (Frontend 실행)
→ 브라우저에서 /[모듈명]/list 접속
mode=ui
✅ UI Only 팀 개발 완료
모듈: [모듈명]
mode: ui
패턴: [ui=패턴]
피그마: [URL 또는 없음]
결과:
✅ ui-dev: UI 컴포넌트 생성 완료
✅ frontend-qa: vue-tsc + lint + build 통과
생성된 파일:
├── front/src/modules/[모듈명]/pages/list.vue
├── front/src/modules/[모듈명]/pages/list-search.vue
├── front/src/modules/[모듈명]/pages/list-table.vue
├── front/src/modules/[모듈명]/modals/insert.modal.vue
├── front/src/modules/[모듈명]/modals/update.modal.vue
├── front/src/modules/[모듈명]/modals/detail.modal.vue
├── front/src/modules/[모듈명]/_[모듈명].routes.ts
└── front/src/modules/[모듈명]/_[모듈명].validator.ts
다음 단계:
→ bun run dev (Frontend 실행)
→ 브라우저에서 /[모듈명]/list 접속
mode=fullstack
🎉 풀스택 개발 완료!
모듈: [모듈명]
mode: fullstack
결과:
✅ backend-dev: API 생성 완료
✅ backend-qa: TDD X개 통과
✅ store-dev: Store 생성 완료
✅ ui-dev: UI 컴포넌트 생성 완료
✅ frontend-qa: vue-tsc + lint + build 통과
생성된 파일:
Backend:
├── api/src/modules/[모듈명]/type/
├── api/src/modules/[모듈명]/dao/
├── api/src/modules/[모듈명]/service/
├── api/src/modules/[모듈명]/controller/
└── api/src/modules/[모듈명]/test/
Frontend:
├── front/src/modules/[모듈명]/type/
├── front/src/modules/[모듈명]/store/
├── front/src/modules/[모듈명]/pages/
├── front/src/modules/[모듈명]/modals/
├── front/src/modules/[모듈명]/_[모듈명].routes.ts
└── front/src/modules/[모듈명]/_[모듈명].validator.ts
다음 단계:
→ bun start (Backend 실행)
→ bun run dev (Frontend 실행)
→ 브라우저에서 /[모듈명]/list 접속
Examples
# 기존 UI에 API + Store 연결
/peach-agent-team notice-board mode=backend
# UI만 구현
/peach-agent-team member-list mode=ui ui=two-depth figma=https://figma.com/file/xxx
# 전체 풀스택 생성
/peach-agent-team product-manage mode=fullstack ui=page file=Y
# opus 모델로 서브에이전트 실행
/peach-agent-team product-manage mode=fullstack model=opus ui=page
Weekly Installs
3
Repository
peachsolution/p…-harnessFirst Seen
1 day ago
Security Audits
Installed on
cursor3
codex3
claude-code3
antigravity3
gemini-cli3