@anhth2/spec-driven-dev-plugin 0.10.0 → 0.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (207) hide show
  1. package/commands/debug.md +43 -8
  2. package/commands/define-product.md +43 -8
  3. package/commands/dev-gen-test.md +44 -9
  4. package/commands/dev-gen-test.tmpl +1 -1
  5. package/commands/dev-run-test.md +48 -10
  6. package/commands/dev-run-test.tmpl +5 -2
  7. package/commands/dev-smoke-test.md +43 -8
  8. package/commands/fix-bug.md +79 -14
  9. package/commands/fix-bug.tmpl +36 -6
  10. package/commands/generate-bdd.md +49 -10
  11. package/commands/generate-bdd.tmpl +6 -2
  12. package/commands/generate-code.md +44 -9
  13. package/commands/generate-code.tmpl +1 -1
  14. package/commands/generate-design-spec.md +43 -8
  15. package/commands/generate-prd.md +43 -8
  16. package/commands/generate-spec-manifest.md +43 -8
  17. package/commands/generate-tech-docs.md +43 -8
  18. package/commands/learn.md +43 -8
  19. package/commands/propose-scenario.md +74 -19
  20. package/commands/propose-scenario.tmpl +31 -11
  21. package/commands/qc-analyze.md +534 -0
  22. package/commands/qc-analyze.tmpl +86 -0
  23. package/commands/qc-design-test.md +515 -0
  24. package/commands/qc-design-test.tmpl +67 -0
  25. package/commands/qc-plan.md +497 -0
  26. package/commands/qc-plan.tmpl +49 -0
  27. package/commands/qc-report.md +508 -0
  28. package/commands/qc-report.tmpl +60 -0
  29. package/commands/qc-review.md +501 -0
  30. package/commands/qc-review.tmpl +53 -0
  31. package/commands/qc-run-test.md +549 -0
  32. package/commands/qc-run-test.tmpl +83 -0
  33. package/commands/refine-prd.md +43 -8
  34. package/commands/report-bug.md +59 -10
  35. package/commands/report-bug.tmpl +16 -2
  36. package/commands/review-code.md +43 -8
  37. package/commands/review-context.md +43 -8
  38. package/commands/review-tech-docs.md +43 -8
  39. package/commands/setup-ai-first.md +7 -0
  40. package/commands/sync.md +19 -9
  41. package/commands/sync.tmpl +12 -9
  42. package/commands/update-framework.md +7 -0
  43. package/commands/validate-traces.md +67 -12
  44. package/commands/validate-traces.tmpl +24 -4
  45. package/core/FRAMEWORK_VERSION +1 -1
  46. package/core/commands/debug.md +43 -8
  47. package/core/commands/define-product.md +43 -8
  48. package/core/commands/dev-gen-test.md +44 -9
  49. package/core/commands/dev-run-test.md +48 -10
  50. package/core/commands/dev-smoke-test.md +43 -8
  51. package/core/commands/fix-bug.md +79 -14
  52. package/core/commands/generate-bdd.md +49 -10
  53. package/core/commands/generate-code.md +44 -9
  54. package/core/commands/generate-design-spec.md +43 -8
  55. package/core/commands/generate-prd.md +43 -8
  56. package/core/commands/generate-spec-manifest.md +43 -8
  57. package/core/commands/generate-tech-docs.md +43 -8
  58. package/core/commands/learn.md +43 -8
  59. package/core/commands/propose-scenario.md +74 -19
  60. package/core/commands/qc-analyze.md +534 -0
  61. package/core/commands/qc-design-test.md +515 -0
  62. package/core/commands/qc-plan.md +497 -0
  63. package/core/commands/qc-report.md +508 -0
  64. package/core/commands/qc-review.md +501 -0
  65. package/core/commands/qc-run-test.md +549 -0
  66. package/core/commands/refine-prd.md +43 -8
  67. package/core/commands/report-bug.md +59 -10
  68. package/core/commands/review-code.md +43 -8
  69. package/core/commands/review-context.md +43 -8
  70. package/core/commands/review-tech-docs.md +43 -8
  71. package/core/commands/setup-ai-first.md +7 -0
  72. package/core/commands/sync.md +19 -9
  73. package/core/commands/update-framework.md +7 -0
  74. package/core/commands/validate-traces.md +67 -12
  75. package/core/modules/qc-playwright/stack-profile.yaml +65 -0
  76. package/core/skills/code/SKILL.md +50 -8
  77. package/core/skills/debug/SKILL.md +57 -8
  78. package/core/skills/design-spec/SKILL.md +43 -8
  79. package/core/skills/discovery/SKILL.md +43 -8
  80. package/core/skills/prd/SKILL.md +14 -0
  81. package/core/skills/qc/qa-analyst/DOC_GAPS.template.md +63 -0
  82. package/core/skills/qc/qa-analyst/acceptance-criteria.md +60 -0
  83. package/core/skills/qc/qa-analyst/business-rules.md +59 -0
  84. package/core/skills/qc/qa-analyst/data-flow.md +64 -0
  85. package/core/skills/qc/qa-analyst/spec-breakdown.md +61 -0
  86. package/core/skills/qc/qa-designer/e2e/journey.md +41 -0
  87. package/core/skills/qc/qa-designer/exploratory/charter.md +68 -0
  88. package/core/skills/qc/qa-designer/exploratory/explore-to-functional.md +43 -0
  89. package/core/skills/qc/qa-designer/functional/api.md +45 -0
  90. package/core/skills/qc/qa-designer/functional/gui-feature.md +46 -0
  91. package/core/skills/qc/qa-designer/functional/gui-screen.md +52 -0
  92. package/core/skills/qc/qa-designer/integration/api.md +42 -0
  93. package/core/skills/qc/qa-designer/integration/db.md +39 -0
  94. package/core/skills/qc/qa-designer/integration/gui.md +40 -0
  95. package/core/skills/qc/qa-designer/integration/kafka.md +40 -0
  96. package/core/skills/qc/qa-designer/non-functional.md +40 -0
  97. package/core/skills/qc/qa-planner/test-plan.md +120 -0
  98. package/core/skills/qc/qa-reviewer/script/e2e.md +87 -0
  99. package/core/skills/qc/qa-reviewer/script/exploratory.md +45 -0
  100. package/core/skills/qc/qa-reviewer/script/functional.md +101 -0
  101. package/core/skills/qc/qa-reviewer/script/integration.md +91 -0
  102. package/core/skills/qc/qa-reviewer/script/non-functional.md +126 -0
  103. package/core/skills/qc/qa-reviewer/test-case/e2e.md +73 -0
  104. package/core/skills/qc/qa-reviewer/test-case/exploratory.md +43 -0
  105. package/core/skills/qc/qa-reviewer/test-case/functional.md +76 -0
  106. package/core/skills/qc/qa-reviewer/test-case/integration.md +69 -0
  107. package/core/skills/qc/qa-reviewer/test-case/non-functional.md +73 -0
  108. package/core/skills/qc/qa-runner/e2e.md +49 -0
  109. package/core/skills/qc/qa-runner/exploratory/session.md +36 -0
  110. package/core/skills/qc/qa-runner/functional/api.md +35 -0
  111. package/core/skills/qc/qa-runner/functional/gui-feature.md +51 -0
  112. package/core/skills/qc/qa-runner/functional/gui-screen.md +55 -0
  113. package/core/skills/qc/qa-runner/integration.md +47 -0
  114. package/core/skills/qc/qa-runner/non-functional.md +49 -0
  115. package/core/skills/qc/qa-runner/report/report.md +37 -0
  116. package/core/skills/setup-ai-first/SKILL.md +7 -0
  117. package/core/skills/spec/SKILL.md +14 -0
  118. package/core/skills/test/SKILL.md +93 -16
  119. package/core/steps/context-loader.md +36 -8
  120. package/core/steps/report-footer.md +7 -0
  121. package/core/templates/project-context.yaml +27 -1
  122. package/docs/01-getting-started/README.md +19 -0
  123. package/docs/01-getting-started/core-concepts.md +102 -0
  124. package/docs/01-getting-started/installation.md +156 -0
  125. package/docs/01-getting-started/quickstart.md +85 -0
  126. package/docs/02-guides/README.md +27 -0
  127. package/docs/02-guides/developer/README.md +46 -0
  128. package/docs/02-guides/developer/bdd-and-trace.md +123 -0
  129. package/docs/02-guides/developer/commands.md +76 -0
  130. package/docs/02-guides/developer/pr-checklist.md +15 -0
  131. package/docs/02-guides/developer/scenarios.md +448 -0
  132. package/docs/02-guides/developer/workflow.md +61 -0
  133. package/docs/02-guides/product-owner/README.md +77 -0
  134. package/docs/02-guides/product-owner/commands.md +30 -0
  135. package/docs/02-guides/product-owner/handoff-checklist.md +42 -0
  136. package/docs/02-guides/product-owner/prd-writing-rules.md +45 -0
  137. package/docs/02-guides/product-owner/scenarios.md +357 -0
  138. package/docs/02-guides/qc-automation.md +157 -0
  139. package/docs/02-guides/tester/README.md +74 -0
  140. package/docs/02-guides/tester/bug-reporting.md +117 -0
  141. package/docs/02-guides/tester/reading-specs.md +79 -0
  142. package/docs/02-guides/tester/scenarios.md +186 -0
  143. package/docs/02-guides/tester/spec-manifest.md +124 -0
  144. package/docs/02-guides/tester/test-checklist.md +31 -0
  145. package/docs/02-guides/tester/workflow.md +80 -0
  146. package/docs/03-concepts/README.md +19 -0
  147. package/docs/03-concepts/architecture.md +245 -0
  148. package/docs/03-concepts/pipeline.md +262 -0
  149. package/docs/03-concepts/traceability.md +149 -0
  150. package/docs/04-operations/README.md +33 -0
  151. package/docs/04-operations/bug-flow.md +362 -0
  152. package/docs/04-operations/publishing.md +137 -0
  153. package/docs/04-operations/sync-and-update.md +365 -0
  154. package/docs/05-reference/README.md +29 -0
  155. package/docs/05-reference/commands.md +229 -0
  156. package/docs/05-reference/modules.md +110 -0
  157. package/docs/05-reference/trace-schema.md +152 -0
  158. package/docs/README.md +51 -0
  159. package/modules/qc-playwright/stack-profile.yaml +65 -0
  160. package/package.json +2 -2
  161. package/skills/code/SKILL.md +50 -8
  162. package/skills/debug/SKILL.md +57 -8
  163. package/skills/design-spec/SKILL.md +43 -8
  164. package/skills/discovery/SKILL.md +43 -8
  165. package/skills/prd/SKILL.md +14 -0
  166. package/skills/qc/qa-analyst/DOC_GAPS.template.md +63 -0
  167. package/skills/qc/qa-analyst/acceptance-criteria.md +60 -0
  168. package/skills/qc/qa-analyst/business-rules.md +59 -0
  169. package/skills/qc/qa-analyst/data-flow.md +64 -0
  170. package/skills/qc/qa-analyst/spec-breakdown.md +61 -0
  171. package/skills/qc/qa-designer/e2e/journey.md +41 -0
  172. package/skills/qc/qa-designer/exploratory/charter.md +68 -0
  173. package/skills/qc/qa-designer/exploratory/explore-to-functional.md +43 -0
  174. package/skills/qc/qa-designer/functional/api.md +45 -0
  175. package/skills/qc/qa-designer/functional/gui-feature.md +46 -0
  176. package/skills/qc/qa-designer/functional/gui-screen.md +52 -0
  177. package/skills/qc/qa-designer/integration/api.md +42 -0
  178. package/skills/qc/qa-designer/integration/db.md +39 -0
  179. package/skills/qc/qa-designer/integration/gui.md +40 -0
  180. package/skills/qc/qa-designer/integration/kafka.md +40 -0
  181. package/skills/qc/qa-designer/non-functional.md +40 -0
  182. package/skills/qc/qa-planner/test-plan.md +120 -0
  183. package/skills/qc/qa-reviewer/script/e2e.md +87 -0
  184. package/skills/qc/qa-reviewer/script/exploratory.md +45 -0
  185. package/skills/qc/qa-reviewer/script/functional.md +101 -0
  186. package/skills/qc/qa-reviewer/script/integration.md +91 -0
  187. package/skills/qc/qa-reviewer/script/non-functional.md +126 -0
  188. package/skills/qc/qa-reviewer/test-case/e2e.md +73 -0
  189. package/skills/qc/qa-reviewer/test-case/exploratory.md +43 -0
  190. package/skills/qc/qa-reviewer/test-case/functional.md +76 -0
  191. package/skills/qc/qa-reviewer/test-case/integration.md +69 -0
  192. package/skills/qc/qa-reviewer/test-case/non-functional.md +73 -0
  193. package/skills/qc/qa-runner/e2e.md +49 -0
  194. package/skills/qc/qa-runner/exploratory/session.md +36 -0
  195. package/skills/qc/qa-runner/functional/api.md +35 -0
  196. package/skills/qc/qa-runner/functional/gui-feature.md +51 -0
  197. package/skills/qc/qa-runner/functional/gui-screen.md +55 -0
  198. package/skills/qc/qa-runner/integration.md +47 -0
  199. package/skills/qc/qa-runner/non-functional.md +49 -0
  200. package/skills/qc/qa-runner/report/report.md +37 -0
  201. package/skills/setup-ai-first/SKILL.md +7 -0
  202. package/skills/spec/SKILL.md +14 -0
  203. package/skills/test/SKILL.md +93 -16
  204. package/steps/context-loader.md +36 -8
  205. package/steps/report-footer.md +7 -0
  206. package/templates/project-context.yaml +27 -1
  207. package/ARCHITECTURE.md +0 -258
