Files
invyone/_pipeline_backup/runs/2026-03-28_pipe-20260328041806-pbum/plan.md
T

8.4 KiB

Pipeline: XML SQL 포맷팅 2차 (미완료분 + 파일명 변경)

config

  • max_retries: 3
  • parallel: true
  • timeout: 30m
  • design_first: false
  • model: sonnet
  • max_concurrent: 5

tasks

task-1: Screen/Layout XML 포맷팅 (3+4 분리) [backend]

  • depends: none

  • done_when: SQL 전부 대문자 + 줄 띄움

  • files: backend-spring/src/main/resources/mapper/ScreenManagementMapper.xml, backend-spring/src/main/resources/mapper/ScreenStandardMapper.xml, backend-spring/src/main/resources/mapper/ScreenFileMapper.xml

  • test: cd backend-spring && ./gradlew compileJava 2>&1 | tail -20

  • context: | XML 내부 SQL 쿼리를 덕일 스타일로 포맷팅. 기능/로직 변경 없이 포맷만 변경.

    ★ 규칙 1: SQL 키워드 전부 대문자 select → SELECT, from → FROM, where → WHERE, and → AND, or → OR, left join → LEFT JOIN, order by → ORDER BY, group by → GROUP BY, insert into → INSERT INTO, update → UPDATE, set → SET, delete → DELETE, values → VALUES, as → AS, on → ON, in → IN, not → NOT, null → NULL, is → IS, like → LIKE, ilike → ILIKE, between → BETWEEN, exists → EXISTS, case → CASE, when → WHEN, then → THEN, else → ELSE, end → END, union all → UNION ALL, with recursive → WITH RECURSIVE, cast → CAST, coalesce → COALESCE, count → COUNT, sum → SUM, distinct → DISTINCT, limit → LIMIT, offset → OFFSET, asc → ASC, desc → DESC, returning → RETURNING, now() → NOW(), upper() → UPPER(), to_char() → TO_CHAR()

    ★ 규칙 2: 컬럼명/테이블명/별칭 전부 대문자 screen_definitions → SCREEN_DEFINITIONS, screen_code → SCREEN_CODE, sd → SD, company_code → COMPANY_CODE 등

    ★ 규칙 3: SELECT 컬럼 한 줄에 하나, 쉼표는 앞에 변경 전: SELECT sd., screen_code, table_name FROM screen_definitions 변경 후: SELECT SD. , SCREEN_CODE , TABLE_NAME FROM SCREEN_DEFINITIONS

    ★ 규칙 4: INSERT 컬럼/VALUES 한 줄에 하나 변경 전: INSERT INTO table (col1, col2) VALUES (#{val1}, #{val2}) 변경 후: INSERT INTO TABLE ( COL1 , COL2 ) VALUES ( #{val1} , #{val2} )

    ★ 규칙 5: UPDATE SET 한 줄에 하나 변경 후: UPDATE TABLE SET COL1 = #{val1} , COL2 = #{val2} WHERE ID = #{id}

    ★ 규칙 6: JOIN/WHERE/ORDER BY 절 단위 줄 구분

    ★ 절대 바꾸면 안 되는 것:

    • #{파라미터} camelCase 유지
    • test="" 안 변수명 유지
    • SQL 문자열 리터럴 값 유지: 'active', '*' 등
    • id, namespace, refid 값 유지
    • 쿼리 로직/결과 변경 금지

task-2: Screen/Layout XML 포맷팅 나머지 (4개) [backend]

  • depends: none
  • done_when: SQL 전부 대문자 + 줄 띄움
  • files: backend-spring/src/main/resources/mapper/ScreenGroupMapper.xml, backend-spring/src/main/resources/mapper/ScreenEmbeddingMapper.xml, backend-spring/src/main/resources/mapper/LayoutMapper.xml, backend-spring/src/main/resources/mapper/WebTypeStandardMapper.xml
  • test: cd backend-spring && ./gradlew compileJava 2>&1 | tail -20
  • context: | task-1과 동일한 포맷팅 규칙 적용.

task-3: Finance/Tax XML 포맷팅 (4개) [backend]

  • depends: none
  • done_when: SQL 전부 대문자 + 줄 띄움
  • files: backend-spring/src/main/resources/mapper/TaxInvoiceMapper.xml, backend-spring/src/main/resources/mapper/BomMapper.xml, backend-spring/src/main/resources/mapper/ProductionMapper.xml, backend-spring/src/main/resources/mapper/SalesReportMapper.xml
  • test: cd backend-spring && ./gradlew compileJava 2>&1 | tail -20
  • context: | task-1과 동일한 포맷팅 규칙 적용.

task-4: Finance/Report XML 포맷팅 (3개) [backend]

  • depends: none
  • done_when: SQL 전부 대문자 + 줄 띄움
  • files: backend-spring/src/main/resources/mapper/AnalyticsReportMapper.xml, backend-spring/src/main/resources/mapper/DeliveryMapper.xml, backend-spring/src/main/resources/mapper/PackagingMapper.xml
  • test: cd backend-spring && ./gradlew compileJava 2>&1 | tail -20
  • context: | task-1과 동일한 포맷팅 규칙 적용.

task-5: Logistics XML 포맷팅 1 (7개) [backend]

  • depends: none
  • done_when: SQL 전부 대문자 + 줄 띄움
  • files: backend-spring/src/main/resources/mapper/ShippingPlanMapper.xml, backend-spring/src/main/resources/mapper/ShippingOrderMapper.xml, backend-spring/src/main/resources/mapper/BookingMapper.xml, backend-spring/src/main/resources/mapper/DriverMapper.xml, backend-spring/src/main/resources/mapper/VehicleMapper.xml, backend-spring/src/main/resources/mapper/VehicleTripMapper.xml, backend-spring/src/main/resources/mapper/YardLayoutMapper.xml
  • test: cd backend-spring && ./gradlew compileJava 2>&1 | tail -20
  • context: | task-1과 동일한 포맷팅 규칙 적용.

task-6: Logistics XML 포맷팅 2 (7개) [backend]

  • depends: none
  • done_when: SQL 전부 대문자 + 줄 띄움
  • files: backend-spring/src/main/resources/mapper/DigitalTwinMapper.xml, backend-spring/src/main/resources/mapper/DashboardMapper.xml, backend-spring/src/main/resources/mapper/ReportMapper.xml, backend-spring/src/main/resources/mapper/BarcodeLabelMapper.xml, backend-spring/src/main/resources/mapper/MapDataMapper.xml, backend-spring/src/main/resources/mapper/ExcelMappingMapper.xml, backend-spring/src/main/resources/mapper/RiskAlertMapper.xml
  • test: cd backend-spring && ./gradlew compileJava 2>&1 | tail -20
  • context: | task-1과 동일한 포맷팅 규칙 적용.

task-7: Logistics XML 포맷팅 3 (7개) [backend]

  • depends: none
  • done_when: SQL 전부 대문자 + 줄 띄움
  • files: backend-spring/src/main/resources/mapper/PopActionMapper.xml, backend-spring/src/main/resources/mapper/PopProductionMapper.xml, backend-spring/src/main/resources/mapper/WorkHistoryMapper.xml, backend-spring/src/main/resources/mapper/MoldMapper.xml, backend-spring/src/main/resources/mapper/DesignMapper.xml, backend-spring/src/main/resources/mapper/CollectionMapper.xml, backend-spring/src/main/resources/mapper/DataMapper.xml
  • test: cd backend-spring && ./gradlew compileJava 2>&1 | tail -20
  • context: | task-1과 동일한 포맷팅 규칙 적용.

task-8: 나머지 XML 포맷팅 (9개) [backend]

  • depends: none
  • done_when: SQL 전부 대문자 + 줄 띄움
  • files: backend-spring/src/main/resources/mapper/ApprovalMapper.xml, backend-spring/src/main/resources/mapper/AuditLogMapper.xml, backend-spring/src/main/resources/mapper/RoleMapper.xml, backend-spring/src/main/resources/mapper/DepartmentMapper.xml, backend-spring/src/main/resources/mapper/CompanyManagementMapper.xml, backend-spring/src/main/resources/mapper/SystemNoticeMapper.xml, backend-spring/src/main/resources/mapper/DataAdvancedMapper.xml, backend-spring/src/main/resources/mapper/CategoryValueCascadingMapper.xml
  • test: cd backend-spring && ./gradlew compileJava 2>&1 | tail -20
  • context: | task-1과 동일한 포맷팅 규칙 적용.

task-9: XML 파일명 변경 (96개) [backend]

  • depends: task-1, task-2, task-3, task-4, task-5, task-6, task-7, task-8

  • done_when: 모든 XML 파일명이 소문자 덕일 스타일

  • files: backend-spring/src/main/resources/mapper/

  • test: cd backend-spring && ls src/main/resources/mapper/ | grep -c "Mapper" | xargs test 0 -eq

  • context: | XML 파일명을 덕일 스타일 소문자로 변경.

    AdminMapper.xml → admin.xml TodoMapper.xml → todo.xml CommonMapper.xml → common.xml AuthMapper.xml → auth.xml DataAdvancedMapper.xml → dataAdvanced.xml TableCategoryValueMapper.xml → tableCategoryValue.xml ScreenManagementMapper.xml → screenManagement.xml AiAssistantProxyMapper.xml → aiAssistantProxy.xml AnalyticsReportMapper.xml → analyticsReport.xml ... (96개 전부 동일 규칙: PascalCase에서 "Mapper" 제거 후 camelCase)

    application.yml의 mapper-locations는 classpath:mapper/*.xml 이므로 파일명만 바꿔도 자동 인식.

    ★ git mv를 사용하여 이력 보존할 것. ★ 파일 내부는 건드리지 말 것 (이미 포맷팅 완료).

task-10: 전체 빌드 검증 [backend]

  • depends: task-9
  • done_when: bootJar 성공
  • files: backend-spring/build.gradle
  • test: cd backend-spring && ./gradlew compileJava 2>&1 | tail -20
  • verify: cd backend-spring && ./gradlew bootJar 2>&1 | tail -20
  • context: | XML 포맷팅 + 파일명 변경 후 bootJar 빌드 통과 확인.