@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.
- package/commands/debug.md +43 -8
- package/commands/define-product.md +43 -8
- package/commands/dev-gen-test.md +44 -9
- package/commands/dev-gen-test.tmpl +1 -1
- package/commands/dev-run-test.md +48 -10
- package/commands/dev-run-test.tmpl +5 -2
- package/commands/dev-smoke-test.md +43 -8
- package/commands/fix-bug.md +79 -14
- package/commands/fix-bug.tmpl +36 -6
- package/commands/generate-bdd.md +49 -10
- package/commands/generate-bdd.tmpl +6 -2
- package/commands/generate-code.md +44 -9
- package/commands/generate-code.tmpl +1 -1
- package/commands/generate-design-spec.md +43 -8
- package/commands/generate-prd.md +43 -8
- package/commands/generate-spec-manifest.md +43 -8
- package/commands/generate-tech-docs.md +43 -8
- package/commands/learn.md +43 -8
- package/commands/propose-scenario.md +74 -19
- package/commands/propose-scenario.tmpl +31 -11
- package/commands/qc-analyze.md +534 -0
- package/commands/qc-analyze.tmpl +86 -0
- package/commands/qc-design-test.md +515 -0
- package/commands/qc-design-test.tmpl +67 -0
- package/commands/qc-plan.md +497 -0
- package/commands/qc-plan.tmpl +49 -0
- package/commands/qc-report.md +508 -0
- package/commands/qc-report.tmpl +60 -0
- package/commands/qc-review.md +501 -0
- package/commands/qc-review.tmpl +53 -0
- package/commands/qc-run-test.md +549 -0
- package/commands/qc-run-test.tmpl +83 -0
- package/commands/refine-prd.md +43 -8
- package/commands/report-bug.md +59 -10
- package/commands/report-bug.tmpl +16 -2
- package/commands/review-code.md +43 -8
- package/commands/review-context.md +43 -8
- package/commands/review-tech-docs.md +43 -8
- package/commands/setup-ai-first.md +7 -0
- package/commands/sync.md +19 -9
- package/commands/sync.tmpl +12 -9
- package/commands/update-framework.md +7 -0
- package/commands/validate-traces.md +67 -12
- package/commands/validate-traces.tmpl +24 -4
- package/core/FRAMEWORK_VERSION +1 -1
- package/core/commands/debug.md +43 -8
- package/core/commands/define-product.md +43 -8
- package/core/commands/dev-gen-test.md +44 -9
- package/core/commands/dev-run-test.md +48 -10
- package/core/commands/dev-smoke-test.md +43 -8
- package/core/commands/fix-bug.md +79 -14
- package/core/commands/generate-bdd.md +49 -10
- package/core/commands/generate-code.md +44 -9
- package/core/commands/generate-design-spec.md +43 -8
- package/core/commands/generate-prd.md +43 -8
- package/core/commands/generate-spec-manifest.md +43 -8
- package/core/commands/generate-tech-docs.md +43 -8
- package/core/commands/learn.md +43 -8
- package/core/commands/propose-scenario.md +74 -19
- package/core/commands/qc-analyze.md +534 -0
- package/core/commands/qc-design-test.md +515 -0
- package/core/commands/qc-plan.md +497 -0
- package/core/commands/qc-report.md +508 -0
- package/core/commands/qc-review.md +501 -0
- package/core/commands/qc-run-test.md +549 -0
- package/core/commands/refine-prd.md +43 -8
- package/core/commands/report-bug.md +59 -10
- package/core/commands/review-code.md +43 -8
- package/core/commands/review-context.md +43 -8
- package/core/commands/review-tech-docs.md +43 -8
- package/core/commands/setup-ai-first.md +7 -0
- package/core/commands/sync.md +19 -9
- package/core/commands/update-framework.md +7 -0
- package/core/commands/validate-traces.md +67 -12
- package/core/modules/qc-playwright/stack-profile.yaml +65 -0
- package/core/skills/code/SKILL.md +50 -8
- package/core/skills/debug/SKILL.md +57 -8
- package/core/skills/design-spec/SKILL.md +43 -8
- package/core/skills/discovery/SKILL.md +43 -8
- package/core/skills/prd/SKILL.md +14 -0
- package/core/skills/qc/qa-analyst/DOC_GAPS.template.md +63 -0
- package/core/skills/qc/qa-analyst/acceptance-criteria.md +60 -0
- package/core/skills/qc/qa-analyst/business-rules.md +59 -0
- package/core/skills/qc/qa-analyst/data-flow.md +64 -0
- package/core/skills/qc/qa-analyst/spec-breakdown.md +61 -0
- package/core/skills/qc/qa-designer/e2e/journey.md +41 -0
- package/core/skills/qc/qa-designer/exploratory/charter.md +68 -0
- package/core/skills/qc/qa-designer/exploratory/explore-to-functional.md +43 -0
- package/core/skills/qc/qa-designer/functional/api.md +45 -0
- package/core/skills/qc/qa-designer/functional/gui-feature.md +46 -0
- package/core/skills/qc/qa-designer/functional/gui-screen.md +52 -0
- package/core/skills/qc/qa-designer/integration/api.md +42 -0
- package/core/skills/qc/qa-designer/integration/db.md +39 -0
- package/core/skills/qc/qa-designer/integration/gui.md +40 -0
- package/core/skills/qc/qa-designer/integration/kafka.md +40 -0
- package/core/skills/qc/qa-designer/non-functional.md +40 -0
- package/core/skills/qc/qa-planner/test-plan.md +120 -0
- package/core/skills/qc/qa-reviewer/script/e2e.md +87 -0
- package/core/skills/qc/qa-reviewer/script/exploratory.md +45 -0
- package/core/skills/qc/qa-reviewer/script/functional.md +101 -0
- package/core/skills/qc/qa-reviewer/script/integration.md +91 -0
- package/core/skills/qc/qa-reviewer/script/non-functional.md +126 -0
- package/core/skills/qc/qa-reviewer/test-case/e2e.md +73 -0
- package/core/skills/qc/qa-reviewer/test-case/exploratory.md +43 -0
- package/core/skills/qc/qa-reviewer/test-case/functional.md +76 -0
- package/core/skills/qc/qa-reviewer/test-case/integration.md +69 -0
- package/core/skills/qc/qa-reviewer/test-case/non-functional.md +73 -0
- package/core/skills/qc/qa-runner/e2e.md +49 -0
- package/core/skills/qc/qa-runner/exploratory/session.md +36 -0
- package/core/skills/qc/qa-runner/functional/api.md +35 -0
- package/core/skills/qc/qa-runner/functional/gui-feature.md +51 -0
- package/core/skills/qc/qa-runner/functional/gui-screen.md +55 -0
- package/core/skills/qc/qa-runner/integration.md +47 -0
- package/core/skills/qc/qa-runner/non-functional.md +49 -0
- package/core/skills/qc/qa-runner/report/report.md +37 -0
- package/core/skills/setup-ai-first/SKILL.md +7 -0
- package/core/skills/spec/SKILL.md +14 -0
- package/core/skills/test/SKILL.md +93 -16
- package/core/steps/context-loader.md +36 -8
- package/core/steps/report-footer.md +7 -0
- package/core/templates/project-context.yaml +27 -1
- package/docs/01-getting-started/README.md +19 -0
- package/docs/01-getting-started/core-concepts.md +102 -0
- package/docs/01-getting-started/installation.md +156 -0
- package/docs/01-getting-started/quickstart.md +85 -0
- package/docs/02-guides/README.md +27 -0
- package/docs/02-guides/developer/README.md +46 -0
- package/docs/02-guides/developer/bdd-and-trace.md +123 -0
- package/docs/02-guides/developer/commands.md +76 -0
- package/docs/02-guides/developer/pr-checklist.md +15 -0
- package/docs/02-guides/developer/scenarios.md +448 -0
- package/docs/02-guides/developer/workflow.md +61 -0
- package/docs/02-guides/product-owner/README.md +77 -0
- package/docs/02-guides/product-owner/commands.md +30 -0
- package/docs/02-guides/product-owner/handoff-checklist.md +42 -0
- package/docs/02-guides/product-owner/prd-writing-rules.md +45 -0
- package/docs/02-guides/product-owner/scenarios.md +357 -0
- package/docs/02-guides/qc-automation.md +157 -0
- package/docs/02-guides/tester/README.md +74 -0
- package/docs/02-guides/tester/bug-reporting.md +117 -0
- package/docs/02-guides/tester/reading-specs.md +79 -0
- package/docs/02-guides/tester/scenarios.md +186 -0
- package/docs/02-guides/tester/spec-manifest.md +124 -0
- package/docs/02-guides/tester/test-checklist.md +31 -0
- package/docs/02-guides/tester/workflow.md +80 -0
- package/docs/03-concepts/README.md +19 -0
- package/docs/03-concepts/architecture.md +245 -0
- package/docs/03-concepts/pipeline.md +262 -0
- package/docs/03-concepts/traceability.md +149 -0
- package/docs/04-operations/README.md +33 -0
- package/docs/04-operations/bug-flow.md +362 -0
- package/docs/04-operations/publishing.md +137 -0
- package/docs/04-operations/sync-and-update.md +365 -0
- package/docs/05-reference/README.md +29 -0
- package/docs/05-reference/commands.md +229 -0
- package/docs/05-reference/modules.md +110 -0
- package/docs/05-reference/trace-schema.md +152 -0
- package/docs/README.md +51 -0
- package/modules/qc-playwright/stack-profile.yaml +65 -0
- package/package.json +2 -2
- package/skills/code/SKILL.md +50 -8
- package/skills/debug/SKILL.md +57 -8
- package/skills/design-spec/SKILL.md +43 -8
- package/skills/discovery/SKILL.md +43 -8
- package/skills/prd/SKILL.md +14 -0
- package/skills/qc/qa-analyst/DOC_GAPS.template.md +63 -0
- package/skills/qc/qa-analyst/acceptance-criteria.md +60 -0
- package/skills/qc/qa-analyst/business-rules.md +59 -0
- package/skills/qc/qa-analyst/data-flow.md +64 -0
- package/skills/qc/qa-analyst/spec-breakdown.md +61 -0
- package/skills/qc/qa-designer/e2e/journey.md +41 -0
- package/skills/qc/qa-designer/exploratory/charter.md +68 -0
- package/skills/qc/qa-designer/exploratory/explore-to-functional.md +43 -0
- package/skills/qc/qa-designer/functional/api.md +45 -0
- package/skills/qc/qa-designer/functional/gui-feature.md +46 -0
- package/skills/qc/qa-designer/functional/gui-screen.md +52 -0
- package/skills/qc/qa-designer/integration/api.md +42 -0
- package/skills/qc/qa-designer/integration/db.md +39 -0
- package/skills/qc/qa-designer/integration/gui.md +40 -0
- package/skills/qc/qa-designer/integration/kafka.md +40 -0
- package/skills/qc/qa-designer/non-functional.md +40 -0
- package/skills/qc/qa-planner/test-plan.md +120 -0
- package/skills/qc/qa-reviewer/script/e2e.md +87 -0
- package/skills/qc/qa-reviewer/script/exploratory.md +45 -0
- package/skills/qc/qa-reviewer/script/functional.md +101 -0
- package/skills/qc/qa-reviewer/script/integration.md +91 -0
- package/skills/qc/qa-reviewer/script/non-functional.md +126 -0
- package/skills/qc/qa-reviewer/test-case/e2e.md +73 -0
- package/skills/qc/qa-reviewer/test-case/exploratory.md +43 -0
- package/skills/qc/qa-reviewer/test-case/functional.md +76 -0
- package/skills/qc/qa-reviewer/test-case/integration.md +69 -0
- package/skills/qc/qa-reviewer/test-case/non-functional.md +73 -0
- package/skills/qc/qa-runner/e2e.md +49 -0
- package/skills/qc/qa-runner/exploratory/session.md +36 -0
- package/skills/qc/qa-runner/functional/api.md +35 -0
- package/skills/qc/qa-runner/functional/gui-feature.md +51 -0
- package/skills/qc/qa-runner/functional/gui-screen.md +55 -0
- package/skills/qc/qa-runner/integration.md +47 -0
- package/skills/qc/qa-runner/non-functional.md +49 -0
- package/skills/qc/qa-runner/report/report.md +37 -0
- package/skills/setup-ai-first/SKILL.md +7 -0
- package/skills/spec/SKILL.md +14 -0
- package/skills/test/SKILL.md +93 -16
- package/steps/context-loader.md +36 -8
- package/steps/report-footer.md +7 -0
- package/templates/project-context.yaml +27 -1
- 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).
|