@edupia-tutor/spec-driven-docs 0.14.0 → 0.14.2

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 (162) hide show
  1. package/bin/index.js +12 -1
  2. package/commands/debug.md +436 -436
  3. package/commands/debug.tmpl +111 -111
  4. package/commands/define-product.md +350 -345
  5. package/commands/define-product.tmpl +69 -64
  6. package/commands/dev-gen-test.md +365 -365
  7. package/commands/dev-gen-test.tmpl +63 -63
  8. package/commands/dev-run-test.md +376 -376
  9. package/commands/dev-run-test.tmpl +74 -74
  10. package/commands/dev-smoke-test.md +341 -341
  11. package/commands/dev-smoke-test.tmpl +60 -60
  12. package/commands/fix-bug.md +403 -403
  13. package/commands/fix-bug.tmpl +78 -78
  14. package/commands/generate-bdd.md +513 -513
  15. package/commands/generate-bdd.tmpl +211 -211
  16. package/commands/generate-code.md +481 -483
  17. package/commands/generate-code.tmpl +179 -181
  18. package/commands/generate-design-spec.md +497 -497
  19. package/commands/generate-design-spec.tmpl +220 -220
  20. package/commands/generate-prd.md +452 -400
  21. package/commands/generate-prd.tmpl +50 -200
  22. package/commands/generate-spec-manifest.md +340 -340
  23. package/commands/generate-spec-manifest.tmpl +59 -59
  24. package/commands/generate-tech-docs.md +365 -365
  25. package/commands/generate-tech-docs.tmpl +84 -84
  26. package/commands/learn.md +347 -347
  27. package/commands/learn.tmpl +22 -22
  28. package/commands/map-testids.md +322 -322
  29. package/commands/map-testids.tmpl +41 -41
  30. package/commands/propose-scenario.md +335 -335
  31. package/commands/propose-scenario.tmpl +54 -54
  32. package/commands/qc-analyze.md +323 -324
  33. package/commands/qc-analyze.tmpl +42 -43
  34. package/commands/qc-design-test.md +304 -304
  35. package/commands/qc-design-test.tmpl +23 -23
  36. package/commands/qc-plan.md +297 -297
  37. package/commands/qc-plan.tmpl +16 -16
  38. package/commands/qc-report.md +302 -302
  39. package/commands/qc-report.tmpl +21 -21
  40. package/commands/qc-review.md +298 -298
  41. package/commands/qc-review.tmpl +17 -17
  42. package/commands/qc-run-test.md +337 -337
  43. package/commands/qc-run-test.tmpl +35 -35
  44. package/commands/refine-prd.md +428 -430
  45. package/commands/refine-prd.tmpl +62 -62
  46. package/commands/report-bug.md +351 -351
  47. package/commands/report-bug.tmpl +70 -70
  48. package/commands/review-code.md +364 -364
  49. package/commands/review-code.tmpl +39 -39
  50. package/commands/review-context.md +578 -580
  51. package/commands/review-context.tmpl +212 -212
  52. package/commands/review-tech-docs.md +427 -427
  53. package/commands/review-tech-docs.tmpl +146 -146
  54. package/commands/setup-ai-first.md +239 -239
  55. package/commands/setup-ai-first.tmpl +133 -133
  56. package/commands/sync.md +145 -145
  57. package/commands/sync.tmpl +93 -93
  58. package/commands/update-framework.md +88 -88
  59. package/commands/update-framework.tmpl +36 -36
  60. package/commands/validate-traces.md +381 -381
  61. package/commands/validate-traces.tmpl +100 -100
  62. package/core/FRAMEWORK_VERSION +1 -1
  63. package/core/commands/debug.md +436 -436
  64. package/core/commands/define-product.md +350 -345
  65. package/core/commands/dev-gen-test.md +365 -365
  66. package/core/commands/dev-run-test.md +376 -376
  67. package/core/commands/dev-smoke-test.md +341 -341
  68. package/core/commands/fix-bug.md +403 -403
  69. package/core/commands/generate-bdd.md +513 -513
  70. package/core/commands/generate-code.md +481 -483
  71. package/core/commands/generate-design-spec.md +497 -497
  72. package/core/commands/generate-prd.md +452 -400
  73. package/core/commands/generate-spec-manifest.md +340 -340
  74. package/core/commands/generate-tech-docs.md +365 -365
  75. package/core/commands/learn.md +347 -347
  76. package/core/commands/map-testids.md +322 -322
  77. package/core/commands/propose-scenario.md +335 -335
  78. package/core/commands/qc-analyze.md +323 -324
  79. package/core/commands/qc-design-test.md +304 -304
  80. package/core/commands/qc-plan.md +297 -297
  81. package/core/commands/qc-report.md +302 -302
  82. package/core/commands/qc-review.md +298 -298
  83. package/core/commands/qc-run-test.md +337 -337
  84. package/core/commands/refine-prd.md +428 -430
  85. package/core/commands/report-bug.md +351 -351
  86. package/core/commands/review-code.md +364 -364
  87. package/core/commands/review-context.md +578 -580
  88. package/core/commands/review-tech-docs.md +427 -427
  89. package/core/commands/setup-ai-first.md +239 -239
  90. package/core/commands/sync.md +145 -145
  91. package/core/commands/update-framework.md +88 -88
  92. package/core/commands/validate-traces.md +381 -381
  93. package/core/skills/code/SKILL.md +389 -389
  94. package/core/skills/debug/SKILL.md +391 -391
  95. package/core/skills/design-spec/SKILL.md +318 -318
  96. package/core/skills/discovery/SKILL.md +7 -547
  97. package/core/skills/prd/SKILL.md +298 -394
  98. package/core/skills/setup-ai-first/SKILL.md +80 -80
  99. package/core/skills/spec/SKILL.md +178 -178
  100. package/core/skills/test/SKILL.md +604 -604
  101. package/core/steps/capture-lesson.md +44 -44
  102. package/core/steps/context-loader.md +175 -175
  103. package/core/steps/gate.md +54 -54
  104. package/core/steps/report-footer.md +52 -52
  105. package/core/steps/review-fanout.md +85 -87
  106. package/core/steps/spawn-agent.md +45 -45
  107. package/core/steps/trace-mirror.md +21 -21
  108. package/core/templates/architecture.template.md +37 -37
  109. package/core/templates/design-spec.template.md +77 -77
  110. package/core/templates/platform-guide.template.md +47 -47
  111. package/core/templates/prd.template.md +107 -232
  112. package/core/templates/product-definition.template.md +101 -88
  113. package/core/templates/project-context.yaml +2 -2
  114. package/docs/01-getting-started/core-concepts.md +1 -1
  115. package/docs/01-getting-started/quickstart.md +7 -7
  116. package/docs/02-guides/developer/bdd-and-trace.md +1 -1
  117. package/docs/02-guides/developer/scenarios.md +5 -5
  118. package/docs/02-guides/product-owner/handoff-checklist.md +1 -1
  119. package/docs/02-guides/product-owner/scenarios.md +23 -23
  120. package/docs/02-guides/tester/bug-reporting.md +2 -2
  121. package/docs/02-guides/tester/reading-specs.md +2 -2
  122. package/docs/02-guides/tester/scenarios.md +1 -1
  123. package/docs/02-guides/tester/spec-manifest.md +3 -3
  124. package/docs/02-guides/tester/workflow.md +1 -1
  125. package/docs/03-concepts/architecture.md +3 -3
  126. package/docs/03-concepts/pipeline.md +3 -3
  127. package/docs/04-operations/publishing.md +20 -3
  128. package/docs/04-operations/sync-and-update.md +5 -5
  129. package/docs/05-reference/command-cheatsheet.md +2 -2
  130. package/docs/05-reference/commands.md +8 -8
  131. package/package.json +1 -1
  132. package/scripts/migrate-specs.js +5 -3
  133. package/scripts/rename-prd-files.js +174 -0
  134. package/skills/code/SKILL.md +389 -389
  135. package/skills/code/SKILL.tmpl +56 -56
  136. package/skills/debug/SKILL.md +391 -391
  137. package/skills/debug/SKILL.tmpl +60 -60
  138. package/skills/design-spec/SKILL.md +318 -318
  139. package/skills/design-spec/SKILL.tmpl +37 -37
  140. package/skills/discovery/SKILL.md +7 -547
  141. package/skills/discovery/SKILL.tmpl +7 -140
  142. package/skills/prd/SKILL.md +298 -394
  143. package/skills/prd/SKILL.tmpl +40 -151
  144. package/skills/setup-ai-first/SKILL.md +80 -80
  145. package/skills/setup-ai-first/SKILL.tmpl +28 -28
  146. package/skills/spec/SKILL.md +178 -178
  147. package/skills/spec/SKILL.tmpl +20 -20
  148. package/skills/test/SKILL.md +604 -604
  149. package/skills/test/SKILL.tmpl +44 -44
  150. package/steps/capture-lesson.md +44 -44
  151. package/steps/context-loader.md +175 -175
  152. package/steps/gate.md +54 -54
  153. package/steps/report-footer.md +52 -52
  154. package/steps/review-fanout.md +85 -87
  155. package/steps/spawn-agent.md +45 -45
  156. package/steps/trace-mirror.md +21 -21
  157. package/templates/architecture.template.md +37 -37
  158. package/templates/design-spec.template.md +77 -77
  159. package/templates/platform-guide.template.md +47 -47
  160. package/templates/prd.template.md +107 -232
  161. package/templates/product-definition.template.md +101 -88
  162. package/templates/project-context.yaml +2 -2
@@ -1,152 +1,152 @@
1
- # /review-context — Review PRD or BDD for Quality & Consistency
1
+ # /review-context — Review PRD hoặc BDD về Chất lượng & Tính nhất quán
2
2
 
3
- **READ-ONLY analysis mode writes a findings file, does NOT modify the target.**
4
- **Use `--resume` to apply accepted findings.**
3
+ **Chế độ phân tích READ-ONLY — ghi file findings, KHÔNG sửa target.**
4
+ **Dùng `--resume` để áp dụng các finding được chấp nhận.**
5
5
 
6
6
  ## Gate
7
- # Gate — Universal Entry Procedure
7
+ # Gate — Quy trình vào chuẩn cho mọi lệnh
8
8
 
9
- Every command must execute this gate before proceeding with its specific logic.
9
+ Mọi lệnh PHẢI chạy gate này trước khi thực thi phần logic riêng của nó.
10
10
 
11
- ## Step 0 — Sub-Agent Mode Check
11
+ ## Bước 0 — Kiểm tra chế độ Sub-Agent
12
12
 
13
- Before anything else, check if `$ARGUMENTS` is a JSON payload from an orchestrator:
13
+ Trước tiên, kiểm tra xem `$ARGUMENTS` phải payload JSON từ một orchestrator hay không:
14
14
 
15
- 1. Attempt to parse `$ARGUMENTS` as JSON.
16
- 2. If it parses successfully **and** contains `"_agent_mode": true`:
17
- - **Skip Steps 1, 2, and 3 of this Gate entirely.**
18
- - Set target file = `payload.target_file`
19
- - Set loaded context = `payload.context` (do NOT run context-loader.md)
20
- - Set UC scope = `payload.uc_id` (process only this UC)
21
- - Set line range = `payload.uc_section` (read only that PRD section)
22
- - Proceed directly to the command-specific logic.
23
- 3. If `$ARGUMENTS` is not JSON or `_agent_mode` is absent continue to Step 1 (normal mode).
15
+ 1. Thử parse `$ARGUMENTS` dưới dạng JSON.
16
+ 2. Nếu parse thành công **và** chứa `"_agent_mode": true`:
17
+ - **Bỏ qua hoàn toàn Bước 1, 2 3 của Gate này.**
18
+ - Đặt target file = `payload.target_file`
19
+ - Đặt loaded context = `payload.context` (KHÔNG chạy context-loader.md)
20
+ - Đặt phạm vi UC = `payload.uc_id` (chỉ xử UC này)
21
+ - Đặt line range = `payload.uc_section` (chỉ đọc đúng section đó của PRD)
22
+ - Đi thẳng tới phần logic riêng của lệnh.
23
+ 3. Nếu `$ARGUMENTS` không phải JSON hoặc không có `_agent_mode` tiếp tục sang Bước 1 (chế độ thường).
24
24
 
25
- ## Step 0-B — Model Check
25
+ ## Bước 0-B — Kiểm tra Model
26
26
 
27
- *Skip this step if `_agent_mode: true` (sub-agent — orchestrator already validated).*
27
+ *Bỏ qua bước này nếu `_agent_mode: true` (sub-agent — orchestrator đã kiểm tra rồi).*
28
28
 
29
- Complex generation and review commands require strong reasoning.
30
- Using a smaller model risks missed edge cases, incomplete spec analysis, and architecture violations.
29
+ Các lệnh sinh nội dung và review phức tạp đòi hỏi khả năng suy luận mạnh.
30
+ Dùng model nhỏ hơn sẽ rủi ro: bỏ sót edge case, phân tích spec thiếu sót, vi phạm kiến trúc.
31
31
 
32
- Display and wait for response:
32
+ Hiển thị chờ phản hồi:
33
33
 
34
34
  ```
35
35
  ⚙️ MODEL CHECK
36
36
  ──────────────────────────────────────────────────────────────────
37
- Recommended : claude-opus-4 (or latest Opus model)
38
- Why needed : Spec analysis, architecture review, code generation
39
- require deep reasoning. Smaller models miss edge cases.
37
+ Recommended : claude-opus-4 (hoặc model Opus mới nhất)
38
+ Why needed : Phân tích spec, review kiến trúc, sinh code đòi hỏi
39
+ suy luận sâu. Model nhỏ hơn dễ bỏ sót edge case.
40
40
 
41
- To switch in Claude Code:
42
- • Settings → Model → select "claude-opus"
43
- or: /model → choose claude-opus
41
+ Cách đổi trong Claude Code:
42
+ • Settings → Model → chọn "claude-opus"
43
+ hoặc: /model → chọn claude-opus
44
44
 
45
- Running on claude-opus?
46
- Y — yes, on claude-opus → proceed
47
- S — skip check (I accept lower quality risk with current model)
45
+ Đang chạy claude-opus?
46
+ Y — đúng, đang dùng claude-opus → tiếp tục
47
+ S — bỏ qua kiểm tra (tôi chấp nhận rủi ro chất lượng thấp hơn với model hiện tại)
48
48
  ──────────────────────────────────────────────────────────────────
49
49
  ```
50
50
 
51
- - "Y" → proceed to Step 1.
52
- - "S" → proceed to Step 1 (user accepts risk, add ⚠️ to final report).
53
- - "N" or anything else → **STOP.** Output: "Please switch to claude-opus, then re-run this command."
51
+ - "Y" → tiếp tục sang Bước 1.
52
+ - "S" → tiếp tục sang Bước 1 (người dùng chấp nhận rủi ro, thêm ⚠️ vào report cuối).
53
+ - "N" hoặc bất kỳ giá trị nào khác → **DỪNG.** Xuất: "Vui lòng chuyển sang claude-opus rồi chạy lại lệnh này."
54
54
 
55
- ## Step 1 — Resolve Target File
55
+ ## Bước 1 — Xác định Target File
56
56
 
57
- 1. If `$ARGUMENTS` is provided and points to an existing file → use it directly as the target.
58
- 2. If `$ARGUMENTS` is a **bare UC-ID / ticket ID / partial name** (no path) → resolve it to a file by globbing the feature-package layout. The `{prd-slug}` is **not known yet**, so use a `*` wildcard for that segment, and a recursive `**` under `bdd/` so the platform subfolders (`bdd/web/`, `bdd/app/`, `bdd/system/`) are all covered:
59
- - **BDD commands** (target is a `.feature`): `{specs_dir}/{domain}/*/bdd/**/{UC-ID}*.feature` — or `{specs_dir}/*/*/bdd/**/{UC-ID}*.feature` if the domain is also unknown. If a platform/scope is implied by the command (e.g. a system tech-doc needs the `system/` BDD), prefer the match under that platform subfolder.
60
- - **PRD commands** (target is `prd.md`): `{specs_dir}/{domain}/*/prd.md` (match the feature folder whose id corresponds), else `{specs_dir}/*/*/prd.md`.
61
- - **tech-docs commands**: `{specs_dir}/{domain}/*/tech-docs/{UC-ID}*-tech-design*.md`.
62
- - **design-spec commands**: `{specs_dir}/{domain}/*/design-spec/{TICKET-ID}*.md`.
57
+ 1. Nếu `$ARGUMENTS` được cung cấp trỏ tới một file tồn tại dùng trực tiếp làm target.
58
+ 2. Nếu `$ARGUMENTS` một **UC-ID / ticket ID / tên rút gọn** (không path) → phân giải thành file bằng cách glob theo bố cục feature-package. `{prd-slug}` lúc này **chưa biết**, nên dùng wildcard `*` cho segment đó, `**` đệ quy dưới `bdd/` để phủ hết các thư mục con theo platform (`bdd/web/`, `bdd/app/`, `bdd/system/`):
59
+ - **Lệnh BDD** (target `.feature`): `{specs_dir}/{domain}/*/bdd/**/{UC-ID}*.feature` — hoặc `{specs_dir}/*/*/bdd/**/{UC-ID}*.feature` nếu domain cũng chưa biết. Nếu lệnh ngụ ý một platform/scope cụ thể (vd: system tech-doc cần BDD `system/`), ưu tiên kết quả trong thư mục con platform đó.
60
+ - **Lệnh PRD** (target file PRD `{TICKET-ID}-{prd-slug}.md` — file `.md` duy nhất ở gốc feature folder, cạnh `bdd/`): `{specs_dir}/{domain}/*/{TICKET-ID}*.md` nếu biết TICKET-ID; nếu không, `{specs_dir}/{domain}/*/*.md` (khớp feature folder id tương ứng), hoặc `{specs_dir}/*/*/*.md` nếu domain cũng chưa biết. *(Glob `*/*.md` ở cấp gốc folder chỉ khớp PRD — tech-docs/design-spec `.md` nằm sâu hơn trong thư mục con.)*
61
+ - **Lệnh tech-docs**: `{specs_dir}/{domain}/*/tech-docs/{UC-ID}*-tech-design*.md`.
62
+ - **Lệnh design-spec**: `{specs_dir}/{domain}/*/design-spec/{TICKET-ID}*.md`.
63
63
 
