@edupia-tutor/spec-driven-docs 0.14.6 → 0.14.8

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 (130) hide show
  1. package/bin/index.js +1 -1
  2. package/commands/debug.md +1 -1
  3. package/commands/define-product.md +1 -1
  4. package/commands/dev-gen-test.md +1 -1
  5. package/commands/dev-run-test.md +1 -1
  6. package/commands/dev-smoke-test.md +1 -1
  7. package/commands/fix-bug.md +1 -1
  8. package/commands/generate-bdd.md +74 -5
  9. package/commands/generate-bdd.tmpl +73 -4
  10. package/commands/generate-code.md +19 -2
  11. package/commands/generate-code.tmpl +18 -1
  12. package/commands/generate-design-spec.md +50 -6
  13. package/commands/generate-design-spec.tmpl +49 -5
  14. package/commands/generate-prd.md +9 -5
  15. package/commands/generate-prd.tmpl +1 -0
  16. package/commands/generate-spec-manifest.md +1 -1
  17. package/commands/generate-tech-docs.md +2 -1
  18. package/commands/generate-tech-docs.tmpl +1 -0
  19. package/commands/learn.md +1 -1
  20. package/commands/map-testids.md +1 -1
  21. package/commands/propose-scenario.md +7 -3
  22. package/commands/propose-scenario.tmpl +6 -2
  23. package/commands/qc-analyze.md +15 -1
  24. package/commands/qc-analyze.tmpl +14 -0
  25. package/commands/qc-design-test.md +1 -1
  26. package/commands/qc-plan.md +1 -1
  27. package/commands/qc-report.md +1 -1
  28. package/commands/qc-review.md +1 -1
  29. package/commands/qc-run-test.md +1 -1
  30. package/commands/refine-prd.md +33 -13
  31. package/commands/refine-prd.tmpl +32 -12
  32. package/commands/report-bug.md +1 -1
  33. package/commands/review-code.md +1 -1
  34. package/commands/review-context.md +49 -27
  35. package/commands/review-context.tmpl +48 -26
  36. package/commands/review-tech-docs.md +1 -1
  37. package/commands/setup-ai-first.md +10 -10
  38. package/commands/setup-ai-first.tmpl +9 -9
  39. package/commands/sync.md +1 -1
  40. package/commands/update-framework.md +1 -1
  41. package/commands/validate-traces.md +2 -1
  42. package/commands/validate-traces.tmpl +1 -0
  43. package/core/FRAMEWORK_VERSION +1 -1
  44. package/core/commands/debug.md +1 -1
  45. package/core/commands/define-product.md +1 -1
  46. package/core/commands/dev-gen-test.md +1 -1
  47. package/core/commands/dev-run-test.md +1 -1
  48. package/core/commands/dev-smoke-test.md +1 -1
  49. package/core/commands/fix-bug.md +1 -1
  50. package/core/commands/generate-bdd.md +74 -5
  51. package/core/commands/generate-code.md +19 -2
  52. package/core/commands/generate-design-spec.md +50 -6
  53. package/core/commands/generate-prd.md +9 -5
  54. package/core/commands/generate-spec-manifest.md +1 -1
  55. package/core/commands/generate-tech-docs.md +2 -1
  56. package/core/commands/learn.md +1 -1
  57. package/core/commands/map-testids.md +1 -1
  58. package/core/commands/propose-scenario.md +7 -3
  59. package/core/commands/qc-analyze.md +15 -1
  60. package/core/commands/qc-design-test.md +1 -1
  61. package/core/commands/qc-plan.md +1 -1
  62. package/core/commands/qc-report.md +1 -1
  63. package/core/commands/qc-review.md +1 -1
  64. package/core/commands/qc-run-test.md +1 -1
  65. package/core/commands/refine-prd.md +33 -13
  66. package/core/commands/report-bug.md +1 -1
  67. package/core/commands/review-code.md +1 -1
  68. package/core/commands/review-context.md +49 -27
  69. package/core/commands/review-tech-docs.md +1 -1
  70. package/core/commands/setup-ai-first.md +10 -10
  71. package/core/commands/sync.md +1 -1
  72. package/core/commands/update-framework.md +1 -1
  73. package/core/commands/validate-traces.md +2 -1
  74. package/core/skills/code/SKILL.md +7 -759
  75. package/core/skills/debug/SKILL.md +9 -859
  76. package/core/skills/design-spec/SKILL.md +3 -582
  77. package/core/skills/prd/SKILL.md +5 -464
  78. package/core/skills/setup-ai-first/SKILL.md +3 -208
  79. package/core/skills/spec/SKILL.md +7 -450
  80. package/core/skills/test/SKILL.md +10 -1290
  81. package/core/steps/report-footer.md +1 -1
  82. package/core/steps/spawn-agent.md +12 -7
  83. package/core/templates/prd.template.md +7 -4
  84. package/core/templates/project-context.yaml +2 -2
  85. package/docs/01-getting-started/core-concepts.md +3 -3
  86. package/docs/01-getting-started/quickstart.md +4 -3
  87. package/docs/02-guides/bdd-input-checklist.md +68 -0
  88. package/docs/02-guides/developer/README.md +3 -0
  89. package/docs/02-guides/developer/bdd-and-trace.md +4 -3
  90. package/docs/02-guides/developer/commands.md +3 -3
  91. package/docs/02-guides/developer/pr-checklist.md +1 -0
  92. package/docs/02-guides/developer/scenarios.md +2 -2
  93. package/docs/02-guides/developer/workflow.md +3 -3
  94. package/docs/02-guides/prd-input-checklist.md +94 -0
  95. package/docs/02-guides/product-owner/README.md +5 -3
  96. package/docs/02-guides/product-owner/commands.md +1 -1
  97. package/docs/02-guides/product-owner/handoff-checklist.md +5 -5
  98. package/docs/02-guides/product-owner/scenarios.md +19 -17
  99. package/docs/02-guides/tech-docs-input-checklist.md +82 -0
  100. package/docs/02-guides/tester/README.md +1 -1
  101. package/docs/02-guides/tester/bug-reporting.md +1 -1
  102. package/docs/02-guides/tester/qc-automation.md +1 -1
  103. package/docs/03-concepts/README.md +1 -0
  104. package/docs/03-concepts/mechanisms-explained.md +34 -0
  105. package/docs/03-concepts/pipeline.md +12 -9
  106. package/docs/03-concepts/traceability.md +7 -4
  107. package/docs/04-operations/bug-flow.md +2 -0
  108. package/docs/04-operations/sync-and-update.md +3 -3
  109. package/docs/05-reference/command-cheatsheet.md +9 -9
  110. package/docs/05-reference/commands.md +12 -10
  111. package/docs/05-reference/trace-schema.md +2 -1
  112. package/package.json +1 -1
  113. package/skills/code/SKILL.md +7 -759
  114. package/skills/code/SKILL.tmpl +7 -164
  115. package/skills/debug/SKILL.md +9 -859
  116. package/skills/debug/SKILL.tmpl +9 -252
  117. package/skills/design-spec/SKILL.md +3 -582
  118. package/skills/design-spec/SKILL.tmpl +3 -87
  119. package/skills/prd/SKILL.md +5 -464
  120. package/skills/prd/SKILL.tmpl +5 -63
  121. package/skills/setup-ai-first/SKILL.md +3 -208
  122. package/skills/setup-ai-first/SKILL.tmpl +3 -108
  123. package/skills/spec/SKILL.md +7 -450
  124. package/skills/spec/SKILL.tmpl +7 -162
  125. package/skills/test/SKILL.md +10 -1290
  126. package/skills/test/SKILL.tmpl +10 -288
  127. package/steps/report-footer.md +1 -1
  128. package/steps/spawn-agent.md +12 -7
  129. package/templates/prd.template.md +7 -4
  130. package/templates/project-context.yaml +2 -2
@@ -2,1297 +2,17 @@
2
2
  description: Sinh unit và integration test từ BDD spec, chạy test suite và report kết quả, hoặc dev-smoke-test các API endpoint live trên service đang chạy. Trigger when: "/dev-gen-test", "/dev-run-test", "/dev-smoke-test", "tạo test", "viết test", "chạy test", "generate tests", "run tests", "test kết quả", "smoke test", "test API", "kiểm tra endpoint đang chạy".
3
3
  ---
4
4
 
5
- # Test Skills — Generate, Run & Smoke Test
5
+ # Test Skills — Generate, Run & Smoke (Dev Self-Check)
6
6
 
7
- Skill này xử lý ba lệnh: `/dev-gen-test`, `/dev-run-test`, `/dev-smoke-test`.
7
+ Skill này xử lý `/dev-gen-test`, `/dev-run-test`, `/dev-smoke-test` — **dev self-check** (`dev_selftest`), KHÔNG phải QC chính thức (`/qc-*`). Để **không lệch**, skill KHÔNG nhân bản — mỗi lệnh thực thi **y hệt** command.
8
8
 
