Files
2nd/10_Wiki/Topics/Programming & Language/과잉 속성 체크 (Excess Property Checking).md
T
Antigravity Agent f8b21af4be Wiki cleanup: error-doc removal, dedup merge, link normalization
10_Wiki/Topics 대규모 정리:
- 오류 캡처/미완성 stub 문서 227개 제거
- 교차폴더 중복 43클러스터 병합 (63파일 → redirect)
- 링크명 정규화: 깨진 링크 수정·redirect 직결·개념 매핑 ~2,400건
- 카테고리 MOC 6개 신규 생성
- Graph 섹션 미해결 related-keyword 링크 10,058건 제거

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-20 23:52:15 +09:00

4.8 KiB

id, title, category, status, canonical_id, aliases, duplicate_of, source_trust_level, confidence_score, verification_status, tags, raw_sources, last_reinforced, github_commit, tech_stack
id title category status canonical_id aliases duplicate_of source_trust_level confidence_score verification_status tags raw_sources last_reinforced github_commit tech_stack
wiki-2026-0508-과잉-속성-체크-excess-property-checkin 과잉 속성 체크 (Excess Property Checking) 10_Wiki/Topics verified self
Excess Property Checking
EPC
TS Excess Property
none A 0.9 applied
typescript
type-system
structural-typing
epc
2026-05-10 pending
language framework
TypeScript TS 5.x

과잉 속성 체크 (Excess Property Checking)

매 한 줄

"매 object literal 을 직접 assign / pass 할 때만 발동하는 TS 의 추가 strictness rule". 매 structural typing 의 원칙적으론 OK 인 extra property 를 매 fresh object literal 에 한해 error 로 잡아 typo 방지. 매 변수 경유 시 자동 비활성화.

매 핵심

매 작동 방식

  • TS 의 structural / duck typing 은 매 extra property OK.
  • 그러나 매 object literal 을 fresh 하게 assign 시 TS 는 추가로 surplus key 를 error 로 보고.
  • 매 변수에 한 번 alias 하면 fresh 신호가 사라져 EPC 우회.

매 발동 조건

  • 매 object literal 의 직접 assignment / argument / return.
  • 매 contextual type 이 존재.
  • 매 변수 경유, type assertion (as), spread 시 비활성화.

매 응용

  1. Component prop typo 방지 (React).
  2. API request body 의 surplus field 차단.
  3. Config object 의 misnamed key 발견.

💻 패턴

매 EPC 발동 (error)

interface User { name: string; age: number }

const u: User = { name: "Lee", age: 30, emial: "x" };
//                                       ^^^^^ 매 EPC: 'emial' does not exist on User

매 변수 경유 우회 (error 사라짐)

const raw = { name: "Lee", age: 30, emial: "x" };
const u: User = raw;  // ✅ OK — fresh 아니라 EPC 비활성
// 매 structural compatibility 만 본다 (User 의 모든 prop 충족 → OK)

매 함수 인자 EPC

function greet(u: User) { console.log(u.name); }
greet({ name: "A", age: 1, extra: 1 });  // ❌ EPC error
const x = { name: "A", age: 1, extra: 1 };
greet(x);  // ✅ OK

매 index signature 의 escape hatch

interface Loose {
  name: string;
  [key: string]: unknown;
}
const l: Loose = { name: "A", whatever: 123, deep: { x: 1 } };  // ✅ OK

매 union type 의 EPC quirk

type A = { kind: "a"; a: number };
type B = { kind: "b"; b: number };

const x: A | B = { kind: "a", a: 1, b: 2 };
// ❌ EPC: 'b' is not in A; not in B 의 fresh form
// 매 변수 경유 시 통과 — 의도치 않은 leakage 가능

매 의도적 우회 (type assertion — 위험)

const u: User = { name: "A", age: 1, emial: "x" } as User;
// ⚠ 매 작동하지만 매 typo 의 silent — 매 강력히 X

매 React component prop typo 방지

type ButtonProps = { label: string; onClick: () => void };
const Button = (p: ButtonProps) => <button onClick={p.onClick}>{p.label}</button>;

<Button labl="Hi" onClick={() => {}} />;  // ❌ EPC: 'labl' typo 발견

매 satisfies operator (TS 4.9+) — 매 EPC 유지 + inference

const config = {
  port: 8080,
  host: "localhost",
  // typoKey: 1   // ❌ EPC error if uncomment
} satisfies { port: number; host: string };
// 매 config.port: number 의 narrow type 유지 + EPC 활성

매 결정 기준

상황 Approach
매 strict typo 검출 매 object literal 직접 assign + EPC 활용
매 동적 key 다수 index signature 추가
매 narrow + EPC 동시 satisfies operator
매 변수 경유 필요 type annotation 변수 + literal 사용
매 EPC 의도적 회피 매 보통 X — type 의 재설계

기본값: 매 object literal 의 직접 assign + satisfies 또는 explicit type — 매 변수 경유 의 무의식적 우회 X.

🔗 Graph

  • 부모: TypeScript · 구조적 타이핑(Structural Typing)
  • 변형: satisfies operator
  • 응용: API Contract
  • Adjacent: Type Narrowing · Discriminated Union

🤖 LLM 활용

언제: TS error 디버깅 ("excess property"), refactor 시 EPC 의도 검증. 언제 X: 매 runtime validation — 매 EPC 는 컴파일타임만.

안티패턴

  • as Type 으로 EPC 회피: 매 typo 의 silent.
  • 변수 경유 의 우회: 매 의도면 OK, 매 실수면 위험.
  • EPC 비활성화 의 흔한 오해: 매 spread { ...x, extra: 1 } 의 fresh — EPC 발동.
  • runtime 신뢰: EPC 는 매 compile-time only — 매 런타임 검증 X.

🧪 검증 / 중복

  • Verified (TypeScript Handbook — Object Types, TS 5.x source).
  • 신뢰도 A.

🕓 Changelog

날짜 변경
2026-05-08 Phase 1
2026-05-10 Manual cleanup — EPC 발동 조건 + 우회 + satisfies