64
- Once a file matches: set it as the target **and** record `domain` + `prd_slug` from its path (per the extraction rule in `context-loader.md` Step 1 — `prd_slug` = first segment after `{specs_dir}/{domain}/`). Every path the command later reads or writes (sibling BDD/tech-docs/design-spec/trace) uses **that resolved `prd_slug`**, so all artifacts stay in one feature package. If several files match (e.g. multiple platforms), pick per the command's platform/scope or list them and ask.
65
- 3. If `$ARGUMENTS` is empty or no match found:
66
- - List files in the relevant directory for this command (e.g., `specs/*/*/prd.md` for PRD commands, `specs/*/*/bdd/**/*.feature` for BDD commands).
67
- - Present the list to the user and ask: "Which file do you want to work with? (Enter number or filename)"
68
- - Wait for user selection before continuing.
64
+ Khi một file khớp: đặt làm target **và** ghi lại `domain` + `prd_slug` từ path của nó (theo quy tắc trích xuất trong `context-loader.md` Bước 1 — `prd_slug` = segment đầu tiên sau `{specs_dir}/{domain}/`). Mọi path lệnh đọc/ghi về sau (BDD/tech-docs/design-spec/trace cùng cấp) đều dùng **`prd_slug` đã phân giải đó**, nên tất cả artifact nằm chung một feature package. Nếu nhiều file khớp (vd: nhiều platform), chọn theo platform/scope của lệnh hoặc liệt kê ra và hỏi.
65
+ 3. Nếu `$ARGUMENTS` rỗng hoặc không tìm thấy file khớp:
66
+ - Liệt các file trong thư mục liên quan của lệnh này (vd: `specs/*/*/*.md` file PRD ở gốc mỗi feature folder — cho lệnh PRD, `specs/*/*/bdd/**/*.feature` cho lệnh BDD).
67
+ - Hiển thị danh sách cho người dùng và hỏi: "Bạn muốn làm việc với file nào? (Nhập số thứ tự hoặc tên file)"
68
+ - Chờ người dùng chọn rồi mới tiếp tục.
69
69
 
70
- ## Step 2 — Execute Context Loader
70
+ ## Bước 2 — Chạy Context Loader
71
71
 
72
- Load all project context by following the procedure in `steps/context-loader.md`.
73
- Store all loaded context in memory for use throughout this command session.
72
+ Nạp toàn bộ context của dự án bằng cách làm theo quy trình trong `steps/context-loader.md`.
73
+ Lưu toàn bộ context đã nạp vào bộ nhớ để dùng xuyên suốt phiên làm việc của lệnh.
74
74
 
75
- ## Step 3 — CHECKPOINT
75
+ ## Bước 3 — CHECKPOINT
76
76
 
77
- After completing Steps 1 and 2, display a summary and wait for confirmation:
77
+ Sau khi hoàn thành Bước 1 2, hiển thị bản tóm tắt chờ xác nhận:
78
78
 
79
79
  ```
80
80
  CHECKPOINT
81
81
  -----------
82
82
  Target : {resolved file path}
83
- Project : {project.name from project-context.yaml}
83
+ Project : {project.name từ project-context.yaml}
84
84
  Tech stack : {language} / {framework}
85
- Module : {module if set, else "not configured"}
86
- Domains : {comma-separated domain list}
85
+ Module : {module nếu có, else "not configured"}
86
+ Domains : {danh sách domain, ngăn cách bởi dấu phẩy}
87
87
 
88
- Proceed? (Y/N)
88
+ Tiếp tục? (Y/N)
89
89
  ```
90
90
 
91
- Wait for explicit "Y" or "N" from the user before continuing.
92
- - "Y" → proceed to the command-specific steps below.
93
- - "N" → stop and ask what the user wants to change.
91
+ Chờ người dùng trả lời rõ ràng "Y" hoặc "N" rồi mới tiếp tục.
92
+ - "Y" → tiếp tục sang các bước riêng của lệnh bên dưới.
93
+ - "N" → dừng lại hỏi người dùng muốn thay đổi gì.
94
94
 
95
95
 
96
- *Note: For this command, the target in Step 1 is either a `.md` PRD file or a `.feature` BDD file.
97
- If the path is a `prd.md` under `{paths.specs_dir}/{domain}/{prd-slug}/` → PRD Review Mode.
98
- If the path ends with `.feature` → BDD Review Mode.
99
- If `$ARGUMENTS` contains `--resume` → skip to Resume Mode below.
100
- If `$ARGUMENTS` contains `--fix` → skip to Fix Mode below (apply all auto-fixable findings immediately).*
96
+ *Lưu ý: Với lệnh này, target Bước 1 một file PRD `.md` hoặc file BDD `.feature`.
97
+ Nếu path file PRD (`{TICKET-ID}-{prd-slug}.md` file `.md` ở gốc feature folder `{paths.specs_dir}/{domain}/{prd-slug}/`) → PRD Review Mode.
98
+ Nếu path kết thúc bằng `.feature` → BDD Review Mode.
99
+ Nếu `$ARGUMENTS` chứa `--resume` → bỏ qua sang Resume Mode bên dưới.
100
+ Nếu `$ARGUMENTS` chứa `--fix` → bỏ qua sang Fix Mode bên dưới (áp dụng ngay mọi finding auto-fixable).*
101
101
 
102
102
  ## Context
103
- # Context Loader — Load All Project Context
103
+ # Context Loader — Nạp toàn bộ context dự án
104
104
 
105
- Execute these steps in order. Store everything in memory for the duration of the command session.
105
+ Thực hiện các bước theo đúng thứ tự. Lưu mọi thứ vào bộ nhớ trong suốt phiên làm việc của lệnh.
106
106
 
107
- **Priority guide (anti-lost-in-middle):**
108
- - Steps 1–2 are PROJECT-CONFIG — loaded first, resolve all paths and metadata.
109
- - Step 3 is CRITICAL — architecture + coding standards, the highest-priority facts for generation.
110
- - Step 4 is SAFETY — data protection rules, enforced silently for the entire session.
111
- - Steps 5–6 are DOMAIN KNOWLEDGE — terminology and entity definitions.
112
- - Step 7 is the WORKING MEMORY RECAP — locks critical facts into the top of working memory.
107
+ **Hướng dẫn ưu tiên (chống lost-in-middle):**
108
+ - Bước 1–2 PROJECT-CONFIG — nạp trước, phân giải mọi path metadata.
109
+ - Bước 3 CRITICAL — kiến trúc + coding standards, các sự thật ưu tiên cao nhất khi sinh nội dung.
110
+ - Bước 4 SAFETY — quy tắc bảo vệ dữ liệu, thực thi ngầm suốt cả phiên.
111
+ - Bước 5–6 DOMAIN KNOWLEDGE — thuật ngữ và định nghĩa entity.
112
+ - Bước 7 WORKING MEMORY RECAP — chốt các sự thật quan trọng lên đầu bộ nhớ làm việc.
113
113
 
114
114
  ---
115
115
 
116
- ## Step 1 — [PROJECT-CONFIG] Load project-context.yaml
116
+ ## Bước 1 — [PROJECT-CONFIG] Nạp project-context.yaml
117
117
 
118
- Read `.agent/project-context.yaml`. Extract and store:
118
+ Đọc `.agent/project-context.yaml`. Trích xuất và lưu:
119
119
 
120
120
  **Tech Stack:**
