agentic-dev 0.2.11 → 0.2.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (276) hide show
  1. package/README.md +72 -54
  2. package/bin/agentic-dev.mjs +162 -11
  3. package/lib/github.mjs +246 -0
  4. package/lib/orchestration-assets.mjs +249 -0
  5. package/lib/scaffold.mjs +89 -0
  6. package/package.json +8 -19
  7. package/.dockerignore +0 -8
  8. package/.env.example +0 -50
  9. package/.gitignore +0 -16
  10. package/AGENTS.md +0 -86
  11. package/SDD_SKILL.md +0 -589
  12. package/compose.yml +0 -206
  13. package/infra/compose/.env.dev.example +0 -28
  14. package/infra/compose/.env.prod.example +0 -29
  15. package/infra/compose/README.md +0 -35
  16. package/infra/compose/dev.yml +0 -125
  17. package/infra/compose/prod.yml +0 -126
  18. package/infra/terraform/README.md +0 -34
  19. package/infra/terraform/aws/data/.terraform.lock.hcl +0 -25
  20. package/infra/terraform/aws/data/README.md +0 -18
  21. package/infra/terraform/aws/data/main.tf +0 -147
  22. package/infra/terraform/aws/data/outputs.tf +0 -14
  23. package/infra/terraform/aws/data/variables.tf +0 -57
  24. package/infra/terraform/aws/data/versions.tf +0 -10
  25. package/infra/terraform/aws/domain/.terraform.lock.hcl +0 -25
  26. package/infra/terraform/aws/domain/README.md +0 -20
  27. package/infra/terraform/aws/domain/env/dev.tfvars.example +0 -6
  28. package/infra/terraform/aws/domain/env/prod.tfvars.example +0 -7
  29. package/infra/terraform/aws/domain/main.tf +0 -149
  30. package/infra/terraform/aws/domain/outputs.tf +0 -29
  31. package/infra/terraform/aws/domain/variables.tf +0 -58
  32. package/infra/terraform/aws/domain/versions.tf +0 -10
  33. package/infra/terraform/openstack/README.md +0 -38
  34. package/infra/terraform/openstack/dev/.terraform.lock.hcl +0 -24
  35. package/infra/terraform/openstack/dev/README.md +0 -18
  36. package/infra/terraform/openstack/dev/main.tf +0 -49
  37. package/infra/terraform/openstack/dev/providers.tf +0 -15
  38. package/infra/terraform/openstack/dev/terraform.tfvars.example +0 -54
  39. package/infra/terraform/openstack/dev/variables.tf +0 -210
  40. package/infra/terraform/openstack/dev/versions.tf +0 -10
  41. package/infra/terraform/openstack/modules/environment_host/main.tf +0 -143
  42. package/infra/terraform/openstack/modules/environment_host/outputs.tf +0 -25
  43. package/infra/terraform/openstack/modules/environment_host/templates/docker-host-user-data.sh.tftpl +0 -40
  44. package/infra/terraform/openstack/modules/environment_host/variables.tf +0 -145
  45. package/infra/terraform/openstack/modules/environment_host/versions.tf +0 -7
  46. package/infra/terraform/openstack/prod/.terraform.lock.hcl +0 -24
  47. package/infra/terraform/openstack/prod/README.md +0 -18
  48. package/infra/terraform/openstack/prod/main.tf +0 -49
  49. package/infra/terraform/openstack/prod/providers.tf +0 -15
  50. package/infra/terraform/openstack/prod/terraform.tfvars.example +0 -55
  51. package/infra/terraform/openstack/prod/variables.tf +0 -210
  52. package/infra/terraform/openstack/prod/versions.tf +0 -10
  53. package/infra/terraform/openstack/server/.terraform.lock.hcl +0 -45
  54. package/infra/terraform/openstack/server/README.md +0 -47
  55. package/infra/terraform/openstack/server/main.tf +0 -161
  56. package/infra/terraform/openstack/server/outputs.tf +0 -30
  57. package/infra/terraform/openstack/server/providers.tf +0 -30
  58. package/infra/terraform/openstack/server/templates/server-user-data.sh.tftpl +0 -50
  59. package/infra/terraform/openstack/server/variables.tf +0 -233
  60. package/infra/terraform/openstack/server/zz_aspace.auto.tfvars.example.json +0 -29
  61. package/pnpm-workspace.yaml +0 -2
  62. package/scripts/dev/audit_sdd_build_ast.py +0 -277
  63. package/sdd/01_planning/01_feature/INDEX.md +0 -16
  64. package/sdd/01_planning/01_feature/README.md +0 -76
  65. package/sdd/01_planning/01_feature/alerts_feature_spec.md +0 -55
  66. package/sdd/01_planning/01_feature/auth_feature_spec.md +0 -57
  67. package/sdd/01_planning/01_feature/catalog_feature_spec.md +0 -61
  68. package/sdd/01_planning/01_feature/fulfillment_feature_spec.md +0 -58
  69. package/sdd/01_planning/01_feature/health_feature_spec.md +0 -52
  70. package/sdd/01_planning/01_feature/inventory_feature_spec.md +0 -60
  71. package/sdd/01_planning/01_feature/order_feature_spec.md +0 -63
  72. package/sdd/01_planning/01_feature/shipping_feature_spec.md +0 -55
  73. package/sdd/01_planning/01_feature/support_feature_spec.md +0 -53
  74. package/sdd/01_planning/01_feature/user_feature_spec.md +0 -54
  75. package/sdd/01_planning/02_screen/INDEX.md +0 -13
  76. package/sdd/01_planning/02_screen/README.md +0 -41
  77. package/sdd/01_planning/02_screen/admin_screen_spec.pdf +0 -0
  78. package/sdd/01_planning/02_screen/assets/README.md +0 -16
  79. package/sdd/01_planning/02_screen/assets/example/README.md +0 -13
  80. package/sdd/01_planning/02_screen/landing_screen_spec.pdf +0 -0
  81. package/sdd/01_planning/02_screen/mobile_screen_spec.pdf +0 -0
  82. package/sdd/01_planning/02_screen/web_screen_spec.pdf +0 -0
  83. package/sdd/01_planning/03_architecture/INDEX.md +0 -9
  84. package/sdd/01_planning/03_architecture/README.md +0 -25
  85. package/sdd/01_planning/03_architecture/architecture_document_structure.md +0 -77
  86. package/sdd/01_planning/03_architecture/backend/README.md +0 -10
  87. package/sdd/01_planning/03_architecture/frontend/README.md +0 -12
  88. package/sdd/01_planning/03_architecture/infra/README.md +0 -10
  89. package/sdd/01_planning/03_architecture/tech-research/README.md +0 -4
  90. package/sdd/01_planning/03_architecture/templates_system_architecture.md +0 -84
  91. package/sdd/01_planning/04_data/INDEX.md +0 -4
  92. package/sdd/01_planning/04_data/README.md +0 -10
  93. package/sdd/01_planning/04_data/templates_data_modeling.md +0 -119
  94. package/sdd/01_planning/05_api/README.md +0 -12
  95. package/sdd/01_planning/05_api/templates_api_contract.md +0 -90
  96. package/sdd/01_planning/06_iac/README.md +0 -11
  97. package/sdd/01_planning/06_iac/templates_runtime_and_cicd_baseline.md +0 -46
  98. package/sdd/01_planning/07_integration/README.md +0 -11
  99. package/sdd/01_planning/07_integration/templates_frontend_api_integration.md +0 -46
  100. package/sdd/01_planning/08_nonfunctional/README.md +0 -7
  101. package/sdd/01_planning/09_security/README.md +0 -7
  102. package/sdd/01_planning/10_test/README.md +0 -12
  103. package/sdd/01_planning/10_test/templates_test_strategy.md +0 -60
  104. package/sdd/01_planning/INDEX.md +0 -19
  105. package/sdd/01_planning/README.md +0 -17
  106. package/sdd/02_plan/01_feature/README.md +0 -34
  107. package/sdd/02_plan/01_feature/_feature_todo_template.md +0 -29
  108. package/sdd/02_plan/02_screen/INDEX.md +0 -19
  109. package/sdd/02_plan/02_screen/README.md +0 -39
  110. package/sdd/02_plan/02_screen/_screen_todo_template.md +0 -60
  111. package/sdd/02_plan/03_architecture/README.md +0 -23
  112. package/sdd/02_plan/03_architecture/architecture_document_governance.md +0 -40
  113. package/sdd/02_plan/03_architecture/build_ast_runtime_tree_governance.md +0 -53
  114. package/sdd/02_plan/03_architecture/repository_governance.md +0 -39
  115. package/sdd/02_plan/03_architecture/runtime_and_structure_governance.md +0 -38
  116. package/sdd/02_plan/03_architecture/templates-hexagonal-template-architecture.md +0 -9
  117. package/sdd/02_plan/03_architecture/toolchain_governance.md +0 -98
  118. package/sdd/02_plan/04_data/README.md +0 -5
  119. package/sdd/02_plan/05_api/README.md +0 -5
  120. package/sdd/02_plan/06_iac/README.md +0 -11
  121. package/sdd/02_plan/06_iac/dev_runtime_delivery.md +0 -36
  122. package/sdd/02_plan/06_iac/template_runtime_delivery.md +0 -50
  123. package/sdd/02_plan/07_integration/README.md +0 -5
  124. package/sdd/02_plan/07_integration/frontend_live_integration.md +0 -31
  125. package/sdd/02_plan/08_nonfunctional/README.md +0 -5
  126. package/sdd/02_plan/08_nonfunctional/repository_hygiene.md +0 -26
  127. package/sdd/02_plan/09_security/README.md +0 -5
  128. package/sdd/02_plan/10_test/README.md +0 -11
  129. package/sdd/02_plan/10_test/regression_verification.md +0 -39
  130. package/sdd/02_plan/10_test/templates/README.md +0 -8
  131. package/sdd/02_plan/10_test/templates/ui_parity_web_contract.template.yaml +0 -23
  132. package/sdd/02_plan/10_test/verification_strategy.md +0 -43
  133. package/sdd/02_plan/99_generated/from_planning/ui_parity/.gitkeep +0 -1
  134. package/sdd/02_plan/README.md +0 -40
  135. package/sdd/03_build/01_feature/README.md +0 -20
  136. package/sdd/03_build/01_feature/domain/README.md +0 -3
  137. package/sdd/03_build/01_feature/domain/account_and_access.md +0 -20
  138. package/sdd/03_build/01_feature/domain/catalog_and_inventory.md +0 -20
  139. package/sdd/03_build/01_feature/domain/ordering_and_fulfillment.md +0 -21
  140. package/sdd/03_build/01_feature/domain/support_and_observability.md +0 -21
  141. package/sdd/03_build/01_feature/domain_surfaces.md +0 -28
  142. package/sdd/03_build/01_feature/service/README.md +0 -3
  143. package/sdd/03_build/01_feature/service/admin_surface.md +0 -15
  144. package/sdd/03_build/01_feature/service/landing_surface.md +0 -13
  145. package/sdd/03_build/01_feature/service/mobile_surface.md +0 -14
  146. package/sdd/03_build/01_feature/service/web_surface.md +0 -14
  147. package/sdd/03_build/02_screen/README.md +0 -25
  148. package/sdd/03_build/02_screen/_screen_build_template.md +0 -26
  149. package/sdd/03_build/02_screen/admin/README.md +0 -5
  150. package/sdd/03_build/02_screen/landing/README.md +0 -5
  151. package/sdd/03_build/02_screen/mobile/README.md +0 -5
  152. package/sdd/03_build/02_screen/web/README.md +0 -5
  153. package/sdd/03_build/03_architecture/README.md +0 -10
  154. package/sdd/03_build/03_architecture/architecture_document_governance.md +0 -30
  155. package/sdd/03_build/03_architecture/build_ast_runtime_tree_governance.md +0 -24
  156. package/sdd/03_build/03_architecture/repository_governance.md +0 -18
  157. package/sdd/03_build/03_architecture/toolchain_governance.md +0 -36
  158. package/sdd/03_build/06_iac/README.md +0 -3
  159. package/sdd/03_build/06_iac/dev_runtime_delivery.md +0 -10
  160. package/sdd/03_build/06_iac/template_runtime_delivery.md +0 -49
  161. package/sdd/03_build/07_integration/README.md +0 -3
  162. package/sdd/03_build/07_integration/frontend_live_integration.md +0 -11
  163. package/sdd/03_build/08_nonfunctional/README.md +0 -3
  164. package/sdd/03_build/08_nonfunctional/repository_hygiene.md +0 -10
  165. package/sdd/03_build/10_test/README.md +0 -9
  166. package/sdd/03_build/10_test/regression_verification.md +0 -16
  167. package/sdd/03_build/10_test/verification_harness.md +0 -11
  168. package/sdd/03_build/README.md +0 -35
  169. package/sdd/03_verify/01_feature/README.md +0 -5
  170. package/sdd/03_verify/01_feature/domain_verification.md +0 -14
  171. package/sdd/03_verify/01_feature/service_verification.md +0 -22
  172. package/sdd/03_verify/02_screen/README.md +0 -6
  173. package/sdd/03_verify/02_screen/_screen_verify_template.md +0 -20
  174. package/sdd/03_verify/02_screen/admin/README.md +0 -4
  175. package/sdd/03_verify/02_screen/landing/README.md +0 -4
  176. package/sdd/03_verify/02_screen/mobile/README.md +0 -4
  177. package/sdd/03_verify/02_screen/web/README.md +0 -4
  178. package/sdd/03_verify/03_architecture/README.md +0 -10
  179. package/sdd/03_verify/03_architecture/architecture_document_governance.md +0 -15
  180. package/sdd/03_verify/03_architecture/build_ast_runtime_tree_governance.md +0 -28
  181. package/sdd/03_verify/03_architecture/repository_governance.md +0 -16
  182. package/sdd/03_verify/03_architecture/toolchain_governance.md +0 -58
  183. package/sdd/03_verify/06_iac/README.md +0 -3
  184. package/sdd/03_verify/06_iac/dev_runtime_delivery.md +0 -10
  185. package/sdd/03_verify/06_iac/template_runtime_delivery.md +0 -42
  186. package/sdd/03_verify/07_integration/README.md +0 -3
  187. package/sdd/03_verify/07_integration/frontend_live_integration.md +0 -16
  188. package/sdd/03_verify/08_nonfunctional/README.md +0 -3
  189. package/sdd/03_verify/08_nonfunctional/repository_hygiene.md +0 -14
  190. package/sdd/03_verify/10_test/README.md +0 -9
  191. package/sdd/03_verify/10_test/regression_verification.md +0 -16
  192. package/sdd/03_verify/10_test/ui_parity/README.md +0 -4
  193. package/sdd/03_verify/10_test/ui_parity/loop_runs/.gitkeep +0 -0
  194. package/sdd/03_verify/10_test/ui_parity/reference/.gitkeep +0 -0
  195. package/sdd/03_verify/10_test/ui_parity/staged_runs/.gitkeep +0 -0
  196. package/sdd/03_verify/10_test/verification_harness.md +0 -17
  197. package/sdd/03_verify/README.md +0 -22
  198. package/sdd/05_operate/01_runbooks/.gitkeep +0 -1
  199. package/sdd/05_operate/01_runbooks/README.md +0 -4
  200. package/sdd/05_operate/02_delivery_status/README.md +0 -4
  201. package/sdd/05_operate/02_delivery_status/service_status.md +0 -16
  202. package/sdd/05_operate/README.md +0 -12
  203. package/sdd/99_toolchain/01_automation/.gitkeep +0 -1
  204. package/sdd/99_toolchain/01_automation/README.md +0 -76
  205. package/sdd/99_toolchain/01_automation/agentic-dev/analyze_proof_results.py +0 -132
  206. package/sdd/99_toolchain/01_automation/agentic-dev/analyze_route_gap.py +0 -85
  207. package/sdd/99_toolchain/01_automation/agentic-dev/assets/repo-contract.template.json +0 -75
  208. package/sdd/99_toolchain/01_automation/agentic-dev/bootstrap_frontend_parity.sh +0 -84
  209. package/sdd/99_toolchain/01_automation/agentic-dev/init_frontend_parity.sh +0 -33
  210. package/sdd/99_toolchain/01_automation/agentic-dev/init_repo_contract.sh +0 -51
  211. package/sdd/99_toolchain/01_automation/agentic-dev/repo-contract.json +0 -76
  212. package/sdd/99_toolchain/01_automation/agentic-dev/resolve_frontend_target.py +0 -52
  213. package/sdd/99_toolchain/01_automation/agentic-dev/resolve_repo_contract.py +0 -56
  214. package/sdd/99_toolchain/01_automation/agentic-dev/run_frontend_target.sh +0 -100
  215. package/sdd/99_toolchain/01_automation/agentic-dev/run_repo_phase.sh +0 -140
  216. package/sdd/99_toolchain/01_automation/agentic-dev/validate_json_schema.py +0 -39
  217. package/sdd/99_toolchain/01_automation/agentic-parity-harness-design.md +0 -291
  218. package/sdd/99_toolchain/01_automation/assets/admin_screen_capture/dashboard.png +0 -0
  219. package/sdd/99_toolchain/01_automation/assets/admin_screen_capture/login.png +0 -0
  220. package/sdd/99_toolchain/01_automation/assets/admin_screen_capture/queue.png +0 -0
  221. package/sdd/99_toolchain/01_automation/assets/admin_screen_capture/support.png +0 -0
  222. package/sdd/99_toolchain/01_automation/assets/landing_screen_capture/home.png +0 -0
  223. package/sdd/99_toolchain/01_automation/assets/landing_screen_capture/login.png +0 -0
  224. package/sdd/99_toolchain/01_automation/assets/landing_screen_capture/workspace.png +0 -0
  225. package/sdd/99_toolchain/01_automation/assets/mobile_screen_capture/dashboard.png +0 -0
  226. package/sdd/99_toolchain/01_automation/assets/mobile_screen_capture/fulfillment.png +0 -0
  227. package/sdd/99_toolchain/01_automation/assets/mobile_screen_capture/login.png +0 -0
  228. package/sdd/99_toolchain/01_automation/assets/web_screen_capture/dashboard.png +0 -0
  229. package/sdd/99_toolchain/01_automation/assets/web_screen_capture/login.png +0 -0
  230. package/sdd/99_toolchain/01_automation/assets/web_screen_capture/orders.png +0 -0
  231. package/sdd/99_toolchain/01_automation/build_asset_recipes.py +0 -10
  232. package/sdd/99_toolchain/01_automation/build_screen_spec_pdf.py +0 -427
  233. package/sdd/99_toolchain/01_automation/capture_screen_assets.mjs +0 -148
  234. package/sdd/99_toolchain/01_automation/harness-layout.md +0 -34
  235. package/sdd/99_toolchain/01_automation/parity-execution-tooling-design.md +0 -319
  236. package/sdd/99_toolchain/01_automation/playwright_exactness_manifest.py +0 -21
  237. package/sdd/99_toolchain/01_automation/run_playwright_exactness.py +0 -87
  238. package/sdd/99_toolchain/01_automation/screen_spec_manifest.py +0 -321
  239. package/sdd/99_toolchain/01_automation/spec_asset_builder.py +0 -274
  240. package/sdd/99_toolchain/01_automation/ui-contract-projection.md +0 -79
  241. package/sdd/99_toolchain/01_automation/ui-parity/README.md +0 -60
  242. package/sdd/99_toolchain/01_automation/ui-parity/cli/extract-reference-pages.mjs +0 -2
  243. package/sdd/99_toolchain/01_automation/ui-parity/cli/materialize-reference-assets.mjs +0 -58
  244. package/sdd/99_toolchain/01_automation/ui-parity/cli/normalize-reference-assets.mjs +0 -2
  245. package/sdd/99_toolchain/01_automation/ui-parity/cli/route-gap-report.mjs +0 -187
  246. package/sdd/99_toolchain/01_automation/ui-parity/cli/run-proof.mjs +0 -50
  247. package/sdd/99_toolchain/01_automation/ui-parity/cli/scaffold-contract.mjs +0 -62
  248. package/sdd/99_toolchain/01_automation/ui-parity/cli/upload-parity1.mjs +0 -2
  249. package/sdd/99_toolchain/01_automation/ui-parity/contracts/collector-metadata.schema.json +0 -33
  250. package/sdd/99_toolchain/01_automation/ui-parity/contracts/proof-result.schema.json +0 -76
  251. package/sdd/99_toolchain/01_automation/ui-parity/contracts/route-gap-report.schema.json +0 -95
  252. package/sdd/99_toolchain/01_automation/ui-parity/core/capture-runner.mjs +0 -55
  253. package/sdd/99_toolchain/01_automation/ui-parity/core/load-adapter.mjs +0 -25
  254. package/sdd/99_toolchain/01_automation/ui-parity/core/load-contract.mjs +0 -81
  255. package/sdd/99_toolchain/01_automation/ui-parity/core/paths.mjs +0 -23
  256. package/sdd/99_toolchain/01_automation/ui-parity/core/proof-runner.mjs +0 -255
  257. package/sdd/99_toolchain/01_automation/ui-parity/interfaces/ui-parity-artifact-layout.md +0 -23
  258. package/sdd/99_toolchain/01_automation/ui-parity/interfaces/ui-parity-proof-interface.md +0 -60
  259. package/sdd/99_toolchain/01_automation/ui-parity/interfaces/ui-parity-route-gap-interface.md +0 -82
  260. package/sdd/99_toolchain/01_automation/ui-parity/runtime/playwright-runtime.mjs +0 -16
  261. package/sdd/99_toolchain/01_automation/ui-parity/runtime/static-runtime.mjs +0 -6
  262. package/sdd/99_toolchain/02_policies/.gitkeep +0 -1
  263. package/sdd/99_toolchain/02_policies/build-ast-governance-policy.md +0 -22
  264. package/sdd/99_toolchain/02_policies/compose-runtime-baseline-policy.md +0 -24
  265. package/sdd/99_toolchain/02_policies/convention-storage-policy.md +0 -26
  266. package/sdd/99_toolchain/02_policies/main-push-before-dev-deploy-policy.md +0 -27
  267. package/sdd/99_toolchain/02_policies/regression-verification-policy.md +0 -22
  268. package/sdd/99_toolchain/03_templates/.gitkeep +0 -1
  269. package/sdd/99_toolchain/03_templates/asset_recipe_manifest.example.py +0 -38
  270. package/sdd/99_toolchain/03_templates/generated_assets/README.md +0 -11
  271. package/sdd/99_toolchain/03_templates/generated_assets/example-brand-lockup.svg +0 -3
  272. package/sdd/99_toolchain/03_templates/generated_assets/example-brand-mark.svg +0 -3
  273. package/sdd/99_toolchain/03_templates/generated_assets/example-brand-wordmark.svg +0 -3
  274. package/sdd/99_toolchain/03_templates/playwright_exactness_manifest.example.py +0 -21
  275. package/sdd/99_toolchain/README.md +0 -23
  276. package/sdd/README.md +0 -21
