docs: finalized wiki integrity maintenance (v3.0 standard) - pruned 1400+ stubs and fixed 11k+ ghost links
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
---
|
||||
id: [[P-Reinforce]]-AUTO-26C070
|
||||
id: [[P-Reinforce|P-Reinforce]]-AUTO-26C070
|
||||
category: "10_Wiki/💡 Topics/Programming & Language"
|
||||
confidence_score: 0.90
|
||||
tags: [auto-reinforced]
|
||||
@@ -7,15 +7,15 @@ last_reinforced: 2026-04-20
|
||||
github_commit: "[P-Reinforce] Continuous Worker - Git Pre-commit 훅을 활용한 개발 워크플로우 자동화"
|
||||
---
|
||||
|
||||
# [[Git Pre-commit 훅을 활용한 개발 워크플로우 자동화]]
|
||||
# [[Git Pre-commit 훅을 활용한 개발 워크플로우 자동화|Git Pre-commit 훅을 활용한 개발 워크플로우 자동화]]
|
||||
|
||||
## 📌 한 줄 통찰 (The Karpathy Summary)
|
||||
> Git Pre-commit 훅은 커밋이 코드 저장소에 기록되기 직전에 자동으로 실행되는 스크립트이다 [1]. 개발 팀은 주로 [[Husky]]와 [[lint-staged]] 같은 도구를 결합하여 사용하여, 커밋 대상 파일(staged files)에 대해서만 린트(Lint) 검사와 코드 포맷팅을 자동으로 수행한다 [2, 3]. 이를 통해 문법적 결함이 있거나 팀의 컨벤션에 맞지 않는 코드가 저장소에 유입되는 것을 사전에 차단하고, 일관된 코드 품질을 빠르고 효율적으로 유지할 수 있다 [3, 4].
|
||||
> Git Pre-commit 훅은 커밋이 코드 저장소에 기록되기 직전에 자동으로 실행되는 스크립트이다 [1]. 개발 팀은 주로 [[Husky|Husky]]와 [[lint-staged|lint-staged]] 같은 도구를 결합하여 사용하여, 커밋 대상 파일(staged files)에 대해서만 린트(Lint) 검사와 코드 포맷팅을 자동으로 수행한다 [2, 3]. 이를 통해 문법적 결함이 있거나 팀의 컨벤션에 맞지 않는 코드가 저장소에 유입되는 것을 사전에 차단하고, 일관된 코드 품질을 빠르고 효율적으로 유지할 수 있다 [3, 4].
|
||||
|
||||
## 📖 구조화된 지식 (Synthesized Content)
|
||||
* **Git 훅과 Pre-commit의 역할:** Git 훅은 커밋 생성 전(`pre-commit`), 푸시 전(`pre-push`) 등 Git 워크플로우의 특정 이벤트 시점에 실행되는 쉘 스크립트이다 [1]. 그중에서도 `pre-commit` 훅은 코드가 코드 저장소에 들어가기 전의 최후의 방어선 역할을 수행하며, 빠른 포맷팅이나 린팅을 자동화하는 데 가장 적합하다 [1, 5].
|
||||
* **Husky를 통한 훅 관리:** 기본적으로 Git 훅은 `.git/hooks/` 폴더에 로컬로 존재하고 버전 관리가 되지 않기 때문에 새로운 팀원이나 CI 환경에 자동으로 공유되지 않는 한계가 있다 [2]. Husky는 훅 스크립트를 `.husky/`와 같이 버전 관리 시스템이 추적할 수 있는 디렉토리에 저장하고, Git의 `core.hooksPath`를 변경하여 이 문제를 해결하는 도구이다 [2, 6]. `package.json`의 `prepare` 스크립트 설정을 통해 팀원이 `npm install`을 실행할 때 자동으로 훅이 연동되도록 구성할 수 있다 [7, 8].
|
||||
* **lint-staged를 통한 성능 및 시간 최적화:** 커밋을 할 때마다 수많은 파일로 구성된 전체 코드베이스에 대해 [[ESLint]]나 [[Prettier]]를 실행하면 시간이 오래 걸려 개발 생산성을 크게 저하시킨다 [2, 5]. `lint-staged`는 오직 변경되어 Git의 스테이징 영역(staged files)에 올라간 파일들만 필터링하여 명령어를 실행하는 라우터 역할을 하므로, 검사 시간을 단 몇 초 이내로 대폭 줄여준다 [2, 9, 10].
|
||||
* **lint-staged를 통한 성능 및 시간 최적화:** 커밋을 할 때마다 수많은 파일로 구성된 전체 코드베이스에 대해 [[ESLint|ESLint]]나 [[Prettier|Prettier]]를 실행하면 시간이 오래 걸려 개발 생산성을 크게 저하시킨다 [2, 5]. `lint-staged`는 오직 변경되어 Git의 스테이징 영역(staged files)에 올라간 파일들만 필터링하여 명령어를 실행하는 라우터 역할을 하므로, 검사 시간을 단 몇 초 이내로 대폭 줄여준다 [2, 9, 10].
|
||||
* **자동화 워크플로우 통합 동작 방식:** `pre-commit` 훅에서 `lint-staged`를 호출하도록 구성하면, 커밋을 시도할 때마다 자동으로 ESLint를 통한 오류 검출(및 `--fix`를 통한 자동 수정)과 Prettier를 통한 코드 정렬이 이루어진다 [7, 11]. `lint-staged`는 포맷팅으로 인해 수정된 파일들을 수동으로 추가할 필요 없이 알아서 다시 스테이징 처리한다 [7, 10]. 만약 해결할 수 없는 구문 오류나 규칙 위반이 발견되면 스크립트가 실패하며 커밋 프로세스가 즉시 중단된다 [12].
|
||||
* **로컬 자동화와 CI(지속적 통합)의 관계:** 개발자는 급하거나 훅이 고장 난 경우 `--no-verify` 플래그를 사용하거나 `HUSKY=0` 환경 변수를 설정하여 로컬 훅 실행을 우회(Bypass)할 수 있다 [13-15]. 따라서 Git 훅은 개발자에게 빠른 피드백을 제공하는 도구일 뿐이며, 최종적인 코드 강제 집행과 완벽한 보장을 위해서는 CI 서버에서 전체 테스트 및 검사가 반드시 병행되어야 한다 [14, 16, 17].
|
||||
|
||||
@@ -24,8 +24,8 @@ github_commit: "[P-Reinforce] Continuous Worker - Git Pre-commit 훅을 활용
|
||||
- **정책 변화:** Programming & Language 분야의 자동 자산화 수행.
|
||||
|
||||
## 🔗 지식 연결 (Graph)
|
||||
- **Related Topics:** [[Husky]], [[lint-staged]], [[ESLint]], [[Prettier]], [[Continuous Integration (CI)]]
|
||||
- **Projects/Contexts:** [[팀 단위 코드 품질 및 컨벤션 유지]], [[대규모 모노레포([[Turborepo]]) 환경에서의 린트 오케스트레이션]]
|
||||
- **Related Topics:** [[Husky|Husky]], lint-staged, ESLint, [[Prettier|Prettier]], [[Continuous Integration (CI)|Continuous Integration (CI]]
|
||||
- **Projects/Contexts:** [[팀 단위 코드 품질 및 컨벤션 유지|팀 단위 코드 품질 및 컨벤션 유지]], 대규모 모노레포(Turborepo) 환경에서의 린트 오케스트레이션
|
||||
- **Contradictions/Notes:** `lint-staged`는 전체 프로젝트를 검사하도록 설계된 도구(예: 전체 구조를 파악해야 하는 `ng lint`나 TypeScript의 `tsc --noEmit` 등)를 래핑하는 용도로는 적합하지 않으며, 단일 파일 단위로 처리 가능한 작업에만 사용해야 한다 [18-20]. 또한, 설정 시 여러 명령어가 동일한 파일을 동시에 수정하도록 구성하면 경쟁 조건(Race condition)이 발생하여 코드가 망가질 수 있으므로, 명령어 배열(Array)을 사용하여 순차적으로 실행되게 설정해야 한다 [21].
|
||||
|
||||
---
|
||||
|
||||
Reference in New Issue
Block a user