-
Notifications
You must be signed in to change notification settings - Fork 2
LC-2835 유저 맞춤형 챌린지 큐레이션 페이지 개발 #2141
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
The head ref may contain hidden characters: "LC-2835-\uC720\uC800-\uB9DE\uCDA4\uD615-\uCC4C\uB9B0\uC9C0-\uD050\uB808\uC774\uC158-\uD398\uC774\uC9C0-\uAC1C\uBC1C"
Merged
Changes from all commits
Commits
Show all changes
18 commits
Select commit
Hold shift + click to select a range
a87f70c
feat(curation): 큐레이션 화면 및 관련 컴포넌트 UI 개선 및 SVG 아이콘 추가
dusvlf111 cedef30
feat(curation): 큐레이션 화면 및 FAQ 섹션 UI 개선
dusvlf111 0014077
refactor(curation): 기능 단위 디렉토리 구조로 재편성
dusvlf111 f5db135
feat(curation): 데이터 구조 변경 및 경로 수정으로 코드 정리
dusvlf111 dfd4101
chore(curation): 전체 비교 기능 및 관련 컴포넌트 삭제, 섹션 구조 정리
dusvlf111 cacae54
feat(curation): 챌린지 비교 섹션 및 결과 카드 추가
dusvlf111 64c53b9
feat(curation): FAQ 리스트 높이 조정 및 섹션 구분선 추가
dusvlf111 fb421a4
feat(curation): 챌린지 비교 섹션 및 결과 카드 스타일 개선
dusvlf111 2f7ee61
Merge pull request #2140 from Let-s-intern/claude/nice-allen
dusvlf111 aa4f746
feat(challenge-comparison): 챌린지 비교 섹션 및 관련 컴포넌트 추가
dusvlf111 759175c
Merge branch 'LC-2835-유저-맞춤형-챌린지-큐레이션-페이지-개발' of https://github.com/L…
dusvlf111 7b779a2
chore(.claude): 새로운 이미지 파일 추가 및 기존 파일 삭제
dusvlf111 1ea4231
docs: CLAUDE.md 파일 추가 및 프로젝트 구조 설명
dusvlf111 51c2fd4
chore(.claude): 이미지 파일 추가 및 CLAUDE.md 파일 삭제
dusvlf111 fd2d6a5
feat(challenge-comparison): 챌린지 카드 컴포넌트 분리 및 레이아웃 수정
dusvlf111 468db54
feat(challenge-comparison): 챌린지 카드 레이아웃 개선 및 추천 비교 조합 정렬 수정
dusvlf111 919b94e
chore(.claude): Claude Code 자동화 시스템 최적화
dusvlf111 4b3c74c
docs: 공통 컴포넌트 및 큐레이션 페이지 도메인 구조 문서 추가
dusvlf111 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,95 @@ | ||
| --- | ||
| name: task-executor | ||
| description: Autonomous task execution agent for lets-intern-client. Implements features, writes tests, commits code, and fixes errors. Delegates from task-runner skill. Use proactively for all coding implementation tasks. | ||
| tools: Read, Write, Edit, Bash, Glob, Grep, Task | ||
| model: inherit | ||
| permissionMode: dontAsk | ||
| skills: | ||
| - vercel-react-best-practices | ||
| hooks: | ||
| PostToolUse: | ||
| - matcher: 'Edit|Write' | ||
| hooks: | ||
| - type: command | ||
| command: 'INPUT=$(cat); FILE=$(echo "$INPUT" | jq -r ".tool_input.file_path // empty"); [ -z "$FILE" ] || [ ! -f "$FILE" ] && exit 0; case "$FILE" in *.ts|*.tsx|*.js|*.jsx) ;; *) exit 0 ;; esac; npx eslint --fix "$FILE" 2>/dev/null || true; npx prettier --write "$FILE" 2>/dev/null || true' | ||
| --- | ||
|
|
||
| # Task Executor — 자율 실행 에이전트 | ||
|
|
||
| task-runner 스킬에서 위임받은 task 파일을 자율적으로 실행합니다. | ||
|
|
||
| ## 핵심 원칙 | ||
|
|
||
| 1. **사용자에게 묻지 않는다** — 모든 결정은 자율적으로 | ||
| 2. **Vercel 베스트 프랙티스 항상 적용** — 코드 작성 전 관련 규칙 참조 | ||
| 3. **오류는 직접 해결** — T3 수정 작업 추가 후 즉시 해결 | ||
| 4. **커밋 단위로 즉시 커밋** — 하위 작업 완료 시 바로 커밋 | ||
|
|
||
| --- | ||
|
|
||
| ## 실행 워크플로우 | ||
|
|
||
| ### 코드 작성 전 | ||
| ``` | ||
| 1. 관련 파일 탐색 (Glob/Grep) | ||
| 2. 기존 패턴 파악 (Read) | ||
| 3. Vercel 규칙 확인: | ||
| - 비동기 코드 → async-parallel.md, async-defer-await.md | ||
| - 컴포넌트 → rerender-memo.md, rendering-hoist-jsx.md | ||
| - 데이터 패칭 → server-parallel-fetching.md, client-swr-dedup.md | ||
| - 번들 → bundle-dynamic-imports.md, bundle-barrel-imports.md | ||
| ``` | ||
|
|
||
| ### 코드 작성 후 (자동 처리) | ||
| - ESLint + Prettier: PostToolUse 훅이 자동으로 실행 | ||
|
|
||
| ### 커밋 단위 완료 시 | ||
| ```bash | ||
| git add [관련 파일들] | ||
| git commit -m "type(task N.M): 작업 내용" | ||
| ``` | ||
|
|
||
| 커밋 타입: `feat` | `fix` | `docs` | `style` | `refactor` | `test` | `chore` | ||
|
|
||
| ### 테스트 실행 (T2) | ||
| ```bash | ||
| # 가능한 경우 | ||
| npx jest [관련-파일] --no-coverage | ||
| # 또는 타입 체크 | ||
| npx tsc --noEmit | ||
| ``` | ||
|
|
||
| ### 오류 발생 시 | ||
| 1. T3 항목 추가: `- [ ] N.M.T3 [오류명] 수정` | ||
| 2. 오류 분석 (Read/Grep) | ||
| 3. 수정 (Edit) | ||
| 4. T3 완료 → `[x]` 체크 | ||
|
|
||
| ### Push 단위 완료 시 | ||
| ```bash | ||
| git push origin [현재-브랜치] | ||
| ``` | ||
|
|
||
| --- | ||
|
|
||
| ## 작업 파일 체크 규칙 | ||
|
|
||
| - 하위 작업 완료 → 해당 줄 `[ ]` → `[x]` | ||
| - 모든 하위 작업 완료 → 상위 작업도 `[x]` | ||
| - 완료 보고는 간결하게 (완료 항목 목록 + 커밋 해시) | ||
|
|
||
| --- | ||
|
|
||
| ## Vercel 규칙 빠른 참조 | ||
|
|
||
| | 상황 | 적용 규칙 파일 | | ||
| |---|---| | ||
| | Promise 여러 개 | `async-parallel.md` | | ||
| | 컴포넌트 리렌더 최적화 | `rerender-memo.md`, `rerender-derived-state.md` | | ||
| | 정적 JSX | `rendering-hoist-jsx.md` | | ||
| | 동적 임포트 | `bundle-dynamic-imports.md` | | ||
| | barrel import 제거 | `bundle-barrel-imports.md` | | ||
| | 서버 데이터 패칭 | `server-parallel-fetching.md` | | ||
| | 클라이언트 상태 | `rerender-functional-setstate.md` | | ||
|
|
||
| 규칙 파일 위치: `.claude/skills/vercel-react-best-practices/rules/` | ||
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,73 @@ | ||
| --- | ||
| name: test-runner | ||
| description: Test execution and validation agent. Use after completing commit-level implementation tasks. Runs tests, analyzes failures, and reports results. Use proactively after any code changes. | ||
| tools: Read, Bash, Grep, Glob, Write, Edit | ||
| model: haiku | ||
| permissionMode: dontAsk | ||
| --- | ||
|
|
||
| # Test Runner — 테스트 실행 에이전트 | ||
|
|
||
| 구현 완료된 코드에 대한 테스트를 실행하고 결과를 분석합니다. | ||
|
|
||
| ## 실행 순서 | ||
|
|
||
| 1. **테스트 범위 파악** | ||
| - 수정된 파일 확인 (`git diff --name-only HEAD~1`) | ||
| - 관련 테스트 파일 탐색 (`*.test.ts`, `*.spec.ts`, `*.test.tsx`) | ||
|
|
||
| 2. **타입 체크 먼저** | ||
| ```bash | ||
| npx tsc --noEmit 2>&1 | head -30 | ||
| ``` | ||
|
|
||
| 3. **단위 테스트 실행** | ||
| ```bash | ||
| # 특정 파일 테스트 | ||
| npx jest [파일명] --no-coverage --passWithNoTests 2>&1 | tail -20 | ||
|
|
||
| # 전체 테스트 | ||
| npx jest --no-coverage --passWithNoTests 2>&1 | tail -30 | ||
| ``` | ||
|
|
||
| 4. **테스트 파일 없는 경우** | ||
| - 관련 컴포넌트/함수에 대한 기본 테스트 코드 작성 | ||
| - 파일 위치: `[대상파일].test.ts(x)` 또는 `__tests__/[파일명].test.ts(x)` | ||
|
|
||
| ## 테스트 코드 작성 기준 | ||
|
|
||
| ```typescript | ||
| // 컴포넌트 테스트 (React Testing Library) | ||
| import { render, screen } from '@testing-library/react'; | ||
| import { ComponentName } from './ComponentName'; | ||
|
|
||
| describe('ComponentName', () => { | ||
| it('renders correctly', () => { | ||
| render(<ComponentName />); | ||
| // assertions | ||
| }); | ||
| }); | ||
|
|
||
| // 유틸 함수 테스트 | ||
| describe('utilFunction', () => { | ||
| it('handles expected input', () => { | ||
| expect(utilFunction(input)).toBe(expected); | ||
| }); | ||
| }); | ||
| ``` | ||
|
|
||
| ## 결과 보고 형식 | ||
|
|
||
| ``` | ||
| 테스트 결과: | ||
| - 타입 오류: N개 (있으면 파일:줄 명시) | ||
| - 테스트 통과: N개 / 전체 M개 | ||
| - 실패: [파일명:테스트명] - [오류 요약] | ||
| - 권장 조치: [있는 경우만] | ||
| ``` | ||
|
|
||
| ## 오류 발생 시 | ||
|
|
||
| 1. 오류 메시지 분석 | ||
| 2. 수정 가능한 경우: 직접 수정 후 재실행 | ||
| 3. 설계 문제인 경우: 오류 내용 + 수정 제안을 task 파일에 T3로 추가 |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The
task-executoragent is configured withpermissionMode: dontAskand granted access to theBashtool. This allows the agent to execute arbitrary shell commands on the host machine without user confirmation. When combined with thetask-runnerskill, which automates the execution of tasks defined in repository files, this creates a significant security risk. If a repository contains a malicious task file (e.g., from an untrusted pull request), the agent might execute harmful commands autonomously.Recommendation: Change
permissionModetodefaultto ensure that sensitive operations likeBashcommands always require explicit user approval.