@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.
- package/bin/index.js +12 -1
- package/commands/debug.md +436 -436
- package/commands/debug.tmpl +111 -111
- package/commands/define-product.md +350 -345
- package/commands/define-product.tmpl +69 -64
- package/commands/dev-gen-test.md +365 -365
- package/commands/dev-gen-test.tmpl +63 -63
- package/commands/dev-run-test.md +376 -376
- package/commands/dev-run-test.tmpl +74 -74
- package/commands/dev-smoke-test.md +341 -341
- package/commands/dev-smoke-test.tmpl +60 -60
- package/commands/fix-bug.md +403 -403
- package/commands/fix-bug.tmpl +78 -78
- package/commands/generate-bdd.md +513 -513
- package/commands/generate-bdd.tmpl +211 -211
- package/commands/generate-code.md +481 -483
- package/commands/generate-code.tmpl +179 -181
- package/commands/generate-design-spec.md +497 -497
- package/commands/generate-design-spec.tmpl +220 -220
- package/commands/generate-prd.md +452 -400
- package/commands/generate-prd.tmpl +50 -200
- package/commands/generate-spec-manifest.md +340 -340
- package/commands/generate-spec-manifest.tmpl +59 -59
- package/commands/generate-tech-docs.md +365 -365
- package/commands/generate-tech-docs.tmpl +84 -84
- package/commands/learn.md +347 -347
- package/commands/learn.tmpl +22 -22
- package/commands/map-testids.md +322 -322
- package/commands/map-testids.tmpl +41 -41
- package/commands/propose-scenario.md +335 -335
- package/commands/propose-scenario.tmpl +54 -54
- package/commands/qc-analyze.md +323 -324
- package/commands/qc-analyze.tmpl +42 -43
- package/commands/qc-design-test.md +304 -304
- package/commands/qc-design-test.tmpl +23 -23
- package/commands/qc-plan.md +297 -297
- package/commands/qc-plan.tmpl +16 -16
- package/commands/qc-report.md +302 -302
- package/commands/qc-report.tmpl +21 -21
- package/commands/qc-review.md +298 -298
- package/commands/qc-review.tmpl +17 -17
- package/commands/qc-run-test.md +337 -337
- package/commands/qc-run-test.tmpl +35 -35
- package/commands/refine-prd.md +428 -430
- package/commands/refine-prd.tmpl +62 -62
- package/commands/report-bug.md +351 -351
- package/commands/report-bug.tmpl +70 -70
- package/commands/review-code.md +364 -364
- package/commands/review-code.tmpl +39 -39
- package/commands/review-context.md +578 -580
- package/commands/review-context.tmpl +212 -212
- package/commands/review-tech-docs.md +427 -427
- package/commands/review-tech-docs.tmpl +146 -146
- package/commands/setup-ai-first.md +239 -239
- package/commands/setup-ai-first.tmpl +133 -133
- package/commands/sync.md +145 -145
- package/commands/sync.tmpl +93 -93
- package/commands/update-framework.md +88 -88
- package/commands/update-framework.tmpl +36 -36
- package/commands/validate-traces.md +381 -381
- package/commands/validate-traces.tmpl +100 -100
- package/core/FRAMEWORK_VERSION +1 -1
- package/core/commands/debug.md +436 -436
- package/core/commands/define-product.md +350 -345
- package/core/commands/dev-gen-test.md +365 -365
- package/core/commands/dev-run-test.md +376 -376
- package/core/commands/dev-smoke-test.md +341 -341
- package/core/commands/fix-bug.md +403 -403
- package/core/commands/generate-bdd.md +513 -513
- package/core/commands/generate-code.md +481 -483
- package/core/commands/generate-design-spec.md +497 -497
- package/core/commands/generate-prd.md +452 -400
- package/core/commands/generate-spec-manifest.md +340 -340
- package/core/commands/generate-tech-docs.md +365 -365
- package/core/commands/learn.md +347 -347
- package/core/commands/map-testids.md +322 -322
- package/core/commands/propose-scenario.md +335 -335
- package/core/commands/qc-analyze.md +323 -324
- package/core/commands/qc-design-test.md +304 -304
- package/core/commands/qc-plan.md +297 -297
- package/core/commands/qc-report.md +302 -302
- package/core/commands/qc-review.md +298 -298
- package/core/commands/qc-run-test.md +337 -337
- package/core/commands/refine-prd.md +428 -430
- package/core/commands/report-bug.md +351 -351
- package/core/commands/review-code.md +364 -364
- package/core/commands/review-context.md +578 -580
- package/core/commands/review-tech-docs.md +427 -427
- package/core/commands/setup-ai-first.md +239 -239
- package/core/commands/sync.md +145 -145
- package/core/commands/update-framework.md +88 -88
- package/core/commands/validate-traces.md +381 -381
- package/core/skills/code/SKILL.md +389 -389
- package/core/skills/debug/SKILL.md +391 -391
- package/core/skills/design-spec/SKILL.md +318 -318
- package/core/skills/discovery/SKILL.md +7 -547
- package/core/skills/prd/SKILL.md +298 -394
- package/core/skills/setup-ai-first/SKILL.md +80 -80
- package/core/skills/spec/SKILL.md +178 -178
- package/core/skills/test/SKILL.md +604 -604
- package/core/steps/capture-lesson.md +44 -44
- package/core/steps/context-loader.md +175 -175
- package/core/steps/gate.md +54 -54
- package/core/steps/report-footer.md +52 -52
- package/core/steps/review-fanout.md +85 -87
- package/core/steps/spawn-agent.md +45 -45
- package/core/steps/trace-mirror.md +21 -21
- package/core/templates/architecture.template.md +37 -37
- package/core/templates/design-spec.template.md +77 -77
- package/core/templates/platform-guide.template.md +47 -47
- package/core/templates/prd.template.md +107 -232
- package/core/templates/product-definition.template.md +101 -88
- package/core/templates/project-context.yaml +2 -2
- package/docs/01-getting-started/core-concepts.md +1 -1
- package/docs/01-getting-started/quickstart.md +7 -7
- package/docs/02-guides/developer/bdd-and-trace.md +1 -1
- package/docs/02-guides/developer/scenarios.md +5 -5
- package/docs/02-guides/product-owner/handoff-checklist.md +1 -1
- package/docs/02-guides/product-owner/scenarios.md +23 -23
- package/docs/02-guides/tester/bug-reporting.md +2 -2
- package/docs/02-guides/tester/reading-specs.md +2 -2
- package/docs/02-guides/tester/scenarios.md +1 -1
- package/docs/02-guides/tester/spec-manifest.md +3 -3
- package/docs/02-guides/tester/workflow.md +1 -1
- package/docs/03-concepts/architecture.md +3 -3
- package/docs/03-concepts/pipeline.md +3 -3
- package/docs/04-operations/publishing.md +20 -3
- package/docs/04-operations/sync-and-update.md +5 -5
- package/docs/05-reference/command-cheatsheet.md +2 -2
- package/docs/05-reference/commands.md +8 -8
- package/package.json +1 -1
- package/scripts/migrate-specs.js +5 -3
- package/scripts/rename-prd-files.js +174 -0
- package/skills/code/SKILL.md +389 -389
- package/skills/code/SKILL.tmpl +56 -56
- package/skills/debug/SKILL.md +391 -391
- package/skills/debug/SKILL.tmpl +60 -60
- package/skills/design-spec/SKILL.md +318 -318
- package/skills/design-spec/SKILL.tmpl +37 -37
- package/skills/discovery/SKILL.md +7 -547
- package/skills/discovery/SKILL.tmpl +7 -140
- package/skills/prd/SKILL.md +298 -394
- package/skills/prd/SKILL.tmpl +40 -151
- package/skills/setup-ai-first/SKILL.md +80 -80
- package/skills/setup-ai-first/SKILL.tmpl +28 -28
- package/skills/spec/SKILL.md +178 -178
- package/skills/spec/SKILL.tmpl +20 -20
- package/skills/test/SKILL.md +604 -604
- package/skills/test/SKILL.tmpl +44 -44
- package/steps/capture-lesson.md +44 -44
- package/steps/context-loader.md +175 -175
- package/steps/gate.md +54 -54
- package/steps/report-footer.md +52 -52
- package/steps/review-fanout.md +85 -87
- package/steps/spawn-agent.md +45 -45
- package/steps/trace-mirror.md +21 -21
- package/templates/architecture.template.md +37 -37
- package/templates/design-spec.template.md +77 -77
- package/templates/platform-guide.template.md +47 -47
- package/templates/prd.template.md +107 -232
- package/templates/product-definition.template.md +101 -88
- package/templates/project-context.yaml +2 -2
|
@@ -1,145 +1,145 @@
|
|
|
1
|
-
# /generate-code —
|
|
1
|
+
# /generate-code — Sinh Implementation Code
|
|
2
2
|
|
|
3
3
|
## Gate
|
|
4
|
-
# Gate —
|
|
4
|
+
# Gate — Quy trình vào chuẩn cho mọi lệnh
|
|
5
5
|
|
|
6
|
-
|
|
6
|
+
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ó.
|
|
7
7
|
|
|
8
|
-
##
|
|
8
|
+
## Bước 0 — Kiểm tra chế độ Sub-Agent
|
|
9
9
|
|
|
10
|
-
|
|
10
|
+
Trước tiên, kiểm tra xem `$ARGUMENTS` có phải là payload JSON từ một orchestrator hay không:
|
|
11
11
|
|
|
12
|
-
1.
|
|
13
|
-
2.
|
|
14
|
-
- **
|
|
15
|
-
-
|
|
16
|
-
-
|
|
17
|
-
-
|
|
18
|
-
-
|
|
19
|
-
-
|
|
20
|
-
3.
|
|
12
|
+
1. Thử parse `$ARGUMENTS` dưới dạng JSON.
|
|
13
|
+
2. Nếu parse thành công **và** chứa `"_agent_mode": true`:
|
|
14
|
+
- **Bỏ qua hoàn toàn Bước 1, 2 và 3 của Gate này.**
|
|
15
|
+
- Đặt target file = `payload.target_file`
|
|
16
|
+
- Đặt loaded context = `payload.context` (KHÔNG chạy context-loader.md)
|
|
17
|
+
- Đặt phạm vi UC = `payload.uc_id` (chỉ xử lý UC này)
|
|
18
|
+
- Đặt line range = `payload.uc_section` (chỉ đọc đúng section đó của PRD)
|
|
19
|
+
- Đi thẳng tới phần logic riêng của lệnh.
|
|
20
|
+
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).
|
|
21
21
|
|
|
22
|
-
##
|
|
22
|
+
## Bước 0-B — Kiểm tra Model
|
|
23
23
|
|
|
24
|
-
*
|
|
24
|
+
*Bỏ qua bước này nếu `_agent_mode: true` (sub-agent — orchestrator đã kiểm tra rồi).*
|
|
25
25
|
|
|
26
|
-
|
|
27
|
-
|
|
26
|
+
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.
|
|
27
|
+
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.
|
|
28
28
|
|
|
29
|
-
|
|
29
|
+
Hiển thị và chờ phản hồi:
|
|
30
30
|
|
|
31
31
|
```
|
|
32
32
|
⚙️ MODEL CHECK
|
|
33
33
|
──────────────────────────────────────────────────────────────────
|
|
34
|
-
Recommended : claude-opus-4 (
|
|
35
|
-
Why needed :
|
|
36
|
-
|
|
34
|
+
Recommended : claude-opus-4 (hoặc model Opus mới nhất)
|
|
35
|
+
Why needed : Phân tích spec, review kiến trúc, sinh code đòi hỏi
|
|
36
|
+
suy luận sâu. Model nhỏ hơn dễ bỏ sót edge case.
|
|
37
37
|
|
|
38
|
-
|
|
39
|
-
• Settings → Model →
|
|
40
|
-
•
|
|
38
|
+
Cách đổi trong Claude Code:
|
|
39
|
+
• Settings → Model → chọn "claude-opus"
|
|
40
|
+
• hoặc: /model → chọn claude-opus
|
|
41
41
|
|
|
42
|
-
|
|
43
|
-
Y —
|
|
44
|
-
S —
|
|
42
|
+
Đang chạy claude-opus?
|
|
43
|
+
Y — đúng, đang dùng claude-opus → tiếp tục
|
|
44
|
+
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)
|
|
45
45
|
──────────────────────────────────────────────────────────────────
|
|
46
46
|
```
|
|
47
47
|
|
|
48
|
-
- "Y" →
|
|
49
|
-
- "S" →
|
|
50
|
-
- "N"
|
|
48
|
+
- "Y" → tiếp tục sang Bước 1.
|
|
49
|
+
- "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).
|
|
50
|
+
- "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."
|
|
51
51
|
|
|
52
|
-
##
|
|
52
|
+
## Bước 1 — Xác định Target File
|
|
53
53
|
|
|
54
|
-
1.
|
|
55
|
-
2.
|
|
56
|
-
- **BDD
|
|
57
|
-
- **PRD
|
|
58
|
-
- **tech-docs
|
|
59
|
-
- **design-spec
|
|
54
|
+
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.
|
|
55
|
+
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/`):
|
|
56
|
+
- **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 đó.
|
|
57
|
+
- **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.)*
|
|
58
|
+
- **Lệnh tech-docs**: `{specs_dir}/{domain}/*/tech-docs/{UC-ID}*-tech-design*.md`.
|
|
59
|
+
- **Lệnh design-spec**: `{specs_dir}/{domain}/*/design-spec/{TICKET-ID}*.md`.
|
|
60
60
|
|
|
61
|
-
|
|
62
|
-
3.
|
|
63
|
-
-
|
|
64
|
-
-
|
|
65
|
-
-
|
|
61
|
+
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.
|
|
62
|
+
3. Nếu `$ARGUMENTS` rỗng hoặc không tìm thấy file khớp:
|
|
63
|
+
- 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).
|
|
64
|
+
- 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)"
|
|
65
|
+
- Chờ người dùng chọn rồi mới tiếp tục.
|
|
66
66
|
|
|
67
|
-
##
|
|
67
|
+
## Bước 2 — Chạy Context Loader
|
|
68
68
|
|
|
69
|
-
|
|
70
|
-
|
|
69
|
+
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`.
|
|
70
|
+
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.
|
|
71
71
|
|
|
72
|
-
##
|
|
72
|
+
## Bước 3 — CHECKPOINT
|
|
73
73
|
|
|
74
|
-
|
|
74
|
+
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:
|
|
75
75
|
|
|
76
76
|
```
|
|
77
77
|
CHECKPOINT
|
|
78
78
|
-----------
|
|
79
79
|
Target : {resolved file path}
|
|
80
|
-
Project : {project.name
|
|
80
|
+
Project : {project.name từ project-context.yaml}
|
|
81
81
|
Tech stack : {language} / {framework}
|
|
82
|
-
Module : {module
|
|
83
|
-
Domains : {
|
|
82
|
+
Module : {module nếu có, else "not configured"}
|
|
83
|
+
Domains : {danh sách domain, ngăn cách bởi dấu phẩy}
|
|
84
84
|
|
|
85
|
-
|
|
85
|
+
Tiếp tục? (Y/N)
|
|
86
86
|
```
|
|
87
87
|
|
|
88
|
-
|
|
89
|
-
- "Y" →
|
|
90
|
-
- "N" →
|
|
88
|
+
Chờ người dùng trả lời rõ ràng "Y" hoặc "N" rồi mới tiếp tục.
|
|
89
|
+
- "Y" → tiếp tục sang các bước riêng của lệnh bên dưới.
|
|
90
|
+
- "N" → dừng lại và hỏi người dùng muốn thay đổi gì.
|
|
91
91
|
|
|
92
92
|
|
|
93
|
-
*
|
|
93
|
+
*Lưu ý: Với lệnh này, target ở Bước 1 là một file `.feature` hoặc UC-ID. Nếu `$ARGUMENTS` là UC-ID, tìm file feature khớp bằng cách glob `{paths.specs_dir}/{domain}/*/bdd/**/{UC-ID}*.feature` (wildcard `*` cho prd-slug chưa biết, `**` đệ quy để phủ các thư mục con platform `web/`·`app/`·`system/`); lấy `domain` + `prd_slug` từ path khớp. Cũng kiểm tra `{paths.trace_dir}/{domain}/{prd-slug}/{UC-ID}.tsv` tìm drift (new vs drifted vs synced).*
|
|
94
94
|
|
|
95
95
|
## Context
|
|
96
|
-
# Context Loader —
|
|
96
|
+
# Context Loader — Nạp toàn bộ context dự án
|
|
97
97
|
|
|
98
|
-
|
|
98
|
+
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.
|
|
99
99
|
|
|
100
|
-
**
|
|
101
|
-
-
|
|
102
|
-
-
|
|
103
|
-
-
|
|
104
|
-
-
|
|
105
|
-
-
|
|
100
|
+
**Hướng dẫn ưu tiên (chống lost-in-middle):**
|
|
101
|
+
- Bước 1–2 là PROJECT-CONFIG — nạp trước, phân giải mọi path và metadata.
|
|
102
|
+
- 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.
|
|
103
|
+
- Bước 4 là SAFETY — quy tắc bảo vệ dữ liệu, thực thi ngầm suốt cả phiên.
|
|
104
|
+
- Bước 5–6 là DOMAIN KNOWLEDGE — thuật ngữ và định nghĩa entity.
|
|
105
|
+
- 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.
|
|
106
106
|
|
|
107
107
|
---
|
|
108
108
|
|
|
109
|
-
##
|
|
109
|
+
## Bước 1 — [PROJECT-CONFIG] Nạp project-context.yaml
|
|
110
110
|
|
|
111
|
-
|
|
111
|
+
Đọc `.agent/project-context.yaml`. Trích xuất và lưu:
|
|
112
112
|
|
|
113
113
|
**Tech Stack:**
|
|
114
|
-
- `tech_stack.language` →
|
|
115
|
-
- `tech_stack.framework` →
|
|
116
|
-
- `tech_stack.build_tool` → build tool (
|
|
117
|
-
- `tech_stack.test_framework` → test framework (
|
|
118
|
-
- `tech_stack.database` → database (
|
|
119
|
-
- `tech_stack.module` →
|
|
114
|
+
- `tech_stack.language` → ngôn ngữ đang dùng (vd: Java 17, TypeScript, C#, Go)
|
|
115
|
+
- `tech_stack.framework` → framework đang dùng (vd: Spring Boot 3.2, Angular 17, .NET 8)
|
|
116
|
+
- `tech_stack.build_tool` → build tool (vd: Maven, npm, dotnet, go)
|
|
117
|
+
- `tech_stack.test_framework` → test framework (vd: JUnit 5 + Mockito, Jest, xUnit)
|
|
118
|
+
- `tech_stack.database` → database (vd: PostgreSQL, MySQL, MongoDB)
|
|
119
|
+
- `tech_stack.module` → module profile đang dùng (vd: java-spring, angular, dotnet, golang, context-engineering)
|
|
120
120
|
|
|
121
121
|
**Conventions:**
|
|
122
|
-
- `conventions.build_command` →
|
|
123
|
-
- `conventions.test_command` →
|
|
124
|
-
- `conventions.service_run` →
|
|
125
|
-
- `conventions.ticket_prefix` → ticket ID
|
|
122
|
+
- `conventions.build_command` → cách compile/build
|
|
123
|
+
- `conventions.test_command` → cách chạy test
|
|
124
|
+
- `conventions.service_run` → cách khởi động service
|
|
125
|
+
- `conventions.ticket_prefix` → tiền tố ticket ID (vd: PROJ, FEAT, UC)
|
|
126
126
|
|
|
127
127
|
**Domains:**
|
|
128
|
-
- `domains` →
|
|
129
|
-
|
|
130
|
-
**Paths (
|
|
131
|
-
- `paths.specs_dir` → spec
|
|
132
|
-
- `paths.refinement_dir` → findings/review
|
|
133
|
-
- `paths.qc_dir` → QC automation
|
|
134
|
-
- `paths.qc_skills_dir` →
|
|
135
|
-
- `paths.product_definitions_dir` → product
|
|
136
|
-
- `paths.domain_knowledge_dir` → domain knowledge
|
|
137
|
-
- `paths.business_dictionary` → path
|
|
138
|
-
- `paths.core_entities` → path
|
|
139
|
-
- `paths.tech_docs_dir` →
|
|
140
|
-
- `paths.trace_dir` →
|
|
141
|
-
|
|
142
|
-
|
|
128
|
+
- `domains` → danh sách các business domain đang hoạt động
|
|
129
|
+
|
|
130
|
+
**Paths (nếu có):**
|
|
131
|
+
- `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)
|
|
132
|
+
- `paths.refinement_dir` → thư mục output cho findings/review
|
|
133
|
+
- `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}/`)
|
|
134
|
+
- `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 đè)
|
|
135
|
+
- `paths.product_definitions_dir` → gốc product definition
|
|
136
|
+
- `paths.domain_knowledge_dir` → gốc domain knowledge
|
|
137
|
+
- `paths.business_dictionary` → path tới business-dictionary.md
|
|
138
|
+
- `paths.core_entities` → path tới core-entities.md
|
|
139
|
+
- `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/`)
|
|
140
|
+
- `paths.trace_dir` → thư mục trạng thái trace; cấu trúc: `.trace/{domain}/{prd-slug}/{UC-ID}.tsv`
|
|
141
|
+
|
|
142
|
+
Nếu không có section `paths`, dùng các giá trị mặc định:
|
|
143
143
|
- `specs_dir` = `specs`
|
|
144
144
|
- `refinement_dir` = `.agent/review`
|
|
145
145
|
- `qc_dir` = `docs`
|
|
@@ -151,184 +151,184 @@ If `paths` section is absent, use these defaults:
|
|
|
151
151
|
- `tech_docs_dir` = `specs`
|
|
152
152
|
- `trace_dir` = `.trace`
|
|
153
153
|
|
|
154
|
-
|
|
154
|
+
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.
|
|
155
155
|
|
|
156
|
-
**
|
|
157
|
-
- `specs/payment/create-invoice/
|
|
158
|
-
- `specs/payment/create-invoice/bdd/system/PAY-UC1.feature` → `prd_slug = create-invoice` *(
|
|
159
|
-
- `specs/payment/create-invoice/bdd/web/PAY-UC1.feature` → `prd_slug = create-invoice` *(
|
|
160
|
-
- `specs/payment/create-invoice/tech-docs/PAY-UC1-tech-design.md` → `prd_slug = create-invoice` *(
|
|
156
|
+
**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ụ:
|
|
157
|
+
- `specs/payment/create-invoice/PAY01-create-invoice.md` → `prd_slug = create-invoice`
|
|
158
|
+
- `specs/payment/create-invoice/bdd/system/PAY-UC1.feature` → `prd_slug = create-invoice` *(KHÔNG phải `system`)*
|
|
159
|
+
- `specs/payment/create-invoice/bdd/web/PAY-UC1.feature` → `prd_slug = create-invoice` *(KHÔNG phải `web`)*
|
|
160
|
+
- `specs/payment/create-invoice/tech-docs/PAY-UC1-tech-design.md` → `prd_slug = create-invoice` *(KHÔNG phải `tech-docs`)*
|
|
161
161
|
- `specs/payment/create-invoice/design-spec/PAY-design-spec-web.md` → `prd_slug = create-invoice`
|
|
162
162
|
|
|
163
|
-
|
|
163
|
+
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ừ đó.
|
|
164
164
|
|
|
165
|
-
|
|
165
|
+
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.
|
|
166
166
|
|
|
167
167
|
---
|
|
168
168
|
|
|
169
|
-
##
|
|
169
|
+
## Bước 1.5 — [SERVICE ROUTING] Phân giải path service (chế độ umbrella)
|
|
170
170
|
|
|
171
|
-
*
|
|
171
|
+
*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.*
|
|
172
172
|
|
|
173
|
-
|
|
173
|
+
Nếu có section `services`:
|
|
174
174
|
|
|
175
|
-
**1.
|
|
176
|
-
-
|
|
177
|
-
-
|
|
178
|
-
*(
|
|
179
|
-
-
|
|
175
|
+
**1. Phát hiện active domain** (theo thứ tự ưu tiên):
|
|
176
|
+
- Đọc `@trace.domain` từ frontmatter của target file (nếu Gate đã nạp một target file)
|
|
177
|
+
- 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.
|
|
178
|
+
*(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`)*
|
|
179
|
+
- Nếu `$ARGUMENTS` chứa một path, trích xuất segment domain sau `specs_dir`
|
|
180
180
|
|
|
181
|
-
**2. Route
|
|
182
|
-
- Override `paths.specs_dir` → `services.{domain}.specs_dir` — **
|
|
183
|
-
- Override `paths.tech_docs_dir` → `services.{domain}.tech_docs_dir` — **
|
|
184
|
-
-
|
|
185
|
-
-
|
|
186
|
-
-
|
|
181
|
+
**2. Route tới service** — nếu active domain khớp với một key trong `services`:
|
|
182
|
+
- 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.
|
|
183
|
+
- 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.
|
|
184
|
+
- Lưu `active_service` = `services.{domain}.path`
|
|
185
|
+
- Lưu `active_service_module` = `services.{domain}.module`
|
|
186
|
+
- Nếu service có `module` riêng → dùng nó làm `active_module` (override `tech_stack.module`)
|
|
187
187
|
|
|
188
|
-
**3. Fallback** —
|
|
189
|
-
-
|
|
190
|
-
-
|
|
188
|
+
**3. Fallback** — nếu không phát hiện được domain hoặc không có service key khớp:
|
|
189
|
+
- Giữ path mặc định từ Bước 1
|
|
190
|
+
- Đặt `active_service = unresolved`
|
|
191
191
|
|
|
192
|
-
**4.
|
|
193
|
-
- Override `paths.specs_dir` → `{spec_source}/specs` — **
|
|
194
|
-
- Override `paths.tech_docs_dir` → `{spec_source}/specs` — **
|
|
192
|
+
**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:`:
|
|
193
|
+
- 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`.)*
|
|
194
|
+
- 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.)*
|
|
195
195
|
- Override `paths.domain_knowledge_dir` → `{spec_source}/specs/domain-knowledge`
|
|
196
196
|
- Override `paths.business_dictionary` → `{spec_source}/specs/domain-knowledge/business-dictionary.md`
|
|
197
197
|
- Override `paths.core_entities` → `{spec_source}/specs/domain-knowledge/core-entities.md`
|
|
198
198
|
- Override `paths.bug_reports_dir` → `{spec_source}/feedback/bug-reports`
|
|
199
199
|
- Override `paths.bdd_proposals_dir` → `{spec_source}/feedback/bdd-proposals`
|
|
200
200
|
- Override `paths.prd_change_requests_dir` → `{spec_source}/feedback/prd-change-requests`
|
|
201
|
-
- Override `paths.trace_dir` → `{spec_source}/.trace` — **
|
|
201
|
+
- 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`.)*
|
|
202
202
|
|
|
203
|
-
> **
|
|
203
|
+
> **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.
|
|
204
204
|
|
|
205
205
|
---
|
|
206
206
|
|
|
207
|
-
##
|
|
207
|
+
## Bước 1.6 — [SERVICE CONVENTIONS] Nạp convention riêng của service (chế độ umbrella)
|
|
208
208
|
|
|
209
|
-
*
|
|
209
|
+
*Bỏ qua hoàn toàn bước này nếu `active_service` là `"unresolved"` hoặc context ở chế độ single-service.*
|
|
210
210
|
|
|
211
|
-
|
|
211
|
+
Khi `active_service` đã được phân giải thành một path thật ở Bước 1.5 (vd: `user-service/`):
|
|
212
212
|
|
|
213
|
-
**1.
|
|
213
|
+
**1. Định vị config của service** — thử theo thứ tự ưu tiên:
|
|
214
214
|
- `{active_service}/.agent/project-context.yaml`
|
|
215
215
|
- `{active_service}/project-context.yaml`
|
|
216
216
|
|
|
217
|
-
**2.
|
|
217
|
+
**2. Nếu tìm thấy, override bằng giá trị riêng của service:**
|
|
218
218
|
|
|
219
|
-
|
|
|
219
|
+
| Biến | Nguồn |
|
|
220
220
|
|----------|--------|
|
|
221
|
-
| `conventions.test_command` |
|
|
222
|
-
| `conventions.build_command` |
|
|
223
|
-
| `paths.trace_dir` | **
|
|
224
|
-
| `paths.specs_dir` | **
|
|
221
|
+
| `conventions.test_command` | `conventions.test_command` của service |
|
|
222
|
+
| `conventions.build_command` | `conventions.build_command` của service |
|
|
223
|
+
| `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`). |
|
|
224
|
+
| `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. |
|
|
225
225
|
|
|
226
|
-
**3.
|
|
227
|
-
-
|
|
228
|
-
- **
|
|
226
|
+
**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:
|
|
227
|
+
- Các lệnh shell (`/dev-run-test`, `/dev-gen-test`) chạy **bên trong** `service_root`
|
|
228
|
+
- **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/`).
|
|
229
229
|
|
|
230
|
-
**4.
|
|
230
|
+
**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).
|
|
231
231
|
|
|
232
232
|
---
|
|
233
233
|
|
|
234
|
-
##
|
|
234
|
+
## Bước 2 — [PROJECT-CONFIG] Nạp module stack profile (có điều kiện)
|
|
235
235
|
|
|
236
|
-
|
|
237
|
-
Merge framework
|
|
238
|
-
|
|
236
|
+
Nếu `tech_stack.module` được đặt, đọc `.agent/modules/{module}/stack-profile.yaml`.
|
|
237
|
+
Merge các convention riêng của framework (layer pattern, test pattern, quy tắc đặt tên) vào context đã nạp.
|
|
238
|
+
Nếu file không tồn tại → bỏ qua âm thầm.
|
|
239
239
|
|
|
240
240
|
---
|
|
241
241
|
|
|
242
|
-
##
|
|
242
|
+
## Bước 3 — [CRITICAL] Nạp CLAUDE.md (phân tầng: root + service overlay)
|
|
243
243
|
|
|
244
|
-
|
|
244
|
+
*Đâ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.*
|
|
245
245
|
|
|
246
|
-
CLAUDE.md
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
246
|
+
CLAUDE.md được nạp theo **hai tầng** để các quy tắc toàn-umbrella và kiến trúc/coding standards
|
|
247
|
+
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
|
|
248
|
+
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
|
|
249
|
+
service phải thắng khi sinh code.
|
|
250
250
|
|
|
251
|
-
**
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
251
|
+
**Tầng 1 — [BASE] Root CLAUDE.md (toàn umbrella).**
|
|
252
|
+
Đọc `CLAUDE.md` ở gốc repo. Coi nội dung của nó là **nền tảng dùng chung** cho cả umbrella —
|
|
253
|
+
git convention, tư thế bảo vệ dữ liệu, quy tắc xuyên suốt, và (ở chế độ single-service) là
|
|
254
|
+
kiến trúc + coding standards duy nhất của dự án.
|
|
255
255
|
|
|
256
|
-
**
|
|
257
|
-
*
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
Overlay
|
|
261
|
-
coding standards,
|
|
262
|
-
(
|
|
256
|
+
**Tầng 2 — [OVERLAY] Service CLAUDE.md (chỉ chế độ umbrella).**
|
|
257
|
+
*Chỉ chạy nếu `service_root` đã được set ở Bước 1.6 (tức đã route tới một service thật).*
|
|
258
|
+
Đọc `{service_root}/CLAUDE.md`. File này định nghĩa kiến trúc + coding standards của **stack
|
|
259
|
+
thực sự đang được triển khai** (vd: `user-service` = java-spring, `web` = nextjs).
|
|
260
|
+
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,
|
|
261
|
+
coding standards, và error handling. Các giá trị Tầng 1 mà service không định nghĩa lại
|
|
262
|
+
(vd: git convention, banned pattern dùng chung toàn tổ chức) vẫn có hiệu lực.
|
|
263
263
|
|
|
264
|
-
|
|
264
|
+
Từ kết quả **đã merge**, trích xuất và lưu:
|
|
265
265
|
|
|
266
|
-
- **§1 Project Overview** →
|
|
267
|
-
- **§2 Architecture** → layer
|
|
268
|
-
- **§3 Coding Standards** →
|
|
269
|
-
- **§5 Error Handling** → exception
|
|
270
|
-
- **§7 Git Conventions** →
|
|
266
|
+
- **§1 Project Overview** → tên dự án, ngôn ngữ, framework, lệnh build/test, domains
|
|
267
|
+
- **§2 Architecture** → thứ tự layer (vd: Controller → Facade → Service → Repository), quy tắc kiến trúc — *service overlay thắng*
|
|
268
|
+
- **§3 Coding Standards** → quy tắc đặt tên (class, method), kiểu response wrapper, pattern bị cấm — *service overlay thắng*
|
|
269
|
+
- **§5 Error Handling** → kiểu exception, mapping HTTP status code, tên class not-found exception — *service overlay thắng*
|
|
270
|
+
- **§7 Git Conventions** → pattern đặt tên branch, format commit message — *lấy theo root trừ khi service định nghĩa lại*
|
|
271
271
|
|
|
272
|
-
**
|
|
273
|
-
-
|
|
274
|
-
-
|
|
275
|
-
-
|
|
276
|
-
-
|
|
272
|
+
**Quy tắc phân giải:**
|
|
273
|
+
- Nếu cả hai tầng tồn tại → merge như trên; ghi `claude_md_source = root + {service_root}`.
|
|
274
|
+
- 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}`.
|
|
275
|
+
- 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).
|
|
276
|
+
- 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.
|
|
277
277
|
|
|
278
278
|
---
|
|
279
279
|
|
|
280
|
-
##
|
|
280
|
+
## Bước 4 — [SAFETY] Nạp quy tắc bảo vệ dữ liệu
|
|
281
281
|
|
|
282
|
-
|
|
282
|
+
Đọc `.agent/rules/data-protection.md` (hoặc `rules/data-protection.md` từ bản cài đặt framework).
|
|
283
283
|
|
|
284
|
-
|
|
284
|
+
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.
|
|
285
285
|
|
|
286
|
-
|
|
286
|
+
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*`.
|
|
287
287
|
|
|
288
288
|
---
|
|
289
289
|
|
|
290
|
-
##
|
|
290
|
+
## Bước 5 — [DOMAIN] Nạp Business Dictionary (có điều kiện)
|
|
291
291
|
|
|
292
|
-
|
|
292
|
+
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).
|
|
293
293
|
|
|
294
|
-
|
|
295
|
-
- **Canonical Terms** →
|
|
296
|
-
- **Banned Terms** →
|
|
297
|
-
- **Status / Enum Registry** →
|
|
294
|
+
Nếu tồn tại, đọc và trích xuất:
|
|
295
|
+
- **Canonical Terms** → danh sách đầy đủ các thuật ngữ chuẩn và định nghĩa
|
|
296
|
+
- **Banned Terms** → danh sách đầy đủ các thuật ngữ bị cấm và bản thay thế chuẩn
|
|
297
|
+
- **Status / Enum Registry** → các giá trị enum được phép theo từng entity
|
|
298
298
|
|
|
299
|
-
|
|
300
|
-
-
|
|
301
|
-
-
|
|
299
|
+
Lưu danh sách banned term để **thực thi chủ động** suốt phiên làm việc của lệnh:
|
|
300
|
+
- 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
|
|
301
|
+
- Tự động thay banned term bằng bản chuẩn tương đương
|
|
302
302
|
|
|
303
|
-
|
|
303
|
+
Nếu file không tồn tại → bỏ qua âm thầm. Không cảnh báo hay chặn.
|
|
304
304
|
|
|
305
305
|
---
|
|
306
306
|
|
|
307
|
-
##
|
|
307
|
+
## Bước 6 — [DOMAIN] Nạp Core Entities (có điều kiện)
|
|
308
308
|
|
|
309
|
-
|
|
310
|
-
|
|
309
|
+
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).
|
|
310
|
+
Path mặc định: `specs/domain-knowledge/core-entities.md`.
|
|
311
311
|
|
|
312
|
-
|
|
313
|
-
- **Entity catalog** →
|
|
314
|
-
- **Field name registry** →
|
|
315
|
-
- **Relationship map** →
|
|
312
|
+
Nếu tồn tại, đọc và lưu:
|
|
313
|
+
- **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ệ
|
|
314
|
+
- **Field name registry** → tên field chuẩn dùng trong code và tài liệu được sinh ra
|
|
315
|
+
- **Relationship map** → cách các entity liên hệ với nhau (1:N, N:N, embedded, v.v.)
|
|
316
316
|
|
|
317
|
-
**
|
|
318
|
-
-
|
|
319
|
-
-
|
|
320
|
-
-
|
|
317
|
+
**Cách dùng catalog này:**
|
|
318
|
+
- 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
|
|
319
|
+
- Khi sinh PRD/BDD: tham chiếu tên entity từ catalog này để nhất quán
|
|
320
|
+
- Khi sinh tech-docs: dùng catalog này làm nguồn chân lý cho định nghĩa entity
|
|
321
321
|
|
|
322
|
-
|
|
322
|
+
Nếu file không tồn tại → bỏ qua âm thầm.
|
|
323
323
|
|
|
324
324
|
---
|
|
325
325
|
|
|
326
|
-
##
|
|
326
|
+
## Bước 6.5 — [PLATFORM] Suy ra active_module và platform_type
|
|
327
327
|
|
|
328
|
-
|
|
328
|
+
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:
|
|
329
329
|
|
|
330
330
|
```
|
|
331
|
-
active_module = tech_stack.module (
|
|
331
|
+
active_module = tech_stack.module (vd: "java-spring", "react", "flutter")
|
|
332
332
|
```
|
|
333
333
|
|
|
334
334
|
| `platform_type` | Modules |
|
|
@@ -337,400 +337,398 @@ active_module = tech_stack.module (e.g. "java-spring", "react", "flutter")
|
|
|
337
337
|
| `web-frontend` | `react`, `nextjs`, `vue`, `nuxt`, `angular` |
|
|
338
338
|
| `mobile` | `flutter`, `react-native`, `ios-swiftui`, `android-compose` |
|
|
339
339
|
|
|
340
|
-
|
|
340
|
+
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.
|
|
341
341
|
|
|
342
|
-
|
|
342
|
+
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).
|
|
343
343
|
|
|
344
344
|
---
|
|
345
345
|
|
|
346
|
-
##
|
|
346
|
+
## Bước 6.7 — [GUARDRAILS] Nạp Project Lessons (có điều kiện)
|
|
347
347
|
|
|
348
|
-
*
|
|
349
|
-
|
|
348
|
+
*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`
|
|
349
|
+
hoặc được chấp nhận trong `/review-code`, `/fix-bug`, `/debug`.*
|
|
350
350
|
|
|
351
|
-
|
|
352
|
-
-
|
|
353
|
-
- Else
|
|
354
|
-
-
|
|
351
|
+
Phân giải path file lessons:
|
|
352
|
+
- Dùng `paths.lessons_file` nếu được set (có thể bị service override ở chế độ umbrella, Bước 1.6)
|
|
353
|
+
- Else mặc định `specs/domain-knowledge/lessons-learned.md`
|
|
354
|
+
- Ở 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`
|
|
355
355
|
|
|
356
|
-
|
|
357
|
-
-
|
|
358
|
-
-
|
|
359
|
-
-
|
|
356
|
+
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:
|
|
357
|
+
- 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).
|
|
358
|
+
- 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).
|
|
359
|
+
- 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.
|
|
360
360
|
|
|
361
|
-
|
|
361
|
+
Nếu file không tồn tại → bỏ qua âm thầm (chưa có lesson nào được ghi nhận).
|
|
362
362
|
|
|
363
363
|
---
|
|
364
364
|
|
|
365
|
-
##
|
|
365
|
+
## Bước 7 — [RECAP] Working Memory Recap (chống lost-in-middle)
|
|
366
366
|
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
(recency
|
|
367
|
+
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.
|
|
368
|
+
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
|
|
369
|
+
(hiệu ứng recency — tươi mới nhất trong bộ nhớ làm việc khi bắt đầu task).
|
|
370
370
|
|
|
371
|
-
|
|
371
|
+
Xuất đúng khối này:
|
|
372
372
|
```
|
|
373
373
|
[CTX LOADED]
|
|
374
374
|
Stack : {language} / {framework} / {database}
|
|
375
375
|
Platform : {active_module} ({platform_type})
|
|
376
|
-
Layers : {
|
|
377
|
-
CLAUDE.md : {root + {service_root} | {service_root}
|
|
376
|
+
Layers : {thứ tự layer từ CLAUDE.md §2 đã merge, vd: Controller → Facade → Service → Repository}
|
|
377
|
+
CLAUDE.md : {root + {service_root} | chỉ {service_root} | chỉ root | ⚠️ service overlay THIẾU — dùng root | missing}
|
|
378
378
|
Ticket : {ticket_prefix}-
|
|
379
379
|
Dict : {loaded — N canonical terms, M banned terms | missing}
|
|
380
380
|
Entities : {loaded — EntityA, EntityB, EntityC | missing}
|
|
381
|
-
Lessons : {loaded — N guardrails |
|
|
381
|
+
Lessons : {loaded — N guardrails | chưa có}
|
|
382
382
|
Service : {active_service} ({active_service_module}) | single-service
|
|
383
|
-
Svc Root : {service_root} — conventions + trace_dir
|
|
384
|
-
Status : {FULL | PARTIAL —
|
|
383
|
+
Svc Root : {service_root} — đã nạp conventions + trace_dir từ config service | —
|
|
384
|
+
Status : {FULL | PARTIAL — thiếu: CLAUDE.md / business-dict / core-entities | MINIMAL}
|
|
385
385
|
```
|
|
386
386
|
|
|
387
|
-
|
|
387
|
+
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.
|
|
388
388
|
|
|
389
389
|
---
|
|
390
390
|
|
|
391
|
-
##
|
|
391
|
+
## Hoàn tất nạp Context
|
|
392
392
|
|
|
393
|
-
|
|
394
|
-
-
|
|
395
|
-
-
|
|
396
|
-
- Coding standards
|
|
397
|
-
-
|
|
398
|
-
-
|
|
399
|
-
- Entity catalog (field
|
|
400
|
-
-
|
|
393
|
+
Sau khi hoàn thành tất cả các bước, bạn đã nạp:
|
|
394
|
+
- Định danh dự án, tech stack, convention module
|
|
395
|
+
- Quy tắc kiến trúc và thứ tự layer ← **[CRITICAL — giữ trong bộ nhớ làm việc]**
|
|
396
|
+
- Coding standards và quy tắc đặt tên ← **[CRITICAL — giữ trong bộ nhớ làm việc]**
|
|
397
|
+
- Quy tắc bảo vệ dữ liệu (pattern file nhạy cảm không bao giờ truy cập)
|
|
398
|
+
- Quy tắc thuật ngữ kèm danh sách banned term ← **[DOMAIN — áp dụng cho mọi từ được sinh ra]**
|
|
399
|
+
- Entity catalog (tên field, kiểu, invariant) ← **[DOMAIN — dùng khi sinh code]**
|
|
400
|
+
- Toàn bộ path đã cấu hình
|
|
401
401
|
|
|
402
|
-
|
|
402
|
+
Tiếp tục sang bước kế tiếp của lệnh đang gọi.
|
|
403
403
|
|
|
404
404
|
|
|
405
405
|
---
|
|
406
406
|
|
|
407
407
|
## Scope Lock
|
|
408
408
|
|
|
409
|
-
|
|
409
|
+
Lệnh này giới hạn nghiêm ngặt trong **một file feature** được truyền qua `$ARGUMENTS`:
|
|
410
410
|
|
|
411
|
-
-
|
|
412
|
-
- UC: `{UC-ID}` (
|
|
411
|
+
- File feature: `{path chính xác từ $ARGUMENTS}`
|
|
412
|
+
- UC: `{UC-ID}` (đọc từ `@trace.id` trong header file đó)
|
|
413
413
|
|
|
414
|
-
**
|
|
414
|
+
**KHÔNG đọc hay implement scenario từ bất kỳ file `.feature` nào khác** trong cùng folder domain, kể cả khi chúng dùng chung entity, khái niệm domain, hay tên service.
|
|
415
415
|
|
|
416
416
|
---
|
|
417
417
|
|
|
418
|
-
## Context Load (
|
|
418
|
+
## Context Load (bổ sung)
|
|
419
419
|
|
|
420
|
-
|
|
421
|
-
1.
|
|
422
|
-
2. Tech-doc
|
|
420
|
+
Đọc:
|
|
421
|
+
1. Chỉ file `.feature` đã giới hạn scope
|
|
422
|
+
2. Tech-doc tại `{paths.tech_docs_dir}/{domain}/{prd-slug}/tech-docs/{UC-ID}-tech-design.md` (nếu tồn tại)
|
|
423
423
|
3. CLAUDE.md §architecture + §coding_standards
|
|
424
|
-
4. **(FE/App
|
|
424
|
+
4. **(chỉ FE/App)** Design Spec tại `{paths.specs_dir}/{domain}/{prd-slug}/design-spec/{TICKET-ID}-design-spec-*{slug}.md` (nếu tồn tại) — nguồn của màn hình, component inventory, và link Figma frame từng-màn.
|
|
425
425
|
|
|
426
426
|
---
|
|
427
427
|
|
|
428
428
|
## Phase Detection
|
|
429
429
|
|
|
430
|
-
Parse `$ARGUMENTS`
|
|
430
|
+
Parse `$ARGUMENTS` tìm flag `--phase`:
|
|
431
431
|
|
|
432
|
-
| Flag |
|
|
432
|
+
| Flag | Ý nghĩa |
|
|
433
433
|
|---|---|
|
|
434
|
-
| `--phase=ui` | FE Phase 1 —
|
|
435
|
-
| `--phase=integration` | FE Phase 2 —
|
|
436
|
-
| *(
|
|
437
|
-
|
|
438
|
-
**
|
|
439
|
-
|
|
440
|
-
-
|
|
441
|
-
-
|
|
442
|
-
|
|
443
|
-
**
|
|
444
|
-
|
|
445
|
-
- **BE contract** `{paths.tech_docs_dir}/{domain}/{prd-slug}/tech-docs/{UC-ID}-tech-design.md` —
|
|
446
|
-
- **System BDD** `{paths.specs_dir}/{domain}/{prd-slug}/bdd/system/{TICKET-ID}*.feature` —
|
|
434
|
+
| `--phase=ui` | FE Phase 1 — sinh UI + layer mock API từ System BDD contract |
|
|
435
|
+
| `--phase=integration` | FE Phase 2 — thay mock adapter bằng lời gọi API thật từ tech docs |
|
|
436
|
+
| *(không có)* | Default — full implementation (BE hoặc full-stack không tách mock) |
|
|
437
|
+
|
|
438
|
+
**Nếu `--phase` được set — xác nhận platform:**
|
|
439
|
+
Đọc `@trace.platform` từ header file feature.
|
|
440
|
+
- Nếu `system` → cảnh báo: "Flag `--phase` không áp dụng cho system BDD (hướng BE). Tiếp tục với chế độ default." Coi như không có flag.
|
|
441
|
+
- Nếu `web` hoặc `app` → tiếp tục logic phase bên dưới.
|
|
442
|
+
|
|
443
|
+
**Nếu `--phase=ui`:**
|
|
444
|
+
Phân giải **nguồn shape của mock** (hybrid — ưu tiên contract thật, fallback về System BDD):
|
|
445
|
+
- **BE contract** `{paths.tech_docs_dir}/{domain}/{prd-slug}/tech-docs/{UC-ID}-tech-design.md` — nếu tồn tại, **shape** port/DTO của mock adapter (field request/response, type, error code) lấy từ đây → `mock_source = contract`. Chính xác nhất; không phải rework shape lúc integration.
|
|
446
|
+
- **System BDD** `{paths.specs_dir}/{domain}/{prd-slug}/bdd/system/{TICKET-ID}*.feature` — luôn nạp mệnh đề `Then` để lấy **behavior + giá trị fixture**. Nếu không có BE contract, shape cũng được infer từ đây → `mock_source = system-bdd`, và WARN:
|
|
447
447
|
```
|
|
448
|
-
⚠ BE contract
|
|
449
|
-
System BDD
|
|
450
|
-
|
|
451
|
-
(
|
|
448
|
+
⚠ Không tìm thấy BE contract — shape mock được infer chỉ từ System BDD.
|
|
449
|
+
System BDD mô tả behavior, không phải full request/response shape — mock
|
|
450
|
+
có thể khác API thật; dự kiến điều chỉnh ở --phase=integration.
|
|
451
|
+
(Khuyến nghị: để BE publish {prd-slug}/tech-docs/{UC-ID}-tech-design.md trước để có mock chính xác.)
|
|
452
452
|
```
|
|
453
|
-
-
|
|
453
|
+
- Nếu System BDD cũng thiếu → cảnh báo "Không tìm thấy System BDD — layer mock sẽ dùng fixture placeholder." Tiếp tục.
|
|
454
454
|
|
|
455
|
-
|
|
455
|
+
Lưu `mock_source` (`contract` | `system-bdd`) cho các tag mock bên dưới.
|
|
456
456
|
|
|
457
|
-
**
|
|
458
|
-
Spec
|
|
459
|
-
fidelity than a plain web link.
|
|
457
|
+
**Rồi chạy Figma Dev Mode MCP Check bên dưới** trước khi sinh UI — link frame của Design
|
|
458
|
+
Spec là visual contract, và MCP local đọc chúng với độ trung thực cao hơn nhiều so với link web trần.
|
|
460
459
|
|
|
461
460
|
---
|
|
462
461
|
|
|
463
|
-
## Figma Dev Mode MCP Check *(FE/App
|
|
462
|
+
## Figma Dev Mode MCP Check *(chỉ sinh UI FE/App)*
|
|
464
463
|
|
|
465
|
-
*
|
|
466
|
-
|
|
464
|
+
*Chỉ chạy khi `platform` là `web`/`app` VÀ đang sinh UI (`--phase=ui`, hoặc chế độ default
|
|
465
|
+
cho feature FE/App). Bỏ qua hoàn toàn với BE / platform `system`.*
|
|
467
466
|
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
467
|
+
PO viết Design Spec từ **link web Figma** (read-only, giới hạn). Để codegen,
|
|
468
|
+
**Figma Dev Mode MCP server local** (tích hợp trong **app desktop** Figma) cho nhiều hơn
|
|
469
|
+
nhiều: layout chính xác, **variable/token** design, mapping component **Code Connect**,
|
|
470
|
+
selection context, và code snippet — những thứ một URL web đơn không trả về được.
|
|
472
471
|
|
|
473
|
-
**Step 1 —
|
|
474
|
-
(
|
|
472
|
+
**Step 1 — Phát hiện MCP local.** Kiểm tra xem Figma Dev Mode MCP server có kết nối không
|
|
473
|
+
(một Figma tool kiểu `get_design_context` / `get_code` sẵn có qua MCP).
|
|
475
474
|
|
|
476
|
-
**Step 2 —
|
|
475
|
+
**Step 2 — Nếu CHƯA kết nối → gợi ý dev bật nó, rồi chờ:**
|
|
477
476
|
|
|
478
477
|
```
|
|
479
|
-
🎨 Figma Dev Mode MCP
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
1.
|
|
483
|
-
2.
|
|
484
|
-
3.
|
|
485
|
-
Figma
|
|
486
|
-
(
|
|
487
|
-
4.
|
|
488
|
-
5.
|
|
489
|
-
|
|
490
|
-
|
|
478
|
+
🎨 Không phát hiện Figma Dev Mode MCP.
|
|
479
|
+
Để có code FE chính xác (token, component, Code Connect thật), dùng server LOCAL:
|
|
480
|
+
|
|
481
|
+
1. Mở app Figma DESKTOP (không phải browser)
|
|
482
|
+
2. Mở file/frame của feature này
|
|
483
|
+
3. Bật Dev Mode MCP server:
|
|
484
|
+
Menu Figma → Preferences → "Enable Dev Mode MCP Server"
|
|
485
|
+
(cần Dev hoặc Full seat; server chạy ở http://127.0.0.1:3845)
|
|
486
|
+
4. Đảm bảo MCP server này đã được thêm vào config MCP của Claude Code
|
|
487
|
+
5. Chọn frame của màn bạn đang implement, rồi tiếp tục
|
|
488
|
+
|
|
489
|
+
Gõ C để tiếp tục khi đã bật, hoặc S để skip (fallback về link web + text spec).
|
|
491
490
|
```
|
|
492
491
|
|
|
493
|
-
- `C` →
|
|
494
|
-
- `S` →
|
|
495
|
-
|
|
492
|
+
- `C` → phát hiện lại; nếu giờ đã kết nối → tiếp tục dùng MCP local.
|
|
493
|
+
- `S` → tiếp tục ở **fallback mode**: chỉ dùng link frame web + text spec của Design Spec;
|
|
494
|
+
thêm note ⚠️ trong report cuối rằng UI được sinh mà không có độ trung thực Figma local.
|
|
496
495
|
|
|
497
|
-
**Step 3 —
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
real token names, not hardcoded values.
|
|
496
|
+
**Step 3 — Khi MCP local ĐÃ kết nối:** với mỗi màn đang implement, pull frame được chọn
|
|
497
|
+
qua Figma MCP và ground UI trên layout, variable, và mapping Code Connect trả về. Ưu tiên
|
|
498
|
+
component được map Code-Connect hơn là bịa markup; dùng tên token thật, không phải giá trị hardcode.
|
|
501
499
|
|
|
502
|
-
**
|
|
503
|
-
|
|
504
|
-
- **FE tech-design** (
|
|
505
|
-
- **BE API contract** (endpoint/shape
|
|
500
|
+
**Nếu `--phase=integration`:**
|
|
501
|
+
Phân giải design điều khiển adapter (hai tầng):
|
|
502
|
+
- **FE tech-design** (ưu tiên — mapping port→endpoint→DTO): `{paths.tech_docs_dir}/{domain}/{prd-slug}/tech-docs/{UC-ID}-tech-design-{platform}.md` §4, sinh bởi `/generate-tech-docs` (path FE).
|
|
503
|
+
- **BE API contract** (nguồn endpoint/shape): `{paths.tech_docs_dir}/{domain}/{prd-slug}/tech-docs/{UC-ID}-tech-design.md`.
|
|
506
504
|
|
|
507
|
-
|
|
508
|
-
|
|
505
|
+
Đọc `@trace.status` của cái nào điều khiển adapter (doc FE nếu có, else BE contract).
|
|
506
|
+
Nếu `draft` hoặc `in-review` → cảnh báo:
|
|
509
507
|
```
|
|
510
|
-
⚠ Tech design
|
|
511
|
-
Contract / adapter
|
|
512
|
-
|
|
508
|
+
⚠ Tech design cho {UC-ID} ({platform}) đang {status}.
|
|
509
|
+
Contract / mapping adapter còn có thể đổi.
|
|
510
|
+
Tiếp tục — đảm bảo BE endpoint đã deploy hoặc confirm mapping thủ công.
|
|
513
511
|
```
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
512
|
+
Nếu FE tech-design **thiếu** → cảnh báo: "Không tìm thấy FE tech-design — fallback về BE contract trực tiếp (mapping adapter được infer). Khuyến nghị: chạy `/generate-tech-docs {web|app .feature}` trước."
|
|
513
|
+
Định vị mock adapter có sẵn từ lần chạy `--phase=ui` (tìm `{UC-ID}MockApiAdapter` trong `{paths.src_dir}/{domain}/`).
|
|
514
|
+
Nếu không tìm thấy → cảnh báo: "Không tìm thấy mock adapter — sinh real API adapter từ đầu dùng contract tech-doc."
|
|
517
515
|
|
|
518
516
|
---
|
|
519
517
|
|
|
520
518
|
## Read Trace State
|
|
521
519
|
|
|
522
|
-
|
|
520
|
+
Đọc `{paths.trace_dir}/{domain}/{prd-slug}/{UC-ID}.tsv` nếu tồn tại. Với mỗi scenario row, ghi nhận `status` hiện tại:
|
|
523
521
|
|
|
524
|
-
| Status |
|
|
522
|
+
| Status | Ý nghĩa | Hành động trong lần chạy này |
|
|
525
523
|
|--------|---------|-------------------|
|
|
526
|
-
| `UNTRACKED` | `implemented_by == —` | Generate — scenario
|
|
527
|
-
| `DRIFT` | `spec_ver != gen_ver` | Regenerate — scenario
|
|
528
|
-
| `OK` |
|
|
529
|
-
| `GAP` |
|
|
524
|
+
| `UNTRACKED` | `implemented_by == —` | Generate — scenario chưa có code |
|
|
525
|
+
| `DRIFT` | `spec_ver != gen_ver` | Regenerate — scenario đã cập nhật từ lần codegen trước |
|
|
526
|
+
| `OK` | đã implement + test | Skip trừ khi gen lại tường minh |
|
|
527
|
+
| `GAP` | đã implement, chưa test | Skip codegen — đã code rồi; chạy `/dev-gen-test` thay vì |
|
|
530
528
|
|
|
531
|
-
|
|
532
|
-
|
|
529
|
+
Dùng các status này để điền số **Scenarios** trong plan CHECKPOINT (`{X} new, {Y} drifted, {Z} synced-skip`).
|
|
530
|
+
Nếu `.tsv` không tồn tại → coi mọi scenario là `UNTRACKED`.
|
|
533
531
|
|
|
534
532
|
---
|
|
535
533
|
|
|
536
534
|
## File Scan
|
|
537
535
|
|
|
538
|
-
|
|
536
|
+
Trước khi sinh, xác định file nào cần cho các scenario của UC này. Kiểm tra mỗi file đã tồn tại trên disk chưa.
|
|
539
537
|
|
|
540
|
-
|
|
538
|
+
Phân loại mỗi file:
|
|
541
539
|
|
|
542
|
-
| Status |
|
|
540
|
+
| Status | Ý nghĩa | Hành động |
|
|
543
541
|
|--------|---------|--------|
|
|
544
|
-
| `CREATE` | File
|
|
545
|
-
| `EXTEND` | File
|
|
546
|
-
| `SKIP` | File
|
|
542
|
+
| `CREATE` | File chưa tồn tại | Sinh file mới đầy đủ |
|
|
543
|
+
| `EXTEND` | File tồn tại, cần method mới | Chỉ thêm method mới — KHÔNG viết lại code có sẵn |
|
|
544
|
+
| `SKIP` | File tồn tại và đã phủ tất cả scenario của UC | Để nguyên |
|
|
547
545
|
|
|
548
|
-
> **EXTEND
|
|
546
|
+
> **Quy tắc EXTEND:** Đọc file có sẵn đầy đủ. Định vị đúng class/interface. Chỉ thêm các method mà scenario `{UC-ID}` cần. Giữ nguyên mọi method, field, annotation hiện có y như cũ. Gắn `@trace.implements={UC-ID}-SC{N}` lên mỗi method mới.
|
|
549
547
|
|
|
550
548
|
---
|
|
551
549
|
|
|
552
550
|
## CHECKPOINT — Code Generation Plan
|
|
553
551
|
|
|
554
|
-
|
|
552
|
+
Trước khi sinh code, hiện:
|
|
555
553
|
|
|
556
554
|
```
|
|
557
555
|
Code Generation Plan — {UC-ID}
|
|
558
556
|
──────────────────────────────────────────────────────
|
|
559
557
|
Feature : {name}
|
|
560
|
-
Ticket : {TICKET_ID
|
|
558
|
+
Ticket : {TICKET_ID nếu biết}
|
|
561
559
|
Domain : {domain}
|
|
562
|
-
UC : {UC-ID}
|
|
560
|
+
UC : chỉ {UC-ID} ← các file feature khác trong folder này KHÔNG được đọc
|
|
563
561
|
Tech : {language} / {framework}
|
|
564
|
-
Phase : {UI — mock layer | Integration — real API | Default — full} ←
|
|
562
|
+
Phase : {UI — mock layer | Integration — real API | Default — full} ← bỏ nếu không có flag --phase
|
|
565
563
|
Scenarios: {N} total ({X} new, {Y} drifted, {Z} synced-skip)
|
|
566
|
-
Layer : {
|
|
564
|
+
Layer : {từ CLAUDE.md §2}
|
|
567
565
|
|
|
568
566
|
Files:
|
|
569
|
-
CREATE {N}
|
|
567
|
+
CREATE {N} file mới
|
|
570
568
|
+ {path/FileName.ext}
|
|
571
|
-
EXTEND {M}
|
|
572
|
-
~ {path/FileName.ext} —
|
|
573
|
-
SKIP {K}
|
|
569
|
+
EXTEND {M} file có sẵn (chỉ thêm method)
|
|
570
|
+
~ {path/FileName.ext} — thêm: {methodA}, {methodB}
|
|
571
|
+
SKIP {K} file (không cần đổi)
|
|
574
572
|
= {path/FileName.ext}
|
|
575
573
|
──────────────────────────────────────────────────────
|
|
576
574
|
Proceed? (Y/N)
|
|
577
575
|
```
|
|
578
576
|
|
|
579
|
-
|
|
577
|
+
Chờ "Y" rõ ràng trước khi sinh.
|
|
580
578
|
|
|
581
579
|
## Branch
|
|
582
580
|
```bash
|
|
583
581
|
git checkout -b feature/{TICKET_ID}-{slug}
|
|
584
582
|
```
|
|
585
583
|
|
|
586
|
-
## Generate (layer
|
|
584
|
+
## Generate (thứ tự layer từ CLAUDE.md §2)
|
|
587
585
|
|
|
588
|
-
|
|
589
|
-
DTOs → Entity/Model → Repository → Service interface → Service impl → Facade (
|
|
586
|
+
Thứ tự mặc định (override từ CLAUDE.md nếu khác):
|
|
587
|
+
DTOs → Entity/Model → Repository → Service interface → Service impl → Facade (nếu áp dụng) → Controller
|
|
590
588
|
|
|
591
|
-
**
|
|
589
|
+
**Với file `CREATE`:** sinh file đầy đủ.
|
|
592
590
|
|
|
593
|
-
**
|
|
591
|
+
**Với file `EXTEND`:** mở file có sẵn → chỉ thêm method mới cho `{UC-ID}` → không đụng gì khác.
|
|
594
592
|
|
|
595
|
-
**
|
|
593
|
+
**Tag traceability trên controller/handler (theo cú pháp comment của ngôn ngữ bạn):**
|
|
596
594
|
```
|
|
597
595
|
@trace.implements={UC-ID}-SC{N}
|
|
598
|
-
@trace.prd_version={
|
|
599
|
-
@trace.bdd_version={
|
|
600
|
-
@trace.tech_doc_revision={
|
|
596
|
+
@trace.prd_version={đọc @trace.prd_version từ header file .feature}
|
|
597
|
+
@trace.bdd_version={đọc @trace.bdd_version từ header file .feature}
|
|
598
|
+
@trace.tech_doc_revision={đọc @trace.revision từ header tech-doc, hoặc bỏ nếu không có tech-doc}
|
|
601
599
|
@trace.source={paths.specs_dir}/{domain}/{prd-slug}/bdd/{UC-ID}-{slug}.feature
|
|
602
600
|
```
|
|
603
601
|
|
|
604
|
-
`@trace.prd_version`
|
|
605
|
-
`@trace.bdd_version`
|
|
606
|
-
`@trace.tech_doc_revision`
|
|
607
|
-
`/validate-traces`
|
|
602
|
+
`@trace.prd_version` ghi code này được viết theo version PRD nào.
|
|
603
|
+
`@trace.bdd_version` ghi code này được sinh từ version BDD nào.
|
|
604
|
+
`@trace.tech_doc_revision` ghi code này theo revision tech-design nào.
|
|
605
|
+
`/validate-traces` sẽ gắn cờ drift nếu bất kỳ artifact upstream nào được cập nhật lên version mới hơn.
|
|
608
606
|
|
|
609
|
-
> **
|
|
607
|
+
> **Quy tắc entry-point:** `@trace.implements` phải xuất hiện ở **layer entry-point** như định nghĩa trong `CLAUDE.md §2`. Với REST API → Controller. Với module event-driven → event handler / consumer class. Với context-engineering → hàm orchestration prompt. Không bao giờ chỉ đặt ở layer trong.
|
|
610
608
|
|
|
611
|
-
### Test Selectors — emit
|
|
609
|
+
### Test Selectors — emit element ID ổn định *(chỉ UI FE/App)*
|
|
612
610
|
|
|
613
|
-
|
|
611
|
+
*Áp dụng khi `platform` là `web`/`app` và đang sinh UI (`--phase=ui`, hoặc chế độ default FE/App). Bỏ qua với BE.*
|
|
614
612
|
|
|
615
|
-
|
|
613
|
+
Mỗi element **có action** (button, input, link, select, toggle, form-submit) PHẢI mang một **test-id ổn định** để QC định vị trực tiếp (không scan runtime):
|
|
616
614
|
|
|
617
|
-
1. **
|
|
618
|
-
2. **Emit
|
|
615
|
+
1. **Nguồn id.** Nếu FE tech-design `{paths.tech_docs_dir}/{domain}/{prd-slug}/tech-docs/{UC-ID}-tech-design-{platform}.md` tồn tại, lấy id **nguyên văn** từ bảng §2b Test Selectors của nó (contract). Nếu chưa tồn tại (vd `--phase=ui` trước FE tech-design), **sinh id theo quy ước** `{uc-lower}-{screen}-{element}-{type}` (vd `ft001-login-submit-btn`) để QC vẫn có handle ổn định — chúng sẽ được đối chiếu với §2b của tech-design lúc integration.
|
|
616
|
+
2. **Emit qua attribute platform** (từ `@trace.testid_attr`, hoặc theo module):
|
|
619
617
|
- web (`react`/`nextjs`/`vue`/`angular`) → `data-testid="..."`
|
|
620
618
|
- React Native → `testID="..."`
|
|
621
|
-
- Flutter → `Key('...')` (+ `Semantics(identifier: '...')`
|
|
619
|
+
- Flutter → `Key('...')` (+ `Semantics(identifier: '...')` khi action cần)
|
|
622
620
|
- native iOS → `accessibilityIdentifier = "..."`
|
|
623
|
-
3.
|
|
624
|
-
4. **
|
|
621
|
+
3. Chỉ element có action; đừng spam id lên text tĩnh. Giữ id giống hệt map của tech-design để QC Page Object khớp ngay lần đầu.
|
|
622
|
+
4. **Component catalog tái dùng?** Truyền id qua **forwarding prop** của nó (xem section catalog `## Test-ID Forwarding` — vd `<Button testId="ft001-login-submit-btn">`), không phải attribute thô. Nếu component không forward test-id, hoặc bạn đang backfill màn **existing/brownfield** (không phải sinh mới ở đây), đó là việc của `/map-testids {UC-ID}` — chạy nó thay vì sửa component dùng chung inline.
|
|
625
623
|
|
|
626
|
-
## Mock API Layer (`--phase=ui`
|
|
624
|
+
## Mock API Layer (chỉ `--phase=ui`)
|
|
627
625
|
|
|
628
|
-
*
|
|
626
|
+
*Bỏ qua hoàn toàn section này nếu `--phase` không phải `ui`.*
|
|
629
627
|
|
|
630
|
-
|
|
628
|
+
Dựng mock từ `mock_source` đã phân giải ở Phase Detection — **shape** từ BE contract khi có, **giá trị fixture + behavior** luôn từ mệnh đề `Then` của System BDD:
|
|
631
629
|
|
|
632
|
-
1.
|
|
633
|
-
- `mock_source = contract` → field
|
|
634
|
-
- `mock_source = system-bdd` → shape **
|
|
635
|
-
2. **
|
|
636
|
-
3. **
|
|
637
|
-
- Implements interface `{UC-ID}ApiPort` (
|
|
638
|
-
-
|
|
639
|
-
-
|
|
640
|
-
-
|
|
630
|
+
1. **Định nghĩa shape port** `{UC-ID}ApiPort` (DTO request/response + error code):
|
|
631
|
+
- `mock_source = contract` → tên field / type / error code lấy **nguyên văn từ BE contract** §2 (API Endpoints) / §3 (Data Model) — shape thật.
|
|
632
|
+
- `mock_source = system-bdd` → shape **infer** từ mệnh đề `Then` của System BDD (tạm — xem cảnh báo ở trên).
|
|
633
|
+
2. **Trích dữ liệu fixture** theo từng scenario từ mệnh đề `Then` của System BDD — response success + error (BDD là source of truth cho *giá trị / behavior*, bất kể nguồn shape).
|
|
634
|
+
3. **Sinh mock adapter** tại `{paths.src_dir}/{domain}/{UC-ID}MockApiAdapter.{ext}`:
|
|
635
|
+
- Implements interface `{UC-ID}ApiPort` (cùng interface mà real adapter sẽ implement)
|
|
636
|
+
- Mỗi method trả về fixture data khớp mệnh đề `Then` của BDD, theo shape của port
|
|
637
|
+
- Gồm cả trạng thái success và error (map sang các error scenario trong BDD)
|
|
638
|
+
- Tag traceability:
|
|
641
639
|
```
|
|
642
640
|
@trace.mock_for={UC-ID}
|
|
643
641
|
@trace.mock_source={contract | system-bdd}
|
|
644
642
|
@trace.system_bdd={paths.specs_dir}/{domain}/{prd-slug}/bdd/system/{UC-ID}*.feature
|
|
645
|
-
{@trace.be_contract={UC-ID}-tech-design.md #
|
|
643
|
+
{@trace.be_contract={UC-ID}-tech-design.md # chỉ khi mock_source=contract}
|
|
646
644
|
```
|
|
647
|
-
4. **Wire
|
|
645
|
+
4. **Wire vào layer service/hook** qua environment flag hoặc DI:
|
|
648
646
|
```
|
|
649
647
|
const adapter = IS_MOCK ? new {UC-ID}MockApiAdapter() : new {UC-ID}ApiAdapter()
|
|
650
648
|
```
|
|
651
|
-
- `IS_MOCK`
|
|
649
|
+
- `IS_MOCK` mặc định `true` ở môi trường development/test cho tới khi real adapter được sinh.
|
|
652
650
|
|
|
653
|
-
> Tester
|
|
654
|
-
> Shape
|
|
651
|
+
> Tester dùng mock adapter để test mọi FE scenario mà không cần đợi BE **deploy**.
|
|
652
|
+
> Shape lấy từ BE contract khi có (chính xác, không rework integration); else từ System BDD (tạm — điều chỉnh ở `--phase=integration`). Giá trị fixture luôn từ System BDD — BDD là source of truth cho behavior.
|
|
655
653
|
|
|
656
654
|
---
|
|
657
655
|
|
|
658
|
-
## Integration Phase (`--phase=integration`
|
|
656
|
+
## Integration Phase (chỉ `--phase=integration`)
|
|
659
657
|
|
|
660
|
-
*
|
|
658
|
+
*Bỏ qua hoàn toàn section này nếu `--phase` không phải `integration`.*
|
|
661
659
|
|
|
662
|
-
1.
|
|
663
|
-
2.
|
|
664
|
-
3. **
|
|
665
|
-
- Implements
|
|
666
|
-
-
|
|
667
|
-
-
|
|
668
|
-
-
|
|
660
|
+
1. **Đọc integration design.** Ưu tiên FE tech-design §4 (mapping port→endpoint→DTO→error) tại `{paths.tech_docs_dir}/{domain}/{prd-slug}/tech-docs/{UC-ID}-tech-design-{platform}.md`, dùng BE API contract `{UC-ID}-tech-design.md` làm nguồn endpoint / request-response / error-code. Nếu không có FE tech-design, trích endpoint + shape + error code trực tiếp từ BE contract.
|
|
661
|
+
2. **Đọc mock adapter có sẵn** interface (`{UC-ID}ApiPort`) từ output `--phase=ui`.
|
|
662
|
+
3. **Sinh real API adapter** tại `{paths.src_dir}/{domain}/{UC-ID}ApiAdapter.{ext}`:
|
|
663
|
+
- Implements cùng interface `{UC-ID}ApiPort` như mock adapter
|
|
664
|
+
- Gọi HTTP thật tới endpoint từ contract tech-doc
|
|
665
|
+
- Map field response sang cùng shape mà mock adapter trả về
|
|
666
|
+
- Tag traceability:
|
|
669
667
|
```
|
|
670
668
|
@trace.implements={UC-ID}-SC{N}
|
|
671
|
-
@trace.tech_doc_revision={
|
|
669
|
+
@trace.tech_doc_revision={đọc từ header tech-doc}
|
|
672
670
|
```
|
|
673
|
-
4. **
|
|
674
|
-
5. **
|
|
671
|
+
4. **Lật wire-up**: chuyển DI binding / env flag để service/hook dùng `{UC-ID}ApiAdapter` (thật) thay vì mock.
|
|
672
|
+
5. **KHÔNG xoá mock adapter** — giữ lại cho unit test.
|
|
675
673
|
|
|
676
674
|
---
|
|
677
675
|
|
|
678
|
-
## Self-Review (3
|
|
679
|
-
- [ ]
|
|
680
|
-
- [ ] @trace.implements
|
|
681
|
-
- [ ]
|
|
682
|
-
- [ ] Error handling
|
|
683
|
-
- [ ]
|
|
676
|
+
## Self-Review (3 vòng)
|
|
677
|
+
- [ ] Mỗi scenario có endpoint tương ứng
|
|
678
|
+
- [ ] @trace.implements trên mọi endpoint
|
|
679
|
+
- [ ] Tôn trọng quy tắc layer kiến trúc (CLAUDE.md §2)
|
|
680
|
+
- [ ] Error handling khớp CLAUDE.md §5
|
|
681
|
+
- [ ] Không magic number, không debug logging
|
|
684
682
|
|
|
685
683
|
## Build Verify
|
|
686
684
|
```bash
|
|
687
|
-
{conventions.build_command} #
|
|
685
|
+
{conventions.build_command} # từ project-context.yaml, tối đa 3 retry
|
|
688
686
|
```
|
|
689
687
|
|
|
690
688
|
## Write Trace State
|
|
691
689
|
|
|
692
|
-
|
|
690
|
+
Cập nhật `{paths.trace_dir}/{domain}/{prd-slug}/{UC-ID}.tsv` — với mỗi scenario đã implement, tìm row có sẵn theo `sc_id` và chỉ cập nhật các cột sau. *(Umbrella + `spec_source`: `trace_dir` phân giải về `{spec_source}/.trace` — lệnh này chạy từ `service_root` nhưng ghi trace row vào **spec repo** (liên-repo); commit/push spec submodule cho lần cập nhật trace, cùng với push code 2 tầng.)*
|
|
693
691
|
|
|
694
|
-
|
|
|
692
|
+
| Cột | Giá trị |
|
|
695
693
|
|--------|-------|
|
|
696
|
-
| `gen_ver` | copy `spec_ver`
|
|
694
|
+
| `gen_ver` | copy `spec_ver` từ row `.tsv` hiện tại (= version scenario tại thời điểm codegen) |
|
|
697
695
|
| `implemented_by` | `{ControllerClass}.{methodName}` |
|
|
698
|
-
| `bdd_version` | `@trace.bdd_version`
|
|
699
|
-
| `tech_doc_revision` | `@trace.revision`
|
|
700
|
-
| `fe_tech_doc_revision` | `@trace.revision`
|
|
701
|
-
| `fe_phase` | `ui`
|
|
702
|
-
| `last_updated` |
|
|
696
|
+
| `bdd_version` | `@trace.bdd_version` từ header `.feature` |
|
|
697
|
+
| `tech_doc_revision` | `@trace.revision` từ **BE** contract `{UC-ID}-tech-design.md`, hoặc `—` nếu không có |
|
|
698
|
+
| `fe_tech_doc_revision` | `@trace.revision` từ **FE** tech-design `{UC-ID}-tech-design-{platform}.md` khi sinh FE với `--phase=integration` (doc có §4 điều khiển adapter này); `—` cho BE, hoặc cho FE `--phase=ui` / không có FE tech-design |
|
|
699
|
+
| `fe_phase` | `ui` nếu `--phase=ui` \| `integrated` nếu `--phase=integration` \| `—` nếu không có flag phase |
|
|
700
|
+
| `last_updated` | hôm nay `YYYY-MM-DD` |
|
|
703
701
|
|
|
704
|
-
|
|
705
|
-
`status`
|
|
702
|
+
Giữ nguyên mọi cột khác (`sc_title`, `spec_ver`, `prd_version`, `prd_status`, `uc_status`, `test_count`, `test_classes`, `dev_selftest`, `dev_selftest_at`, `qc_status`, `qc_run_at`, `qc_owner`, `qc_blocked_by`).
|
|
703
|
+
`status` được tính bởi `/validate-traces` — không set ở đây.
|
|
706
704
|
|
|
707
705
|
## Refresh Panel Mirror
|
|
708
|
-
#
|
|
706
|
+
# Làm mới panel mirror của Living Docs *(local, chế độ umbrella)*
|
|
709
707
|
|
|
710
|
-
*
|
|
711
|
-
|
|
708
|
+
*Bỏ qua hoàn toàn ở chế độ single-service (không có `services` và không có `setup.spec_source`) — ở đó
|
|
709
|
+
`.trace/` của chính repo CHÍNH LÀ vị trí panel, nên không có gì để mirror.*
|
|
712
710
|
|
|
713
|
-
|
|
711
|
+
Sau khi cập nhật TSV authoritative tại `{paths.trace_dir}`:
|
|
714
712
|
|
|
715
|
-
**
|
|
716
|
-
`{paths.trace_dir}`
|
|
717
|
-
|
|
718
|
-
commit/push
|
|
719
|
-
1.
|
|
720
|
-
2.
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
713
|
+
**Khi `setup.spec_source` được đặt (trace gộp — trường hợp phổ biến):**
|
|
714
|
+
`{paths.trace_dir}` phân giải về `{spec_source}/.trace` — vị trí authoritative duy nhất.
|
|
715
|
+
Lệnh này chạy từ `service_root`, nên thao tác ghi là **liên-repo vào spec submodule**;
|
|
716
|
+
commit/push spec submodule cho lần cập nhật trace (giống như `feedback/`).
|
|
717
|
+
1. Phân giải `panel_mirror = ./.trace` tại **gốc workspace hiện tại**.
|
|
718
|
+
2. Nếu `panel_mirror` phân giải ra path khác với `{paths.trace_dir}`, copy mỗi
|
|
719
|
+
`{UC-ID}.tsv` vừa cập nhật → `{panel_mirror}/{UC-ID}.tsv` (tạo thư mục; ghi đè).
|
|
720
|
+
Không namespace theo service — chỉ có một bộ trace; service sở hữu được mang trong
|
|
721
|
+
`@trace.service` của từng row.
|
|
724
722
|
|
|
725
|
-
**Legacy (
|
|
726
|
-
Copy
|
|
727
|
-
(
|
|
723
|
+
**Legacy (không có `spec_source` — trace theo service):**
|
|
724
|
+
Copy mỗi `{UC-ID}.tsv` vừa cập nhật → `{panel_mirror}/{service-name}/{UC-ID}.tsv`
|
|
725
|
+
(namespace theo `active_service`).
|
|
728
726
|
|
|
729
|
-
|
|
730
|
-
**
|
|
731
|
-
`{spec_source}/.living-docs/`)
|
|
732
|
-
|
|
733
|
-
sub-agent.
|
|
727
|
+
Cách này giữ panel Living Docs của workspace đang mở luôn mới **giữa các lần sync** — nó chỉ là
|
|
728
|
+
một **mirror tiện lợi cục bộ**. File `trace-report.json` đã merge (canonical, trong
|
|
729
|
+
`{spec_source}/.living-docs/`) được build lại bởi `/sync` hoặc `/validate-traces`. Với các lệnh
|
|
730
|
+
được orchestrate, làm việc này một lần trong orchestrator sau khi tất cả sub-agent trả về — không phải
|
|
731
|
+
bên trong từng sub-agent.
|
|
734
732
|
|
|
735
733
|
|
|
736
734
|
## Commit
|
|
@@ -741,38 +739,38 @@ git commit -m "{commit_format}: {description}"
|
|
|
741
739
|
|
|
742
740
|
## Output
|
|
743
741
|
|
|
744
|
-
# Report Footer —
|
|
742
|
+
# Report Footer — Định dạng output chuẩn cho mọi lệnh
|
|
745
743
|
|
|
746
|
-
|
|
744
|
+
Mọi report của lệnh phải kết thúc bằng section footer chuẩn này.
|
|
747
745
|
|
|
748
746
|
## Status Badge
|
|
749
747
|
|
|
750
|
-
|
|
751
|
-
- `✅ Complete` —
|
|
752
|
-
- `❌ Failed` —
|
|
753
|
-
- `⚠️ Warnings` —
|
|
748
|
+
Chọn một theo kết quả:
|
|
749
|
+
- `✅ Complete` — mọi bước thành công, không có vấn đề
|
|
750
|
+
- `❌ Failed` — lệnh không hoàn thành được do lỗi chặn
|
|
751
|
+
- `⚠️ Warnings` — hoàn thành nhưng có vấn đề không chặn, nên review lại
|
|
754
752
|
|
|
755
753
|
## Output Artifacts
|
|
756
754
|
|
|
757
|
-
|
|
755
|
+
Liệt kê mọi file được tạo hoặc sửa bởi lệnh này:
|
|
758
756
|
```
|
|
759
757
|
Output Artifacts:
|
|
760
|
-
{created|updated} {file-path} ({
|
|
761
|
-
{created|updated} {file-path} ({
|
|
758
|
+
{created|updated} {file-path} ({mô tả ngắn})
|
|
759
|
+
{created|updated} {file-path} ({mô tả ngắn})
|
|
762
760
|
```
|
|
763
761
|
|
|
764
|
-
|
|
762
|
+
Nếu không ghi file nào (vd: lệnh review hoặc phân tích) → ghi `Output Artifacts: none (read-only)`.
|
|
765
763
|
|
|
766
764
|
## Pipeline Position
|
|
767
765
|
|
|
768
|
-
|
|
769
|
-
|
|
766
|
+
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`,
|
|
767
|
+
để người dùng luôn thấy lệnh này nằm ở đâu trong luồng end-to-end:
|
|
770
768
|
|
|
771
769
|
```
|
|
772
770
|
Discovery → PRD → [Design Spec] → BDD → Tech Design → Code → Dev Self-Check → QC → Trace Audit
|
|
773
771
|
```
|
|
774
772
|
|
|
775
|
-
|
|
773
|
+
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:
|
|
776
774
|
|
|
777
775
|
| Phase | Commands |
|
|
778
776
|
|-------|----------|
|
|
@@ -786,84 +784,84 @@ Find the current command in this phase legend and mark **its** phase in the map
|
|
|
786
784
|
| QC | `/qc-analyze` · `/qc-plan` · `/qc-design-test` · `/qc-review` · `/qc-run-test` · `/qc-report` |
|
|
787
785
|
| Trace Audit | `/validate-traces` |
|
|
788
786
|
|
|
789
|
-
|
|
787
|
+
Với **lệnh review**, thêm vòng review 3 bước và đánh dấu bước hiện tại, vd:
|
|
790
788
|
`Vòng review: [① phân tích ◀] → ② Review Board → ③ --resume`.
|
|
791
789
|
|
|
792
|
-
**
|
|
793
|
-
`/report-bug`, `/propose-scenario`, `/generate-spec-manifest`)
|
|
794
|
-
**
|
|
790
|
+
**Lệnh xuyên suốt** (`/sync`, `/update-framework`, `/fix-bug`, `/debug`, `/learn`,
|
|
791
|
+
`/report-bug`, `/propose-scenario`, `/generate-spec-manifest`) nằm ngoài pipeline tuyến tính —
|
|
792
|
+
**bỏ hẳn dòng Pipeline** cho các lệnh này (đừng cố nhét chúng vào sơ đồ).
|
|
795
793
|
|
|
796
|
-
##
|
|
794
|
+
## Gợi ý lệnh tiếp theo
|
|
797
795
|
|
|
798
|
-
|
|
796
|
+
Gợi ý lệnh kế tiếp hợp lý theo phase của workflow:
|
|
799
797
|
|
|
800
|
-
|
|
|
798
|
+
| Lệnh hiện tại | Gợi ý lệnh tiếp theo |
|
|
801
799
|
|-------------------------|-----------------------------------------------|
|
|
802
|
-
| /setup-ai-first | `/define-product`
|
|
800
|
+
| /setup-ai-first | `/define-product` để bắt đầu feature đầu tiên |
|
|
803
801
|
| /define-product | `/generate-prd {product-definition-file}` |
|
|
804
|
-
| /generate-prd | `/refine-prd {prd-file}`
|
|
805
|
-
| /refine-prd |
|
|
806
|
-
| /review-context (PRD) | FE/App: `/generate-design-spec {prd-file}` (
|
|
807
|
-
| /generate-design-spec | Designer review →
|
|
808
|
-
| /generate-bdd | `/review-context {feature-file}`
|
|
809
|
-
| /review-context (BDD) | `/generate-tech-docs {UC-ID}`
|
|
810
|
-
| /qc-analyze | `/qc-plan {UC-ID}` (
|
|
802
|
+
| /generate-prd | `/refine-prd {prd-file}` rồi `/review-context {prd-file}` |
|
|
803
|
+
| /refine-prd | Mở Review Board → cập nhật PRD → `/review-context {prd-file}` |
|
|
804
|
+
| /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 |
|
|
805
|
+
| /generate-design-spec | Designer review → xác nhận link Figma → PO + Designer sign-off → `/generate-bdd {prd-file}` |
|
|
806
|
+
| /generate-bdd | `/review-context {feature-file}` để kiểm tra độ phủ |
|
|
807
|
+
| /review-context (BDD) | `/generate-tech-docs {UC-ID}` nếu APPROVED; sinh lại nếu NEEDS_FIX |
|
|
808
|
+
| /qc-analyze | `/qc-plan {UC-ID}` (xử lý các gap blocker 🔴 trước) |
|
|
811
809
|
| /qc-plan | `/qc-design-test {UC-ID}` |
|
|
812
|
-
| /qc-design-test | `/qc-review {UC-ID}` (test-case
|
|
813
|
-
| /qc-review (test-case) | `/qc-run-test {UC-ID}`
|
|
814
|
-
| /qc-run-test | `/qc-report {UC-ID}`
|
|
815
|
-
| /qc-review (script) | `/qc-report {UC-ID}`
|
|
816
|
-
| /qc-report | `/validate-traces {UC-ID}`
|
|
810
|
+
| /qc-design-test | `/qc-review {UC-ID}` (review test-case) |
|
|
811
|
+
| /qc-review (test-case) | `/qc-run-test {UC-ID}` nếu APPROVED; sửa TC nếu NEEDS_FIX |
|
|
812
|
+
| /qc-run-test | `/qc-report {UC-ID}` rồi `/qc-review {UC-ID}` (review script) |
|
|
813
|
+
| /qc-review (script) | `/qc-report {UC-ID}` rồi tạo PR nếu APPROVED |
|
|
814
|
+
| /qc-report | `/validate-traces {UC-ID}` để làm mới Living Docs (qc_status) |
|
|
817
815
|
| /generate-tech-docs | `/review-tech-docs {tech-design-file}` |
|
|
818
|
-
| /review-tech-docs | `/generate-code {feature-file}`
|
|
819
|
-
| /generate-code |
|
|
816
|
+
| /review-tech-docs | `/generate-code {feature-file}` nếu APPROVED; sửa doc nếu NEEDS_FIX |
|
|
817
|
+
| /generate-code | Lần gen đầu → `/review-code {UC-ID}`; gen lại → `/dev-gen-test {UC-ID}` |
|
|
820
818
|
| /dev-gen-test | `/dev-run-test {UC-ID}` |
|
|
821
819
|
| /dev-run-test (passing) | `/review-code {UC-ID}` |
|
|
822
|
-
| /dev-run-test (failing) | `/fix-bug {ticket-id}`
|
|
823
|
-
| /review-code | `/dev-smoke-test {UC-ID}`
|
|
824
|
-
| /dev-smoke-test |
|
|
825
|
-
| /validate-traces | DRIFT/UNTRACKED → `/generate-code {UC-ID}`; GAP → `/dev-gen-test {UC-ID}`;
|
|
826
|
-
| /fix-bug |
|
|
827
|
-
| /debug | `/fix-bug {ticket-id}`
|
|
828
|
-
| /report-bug |
|
|
829
|
-
| /propose-scenario |
|
|
830
|
-
| /learn |
|
|
831
|
-
| /sync | `/validate-traces`
|
|
832
|
-
| /update-framework | Review `git diff .agent/`, commit; `/sync`
|
|
833
|
-
|
|
834
|
-
|
|
820
|
+
| /dev-run-test (failing) | `/fix-bug {ticket-id}` hoặc `/debug {error}` |
|
|
821
|
+
| /review-code | `/dev-smoke-test {UC-ID}` hoặc tạo PR |
|
|
822
|
+
| /dev-smoke-test | Tạo PR và link tới ticket |
|
|
823
|
+
| /validate-traces | DRIFT/UNTRACKED → `/generate-code {UC-ID}`; GAP → `/dev-gen-test {UC-ID}`; tất cả OK → tạo PR |
|
|
824
|
+
| /fix-bug | Tạo PR và link tới ticket |
|
|
825
|
+
| /debug | `/fix-bug {ticket-id}` nếu cần sửa |
|
|
826
|
+
| /report-bug | Gửi cho dev (`/fix-bug {BUG-ID}`); nếu thiếu coverage → `/propose-scenario {UC-ID}` |
|
|
827
|
+
| /propose-scenario | Báo PO/Dev review proposal trong `feedback/bdd-proposals/` |
|
|
828
|
+
| /learn | Tiếp tục làm việc — lesson áp dụng ở lệnh kế tiếp |
|
|
829
|
+
| /sync | `/validate-traces` để xem độ phủ đầy đủ; xử lý mọi `📥 tester feedback` được nêu |
|
|
830
|
+
| /update-framework | Review `git diff .agent/`, commit; `/sync` để đồng bộ nội dung dự án |
|
|
831
|
+
|
|
832
|
+
Định dạng footer như sau:
|
|
835
833
|
```
|
|
836
834
|
---
|
|
837
835
|
Status : {badge}
|
|
838
|
-
{Output Artifacts
|
|
836
|
+
{khối Output Artifacts}
|
|
839
837
|
Pipeline : Discovery → PRD → [BDD ◀ bạn ở đây] → Tech Design → Code → Dev Self-Check → QC → Trace Audit
|
|
840
|
-
(review
|
|
841
|
-
Next : {
|
|
838
|
+
(lệnh review) Vòng review: [① phân tích ◀] → ② Review Board → ③ --resume
|
|
839
|
+
Next : {lệnh gợi ý kèm ví dụ tham số}
|
|
842
840
|
```
|
|
843
|
-
*(
|
|
841
|
+
*(Bỏ dòng `Pipeline` cho các lệnh xuyên suốt liệt kê ở trên.)*
|
|
844
842
|
|
|
845
843
|
|
|
846
844
|
```
|
|
847
|
-
/generate-code
|
|
845
|
+
/generate-code Hoàn tất — {UC-ID}
|
|
848
846
|
Files: created={N}, extended={M}, skipped={K} | Build: SUCCESS
|
|
849
847
|
Branch: feature/{TICKET_ID}-{slug}
|
|
850
848
|
Phase : {UI (mock layer) | Integration (real API) | Default (full)}
|
|
851
849
|
fe_phase : {ui | integrated | —}
|
|
852
|
-
Figma : {
|
|
850
|
+
Figma : {Dev Mode MCP local (grounded) | ⚠️ chỉ link web + text spec (không có MCP local) | n/a cho BE} ← chỉ UI FE/App
|
|
853
851
|
|
|
854
852
|
Next:
|
|
855
|
-
--phase=ui
|
|
856
|
-
→
|
|
857
|
-
→
|
|
858
|
-
→
|
|
853
|
+
--phase=ui xong:
|
|
854
|
+
→ Báo tester: FE test được qua mock adapter
|
|
855
|
+
→ Thu sign-off BE → /review-tech-docs {tech-design-file}
|
|
856
|
+
→ Khi BE sẵn sàng → /generate-code {feature-file} --phase=integration
|
|
859
857
|
|
|
860
|
-
--phase=integration
|
|
861
|
-
→ /review-code {UC-ID} ← code review
|
|
862
|
-
→ /dev-gen-test {UC-ID} ← integration test
|
|
858
|
+
--phase=integration xong:
|
|
859
|
+
→ /review-code {UC-ID} ← cần code review
|
|
860
|
+
→ /dev-gen-test {UC-ID} ← bộ integration test
|
|
863
861
|
|
|
864
|
-
Default (
|
|
865
|
-
→ /review-code {UC-ID} ← code review
|
|
862
|
+
Default (không có flag phase):
|
|
863
|
+
→ /review-code {UC-ID} ← cần code review trước khi test
|
|
866
864
|
→ /dev-gen-test {UC-ID}
|
|
867
865
|
|
|
868
|
-
📊 Living Docs:
|
|
866
|
+
📊 Living Docs: chạy /validate-traces (hoặc /sync) để push trace này lên dashboard spec-module.
|
|
869
867
|
```
|