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