9
- ---
10
-
11
- ## /dev-gen-test — Generate Unit & Integration Tests
12
-
13
- ### Gate
14
-
15
- <!-- Directory: specs/*/*/bdd/*.feature — or pass UC-ID/class path as argument -->
16
- # Gate — Quy trình vào chuẩn cho mọi lệnh
17
-
18
- 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ó.
19
-
20
- ## Bước 0 — Kiểm tra chế độ Sub-Agent
21
-
22
- Trước tiên, kiểm tra xem `$ARGUMENTS` có phải là payload JSON từ một orchestrator hay không:
23
-
24
- 1. Thử parse `$ARGUMENTS` dưới dạng JSON.
25
- 2. Nếu parse thành công **và** chứa `"_agent_mode": true`:
26
- - **Bỏ qua hoàn toàn Bước 1, 2 và 3 của Gate này.**
27
- - Đặt target file = `payload.target_file`
28
- - Đặt loaded context = `payload.context` (KHÔNG chạy context-loader.md)
29
- - Đặt phạm vi UC = `payload.uc_id` (chỉ xử lý UC này)
30
- - Đặt line range = `payload.uc_section` (chỉ đọc đúng section đó của PRD)
31
- - Đặt dimension = `payload.dimension` nếu có (lệnh review per-UC: chỉ review đúng lăng kính này)
32
- - Đi thẳng tới phần logic riêng của lệnh.
33
- 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).
34
-
35
- ## Bước 0-B — Kiểm tra Model
36
-
37
- *Bỏ qua bước này nếu `_agent_mode: true` (sub-agent — orchestrator đã kiểm tra rồi).*
38
-
39
- 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.
40
- 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.
41
-
42
- Hiển thị và chờ phản hồi:
43
-
44
- ```
45
- ⚙️ MODEL CHECK
46
- ──────────────────────────────────────────────────────────────────
47
- Recommended : claude-opus-4 (hoặc model Opus mới nhất)
48
- Why needed : Phân tích spec, review kiến trúc, sinh code đòi hỏi
49
- suy luận sâu. Model nhỏ hơn dễ bỏ sót edge case.
50
-
51
- Cách đổi trong Claude Code:
52
- • Settings → Model → chọn "claude-opus"
53
- • hoặc: /model → chọn claude-opus
54
-
55
- Đang chạy claude-opus?
56
- Y — đúng, đang dùng claude-opus → tiếp tục
57
- 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)
58
- ──────────────────────────────────────────────────────────────────
59
- ```
60
-
61
- - "Y" → tiếp tục sang Bước 1.
62
- - "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).
63
- - "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."
64
-
65
- ## Bước 1 — Xác định Target File
66
-
67
- 1. Nếu `$ARGUMENTS` được cung cấp và trỏ tới một file tồn tại → dùng trực tiếp làm target.
68
- 2. Nếu `$ARGUMENTS` là một **UC-ID / ticket ID / tên rút gọn** (không có 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 đó, và `**` đệ quy dưới `bdd/` để phủ hết các thư mục con theo platform (`bdd/web/`, `bdd/app/`, `bdd/system/`):
69
- - **Lệnh BDD** (target là `.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 đó.
70
- - **Lệnh PRD** (target là 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 có 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.)*
71
- - **Lệnh tech-docs**: `{specs_dir}/{domain}/*/tech-docs/{UC-ID}*-tech-design*.md`.
72
- - **Lệnh design-spec**: `{specs_dir}/{domain}/*/design-spec/{TICKET-ID}*.md`.
73
-
74
- Khi một file khớp: đặt nó 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 mà 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.
75
- 3. Nếu `$ARGUMENTS` rỗng hoặc không tìm thấy file khớp:
76
- - Liệt kê 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).
77
- - 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)"
78
- - Chờ người dùng chọn rồi mới tiếp tục.
79
-
80
- ## Bước 2 — Chạy Context Loader
81
-
82
- 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`.
83
- 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.
84
-
85
- ## Bước 3 — CHECKPOINT
86
-
87
- Sau khi hoàn thành Bước 1 và 2, hiển thị bản tóm tắt và chờ xác nhận:
88
-
89
- ```
90
- CHECKPOINT
91
- -----------
92
- Target : {resolved file path}
93
- Project : {project.name từ project-context.yaml}
94
- Tech stack : {language} / {framework}
95
- Module : {module nếu có, else "not configured"}
96
- Domains : {danh sách domain, ngăn cách bởi dấu phẩy}
97
-
98
- Tiếp tục? (Y/N)
99
- ```
100
-
101
- Chờ người dùng trả lời rõ ràng "Y" hoặc "N" rồi mới tiếp tục.
102
- - "Y" → tiếp tục sang các bước riêng của lệnh bên dưới.
103
- - "N" → dừng lại và hỏi người dùng muốn thay đổi gì.
104
-
105
-
106
- Cũng đọc:
107
- - File `.feature` để hiểu các behavior kỳ vọng
108
- - Tìm file cần test: Controller có `@trace.implements={UC-ID}`, Service implementation, Facade implementation (nếu áp dụng)
109
-
110
- ### CHECKPOINT — Test Plan
111
-
112
- Trước khi sinh, trình bày plan:
113
-
114
- ```
115
- Test Plan — {UC-ID}:
116
-
117
- Unit Tests ({unit test framework}):
118
- - {ServiceName}ServiceImplTest
119
- • {method}: {scenario} → {expected result}
120
- - {FacadeName}FacadeImplTest (if applicable)
121
- • {method}: {scenario} → {expected result}
122
-
123
- Integration Tests:
124
- - {ControllerName}ControllerTest
125
- • {endpoint}: {scenario} → HTTP {status}
126
-
127
- Total: {N} test classes, ~{M} test cases
128
- Proceed? (Y/N)
129
- ```
130
-
131
- Chờ xác nhận.
132
-
133
- ### Generate
134
-
135
- #### Unit Test Template
136
-
137
- ```
138
- // @trace.verifies={UC-ID}
139
- // @trace.test_type=unit
140
- [Test class using your project's test framework]
141
-
142
- class {Resource}ServiceImplTest {
143
-
144
- // Mock dependencies
145
-
146
- @Test
147
- // "Should {expected outcome} when {condition}"
148
- void methodName_whenValid_shouldReturnExpected() {
149
- // Given — set up mocks and inputs
150
- // When — call the method under test
151
- // Then — assert results and verify interactions
152
- }
153
-
154
- @Test
155
- // "Should throw {Exception} when {resource} not found"
156
- void methodName_whenNotFound_shouldThrowException() {
157
- // Given — mock returns empty/null
158
- // When & Then — assert exception is thrown
159
- }
160
- }
161
- ```
162
-
163
- #### Integration Test Template (Controller/HTTP layer)
164
-
165
- ```
166
- // @trace.verifies={UC-ID}
167
- // @trace.test_type=integration
168
- [Integration test class for HTTP layer]
169
-
170
- class {Resource}ControllerTest {
171
-
172
- // Inject MockMvc or HTTP test client
173
- // MockBean/stub the Facade/Service
174
-
175
- @Test
176
- // "GET /v1/{resource} - should return 200 with data"
177
- void filter_shouldReturn200() {
178
- // Given — stub facade/service
179
- // When — perform HTTP GET
180
- // Then — assert status 200 and response body
181
- }
182
-
183
- @Test
184
- // "POST /v1/{resource} - should return 201 when valid"
185
- void create_shouldReturn201() {
186
- // Given — stub facade/service
187
- // When — perform HTTP POST with valid body
188
- // Then — assert status 201
189
- }
190
-
191
- @Test
192
- // "POST /v1/{resource} - should return 400 when invalid"
193
- void create_shouldReturn400WhenInvalid() {
194
- // Given — no stub needed
195
- // When — perform HTTP POST with missing required fields
196
- // Then — assert status 400
197
- }
198
- }
199
- ```
200
-
201
- ### File Placement
202
-
203
- Theo cấu trúc test của dự án từ CLAUDE.md. Điển hình:
204
- ```
205
- src/test/{language}/{package}/
206
- ├── service/impl/{Resource}ServiceImplTest.{ext}
207
- ├── facade/impl/{Resource}FacadeImplTest.{ext} (if applicable)
208
- └── controller/{Resource}ControllerTest.{ext}
209
- ```
210
-
211
- ### Self-Review Checklist
212
-
213
- - [ ] Tag `@trace.verifies` trên mỗi test class
214
- - [ ] Mỗi scenario trong .feature có ít nhất một test
215
- - [ ] Chỉ mock đúng layer (không mock repo trong controller test)
216
- - [ ] Test name theo pattern `methodName_whenCondition_shouldOutcome`
217
- - [ ] Không có debug print trong test
218
-
219
- ### Output
220
-
221
- ```
222
- /dev-gen-test Complete — {UC-ID}:
223
- ✅ service/{Service}Test.{ext} ({M} tests)
224
- ✅ facade/{Facade}Test.{ext} ({M} tests)
225
- ✅ controller/{Controller}Test.{ext} ({M} tests)
226
- ```
227
-
228
- # Report Footer — Định dạng output chuẩn cho mọi lệnh
229
-
230
- Mọi report của lệnh phải kết thúc bằng section footer chuẩn này.
231
-
232
- ## Status Badge
233
-
234
- Chọn một theo kết quả:
235
- - `✅ Complete` — mọi bước thành công, không có vấn đề
236
- - `❌ Failed` — lệnh không hoàn thành được do lỗi chặn
237
- - `⚠️ Warnings` — hoàn thành nhưng có vấn đề không chặn, nên review lại
238
-
239
- ## Output Artifacts
240
-
241
- Liệt kê mọi file được tạo hoặc sửa bởi lệnh này:
242
- ```
243
- Output Artifacts:
244
- {created|updated} {file-path} ({mô tả ngắn})
245
- {created|updated} {file-path} ({mô tả ngắn})
246
- ```
247
-
248
- Nếu không ghi file nào (vd: lệnh review hoặc phân tích) → ghi `Output Artifacts: none (read-only)`.
249
-
250
- ## Pipeline Position
251
-
252
- In một sơ đồ pipeline một dòng, đánh dấu phase của lệnh HIỆN TẠI bằng `◀ bạn ở đây`,
253
- để người dùng luôn thấy lệnh này nằm ở đâu trong luồng end-to-end:
254
-
255
- ```
256
- Discovery → PRD → [Design Spec] → BDD → Tech Design → Code → Dev Self-Check → QC → Trace Audit
257
- ```
258
-
259
- Tìm lệnh hiện tại trong bảng phase dưới đây và đánh dấu **phase của nó** trong sơ đồ trên:
260
-
261
- | Phase | Commands |
262
- |-------|----------|
263
- | Discovery | `/define-product` |
264
- | PRD | `/generate-prd` · `/refine-prd` · `/review-context` (PRD) |
265
- | Design Spec | `/generate-design-spec` |
266
- | BDD | `/generate-bdd` · `/review-context` (BDD) |
267
- | Tech Design | `/generate-tech-docs` · `/map-testids` · `/review-tech-docs` |
268
- | Code | `/generate-code` · `/review-code` |
269
- | Dev Self-Check | `/dev-gen-test` · `/dev-run-test` · `/dev-smoke-test` |
270
- | QC | `/qc-analyze` · `/qc-plan` · `/qc-design-test` · `/qc-review` · `/qc-run-test` · `/qc-report` |
271
- | Trace Audit | `/validate-traces` |
272
-
273
- Với **lệnh review**, thêm vòng review 3 bước và đánh dấu bước hiện tại, vd:
274
- `Vòng review: [① phân tích ◀] → ② Review Board → ③ --resume`.
275
-
276
- **Lệnh xuyên suốt** (`/sync`, `/update-framework`, `/fix-bug`, `/debug`, `/learn`,
277
- `/report-bug`, `/propose-scenario`, `/generate-spec-manifest`) nằm ngoài pipeline tuyến tính —
278
- **bỏ hẳn dòng Pipeline** cho các lệnh này (đừng cố nhét chúng vào sơ đồ).
279
-
280
- ## Gợi ý lệnh tiếp theo
281
-
282
- Gợi ý lệnh kế tiếp hợp lý theo phase của workflow:
283
-
284
- | Lệnh hiện tại | Gợi ý lệnh tiếp theo |
285
- |-------------------------|-----------------------------------------------|
286
- | /setup-ai-first | `/define-product` để bắt đầu feature đầu tiên |
287
- | /define-product | `/generate-prd {product-definition-file}` |
288
- | /generate-prd | `/refine-prd {prd-file}` rồi `/review-context {prd-file}` |
289
- | /refine-prd | Mở Review Board → cập nhật PRD → `/review-context {prd-file}` |
290
- | /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 |
291
- | /generate-design-spec | Designer review → xác nhận link Figma → PO + Designer sign-off → `/generate-bdd {prd-file}` |
292
- | /generate-bdd | `/review-context {feature-file}` để kiểm tra độ phủ |
293
- | /review-context (BDD) | `/generate-tech-docs {UC-ID}` nếu APPROVED; sinh lại nếu NEEDS_FIX |
294
- | /qc-analyze | `/qc-plan {UC-ID}` (xử lý các gap blocker 🔴 trước) |
295
- | /qc-plan | `/qc-design-test {UC-ID}` |
296
- | /qc-design-test | `/qc-review {UC-ID}` (review test-case) |
297
- | /qc-review (test-case) | `/qc-run-test {UC-ID}` nếu APPROVED; sửa TC nếu NEEDS_FIX |
298
- | /qc-run-test | `/qc-report {UC-ID}` rồi `/qc-review {UC-ID}` (review script) |
299
- | /qc-review (script) | `/qc-report {UC-ID}` rồi tạo PR nếu APPROVED |
300
- | /qc-report | `/validate-traces {UC-ID}` để làm mới Living Docs (qc_status) |
301
- | /generate-tech-docs | `/review-tech-docs {tech-design-file}` |
302
- | /review-tech-docs | `/generate-code {feature-file}` nếu APPROVED; sửa doc nếu NEEDS_FIX |
303
- | /generate-code | Lần gen đầu → `/review-code {UC-ID}`; gen lại → `/dev-gen-test {UC-ID}` |
304
- | /dev-gen-test | `/dev-run-test {UC-ID}` |
305
- | /dev-run-test (passing) | `/review-code {UC-ID}` |
306
- | /dev-run-test (failing) | `/fix-bug {ticket-id}` hoặc `/debug {error}` |
307
- | /review-code | `/dev-smoke-test {UC-ID}` hoặc tạo PR |
308
- | /dev-smoke-test | Tạo PR và link tới ticket |
309
- | /validate-traces | DRIFT/UNTRACKED → `/generate-code {UC-ID}`; GAP → `/dev-gen-test {UC-ID}`; tất cả OK → tạo PR |
310
- | /fix-bug | Tạo PR và link tới ticket |
311
- | /debug | `/fix-bug {ticket-id}` nếu cần sửa |
312
- | /report-bug | Gửi cho dev (`/fix-bug {BUG-ID}`); nếu thiếu coverage → `/propose-scenario {UC-ID}` |
313
- | /propose-scenario | Báo PO/Dev review proposal trong `feedback/bdd-proposals/` |
314
- | /learn | Tiếp tục làm việc — lesson áp dụng ở lệnh kế tiếp |
315
- | /sync | `/validate-traces` để xem độ phủ đầy đủ; xử lý mọi `📥 tester feedback` được nêu |
316
- | /update-framework | Review `git diff .agent/`, commit; `/sync` để đồng bộ nội dung dự án |
317
-
318
- Định dạng footer như sau:
319
- ```
320
- ---
321
- Status : {badge}
322
- {khối Output Artifacts}
323
- Pipeline : Discovery → PRD → [BDD ◀ bạn ở đây] → Tech Design → Code → Dev Self-Check → QC → Trace Audit
324
- (lệnh review) Vòng review: [① phân tích ◀] → ② Review Board → ③ --resume
325
- Next : {lệnh gợi ý kèm ví dụ tham số}
326
- ```
327
- *(Bỏ dòng `Pipeline` cho các lệnh xuyên suốt liệt kê ở trên.)*
328
-
329
-
330
- ---
331
-
332
- ## /dev-run-test — Run Tests & Report Results
333
-
334
- ### Gate
335
-
336
- # Context Loader — Nạp toàn bộ context dự án
337
-
338
- 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.
339
-
340
- **Hướng dẫn ưu tiên (chống lost-in-middle):**
341
- - Bước 1–2 là PROJECT-CONFIG — nạp trước, phân giải mọi path và metadata.
342
- - Bước 3 là CRITICAL — kiến trúc + coding standards, là các sự thật ưu tiên cao nhất khi sinh nội dung.
343
- - Bước 4 là SAFETY — quy tắc bảo vệ dữ liệu, thực thi ngầm suốt cả phiên.
344
- - Bước 5–6 là DOMAIN KNOWLEDGE — thuật ngữ và định nghĩa entity.
345
- - Bước 7 là WORKING MEMORY RECAP — chốt các sự thật quan trọng lên đầu bộ nhớ làm việc.
346
-
347
- ---
348
-
349
- ## Bước 1 — [PROJECT-CONFIG] Nạp project-context.yaml
350
-
351
- Đọc `.agent/project-context.yaml`. Trích xuất và lưu:
352
-
353
- **Tech Stack:**
354
- - `tech_stack.language` → ngôn ngữ đang dùng (vd: Java 17, TypeScript, C#, Go)
355
- - `tech_stack.framework` → framework đang dùng (vd: Spring Boot 3.2, Angular 17, .NET 8)
356
- - `tech_stack.build_tool` → build tool (vd: Maven, npm, dotnet, go)
357
- - `tech_stack.test_framework` → test framework (vd: JUnit 5 + Mockito, Jest, xUnit)
358
- - `tech_stack.database` → database (vd: PostgreSQL, MySQL, MongoDB)
359
- - `tech_stack.module` → module profile đang dùng (vd: java-spring, angular, dotnet, golang, context-engineering)
360
-
361
- **Conventions:**
362
- - `conventions.build_command` → cách compile/build
363
- - `conventions.test_command` → cách chạy test
364
- - `conventions.service_run` → cách khởi động service
365
- - `conventions.ticket_prefix` → tiền tố ticket ID (vd: PROJ, FEAT, UC)
366
-
367
- **Domains:**
368
- - `domains` → danh sách các business domain đang hoạt động
369
-
370
- **Paths (nếu có):**
371
- - `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)
372
- - `paths.refinement_dir` → thư mục output cho findings/review
373
- - `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}/`)
374
- - `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 đè)
375
- - `paths.product_definitions_dir` → gốc product definition
376
- - `paths.domain_knowledge_dir` → gốc domain knowledge
377
- - `paths.business_dictionary` → path tới business-dictionary.md
378
- - `paths.core_entities` → path tới core-entities.md
379
- - `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/`)
380
- - `paths.trace_dir` → thư mục trạng thái trace; cấu trúc: `.trace/{domain}/{prd-slug}/{UC-ID}.tsv`
381
-
382
- Nếu không có section `paths`, dùng các giá trị mặc định:
383
- - `specs_dir` = `specs`
384
- - `refinement_dir` = `.agent/review`
385
- - `qc_dir` = `docs`
386
- - `qc_skills_dir` = `.agent/skills/qc`
387
- - `product_definitions_dir` = `specs/product-definition`
388
- - `domain_knowledge_dir` = `specs/domain-knowledge`
389
- - `business_dictionary` = `specs/domain-knowledge/business-dictionary.md`
390
- - `core_entities` = `specs/domain-knowledge/core-entities.md`
391
- - `tech_docs_dir` = `specs`
392
- - `trace_dir` = `.trace`
393
-
394
- Lưu ý: Trong bố cục feature-package, `specs_dir` là 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` là tên folder feature-package, không phải một biến config riêng.
395
-
396
- **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, vì 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ụ:
397
- - `specs/payment/create-invoice/PAY01-create-invoice.md` → `prd_slug = create-invoice`
398
- - `specs/payment/create-invoice/bdd/system/PAY-UC1.feature` → `prd_slug = create-invoice` *(KHÔNG phải `system`)*
399
- - `specs/payment/create-invoice/bdd/web/PAY-UC1.feature` → `prd_slug = create-invoice` *(KHÔNG phải `web`)*
400
- - `specs/payment/create-invoice/tech-docs/PAY-UC1-tech-design.md` → `prd_slug = create-invoice` *(KHÔNG phải `tech-docs`)*
401
- - `specs/payment/create-invoice/design-spec/PAY-design-spec-web.md` → `prd_slug = create-invoice`
402
-
403
- 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, và 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 mà nó được suy ra từ đó.
404
-
405
- 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.
406
-
407
- ---
408
-
409
- ## Bước 1.5 — [SERVICE ROUTING] Phân giải path service (chế độ umbrella)
410
-
411
- *Bỏ qua hoàn toàn bước này nếu `setup.mode` không phải `"umbrella"` và không có section `services` trong project-context.yaml.*
412
-
413
- Nếu có section `services`:
414
-
415
- **1. Phát hiện active domain** (theo thứ tự ưu tiên):
416
- - Đọc `@trace.domain` từ frontmatter của target file (nếu Gate đã nạp một target file)
417
- - 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.
418
- *(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`)*
419
- - Nếu `$ARGUMENTS` chứa một path, trích xuất segment domain sau `specs_dir`
420
-
421
- **2. Route tới service** — nếu active domain khớp với một key trong `services`:
422
- - 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**) là artifact dùng chung liên team → để bước 4 route sang spec repo; KHÔNG pin theo service ở đây.
423
- - 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) là artifact liên team và phải nằm trong spec repo dùng chung (xử lý ở bước 4), nên để bước 4 route `tech_docs_dir` — KHÔNG pin theo service ở đây.
424
- - Lưu `active_service` = `services.{domain}.path`
425
- - Lưu `active_service_module` = `services.{domain}.module`
426
- - Nếu service có `module` riêng → dùng nó làm `active_module` (override `tech_stack.module`)
427
-
428
- **3. Fallback** — nếu không phát hiện được domain hoặc không có service key khớp:
429
- - Giữ path mặc định từ Bước 1
430
- - Đặt `active_service = unresolved`
431
-
432
- **4. Tự động override theo spec source** — nếu `setup.spec_source` được đặt VÀ path tương ứng chưa được set tường minh trong `paths:`:
433
- - 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 có `spec_source`.)*
434
- - 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 LÀ API contract liên team: BE viết ở đây, FE/App đọc nó 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 có spec module dùng chung.)*
435
- - Override `paths.domain_knowledge_dir` → `{spec_source}/specs/domain-knowledge`
436
- - Override `paths.business_dictionary` → `{spec_source}/specs/domain-knowledge/business-dictionary.md`
437
- - Override `paths.core_entities` → `{spec_source}/specs/domain-knowledge/core-entities.md`
438
- - Override `paths.bug_reports_dir` → `{spec_source}/feedback/bug-reports`
439
- - Override `paths.bdd_proposals_dir` → `{spec_source}/feedback/bdd-proposals`
440
- - Override `paths.prd_change_requests_dir` → `{spec_source}/feedback/prd-change-requests`
441
- - 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 có 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 có `spec_source`.)*
442
-
443
- > **Vì sao đặt dưới `spec_source`:** PRD, BDD, tech-docs, design-spec, domain knowledge, feedback của tester, **và trạng thái coverage `.trace/`** đều là **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) và 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ự đủ và dễ điều hướng theo feature. Service submodule chỉ chứa **code** (+ tooling build/test). `.trace/` và `feedback/` là khu vực **ghi** của dev/QC trong spec repo. Ở chế độ single-service (không có `spec_source`), mọi thứ mặc định dưới gốc repo — vẫn là một repo.
444
-
445
- ---
446
-
447
- ## Bước 1.6 — [SERVICE CONVENTIONS] Nạp convention riêng của service (chế độ umbrella)
448
-
449
- *Bỏ qua hoàn toàn bước này nếu `active_service` là `"unresolved"` hoặc context ở chế độ single-service.*
450
-
451
- Khi `active_service` đã được phân giải thành một path thật ở Bước 1.5 (vd: `user-service/`):
452
-
453
- **1. Định vị config của service** — thử theo thứ tự ưu tiên:
454
- - `{active_service}/.agent/project-context.yaml`
455
- - `{active_service}/project-context.yaml`
456
-
457
- **2. Nếu tìm thấy, override bằng giá trị riêng của service:**
458
-
459
- | Biến | Nguồn |
460
- |----------|--------|
461
- | `conventions.test_command` | `conventions.test_command` của service |
462
- | `conventions.build_command` | `conventions.build_command` của service |
463
- | `paths.trace_dir` | **Nếu `spec_source` được đặt → giữ route spec-repo của bước 4 (`{spec_source}/.trace`); bỏ qua mọi `trace_dir` cấp service.** Chỉ khi không có `spec_source`: `{active_service}/{service paths.trace_dir}` (mặc định `{active_service}/.trace`). |
464
- | `paths.specs_dir` | **Nếu `spec_source` được đặt → giữ 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 có `spec_source`: `{active_service}/{service paths.specs_dir}` nếu được set, else dùng override ở Bước 1.5. |
465
-
466
- **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:
467
- - Các lệnh shell (`/dev-run-test`, `/dev-gen-test`) chạy **bên trong** `service_root`
468
- - **File source/test** được ghi tương đối với `service_root`; **trace TSV** được ghi vào `{paths.trace_dir}` (là spec repo khi `spec_source` được đặt — một thao tác ghi liên-repo, commit/push vào spec submodule giống như `feedback/`).
469
-
470
- **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 có config override).
471
-
472
- ---
473
-
474
- ## Bước 2 — [PROJECT-CONFIG] Nạp module stack profile (có điều kiện)
475
-
476
- Nếu `tech_stack.module` được đặt, đọc `.agent/modules/{module}/stack-profile.yaml`.
477
- Merge các convention riêng của framework (layer pattern, test pattern, quy tắc đặt tên) vào context đã nạp.
478
- Nếu file không tồn tại → bỏ qua âm thầm.
479
-
480
- ---
481
-
482
- ## Bước 3 — [CRITICAL] Nạp CLAUDE.md (phân tầng: root + service overlay)
483
-
484
- *Đây là context ưu tiên cao nhất — nó định nghĩa CÁCH viết code và tài liệu cho dự án này.*
485
-
486
- CLAUDE.md được nạp theo **hai tầng** để các quy tắc toàn-umbrella và kiến trúc/coding standards
487
- 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
488
- trong một service submodule với stack, kiến trúc, và convention RIÊNG của nó — nên CLAUDE.md của
489
- service phải thắng khi sinh code.
490
-
491
- **Tầng 1 — [BASE] Root CLAUDE.md (toàn umbrella).**
492
- Đọc `CLAUDE.md` ở gốc repo. Coi nội dung của nó là **nền tảng dùng chung** cho cả umbrella —
493
- git convention, tư thế bảo vệ dữ liệu, quy tắc xuyên suốt, và (ở chế độ single-service) là
494
- kiến trúc + coding standards duy nhất của dự án.
495
-
496
- **Tầng 2 — [OVERLAY] Service CLAUDE.md (chỉ chế độ umbrella).**
497
- *Chỉ chạy nếu `service_root` đã được set ở Bước 1.6 (tức đã route tới một service thật).*
498
- Đọc `{service_root}/CLAUDE.md`. File này định nghĩa kiến trúc + coding standards của **stack
499
- thực sự đang được triển khai** (vd: `user-service` = java-spring, `web` = nextjs).
500
- Overlay nó lên trên Tầng 1: **khi có xung đột, giá trị của service THẮNG** cho kiến trúc,
501
- coding standards, và error handling. Các giá trị Tầng 1 mà service không định nghĩa lại
502
- (vd: git convention, banned pattern dùng chung toàn tổ chức) vẫn có hiệu lực.
503
-
504
- Từ kết quả **đã merge**, trích xuất và lưu:
505
-
506
- - **§1 Project Overview** → tên dự án, ngôn ngữ, framework, lệnh build/test, domains
507
- - **§2 Architecture** → thứ tự layer (vd: Controller → Facade → Service → Repository), quy tắc kiến trúc — *service overlay thắng*
508
- - **§3 Coding Standards** → quy tắc đặt tên (class, method), kiểu response wrapper, pattern bị cấm — *service overlay thắng*
509
- - **§5 Error Handling** → kiểu exception, mapping HTTP status code, tên class not-found exception — *service overlay thắng*
510
- - **§7 Git Conventions** → pattern đặt tên branch, format commit message — *lấy theo root trừ khi service định nghĩa lại*
511
-
512
- **Quy tắc phân giải:**
513
- - Nếu cả hai tầng tồn tại → merge như trên; ghi `claude_md_source = root + {service_root}`.
514
- - Nếu chỉ có service overlay (không có root CLAUDE.md) → dùng file service một mình; `claude_md_source = {service_root}`.
515
- - Nếu `service_root` được set nhưng `{service_root}/CLAUDE.md` **thiếu** → fallback về root CLAUDE.md và gắn cờ ⚠️ trong recap Bước 7 (service không có định nghĩa kiến trúc/coding-standards — việc sinh code sẽ dùng mặc định umbrella, có thể sai stack).
516
- - Nếu cả hai đều không tồn tại → ghi nhận CLAUDE.md thiếu và tiếp tục chỉ với dữ liệu từ project-context.yaml.
517
-
518
- ---
519
-
520
- ## Bước 4 — [SAFETY] Nạp quy tắc bảo vệ dữ liệu
521
-
522
- Đọc `.agent/rules/data-protection.md` (hoặc `rules/data-protection.md` từ bản cài đặt framework).
523
-
524
- 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.
525
-
526
- 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*`.
527
-
528
- ---
529
-
530
- ## Bước 5 — [DOMAIN] Nạp Business Dictionary (có điều kiện)
531
-
532
- Kiểm tra file business dictionary có tồn tại không (dùng `paths.business_dictionary` đã phân giải ở Bước 1).
533
-
534
- Nếu tồn tại, đọc và trích xuất:
535
- - **Canonical Terms** → danh sách đầy đủ các thuật ngữ chuẩn và định nghĩa
536
- - **Banned Terms** → danh sách đầy đủ các thuật ngữ bị cấm và bản thay thế chuẩn
537
- - **Status / Enum Registry** → các giá trị enum được phép theo từng entity
538
-
539
- Lưu danh sách banned term để **thực thi chủ động** suốt phiên làm việc của lệnh:
540
- - 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
541
- - Tự động thay banned term bằng bản chuẩn tương đương
542
-
543
- Nếu file không tồn tại → bỏ qua âm thầm. Không cảnh báo hay chặn.
544
-
545
- ---
546
-
547
- ## Bước 6 — [DOMAIN] Nạp Core Entities (có điều kiện)
548
-
549
- Kiểm tra file core entities có tồn tại tại `paths.core_entities` không (đã phân giải ở Bước 1).
550
- Path mặc định: `specs/domain-knowledge/core-entities.md`.
551
-
552
- Nếu tồn tại, đọc và lưu:
553
- - **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, và quan hệ
554
- - **Field name registry** → tên field chuẩn dùng trong code và tài liệu được sinh ra
555
- - **Relationship map** → cách các entity liên hệ với nhau (1:N, N:N, embedded, v.v.)
556
-
557
- **Cách dùng catalog này:**
558
- - Khi sinh code: dùng tên field, kiểu, và quan hệ định nghĩa ở đây — KHÔNG suy đoán từ code có sẵn
559
- - Khi sinh PRD/BDD: tham chiếu tên entity từ catalog này để nhất quán
560
- - Khi sinh tech-docs: dùng catalog này làm nguồn chân lý cho định nghĩa entity
561
-
562
- Nếu file không tồn tại → bỏ qua âm thầm.
563
-
564
- ---
565
-
566
- ## Bước 6.5 — [PLATFORM] Suy ra active_module và platform_type
567
-
568
- Dùng `tech_stack.module` đã nạp ở Bước 1, suy ra và lưu hai biến để mọi lệnh phía sau dùng:
569
-
570
- ```
571
- active_module = tech_stack.module (vd: "java-spring", "react", "flutter")
572
- ```
573
-
574
- | `platform_type` | Modules |
575
- |---|---|
576
- | `backend` | `java-spring`, `golang`, `dotnet`, `php-laravel`, `context-engineering` |
577
- | `web-frontend` | `react`, `nextjs`, `vue`, `nuxt`, `angular` |
578
- | `mobile` | `flutter`, `react-native`, `ios-swiftui`, `android-compose` |
579
-
580
- Nếu `tech_stack.module` rỗng hoặc không nhận diện được → set `platform_type = "unknown"` và gắn cờ ⚠️ trong recap Bước 7.
581
-
582
- Hai biến này (`active_module`, `platform_type`) là 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).
583
-
584
- ---
585
-
586
- ## Bước 6.7 — [GUARDRAILS] Nạp Project Lessons (có điều kiện)
587
-
588
- *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`
589
- hoặc được chấp nhận trong `/review-code`, `/fix-bug`, `/debug`.*
590
-
591
- Phân giải path file lessons:
592
- - Dùng `paths.lessons_file` nếu được set (có thể bị service override ở chế độ umbrella, Bước 1.6)
593
- - Else mặc định `specs/domain-knowledge/lessons-learned.md`
594
- - Ở 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`
595
-
596
- Nếu file tồn tại, đọc và lưu TẤT CẢ lesson làm **GUARDRAIL ĐANG HOẠT ĐỘNG** cho phiên:
597
- - Coi **Rule** của mỗi lesson là ràng buộc cứng — cùng mức ưu tiên với coding standards trong CLAUDE.md (Bước 3).
598
- - 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 có `category` khớp lệnh hiện tại VÀ `scope` khớp target (domain / file).
599
- - Nếu output sinh ra vi phạm một lesson → sửa **trước khi** trình bày, và ghi rõ lesson nào (`L-NNN`) đã được áp dụng.
600
-
601
- Nếu file không tồn tại → bỏ qua âm thầm (chưa có lesson nào được ghi nhận).
602
-
603
- ---
604
-
605
- ## Bước 7 — [RECAP] Working Memory Recap (chống lost-in-middle)
606
-
607
- Sau khi nạp toàn bộ context, tổng hợp và xuất một khối tóm tắt gọn.
608
- 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
609
- (hiệu ứng recency — tươi mới nhất trong bộ nhớ làm việc khi bắt đầu task).
610
-
611
- Xuất đúng khối này:
612
- ```
613
- [CTX LOADED]
614
- Stack : {language} / {framework} / {database}
615
- Platform : {active_module} ({platform_type})
616
- Layers : {thứ tự layer từ CLAUDE.md §2 đã merge, vd: Controller → Facade → Service → Repository}
617
- CLAUDE.md : {root + {service_root} | chỉ {service_root} | chỉ root | ⚠️ service overlay THIẾU — dùng root | missing}
618
- Ticket : {ticket_prefix}-
619
- Dict : {loaded — N canonical terms, M banned terms | missing}
620
- Entities : {loaded — EntityA, EntityB, EntityC | missing}
621
- Lessons : {loaded — N guardrails | chưa có}
622
- Service : {active_service} ({active_service_module}) | single-service
623
- Svc Root : {service_root} — đã nạp conventions + trace_dir từ config service | —
624
- Status : {FULL | PARTIAL — thiếu: CLAUDE.md / business-dict / core-entities | MINIMAL}
625
- ```
626
-
627
- Nếu bất kỳ file CRITICAL nào thiếu (CLAUDE.md), gắn cờ rõ ràng để người dùng quyết định có tiếp tục hay không.
628
-
629
- ---
630
-
631
- ## Hoàn tất nạp Context
632
-
633
- Sau khi hoàn thành tất cả các bước, bạn đã nạp:
634
- - Định danh dự án, tech stack, convention module
635
- - Quy tắc kiến trúc và thứ tự layer ← **[CRITICAL — giữ trong bộ nhớ làm việc]**
636
- - Coding standards và quy tắc đặt tên ← **[CRITICAL — giữ trong bộ nhớ làm việc]**
637
- - Quy tắc bảo vệ dữ liệu (pattern file nhạy cảm không bao giờ truy cập)
638
- - Quy tắc thuật ngữ kèm danh sách banned term ← **[DOMAIN — áp dụng cho mọi từ được sinh ra]**
639
- - Entity catalog (tên field, kiểu, invariant) ← **[DOMAIN — dùng khi sinh code]**
640
- - Toàn bộ path đã cấu hình
641
-
642
- Tiếp tục sang bước kế tiếp của lệnh đang gọi.
9
+ ## /dev-gen-test — Sinh test dev self-check
10
+ → **Đọc và tuân theo `commands/dev-gen-test.md`** với cùng `$ARGUMENTS`.
643
11
 
12
+ ## /dev-run-test — Chạy test & ghi `dev_selftest`
13
+ → **Đọc và tuân theo `commands/dev-run-test.md`** với cùng `$ARGUMENTS`.
14
+ (Command lo: bảng phân tích lỗi theo platform · ghi `dev_selftest`/`dev_selftest_at` vào trace TSV.)
644
15
 
645
- Xác định service/module từ argument (UC-ID hoặc tên service).
646
- Đọc `conventions.test_command` từ project context đã nạp.
647
-
648
- ### Run
649
-
650
- ```bash
651
- # Run all tests in module
652
- {TEST_COMMAND}
653
-
654
- # Run specific test class (faster)
655
- {TEST_COMMAND_FOR_CLASS}
656
-
657
- # Run by pattern
658
- {TEST_COMMAND_BY_PATTERN}
659
- ```
660
-
661
- ### Analyze Results
662
-
663
- #### Khi test PASS
664
-
665
- ```
666
- ✅ Tests passed
667
- - Total: {N}
668
- - Passed: {N}
669
- - Duration: {X}s
670
- ```
671
-
672
- #### Khi test FAIL — Debug Mode
673
-
674
- Đọc stack trace và phân tích:
675
-
676
- | Error Pattern | Nguyên nhân thường gặp | Suggested Fix |
677
- |---|---|---|
678
- | NullPointerException trong test | Thiếu setup mock | Kiểm tra setup `given(...)` cho dependency null |
679
- | Bean/dependency not found | Thiếu khai báo mock/stub | Thêm mock cho dependency thiếu |
680
- | Expected 200 but got 403 | Thiếu setup auth trong test | Thêm auth user/role vào test context |
681
- | Expected 200 but got 400 | Request body fail validation | Kiểm tra field bắt buộc trong request DTO |
682
- | LazyInitializationException | Lazy collection truy cập ngoài transaction | Thêm `@Transactional` trên test hoặc dùng eager fetch |
683
- | Mapper/mapper implementation not found | Code generator (vd MapStruct) chưa chạy | Chạy compile trước khi test |
684
-
685
- ### Output
686
-
687
- ```
688
- /dev-run-test Report — {service}
689
- Run at: {datetime}
690
-
691
- ## Summary
692
- ✅ Passed: {N} | ❌ Failed: {M} | ⏭️ Skipped: {K}
693
- Duration: {X}s
694
-
695
- ## Failed Tests
696
- | Test | Error | Root Cause |
697
- |------|-------|-----------|
698
- | {TestClass}.{method} | {exception} | {analysis} |
699
-
700
- ## Recommendations
701
- {specific fix for each failure}
702
- ```
703
-
704
- # Report Footer — Định dạng output chuẩn cho mọi lệnh
705
-
706
- Mọi report của lệnh phải kết thúc bằng section footer chuẩn này.
707
-
708
- ## Status Badge
709
-
710
- Chọn một theo kết quả:
711
- - `✅ Complete` — mọi bước thành công, không có vấn đề
712
- - `❌ Failed` — lệnh không hoàn thành được do lỗi chặn
713
- - `⚠️ Warnings` — hoàn thành nhưng có vấn đề không chặn, nên review lại
714
-
715
- ## Output Artifacts
716
-
717
- Liệt kê mọi file được tạo hoặc sửa bởi lệnh này:
718
- ```
719
- Output Artifacts:
720
- {created|updated} {file-path} ({mô tả ngắn})
721
- {created|updated} {file-path} ({mô tả ngắn})
722
- ```
723
-
724
- Nếu không ghi file nào (vd: lệnh review hoặc phân tích) → ghi `Output Artifacts: none (read-only)`.
725
-
726
- ## Pipeline Position
727
-
728
- In một sơ đồ pipeline một dòng, đánh dấu phase của lệnh HIỆN TẠI bằng `◀ bạn ở đây`,
729
- để người dùng luôn thấy lệnh này nằm ở đâu trong luồng end-to-end:
730
-
731
- ```
732
- Discovery → PRD → [Design Spec] → BDD → Tech Design → Code → Dev Self-Check → QC → Trace Audit
733
- ```
734
-
735
- Tìm lệnh hiện tại trong bảng phase dưới đây và đánh dấu **phase của nó** trong sơ đồ trên:
736
-
737
- | Phase | Commands |
738
- |-------|----------|
739
- | Discovery | `/define-product` |
740
- | PRD | `/generate-prd` · `/refine-prd` · `/review-context` (PRD) |
741
- | Design Spec | `/generate-design-spec` |
742
- | BDD | `/generate-bdd` · `/review-context` (BDD) |
743
- | Tech Design | `/generate-tech-docs` · `/map-testids` · `/review-tech-docs` |
744
- | Code | `/generate-code` · `/review-code` |
745
- | Dev Self-Check | `/dev-gen-test` · `/dev-run-test` · `/dev-smoke-test` |
746
- | QC | `/qc-analyze` · `/qc-plan` · `/qc-design-test` · `/qc-review` · `/qc-run-test` · `/qc-report` |
747
- | Trace Audit | `/validate-traces` |
748
-
749
- Với **lệnh review**, thêm vòng review 3 bước và đánh dấu bước hiện tại, vd:
750
- `Vòng review: [① phân tích ◀] → ② Review Board → ③ --resume`.
751
-
752
- **Lệnh xuyên suốt** (`/sync`, `/update-framework`, `/fix-bug`, `/debug`, `/learn`,
753
- `/report-bug`, `/propose-scenario`, `/generate-spec-manifest`) nằm ngoài pipeline tuyến tính —
754
- **bỏ hẳn dòng Pipeline** cho các lệnh này (đừng cố nhét chúng vào sơ đồ).
755
-
756
- ## Gợi ý lệnh tiếp theo
757
-
758
- Gợi ý lệnh kế tiếp hợp lý theo phase của workflow:
759
-
760
- | Lệnh hiện tại | Gợi ý lệnh tiếp theo |
761
- |-------------------------|-----------------------------------------------|
762
- | /setup-ai-first | `/define-product` để bắt đầu feature đầu tiên |
763
- | /define-product | `/generate-prd {product-definition-file}` |
764
- | /generate-prd | `/refine-prd {prd-file}` rồi `/review-context {prd-file}` |
765
- | /refine-prd | Mở Review Board → cập nhật PRD → `/review-context {prd-file}` |
766
- | /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 |
767
- | /generate-design-spec | Designer review → xác nhận link Figma → PO + Designer sign-off → `/generate-bdd {prd-file}` |
768
- | /generate-bdd | `/review-context {feature-file}` để kiểm tra độ phủ |
769
- | /review-context (BDD) | `/generate-tech-docs {UC-ID}` nếu APPROVED; sinh lại nếu NEEDS_FIX |
770
- | /qc-analyze | `/qc-plan {UC-ID}` (xử lý các gap blocker 🔴 trước) |
771
- | /qc-plan | `/qc-design-test {UC-ID}` |
772
- | /qc-design-test | `/qc-review {UC-ID}` (review test-case) |
773
- | /qc-review (test-case) | `/qc-run-test {UC-ID}` nếu APPROVED; sửa TC nếu NEEDS_FIX |
774
- | /qc-run-test | `/qc-report {UC-ID}` rồi `/qc-review {UC-ID}` (review script) |
775
- | /qc-review (script) | `/qc-report {UC-ID}` rồi tạo PR nếu APPROVED |
776
- | /qc-report | `/validate-traces {UC-ID}` để làm mới Living Docs (qc_status) |
777
- | /generate-tech-docs | `/review-tech-docs {tech-design-file}` |
778
- | /review-tech-docs | `/generate-code {feature-file}` nếu APPROVED; sửa doc nếu NEEDS_FIX |
779
- | /generate-code | Lần gen đầu → `/review-code {UC-ID}`; gen lại → `/dev-gen-test {UC-ID}` |
780
- | /dev-gen-test | `/dev-run-test {UC-ID}` |
781
- | /dev-run-test (passing) | `/review-code {UC-ID}` |
782
- | /dev-run-test (failing) | `/fix-bug {ticket-id}` hoặc `/debug {error}` |
783
- | /review-code | `/dev-smoke-test {UC-ID}` hoặc tạo PR |
784
- | /dev-smoke-test | Tạo PR và link tới ticket |
785
- | /validate-traces | DRIFT/UNTRACKED → `/generate-code {UC-ID}`; GAP → `/dev-gen-test {UC-ID}`; tất cả OK → tạo PR |
786
- | /fix-bug | Tạo PR và link tới ticket |
787
- | /debug | `/fix-bug {ticket-id}` nếu cần sửa |
788
- | /report-bug | Gửi cho dev (`/fix-bug {BUG-ID}`); nếu thiếu coverage → `/propose-scenario {UC-ID}` |
789
- | /propose-scenario | Báo PO/Dev review proposal trong `feedback/bdd-proposals/` |
790
- | /learn | Tiếp tục làm việc — lesson áp dụng ở lệnh kế tiếp |
791
- | /sync | `/validate-traces` để xem độ phủ đầy đủ; xử lý mọi `📥 tester feedback` được nêu |
792
- | /update-framework | Review `git diff .agent/`, commit; `/sync` để đồng bộ nội dung dự án |
793
-
794
- Định dạng footer như sau:
795
- ```
796
- ---
797
- Status : {badge}
798
- {khối Output Artifacts}
799
- Pipeline : Discovery → PRD → [BDD ◀ bạn ở đây] → Tech Design → Code → Dev Self-Check → QC → Trace Audit
800
- (lệnh review) Vòng review: [① phân tích ◀] → ② Review Board → ③ --resume
801
- Next : {lệnh gợi ý kèm ví dụ tham số}
802
- ```
803
- *(Bỏ dòng `Pipeline` cho các lệnh xuyên suốt liệt kê ở trên.)*
804
-
805
-
806
- ---
807
-
808
- ## /dev-smoke-test — Test Live API Endpoints
809
-
810
- Dùng khi service **đang chạy sẵn** để verify endpoint hoạt động đúng.
811
- Khác `/dev-run-test` (chạy unit/integration test không cần live server).
812
-
813
- ### Phase 1 — Find Service URL
814
-
815
- # Context Loader — Nạp toàn bộ context dự án
816
-
817
- 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.
818
-
819
- **Hướng dẫn ưu tiên (chống lost-in-middle):**
820
- - Bước 1–2 là PROJECT-CONFIG — nạp trước, phân giải mọi path và metadata.
821
- - Bước 3 là CRITICAL — kiến trúc + coding standards, là các sự thật ưu tiên cao nhất khi sinh nội dung.
822
- - Bước 4 là SAFETY — quy tắc bảo vệ dữ liệu, thực thi ngầm suốt cả phiên.
823
- - Bước 5–6 là DOMAIN KNOWLEDGE — thuật ngữ và định nghĩa entity.
824
- - Bước 7 là WORKING MEMORY RECAP — chốt các sự thật quan trọng lên đầu bộ nhớ làm việc.
825
-
826
- ---
827
-
828
- ## Bước 1 — [PROJECT-CONFIG] Nạp project-context.yaml
829
-
830
- Đọc `.agent/project-context.yaml`. Trích xuất và lưu:
831
-
832
- **Tech Stack:**
833
- - `tech_stack.language` → ngôn ngữ đang dùng (vd: Java 17, TypeScript, C#, Go)
834
- - `tech_stack.framework` → framework đang dùng (vd: Spring Boot 3.2, Angular 17, .NET 8)
835
- - `tech_stack.build_tool` → build tool (vd: Maven, npm, dotnet, go)
836
- - `tech_stack.test_framework` → test framework (vd: JUnit 5 + Mockito, Jest, xUnit)
837
- - `tech_stack.database` → database (vd: PostgreSQL, MySQL, MongoDB)
838
- - `tech_stack.module` → module profile đang dùng (vd: java-spring, angular, dotnet, golang, context-engineering)
839
-
840
- **Conventions:**
841
- - `conventions.build_command` → cách compile/build
842
- - `conventions.test_command` → cách chạy test
843
- - `conventions.service_run` → cách khởi động service
844
- - `conventions.ticket_prefix` → tiền tố ticket ID (vd: PROJ, FEAT, UC)
845
-
846
- **Domains:**
847
- - `domains` → danh sách các business domain đang hoạt động
848
-
849
- **Paths (nếu có):**
850
- - `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)
851
- - `paths.refinement_dir` → thư mục output cho findings/review
852
- - `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}/`)
853
- - `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 đè)
854
- - `paths.product_definitions_dir` → gốc product definition
855
- - `paths.domain_knowledge_dir` → gốc domain knowledge
856
- - `paths.business_dictionary` → path tới business-dictionary.md
857
- - `paths.core_entities` → path tới core-entities.md
858
- - `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/`)
859
- - `paths.trace_dir` → thư mục trạng thái trace; cấu trúc: `.trace/{domain}/{prd-slug}/{UC-ID}.tsv`
860
-
861
- Nếu không có section `paths`, dùng các giá trị mặc định:
862
- - `specs_dir` = `specs`
863
- - `refinement_dir` = `.agent/review`
864
- - `qc_dir` = `docs`
865
- - `qc_skills_dir` = `.agent/skills/qc`
866
- - `product_definitions_dir` = `specs/product-definition`
867
- - `domain_knowledge_dir` = `specs/domain-knowledge`
868
- - `business_dictionary` = `specs/domain-knowledge/business-dictionary.md`
869
- - `core_entities` = `specs/domain-knowledge/core-entities.md`
870
- - `tech_docs_dir` = `specs`
871
- - `trace_dir` = `.trace`
872
-
873
- Lưu ý: Trong bố cục feature-package, `specs_dir` là 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` là tên folder feature-package, không phải một biến config riêng.
874
-
875
- **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, vì 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ụ:
876
- - `specs/payment/create-invoice/PAY01-create-invoice.md` → `prd_slug = create-invoice`
877
- - `specs/payment/create-invoice/bdd/system/PAY-UC1.feature` → `prd_slug = create-invoice` *(KHÔNG phải `system`)*
878
- - `specs/payment/create-invoice/bdd/web/PAY-UC1.feature` → `prd_slug = create-invoice` *(KHÔNG phải `web`)*
879
- - `specs/payment/create-invoice/tech-docs/PAY-UC1-tech-design.md` → `prd_slug = create-invoice` *(KHÔNG phải `tech-docs`)*
880
- - `specs/payment/create-invoice/design-spec/PAY-design-spec-web.md` → `prd_slug = create-invoice`
881
-
882
- 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, và 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 mà nó được suy ra từ đó.
883
-
884
- 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.
885
-
886
- ---
887
-
888
- ## Bước 1.5 — [SERVICE ROUTING] Phân giải path service (chế độ umbrella)
889
-
890
- *Bỏ qua hoàn toàn bước này nếu `setup.mode` không phải `"umbrella"` và không có section `services` trong project-context.yaml.*
891
-
892
- Nếu có section `services`:
893
-
894
- **1. Phát hiện active domain** (theo thứ tự ưu tiên):
895
- - Đọc `@trace.domain` từ frontmatter của target file (nếu Gate đã nạp một target file)
896
- - 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.
897
- *(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`)*
898
- - Nếu `$ARGUMENTS` chứa một path, trích xuất segment domain sau `specs_dir`
899
-
900
- **2. Route tới service** — nếu active domain khớp với một key trong `services`:
901
- - 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**) là artifact dùng chung liên team → để bước 4 route sang spec repo; KHÔNG pin theo service ở đây.
902
- - 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) là artifact liên team và phải nằm trong spec repo dùng chung (xử lý ở bước 4), nên để bước 4 route `tech_docs_dir` — KHÔNG pin theo service ở đây.
903
- - Lưu `active_service` = `services.{domain}.path`
904
- - Lưu `active_service_module` = `services.{domain}.module`
905
- - Nếu service có `module` riêng → dùng nó làm `active_module` (override `tech_stack.module`)
906
-
907
- **3. Fallback** — nếu không phát hiện được domain hoặc không có service key khớp:
908
- - Giữ path mặc định từ Bước 1
909
- - Đặt `active_service = unresolved`
910
-
911
- **4. Tự động override theo spec source** — nếu `setup.spec_source` được đặt VÀ path tương ứng chưa được set tường minh trong `paths:`:
912
- - 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 có `spec_source`.)*
913
- - 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 LÀ API contract liên team: BE viết ở đây, FE/App đọc nó 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 có spec module dùng chung.)*
914
- - Override `paths.domain_knowledge_dir` → `{spec_source}/specs/domain-knowledge`
915
- - Override `paths.business_dictionary` → `{spec_source}/specs/domain-knowledge/business-dictionary.md`
916
- - Override `paths.core_entities` → `{spec_source}/specs/domain-knowledge/core-entities.md`
917
- - Override `paths.bug_reports_dir` → `{spec_source}/feedback/bug-reports`
918
- - Override `paths.bdd_proposals_dir` → `{spec_source}/feedback/bdd-proposals`
919
- - Override `paths.prd_change_requests_dir` → `{spec_source}/feedback/prd-change-requests`
920
- - 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 có 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 có `spec_source`.)*
921
-
922
- > **Vì sao đặt dưới `spec_source`:** PRD, BDD, tech-docs, design-spec, domain knowledge, feedback của tester, **và trạng thái coverage `.trace/`** đều là **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) và 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ự đủ và dễ điều hướng theo feature. Service submodule chỉ chứa **code** (+ tooling build/test). `.trace/` và `feedback/` là khu vực **ghi** của dev/QC trong spec repo. Ở chế độ single-service (không có `spec_source`), mọi thứ mặc định dưới gốc repo — vẫn là một repo.
923
-
924
- ---
925
-
926
- ## Bước 1.6 — [SERVICE CONVENTIONS] Nạp convention riêng của service (chế độ umbrella)
927
-
928
- *Bỏ qua hoàn toàn bước này nếu `active_service` là `"unresolved"` hoặc context ở chế độ single-service.*
929
-
930
- Khi `active_service` đã được phân giải thành một path thật ở Bước 1.5 (vd: `user-service/`):
931
-
932
- **1. Định vị config của service** — thử theo thứ tự ưu tiên:
933
- - `{active_service}/.agent/project-context.yaml`
934
- - `{active_service}/project-context.yaml`
935
-
936
- **2. Nếu tìm thấy, override bằng giá trị riêng của service:**
937
-
938
- | Biến | Nguồn |
939
- |----------|--------|
940
- | `conventions.test_command` | `conventions.test_command` của service |
941
- | `conventions.build_command` | `conventions.build_command` của service |
942
- | `paths.trace_dir` | **Nếu `spec_source` được đặt → giữ route spec-repo của bước 4 (`{spec_source}/.trace`); bỏ qua mọi `trace_dir` cấp service.** Chỉ khi không có `spec_source`: `{active_service}/{service paths.trace_dir}` (mặc định `{active_service}/.trace`). |
943
- | `paths.specs_dir` | **Nếu `spec_source` được đặt → giữ 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 có `spec_source`: `{active_service}/{service paths.specs_dir}` nếu được set, else dùng override ở Bước 1.5. |
944
-
945
- **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:
946
- - Các lệnh shell (`/dev-run-test`, `/dev-gen-test`) chạy **bên trong** `service_root`
947
- - **File source/test** được ghi tương đối với `service_root`; **trace TSV** được ghi vào `{paths.trace_dir}` (là spec repo khi `spec_source` được đặt — một thao tác ghi liên-repo, commit/push vào spec submodule giống như `feedback/`).
948
-
949
- **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 có config override).
950
-
951
- ---
952
-
953
- ## Bước 2 — [PROJECT-CONFIG] Nạp module stack profile (có điều kiện)
954
-
955
- Nếu `tech_stack.module` được đặt, đọc `.agent/modules/{module}/stack-profile.yaml`.
956
- Merge các convention riêng của framework (layer pattern, test pattern, quy tắc đặt tên) vào context đã nạp.
957
- Nếu file không tồn tại → bỏ qua âm thầm.
958
-
959
- ---
960
-
961
- ## Bước 3 — [CRITICAL] Nạp CLAUDE.md (phân tầng: root + service overlay)
962
-
963
- *Đây là context ưu tiên cao nhất — nó định nghĩa CÁCH viết code và tài liệu cho dự án này.*
964
-
965
- CLAUDE.md được nạp theo **hai tầng** để các quy tắc toàn-umbrella và kiến trúc/coding standards
966
- 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
967
- trong một service submodule với stack, kiến trúc, và convention RIÊNG của nó — nên CLAUDE.md của
968
- service phải thắng khi sinh code.
969
-
970
- **Tầng 1 — [BASE] Root CLAUDE.md (toàn umbrella).**
971
- Đọc `CLAUDE.md` ở gốc repo. Coi nội dung của nó là **nền tảng dùng chung** cho cả umbrella —
972
- git convention, tư thế bảo vệ dữ liệu, quy tắc xuyên suốt, và (ở chế độ single-service) là
973
- kiến trúc + coding standards duy nhất của dự án.
974
-
975
- **Tầng 2 — [OVERLAY] Service CLAUDE.md (chỉ chế độ umbrella).**
976
- *Chỉ chạy nếu `service_root` đã được set ở Bước 1.6 (tức đã route tới một service thật).*
977
- Đọc `{service_root}/CLAUDE.md`. File này định nghĩa kiến trúc + coding standards của **stack
978
- thực sự đang được triển khai** (vd: `user-service` = java-spring, `web` = nextjs).
979
- Overlay nó lên trên Tầng 1: **khi có xung đột, giá trị của service THẮNG** cho kiến trúc,
980
- coding standards, và error handling. Các giá trị Tầng 1 mà service không định nghĩa lại
981
- (vd: git convention, banned pattern dùng chung toàn tổ chức) vẫn có hiệu lực.
982
-
983
- Từ kết quả **đã merge**, trích xuất và lưu:
984
-
985
- - **§1 Project Overview** → tên dự án, ngôn ngữ, framework, lệnh build/test, domains
986
- - **§2 Architecture** → thứ tự layer (vd: Controller → Facade → Service → Repository), quy tắc kiến trúc — *service overlay thắng*
987
- - **§3 Coding Standards** → quy tắc đặt tên (class, method), kiểu response wrapper, pattern bị cấm — *service overlay thắng*
988
- - **§5 Error Handling** → kiểu exception, mapping HTTP status code, tên class not-found exception — *service overlay thắng*
989
- - **§7 Git Conventions** → pattern đặt tên branch, format commit message — *lấy theo root trừ khi service định nghĩa lại*
990
-
991
- **Quy tắc phân giải:**
992
- - Nếu cả hai tầng tồn tại → merge như trên; ghi `claude_md_source = root + {service_root}`.
993
- - Nếu chỉ có service overlay (không có root CLAUDE.md) → dùng file service một mình; `claude_md_source = {service_root}`.
994
- - Nếu `service_root` được set nhưng `{service_root}/CLAUDE.md` **thiếu** → fallback về root CLAUDE.md và gắn cờ ⚠️ trong recap Bước 7 (service không có định nghĩa kiến trúc/coding-standards — việc sinh code sẽ dùng mặc định umbrella, có thể sai stack).
995
- - Nếu cả hai đều không tồn tại → ghi nhận CLAUDE.md thiếu và tiếp tục chỉ với dữ liệu từ project-context.yaml.
996
-
997
- ---
998
-
999
- ## Bước 4 — [SAFETY] Nạp quy tắc bảo vệ dữ liệu
1000
-
1001
- Đọc `.agent/rules/data-protection.md` (hoặc `rules/data-protection.md` từ bản cài đặt framework).
1002
-
1003
- 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.
1004
-
1005
- 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*`.
1006
-
1007
- ---
1008
-
1009
- ## Bước 5 — [DOMAIN] Nạp Business Dictionary (có điều kiện)
1010
-
1011
- Kiểm tra file business dictionary có tồn tại không (dùng `paths.business_dictionary` đã phân giải ở Bước 1).
1012
-
1013
- Nếu tồn tại, đọc và trích xuất:
1014
- - **Canonical Terms** → danh sách đầy đủ các thuật ngữ chuẩn và định nghĩa
1015
- - **Banned Terms** → danh sách đầy đủ các thuật ngữ bị cấm và bản thay thế chuẩn
1016
- - **Status / Enum Registry** → các giá trị enum được phép theo từng entity
1017
-
1018
- Lưu danh sách banned term để **thực thi chủ động** suốt phiên làm việc của lệnh:
1019
- - 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
1020
- - Tự động thay banned term bằng bản chuẩn tương đương
1021
-
1022
- Nếu file không tồn tại → bỏ qua âm thầm. Không cảnh báo hay chặn.
1023
-
1024
- ---
1025
-
1026
- ## Bước 6 — [DOMAIN] Nạp Core Entities (có điều kiện)
1027
-
1028
- Kiểm tra file core entities có tồn tại tại `paths.core_entities` không (đã phân giải ở Bước 1).
1029
- Path mặc định: `specs/domain-knowledge/core-entities.md`.
1030
-
1031
- Nếu tồn tại, đọc và lưu:
1032
- - **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, và quan hệ
1033
- - **Field name registry** → tên field chuẩn dùng trong code và tài liệu được sinh ra
1034
- - **Relationship map** → cách các entity liên hệ với nhau (1:N, N:N, embedded, v.v.)
1035
-
1036
- **Cách dùng catalog này:**
1037
- - Khi sinh code: dùng tên field, kiểu, và quan hệ định nghĩa ở đây — KHÔNG suy đoán từ code có sẵn
1038
- - Khi sinh PRD/BDD: tham chiếu tên entity từ catalog này để nhất quán
1039
- - Khi sinh tech-docs: dùng catalog này làm nguồn chân lý cho định nghĩa entity
1040
-
1041
- Nếu file không tồn tại → bỏ qua âm thầm.
1042
-
1043
- ---
1044
-
1045
- ## Bước 6.5 — [PLATFORM] Suy ra active_module và platform_type
1046
-
1047
- Dùng `tech_stack.module` đã nạp ở Bước 1, suy ra và lưu hai biến để mọi lệnh phía sau dùng:
1048
-
1049
- ```
1050
- active_module = tech_stack.module (vd: "java-spring", "react", "flutter")
1051
- ```
1052
-
1053
- | `platform_type` | Modules |
1054
- |---|---|
1055
- | `backend` | `java-spring`, `golang`, `dotnet`, `php-laravel`, `context-engineering` |
1056
- | `web-frontend` | `react`, `nextjs`, `vue`, `nuxt`, `angular` |
1057
- | `mobile` | `flutter`, `react-native`, `ios-swiftui`, `android-compose` |
1058
-
1059
- Nếu `tech_stack.module` rỗng hoặc không nhận diện được → set `platform_type = "unknown"` và gắn cờ ⚠️ trong recap Bước 7.
1060
-
1061
- Hai biến này (`active_module`, `platform_type`) là 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).
1062
-
1063
- ---
1064
-
1065
- ## Bước 6.7 — [GUARDRAILS] Nạp Project Lessons (có điều kiện)
1066
-
1067
- *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`
1068
- hoặc được chấp nhận trong `/review-code`, `/fix-bug`, `/debug`.*
1069
-
1070
- Phân giải path file lessons:
1071
- - Dùng `paths.lessons_file` nếu được set (có thể bị service override ở chế độ umbrella, Bước 1.6)
1072
- - Else mặc định `specs/domain-knowledge/lessons-learned.md`
1073
- - Ở 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`
1074
-
1075
- Nếu file tồn tại, đọc và lưu TẤT CẢ lesson làm **GUARDRAIL ĐANG HOẠT ĐỘNG** cho phiên:
1076
- - Coi **Rule** của mỗi lesson là ràng buộc cứng — cùng mức ưu tiên với coding standards trong CLAUDE.md (Bước 3).
1077
- - 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 có `category` khớp lệnh hiện tại VÀ `scope` khớp target (domain / file).
1078
- - Nếu output sinh ra vi phạm một lesson → sửa **trước khi** trình bày, và ghi rõ lesson nào (`L-NNN`) đã được áp dụng.
1079
-
1080
- Nếu file không tồn tại → bỏ qua âm thầm (chưa có lesson nào được ghi nhận).
1081
-
1082
- ---
1083
-
1084
- ## Bước 7 — [RECAP] Working Memory Recap (chống lost-in-middle)
1085
-
1086
- Sau khi nạp toàn bộ context, tổng hợp và xuất một khối tóm tắt gọn.
1087
- 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
1088
- (hiệu ứng recency — tươi mới nhất trong bộ nhớ làm việc khi bắt đầu task).
1089
-
1090
- Xuất đúng khối này:
1091
- ```
1092
- [CTX LOADED]
1093
- Stack : {language} / {framework} / {database}
1094
- Platform : {active_module} ({platform_type})
1095
- Layers : {thứ tự layer từ CLAUDE.md §2 đã merge, vd: Controller → Facade → Service → Repository}
1096
- CLAUDE.md : {root + {service_root} | chỉ {service_root} | chỉ root | ⚠️ service overlay THIẾU — dùng root | missing}
1097
- Ticket : {ticket_prefix}-
1098
- Dict : {loaded — N canonical terms, M banned terms | missing}
1099
- Entities : {loaded — EntityA, EntityB, EntityC | missing}
1100
- Lessons : {loaded — N guardrails | chưa có}
1101
- Service : {active_service} ({active_service_module}) | single-service
1102
- Svc Root : {service_root} — đã nạp conventions + trace_dir từ config service | —
1103
- Status : {FULL | PARTIAL — thiếu: CLAUDE.md / business-dict / core-entities | MINIMAL}
1104
- ```
1105
-
1106
- Nếu bất kỳ file CRITICAL nào thiếu (CLAUDE.md), gắn cờ rõ ràng để người dùng quyết định có tiếp tục hay không.
1107
-
1108
- ---
1109
-
1110
- ## Hoàn tất nạp Context
1111
-
1112
- Sau khi hoàn thành tất cả các bước, bạn đã nạp:
1113
- - Định danh dự án, tech stack, convention module
1114
- - Quy tắc kiến trúc và thứ tự layer ← **[CRITICAL — giữ trong bộ nhớ làm việc]**
1115
- - Coding standards và quy tắc đặt tên ← **[CRITICAL — giữ trong bộ nhớ làm việc]**
1116
- - Quy tắc bảo vệ dữ liệu (pattern file nhạy cảm không bao giờ truy cập)
1117
- - Quy tắc thuật ngữ kèm danh sách banned term ← **[DOMAIN — áp dụng cho mọi từ được sinh ra]**
1118
- - Entity catalog (tên field, kiểu, invariant) ← **[DOMAIN — dùng khi sinh code]**
1119
- - Toàn bộ path đã cấu hình
1120
-
1121
- Tiếp tục sang bước kế tiếp của lệnh đang gọi.
1122
-
1123
-
1124
- Đọc `conventions.service_run` từ project context đã nạp để tìm port.
1125
- Default: `http://localhost:8080`
1126
-
1127
- Kiểm tra service đang chạy:
1128
- ```bash
1129
- curl -s http://localhost:{port}/health
1130
- # or /actuator/health for Spring Boot
1131
- ```
1132
-
1133
- Nếu chưa chạy: "Service is not running. Start it with: `{RUN_COMMAND}` from your project root."
1134
-
1135
- ### Phase 2 — Identify Endpoints
1136
-
1137
- Từ UC-ID → tìm Controller có `@trace.implements={UC-ID}`:
1138
- - Liệt kê: method, path, auth/role bắt buộc
1139
-
1140
- ### Phase 3 — Get Auth Token (nếu cần)
1141
-
1142
- Nếu endpoint yêu cầu auth, hỏi:
1143
- ```
1144
- This endpoint requires authentication. Options:
1145
- 1. Paste your Bearer token (from Postman / browser DevTools / test login)
1146
- 2. Use a test/dev token from your local config
1147
- 3. Skip auth — only test public endpoints
1148
- ```
1149
-
1150
- ### Phase 4 — Run Smoke Test
1151
-
1152
- ```bash
1153
- # GET
1154
- curl -s -X GET "http://localhost:{port}/v1/{resource}?page=0&size=5" \
1155
- -H "Authorization: Bearer {token}" | {JSON_FORMATTER}
1156
-
1157
- # POST
1158
- curl -s -X POST "http://localhost:{port}/v1/{resource}" \
1159
- -H "Authorization: Bearer {token}" \
1160
- -H "Content-Type: application/json" \
1161
- -d '{"field1": "test_value"}'
1162
- ```
1163
-
1164
- ### Phase 5 — Interpret Results
1165
-
1166
- | Result | Ý nghĩa |
1167
- |--------|---------|
1168
- | 200/201 + đúng data | ✅ OK |
1169
- | 200 + sai data | ⚠️ Logic bug → dùng `/debug` |
1170
- | 400 | Request body sai → kiểm tra field bắt buộc |
1171
- | 401 | Token hết hạn hoặc sai realm |
1172
- | 403 | Sai role → kiểm tra auth config |
1173
- | 500 + stacktrace | Server error → dán vào `/debug` |
1174
- | Connection refused | Service chưa chạy hoặc sai port |
1175
-
1176
- Nếu có lỗi trong log:
1177
- ```bash
1178
- tail -n 100 {LOG_FILE_PATH}
1179
- ```
1180
-
1181
- ### Output
1182
-
1183
- ```
1184
- /dev-smoke-test Report — {UC-ID}
1185
- Tested at: {datetime}
1186
- Base URL: http://localhost:{port}
1187
-
1188
- ## Endpoints Tested
1189
- | Method | Path | Status | Result |
1190
- |--------|------|--------|--------|
1191
- | GET | /v1/{resource} | 200 ✅ | 5 records returned |
1192
- | POST | /v1/{resource} | 201 ✅ | Created id=42 |
1193
-
1194
- ## Issues Found
1195
- {describe any failures}
1196
- ```
1197
-
1198
- # Report Footer — Định dạng output chuẩn cho mọi lệnh
1199
-
1200
- Mọi report của lệnh phải kết thúc bằng section footer chuẩn này.
1201
-
1202
- ## Status Badge
1203
-
1204
- Chọn một theo kết quả:
1205
- - `✅ Complete` — mọi bước thành công, không có vấn đề
1206
- - `❌ Failed` — lệnh không hoàn thành được do lỗi chặn
1207
- - `⚠️ Warnings` — hoàn thành nhưng có vấn đề không chặn, nên review lại
1208
-
1209
- ## Output Artifacts
1210
-
1211
- Liệt kê mọi file được tạo hoặc sửa bởi lệnh này:
1212
- ```
1213
- Output Artifacts:
1214
- {created|updated} {file-path} ({mô tả ngắn})
1215
- {created|updated} {file-path} ({mô tả ngắn})
1216
- ```
1217
-
1218
- Nếu không ghi file nào (vd: lệnh review hoặc phân tích) → ghi `Output Artifacts: none (read-only)`.
1219
-
1220
- ## Pipeline Position
1221
-
1222
- In một sơ đồ pipeline một dòng, đánh dấu phase của lệnh HIỆN TẠI bằng `◀ bạn ở đây`,
1223
- để người dùng luôn thấy lệnh này nằm ở đâu trong luồng end-to-end:
1224
-
1225
- ```
1226
- Discovery → PRD → [Design Spec] → BDD → Tech Design → Code → Dev Self-Check → QC → Trace Audit
1227
- ```
1228
-
1229
- Tìm lệnh hiện tại trong bảng phase dưới đây và đánh dấu **phase của nó** trong sơ đồ trên:
1230
-
1231
- | Phase | Commands |
1232
- |-------|----------|
1233
- | Discovery | `/define-product` |
1234
- | PRD | `/generate-prd` · `/refine-prd` · `/review-context` (PRD) |
1235
- | Design Spec | `/generate-design-spec` |
1236
- | BDD | `/generate-bdd` · `/review-context` (BDD) |
1237
- | Tech Design | `/generate-tech-docs` · `/map-testids` · `/review-tech-docs` |
1238
- | Code | `/generate-code` · `/review-code` |
1239
- | Dev Self-Check | `/dev-gen-test` · `/dev-run-test` · `/dev-smoke-test` |
1240
- | QC | `/qc-analyze` · `/qc-plan` · `/qc-design-test` · `/qc-review` · `/qc-run-test` · `/qc-report` |
1241
- | Trace Audit | `/validate-traces` |
1242
-
1243
- Với **lệnh review**, thêm vòng review 3 bước và đánh dấu bước hiện tại, vd:
1244
- `Vòng review: [① phân tích ◀] → ② Review Board → ③ --resume`.
1245
-
1246
- **Lệnh xuyên suốt** (`/sync`, `/update-framework`, `/fix-bug`, `/debug`, `/learn`,
1247
- `/report-bug`, `/propose-scenario`, `/generate-spec-manifest`) nằm ngoài pipeline tuyến tính —
1248
- **bỏ hẳn dòng Pipeline** cho các lệnh này (đừng cố nhét chúng vào sơ đồ).
1249
-
1250
- ## Gợi ý lệnh tiếp theo
1251
-
1252
- Gợi ý lệnh kế tiếp hợp lý theo phase của workflow:
1253
-
1254
- | Lệnh hiện tại | Gợi ý lệnh tiếp theo |
1255
- |-------------------------|-----------------------------------------------|
1256
- | /setup-ai-first | `/define-product` để bắt đầu feature đầu tiên |
1257
- | /define-product | `/generate-prd {product-definition-file}` |
1258
- | /generate-prd | `/refine-prd {prd-file}` rồi `/review-context {prd-file}` |
1259
- | /refine-prd | Mở Review Board → cập nhật PRD → `/review-context {prd-file}` |
1260
- | /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 |
1261
- | /generate-design-spec | Designer review → xác nhận link Figma → PO + Designer sign-off → `/generate-bdd {prd-file}` |
1262
- | /generate-bdd | `/review-context {feature-file}` để kiểm tra độ phủ |
1263
- | /review-context (BDD) | `/generate-tech-docs {UC-ID}` nếu APPROVED; sinh lại nếu NEEDS_FIX |
1264
- | /qc-analyze | `/qc-plan {UC-ID}` (xử lý các gap blocker 🔴 trước) |
1265
- | /qc-plan | `/qc-design-test {UC-ID}` |
1266
- | /qc-design-test | `/qc-review {UC-ID}` (review test-case) |
1267
- | /qc-review (test-case) | `/qc-run-test {UC-ID}` nếu APPROVED; sửa TC nếu NEEDS_FIX |
1268
- | /qc-run-test | `/qc-report {UC-ID}` rồi `/qc-review {UC-ID}` (review script) |
1269
- | /qc-review (script) | `/qc-report {UC-ID}` rồi tạo PR nếu APPROVED |
1270
- | /qc-report | `/validate-traces {UC-ID}` để làm mới Living Docs (qc_status) |
1271
- | /generate-tech-docs | `/review-tech-docs {tech-design-file}` |
1272
- | /review-tech-docs | `/generate-code {feature-file}` nếu APPROVED; sửa doc nếu NEEDS_FIX |
1273
- | /generate-code | Lần gen đầu → `/review-code {UC-ID}`; gen lại → `/dev-gen-test {UC-ID}` |
1274
- | /dev-gen-test | `/dev-run-test {UC-ID}` |
1275
- | /dev-run-test (passing) | `/review-code {UC-ID}` |
1276
- | /dev-run-test (failing) | `/fix-bug {ticket-id}` hoặc `/debug {error}` |
1277
- | /review-code | `/dev-smoke-test {UC-ID}` hoặc tạo PR |
1278
- | /dev-smoke-test | Tạo PR và link tới ticket |
1279
- | /validate-traces | DRIFT/UNTRACKED → `/generate-code {UC-ID}`; GAP → `/dev-gen-test {UC-ID}`; tất cả OK → tạo PR |
1280
- | /fix-bug | Tạo PR và link tới ticket |
1281
- | /debug | `/fix-bug {ticket-id}` nếu cần sửa |
1282
- | /report-bug | Gửi cho dev (`/fix-bug {BUG-ID}`); nếu thiếu coverage → `/propose-scenario {UC-ID}` |
1283
- | /propose-scenario | Báo PO/Dev review proposal trong `feedback/bdd-proposals/` |
1284
- | /learn | Tiếp tục làm việc — lesson áp dụng ở lệnh kế tiếp |
1285
- | /sync | `/validate-traces` để xem độ phủ đầy đủ; xử lý mọi `📥 tester feedback` được nêu |
1286
- | /update-framework | Review `git diff .agent/`, commit; `/sync` để đồng bộ nội dung dự án |
1287
-
1288
- Định dạng footer như sau:
1289
- ```
1290
- ---
1291
- Status : {badge}
1292
- {khối Output Artifacts}
1293
- Pipeline : Discovery → PRD → [BDD ◀ bạn ở đây] → Tech Design → Code → Dev Self-Check → QC → Trace Audit
1294
- (lệnh review) Vòng review: [① phân tích ◀] → ② Review Board → ③ --resume
1295
- Next : {lệnh gợi ý kèm ví dụ tham số}
1296
- ```
1297
- *(Bỏ dòng `Pipeline` cho các lệnh xuyên suốt liệt kê ở trên.)*
1298
-
16
+ ## /dev-smoke-test Smoke test service/app đang chạy
17
+ **Đọc và tuân theo `commands/dev-smoke-test.md`** với cùng `$ARGUMENTS`.
18
+ (Command lo: flow theo từng platform — backend curl/health · web E2E Playwright/Cypress · mobile device/emulator · LLM pipeline.)