chore: .env.development → .example + pre-commit 모노레포 대응

- .env.development을 git에서 제거, .example로 대체 (서버 정책 준수)
- pre-commit hook을 frontend/ 기준으로 수정 (모노레포 구조)
- custom_pre_commit 플래그 활성화

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
htlee 2026-04-07 13:52:53 +09:00
부모 3ced9ffaaa
커밋 a7f3490091
3개의 변경된 파일54개의 추가작업 그리고 64개의 파일을 삭제

파일 보기

@ -1,6 +1,7 @@
{
"applied_global_version": "1.6.1",
"applied_date": "2026-04-06",
"applied_date": "2026-04-07",
"project_type": "react-ts",
"gitea_url": "https://gitea.gc-si.dev"
"gitea_url": "https://gitea.gc-si.dev",
"custom_pre_commit": true
}

파일 보기

@ -1,73 +1,62 @@
#!/bin/bash
#==============================================================================
# pre-commit hook (Monorepo: frontend + backend)
# 변경된 영역만 선택적으로 검증
# pre-commit hook (모노레포: frontend/ 디렉토리 기준)
# TypeScript 컴파일 + 린트 검증 — 실패 시 커밋 차단
#==============================================================================
# 스테이징된 파일 목록
STAGED=$(git diff --cached --name-only --diff-filter=ACM)
# frontend 변경 파일이 있는지 확인
FRONTEND_CHANGED=$(git diff --cached --name-only -- 'frontend/' | head -1)
# frontend 변경 확인
FRONTEND_CHANGED=$(echo "$STAGED" | grep -E '^frontend/' || true)
if [ -z "$FRONTEND_CHANGED" ]; then
echo "pre-commit: frontend 변경 없음, 검증 건너뜀"
exit 0
fi
# backend 변경 확인
BACKEND_CHANGED=$(echo "$STAGED" | grep -E '^backend/' || true)
echo "pre-commit: TypeScript 타입 체크 중..."
# === Frontend 검증 ===
if [ -n "$FRONTEND_CHANGED" ] && [ -d "frontend" ]; then
echo "pre-commit: frontend TypeScript 타입 체크 중..."
if ! command -v npx &>/dev/null; then
# npm 확인
if ! command -v npx &>/dev/null; then
echo "경고: npx가 설치되지 않았습니다. 검증을 건너뜁니다."
elif [ ! -d "frontend/node_modules" ]; then
echo "경고: frontend/node_modules가 없습니다. 'cd frontend && npm install' 후 다시 시도하세요."
exit 1
else
(cd frontend && npx tsc --noEmit --pretty 2>&1)
TSC_RESULT=$?
exit 0
fi
if [ $TSC_RESULT -ne 0 ]; then
# node_modules 확인 (모노레포: frontend/ 기준)
if [ ! -d "frontend/node_modules" ]; then
echo "경고: frontend/node_modules가 없습니다. 'cd frontend && npm install' 실행 후 다시 시도하세요."
exit 1
fi
# TypeScript 타입 체크 (frontend/ 디렉토리에서 실행)
(cd frontend && npx tsc --noEmit --pretty 2>&1)
TSC_RESULT=$?
if [ $TSC_RESULT -ne 0 ]; then
echo ""
echo "╔══════════════════════════════════════════════════════════╗"
echo "║ TypeScript 타입 에러! 커밋이 차단되었습니다. ║"
echo "║ 타입 에러를 수정한 후 다시 커밋해주세요. ║"
echo "╚══════════════════════════════════════════════════════════╝"
echo ""
exit 1
fi
echo "pre-commit: 타입 체크 성공"
fi
# ESLint
if [ -f "frontend/eslint.config.js" ] || [ -f "frontend/eslint.config.mjs" ]; then
echo "pre-commit: frontend ESLint 검증 중..."
(cd frontend && npx eslint src/ --quiet 2>&1)
echo "pre-commit: 타입 체크 성공"
# ESLint 검증 (설정 파일이 있는 경우만)
if [ -f "frontend/.eslintrc.js" ] || [ -f "frontend/.eslintrc.json" ] || [ -f "frontend/.eslintrc.cjs" ] || [ -f "frontend/eslint.config.js" ] || [ -f "frontend/eslint.config.mjs" ]; then
echo "pre-commit: ESLint 검증 중..."
(cd frontend && npx eslint src/ --ext .ts,.tsx --quiet 2>&1)
LINT_RESULT=$?
if [ $LINT_RESULT -ne 0 ]; then
echo ""
echo "╔══════════════════════════════════════════════════════════╗"
echo "║ ESLint 에러! 커밋이 차단되었습니다. ║"
echo "║ 'cd frontend && npm run lint:fix'로 자동 수정 시도. ║"
echo "║ 'cd frontend && npm run lint -- --fix'로 수정하세요. ║"
echo "╚══════════════════════════════════════════════════════════╝"
exit 1
fi
echo "pre-commit: ESLint 통과"
fi
fi
fi
# === Backend 검증 ===
if [ -n "$BACKEND_CHANGED" ] && [ -d "backend" ] && [ -f "backend/pom.xml" ]; then
echo "pre-commit: backend 컴파일 체크 중..."
(cd backend && ./mvnw compile -q 2>&1)
MVN_RESULT=$?
if [ $MVN_RESULT -ne 0 ]; then
echo ""
echo "╔══════════════════════════════════════════════════════════╗"
echo "║ Backend 컴파일 에러! 커밋이 차단되었습니다. ║"
echo "╚══════════════════════════════════════════════════════════╝"
exit 1
fi
echo "pre-commit: backend 컴파일 성공"
fi
exit 0
echo "pre-commit: ESLint 통과"
fi

6
.gitignore vendored
파일 보기

@ -29,9 +29,9 @@ Thumbs.db
.env
.env.*
!.env.example
# 프론트엔드 환경별 설정 (Vite VITE_* 변수, 배포 빌드에 필요)
!frontend/.env.development
!frontend/.env.production
# 프론트엔드 환경별 설정 (.example 파일만 커밋)
!frontend/.env.development.example
!frontend/.env.production.example
secrets/
# === Debug ===