121
- - `tech_stack.language` → active language (e.g., Java 17, TypeScript, C#, Go)
122
- - `tech_stack.framework` → active framework (e.g., Spring Boot 3.2, Angular 17, .NET 8)
123
- - `tech_stack.build_tool` → build tool (e.g., Maven, npm, dotnet, go)
124
- - `tech_stack.test_framework` → test framework (e.g., JUnit 5 + Mockito, Jest, xUnit)
125
- - `tech_stack.database` → database (e.g., PostgreSQL, MySQL, MongoDB)
126
- - `tech_stack.module` → active module profile (e.g., java-spring, angular, dotnet, golang, context-engineering)
121
+ - `tech_stack.language` → ngôn ngữ đang dùng (vd: Java 17, TypeScript, C#, Go)
122
+ - `tech_stack.framework` → framework đang dùng (vd: Spring Boot 3.2, Angular 17, .NET 8)
123
+ - `tech_stack.build_tool` → build tool (vd: Maven, npm, dotnet, go)
124
+ - `tech_stack.test_framework` → test framework (vd: JUnit 5 + Mockito, Jest, xUnit)
125
+ - `tech_stack.database` → database (vd: PostgreSQL, MySQL, MongoDB)
126
+ - `tech_stack.module` → module profile đang dùng (vd: java-spring, angular, dotnet, golang, context-engineering)
127
127
 
128
128
  **Conventions:**
129
- - `conventions.build_command` → how to compile/build
130
- - `conventions.test_command` → how to run tests
131
- - `conventions.service_run` → how to start the service
132
- - `conventions.ticket_prefix` → ticket ID prefix (e.g., PROJ, FEAT, UC)
129
+ - `conventions.build_command` → cách compile/build
130
+ - `conventions.test_command` → cách chạy test
131
+ - `conventions.service_run` → cách khởi động service
132
+ - `conventions.ticket_prefix` → tiền tố ticket ID (vd: PROJ, FEAT, UC)
133
133
 
134
134
  **Domains:**
135
- - `domains` → list of active business domains
136
-
137
- **Paths (if present):**
138
- - `paths.specs_dir` → spec artifacts root — PRD, BDD, tech-docs, design-spec. Structure: `{specs_dir}/{domain}/{prd-slug}/{prd.md | bdd/ | tech-docs/ | design-spec/}`
139
- - `paths.refinement_dir` → findings/review output dir
140
- - `paths.qc_dir` → QC automation artifacts root (visible top-level, one subfolder per UC: `{qc_dir}/{UC-ID}/`)
141
- - `paths.qc_skills_dir` → where qc-* commands load QC skills from (default bundled `.agent/skills/qc`; override to the QC team's own repo/submodule so framework upgrade won't overwrite them)
142
- - `paths.product_definitions_dir` → product definitions root
143
- - `paths.domain_knowledge_dir` → domain knowledge root
144
- - `paths.business_dictionary` → path to business-dictionary.md
145
- - `paths.core_entities` → path to core-entities.md
146
- - `paths.tech_docs_dir` → technical documentation root (merged with specs_dir in feature-package layout — tech-docs live under `{specs_dir}/{domain}/{prd-slug}/tech-docs/`)
147
- - `paths.trace_dir` → trace state directory; structure: `.trace/{domain}/{prd-slug}/{UC-ID}.tsv`
148
-
149
- If `paths` section is absent, use these defaults:
135
+ - `domains` → danh sách các business domain đang hoạt động
136
+
137
+ **Paths (nếu ):**
138
+ - `paths.specs_dir` → gốc của spec artifact — PRD, BDD, tech-docs, design-spec. Cấu trúc: `{specs_dir}/{domain}/{prd-slug}/{ {TICKET-ID}-{prd-slug}.md | bdd/ | tech-docs/ | design-spec/}` (file PRD đặt tên `{TICKET-ID}-{prd-slug}.md`, là file `.md` duy nhất ở gốc feature folder)
139
+ - `paths.refinement_dir` → thư mục output cho findings/review
140
+ - `paths.qc_dir` → gốc artifact QC automation (hiện top-level, mỗi UC một thư mục con: `{qc_dir}/{UC-ID}/`)
141
+ - `paths.qc_skills_dir` → nơi các lệnh qc-* nạp QC skill (mặc định bundled `.agent/skills/qc`; override sang repo/submodule riêng của team QC để bản nâng cấp framework không ghi đè)
142
+ - `paths.product_definitions_dir` → gốc product definition
143
+ - `paths.domain_knowledge_dir` → gốc domain knowledge
144
+ - `paths.business_dictionary` → path tới business-dictionary.md
145
+ - `paths.core_entities` → path tới core-entities.md
146
+ - `paths.tech_docs_dir` → gốc tài liệu kỹ thuật (gộp với specs_dir trong bố cục feature-package — tech-docs nằm dưới `{specs_dir}/{domain}/{prd-slug}/tech-docs/`)
147
+ - `paths.trace_dir` → thư mục trạng thái trace; cấu trúc: `.trace/{domain}/{prd-slug}/{UC-ID}.tsv`
148
+
149
+ Nếu không có section `paths`, dùng các giá trị mặc định:
150
150
  - `specs_dir` = `specs`
151
151
  - `refinement_dir` = `.agent/review`
152
152
  - `qc_dir` = `docs`
@@ -158,184 +158,184 @@ If `paths` section is absent, use these defaults:
158
158
  - `tech_docs_dir` = `specs`
159
159
  - `trace_dir` = `.trace`
160
160
 
161
- Note: In the feature-package layout, `specs_dir` is the unified root. All spec artifact types (PRD, BDD, tech-docs, design-spec) live under `{specs_dir}/{domain}/{prd-slug}/`. The `prd-slug` is the feature-package folder name, not a separate config variable.
161
+ Lưu ý: Trong bố cục feature-package, `specs_dir` gốc thống nhất. Mọi loại spec artifact (PRD, BDD, tech-docs, design-spec) đều nằm dưới `{specs_dir}/{domain}/{prd-slug}/`. `prd-slug` tên folder feature-package, không phải một biến config riêng.
162
162
 
163
- **How to extract `prd_slug` (works for ANY target file, regardless of nesting depth):** given a target path of the form `{specs_dir}/{domain}/{prd-slug}/...`, take the **first path segment after `{specs_dir}/{domain}/`** — i.e. the `{prd-slug}` position. Do NOT use the file's immediate parent folder, because BDD/tech-docs/design-spec artifacts are nested one or two levels deeper inside the package. Examples:
164
- - `specs/payment/create-invoice/prd.md` → `prd_slug = create-invoice`
165
- - `specs/payment/create-invoice/bdd/system/PAY-UC1.feature` → `prd_slug = create-invoice` *(NOT `system`)*
166
- - `specs/payment/create-invoice/bdd/web/PAY-UC1.feature` → `prd_slug = create-invoice` *(NOT `web`)*
167
- - `specs/payment/create-invoice/tech-docs/PAY-UC1-tech-design.md` → `prd_slug = create-invoice` *(NOT `tech-docs`)*
163
+ **Cách trích xuất `prd_slug` (đúng cho MỌI target file, bất kể độ sâu lồng nhau):** với một path target dạng `{specs_dir}/{domain}/{prd-slug}/...`, lấy **segment path đầu tiên sau `{specs_dir}/{domain}/`** — tức vị trí `{prd-slug}`. KHÔNG dùng folder cha trực tiếp của file, artifact BDD/tech-docs/design-spec lồng sâu hơn một hoặc hai cấp bên trong package. Ví dụ:
164
+ - `specs/payment/create-invoice/PAY01-create-invoice.md` → `prd_slug = create-invoice`
165
+ - `specs/payment/create-invoice/bdd/system/PAY-UC1.feature` → `prd_slug = create-invoice` *(KHÔNG phải `system`)*
166
+ - `specs/payment/create-invoice/bdd/web/PAY-UC1.feature` → `prd_slug = create-invoice` *(KHÔNG phải `web`)*
167
+ - `specs/payment/create-invoice/tech-docs/PAY-UC1-tech-design.md` → `prd_slug = create-invoice` *(KHÔNG phải `tech-docs`)*
168
168
  - `specs/payment/create-invoice/design-spec/PAY-design-spec-web.md` → `prd_slug = create-invoice`
169
169
 
170
- All sibling artifacts of one feature (PRD, every platform's BDD, the BE + FE tech-docs, the design-spec, and the trace TSV) therefore resolve to the **same `prd_slug`** — so a synthesized **system** BDD or **system/BE** tech-doc lands in the same `{specs_dir}/{domain}/{prd-slug}/` package as the web/app artifacts it was derived from.
170
+ Mọi artifact cùng cấp của một feature (PRD, BDD của từng platform, tech-docs BE + FE, design-spec, trace TSV) đều phân giải về **cùng một `prd_slug`** — nên một BDD **system** hay tech-doc **system/BE** được tổng hợp sẽ nằm chung package `{specs_dir}/{domain}/{prd-slug}/` với các artifact web/app được suy ra từ đó.
171
171
 
172
- If `tech_stack.module` is set, also load `.agent/modules/{module}/stack-profile.yaml` if it exists.
172
+ Nếu `tech_stack.module` được đặt, đồng thời nạp `.agent/modules/{module}/stack-profile.yaml` nếu file tồn tại.
173
173
 
174
174
  ---
175
175
 
176
- ## Step 1.5 — [SERVICE ROUTING] Resolve service paths (umbrella mode)
176
+ ## Bước 1.5 — [SERVICE ROUTING] Phân giải path service (chế độ umbrella)
177
177
 
178
- *Skip this step entirely if `setup.mode` is not `"umbrella"` and `services` section is absent from project-context.yaml.*
178
+ *Bỏ qua hoàn toàn bước này nếu `setup.mode` không phải `"umbrella"` không có section `services` trong project-context.yaml.*
179
179
 
180
- If `services` section is present:
180
+ Nếu section `services`:
181
181
 
182
- **1. Detect active domain** (in priority order):
183
- - Read `@trace.domain` from target file frontmatter (if Gate loaded a target file)
184
- - Extract from target file path: `domain` = the first segment after the `specs_dir` base path; `prd_slug` = the next segment (the feature-package folder). This holds for any target depth see the `prd_slug` extraction rule in Step 1.
185
- *(e.g., `specs/user/create-account/prd.md` **and** `specs/user/create-account/bdd/system/UC1.feature` both → domain = `user`, prd_slug = `create-account`)*
186
- - If `$ARGUMENTS` contains a path, extract the domain segment after `specs_dir`
182
+ **1. Phát hiện active domain** (theo thứ tự ưu tiên):
183
+ - Đọc `@trace.domain` từ frontmatter của target file (nếu Gate đã nạp một target file)
184
+ - Trích xuất từ path target file: `domain` = segment đầu tiên sau base path `specs_dir`; `prd_slug` = segment kế tiếp (folder feature-package). Điều này đúng mọi độ sâu target — xem quy tắc trích xuất `prd_slug` Bước 1.
185
+ *(vd: `specs/user/create-account/USR01-create-account.md` **và** `specs/user/create-account/bdd/system/UC1.feature` đều → domain = `user`, prd_slug = `create-account`)*
186
+ - Nếu `$ARGUMENTS` chứa một path, trích xuất segment domain sau `specs_dir`
187
187
 
188
- **2. Route to service** — if active domain matches a key in `services`:
189
- - Override `paths.specs_dir` → `services.{domain}.specs_dir` — **only if `setup.spec_source` is NOT set.** When `spec_source` IS set, ALL BDD (web/app/**system**) is a shared cross-team artifact leave `specs_dir` for step 4 to route to the spec repo; do NOT pin it per-service here.
190
- - Override `paths.tech_docs_dir` → `services.{domain}.tech_docs_dir` — **only if `setup.spec_source` is NOT set.** When `spec_source` IS set, the tech-design (API contract) is a cross-team artifact and must live in the shared spec repo (handled in step 4), so leave `tech_docs_dir` for step 4 to route — do NOT pin it per-service here.
191
- - Store `active_service` = `services.{domain}.path`
192
- - Store `active_service_module` = `services.{domain}.module`
193
- - If service has its own `module` → use it as `active_module` (overrides `tech_stack.module`)
188
+ **2. Route tới service** — nếu active domain khớp với một key trong `services`:
189
+ - Override `paths.specs_dir` → `services.{domain}.specs_dir` — **chỉ khi `setup.spec_source` KHÔNG được đặt.** Khi `spec_source` ĐƯỢC đặt, MỌI BDD (web/app/**system**) artifact dùng chung liên team → để bước 4 route sang spec repo; KHÔNG pin theo service ở đây.
190
+ - Override `paths.tech_docs_dir` → `services.{domain}.tech_docs_dir` — **chỉ khi `setup.spec_source` KHÔNG được đặt.** Khi `spec_source` ĐƯỢC đặt, tech-design (API contract) artifact liên team phải nằm trong spec repo dùng chung (xử bước 4), nên để bước 4 route `tech_docs_dir` KHÔNG pin theo service ở đây.
191
+ - Lưu `active_service` = `services.{domain}.path`
192
+ - Lưu `active_service_module` = `services.{domain}.module`
193
+ - Nếu service `module` riêng dùng làm `active_module` (override `tech_stack.module`)
194
194
 
195
- **3. Fallback** — if domain not detected or no matching service key:
196
- - Keep default paths from Step 1
197
- - Set `active_service = unresolved`
195
+ **3. Fallback** — nếu không phát hiện được domain hoặc không có service key khớp:
196
+ - Giữ path mặc định từ Bước 1
197
+ - Đặt `active_service = unresolved`
198
198
 
199
- **4. Spec source auto-override** — if `setup.spec_source` is set AND the corresponding path was not already explicitly set in `paths:`:
200
- - Override `paths.specs_dir` → `{spec_source}/specs` — **always when `spec_source` is set.** All spec artifacts (PRD, BDD, tech-docs, design-spec) live under the unified spec root in the shared spec repo using the feature-package layout: `{spec_source}/specs/{domain}/{prd-slug}/`. Every umbrella (FE/App/BE) reads from here. *(Per-service `specs/` only when there is no `spec_source`.)*
201
- - Override `paths.tech_docs_dir` → `{spec_source}/specs` — **always when `spec_source` is set** (step 2 no longer pins tech-docs per-service in this case). Tech-docs live at `{spec_source}/specs/{domain}/{prd-slug}/tech-docs/`. The tech-design IS the cross-team API contract: BE authors it here, and FE/App read it from the same spec submodule at `/generate-code --phase=integration`. *(Per-service tech-docs only happen when there is no `spec_source` — a pure multi-service BE repo with no shared spec module.)*
199
+ **4. Tự động override theo spec source** — nếu `setup.spec_source` được đặt path tương ứng chưa được set tường minh trong `paths:`:
200
+ - Override `paths.specs_dir` → `{spec_source}/specs` — **luôn khi `spec_source` được đặt.** Mọi spec artifact (PRD, BDD, tech-docs, design-spec) nằm dưới gốc spec thống nhất trong spec repo dùng chung theo bố cục feature-package: `{spec_source}/specs/{domain}/{prd-slug}/`. Mọi umbrella (FE/App/BE) đều đọc từ đây. *(`specs/` theo service chỉ khi không `spec_source`.)*
201
+ - Override `paths.tech_docs_dir` → `{spec_source}/specs` — **luôn khi `spec_source` được đặt** (bước 2 không còn pin tech-docs theo service trong trường hợp này). Tech-docs nằm tại `{spec_source}/specs/{domain}/{prd-slug}/tech-docs/`. Tech-design CHÍNH API contract liên team: BE viết đây, FE/App đọc từ cùng spec submodule tại `/generate-code --phase=integration`. *(tech-docs theo service chỉ xảy ra khi không có `spec_source` — repo BE thuần đa-service không spec module dùng chung.)*
202
202
  - Override `paths.domain_knowledge_dir` → `{spec_source}/specs/domain-knowledge`
203
203
  - Override `paths.business_dictionary` → `{spec_source}/specs/domain-knowledge/business-dictionary.md`
204
204
  - Override `paths.core_entities` → `{spec_source}/specs/domain-knowledge/core-entities.md`
205
205
  - Override `paths.bug_reports_dir` → `{spec_source}/feedback/bug-reports`
206
206
  - Override `paths.bdd_proposals_dir` → `{spec_source}/feedback/bdd-proposals`
207
207
  - Override `paths.prd_change_requests_dir` → `{spec_source}/feedback/prd-change-requests`
208
- - Override `paths.trace_dir` → `{spec_source}/.trace` — **always when `spec_source` is set.** Trace TSVs are consolidated in the spec repo (single authoritative location, no per-service split) so the PM/PO has one place to manage status. Internal structure: `.trace/{domain}/{prd-slug}/{UC-ID}.tsv`. Code-side commands (`/generate-code`, `/dev-run-test`, `/qc-run-test`) run from `service_root` but **write their trace row into `{spec_source}/.trace/{domain}/{prd-slug}/`** — like they already push `feedback/` there. *(Per-service `.trace` only when there is no `spec_source`.)*
208
+ - Override `paths.trace_dir` → `{spec_source}/.trace` — **luôn khi `spec_source` được đặt.** Trace TSV được gộp vào spec repo (một nơi authoritative duy nhất, không tách theo service) để PM/PO một chỗ duy nhất quản lý trạng thái. Cấu trúc bên trong: `.trace/{domain}/{prd-slug}/{UC-ID}.tsv`. Các lệnh phía code (`/generate-code`, `/dev-run-test`, `/qc-run-test`) chạy từ `service_root` nhưng **ghi trace row của chúng vào `{spec_source}/.trace/{domain}/{prd-slug}/`** — giống như chúng đã push `feedback/` vào đó. *(`.trace` theo service chỉ khi không `spec_source`.)*
209
209
 
210
- > **Why under `spec_source`:** PRD, BDD, tech-docs, design-spec, domain knowledge, tester feedback, **and the `.trace/` coverage state** are all **cross-team artifacts** — they live in the **shared spec repo** using the feature-package layout so every umbrella (FE/App/BE) and the PM read one source via `/sync`. In the feature-package layout, a single `specs/{domain}/{prd-slug}/` folder groups all artifact types for one PRD, making the spec repo self-contained and navigable by feature. The service submodule holds only **code** (+ build/test tooling). `.trace/` and `feedback/` are the dev/QC **write areas** in the spec repo. In single-service mode (no `spec_source`), everything defaults under the repo root still one repo.
210
+ > ** sao đặt dưới `spec_source`:** PRD, BDD, tech-docs, design-spec, domain knowledge, feedback của tester, ** trạng thái coverage `.trace/`** đều **artifact liên team** — chúng nằm trong **spec repo dùng chung** theo bố cục feature-package để mọi umbrella (FE/App/BE) PM đọc từ một nguồn qua `/sync`. Trong bố cục feature-package, một folder `specs/{domain}/{prd-slug}/` gom tất cả loại artifact của một PRD, giúp spec repo tự đủ dễ điều hướng theo feature. Service submodule chỉ chứa **code** (+ tooling build/test). `.trace/` `feedback/` khu vực **ghi** của dev/QC trong spec repo. chế độ single-service (không `spec_source`), mọi thứ mặc định dưới gốc repo — vẫn một repo.
211
211
 
212
212
  ---
213
213
 
214
- ## Step 1.6 — [SERVICE CONVENTIONS] Load service-specific conventions (umbrella mode)
214
+ ## Bước 1.6 — [SERVICE CONVENTIONS] Nạp convention riêng của service (chế độ umbrella)
215
215
 
216
- *Skip this step entirely if `active_service` is `"unresolved"` or context is single-service mode.*
216
+ *Bỏ qua hoàn toàn bước này nếu `active_service` `"unresolved"` hoặc context chế độ single-service.*
217
217
 
218
- When `active_service` has been resolved to a real path in Step 1.5 (e.g., `user-service/`):
218
+ Khi `active_service` đã được phân giải thành một path thật Bước 1.5 (vd: `user-service/`):
219
219
 
220
- **1. Locate service config** — try in priority order:
220
+ **1. Định vị config của service** — thử theo thứ tự ưu tiên:
221
221
  - `{active_service}/.agent/project-context.yaml`
222
222
  - `{active_service}/project-context.yaml`
223
223
 
224
- **2. If found, override with service-specific values:**
224
+ **2. Nếu tìm thấy, override bằng giá trị riêng của service:**
225
225
 
226
- | Variable | Source |
226
+ | Biến | Nguồn |
227
227
  |----------|--------|
228
- | `conventions.test_command` | service's `conventions.test_command` |
229
- | `conventions.build_command` | service's `conventions.build_command` |
230
- | `paths.trace_dir` | **If `spec_source` is setkeep the Step 4 spec-repo route (`{spec_source}/.trace`); ignore any service-level `trace_dir`.** Only when there is no `spec_source`: `{active_service}/{service paths.trace_dir}` (default `{active_service}/.trace`). |
231
- | `paths.specs_dir` | **If `spec_source` is setkeep the Step 4 spec-repo route (`{spec_source}/specs`); ignore any service-level `specs_dir`** (all spec artifacts are cross-team, never per-service in this mode). Only when there is no `spec_source`: `{active_service}/{service paths.specs_dir}` if set, else the Step 1.5 override. |
228
+ | `conventions.test_command` | `conventions.test_command` của service |
229
+ | `conventions.build_command` | `conventions.build_command` của service |
230
+ | `paths.trace_dir` | **Nếu `spec_source` được đặtgiữ route spec-repo của bước 4 (`{spec_source}/.trace`); bỏ qua mọi `trace_dir` cấp service.** Chỉ khi không `spec_source`: `{active_service}/{service paths.trace_dir}` (mặc định `{active_service}/.trace`). |
231
+ | `paths.specs_dir` | **Nếu `spec_source` được đặtgiữ route spec-repo của bước 4 (`{spec_source}/specs`); bỏ qua mọi `specs_dir` cấp service** (mọi spec artifact đều liên team, không bao giờ theo service chế độ này). Chỉ khi không `spec_source`: `{active_service}/{service paths.specs_dir}` nếu được set, else dùng override ở Bước 1.5. |
232
232
 
233
- **3. Store** `service_root = {active_service}` as the working directory anchor for all downstream commands:
234
- - Shell commands (`/dev-run-test`, `/dev-gen-test`) run **from within** `service_root`
235
- - **Source/test files** are written relative to `service_root`; **trace TSVs** are written to `{paths.trace_dir}` (the spec repo when `spec_source` is seta cross-repo write, committed/pushed to the spec submodule like `feedback/`).
233
+ **3. Lưu** `service_root = {active_service}` làm mốc thư mục làm việc cho mọi lệnh phía sau:
234
+ - Các lệnh shell (`/dev-run-test`, `/dev-gen-test`) chạy **bên trong** `service_root`
235
+ - **File source/test** được ghi tương đối với `service_root`; **trace TSV** được ghi vào `{paths.trace_dir}` ( spec repo khi `spec_source` được đặtmột thao tác ghi liên-repo, commit/push vào spec submodule giống như `feedback/`).
236
236
 
237
- **4. If service config not found** — keep umbrella defaults, still set `service_root = {active_service}` (path anchor is always needed even without a config override).
237
+ **4. Nếu không tìm thấy config của service** — giữ mặc định umbrella, vẫn set `service_root = {active_service}` (luôn cần mốc path kể cả khi không config override).
238
238
 
239
239
  ---
240
240
 
241
- ## Step 2 — [PROJECT-CONFIG] Load module stack profile (conditional)
241
+ ## Bước 2 — [PROJECT-CONFIG] Nạp module stack profile (có điều kiện)
242
242
 
243
- If `tech_stack.module` is set, read `.agent/modules/{module}/stack-profile.yaml`.
244
- Merge framework-specific conventions (layer patterns, test patterns, naming rules) into the loaded context.
245
- If the file does not existskip silently.
243
+ Nếu `tech_stack.module` được đặt, đọc `.agent/modules/{module}/stack-profile.yaml`.
244
+ Merge các convention riêng của framework (layer pattern, test pattern, quy tắc đặt tên) vào context đã nạp.
245
+ Nếu file không tồn tạibỏ qua âm thầm.
246
246
 
247
247
  ---
248
248
 
249
- ## Step 3 — [CRITICAL] Load CLAUDE.md (layered: root + service overlay)
249
+ ## Bước 3 — [CRITICAL] Nạp CLAUDE.md (phân tầng: root + service overlay)
250
250
 
251
- *This is the highest-priority contextit defines HOW to write code and documents for this project.*
251
+ *Đây context ưu tiên cao nhất định nghĩa CÁCH viết code tài liệu cho dự án này.*
252
252
 
253
- CLAUDE.md is loaded in **two layers** so umbrella-wide rules and service-specific
254
- architecture/coding standards compose correctly. The agent always sits at the umbrella
255
- root, but the implementation code lives in a service submodule with its OWN stack,
256
- architecture, and conventions — so the service's CLAUDE.md must win for code generation.
253
+ CLAUDE.md được nạp theo **hai tầng** để các quy tắc toàn-umbrella kiến trúc/coding standards
254
+ riêng của service kết hợp đúng cách. Agent luôn đứng gốc umbrella, nhưng code triển khai nằm
255
+ trong một service submodule với stack, kiến trúc, convention RIÊNG của — nên CLAUDE.md của
256
+ service phải thắng khi sinh code.
257
257
 
258
- **Layer 1 — [BASE] Root CLAUDE.md (umbrella-wide).**
259
- Read `CLAUDE.md` at the repo root. Treat its contents as the **shared baseline** for the
260
- whole umbrella git conventions, data-protection posture, cross-cutting rules, and (in
261
- single-service mode) the project's only architecture + coding standards.
258
+ **Tầng 1 — [BASE] Root CLAUDE.md (toàn umbrella).**
259
+ Đọc `CLAUDE.md` gốc repo. Coi nội dung của **nền tảng dùng chung** cho cả umbrella —
260
+ git convention, thế bảo vệ dữ liệu, quy tắc xuyên suốt, (ở chế độ single-service) là
261
+ kiến trúc + coding standards duy nhất của dự án.
262
262
 
263
- **Layer 2 — [OVERLAY] Service CLAUDE.md (umbrella mode only).**
264
- *Run only if `service_root` was set in Step 1.6 (i.e. a real service was routed to).*
265
- Read `{service_root}/CLAUDE.md`. This file defines the architecture + coding standards of
266
- the **actual stack being implemented** (e.g. `user-service` = java-spring, `web` = nextjs).
267
- Overlay it on top of Layer 1: **on any conflict, the service value WINS** for architecture,
268
- coding standards, and error handling. Layer-1 values that the service does not redefine
269
- (e.g. git conventions, banned patterns shared org-wide) remain in effect.
263
+ **Tầng 2 — [OVERLAY] Service CLAUDE.md (chỉ chế độ umbrella).**
264
+ *Chỉ chạy nếu `service_root` đã được set Bước 1.6 (tức đã route tới một service thật).*
265
+ Đọc `{service_root}/CLAUDE.md`. File này định nghĩa kiến trúc + coding standards của **stack
266
+ thực sự đang được triển khai** (vd: `user-service` = java-spring, `web` = nextjs).
267
+ Overlay lên trên Tầng 1: **khi xung đột, giá trị của service THẮNG** cho kiến trúc,
268
+ coding standards, error handling. Các giá trị Tầng 1 mà service không định nghĩa lại
269
+ (vd: git convention, banned pattern dùng chung toàn tổ chức) vẫn hiệu lực.
270
270
 
271
- From the **merged** result, extract and store:
271
+ Từ kết quả **đã merge**, trích xuất và lưu:
272
272
 
273
- - **§1 Project Overview** → project name, language, framework, build/test commands, domains
274
- - **§2 Architecture** → layer order (e.g., Controller → Facade → Service → Repository), architectural rules — *service overlay wins*
275
- - **§3 Coding Standards** → naming conventions (classes, methods), response wrapper type, forbidden patterns — *service overlay wins*
276
- - **§5 Error Handling** → exception types, HTTP status code mapping, not-found exception class name — *service overlay wins*
277
- - **§7 Git Conventions** → branch naming pattern, commit message format — *root baseline unless service redefines*
273
+ - **§1 Project Overview** → tên dự án, ngôn ngữ, framework, lệnh build/test, domains
274
+ - **§2 Architecture** → thứ tự layer (vd: Controller → Facade → Service → Repository), quy tắc kiến trúc — *service overlay thắng*
275
+ - **§3 Coding Standards** → quy tắc đặt tên (class, method), kiểu response wrapper, pattern bị cấm — *service overlay thắng*
276
+ - **§5 Error Handling** → kiểu exception, mapping HTTP status code, tên class not-found exception — *service overlay thắng*
277
+ - **§7 Git Conventions** → pattern đặt tên branch, format commit message — *lấy theo root trừ khi service định nghĩa lại*
278
278
 
279
- **Resolution rules:**
280
- - If both layers exist → merge as above; record `claude_md_source = root + {service_root}`.
281
- - If only the service overlay exists (no root CLAUDE.md) → use the service file alone; `claude_md_source = {service_root}`.
282
- - If `service_root` is set but `{service_root}/CLAUDE.md` is **missing** → fall back to root CLAUDE.md and flag ⚠️ in the Step 7 recap (the service has no architecture/coding-standards definition — code generation will use umbrella defaults, which may be the wrong stack).
283
- - If neither existsnote CLAUDE.md as missing and continue with project-context.yaml data only.
279
+ **Quy tắc phân giải:**
280
+ - Nếu cả hai tầng tồn tại → merge như trên; ghi `claude_md_source = root + {service_root}`.
281
+ - Nếu chỉ service overlay (không root CLAUDE.md) → dùng file service một mình; `claude_md_source = {service_root}`.
282
+ - Nếu `service_root` được set nhưng `{service_root}/CLAUDE.md` **thiếu** → fallback về root CLAUDE.md gắn cờ ⚠️ trong recap Bước 7 (service không định nghĩa kiến trúc/coding-standards — việc sinh code sẽ dùng mặc định umbrella, thể sai stack).
283
+ - Nếu cả hai đều không tồn tại ghi nhận CLAUDE.md thiếu tiếp tục chỉ với dữ liệu từ project-context.yaml.
284
284
 
285
285
  ---
286
286
 
287
- ## Step 4 — [SAFETY] Load Data Protection Rules
287
+ ## Bước 4 — [SAFETY] Nạp quy tắc bảo vệ dữ liệu
288
288
 
289
- Read `.agent/rules/data-protection.md` (or `rules/data-protection.md` from the framework installation).
289
+ Đọc `.agent/rules/data-protection.md` (hoặc `rules/data-protection.md` từ bản cài đặt framework).
290
290
 
291
- Store the sensitive file patternsyou must **never** read, write, display, or reference content from files matching those patterns for the entire session.
291
+ Lưu các pattern file nhạy cảm bạn **tuyệt đối không** đọc, ghi, hiển thị, hay tham chiếu nội dung từ các file khớp những pattern đó trong suốt cả phiên.
292
292
 
293
- If neither file existsapply built-in defaults: never access `.env*`, `*.key`, `*.pem`, `*secret*`, `*password*`, `*credential*`.
293
+ Nếu cả hai file đều không tồn tại áp dụng mặc định built-in: không bao giờ truy cập `.env*`, `*.key`, `*.pem`, `*secret*`, `*password*`, `*credential*`.
294
294
 
295
295
  ---
296
296
 
297
- ## Step 5 — [DOMAIN] Load Business Dictionary (conditional)
297
+ ## Bước 5 — [DOMAIN] Nạp Business Dictionary (có điều kiện)
298
298
 
299
- Check if the business dictionary file exists (use `paths.business_dictionary` resolved in Step 1).
299
+ Kiểm tra file business dictionary tồn tại không (dùng `paths.business_dictionary` đã phân giải ở Bước 1).
300
300
 
301
- If it exists, read it and extract:
302
- - **Canonical Terms** → complete list of approved terms and their definitions
303
- - **Banned Terms** → complete list of banned terms and their canonical replacements
304
- - **Status / Enum Registry** → allowed enum values per entity
301
+ Nếu tồn tại, đọc trích xuất:
302
+ - **Canonical Terms** → danh sách đầy đủ các thuật ngữ chuẩn và định nghĩa
303
+ - **Banned Terms** → danh sách đầy đủ các thuật ngữ bị cấm và bản thay thế chuẩn
304
+ - **Status / Enum Registry** → các giá trị enum được phép theo từng entity
305
305
 
306
- Store the banned terms list for **active enforcement** throughout the command session:
307
- - When generating any text (PRD, BDD, code comments, tech docs), verify no banned terms appear
308
- - Replace banned terms with their canonical equivalents automatically
306
+ Lưu danh sách banned term để **thực thi chủ động** suốt phiên làm việc của lệnh:
307
+ - Khi sinh bất kỳ văn bản nào (PRD, BDD, comment code, tech docs), kiểm tra không có banned term nào xuất hiện
308
+ - Tự động thay banned term bằng bản chuẩn tương đương
309
309
 
310
- If the file does not existskip silently. Do not warn or block.
310
+ Nếu file không tồn tạibỏ qua âm thầm. Không cảnh báo hay chặn.
311
311
 
312
312
  ---
313
313
 
314
- ## Step 6 — [DOMAIN] Load Core Entities (conditional)
314
+ ## Bước 6 — [DOMAIN] Nạp Core Entities (có điều kiện)
315
315
 
316
- Check if the core entities file exists at `paths.core_entities` (resolved in Step 1).
317
- Default path: `specs/domain-knowledge/core-entities.md`.
316
+ Kiểm tra file core entities tồn tại tại `paths.core_entities` không (đã phân giải ở Bước 1).
317
+ Path mặc định: `specs/domain-knowledge/core-entities.md`.
318
318
 
319
- If it exists, read it and store:
320
- - **Entity catalog** → for each entity: its name, purpose, owner service, key fields (name + type), business invariants, and relationships
321
- - **Field name registry** → canonical field names to use in generated code and documents
322
- - **Relationship map** → how entities relate to each other (1:N, N:N, embedded, etc.)
319
+ Nếu tồn tại, đọc lưu:
320
+ - **Entity catalog** → với mỗi entity: tên, mục đích, service sở hữu, các field chính (tên + kiểu), business invariant, quan hệ
321
+ - **Field name registry** → tên field chuẩn dùng trong code tài liệu được sinh ra
322
+ - **Relationship map** → cách các entity liên hệ với nhau (1:N, N:N, embedded, v.v.)
323
323
 
324
- **How to use this catalog:**
325
- - When generating code: use the field names, types, and relationships defined heredo NOT infer from existing code
326
- - When generating PRD/BDD: reference entity names from this catalog for consistency
327
- - When generating tech-docs: use this catalog as the source-of-truth for entity definitions
324
+ **Cách dùng catalog này:**
325
+ - Khi sinh code: dùng tên field, kiểu, quan hệ định nghĩa ở đây KHÔNG suy đoán từ code có sẵn
326
+ - Khi sinh PRD/BDD: tham chiếu tên entity từ catalog này để nhất quán
327
+ - Khi sinh tech-docs: dùng catalog này làm nguồn chân lý cho định nghĩa entity
328
328
 
329
- If the file does not existskip silently.
329
+ Nếu file không tồn tạibỏ qua âm thầm.
330
330
 
331
331
  ---
332
332
 
333
- ## Step 6.5 — [PLATFORM] Derive active_module and platform_type
333
+ ## Bước 6.5 — [PLATFORM] Suy ra active_module platform_type
334
334
 
335
- Using `tech_stack.module` loaded in Step 1, derive and store two variables for use by all downstream commands:
335
+ Dùng `tech_stack.module` đã nạp Bước 1, suy ra lưu hai biến để mọi lệnh phía sau dùng:
336
336
 
337
337
  ```
338
- active_module = tech_stack.module (e.g. "java-spring", "react", "flutter")
338
+ active_module = tech_stack.module (vd: "java-spring", "react", "flutter")
339
339
  ```
340
340
 
341
341
  | `platform_type` | Modules |
@@ -344,155 +344,155 @@ active_module = tech_stack.module (e.g. "java-spring", "react", "flutter")
344
344
  | `web-frontend` | `react`, `nextjs`, `vue`, `nuxt`, `angular` |
345
345
  | `mobile` | `flutter`, `react-native`, `ios-swiftui`, `android-compose` |
346
346
 
347
- If `tech_stack.module` is blank or not recognized → set `platform_type = "unknown"` and flag as ⚠️ in the Step 7 recap.
347
+ Nếu `tech_stack.module` rỗng hoặc không nhận diện được → set `platform_type = "unknown"` gắn cờ ⚠️ trong recap Bước 7.
348
348
 
349
- These two variables (`active_module`, `platform_type`) are the canonical source for all branching logic in commands that need platform-specific behavior (dev-gen-test, debug, fix-bug, dev-smoke-test).
349
+ Hai biến này (`active_module`, `platform_type`) nguồn chuẩn cho mọi logic rẽ nhánh trong các lệnh cần hành vi riêng theo platform (dev-gen-test, debug, fix-bug, dev-smoke-test).
350
350
 
351
351
  ---
352
352
 
353
- ## Step 6.7 — [GUARDRAILS] Load Project Lessons (conditional)
353
+ ## Bước 6.7 — [GUARDRAILS] Nạp Project Lessons (có điều kiện)
354
354
 
355
- *Accumulated mistakes the AI must not repeat in this project. These are added over time via `/learn`
356
- or accepted during `/review-code`, `/fix-bug`, `/debug`.*
355
+ *Các lỗi tích luỹ mà AI không được lặp lại trong dự án này. Chúng được bổ sung dần qua `/learn`
356
+ hoặc được chấp nhận trong `/review-code`, `/fix-bug`, `/debug`.*
357
357
 
358
- Resolve the lessons file path:
359
- - Use `paths.lessons_file` if set (may be service-overridden in umbrella mode, Step 1.6)
360
- - Else default `specs/domain-knowledge/lessons-learned.md`
361
- - In umbrella/service mode (when `service_root` is set), if `paths.lessons_file` is unset, default to `{service_root}/.agent/project-lessons.md`
358
+ Phân giải path file lessons:
359
+ - Dùng `paths.lessons_file` nếu được set ( thể bị service override ở chế độ umbrella, Bước 1.6)
360
+ - Else mặc định `specs/domain-knowledge/lessons-learned.md`
361
+ - chế độ umbrella/service (khi `service_root` được set), nếu `paths.lessons_file` chưa set, mặc định `{service_root}/.agent/project-lessons.md`
362
362
 
363
- If the file exists, read it and store ALL lessons as **ACTIVE GUARDRAILS** for the session:
364
- - Treat each lesson's **Rule** as a hard constraintsame priority as CLAUDE.md coding standards (Step 3).
365
- - Before generating or modifying any artifact (PRD, BDD, tech-doc, code, test), check the output against every lesson whose `category` matches the current command AND whose `scope` matches the target (domain / file).
366
- - If a generated output would violate a lesson → correct it **before** presenting, and note which lesson (`L-NNN`) was applied.
363
+ Nếu file tồn tại, đọc lưu TẤT CẢ lesson làm **GUARDRAIL ĐANG HOẠT ĐỘNG** cho phiên:
364
+ - Coi **Rule** của mỗi lesson ràng buộc cứng cùng mức ưu tiên với coding standards trong CLAUDE.md (Bước 3).
365
+ - Trước khi sinh hoặc sửa bất kỳ artifact nào (PRD, BDD, tech-doc, code, test), đối chiếu output với mọi lesson `category` khớp lệnh hiện tại `scope` khớp target (domain / file).
366
+ - Nếu output sinh ra vi phạm một lesson → sửa **trước khi** trình bày, ghi lesson nào (`L-NNN`) đã được áp dụng.
367
367
 
368
- If the file does not existskip silently (no lessons captured yet).
368
+ Nếu file không tồn tạibỏ qua âm thầm (chưa lesson nào được ghi nhận).
369
369
 
370
370
  ---
371
371
 
372
- ## Step 7 — [RECAP] Working Memory Recap (anti-lost-in-middle)
372
+ ## Bước 7 — [RECAP] Working Memory Recap (chống lost-in-middle)
373
373
 
374
- After loading all context, synthesize and output a compact summary block.
375
- This recap ensures the most critical facts are stated at the END of context loading
376
- (recency effect freshest in working memory when the task begins).
374
+ Sau khi nạp toàn bộ context, tổng hợp xuất một khối tóm tắt gọn.
375
+ Recap này đảm bảo các sự thật quan trọng nhất được nêu CUỐI quá trình nạp context
376
+ (hiệu ứng recency — tươi mới nhất trong bộ nhớ làm việc khi bắt đầu task).
377
377
 
378
- Output exactly this block:
378
+ Xuất đúng khối này:
379
379
  ```
380
380
  [CTX LOADED]
381
381
  Stack : {language} / {framework} / {database}
382
382
  Platform : {active_module} ({platform_type})
383
- Layers : {layer order from merged CLAUDE.md §2, e.g., Controller → Facade → Service → Repository}
384
- CLAUDE.md : {root + {service_root} | {service_root} only | root only | ⚠️ service overlay MISSINGusing root | missing}
383
+ Layers : {thứ tự layer từ CLAUDE.md §2 đã merge, vd: Controller → Facade → Service → Repository}
384
+ CLAUDE.md : {root + {service_root} | chỉ {service_root} | chỉ root | ⚠️ service overlay THIẾUdùng root | missing}
385
385
  Ticket : {ticket_prefix}-
386
386
  Dict : {loaded — N canonical terms, M banned terms | missing}
387
387
  Entities : {loaded — EntityA, EntityB, EntityC | missing}
388
- Lessons : {loaded — N guardrails | none yet}
388
+ Lessons : {loaded — N guardrails | chưa }
389
389
  Service : {active_service} ({active_service_module}) | single-service
390
- Svc Root : {service_root} — conventions + trace_dir loaded from service config | —
391
- Status : {FULL | PARTIAL — missing: CLAUDE.md / business-dict / core-entities | MINIMAL}
390
+ Svc Root : {service_root} — đã nạp conventions + trace_dir từ config service | —
391
+ Status : {FULL | PARTIAL — thiếu: CLAUDE.md / business-dict / core-entities | MINIMAL}
392
392
  ```
393
393
 
394
- If any CRITICAL file is missing (CLAUDE.md), flag it clearly so the user can decide whether to proceed.
394
+ Nếu bất kỳ file CRITICAL nào thiếu (CLAUDE.md), gắn cờ ràng để người dùng quyết định tiếp tục hay không.
395
395
 
396
396
  ---
397
397
 
398
- ## Context Load Complete
398
+ ## Hoàn tất nạp Context
399
399
 
400
- After completing all steps, you have loaded:
401
- - Project identity, tech stack, module conventions
402
- - Architecture rules and layer order ← **[CRITICAL — hold in working memory]**
403
- - Coding standards and naming conventions ← **[CRITICAL — hold in working memory]**
404
- - Data protection rules (sensitive file patterns to never access)
405
- - Terminology rules with banned-term list ← **[DOMAIN — apply to every generated word]**
406
- - Entity catalog (field names, types, invariants) ← **[DOMAIN — use for code generation]**
407
- - All configured paths
400
+ Sau khi hoàn thành tất cả các bước, bạn đã nạp:
401
+ - Định danh dự án, tech stack, convention module
402
+ - Quy tắc kiến trúc và thứ tự layer ← **[CRITICAL — giữ trong bộ nhớ làm việc]**
403
+ - Coding standards quy tắc đặt tên ← **[CRITICAL — giữ trong bộ nhớ làm việc]**
404
+ - Quy tắc bảo vệ dữ liệu (pattern file nhạy cảm không bao giờ truy cập)
405
+ - Quy tắc thuật ngữ kèm danh sách banned term ← **[DOMAIN — áp dụng cho mọi từ được sinh ra]**
406
+ - Entity catalog (tên field, kiểu, invariant) ← **[DOMAIN — dùng khi sinh code]**
407
+ - Toàn bộ path đã cấu hình
408
408
 
409
- Proceed to the next step of the calling command.
409
+ Tiếp tục sang bước kế tiếp của lệnh đang gọi.
410
410
 
411
411
 
412
412
  ---
413
413
 
414
- ## Detect Review Mode
414
+ ## Phát hiện Review Mode
415
415
 
416
- After resolving the target file:
417
- - `.feature` file → **BDD Review Mode** (jump to BDD section)
418
- - `prd.md` under `{paths.specs_dir}/*/*/` → **PRD Review Mode** (continue below)
419
- - Unknownask: "Is this a PRD file or a BDD feature file? (prd/bdd)"
416
+ Sau khi phân giải target file:
417
+ - File `.feature` → **BDD Review Mode** (nhảy tới section BDD)
418
+ - File `.md` gốc feature folder `{paths.specs_dir}/*/*/` (không phải dưới `bdd/`·`tech-docs/`·`design-spec/`) → **PRD Review Mode** (tiếp tục bên dưới)
419
+ - Không xác định hỏi: "Đây file PRD hay file BDD feature? (prd/bdd)"
420
420
 
421
- Also check flags:
422
- - `--fix` present after running all checks, apply `auto_fixable: true` findings immediately (skip Review Board)
423
- - `--resume` present skip analysis entirely, go to Resume Mode
421
+ Đồng thời kiểm tra flag:
422
+ - `--fix` → sau khi chạy hết các check, áp dụng ngay các finding `auto_fixable: true` (bỏ qua Review Board)
423
+ - `--resume` → bỏ qua phân tích hoàn toàn, sang Resume Mode
424
424
 
425
- Derive the output findings filename:
425
+ Suy ra tên file findings output:
426
426
  - PRD: `{paths.refinement_dir}/{prd-slug}-review-context-findings.yaml`
427
427
  - BDD: `{paths.refinement_dir}/{uc-id}-review-bdd-findings.yaml`
428
428
 
429
429
  ---
430
430
 
431
- ## Review Procedure
432
- # Exhaustive Review Fan-Out + Completeness Convergence
431
+ ## Quy trình Review
432
+ # Review Fan-Out toàn diện + Hội tụ về độ đầy đủ
433
433
 
434
- **Why this exists:** A single-pass review never lists every issue at oncethe model
435
- stops at "enough" findings, so each later review round surfaces *new* problems
436
- (whack-a-mole). This procedure forces the review to **converge in one command run**:
437
- fan out across review dimensions in parallel, then loop a completeness critic until a
438
- round produces nothing new, *before* writing the findings file.
434
+ ** sao có cái này:** Một lượt review đơn không bao giờ liệt hết mọi vấn đề cùng lúc — model
435
+ dừng mức "đủ" findings, nên mỗi vòng review sau lại lòi ra vấn đề *mới*
436
+ (đập chuột chũi). Quy trình này ép review **hội tụ trong một lần chạy lệnh**:
437
+ fan out song song theo các chiều review, rồi lặp một critic độ-đầy-đủ cho tới khi một
438
+ vòng không sinh thêm gì mới, *trước khi* ghi file findings.
439
439
 
440
- The calling command supplies two things:
441
- - **DIMENSIONS** — the list of review dimensions to fan out over
442
- (`/refine-prd` → the 4 lenses; `/review-context` → the P-checks or B-checks).
443
- - **FINDINGS SCHEMA** — the YAML shape each finding must follow (defined in the command).
440
+ Lệnh gọi cung cấp hai thứ:
441
+ - **DIMENSIONS** — danh sách các chiều review để fan out
442
+ (`/refine-prd` → 4 lăng kính; `/review-context` → các P-check hoặc B-check).
443
+ - **FINDINGS SCHEMA** — dạng YAML mỗi finding phải theo (định nghĩa trong lệnh).
444
444
 
445
- > **Sub-agent mode bypass:** If Gate Step 0 set `_agent_mode: true`, this whole
446
- > procedure is **skipped** — the orchestrator is already running one dimension/UC per
447
- > sub-agent. Run the command's checks directly on the scoped section and return findings.
445
+ > **Bỏ qua ở chế độ sub-agent:** Nếu Gate Bước 0 đã set `_agent_mode: true`, toàn bộ
446
+ > quy trình này bị **bỏ qua** — orchestrator đã chạy sẵn một dimension/UC cho mỗi
447
+ > sub-agent. Chạy các check của lệnh trực tiếp trên section đã giới hạn và trả về findings.
448
448
 
449
449
  ---
450
450
 
451
- ## Phase 1 — Parallel dimension scan
451
+ ## Phase 1 — Quét dimension song song
452
452
 
453
- **How many sub-agents:** the agent *count* is not the completeness leverbreadth is
454
- fixed by the DIMENSION taxonomy (adding agents to the same dimension just re-finds the
455
- same issues), and *depth* is owned by the Phase 2 critic loop. Pick the **fan-out
456
- granularity** by target size, reusing the `steps/spawn-agent.md` thresholds:
453
+ **Bao nhiêu sub-agent:** *số lượng* agent không phải đòn bẩy độ đầy đủ bề rộng được
454
+ cố định bởi taxonomy DIMENSION (thêm agent vào cùng một dimension chỉ tìm lại cùng vấn đề),
455
+ còn *độ sâu* thuộc về vòng lặp critic ở Phase 2. Chọn **độ mịn fan-out**
456
+ theo kích thước target, tái dùng ngưỡng của `steps/spawn-agent.md`:
457
457
 
458
- | Target size | Granularity | Agent count |
458
+ | Kích thước target | Độ mịn | Số agent |
459
459
  |-------------|-------------|-------------|
460
- | ≤ 3 UCs **and** ≤ 300 lines | one agent per DIMENSION over the whole file | = number of dimensions |
461
- | > 3 UCs **or** > 300 lines | one agent per **DIMENSION × UC-scope** (UCs + a PRD-global scope), batched to fit the agent cap | `dimensions × (UCs + 1)`, capped (see below) |
460
+ | ≤ 3 UC **và** ≤ 300 dòng | một agent cho mỗi DIMENSION trên cả file | = số dimension |
461
+ | > 3 UC **hoặc** > 300 dòng | một agent cho mỗi **DIMENSION × phạm vi UC** (các UC + một phạm vi PRD-global), gom batch để vừa giới hạn agent | `dimensions × (UCs + 1)`, cap (xem dưới) |
462
462
 
463
- The larger granularity keeps each sub-agent's context small and its scan exhaustive on a
464
- single UC — which is what prevents misses on big PRDs.
463
+ Độ mịn lớn hơn giữ context của mỗi sub-agent nhỏ quét vét cạn trên một
464
+ UC duy nhất chính điều ngăn bỏ sót trên các PRD lớn.
465
465
 
466
- > **Global (non-UC) sections required in `DIMENSION × UC` mode.** Per-UC agents only
467
- > see one UC each, so PRD-wide sections that belong to no UC (scope, success metrics,
468
- > problem statement, terminology, glossary, changelog) would go unscanned. Whenever you
469
- > fan out per UC, also include a **"PRD-global"** scope (the non-UC sections, findings get
470
- > `uc_id: ""`) alongside the UC list. So the natural agent count is `dimensions × (UCs + 1)`.
471
- > (Not needed in the whole-file mode there each agent already sees the global sections.)
466
+ > **Các section global (không thuộc UC) — bắt buộc ở chế độ `DIMENSION × UC`.** Mỗi agent per-UC chỉ
467
+ > thấy một UC, nên các section toàn-PRD không thuộc UC nào (scope, success metric,
468
+ > problem statement, terminology, glossary, changelog) sẽ không được quét. Khi nào
469
+ > fan out theo UC, cũng phải thêm một phạm vi **"PRD-global"** (các section không thuộc UC, finding nhận
470
+ > `uc_id: ""`) bên cạnh danh sách UC. Nên số agent tự nhiên `dimensions × (UCs + 1)`.
471
+ > (Không cần chế độ whole-file — đó mỗi agent đã thấy các section global rồi.)
472
472
 
473
- ### Agent cap — batch UCs when the fan-out gets too wide
473
+ ### Agent cap — gom batch các UC khi fan-out quá rộng
474
474
 
475
- `dimensions × (UCs + 1)` can explode on large PRDs (e.g. 6 checks × (8 UCs + 1) = 54
476
- agents). Cap the wave at **`AGENT_CAP = 12`** agents and batch UC scopes to fit:
475
+ `dimensions × (UCs + 1)` thể bùng nổ trên PRD lớn (vd 6 check × (8 UC + 1) = 54
476
+ agent). Giới hạn mỗi wave **`AGENT_CAP = 12`** agent gom batch các phạm vi UC cho vừa:
477
477
 
478
- 1. Build the scope list = `[UC1, UC2, …, UCn, PRD-global]` (length `UCs + 1`).
479
- 2. Compute scopes-per-agent-bucket: `groups = max(1, floor(AGENT_CAP / dimensions))`.
480
- - If `groups ≥ UCs + 1` → no batching needed, run one agent per `DIMENSION × scope`.
481
- - Else split the scope list into `groups` contiguous buckets of roughly equal size
482
- (keep `PRD-global` in its own bucket if it fits; otherwise append it to the last
483
- bucket). Each agent then handles **one DIMENSION over one bucket of UCs**.
484
- 3. Resulting wave size = `dimensions × groups ≤ AGENT_CAP`.
478
+ 1. Dựng danh sách phạm vi = `[UC1, UC2, …, UCn, PRD-global]` (độ dài `UCs + 1`).
479
+ 2. Tính số-phạm-vi-mỗi-bucket: `groups = max(1, floor(AGENT_CAP / dimensions))`.
480
+ - Nếu `groups ≥ UCs + 1` → không cần batch, chạy một agent cho mỗi `DIMENSION × scope`.
481
+ - Else chia danh sách phạm vi thành `groups` bucket liền kề kích thước xấp xỉ bằng nhau
482
+ (giữ `PRD-global` bucket riêng nếu vừa; nếu không thì gắn vào bucket cuối).
483
+ Mỗi agent khi đó xử lý **một DIMENSION trên một bucket UC**.
484
+ 3. Kích thước wave kết quả = `dimensions × groups ≤ AGENT_CAP`.
485
485
 
486
- A batched agent reviews several UCs at oncestill scoped far tighter than the whole
487
- file, so coverage stays high. `AGENT_CAP` is the only knob; raise it if the host allows
488
- more concurrency, lower it to save tokens. Whole-file mode (≤ 3 UCs) never hits the cap.
486
+ Một agent đã batch review nhiều UC cùng lúc vẫn giới hạn chặt hơn nhiều so với cả
487
+ file, nên độ phủ vẫn cao. `AGENT_CAP` núm chỉnh duy nhất; tăng nếu host cho phép
488
+ concurrency nhiều hơn, giảm để tiết kiệm token. Chế độ whole-file (≤ 3 UC) không bao giờ chạm cap.
489
489
 
490
- Spawn the chosen sub-agents using the Agent tool (send them in a single message so they
491
- run concurrently). Each sub-agent gets a **fresh context window** and scans its scope
492
- through its **one** dimension onlydeeper coverage than one session juggling every
493
- dimension at once (avoids lost-in-the-middle).
490
+ Spawn các sub-agent đã chọn bằng Agent tool (gửi trong một message duy nhất để chúng
491
+ chạy đồng thời). Mỗi sub-agent nhận một **context window mới** quét phạm vi của nó
492
+ chỉ qua **một** dimension duy nhất độ phủ sâu hơn một session phải tung hứng mọi
493
+ dimension cùng lúc (tránh lost-in-the-middle).
494
494
 
495
- Sub-agent prompt template (fill the braces):
495
+ Template prompt cho sub-agent (điền vào các ngoặc):
496
496
 
497
497
  ```
498
498
  You are a {DIMENSION_NAME} reviewer. Read the full target file at {target_file}.
@@ -508,20 +508,20 @@ Return a JSON array of findings, each:
508
508
  Return [] if this dimension is clean. Return ONLY the JSON array.
509
509
  ```
510
510
 
511
- Collect every sub-agent's array into one consolidated list `ALL_FINDINGS`.
511
+ Gom mảng findings của mọi sub-agent vào một danh sách hợp nhất `ALL_FINDINGS`.
512
512
 
513
513
  ---
514
514
 
515
- ## Phase 2 — Completeness-critic convergence loop
515
+ ## Phase 2 — Vòng lặp hội tụ critic độ-đầy-đủ
516
516
 
517
- This is the anti-whack-a-mole step. Repeat until **two consecutive rounds add zero new
518
- findings**, or a hard cap of **3 rounds**, whichever comes first:
517
+ Đây bước chống đập-chuột-chũi. Lặp cho tới khi **hai vòng liên tiếp thêm 0 finding
518
+ mới**, hoặc tới cap cứng **3 vòng**, cái nào đến trước:
519
519
 
520
- 1. Spawn one **completeness-critic** sub-agent with the Agent tool. Give it:
521
- - the full target file (`{target_file}`),
522
- - the current `ALL_FINDINGS` list (so it knows what is already captured),
523
- - the same slim context.
524
- Prompt it:
520
+ 1. Spawn một sub-agent **completeness-critic** bằng Agent tool. Cho nó:
521
+ - toàn bộ target file (`{target_file}`),
522
+ - danh sách `ALL_FINDINGS` hiện tại (để biết những đã được ghi nhận),
523
+ - cùng context gọn đó.
524
+ Prompt nó:
525
525
  ```
526
526
  Here is a document and a list of issues already found. Read the WHOLE document.
527
527
  List ONLY real, additional issues NOT already in the list — gaps, ambiguities,
@@ -530,142 +530,140 @@ findings**, or a hard cap of **3 rounds**, whichever comes first:
530
530
  Do NOT repeat anything already listed. Return the same finding JSON shape, or [] if
531
531
  nothing new.
532
532
  ```
533
- 2. Append any genuinely new findings (not already in `ALL_FINDINGS`) to the list.
534
- 3. If this round returned 0 newincrement the dry-round counter; else reset it to 0.
535
- 4. Stop when dry-round counter reaches 2, or after 3 rounds total.
533
+ 2. Thêm bất kỳ finding thực sự mới (chưa trong `ALL_FINDINGS`) vào danh sách.
534
+ 3. Nếu vòng này trả 0 finding mới tăng bộ đếm dry-round; ngược lại reset về 0.
535
+ 4. Dừng khi bộ đếm dry-round đạt 2, hoặc sau tổng cộng 3 vòng.
536
536
 
537
- Record `convergence_rounds` (how many critic rounds ran) for the report.
537
+ Ghi lại `convergence_rounds` (số vòng critic đã chạy) cho report.
538
538
 
539
539
  ---
540
540
 
541
- ## Phase 3 — Dedup, resolve conflicts, merge
542
-
543
- Sub-agents run **blind to each other** (independence = diverse coverage). They never
544
- talk or reconcile among themselvesall duplicate/conflict resolution happens **here in
545
- the orchestrator**, where the full set is visible.
546
-
547
- 1. **Deduplicate** `ALL_FINDINGS`: two findings are duplicates if they target the same
548
- `section` + `uc_id` and describe the same underlying issue. Keep the one with the
549
- richer `suggestion`; if they differ on severity, keep the **higher** severity.
550
- 2. **Resolve conflicts** — group remaining findings by `section` + `uc_id` and check for
551
- contradictions (two findings whose `suggestion`s cannot both be applied, or that
552
- propose opposite fixes for the same spot):
553
- - If the two suggestions can be **merged** into one coherent fix merge them into a
554
- single finding.
555
- - If they are **mutually exclusive** emit **one** finding that states both options
556
- and set `auto_fixable: false` with `status: "needs_discussion"` (PRD) /
557
- `status: "pending"` (review) so a human picks never silently drop one side.
558
- - If a finding is **invalidated** by another (e.g. a structural finding says a section
559
- is missing, but another quotes content from it) drop the invalid one.
560
- 3. **Sort** by severity (critical major minor), then by `section` order in the file.
561
- 4. **Assign stable IDs** `F001, F002, …` in that sorted order.
562
- 5. Map each finding's `dimension` into the command's schema field
563
- (`lens` for `/refine-prd`; `check_id` for `/review-context`).
564
- 6. Write the **single** findings file in the FINDINGS SCHEMA the command defines.
565
-
566
- In the command's final report, add one line:
541
+ ## Phase 3 — Dedup, giải quyết xung đột, merge
542
+
543
+ Các sub-agent chạy ** với nhau** (độc lập = độ phủ đa dạng). Chúng không bao giờ
544
+ trao đổi hay điều hoà giữa chúng mọi xử lý trùng/xung đột diễn ra **ở đây trong
545
+ orchestrator**, nơi thấy toàn bộ tập findings.
546
+
547
+ 1. **Khử trùng lặp** `ALL_FINDINGS`: hai finding trùng nếu cùng nhắm tới cùng
548
+ `section` + `uc_id` tả cùng một vấn đề gốc. Giữ cái `suggestion`
549
+ phong phú hơn; nếu khác nhau về severity, giữ severity **cao hơn**.
550
+ 2. **Giải quyết xung đột** — nhóm các finding còn lại theo `section` + `uc_id` kiểm tra
551
+ mâu thuẫn (hai finding `suggestion` không thể cùng áp dụng, hoặc đề xuất sửa ngược nhau cho cùng một chỗ):
552
+ - Nếu hai đề xuất thể **merge** thành một bản sửa mạch lạc → merge thành một finding duy nhất.
553
+ - Nếu chúng **loại trừ lẫn nhau** phát ra **một** finding nêu cả hai phương án
554
+ set `auto_fixable: false` với `status: "needs_discussion"` (PRD) /
555
+ `status: "pending"` (review) để con người chọn không bao giờ âm thầm bỏ một bên.
556
+ - Nếu một finding bị **vô hiệu** bởi finding khác (vd một finding cấu trúc nói một section
557
+ bị thiếu, nhưng một finding khác trích dẫn nội dung từ chính section đó) → bỏ cái không hợp lệ.
558
+ 3. **Sắp xếp** theo severity (critical major minor), rồi theo thứ tự `section` trong file.
559
+ 4. **Gán ID ổn định** `F001, F002, …` theo thứ tự đã sắp đó.
560
+ 5. Map `dimension` của mỗi finding vào field schema của lệnh
561
+ (`lens` cho `/refine-prd`; `check_id` cho `/review-context`).
562
+ 6. Ghi **một** file findings duy nhất theo FINDINGS SCHEMA mà lệnh định nghĩa.
563
+
564
+ Trong report cuối của lệnh, thêm một dòng:
567
565
  ```
568
- Convergence: {convergence_rounds} critic round(s) — findings file is complete; re-running should surface 0 new issues.
566
+ Convergence: {convergence_rounds} vòng critic — file findings đã đầy đủ; chạy lại sẽ lòi ra 0 vấn đề mới.
569
567
  ```
570
568
 
571
569
 
572
- **How the checks below map onto the procedure:**
573
- - **DIMENSIONS** = the check groups for the detected mode — PRD: `P1, P2, P4, P5`; BDD: `B1, B2, B3, B4, B5, B6`. Fan out one sub-agent per check group, each scanning the full target file for just that group.
574
- - **Orchestrator-run checks (not fanned out):** `P0` (umbrella routing) and `P3` (cross-PRD conflict) need config / other-PRD contextthe orchestrator runs these itself **before** the fan-out and adds their results to `ALL_FINDINGS`.
575
- - The completeness-critic loop (Phase 2) guarantees the findings file is complete in one runre-running `/review-context` should surface **0 new** findings. Map each dimension into the `check_id` field of the schema below.
570
+ **Các check dưới đây map vào quy trình như sau:**
571
+ - **DIMENSIONS** = các nhóm check theo mode phát hiện được — PRD: `P1, P2, P4, P5`; BDD: `B1, B2, B3, B4, B5, B6`. Fan out một sub-agent cho mỗi nhóm check, mỗi cái quét toàn bộ target file chỉ cho nhóm đó.
572
+ - **Check do orchestrator chạy (không fan out):** `P0` (umbrella routing) `P3` (xung đột cross-PRD) cần config / context của PRD khác — orchestrator tự chạy chúng **trước** fan-out thêm kết quả vào `ALL_FINDINGS`.
573
+ - Vòng lặp completeness-critic (Phase 2) đảm bảo file findings đầy đủ trong một lần chạychạy lại `/review-context` sẽ lòi ra **0 finding mới**. Map mỗi dimension vào field `check_id` của schema dưới đây.
576
574
 
577
575
  ---
578
576
 
579
577
  ## PRD Review Mode
580
578
 
581
- ### P0 — Umbrella Routing Check (umbrella mode only)
579
+ ### P0 — Umbrella Routing Check (chỉ chế độ umbrella)
582
580
 
583
- *Skip this check entirely if `setup.mode` is not `"umbrella"` (i.e., `services` section absent from project-context.yaml).*
581
+ *Bỏ qua hoàn toàn check này nếu `setup.mode` không phải `"umbrella"` (tức không có section `services` trong project-context.yaml).*
584
582
 
585
- When `setup.mode = umbrella`, the PRD must have correct routing metadata so context-loader Step 1.5 can direct generated output to the right service submodule. Run these checks **before P1–P5**:
583
+ Khi `setup.mode = umbrella`, PRD phải metadata routing đúng để context-loader Bước 1.5 thể đưa output sinh ra tới đúng service submodule. Chạy các check này **trước P1–P5**:
586
584
 
587
- **P0.1 — `@trace.domain` presence**
588
- - Read the PRD frontmatter block (lines starting with `@trace.` at top of file)
589
- - If `@trace.domain` is **absent** → **critical** finding:
590
- - `finding`: "`@trace.domain` is missing. Dev team's umbrella routing depends on this field to route BDD and code output to the correct service submodule."
591
- - `suggestion`: "Add `@trace.domain: {domain}` to the PRD frontmatter. Use one of the domain keys defined in the umbrella's `project-context.yaml` services section."
592
- - `auto_fixable: false` — PO must confirm the correct domain name
585
+ **P0.1 — `@trace.domain` có mặt**
586
+ - Đọc block frontmatter của PRD (các dòng bắt đầu bằng `@trace.` đầu file)
587
+ - Nếu `@trace.domain` **vắng mặt** → finding **critical**:
588
+ - `finding`: "`@trace.domain` đang thiếu. Umbrella routing của team dev phụ thuộc field này để đưa BDD code output tới đúng service submodule."
589
+ - `suggestion`: "Thêm `@trace.domain: {domain}` vào frontmatter của PRD. Dùng một trong các domain key được định nghĩa trong section services của `project-context.yaml` của umbrella."
590
+ - `auto_fixable: false` — PO phải confirm tên domain đúng
593
591
 
594
- **P0.2 — `@trace.domain` matches a service key**
595
- - If `@trace.domain` is present, check if its value matches any key in the `services` section of project-context.yaml
596
- - If **no match found** → **critical** finding:
597
- - `finding`: "`@trace.domain: {value}` does not match any key in the umbrella's `services` config. Routing will fall back to default paths and BDD may be generated to the wrong location."
598
- - `suggestion`: "Either update `@trace.domain` to match an existing service key ({list known keys}), or add a new entry to `services` in project-context.yaml for domain `{value}`."
592
+ **P0.2 — `@trace.domain` khớp một service key**
593
+ - Nếu `@trace.domain` mặt, kiểm tra giá trị của có khớp key nào trong section `services` của project-context.yaml không
594
+ - Nếu **không khớp** → finding **critical**:
595
+ - `finding`: "`@trace.domain: {value}` không khớp key nào trong config `services` của umbrella. Routing sẽ fallback về path mặc định BDD thể được sinh sai chỗ."
596
+ - `suggestion`: "Hoặc cập nhật `@trace.domain` cho khớp một service key có sẵn ({list known keys}), hoặc thêm entry mới vào `services` trong project-context.yaml cho domain `{value}`."
599
597
  - `auto_fixable: false`
600
- - If `services` section is not yet configured (empty/placeholder) → **major** finding:
601
- - `finding`: "Umbrella `services` section is not yet configured. Cannot verify domain routing."
602
- - `suggestion`: "Update `.agent/project-context.yaml` services section with domain-to-submodule mapping before generating BDD."
598
+ - Nếu section `services` chưa được cấu hình (rỗng/placeholder) → finding **major**:
599
+ - `finding`: "Section `services` của umbrella chưa được cấu hình. Không thể kiểm chứng domain routing."
600
+ - `suggestion`: "Cập nhật section services trong `.agent/project-context.yaml` với mapping domain-to-submodule trước khi sinh BDD."
603
601
  - `auto_fixable: false`
604
602
 
605
- **P0.3 — `@trace.status` check**
606
- - If `@trace.status` is absent → **minor**, `auto_fixable: true` (add `@trace.status: draft`)
607
- - If `@trace.status: draft` → **major**, `auto_fixable: false`:
608
- - `finding`: "PRD status is `draft`. Dev team should not generate BDD from an unapproved PRD."
609
- - `suggestion`: "PO/SA should review and update status to `approved` before dev team proceeds."
603
+ **P0.3 — Check `@trace.status`**
604
+ - Nếu `@trace.status` vắng mặt → **minor**, `auto_fixable: true` (thêm `@trace.status: draft`)
605
+ - Nếu `@trace.status: draft` → **major**, `auto_fixable: false`:
606
+ - `finding`: "PRD status `draft`. Team dev không nên sinh BDD từ một PRD chưa được duyệt."
607
+ - `suggestion`: "PO/SA nên review cập nhật status thành `approved` trước khi team dev tiếp tục."
610
608
 
611
- > **P0 is a gate check:** If P0.1 or P0.2 yields a critical finding, display a warning before proceeding:
609
+ > **P0 một gate check:** Nếu P0.1 hoặc P0.2 cho finding critical, hiển thị cảnh báo trước khi tiếp tục:
612
610
  > ```
613
- > ⚠️ ROUTING WARNING: @trace.domain issue detected.
614
- > BDD/code generated from this PRD may land in the wrong service submodule.
615
- > Resolve P0 findings before running /generate-bdd.
611
+ > ⚠️ ROUTING WARNING: phát hiện vấn đề @trace.domain.
612
+ > BDD/code sinh từ PRD này thể rơi vào sai service submodule.
613
+ > Giải quyết các finding P0 trước khi chạy /generate-bdd.
616
614
  > ```
617
- > Then continue with P1–P5 (do not abort — PO may be reviewing early-stage PRDs).
615
+ > Rồi tiếp tục với P1–P5 (đừng abort — PO thể đang review PRD giai đoạn sớm).
618
616
 
619
617
  ### P1 — Terminology Check (Business Dictionary)
620
618
 
621
- Load `{paths.business_dictionary}`.
622
- Scan the entire PRD for terminology issues:
619
+ Nạp `{paths.business_dictionary}`.
620
+ Quét toàn bộ PRD tìm vấn đề thuật ngữ:
623
621
 
624
- 1. **Banned terms** — every occurrence of a term in §Banned Terms:
625
- → Severity: **critical**. AI can auto-fix in `--resume`.
622
+ 1. **Banned terms** — mọi lần xuất hiện của một term trong §Banned Terms:
623
+ → Severity: **critical**. AI thể auto-fix khi `--resume`.
626
624
 
627
- 2. **Inconsistent usage** — same concept named differently across sections:
628
- → Severity: **major**. Flag both occurrences. Human decides canonical form in Review Board note.
625
+ 2. **Dùng không nhất quán** — cùng một khái niệm được đặt tên khác nhau giữa các section:
626
+ → Severity: **major**. Gắn cờ cả hai chỗ. Người quyết định dạng chuẩn trong note Review Board.
629
627
 
630
- 3. **Unlisted business terms**important terms absent from the dictionary:
631
- → Severity: **minor**. Suggest adding to `business-dictionary.md`.
628
+ 3. **Business term chưa liệt kê** các term quan trọng vắng trong dictionary:
629
+ → Severity: **minor**. Đề xuất thêm vào `business-dictionary.md`.
632
630
 
633
631
  ### P2 — Ambiguity Check
634
632
 
635
- Scan each AC and BR for:
633
+ Quét mỗi AC BR tìm:
636
634
 
637
- | Signal | Example | Severity |
635
+ | Tín hiệu | dụ | Severity |
638
636
  |--------|---------|----------|
639
- | Vague quantifier | "fast", "large", "reasonable", "quickly" | Critical |
640
- | Missing actor | "the system should" with no trigger specified | Major |
641
- | Undefined reference | "{SomeThing}" used but never defined in this PRD | Major |
642
- | Missing negative path | AC only describes happy path but BR has error conditions | Minor |
643
- | Passive voice hiding actor | "Invoice is created" — who creates it? | Minor |
637
+ | Định lượng mơ hồ | "nhanh", "lớn", "hợp lý", "mau" | Critical |
638
+ | Thiếu actor | "hệ thống nên" không nêu trigger | Major |
639
+ | Tham chiếu chưa định nghĩa | "{SomeThing}" được dùng nhưng chưa định nghĩa trong PRD này | Major |
640
+ | Thiếu luồng âm | AC chỉ tả happy path nhưng BR điều kiện lỗi | Minor |
641
+ | Câu bị động giấu actor | "Invoice is created" — ai tạo? | Minor |
644
642
 
645
- → AI cannot auto-fix P2 findings. Human must write the fix in Review Board "Modify" note.
643
+ → AI không thể auto-fix finding P2. Người phải viết bản fix trong note "Modify" của Review Board.
646
644
 
647
645
  ### P3 — Domain Conflict Check
648
646
 
649
- List all other PRDs in `{paths.specs_dir}/{domain}/*/prd.md`.
650
- For each one, check if this PRD contradicts a defined BR (same trigger, different outcome)
651
- or redefines an entity field/status transition differently.
647
+ Liệt tất cả PRD khác trong `{paths.specs_dir}/{domain}/*/*.md` (file `.md` ở gốc mỗi feature folder = PRD).
648
+ Với mỗi PRD, kiểm tra xem PRD này mâu thuẫn với một BR đã định nghĩa không (cùng trigger, khác outcome)
649
+ hoặc định nghĩa lại field/status transition của một entity khác đi.
652
650
 
653
- → Severity: **critical**. Human decides which PRD is correct. Note required.
651
+ → Severity: **critical**. Người quyết định PRD nào đúng. Bắt buộc có note.
654
652
 
655
653
  ### P4 — Structural Completeness
656
654
 
657
- - [ ] Metadata block: Version, Author, Date, Status
658
- - [ ] At least 1 UC with `#### {TICKET-ID}-UC{N}:` heading
659
- - [ ] Each UC has: Description, Actors, Preconditions, Acceptance Criteria, Business Rules
660
- - [ ] `## Changelog` section exists
661
- - [ ] No `{{PLACEHOLDER}}` values unfilled
655
+ - [ ] Block Metadata: Version, Author, Date, Status
656
+ - [ ] Ít nhất 1 UC với heading `#### {TICKET-ID}-UC{N}:`
657
+ - [ ] Mỗi UC có: Description, Actors, Preconditions, Acceptance Criteria, Business Rules
658
+ - [ ] Có section `## Changelog`
659
+ - [ ] Không còn giá trị `{{PLACEHOLDER}}` chưa điền
662
660
 
663
- Missing sections: **major**. AI can add skeleton in `--resume` if accepted.
661
+ Section thiếu: **major**. AI thể thêm skeleton khi `--resume` nếu được chấp nhận.
664
662
 
665
- ### P5 — Custom Criteria (optional)
663
+ ### P5 — Custom Criteria (tuỳ chọn)
666
664
 
667
- If `$ARGUMENTS` contains additional criteria after the file path, evaluate them and create
668
- findings with `check_id: "P5"` and severity as appropriate.
665
+ Nếu `$ARGUMENTS` chứa tiêu chí bổ sung sau path file, đánh giá chúng và tạo
666
+ finding với `check_id: "P5"` severity phù hợp.
669
667
 
670
668
  ---
671
669
 
@@ -673,8 +671,8 @@ findings with `check_id: "P5"` and severity as appropriate.
673
671
 
674
672
  ### B1 — PRD Coverage Check
675
673
 
676
- Load the PRD referenced by `# @trace.prd:` in the feature file header.
677
- Map every AC and every BR (including sub-bullets) to scenarios:
674
+ Nạp PRD được tham chiếu bởi `# @trace.prd:` trong header file feature.
675
+ Map mọi AC mọi BR (gồm cả sub-bullet) sang scenario:
678
676
 
679
677
  ```
680
678
  AC1 ({short text}) → SC1, SC2 ✅
@@ -683,64 +681,64 @@ BR1 ({short text}) → SC1 ✅
683
681
  BR2 ({short text}) → MISSING ❌
684
682
  ```
685
683
 
686
- Each missing AC/BR coverage: **critical** finding.
687
- If accepted in Review Board, `--resume` generates the missing scenario(s).
684
+ Mỗi AC/BR thiếu coverage: finding **critical**.
685
+ Nếu được chấp nhận trong Review Board, `--resume` sinh scenario còn thiếu.
688
686
 
689
687
  ### B2 — Terminology & Entity Check
690
688
 
691
- Using `{paths.business_dictionary}` and `{paths.core_entities}`:
689
+ Dùng `{paths.business_dictionary}` `{paths.core_entities}`:
692
690
 
693
- 1. **Banned terms in steps** → **critical**, auto-fixable in `--resume`
694
- 2. **Non-canonical entity names** → **major**, auto-fixable
695
- 3. **Non-canonical field names in data tables** → **major**, auto-fixable
696
- 4. **Technically-looking sample data** (UUIDs, `item_123`) → **minor**, auto-fixable
691
+ 1. **Banned terms trong steps** → **critical**, auto-fixable khi `--resume`
692
+ 2. **Tên entity không chuẩn** → **major**, auto-fixable
693
+ 3. **Tên field không chuẩn trong data table** → **major**, auto-fixable
694
+ 4. **Sample data trông kỹ thuật** (UUID, `item_123`) → **minor**, auto-fixable
697
695
 
698
696
  ### B3 — Gherkin Rules Check (R1–R10)
699
697
 
700
698
  | Rule | Check | Auto-fixable? |
701
699
  |------|-------|---------------|
702
- | R1 | Every scenario has Given + When + Then | No — needs scenario redesign |
703
- | R2 | No chained `When … Then … When` | No — needs redesign |
704
- | R3 | No UI selectors / API paths / tech terms in steps | Yes — replace with business phrasing |
705
- | R4 | Scenario name is a business outcome | No — needs human rename |
706
- | R5 | Declarative WHAT, not imperative HOW | No — needs rewrite |
707
- | R6 | `Then` asserts observable business outcome | No — needs redesign |
708
- | R7 | Concrete values, not "valid data" | Yes — substitute realistic values |
709
- | R8 | Each scenario is independently runnable | No — needs redesign |
710
- | R9 | Data tables have enough columns for Then | Yes — add missing columns |
711
- | R10 | Cross-UC reference uses navigation phrasing + Note | Yes — add Note comment |
712
-
713
- → R3, R7, R9, R10 violations: auto-fixable. Others require human guidance via Review Board note.
700
+ | R1 | Mỗi scenario Given + When + Then | No — cần thiết kế lại scenario |
701
+ | R2 | Không chained `When … Then … When` | No — cần thiết kế lại |
702
+ | R3 | Không UI selector / API path / tech term trong steps | Yes — thay bằng cách diễn đạt nghiệp vụ |
703
+ | R4 | Tên scenario một business outcome | No — cần người đổi tên |
704
+ | R5 | Khai báo WHAT, không phải mệnh lệnh HOW | No — cần viết lại |
705
+ | R6 | `Then` khẳng định business outcome quan sát được | No — cần thiết kế lại |
706
+ | R7 | Giá trị cụ thể, không phải "valid data" | Yes — thay bằng giá trị thực tế |
707
+ | R8 | Mỗi scenario chạy độc lập được | No — cần thiết kế lại |
708
+ | R9 | Data table đủ cột cho Then | Yes — thêm cột còn thiếu |
709
+ | R10 | Cross-UC reference dùng cách diễn đạt navigation + Note | Yes — thêm comment Note |
710
+
711
+ Vi phạm R3, R7, R9, R10: auto-fixable. Còn lại cần người hướng dẫn qua note Review Board.
714
712
 
715
713
  ### B4 — Compliance Checks (C.1–C.5)
716
714
 
717
- - [ ] C.1 Wireframe Coverage: every screen component/action has ≥1 SC → finding per missing item
718
- - [ ] C.2 PRD Traceability: covered fully by B1 — do NOT create new findings here; deduplicate against B1 findings
719
- - [ ] C.3 Business Dictionary terms usedsame as B2
720
- - [ ] C.4 Banned Terms: 0 banned terms → **critical**, auto-fixable
721
- - [ ] C.5 NHÓM Grouping: if ≥3 SCs, grouped by business theme → **major**, auto-fixable
715
+ - [ ] C.1 Wireframe Coverage: mỗi component/action của màn hình có ≥1 SC → một finding cho mỗi mục thiếu
716
+ - [ ] C.2 PRD Traceability: đã phủ đầy đủ bởi B1 — KHÔNG tạo finding mới đây; dedup với finding B1
717
+ - [ ] C.3 Term Business Dictionary được dùnggiống B2
718
+ - [ ] C.4 Banned Terms: 0 banned term → **critical**, auto-fixable
719
+ - [ ] C.5 NHÓM Grouping: nếu ≥3 SC, gom nhóm theo business theme → **major**, auto-fixable
722
720
 
723
721
  ### B5 — Metadata & Structural Check
724
722
 
725
- - [ ] File header has all required `@trace.*` fieldscheck each explicitly: `@trace.id`, `@trace.title`, `@trace.revision`, `@trace.domain`, `@trace.service`, `@trace.module`, `@trace.status`, `@trace.author`, `@trace.created_at`, `@trace.prd`, `@trace.prd_version`, `@trace.bdd_version`, `@trace.business_rules`, `@trace.dataset` → **minor** per missing field, auto-fixable
726
- - Note: `@trace.revision` is always `1` (static field — see generate-bdd.tmpl). Only check for presence; do NOT flag value as stale.
727
- - [ ] Every scenario has `# @trace.scenario`, `# @trace.sc_version`, `# @trace.business_rules`, `# Side-effects:` → **minor**, auto-fixable
728
- - [ ] Coverage Matrix at end of file → **major**, auto-fixable (AI regenerates)
729
- - [ ] Pre-merge Checklist at end of file → **minor**, auto-fixable
723
+ - [ ] Header file đủ các field `@trace.*` bắt buộc kiểm tra từng cái tường minh: `@trace.id`, `@trace.title`, `@trace.revision`, `@trace.domain`, `@trace.service`, `@trace.module`, `@trace.status`, `@trace.author`, `@trace.created_at`, `@trace.prd`, `@trace.prd_version`, `@trace.bdd_version`, `@trace.business_rules`, `@trace.dataset` → **minor** cho mỗi field thiếu, auto-fixable
724
+ - Lưu ý: `@trace.revision` luôn `1` (field tĩnh xem generate-bdd.tmpl). Chỉ kiểm tra có mặt; KHÔNG gắn cờ giá trị stale.
725
+ - [ ] Mỗi scenario `# @trace.scenario`, `# @trace.sc_version`, `# @trace.business_rules`, `# Side-effects:` → **minor**, auto-fixable
726
+ - [ ] Coverage Matrix cuối file → **major**, auto-fixable (AI sinh lại)
727
+ - [ ] Pre-merge Checklist cuối file → **minor**, auto-fixable
730
728
 
731
729
  ### B6 — Side-effect Completeness
732
730
 
733
- For each `@happy` scenario:
734
- - `# Side-effects:` comment lists all observable side effects
735
- - `Then` block has `And <side-effect>` for each listed side effect
731
+ Với mỗi scenario `@happy`:
732
+ - Comment `# Side-effects:` liệt tất cả side effect quan sát được
733
+ - Block `Then` `And <side-effect>` cho mỗi side effect đã liệt kê
736
734
 
737
- Missing side-effect assertion: **major**, auto-fixable.
735
+ Thiếu assertion side-effect: **major**, auto-fixable.
738
736
 
739
737
  ---
740
738
 
741
- ## Write Findings File
739
+ ## Ghi File Findings
742
740
 
743
- After running all checks, write `{paths.refinement_dir}/{slug}-review-*-findings.yaml`:
741
+ Sau khi chạy hết các check, ghi `{paths.refinement_dir}/{slug}-review-*-findings.yaml`:
744
742
 
745
743
  ```yaml
746
744
  source_file: "{absolute path to reviewed file}"
@@ -750,14 +748,14 @@ status: "pending_review"
750
748
 
751
749
  findings:
752
750
  - id: "F001"
753
- check_id: "P1" # P1-P5 for PRD; B1-B6 for BDD
751
+ check_id: "P1" # P1-P5 cho PRD; B1-B6 cho BDD
754
752
  severity: "critical" # critical | major | minor
755
- section: "{section or scenario ID where issue was found}"
756
- uc_id: "{UC-ID this finding belongs to — PRD: the UC heading; BDD: @trace.id; \"\" if global}"
757
- quote: "{verbatim snippet copied EXACTLY from the reviewed file at the issue location, ≤120 chars}"
758
- finding: "{clear description of the issue}"
759
- suggestion: "{specific actionable fix — AI will apply this in --resume if accepted}"
760
- auto_fixable: true # true = AI can apply; false = human must write note in Review Board
753
+ section: "{section hoặc scenario ID nơi tìm thấy lỗi}"
754
+ uc_id: "{UC-ID finding này thuộc về — PRD: UC heading; BDD: @trace.id; \"\" nếu global}"
755
+ quote: "{trích đoạn nguyên văn copy CHÍNH XÁC từ file đang review tại vị trí lỗi, ≤120 ký tự}"
756
+ finding: "{ tả ràng vấn đề}"
757
+ suggestion: "{bản fix cụ thể, hành động được — AI sẽ áp dụng khi --resume nếu được chấp nhận}"
758
+ auto_fixable: true # true = AI áp dụng được; false = người phải viết note trong Review Board
761
759
  status: "pending" # pending | accepted | modified | rejected | deferred
762
760
 
763
761
  summary:
@@ -768,54 +766,54 @@ summary:
768
766
  recommendation: "APPROVED | NEEDS_REVISION | BLOCKED"
769
767
  ```
770
768
 
771
- > **Locator fields (`quote` + `uc_id`) — required for Review Board source-jump.**
772
- > For every finding, copy a short **verbatim** `quote` straight from the reviewed file at the exact
773
- > spot the issue occursdo NOT paraphrase; it is matched against the document to locate the line.
774
- > Set `uc_id` to the owning Use Case (`@trace.id` for BDD, the UC heading for PRD; `""` if global).
775
- > These let a reviewer click a finding in the Review Board and jump to the precise source location.
769
+ > **Field định vị (`quote` + `uc_id`) — bắt buộc cho source-jump của Review Board.**
770
+ > Với mỗi finding, copy một đoạn `quote` **nguyên văn** thẳng từ file đang review tại đúng
771
+ > chỗ lỗi xảy raKHÔNG diễn giải lại; được so khớp với tài liệu để định vị dòng.
772
+ > Đặt `uc_id` Use Case sở hữu (`@trace.id` cho BDD, UC heading cho PRD; `""` nếu global).
773
+ > Hai field này cho phép reviewer click một finding trong Review Board nhảy tới đúng vị trí nguồn.
776
774
 
777
- ## Post-Analysis Routing
775
+ ## Định tuyến sau phân tích (Post-Analysis Routing)
778
776
 
779
- After running all checks and writing the findings file:
777
+ Sau khi chạy hết các check ghi file findings:
780
778
 
781
- **If `--fix` flag present**jump to Fix Mode (apply `auto_fixable: true` findings immediately).
779
+ **Nếu flag `--fix`**nhảy tới Fix Mode (áp dụng ngay các finding `auto_fixable: true`).
782
780
 
783
- **If no flag** → print Report below and stop.
781
+ **Nếu không flag** → in Report bên dưới và dừng.
784
782
 
785
783
  ## Report
786
784
 
787
- # Report Footer — Standard Command Output Format
785
+ # Report Footer — Định dạng output chuẩn cho mọi lệnh
788
786
 
789
- Every command report must end with this standard footer section.
787
+ Mọi report của lệnh phải kết thúc bằng section footer chuẩn này.
790
788
 
791
789
  ## Status Badge
792
790
 
793
- Choose one based on outcome:
794
- - `✅ Complete` — all steps succeeded, no issues found
795
- - `❌ Failed` — command could not complete due to a blocking error
796
- - `⚠️ Warnings` — completed with non-blocking issues that should be reviewed
791
+ Chọn một theo kết quả:
792
+ - `✅ Complete` — mọi bước thành công, không vấn đề
793
+ - `❌ Failed` — lệnh không hoàn thành được do lỗi chặn
794
+ - `⚠️ Warnings` — hoàn thành nhưng vấn đề không chặn, nên review lại
797
795
 
798
796
  ## Output Artifacts
799
797
 
800
- List every file created or modified by this command:
798
+ Liệt mọi file được tạo hoặc sửa bởi lệnh này:
801
799
  ```
802
800
  Output Artifacts:
803
- {created|updated} {file-path} ({brief description})
804
- {created|updated} {file-path} ({brief description})
801
+ {created|updated} {file-path} ({ tả ngắn})
802
+ {created|updated} {file-path} ({ tả ngắn})
805
803
  ```
806
804
 
807
- If no files were written (e.g., review or analysis commands) → write `Output Artifacts: none (read-only)`.
805
+ Nếu không ghi file nào (vd: lệnh review hoặc phân tích) → ghi `Output Artifacts: none (read-only)`.
808
806
 
809
807
  ## Pipeline Position
810
808
 
811
- Print a one-line map of the pipeline with the CURRENT command's phase marked `◀ bạn ở đây`,
812
- so the user always sees where this command sits in the end-to-end flow:
809
+ In một đồ pipeline một dòng, đánh dấu phase của lệnh HIỆN TẠI bằng `◀ bạn ở đây`,
810
+ để người dùng luôn thấy lệnh này nằm đâu trong luồng end-to-end:
813
811
 
814
812
  ```
815
813
  Discovery → PRD → [Design Spec] → BDD → Tech Design → Code → Dev Self-Check → QC → Trace Audit
816
814
  ```
817
815
 
818
- Find the current command in this phase legend and mark **its** phase in the map above:
816
+ Tìm lệnh hiện tại trong bảng phase dưới đây đánh dấu **phase của nó** trong sơ đồ trên:
819
817
 
820
818
  | Phase | Commands |
821
819
  |-------|----------|
@@ -829,219 +827,219 @@ Find the current command in this phase legend and mark **its** phase in the map
829
827
  | QC | `/qc-analyze` · `/qc-plan` · `/qc-design-test` · `/qc-review` · `/qc-run-test` · `/qc-report` |
830
828
  | Trace Audit | `/validate-traces` |
831
829
 
832
- For a **review command**, also append the 3-step review loop with the current step marked, e.g.:
830
+ Với **lệnh review**, thêm vòng review 3 bước đánh dấu bước hiện tại, vd:
833
831
  `Vòng review: [① phân tích ◀] → ② Review Board → ③ --resume`.
834
832
 
835
- **Cross-cutting commands** (`/sync`, `/update-framework`, `/fix-bug`, `/debug`, `/learn`,
836
- `/report-bug`, `/propose-scenario`, `/generate-spec-manifest`) sit outside the linear pipeline
837
- **omit the Pipeline line entirely** for these (do not force-fit them onto the map).
833
+ **Lệnh xuyên suốt** (`/sync`, `/update-framework`, `/fix-bug`, `/debug`, `/learn`,
834
+ `/report-bug`, `/propose-scenario`, `/generate-spec-manifest`) nằm ngoài pipeline tuyến tính
835
+ **bỏ hẳn dòng Pipeline** cho các lệnh này (đừng cố nhét chúng vào đồ).
838
836
 
839
- ## Next Command Suggestion
837
+ ## Gợi ý lệnh tiếp theo
840
838
 
841
- Suggest the logical next command based on workflow phase:
839
+ Gợi ý lệnh kế tiếp hợp theo phase của workflow:
842
840
 
843
- | Current command | Suggest next |
841
+ | Lệnh hiện tại | Gợi ý lệnh tiếp theo |
844
842
  |-------------------------|-----------------------------------------------|
845
- | /setup-ai-first | `/define-product` to start your first feature |
843
+ | /setup-ai-first | `/define-product` để bắt đầu feature đầu tiên |
846
844
  | /define-product | `/generate-prd {product-definition-file}` |
847
- | /generate-prd | `/refine-prd {prd-file}` then `/review-context {prd-file}` |
848
- | /refine-prd | Open Review Board → update PRD → `/review-context {prd-file}` |
849
- | /review-context (PRD) | FE/App: `/generate-design-spec {prd-file}` (then BDD after sign-off); BE: `/generate-bdd {prd-file}` directly; fix PRD if NEEDS_FIX |
850
- | /generate-design-spec | Designer review → Figma links confirmed → PO + Designer sign-off → `/generate-bdd {prd-file}` |
851
- | /generate-bdd | `/review-context {feature-file}` to verify coverage |
852
- | /review-context (BDD) | `/generate-tech-docs {UC-ID}` if APPROVED; regenerate if NEEDS_FIX |
853
- | /qc-analyze | `/qc-plan {UC-ID}` (resolve 🔴 blocker gaps first) |
845
+ | /generate-prd | `/refine-prd {prd-file}` rồi `/review-context {prd-file}` |
846
+ | /refine-prd | Mở Review Board → cập nhật PRD → `/review-context {prd-file}` |
847
+ | /review-context (PRD) | FE/App: `/generate-design-spec {prd-file}` (rồi BDD sau khi sign-off); BE: `/generate-bdd {prd-file}` trực tiếp; sửa PRD nếu NEEDS_FIX |
848
+ | /generate-design-spec | Designer review → xác nhận link Figma → PO + Designer sign-off → `/generate-bdd {prd-file}` |
849
+ | /generate-bdd | `/review-context {feature-file}` để kiểm tra độ phủ |
850
+ | /review-context (BDD) | `/generate-tech-docs {UC-ID}` nếu APPROVED; sinh lại nếu NEEDS_FIX |
851
+ | /qc-analyze | `/qc-plan {UC-ID}` (xử các gap blocker 🔴 trước) |
854
852
  | /qc-plan | `/qc-design-test {UC-ID}` |
855
- | /qc-design-test | `/qc-review {UC-ID}` (test-case review) |
856
- | /qc-review (test-case) | `/qc-run-test {UC-ID}` if APPROVED; fix TCs if NEEDS_FIX |
857
- | /qc-run-test | `/qc-report {UC-ID}` then `/qc-review {UC-ID}` (script review) |
858
- | /qc-review (script) | `/qc-report {UC-ID}` then create PR if APPROVED |
859
- | /qc-report | `/validate-traces {UC-ID}` to refresh Living Docs (qc_status) |
853
+ | /qc-design-test | `/qc-review {UC-ID}` (review test-case) |
854
+ | /qc-review (test-case) | `/qc-run-test {UC-ID}` nếu APPROVED; sửa TC nếu NEEDS_FIX |
855
+ | /qc-run-test | `/qc-report {UC-ID}` rồi `/qc-review {UC-ID}` (review script) |
856
+ | /qc-review (script) | `/qc-report {UC-ID}` rồi tạo PR nếu APPROVED |
857
+ | /qc-report | `/validate-traces {UC-ID}` để làm mới Living Docs (qc_status) |
860
858
  | /generate-tech-docs | `/review-tech-docs {tech-design-file}` |
861
- | /review-tech-docs | `/generate-code {feature-file}` if APPROVED; fix doc if NEEDS_FIX |
862
- | /generate-code | First gen → `/review-code {UC-ID}`; re-gen → `/dev-gen-test {UC-ID}` |
859
+ | /review-tech-docs | `/generate-code {feature-file}` nếu APPROVED; sửa doc nếu NEEDS_FIX |
860
+ | /generate-code | Lần gen đầu → `/review-code {UC-ID}`; gen lại → `/dev-gen-test {UC-ID}` |
863
861
  | /dev-gen-test | `/dev-run-test {UC-ID}` |
864
862
  | /dev-run-test (passing) | `/review-code {UC-ID}` |
865
- | /dev-run-test (failing) | `/fix-bug {ticket-id}` or `/debug {error}` |
866
- | /review-code | `/dev-smoke-test {UC-ID}` or create PR |
867
- | /dev-smoke-test | Create PR and link to ticket |
868
- | /validate-traces | DRIFT/UNTRACKED → `/generate-code {UC-ID}`; GAP → `/dev-gen-test {UC-ID}`; all OK → create PR |
869
- | /fix-bug | Create PR and link to ticket |
870
- | /debug | `/fix-bug {ticket-id}` if fix needed |
871
- | /report-bug | Send to dev (`/fix-bug {BUG-ID}`); if coverage gap → `/propose-scenario {UC-ID}` |
872
- | /propose-scenario | Notify PO/Dev to review the proposal in `feedback/bdd-proposals/` |
873
- | /learn | Continue working — lesson applies on next command |
874
- | /sync | `/validate-traces` for full coverage; act on any `📥 tester feedback` surfaced |
875
- | /update-framework | Review `git diff .agent/`, commit; `/sync` for project content |
876
-
877
- Format the footer as:
863
+ | /dev-run-test (failing) | `/fix-bug {ticket-id}` hoặc `/debug {error}` |
864
+ | /review-code | `/dev-smoke-test {UC-ID}` hoặc tạo PR |
865
+ | /dev-smoke-test | Tạo PR link tới ticket |
866
+ | /validate-traces | DRIFT/UNTRACKED → `/generate-code {UC-ID}`; GAP → `/dev-gen-test {UC-ID}`; tất cả OK → tạo PR |
867
+ | /fix-bug | Tạo PR link tới ticket |
868
+ | /debug | `/fix-bug {ticket-id}` nếu cần sửa |
869
+ | /report-bug | Gửi cho dev (`/fix-bug {BUG-ID}`); nếu thiếu coverage → `/propose-scenario {UC-ID}` |
870
+ | /propose-scenario | Báo PO/Dev review proposal trong `feedback/bdd-proposals/` |
871
+ | /learn | Tiếp tục làm việc — lesson áp dụng lệnh kế tiếp |
872
+ | /sync | `/validate-traces` để xem độ phủ đầy đủ; xử lý mọi `📥 tester feedback` được nêu |
873
+ | /update-framework | Review `git diff .agent/`, commit; `/sync` để đồng bộ nội dung dự án |
874
+
875
+ Định dạng footer như sau:
878
876
  ```
879
877
  ---
880
878
  Status : {badge}
881
- {Output Artifacts block}
879
+ {khối Output Artifacts}
882
880
  Pipeline : Discovery → PRD → [BDD ◀ bạn ở đây] → Tech Design → Code → Dev Self-Check → QC → Trace Audit
883
- (review cmd) Vòng review: [① phân tích ◀] → ② Review Board → ③ --resume
884
- Next : {suggested command with example arguments}
881
+ (lệnh review) Vòng review: [① phân tích ◀] → ② Review Board → ③ --resume
882
+ Next : {lệnh gợi ý kèm ví dụ tham số}
885
883
  ```
886
- *(Omit the `Pipeline` line for cross-cutting commands listed above.)*
884
+ *(Bỏ dòng `Pipeline` cho các lệnh xuyên suốt liệt kê ở trên.)*
887
885
 
888
886
 
889
887
  ```
890
- /review-context Complete — {target file}
888
+ /review-context Hoàn tất — {target file}
891
889
  Mode: {PRD | BDD}
892
890
  Findings: {total} | 🔴 Critical: {N} | 🟡 Major: {N} | 🟢 Minor: {N}
893
891
  Auto-fixable: {N} | Needs human decision: {N}
894
892
 
895
- Findings file:
893
+ File findings:
896
894
  {If PRD}: {paths.refinement_dir}/{prd-slug}-review-context-findings.yaml
897
895
  {If BDD}: {paths.refinement_dir}/{uc-id}-review-bdd-findings.yaml
898
896
 
899
- Next options:
897
+ Lựa chọn tiếp theo:
900
898
  A) Quick fix : /review-context --fix {target-file}
901
- applies all auto-fixable findings immediately
902
- B) Review Board: open findings file → accept/modify/reject
899
+ áp dụng ngay mọi finding auto-fixable
900
+ B) Review Board: mở file findings → accept/modify/reject
903
901
  → /review-context --resume {target-file}
904
902
  ```
905
903
 
906
904
  ---
907
905
 
908
- ## Fix Mode — Apply Auto-Fixable Findings Immediately
906
+ ## Fix Mode — Áp dụng ngay các Finding Auto-Fixable
909
907
 
910
- *Triggered when `$ARGUMENTS` contains `--fix`.*
911
- *Example: `/review-context --fix specs/payment/process-payment/bdd/PAY-001.feature`*
908
+ *Kích hoạt khi `$ARGUMENTS` chứa `--fix`.*
909
+ * dụ: `/review-context --fix specs/payment/process-payment/bdd/PAY-001.feature`*
912
910
 
913
- This mode runs the full analysis (same as default), then immediately applies every
914
- `auto_fixable: true` finding without going through the Review Board.
911
+ Mode này chạy toàn bộ phân tích (giống mặc định), rồi áp dụng ngay mọi finding
912
+ `auto_fixable: true` không qua Review Board.
915
913
 
916
- Use for: BDD cleanup, terminology fixes, metadata gaps anything the AI can safely
917
- correct without a human judgment call. Findings requiring human decisions are written
918
- to the findings file as usual and left `status: pending`.
914
+ Dùng cho: dọn BDD, fix thuật ngữ, gap metadata — bất cứ thứ gì AI thể sửa an toàn
915
+ không cần phán đoán của con người. Finding cần quyết định của con người vẫn được ghi
916
+ vào file findings như thường để `status: pending`.
919
917
 
920
- ### Phase 1 — Run analysis
918
+ ### Phase 1 — Chạy phân tích
921
919
 
922
- Run all checks via the **Review Procedure** (fan-out + completeness loop) exactly as in the default mode.
923
- Write the findings file with all `status: "pending"` as usual.
920
+ Chạy hết các check qua **Quy trình Review** (fan-out + completeness loop) đúng như mode mặc định.
921
+ Ghi file findings với tất cả `status: "pending"` như thường.
924
922
 
925
- ### Phase 2 — Apply auto-fixable findings
923
+ ### Phase 2 — Áp dụng các finding auto-fixable
926
924
 
927
- For each finding where `auto_fixable: true`, in order (critical → major → minor):
925
+ Với mỗi finding `auto_fixable: true`, theo thứ tự (critical → major → minor):
928
926
 
929
- **For PRD files:**
927
+ **Với file PRD:**
930
928
 
931
- | check_id | What to apply |
929
+ | check_id | Áp dụng |
932
930
  |----------|--------------|
933
- | P0.3 (Missing status) | Add `@trace.status: draft` to frontmatter |
934
- | P1 (Banned term) | Replace every banned term occurrence with canonical term |
935
- | P4 (Structure) | Add missing section/metadata skeleton |
931
+ | P0.3 (Thiếu status) | Thêm `@trace.status: draft` vào frontmatter |
932
+ | P1 (Banned term) | Thay mọi lần xuất hiện banned term bằng canonical term |
933
+ | P4 (Structure) | Thêm skeleton section/metadata còn thiếu |
936
934
 
937
- **For BDD files:**
935
+ **Với file BDD:**
938
936
 
939
- | check_id | What to apply |
937
+ | check_id | Áp dụng |
940
938
  |----------|--------------|
941
- | B2 (Terminology) | Replace banned terms, fix entity/field names, fix technical sample data |
942
- | B3 R3 | Replace tech terms/UI selectors with business phrasing |
943
- | B3 R7 | Substitute concrete realistic values |
944
- | B3 R9 | Add missing data table columns |
945
- | B3 R10 | Add cross-UC navigation Note comment |
946
- | B4 C4 | Fix banned terms in tags |
947
- | B4 C5 | Add NHÓM grouping if ≥3 SCs |
948
- | B5 | Add missing @trace headers, regenerate Coverage Matrix / Pre-merge Checklist |
949
- | B6 | Add missing `And <side-effect>` to Then blocks |
950
-
951
- After applying each finding, mark it `status: "applied_automatically"` in the findings file.
939
+ | B2 (Terminology) | Thay banned term, fix tên entity/field, fix sample data kỹ thuật |
940
+ | B3 R3 | Thay tech term/UI selector bằng cách diễn đạt nghiệp vụ |
941
+ | B3 R7 | Thay bằng giá trị thực tế cụ thể |
942
+ | B3 R9 | Thêm cột data table còn thiếu |
943
+ | B3 R10 | Thêm comment Note navigation cross-UC |
944
+ | B4 C4 | Fix banned term trong tag |
945
+ | B4 C5 | Thêm NHÓM grouping nếu ≥3 SC |
946
+ | B5 | Thêm @trace header còn thiếu, sinh lại Coverage Matrix / Pre-merge Checklist |
947
+ | B6 | Thêm `And <side-effect>` còn thiếu vào block Then |
948
+
949
+ Sau khi áp dụng mỗi finding, đánh dấu `status: "applied_automatically"` trong file findings.
952
950
 
953
951
  ### Phase 3 — Version bump
954
952
 
955
- - **PRD**: if ≥1 finding applied → bump **minor** version (auto-fix only applies P1 banned-term replacements and P4 skeleton additionsnever alters UC structure or BR content, so minor bump is always correct), add Changelog entry:
953
+ - **PRD**: nếu ≥1 finding được áp dụng → bump version **minor** (auto-fix chỉ áp dụng thay banned-term P1 thêm skeleton P4không bao giờ thay đổi cấu trúc UC hay nội dung BR, nên minor bump luôn đúng), thêm entry Changelog:
956
954
  `Auto-fix: applied {N} auto-fixable review-context findings`
957
- - **BDD**: if ≥1 finding appliedincrement `@trace.bdd_version` by 0.1
955
+ - **BDD**: nếu ≥1 finding được áp dụng tăng `@trace.bdd_version` lên 0.1
958
956
 
959
957
  ### Phase 4 — Report
960
958
 
961
959
  ```
962
- /review-context --fix Applied — {target file}
960
+ /review-context --fix Đã áp dụng — {target file}
963
961
  Mode: {PRD | BDD}
964
962
 
965
963
  Auto-fixed : {N} findings ({critical} critical, {major} major, {minor} minor)
966
- - {change 1 summary}
967
- - {change 2 summary}
964
+ - {tóm tắt change 1}
965
+ - {tóm tắt change 2}
968
966
 
969
- Still pending (needs human decision): {N}
970
- - F00X [{severity}] {finding summary} ← open findings file in Review Board
967
+ Còn pending (cần quyết định của con người): {N}
968
+ - F00X [{severity}] {tóm tắt finding} ← mở file findings trong Review Board
971
969
 
972
970
  {If PRD}: Version bumped: {old} → {new}
973
971
  {If BDD}: bdd_version: {old} → {new}
974
972
 
975
- Findings file:
973
+ File findings:
976
974
  {If PRD}: {paths.refinement_dir}/{prd-slug}-review-context-findings.yaml
977
975
  {If BDD}: {paths.refinement_dir}/{uc-id}-review-bdd-findings.yaml
978
- Re-run /review-context {file} to confirm 0 remaining critical findings.
976
+ Chạy lại /review-context {file} để xác nhận 0 finding critical còn lại.
979
977
  ```
980
978
 
981
- If 0 findings were auto-fixable → print:
979
+ Nếu 0 finding nào auto-fixable → in:
982
980
  ```
983
- Nothing to auto-fix. All {N} findings require human decision.
984
- Open findings file in Review Board → then run: /review-context --resume {file}
981
+ Không gì để auto-fix. Cả {N} finding đều cần quyết định của con người.
982
+ Mở file findings trong Review Board → rồi chạy: /review-context --resume {file}
985
983
  ```
986
984
 
987
985
  ---
988
986
 
989
- ## Resume Mode — Apply Accepted Findings
987
+ ## Resume Mode — Áp dụng các Finding được chấp nhận
990
988
 
991
- *Triggered when `$ARGUMENTS` contains `--resume`.*
992
- *Example: `/review-context --resume specs/payment/process-payment/prd.md`*
989
+ *Kích hoạt khi `$ARGUMENTS` chứa `--resume`.*
990
+ * dụ: `/review-context --resume specs/payment/process-payment/PAY01-process-payment.md`*
993
991
 
994
- ### Phase 1 — Read accepted findings
992
+ ### Phase 1 — Đọc các finding được chấp nhận
995
993
 
996
- 1. Derive findings filename from target file using the same rule as Detect Review Mode:
994
+ 1. Suy ra tên file findings từ target file dùng cùng quy tắc như Detect Review Mode:
997
995
  - PRD: `{paths.refinement_dir}/{prd-slug}-review-context-findings.yaml`
998
996
  - BDD: `{paths.refinement_dir}/{uc-id}-review-bdd-findings.yaml`
999
- 2. Read the findings file.
1000
- 3. Collect findings where `status: "accepted"` or `status: "modified"`.
1001
- 4. If nonereport "No accepted findings. File unchanged." and stop.
997
+ 2. Đọc file findings.
998
+ 3. Gom các finding `status: "accepted"` hoặc `status: "modified"`.
999
+ 4. Nếu không báo "No accepted findings. File unchanged." dừng.
1002
1000
 
1003
- ### Phase 2 — Apply fixes
1001
+ ### Phase 2 — Áp dụng fix
1004
1002
 
1005
- Apply in order: critical → major → minor.
1003
+ Áp dụng theo thứ tự: critical → major → minor.
1006
1004
 
1007
- **For PRD findings:**
1008
- | check_id | What to do |
1005
+ **Với finding PRD:**
1006
+ | check_id | Làm |
1009
1007
  |----------|-----------|
1010
- | P0.3 (Missing status) | Add `@trace.status: draft` to frontmatter |
1011
- | P1 (Banned term) | Replace every occurrence of banned term with canonical term |
1012
- | P2 (Ambiguity) | Apply the fix stated in `suggestion` or `modified` note |
1013
- | P3 (Conflict) | Apply the resolution stated in the modified note |
1014
- | P4 (Structure) | Add the missing section/metadata field |
1015
- | P5 (Custom) | Apply as stated in suggestion/note |
1008
+ | P0.3 (Thiếu status) | Thêm `@trace.status: draft` vào frontmatter |
1009
+ | P1 (Banned term) | Thay mọi lần xuất hiện banned term bằng canonical term |
1010
+ | P2 (Ambiguity) | Áp dụng fix nêu trong `suggestion` hoặc note `modified` |
1011
+ | P3 (Conflict) | Áp dụng cách giải quyết nêu trong note modified |
1012
+ | P4 (Structure) | Thêm section/metadata field còn thiếu |
1013
+ | P5 (Custom) | Áp dụng như nêu trong suggestion/note |
1016
1014
 
1017
- After applying, bump PRD version (minor) and add Changelog entry.
1015
+ Sau khi áp dụng, bump version PRD (minor) thêm entry Changelog.
1018
1016
 
1019
- **For BDD findings:**
1020
- | check_id | What to do |
1017
+ **Với finding BDD:**
1018
+ | check_id | Làm |
1021
1019
  |----------|-----------|
1022
- | B1 (Coverage gap) | Generate new scenario(s) for the uncovered AC/BR and insert into correct NHÓM |
1023
- | B2 (Terminology) | Replace banned terms, fix entity/field names |
1024
- | B3 (Gherkin rule) | Apply rule-specific fix (replace tech terms, add concrete values, etc.) |
1025
- | B4 (Compliance) | Add NHÓM grouping, fix @trace tags |
1026
- | B5 (Metadata) | Add missing @trace headers, regenerate Coverage Matrix / Pre-merge Checklist |
1027
- | B6 (Side effects) | Add missing `And <side-effect>` to Then block |
1020
+ | B1 (Coverage gap) | Sinh scenario mới cho AC/BR chưa phủ chèn vào đúng NHÓM |
1021
+ | B2 (Terminology) | Thay banned term, fix tên entity/field |
1022
+ | B3 (Gherkin rule) | Áp dụng fix theo từng rule (thay tech term, thêm giá trị cụ thể, v.v.) |
1023
+ | B4 (Compliance) | Thêm NHÓM grouping, fix tag @trace |
1024
+ | B5 (Metadata) | Thêm @trace header còn thiếu, sinh lại Coverage Matrix / Pre-merge Checklist |
1025
+ | B6 (Side effects) | Thêm `And <side-effect>` còn thiếu vào block Then |
1028
1026
 
1029
- After applying, increment `@trace.bdd_version` in file header by 0.1.
1030
- Also update `{paths.trace_dir}/{domain}/{prd-slug}/{UC-ID}.tsv`: set `bdd_version` column to the new `@trace.bdd_version` value for all rows, and set `last_updated` to today's date.
1027
+ Sau khi áp dụng, tăng `@trace.bdd_version` trong header file lên 0.1.
1028
+ Đồng thời cập nhật `{paths.trace_dir}/{domain}/{prd-slug}/{UC-ID}.tsv`: đặt cột `bdd_version` thành giá trị `@trace.bdd_version` mới cho mọi row, đặt `last_updated` thành ngày hôm nay.
1031
1029
 
1032
1030
  ### Phase 3 — Report
1033
1031
 
1034
1032
  ```
1035
- /review-context --resume Applied — {target file}
1033
+ /review-context --resume Đã áp dụng — {target file}
1036
1034
  Applied : {N} findings ({critical} critical, {major} major, {minor} minor)
1037
1035
  Skipped : {N} rejected/deferred
1038
1036
 
1039
1037
  Changes:
1040
- - {change 1 summary}
1041
- - {change 2 summary}
1038
+ - {tóm tắt change 1}
1039
+ - {tóm tắt change 2}
1042
1040
 
1043
1041
  {If PRD}: Version bumped: {old} → {new}
1044
1042
  {If BDD}: bdd_version: {old} → {new}
1045
1043
 
1046
- Re-run /review-context {file} to confirm 0 remaining critical findings.
1044
+ Chạy lại /review-context {file} để xác nhận 0 finding critical còn lại.
1047
1045
  ```