Files
MH-DashBoard-organization/docs/WORK_RULEBOOK.md

6.1 KiB

Work Rulebook

Purpose

이 문서는 이 프로젝트에서 매일 작업을 시작하고 마무리할 때 반드시 따를 운영 규칙을 고정하기 위한 룰북이다.

목표는 아래 4가지다.

  • 완료된 기능의 회귀 방지
  • 코드 문제와 DB 문제의 혼선 방지
  • 작업 기록 누락 방지
  • 매일 같은 기준으로 안정적으로 이어서 작업

Rule 0. Morning Start Mandatory Check

이 규칙은 강제 규칙이다.

매일 아침 또는 그날의 첫 작업을 시작할 때는, 코드를 수정하기 전에 반드시 아래 순서를 먼저 수행한다.

  1. Gitea 브랜치 상태 확인
  2. 열린 이슈 확인
  3. 이 문서 WORK_RULEBOOK.md 확인
  4. 최신 체크포인트 문서 확인
  5. 현재 워크트리의 미푸시 커밋, 변경 파일, 미추적 파일 확인

위 5단계를 확인하기 전에는 새 코드 작성, 기존 코드 수정, 임의 테스트 진행을 시작하지 않는다.

즉:

  • "오늘 첫 작업"의 시작점은 코드 수정이 아니라 상태 확인이다.
  • 이 절차를 건너뛰고 바로 수정 작업에 들어가는 것은 금지한다.

Rule 1. Completed Feature Protection

완료 판정된 작업물의 기능과 코드는 함부로 건드리지 않는다.

세부 규칙:

  • 직접 관련된 이슈가 없으면 완료 기능을 수정하지 않는다.
  • 완료 기능 수정이 필요하면 먼저 이유와 영향 범위를 이슈 또는 코멘트에 남긴다.
  • 단순 편의상 구조를 바꾸거나 정리하는 리팩터링으로 완료 기능 동작을 바꾸지 않는다.
  • 완료 기능을 수정한 경우에는 관련 회귀 검증까지 완료해야 한다.

핵심 원칙:

  • "고치는 김에 같이 정리"를 금지한다.
  • 수정 범위는 현재 작업 목적에 필요한 최소 범위로 제한한다.

Rule 2. Work Must Be Tied To An Issue

원칙적으로 이슈 없는 작업은 하지 않는다.

세부 규칙:

  • 모든 작업은 기존 이슈에 연결하거나 새 이슈/작업 메모를 만든 뒤 시작한다.
  • 왜 하는 작업인지 한 줄로라도 남긴다.
  • 임시 대응도 예외가 아니다.

Rule 3. Branch And Workspace Awareness

작업 전에 현재 브랜치와 워크트리 상태를 먼저 확인한다.

반드시 확인할 항목:

  • 현재 브랜치
  • 원격 대비 ahead / behind 상태
  • 미푸시 커밋
  • 수정된 파일
  • 미추적 파일

금지:

  • 로컬에서만 있는 상태를 기준 진실처럼 가정하기
  • 미정리 변경사항을 모른 채 새 작업을 덧붙이기

Rule 4. DB Before Code Assumption

조직도, 멤버, 자리배치도, 권한 문제는 코드보다 DB 상태 영향을 먼저 의심한다.

세부 규칙:

  • dev DB와 prod DB가 다른데 코드 버그로 단정하지 않는다.
  • 공개용 기준 데이터가 필요한 검증은 먼저 동기화 상태를 확인한다.
  • DB 차이를 무시한 검증 결과를 신뢰하지 않는다.

Rule 5. Dev / Prod Protocol Is Mandatory

docs/DEV_PROD_DB_PROTOCOL.md 의 규칙은 권고가 아니라 작업 기준이다.

핵심 원칙:

  • 코드 선행은 8081
  • 데이터 정본은 8080
  • 8081 DB는 독립 정본이 아니라 검증용 복제본처럼 다룬다

조직도/자리배치도/멤버 검증 전에는 필요 시 아래를 먼저 수행한다.

  • ./scripts/sync_prod_db_to_dev.sh minimal

분석 화면까지 공개용 기준으로 맞출 필요가 있으면 아래를 사용한다.

  • ./scripts/sync_prod_db_to_dev.sh full

Rule 6. Validation Before Completion

완료 기준은 "코드를 썼다"가 아니라 "실제 동작을 검증했다"이다.

세부 규칙:

  • 검증 없이 완료로 판단하지 않는다.
  • 감으로 확인하지 않고 체크리스트 기준으로 확인한다.
  • 회귀 가능성이 있는 수정은 관련 기능까지 같이 확인한다.

검증 기준 문서:

  • docs/REGRESSION_CHECKLIST.md

Rule 7. Seat Map Work Is High Risk

자리배치도 관련 작업은 항상 고위험 작업으로 취급한다.

작업 시 최소 확인 항목:

  1. 관리자 DnD 배치 / 저장
  2. 조직도 상세의 seat preview
  3. 비관리자 seatmap 진입 / 표시

오피스가 여러 개면 아래 모두 확인한다.

  • 기술개발센터
  • 한맥빌딩 6층
  • 한맥빌딩 7층

기술개발센터만 보고 완료 처리하지 않는다.

Rule 8. Auth / Schema / Sync Changes Are High Risk

아래 영역은 일반 기능 수정처럼 다루지 않는다.

  • auth.*
  • members
  • seat_maps
  • seat_slots
  • seat_positions
  • 동기화 스크립트
  • 스키마 변경

이 작업은 반드시:

  • 변경 이유 명시
  • 영향 범위 확인
  • 관련 검증 수행
  • 결과 기록

까지 포함해야 한다.

Rule 9. Temporary Logic Must Be Tracked

mock, fallback, hotfix, 임시 우회 로직은 허용할 수 있다. 하지만 반드시 추적 가능해야 한다.

세부 규칙:

  • 왜 임시인지 기록한다.
  • 제거 또는 정식화할 이슈를 연결한다.
  • 운영 기준 로직처럼 장기 방치하지 않는다.

Rule 10. End-Of-Day Closing Record

작업 종료 시 아래를 반드시 남긴다.

  • 무엇을 했는지
  • 무엇을 검증했는지
  • 무엇이 아직 남았는지
  • 다음에 어디서 이어야 하는지

남길 위치:

  • Gitea 이슈 코멘트
  • 또는 체크포인트 문서

둘 다 가능하면 둘 다 남긴다.

Daily Start Checklist

매일 첫 작업 시작 전 체크:

  • 현재 브랜치 확인
  • 원격 대비 커밋 상태 확인
  • 열린 이슈 확인
  • WORK_RULEBOOK.md 확인
  • 최신 체크포인트 확인
  • 미추적 / 수정 파일 확인
  • 오늘 작업이 코드 문제인지 DB 문제인지 먼저 구분
  • 공개용 기준 데이터 검증이 필요한지 판단

Daily End Checklist

매일 작업 종료 전 체크:

  • 오늘 변경 파일 정리
  • 검증 결과 정리
  • 미완료 항목 정리
  • 관련 이슈 코멘트 또는 문서 업데이트
  • 다음 시작 지점 명시

One-Line Operating Principle

이 프로젝트의 작업 기준은 아래 한 줄로 요약한다.

  • 상태를 먼저 확인하고, 완료 기능은 보호하며, DB와 검증을 무시하지 않고, 기록을 남기면서 작업한다.