@@ -1,12 +0,0 @@
1
- # 10 Test
2
-
3
- 테스트 원천 목록을 둔다.
4
-
5
- - frontend build matrix
6
- - api pytest matrix
7
- - auth runtime smoke
8
- - compose validation
9
-
10
- ## Canonical Docs
11
-
12
- - [templates_test_strategy.md](./templates_test_strategy.md)
@@ -1,60 +0,0 @@
1
- # templates test strategy
2
-
3
- - 작성 버전: 1.0.0
4
-
5
- ## Purpose
6
-
7
- template baseline을 유지하기 위한 테스트 전략을 정의한다.
8
-
9
- ## 1. Backend
10
-
11
- - `server/tests/e2e/test_domain_feature_flows.py`
12
- - `AUT-F001`
13
- - `AUT-F002`
14
- - `USR-F001`
15
- - `USR-F002`
16
- - `USR-F003`
17
- - `CAT-F001`
18
- - `CAT-F003`
19
- - `CAT-F004`
20
- - `CAT-F005`
21
- - `INV-F001`
22
- - `INV-F002`
23
- - `INV-F003`
24
- - `INV-F004`
25
- - `INV-F005`
26
- - `INV-F006`
27
- - `ORD-F001`
28
- - `ORD-F002`
29
- - `ORD-F003`
30
- - `ORD-F004`
31
- - `ORD-F005`
32
- - `ORD-F006`
33
- - `SHP-F001`
34
- - `SHP-F002`
35
- - `SHP-F003`
36
- - `ALR-F001`
37
- - `ALR-F002`
38
- - `ALR-F003`
39
- - `SUP-F001`
40
- - `SUP-F002`
41
- - `SUP-F003`
42
- - `FUL-F001`
43
- - `FUL-F002`
44
- - `FUL-F003`
45
- - `server/tests/test_health.py`
46
- - `HLT-F001`
47
- - `HLT-F002`
48
- - auth/user smoke
49
-
50
- ## 2. Frontend
51
-
52
- - `web`, `admin`, `mobile`, `landing`는 각 서비스별 production build를 통과해야 한다.
53
- - screen spec은 `WEB-S001`, `ADM-S001`, `MOB-S001`, `LND-S001` 규칙으로 구현 route와 관련 feature를 함께 검증한다.
54
- - parity harness가 활성화되면 route-gap과 proof artifact를 추가 검증한다.
55
-
56
- ## 3. CI Gate
57
-
58
- - backend: `./.venv/bin/python -m pytest -q` 또는 CI 환경의 `uv run pytest -q`
59
- - frontend: `pnpm build` matrix
60
- - toolchain: `build_screen_spec_pdf.py`, `capture_screen_assets.mjs`, `new_plan.sh` shell validation
@@ -1,19 +0,0 @@
1
- # Planning Index
2
-
3
- - [01_feature/INDEX.md](./01_feature/INDEX.md)
4
- - [02_screen/INDEX.md](./02_screen/INDEX.md)
5
- - [03_architecture/INDEX.md](./03_architecture/INDEX.md)
6
- - [04_data/INDEX.md](./04_data/INDEX.md)
7
- - [05_api/README.md](./05_api/README.md)
8
- - [06_iac/README.md](./06_iac/README.md)
9
- - [07_integration/README.md](./07_integration/README.md)
10
- - [08_nonfunctional/README.md](./08_nonfunctional/README.md)
11
- - [09_security/README.md](./09_security/README.md)
12
- - [10_test/README.md](./10_test/README.md)
13
-
14
- ## Structure Rule
15
-
16
- - `01_feature`, `02_screen`는 실제 서비스 표면(`web`, `mobile`, `admin`, `landing`) 기준으로 유지한다.
17
- - `03_architecture` 이후는 서비스별 실산출물이 없으면 common-first로 유지한다.
18
- - `03_architecture`는 공통 문서를 먼저 두고 필요 시 `frontend/`, `backend/`, `infra/`, `tech-research/`로 세분화한다.
19
- - 데이터 모델링은 `04_data`에서 다루고 architecture 문서에는 중복 기록하지 않는다.
@@ -1,17 +0,0 @@
1
- # Planning Governance
2
-
3
- ## Purpose
4
-
5
- - `sdd/01_planning/`은 현재 구현과 검수의 기준이 되는 canonical spec을 유지한다.
6
- - feature, screen, architecture, data, API, IAC, integration, nonfunctional, security, test planning 모두 현재 기준만 남긴다.
7
-
8
- ## Final-Only Rule
9
-
10
- - planning도 날짜별 작업 메모나 히스토리성 보조 문서를 쌓지 않는다.
11
- - 계속 참고할 가치가 있는 리서치만 현재형 문서로 유지한다.
12
- - source reference가 필요하면 현재 canonical source만 남기고, raw capture log나 일회성 추출 로그는 두지 않는다.
13
-
14
- ## Structure Rule
15
-
16
- - `01_feature`, `02_screen`는 실제 서비스 표면 기준으로 유지한다.
17
- - `03_architecture` 이후 planning 폴더는 서비스별 실산출물이 없으면 common-first 구조로 유지한다.
@@ -1,34 +0,0 @@
1
- # Feature TODO Rule
2
-
3
- ## Common Rule
4
-
5
- - 이 폴더는 `sdd/02_plan` 아래에서 에이전트의 현재 개발 계획을 관리한다.
6
- - 다른 `02_plan` 폴더와 동일하게 `README.md + durable TODO 파일`만 유지하고, dated plan history는 두지 않는다.
7
-
8
- ## Canonical Rule
9
-
10
- - 기능 계획은 domain별 durable TODO 파일로 관리한다.
11
- - 신규 작업이 생겨도 날짜별 파일을 추가하지 않는다.
12
- - 같은 domain 파일 안에서는 canonical 기능코드 기준 표만 계속 갱신한다.
13
- - service feature spec은 source reference로만 사용하고, active TODO는 domain 파일만 유지한다.
14
-
15
- ## Naming
16
-
17
- - 파일명은 날짜 prefix를 쓰지 않는다.
18
- - 권장 형식: `{domain}_todos.md`
19
-
20
- ## Location
21
-
22
- - active feature TODO는 `sdd/02_plan/01_feature/` root에 둔다.
23
-
24
- ## Minimum Sections
25
-
26
- - domain summary
27
- - feature items
28
- - acceptance criteria
29
- - current notes
30
- - latest verification
31
-
32
- ## Template
33
-
34
- - [`_feature_todo_template.md`](_feature_todo_template.md)
@@ -1,29 +0,0 @@
1
- # {domain code} {domain name}
2
-
3
- - Owner: Codex
4
- - Status: active
5
-
6
- ## Domain Summary
7
-
8
- - domain code:
9
- - canonical source:
10
- - update rule: 이 파일 안에서 feature code 기준으로 계속 갱신한다.
11
-
12
- ## Feature Items
13
-
14
- | Feature Code | Use Case | Status | Current Notes |
15
- | --- | --- | --- | --- |
16
- | `{DOMAIN}-F001` | | `planned` | |
17
-
18
- ## Acceptance Criteria
19
-
20
- - [ ] 이 파일이 해당 domain feature TODO의 single source of truth로 유지된다.
21
- - [ ] 신규 작업은 해당 feature code row와 current notes만 갱신한다.
22
-
23
- ## Current Notes
24
-
25
- - TODO는 canonical domain feature code 기준으로만 유지한다.
26
-
27
- ## Latest Verification
28
-
29
- - current plan normalization reference: `sdd/02_plan/01_feature/<domain>_todos.md`
@@ -1,19 +0,0 @@
1
- # Screen TODO Index
2
-
3
- ## Canonical Sources
4
-
5
- - [mobile_screen_spec.pdf](../../01_planning/02_screen/mobile_screen_spec.pdf)
6
- - [web_screen_spec.pdf](../../01_planning/02_screen/web_screen_spec.pdf)
7
- - [admin_screen_spec.pdf](../../01_planning/02_screen/admin_screen_spec.pdf)
8
- - [landing_screen_spec.pdf](../../01_planning/02_screen/landing_screen_spec.pdf)
9
-
10
- ## Current Planning Templates
11
-
12
- - [README.md](./README.md)
13
- - [_screen_todo_template.md](./_screen_todo_template.md)
14
-
15
- ## Naming Rule
16
-
17
- - active screen plan file: `<service>_todos.md`
18
- - screen section identifier inside file: `{SERVICE}-S{NNN}`
19
- - mobile legacy source key는 필요할 때만 문서 내부에서 `APP_###` field로 기록한다.
@@ -1,39 +0,0 @@
1
- # Screen TODO Rule
2
-
3
- ## Common Rule
4
-
5
- - 이 폴더는 `sdd/02_plan` 아래에서 에이전트의 현재 개발 계획을 관리한다.
6
- - 다른 `02_plan` 폴더와 동일하게 `README.md + durable TODO 파일`만 유지하고, dated plan history는 두지 않는다.
7
- - 개발계가 있는 화면 작업은 `구현 -> build -> DEV(개발계) 배포 -> DEV 검수 -> 같은 TODO 파일 갱신`을 기본 루틴으로 둔다.
8
-
9
- ## Canonical Rule
10
-
11
- - 화면 계획은 service별 durable TODO 파일로 관리한다.
12
- - `01_feature`와 동일하게 날짜별 작업 문서를 계속 추가하지 않는다.
13
- - 같은 service 파일 안에서 화면코드 기준으로 계속 갱신한다.
14
- - mobile source key인 `APP_###`는 파일명이 아니라 문서 내부 field로만 기록한다.
15
- - 과거 screen plan 문서는 별도 보관하지 않고, 현재 기준 README와 service TODO만 유지한다.
16
-
17
- ## Location
18
-
19
- - 서비스별 화면 TODO는 `sdd/02_plan/02_screen/` root에 둔다.
20
- - 예:
21
- - `sdd/02_plan/02_screen/mobile_todos.md`
22
- - `sdd/02_plan/02_screen/web_todos.md`
23
-
24
- ## Naming
25
-
26
- - 파일명은 날짜 prefix를 쓰지 않는다.
27
- - 권장 형식: `{service}_todos.md`
28
-
29
- ## Minimum Sections
30
-
31
- - service summary
32
- - shared constraints or baseline
33
- - screen items
34
- - delivery phases or backlog
35
- - latest verification references
36
-
37
- ## Template
38
-
39
- - [`_screen_todo_template.md`](_screen_todo_template.md)
@@ -1,60 +0,0 @@
1
- # {service} screen TODO
2
-
3
- - Owner: Codex
4
- - Status: active
5
-
6
- ## Service Summary
7
-
8
- - service:
9
- - canonical source:
10
- - update rule: 이 파일 안에서 화면코드 기준으로 계속 갱신한다.
11
-
12
- ## Shared Constraints
13
-
14
- - source key rule:
15
- - route baseline:
16
- - shared API/modeling note:
17
-
18
- ## Screen Items
19
-
20
- ### {screen code} {screen name}
21
-
22
- #### Screen Summary
23
-
24
- - source key:
25
- - route:
26
- - retained runtime tree:
27
- - local exactness suite id:
28
- - canonical runner command: `python3 sdd/99_toolchain/01_automation/run_playwright_exactness.py --suite <suite-id> --base-url <url>`
29
-
30
- #### Acceptance Criteria
31
-
32
- - [ ]
33
- - [ ] relevant builder/design guide baseline is current for this surface
34
- - [ ] Playwright exactness suite exists or is extended in the same task
35
- - [ ] verify artifact path (`json/png`) is identified before implementation closes
36
-
37
- #### Open TODO
38
-
39
- - [ ]
40
-
41
- #### Current Notes
42
-
43
- - current scope/status notes only
44
- - use Browser Use/manual capture only as supplemental diagnosis when a Playwright suite already exists
45
-
46
- #### Latest Verification
47
-
48
- - current build/verify references:
49
- - latest exactness command:
50
- - latest exactness artifact:
51
-
52
- ## Delivery Phases
53
-
54
- - `P0`:
55
- - `P1`:
56
- - `P2`:
57
-
58
- ## Current Notes
59
-
60
- - current service-level notes only
@@ -1,23 +0,0 @@
1
- # Architecture Planning
2
-
3
- - 이 폴더는 `sdd/02_plan` 아래에서 에이전트의 현재 개발 계획을 관리한다.
4
- - 이 폴더는 구조, 리포지토리 거버넌스, 런타임 정렬, 툴체인 규칙 같은 횡단 계획을 durable 문서로 유지한다.
5
- - 날짜 기반 작업 메모는 남기지 않고, 현재 적용돼야 하는 규칙과 backlog만 덮어쓴다.
6
-
7
- ## Plan Rule
8
-
9
- - 다른 `02_plan` 폴더와 동일하게 `README.md + durable 문서`만 유지하고, dated plan history는 두지 않는다.
10
- - `sdd/02_plan`은 현재 실행해야 할 기준만 남기고, 과거 계획 히스토리는 보관하지 않는다.
11
- - 개발계가 있는 대상은 `구현 -> build -> main push -> DEV(개발계) 배포 -> DEV 검수 -> 문서 갱신`을 기본 루틴으로 본다.
12
- - feature는 domain TODO 파일 안에서 기능코드 기준으로 관리한다.
13
- - screen은 service TODO 파일 안에서 화면코드 기준으로 관리한다.
14
- - architecture, IAC, test도 dated memo 대신 section README와 durable governance 문서에서 현재 규칙만 유지한다.
15
- - `02_plan` section 구조와 README 규칙은 final-only 기준으로 유지한다.
16
-
17
- ## Current Documents
18
-
19
- - [architecture_document_governance.md](architecture_document_governance.md)
20
- - [repository_governance.md](repository_governance.md)
21
- - [runtime_and_structure_governance.md](runtime_and_structure_governance.md)
22
- - [toolchain_governance.md](toolchain_governance.md)
23
- - [templates-hexagonal-template-architecture.md](templates-hexagonal-template-architecture.md)
@@ -1,40 +0,0 @@
1
- # architecture document governance
2
-
3
- - Owner: Codex
4
- - Status: active
5
-
6
- ## Scope
7
-
8
- - In scope:
9
- - `sdd/01_planning/03_architecture` 문서 구조와 경계를 공통 규칙으로 정의한다.
10
- - 아키텍처 planning 문서는 공통/일반화된 구조를 우선 기록하되, 필요 시 `frontend`, `backend`, `infra`, `tech-research`로 특화 문서를 둔다.
11
- - 프런트엔드, 백엔드, 인프라의 구조/패턴/구현 선택을 architecture 범위로 유지한다.
12
- - 데이터 모델링 경계는 `sdd/01_planning/04_data`로 분리한다.
13
- - Out of scope:
14
- - feature별 business rule 상세
15
- - screen별 route/CTA/전이 상세
16
- - entity/schema/ERD 수준의 데이터 모델링 상세
17
-
18
- ## Acceptance Criteria
19
-
20
- - [ ] `03_architecture`는 공통 아키텍처 문서와 특화 아키텍처 문서를 함께 수용하는 구조로 설명된다.
21
- - [ ] frontend/backend/infra가 architecture 범위에 포함된다는 점이 planning 문서에 명시된다.
22
- - [ ] data modeling은 `04_data` 경계로 분리된다는 점이 planning 문서에 명시된다.
23
-
24
- ## Current Notes
25
-
26
- - architecture 문서는 우선 공통 구조를 설명하고, 세부 구현 논점이 필요할 때만 영역별 문서로 내려간다.
27
- - frontend architecture는 모듈화, 컴포넌트, store/state, domain/use case, UI/UX, storage, API adapter 패턴을 다룬다.
28
- - backend architecture는 DDD context 구조, context 내부 계층, 3-layer, hexagonal, monolith/MSA/EDA/CQRS 같은 패턴과 실제 구현체 선택을 다룬다.
29
- - infra architecture는 컨테이너, 오케스트레이션, 데이터베이스, 네트워크, 이중화, 멀티리전 같은 서비스 기반 구조를 다룬다.
30
-
31
- ## Validation
32
-
33
- - current references:
34
- - `sdd/01_planning/03_architecture/README.md`
35
- - `sdd/01_planning/03_architecture/INDEX.md`
36
- - `sdd/01_planning/03_architecture/architecture_document_structure.md`
37
- - `sdd/01_planning/03_architecture/frontend/README.md`
38
- - `sdd/01_planning/03_architecture/backend/README.md`
39
- - `sdd/01_planning/03_architecture/infra/README.md`
40
- - `sdd/01_planning/04_data/README.md`
@@ -1,53 +0,0 @@
1
- # build ast runtime tree governance
2
-
3
- - Owner: Codex
4
- - Status: active
5
-
6
- ## Scope
7
-
8
- - In scope:
9
- - `sdd/03_build` service summary를 실제 템플릿 runtime assembly 기준으로 재정렬한다.
10
- - Claude/Codex/Ralph 하네스가 동일한 current-state build reading 규칙을 따르도록 canonical policy를 추가한다.
11
- - `scripts/dev/audit_sdd_build_ast.py`를 템플릿 정본 gate로 유지한다.
12
- - provider-first infra baseline과 build/runtime/toolchain 문서 간의 current-state drift를 줄인다.
13
- - Out of scope:
14
- - 템플릿 앱/서버의 기능 요구사항 자체 변경
15
- - 제품별 downstream branding이나 credential 값 추가
16
-
17
- ## Assumptions
18
-
19
- - template repo의 `sdd/03_build`는 clone 이후 downstream repo가 그대로 이어받는 current-state 설명 문서다.
20
- - AST-style build 문서는 모든 관계를 하나의 트리에 과적재하지 않고, 주 runtime chain과 cross-cutting contract를 분리해 설명한다.
21
- - agentic harness는 repo-local path와 generic scaffold만 포함하고 실제 run 산출물은 commit 대상이 아니다.
22
-
23
- ## Acceptance Criteria
24
-
25
- - [x] `scripts/dev/audit_sdd_build_ast.py`가 `ast_similarity=10`, `implementation_traceability=10`, `human_agent_readability=10`을 반환한다.
26
- - [x] `mobile`, `web`, `admin`, `landing` service summary가 실제 `main.tsx -> AuthProvider -> BrowserRouter -> App -> ProtectedRoute/shell -> route leaf` 체인을 반영한다.
27
- - [x] `README`, `AGENTS`, `CLAUDE`, toolchain policy가 `.agent`, role agent, skill alias, AST current-state 규칙을 같이 설명한다.
28
- - [x] template infra 문서는 provider-first baseline(`aws/data`, `aws/domain`, `openstack/server`)을 current canonical split으로 설명한다.
29
-
30
- ## Execution Checklist
31
-
32
- - [x] 기존 템플릿의 agentic/toolchain/AST 누락 축을 정리한다.
33
- - [x] `.agent` Ralph scaffold와 Claude/Codex alias/role surface를 추가한다.
34
- - [x] AST audit script와 plan/build/verify current-state 문서를 추가한다.
35
- - [x] service build summary를 runtime tree 기준으로 재작성한다.
36
- - [x] infra current-state 문서를 provider-first baseline으로 갱신한다.
37
- - [x] root compose baseline을 provider-first runtime split까지 더 일반화할 추가 필요 여부를 follow-up으로 평가한다.
38
-
39
- ## Work Log
40
-
41
- - 2026-03-19: `templates`가 starter scaffold로는 충분하지만 `passv`/`palcar`에서 검증된 agentic harness, AST build governance, provider-first infra split이 빠져 있어 canonical repo로 승격이 필요하다고 정리했다.
42
- - 2026-03-19: `.agent` Ralph scaffold, Claude role agent surface, Codex alias skill, OTRO validation helper 문서를 정본에 추가하기로 결정했다.
43
- - 2026-03-19: `sdd/03_build/01_feature/service/*.md`를 실제 템플릿 runtime composition 기준으로 다시 쓰고 AST gate로 검증하는 흐름을 고정했다.
44
- - 2026-03-19: infra current-state는 기존 `openstack/dev|prod` 설명에 더해 `aws/data`, `aws/domain`, `openstack/server` provider-first split을 canonical baseline으로 반영했다.
45
- - 2026-03-19: AST gate와 `terraform validate` 3종이 모두 통과해 canonical template upgrade의 구조적 baseline을 고정했다.
46
-
47
- ## Validation
48
-
49
- - `python3 scripts/dev/audit_sdd_build_ast.py --write .agent/sdd-build-ast-audit.json`
50
- - `rg -n "Ralph|iteration|Current Build Note|2026-" sdd/03_build -g '*.md'`
51
- - `terraform -chdir=infra/terraform/aws/data init -backend=false && terraform -chdir=infra/terraform/aws/data validate`
52
- - `terraform -chdir=infra/terraform/aws/domain init -backend=false && terraform -chdir=infra/terraform/aws/domain validate`
53
- - `terraform -chdir=infra/terraform/openstack/server init -backend=false && terraform -chdir=infra/terraform/openstack/server validate`
@@ -1,39 +0,0 @@
1
- # repository governance
2
-
3
- - Owner: Codex
4
- - Status: active
5
-
6
- ## Scope
7
-
8
- - In scope:
9
- - `main` canonical branch 운영
10
- - repo path와 주요 문서 구조 정합성 유지
11
- - SDD final-only 원칙 유지
12
- - Out of scope:
13
- - 서비스별 feature/screen 상세 TODO
14
-
15
- ## Acceptance Criteria
16
-
17
- - [x] `main`을 정본 브랜치로 유지한다.
18
- - [x] repo 경로와 주요 문서는 현재 `client/*`, `server/*`, `sdd/*` 구조를 기준으로 설명한다.
19
- - [x] plan/build/verify/operate는 dated history 없이 durable 문서만 유지한다.
20
-
21
- ## Execution Checklist
22
-
23
- - [x] branch 운영 원칙을 현재 방식으로 고정한다.
24
- - [x] repo 주요 경로 기준을 `client/*`, `server/*`, `sdd/*` 구조로 고정한다.
25
- - [x] SDD final-only 원칙을 반영한다.
26
-
27
- ## Current Notes
28
-
29
- - `main`을 canonical branch로 유지하는 규칙을 사용한다.
30
- - 템플릿 frontend 경로는 `client/web`, `client/admin`, `client/mobile`, `client/landing` 기준이다.
31
- - SDD는 최종 일관성 문서만 유지하고, raw 운영 로그는 runtime logging system에 남긴다.
32
- - data modeling 계획 루트는 `sdd/01_planning/04_data`와 `sdd/02_plan/04_data`를 기준으로 유지한다.
33
-
34
- ## Validation
35
-
36
- - current references:
37
- - `AGENTS.md`
38
- - `sdd/03_build/03_architecture/repository_governance.md`
39
- - `sdd/03_verify/03_architecture/repository_governance.md`
@@ -1,38 +0,0 @@
1
- # runtime and structure governance
2
-
3
- - Owner: Codex
4
- - Status: active
5
-
6
- ## Scope
7
-
8
- - In scope:
9
- - template repo의 `server/*`, `client/*`, `infra/*` current 구조 기준 유지
10
- - screen PDF, toolchain, runtime entrypoint 같은 현재 구조 설명
11
- - Out of scope:
12
- - 서비스별 구현 상세
13
-
14
- ## Acceptance Criteria
15
-
16
- - [x] repo structure 설명은 현재 폴더 구조를 기준으로 유지한다.
17
- - [x] runtime path와 screen planning path는 현재 canonical 위치만 가리킨다.
18
- - [x] dated refactor memo 없이 current structure만 남긴다.
19
-
20
- ## Execution Checklist
21
-
22
- - [x] repo structure 기준 경로를 다시 점검한다.
23
- - [x] stale path reference를 current path로 교체한다.
24
- - [x] runtime/structure 설명을 durable 문서로 유지한다.
25
-
26
- ## Current Notes
27
-
28
- - backend는 `server/contexts/*`, frontend는 `client/*`, 인프라는 `infra/*` current structure를 기준으로 설명한다.
29
- - screen planning은 `sdd/01_planning/02_screen/*.pdf`를 canonical source로 유지한다.
30
- - architecture planning은 root common docs + `frontend/`, `backend/`, `infra/`, `tech-research/` split을 기준으로 유지한다.
31
- - 저장소 구조 정렬 결과는 현재 디렉터리 기준만 남긴다.
32
-
33
- ## Validation
34
-
35
- - current references:
36
- - `sdd/01_planning/README.md`
37
- - `sdd/03_build/03_architecture/repository_governance.md`
38
- - `sdd/03_verify/03_architecture/repository_governance.md`
@@ -1,9 +0,0 @@
1
- # Templates Hexagonal Template Architecture
2
-
3
- 현재 템플릿 레포의 기본 아키텍처 원칙:
4
-
5
- - 프론트는 `React + Tailwind + CSS token surface`
6
- - 백엔드는 `hexagonal + DDD`
7
- - 컨텍스트 외부 진입점은 `contracts`
8
- - adapter는 교환 가능해야 하며 application/domain은 저장소 세부사항을 직접 알지 않는다
9
- - 데이터 모델링 상세는 architecture가 아니라 `04_data`에서 다룬다
@@ -1,98 +0,0 @@
1
- # toolchain governance
2
-
3
- - Owner: Codex
4
- - Status: active
5
-
6
- ## Scope
7
-
8
- - In scope:
9
- - `sdd/99_toolchain` 아래 자동화 도구와 policy 문서의 current rule 유지
10
- - Playwright exactness runner/manifest를 local screen regression의 canonical gate로 유지
11
- - skill/tooling path와 proof artifact path 정렬
12
- - local Claude/Codex `sdd` skill의 canonical path와 실제 저장소 구조 정렬
13
- - `sdd` skill의 rollout gate를 explicit deployment scope 기준으로 제한
14
- - 존재하지 않는 template builder file을 required canonical path처럼 안내하지 않도록 정리
15
- - 프로젝트 루트에서 `sdd` skill을 설명하는 단일 entrypoint 문서 유지
16
- - 루트 `SDD_SKILL.md`가 workflow, `sdd/` 구조, flow별 설명까지 포함하도록 확장
17
- - 루트 `SDD_SKILL.md`가 toolchain, visual fidelity, exactness, functional alignment 구조까지 설명하도록 확장
18
- - 루트 `SDD_SKILL.md`가 `sdd` 스킬의 trigger, non-use case, governance, section map, schema parity, regression, rollout, completion gate까지 포함하도록 확장
19
- - ignored 상태였던 durable local scaffold/config를 template-tracked asset으로 승격
20
- - Out of scope:
21
- - 개별 서비스 구현
22
-
23
- ## Acceptance Criteria
24
-
25
- - [x] skill/tooling 관련 경로가 current SDD 구조를 가리킨다.
26
- - [x] proof artifact 예시도 final-only verify structure를 따른다.
27
- - [x] toolchain 설명은 현재 workflow rule만 남긴다.
28
- - [x] 화면명세 기반 정적 자산은 canonical `스펙에셋빌더` 선행 추출 rule을 current workflow로 유지한다.
29
- - [x] 회귀 검수 범위 선택 rule이 policy, toolchain, skill, SDD test 문서에 공통 반영된다.
30
- - [x] `.claude/skills/sdd-dev/SKILL.md`의 Codex canonical path가 실제 `.codex/skills/sdd/` 구조를 가리킨다.
31
- - [x] `sdd` skill은 rollout이 explicit scope일 때만 DEV/PROD/rollback gate를 completion bar로 해석한다.
32
- - [x] 디자인 가이드 builder 안내는 현재 저장소에 실제로 존재하는 automation inventory 기준으로만 적는다.
33
- - [x] 프로젝트 루트에서 `sdd` skill 용도와 canonical path를 빠르게 확인할 수 있는 단일 markdown entrypoint가 있다.
34
- - [x] `SDD_SKILL.md`는 요약 수준을 넘어서 workflow, folder structure, flow별 역할을 명확하게 설명한다.
35
- - [x] `SDD_SKILL.md`는 toolchain 역할과 visual fidelity / exactness / 기능 정합성 구조를 명확하게 설명한다.
36
- - [x] `SDD_SKILL.md`는 `sdd` 스킬의 거의 전체 해설서 수준으로 trigger, artifact rule, rollout gate, completion gate까지 설명한다.
37
- - [x] durable local scaffold/config 파일은 tracked asset으로 승격되고, generated/cache artifact는 계속 ignore된다.
38
- - [x] Playwright screen exactness는 ad-hoc CLI가 아니라 `sdd/99_toolchain/01_automation/` wrapper/manifest 기준으로 실행한다.
39
-
40
- ## Execution Checklist
41
-
42
- - [x] stale verify/build path를 current path로 교체한다.
43
- - [x] toolchain README와 design note를 current governance와 정렬한다.
44
- - [x] reusable template path를 final-only 구조에 맞춘다.
45
- - [x] screen-spec static asset extraction rule을 skill과 toolchain 문서에 공통 반영한다.
46
- - [x] regression verification rule을 policy, skill, toolchain, test planning에 공통 반영한다.
47
- - [x] Claude `sdd-dev` alias가 stale `.codex/skills/sdd-dev/` 경로를 참조하지 않도록 정리한다.
48
- - [x] Codex/Claude `sdd` skill에서 rollout gate를 explicit deployment scope 조건으로 정리한다.
49
- - [x] 존재하지 않는 `screen_design_guide_builder.py`를 template canonical file처럼 적지 않도록 수정한다.
50
- - [x] 루트에 `sdd` skill 요약 문서를 추가하고 canonical source를 명시한다.
51
- - [x] 루트 `SDD_SKILL.md`에 workflow 단계, section 역할, flow별 상세 설명을 보강한다.
52
- - [x] 루트 `SDD_SKILL.md`에 toolchain, parity/proof, exactness, functional alignment 설명을 추가한다.
53
- - [x] 루트 `SDD_SKILL.md`에 trigger rule, non-use case, governance, section routing, schema parity, regression, completion gate 설명을 추가한다.
54
- - [x] `.claude/settings.local.json`, `.agent/sdd-build-ast-audit.json`, `.agent/runs/README.md`를 tracked asset으로 승격한다.
55
- - [x] `node_modules`, `dist`, `.venv`, `.terraform`, cache 계열은 generated/local artifact로 계속 제외한다.
56
- - [x] Playwright exactness suite registry와 runner를 toolchain canonical entrypoint로 편입한다.
57
- - [x] screen template가 suite id와 canonical runner command를 기본 항목으로 가진다.
58
-
59
- ## Current Notes
60
-
61
- - toolchain은 `sdd/99_toolchain/01_automation`, `02_policies`, `03_templates` current split을 따른다.
62
- - Playwright local exactness는 `run_playwright_exactness.py`와 `playwright_exactness_manifest.py`를 canonical entrypoint로 사용한다.
63
- - screen 작업은 가능하면 `npx playwright test ...`를 직접 쓰지 않고 toolchain runner를 통해 suite id 기준으로 실행한다.
64
- - proof artifact는 `sdd/03_verify/10_test/ui_parity/` current path를 기준으로 관리한다.
65
- - toolchain 정책 문서의 정본은 `sdd/99_toolchain/02_policies`에 둔다.
66
- - skill/tooling 사용 여부는 개별 dated memo가 아니라 현재 workflow rule로만 유지한다.
67
- - 화면명세서의 icon/image/logo 등 재사용 가능한 정적 자산은 `spec_asset_builder.py` 또는 wrapper를 먼저 사용해 추출하고, 수동 재작성은 builder가 표현하지 못하는 경우에만 예외로 허용한다.
68
- - reusable asset planning root는 `sdd/01_planning/02_screen/assets/`이고, local Codex/Claude `sdd` skill도 같은 경로 기준으로 유지한다.
69
- - 회귀 검수는 direct target-only 확인으로 끝내지 않고, `sdd/02_plan/10_test/regression_verification.md` 기준으로 selected surface를 retained current-state로 남긴다.
70
- - Claude `sdd-dev` canonical asset reference는 현재 저장소의 `.codex/skills/sdd/` path를 기준으로 맞춘다.
71
- - rollout, DEV/PROD gate, rollback rule은 사용자가 배포를 요청했거나 저장소의 current policy/plan이 rollout을 completion bar로 올린 경우에만 강제한다.
72
- - 디자인 가이드 builder reference는 실제 존재하는 automation inventory를 기준으로 적고, 없는 file path를 canonical prerequisite처럼 고정하지 않는다.
73
- - 루트 `SDD_SKILL.md`는 단순 요약이 아니라 입문용 설명 문서로 유지하되, canonical rule은 local skill 원문과 toolchain policy에 둔다.
74
- - 루트 `SDD_SKILL.md`는 builder/harness/policy가 visual fidelity, exactness, 기능 정합성을 어떻게 연결하는지까지 설명한다.
75
- - 루트 `SDD_SKILL.md`는 skill 원문을 읽기 전에 전체 mental model을 잡는 해설서 역할을 하도록 유지한다.
76
- - `.claude/settings.local.json`은 local permission preset이지만 현재 템플릿이 재사용하는 scaffold로 승격한다.
77
- - `.agent/sdd-build-ast-audit.json`과 `.agent/runs/README.md`는 Ralph/AST scaffold의 durable template asset으로 승격한다.
78
- - generated output인 `dist`, `node_modules`, `.venv`, `.terraform`, cache, runtime run output은 계속 template commit 대상에서 제외한다.
79
-
80
- ## Validation
81
-
82
- - current references:
83
- - `AGENTS.md`
84
- - `.codex/skills/sdd/SKILL.md`
85
- - `.claude/skills/sdd/SKILL.md`
86
- - `.claude/skills/sdd-dev/SKILL.md`
87
- - `.claude/settings.local.json`
88
- - `.agent/sdd-build-ast-audit.json`
89
- - `.agent/runs/README.md`
90
- - `SDD_SKILL.md`
91
- - `sdd/01_planning/02_screen/assets/README.md`
92
- - `sdd/99_toolchain/01_automation/README.md`
93
- - `sdd/99_toolchain/01_automation/playwright_exactness_manifest.py`
94
- - `sdd/99_toolchain/01_automation/run_playwright_exactness.py`
95
- - `sdd/02_plan/10_test/verification_strategy.md`
96
- - `sdd/03_verify/10_test/verification_harness.md`
97
- - `sdd/99_toolchain/02_policies/regression-verification-policy.md`
98
- - `sdd/02_plan/10_test/regression_verification.md`
@@ -1,5 +0,0 @@
1
- # Data Planning
2
-
3
- - 이 폴더는 `sdd/02_plan` 아래에서 에이전트의 현재 개발 계획을 관리한다.
4
- - 데이터 모델, 관계, 키 정책 정렬 계획을 현재형 durable 문서로 유지한다.
5
- - dated data planning memo를 쌓지 않는다.
@@ -1,5 +0,0 @@
1
- # API Planning
2
-
3
- - 이 폴더는 `sdd/02_plan` 아래에서 에이전트의 현재 개발 계획을 관리한다.
4
- - API contract, request/response, transport rule 정렬 계획을 현재형 durable 문서로 유지한다.
5
- - dated API planning memo를 쌓지 않는다.
@@ -1,11 +0,0 @@
1
- # IaC Planning
2
-
3
- - 이 폴더는 `sdd/02_plan` 아래에서 에이전트의 현재 개발 계획을 관리한다.
4
- - 이 폴더는 배포, 런타임, 데이터베이스 운영 계획을 durable 문서로 유지한다.
5
- - dated deploy plan은 남기지 않고, 현재 유효한 delivery/runtime 계획만 갱신한다.
6
-
7
- ## Common Rule
8
-
9
- - 다른 `02_plan` 폴더와 동일하게 `README.md + durable 문서`만 유지한다.
10
- - 실제 계획은 대상 문서를 직접 갱신하는 방식으로 관리하고, 날짜 기반 임시 plan 파일은 두지 않는다.
11
- - 개발계가 있는 대상은 `build -> main push -> DEV(개발계) 배포 -> DEV(개발계) 검수`를 delivery 기본 루틴으로 포함한다.