@@ -0,0 +1,362 @@
1
+ [📚 Docs](../README.md) › [Operations](README.md) › Bug Flow
2
+
3
+ # Bug Flow — PO · Dev · Tester · QC
4
+
5
+ > Cách **PO, Dev, Tester, và QC phối hợp** khi phát hiện bug. Mọi bug đều được trace về spec layer để fix đúng chỗ và tránh lặp lại.
6
+
7
+ > **QC cũng là nguồn bug.** Pipeline `/qc-*` đẩy vào **cùng** flow này: `/qc-run-test` FAIL = `product-gap` → `/report-bug {UC-ID}`; `/qc-analyze` `DOC_GAPS` blocker (spec sai/mơ hồ) → `/report-bug` (Case 2/3) hoặc thiếu coverage → `/propose-scenario`. Cùng phân loại Case 1–6 bên dưới. Chi tiết: [Guide · QC Automation](../02-guides/qc-automation.md#khi-qc-tìm-thấy-bug--spec-gap--đẩy-lên-specs).
8
+
9
+ ---
10
+
11
+ ## Mục lục
12
+
13
+ 1. [Bug thuộc layer nào?](#1-bug-thuộc-layer-nào)
14
+ 2. [Bảng quyết định nhanh](#2-bảng-quyết-định-nhanh)
15
+ 3. [Case 1 — Code Bug (Code ≠ BDD)](#3-case-1--code-bug-code--bdd)
16
+ 4. [Case 2 — BDD Bug (BDD ≠ PRD)](#4-case-2--bdd-bug-bdd--prd)
17
+ 5. [Case 3 — PRD Ambiguity (PRD không rõ)](#5-case-3--prd-ambiguity-prd-không-rõ)
18
+ 6. [Case 4 — PRD Change (yêu cầu thay đổi)](#6-case-4--prd-change-yêu-cầu-thay-đổi)
19
+ 7. [Case 5 — Design Spec Bug (UI ≠ Design Spec)](#7-case-5--design-spec-bug-ui--design-spec)
20
+ 8. [Case 6 — Environment / Data Bug](#8-case-6--environment--data-bug)
21
+ 9. [Giao tiếp hiệu quả — các format thông báo](#9-giao-tiếp-hiệu-quả--các-format-thông-báo)
22
+ 10. [Checklist đóng bug](#10-checklist-đóng-bug)
23
+
24
+ ---
25
+
26
+ ## 1. Bug thuộc layer nào?
27
+
28
+ Tester đọc spec chain **PRD → BDD → Code** để xác định layer của bug:
29
+
30
+ ```
31
+ ┌─────────────────────────────┐
32
+ │ Bug được phát hiện │
33
+ └──────────────┬──────────────┘
34
+ ┌──────────────▼──────────────┐
35
+ │ Tester đọc PRD → BDD → Code │
36
+ └──────────────┬──────────────┘
37
+ ┌────────────────────┼────────────────────┐
38
+ ┌───────▼───────┐ ┌─────────▼─────────┐ ┌────────▼────────┐
39
+ │ PRD mơ hồ / │ │ BDD sai so PRD / │ │ Code sai so BDD │
40
+ │ yêu cầu đổi │ │ thiếu scenario │ │ (phổ biến nhất) │
41
+ └───────┬───────┘ └─────────┬─────────┘ └────────┬────────┘
42
+ → PO xử lý → Dev xử lý → Dev xử lý
43
+ (Case 3, 4) (Case 2) (Case 1)
44
+ ```
45
+
46
+ ---
47
+
48
+ ## 2. Bảng quyết định nhanh
49
+
50
+ | PRD | BDD | Code | Chẩn đoán | Ai fix | Re-test |
51
+ |---|---|---|---|---|---|
52
+ | ✅ rõ ràng | ✅ đúng | ❌ sai | **Code bug** | Dev | Tester |
53
+ | ✅ rõ ràng | ❌ sai | ❌ sai | **BDD bug** | Dev | Tester |
54
+ | ❌ mơ hồ | bất kỳ | bất kỳ | **PRD ambiguity** | PO → Dev | Tester |
55
+ | ✅ rõ ràng | ✅ đúng | ✅ đúng | **Env / data bug** | DevOps / Dev | Tester |
56
+ | Yêu cầu thay đổi | cũ | cũ | **PRD change** | PO → Dev | Tester |
57
+ | ✅ rõ ràng | ✅ đúng | ❌ UI sai | **Design Spec bug** | PO/Designer → Dev | Tester |
58
+
59
+ ---
60
+
61
+ ## 3. Case 1 — Code Bug (Code ≠ BDD)
62
+
63
+ > Phổ biến nhất. Spec đúng, code implement sai.
64
+
65
+ ```
66
+ Tester Dev
67
+ ────── ────────────────────────────────────────────
68
+ Gửi bug report
69
+ (kèm spec context:
70
+ PRD path, BDD path,
71
+ AC bị vi phạm,
72
+ BDD scenario fail)
73
+ Nhận bug report; đọc BDD scenario được chỉ định
74
+ /fix-bug "{BUG-ID}: {mô tả}"
75
+ → agent tìm divergence code vs BDD → propose fix
76
+ Review + apply fix
77
+ /dev-run-test → dev self-check pass ✅
78
+ (dev_selftest — smoke check, KHÔNG phải official QC;
79
+ QC pipeline /qc-run-test set qc_status ở flow riêng)
80
+ /validate-traces → no broken
81
+ Tạo PR + notify tester:
82
+ "Fixed — root cause: {X}; Re-test: {BDD scenario}"
83
+ Nhận thông báo; re-test scenario
84
+ → PASS: đóng bug
85
+ → FAIL: gửi lại với actual behavior mới
86
+ ```
87
+
88
+ **Ví dụ:**
89
+
90
+ ```
91
+ Bug: FT-001 — tài khoản khoá sau 6 lần sai, không phải 5
92
+ PRD AC3 : "5 lần sai → khoá" ✅
93
+ BDD SC3 : "When 5 failures, Then 423" ✅
94
+ Code : if failCount > 5: lock() ❌ ← > thay vì >=
95
+ Fix: đổi > thành >= → chạy BDD test → pass
96
+ → notify: "Case 1 fixed, re-test FT-001-UC2-SC3"
97
+ ```
98
+
99
+ > **Nếu root cause là lỗi AI hay lặp khi gen code** (vd dùng `>` thay vì `>=` cho boundary, hay gọi repository thẳng từ controller): `/fix-bug` sẽ hỏi *"Record as a project lesson? (Y/N)"* → chọn **Y**. Lesson được nạp vào mọi lần gen sau. Hoặc chủ động `/learn "AI hay X, đúng phải Y"`.
100
+
101
+ ---
102
+
103
+ ## 4. Case 2 — BDD Bug (BDD ≠ PRD)
104
+
105
+ > Dev gen BDD sai từ đầu, hoặc PRD đã update nhưng BDD chưa.
106
+
107
+ ```
108
+ Tester Dev PO/BA
109
+ ────── ──────────── ──────
110
+ Gửi bug report
111
+ (BDD scenario mâu
112
+ thuẫn với PRD AC)
113
+ Đọc PRD → BDD: xác nhận BDD sai
114
+ Nếu PRD rõ ràng:
115
+ → update BDD scenario + code nếu cần
116
+ → /dev-run-test → dev self-check pass
117
+ → /validate-traces → PR + notify
118
+ Nếu PRD chưa đủ rõ → báo PO
119
+ Clarify PRD
120
+ (không đổi version
121
+ nếu chỉ làm rõ)
122
+ Update BDD + code → PR + notify
123
+ Re-test
124
+ ```
125
+
126
+ **Ví dụ:**
127
+
128
+ ```
129
+ Bug: FT-001 — BDD ghi "3 lần sai → khoá", PRD ghi "5 lần"
130
+ PRD AC3 : "5 lần sai → khoá" ✅
131
+ BDD SC3 : "When 3 failures, Then 423" ❌ ← dev gen BDD sai
132
+ Code : if failCount >= 3: lock() ❌ ← code theo BDD sai
133
+ Fix: 1) BDD 3→5 2) code >=3 → >=5 3) update test data
134
+ → notify: "BDD + code fixed, re-test với 5 lần"
135
+ ```
136
+
137
+ ---
138
+
139
+ ## 5. Case 3 — PRD Ambiguity (PRD không rõ)
140
+
141
+ > Không ai sai — PRD viết thiếu, dev và tester hiểu khác nhau.
142
+
143
+ ```
144
+ Tester Dev PO/BA
145
+ ────── ──────────── ──────
146
+ Gửi bug report
147
+ (AC mơ hồ: dev hiểu
148
+ X, tester expect Y)
149
+ Đọc PRD → xác nhận AC chưa đủ rõ
150
+ KHÔNG tự fix code
151
+ Báo PO: "AC3 mơ hồ: dev assume 5 lần,
152
+ tester expect 3. Đúng là bao nhiêu?"
153
+ Quyết định: 5 lần
154
+ Update PRD AC3
155
+ Bump version nếu
156
+ thay đổi behavior
157
+ Notify dev + tester
158
+ Nhận PRD mới; update BDD/code nếu cần
159
+ /validate-traces → PR + notify
160
+ Re-test theo PRD mới
161
+ ```
162
+
163
+ **Ví dụ:**
164
+
165
+ ```
166
+ PRD AC3: "Sai password nhiều lần → khoá tài khoản" ← "nhiều lần" = bao nhiêu?
167
+ Dev assume 5 lần; Tester expect 3 lần (thông lệ ngân hàng)
168
+ → Không phải bug code/BDD — là PRD thiếu thông tin
169
+ → PO quyết định 5 lần: "Sai password 5 lần liên tiếp → khoá 30 phút"
170
+ → BDD đã đúng → chỉ close bug, không fix code
171
+ ```
172
+
173
+ ---
174
+
175
+ ## 6. Case 4 — PRD Change (yêu cầu thay đổi)
176
+
177
+ > Không phải bug — business requirement thay đổi sau khi đã implement.
178
+
179
+ ```
180
+ Tester Dev PO/BA
181
+ ────── ──────────── ──────
182
+ Gửi bug report
183
+ (behavior đổi theo
184
+ yêu cầu business mới)
185
+ So sánh PRD version: code theo v1.0,
186
+ tester expect v1.1 → báo PO xác nhận
187
+ Xác nhận: PRD change,
188
+ không phải bug
189
+ Update PRD v1.1
190
+ Notify dev + tester
191
+ Nhận PRD v1.1
192
+ /review-context → xem diff
193
+ Update BDD + code + tests
194
+ /validate-traces → PR + notify:
195
+ "Implemented per PRD v1.1; re-test behavior mới"
196
+ Re-test theo PRD v1.1
197
+ ```
198
+
199
+ **Lưu ý quan trọng:** Bug report phải được **re-classify** thành "PRD Change Request" trước khi xử lý — không đưa vào bug backlog.
200
+
201
+ ---
202
+
203
+ ## 7. Case 5 — Design Spec Bug (UI ≠ Design Spec)
204
+
205
+ > Chỉ áp dụng cho FE/App. Code không khớp Design Spec.
206
+
207
+ ```
208
+ Tester Dev (FE/App) PO/BA + Designer
209
+ ────── ──────────── ──────────────────
210
+ Gửi bug report
211
+ (screen X không khớp
212
+ Design Spec section Y)
213
+ Đọc Design Spec → xác nhận spec nói gì
214
+ Nếu code sai Design Spec:
215
+ → fix code theo spec → PR + notify
216
+ Nếu Design Spec sai/lỗi thời:
217
+ → báo PO/Designer
218
+ Review + update Design Spec
219
+ Notify dev
220
+ Nhận Design Spec mới → fix code → PR + notify
221
+ Re-test UI
222
+ ```
223
+
224
+ ---
225
+
226
+ ## 8. Case 6 — Environment / Data Bug
227
+
228
+ > Spec đúng hết, code đúng hết — lỗi ở infra hoặc test data.
229
+
230
+ ```
231
+ Dấu hiệu nhận biết:
232
+ - Bug chỉ xảy ra trên staging, không reproduce local
233
+ - Bug xảy ra với 1 user cụ thể, không với user khác
234
+ - Bug xảy ra sau deploy, không trước
235
+ - /dev-run-test (dev_selftest — dev self-check) pass nhưng manual / QC test fail
236
+
237
+ Xử lý:
238
+ Tester → cung cấp: environment, user ID, timestamp, request ID
239
+ Dev → check logs, config, database state
240
+ DevOps → check infra, env vars, deploy artifacts
241
+ ```
242
+
243
+ ---
244
+
245
+ ## 9. Giao tiếp hiệu quả — các format thông báo
246
+
247
+ ### Git flow của feedback loop (2 repo, 1 vòng)
248
+
249
+ Mọi feedback đi qua **git**, không qua chat: file được ghi vào spec repo, commit+push, rồi PO/Dev kéo về bằng `/sync`. Đây là đường đi đầy đủ — từ lúc QC/Tester phát hiện tới lúc bug `Closed`:
250
+
251
+ ```
252
+ QC / Tester SPEC REPO (PO sở hữu) SERVICE SUBMODULE (Dev sở hữu)
253
+ ───────────── ───────────────────── ──────────────────────────────
254
+ /report-bug read-only
255
+ /propose-scenario specs/code
256
+ (QC: /qc-run-test FAIL,
257
+ /qc-analyze DOC_GAPS)
258
+ │ ghi file ──────────────▶ feedback/bug-reports/*.md (KHÔNG sửa specs/code trực tiếp)
259
+ feedback/bdd-proposals/*.md
260
+ feedback/prd-change-requests/*.md
261
+ State: Open
262
+ │ git commit + push (tầng spec repo)
263
+
264
+ origin(spec) ──── /sync (PO/Dev pull) ────┐
265
+
266
+ ┌──────────────── phân loại (Case 1–6) ───────────────┐
267
+ ▼ ▼
268
+ PRD/BDD gap → PO sửa PRD + bump Code bug → Dev /fix-bug {BUG-ID}
269
+ → commit+push spec repo → set State: Fixed
270
+ → /generate-bdd lại → commit+push service (tầng 1)
271
+ │ + umbrella pointer (tầng 2)
272
+ └───────────────────┬──────────────────┘
273
+
274
+ QC /qc-run-test re-verify ──── pass ──▶ State: Closed
275
+ (qc_owner / qc_blocked_by tự clear)
276
+ ```
277
+
278
+ - **2 tầng push** chỉ áp dụng phía service submodule (xem [Sync & Update §4.4](sync-and-update.md#44--commit-2-tầng-thay-đổi-trong-service-submodule)); feedback file nằm trong **spec repo** nên chỉ cần push 1 tầng ở đó.
279
+ - `/sync` chỉ surface bug `State: Open`; `Fixed`/`Closed` để riêng (xem [§10](#10-checklist-đóng-bug)).
280
+
281
+ ### Bug report (Tester → Dev)
282
+
283
+ Tester chạy `/report-bug {UC-ID} {mô tả}` → tự sinh report theo format dưới (gồm phân loại layer + phát hiện coverage gap), commit+push vào **spec repo** `feedback/bug-reports/{BUG-ID}.md`. PO/Dev thấy khi chạy `/sync` (dòng `📥 New tester feedback`):
284
+
285
+ ```
286
+ [BUG-{ID}] {Feature} — {mô tả ngắn}
287
+
288
+ Spec: {PRD path} v{x.x} | AC{N}: "{AC text}"
289
+ BDD: {BDD path} → "{Scenario title}" (hoặc: ⚠️ no scenario covers this)
290
+ Layer: Code / BDD / PRD / Env ← Tester đề xuất, Dev xác nhận
291
+
292
+ Expected: {theo spec}
293
+ Actual: {thực tế}
294
+ Repro: {steps}
295
+ Env: staging / {date deploy}
296
+ ```
297
+
298
+ > **Nếu Layer = "coverage gap"** (behavior đúng nhưng chưa scenario nào cover): tester chạy `/propose-scenario {UC-ID}` → draft scenario vào `bdd-proposals/` cho PO/Dev duyệt. Xem [Case 2](#4-case-2--bdd-bug-bdd--prd).
299
+
300
+ ### Fix xong (Dev → Tester)
301
+
302
+ ```
303
+ [BUG-{ID}] Fixed ✅
304
+
305
+ Root cause: Case {1..6} — {mô tả ngắn}
306
+ Changed:
307
+ - {file/component}: {what changed}
308
+ - BDD: {updated / unchanged}
309
+ - PRD: {unchanged / clarified by PO}
310
+
311
+ Deploy: staging @ {time} — {commit/PR link}
312
+ Re-test: {BDD scenario ID hoặc AC number}
313
+ ```
314
+
315
+ ### Cần PO clarify (Dev → PO)
316
+
317
+ ```
318
+ [PRD-CLARIFY] {Feature} — AC{N} mơ hồ
319
+
320
+ Tình huống:
321
+ Dev implement: {X}
322
+ Tester expect: {Y}
323
+ Triggered by: BUG-{ID}
324
+
325
+ PRD AC hiện tại: "{AC text}"
326
+
327
+ Câu hỏi: {câu hỏi cụ thể — 1 câu}
328
+ Cần trả lời trước: {date} để unblock tester
329
+ ```
330
+
331
+ ---
332
+
333
+ ## 10. Checklist đóng bug
334
+
335
+ Trước khi đánh "Resolved":
336
+
337
+ **Dev:**
338
+ - [ ] Root cause xác định rõ (Case 1/2/3/4/5/6)
339
+ - [ ] Fix đúng layer — không patch code khi lỗi ở BDD hoặc PRD
340
+ - [ ] `/validate-traces` → no broken traces
341
+ - [ ] `/dev-run-test` → dev self-check pass (`dev_selftest` — smoke check, KHÔNG thay official QC `qc_status` do `/qc-run-test` set)
342
+ - [ ] Nếu root cause là lỗi AI gen hay lặp → đã `/learn` (hoặc accept prompt khi `/fix-bug`)
343
+ - [ ] Notify tester với đầy đủ thông tin re-test
344
+
345
+ **Tester / QC:**
346
+ - [ ] Re-test đúng scenario được chỉ định (QC: `/qc-run-test {UC-ID}` lại → `qc_status` flip `fail → pass`)
347
+ - [ ] Kiểm tra regression: các AC khác của cùng PRD không bị ảnh hưởng
348
+ - [ ] Confirm PASS trước khi close
349
+
350
+ **Vòng đời bug report (đừng để `feedback/` phình mãi):**
351
+ - [ ] `State` của `feedback/bug-reports/{BUG-ID}.md`: `🟢 Open` → `🟡 Fixed` (set bởi `/fix-bug {BUG-ID}`) → `🟢 Closed` (sau khi `/qc-run-test` re-verify pass).
352
+ - [ ] Khi `Closed`: `/qc-run-test` clear `qc_owner`/`qc_blocked_by` của SC (tự động khi `qc_status=pass`); tuỳ chọn move file sang `feedback/bug-reports/archive/`.
353
+ - [ ] `/sync` chỉ surface bug `State: Open` là "đang chờ" — Fixed/Closed không làm nhiễu PO/PM.
354
+
355
+ **PO** *(nếu PRD được cập nhật)*:
356
+ - [ ] PRD version mới đã được bump
357
+ - [ ] Changelog có entry cho thay đổi
358
+ - [ ] Notify dev và tester về version mới
359
+
360
+ ---
361
+
362
+ *Xem thêm:* [Sync & Update](sync-and-update.md) · [Guide · Tester](../02-guides/tester/README.md) · [Guide · QC Automation](../02-guides/qc-automation.md).
@@ -0,0 +1,137 @@
1
+ [📚 Docs](../README.md) › [Operations](README.md) › Publishing
2
+
3
+ # Publishing — Publish lên npm
4
+
5
+ > Hướng dẫn publish package `@anhth2/spec-driven-dev-plugin` lên npm: setup lần đầu, publish version mới, kiểm tra sau publish, và transfer ownership.
6
+
7
+ Package: `@anhth2/spec-driven-dev-plugin`
8
+ Registry: <https://www.npmjs.com/package/@anhth2/spec-driven-dev-plugin>
9
+
10
+ ---
11
+
12
+ ## Mục lục
13
+
14
+ 1. [Yêu cầu](#1-yêu-cầu)
15
+ 2. [Setup lần đầu](#2-setup-lần-đầu)
16
+ 3. [Publish version mới](#3-publish-version-mới)
17
+ 4. [Kiểm tra sau khi publish](#4-kiểm-tra-sau-khi-publish)
18
+ 5. [Transfer package sang account khác](#5-transfer-package-sang-account-khác)
19
+
20
+ ---
21
+
22
+ ## 1. Yêu cầu
23
+
24
+ - Node.js đã cài (`node -v`)
25
+ - Tài khoản npm: <https://www.npmjs.com> (hiện đang dùng account `anhth2`)
26
+
27
+ ---
28
+
29
+ ## 2. Setup lần đầu
30
+
31
+ ### 2.1 — Đăng nhập npm
32
+
33
+ ```powershell
34
+ npm login
35
+ ```
36
+
37
+ Trình duyệt sẽ mở trang xác thực npm. Đăng nhập bằng account `anhth2`, sau đó quay lại terminal. Kiểm tra:
38
+
39
+ ```powershell
40
+ npm whoami
41
+ # output: anhth2
42
+ ```
43
+
44
+ ### 2.2 — Tạo Access Token (nếu cần dùng CI hoặc tránh 2FA mỗi lần)
45
+
46
+ 1. Vào <https://www.npmjs.com> → Avatar → **Access Tokens**
47
+ 2. **Generate New Token** → **Granular Access Token**
48
+ 3. Điền:
49
+ - Name: `publish-spec-driven-dev`
50
+ - Expiration: 1 year
51
+ - Packages: chọn `@anhth2/spec-driven-dev-plugin` → **Read and write**
52
+ 4. Copy token, lưu vào nơi an toàn
53
+
54
+ Publish với token:
55
+
56
+ ```powershell
57
+ npm publish --token <your-token>
58
+ ```
59
+
60
+ ---
61
+
62
+ ## 3. Publish version mới
63
+
64
+ ### Bước 1 — Cập nhật nội dung commands (nếu có thay đổi)
65
+
66
+ Sửa các file trong thư mục `commands/`.
67
+
68
+ ### Bước 2 — Tăng version trong `package.json` (semver)
69
+
70
+ | Loại thay đổi | Lệnh | Ví dụ |
71
+ |---|---|---|
72
+ | Fix nhỏ, sửa lỗi | `npm version patch` | 0.1.0 → 0.1.1 |
73
+ | Thêm command mới | `npm version minor` | 0.1.0 → 0.2.0 |
74
+ | Thay đổi lớn, breaking | `npm version major` | 0.1.0 → 1.0.0 |
75
+
76
+ ```powershell
77
+ # Ví dụ: thêm command mới
78
+ npm version minor
79
+ ```
80
+
81
+ Lệnh này tự động cập nhật `version` trong `package.json` và tạo git commit + tag.
82
+
83
+ ### Bước 3 — Publish
84
+
85
+ ```powershell
86
+ npm publish
87
+ ```
88
+
89
+ ### Bước 4 — Push git (bao gồm tag vừa tạo)
90
+
91
+ ```powershell
92
+ git push && git push --tags
93
+ ```
94
+
95
+ ---
96
+
97
+ ## 4. Kiểm tra sau khi publish
98
+
99
+ ```powershell
100
+ # Xem version mới trên npm
101
+ npm view @anhth2/spec-driven-dev-plugin version
102
+
103
+ # Chạy thử
104
+ npx @anhth2/spec-driven-dev-plugin@latest
105
+ ```
106
+
107
+ ---
108
+
109
+ ## 5. Transfer package sang account khác
110
+
111
+ Khi cần chuyển quyền sở hữu package cho người khác (ví dụ: sang account `edupia-team`):
112
+
113
+ ### Thêm maintainer
114
+
115
+ ```powershell
116
+ npm owner add <npm-username> @anhth2/spec-driven-dev-plugin
117
+ ```
118
+
119
+ ### Transfer toàn bộ
120
+
121
+ ```powershell
122
+ npm access grant read-write <npm-username> @anhth2/spec-driven-dev-plugin
123
+ ```
124
+
125
+ Hoặc làm thủ công trên website:
126
+
127
+ 1. Vào <https://www.npmjs.com/package/@anhth2/spec-driven-dev-plugin>
128
+ 2. Tab **Settings** → **Maintainers** → thêm username mới
129
+
130
+ > **Lưu ý:** Nếu muốn đổi tên package, cần publish lại với tên mới vì npm không cho đổi tên package đã publish. Sau đó deprecate package cũ:
131
+ > ```powershell
132
+ > npm deprecate @anhth2/spec-driven-dev-plugin "Moved to <new-package-name>"
133
+ > ```
134
+
135
+ ---
136
+
137
+ *Xem thêm:* [Sync & Update](sync-and-update.md) (`/update-framework` kéo version mới từ npm về project) · [Bug Flow](bug-flow.md).