spec-lite 1.2.2 → 1.3.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.
@@ -0,0 +1,365 @@
1
+ ---
2
+ name: spec-test
3
+ description: Tạo test.md cho một integration bằng cách mechanical derive Test Scenarios + Test Cases từ Flows/US/AC/VR/FAC trong frd.md. Auto-cascade lên feature/{F-XXX}/tsd.md. Role QC, song song với /spec-tech (DEV) — cả hai chỉ phụ thuộc spec.md approved.
4
+ ---
5
+
6
+ # spec-test
7
+
8
+ ## Overview
9
+
10
+ Tạo `test.md` cho một integration trong `specs/integrations/{slug}/`.
11
+
12
+ `test.md` là verification design ở integration level — định nghĩa **how to verify** rằng integration đáp ứng `spec.md`. Nội dung gồm Test Strategy (per integration) + Changes blocks cascade lên feature `tsd.md` (Test Spec Document).
13
+
14
+ **Hai artifact tách bạch:**
15
+ - `specs/integrations/{slug}/test.md` — integration-level, ephemeral, PR record bất biến sau approve (single-word naming như `spec.md` / `tech.md` / `plan.md`).
16
+ - `specs/main/feature/{F-XXX}-{slug}/tsd.md` — feature-level, persistent canonical artifact (3-letter naming như `frd.md` / `fdd.md`). TC content cuối cùng nằm ở đây.
17
+
18
+ **Role:** QC. Song song với `/spec-tech` (DEV role). Cả hai chỉ phụ thuộc `spec.md` approved — không có thứ tự bắt buộc giữa chúng.
19
+
20
+ **Cốt lõi:** agent **mechanical derive** TC từ frd.md (mỗi Flow → TS, mỗi US/AC → Functional TC, mỗi VR → Validation TC positive+negative, mỗi FAC → Feature AC TC). Agent KHÔNG sáng tạo TC ngoài frd — phần đó là QC thêm tay khi review.
21
+
22
+ ## When to Use
23
+
24
+ - `spec.md` đã được approve → bắt đầu thiết kế verification
25
+ - Bổ sung `test.md` cho integration đã có spec.md/tech.md nhưng chưa có test.md
26
+
27
+ ## When NOT to Use
28
+
29
+ - `spec.md` chưa có hoặc chưa approve → chạy `/spec-new` trước
30
+ - Integration có `features: []` (không touch feature nào) → `test.md` không áp dụng vì component-level `tsd.md` không tồn tại trong kit này (xem `templates/main/feature/tsd-template.md` — component contract verify gián tiếp qua feature TC + unit test trong code). Verification cho integration thuần component → đặt trong tech.md hoặc phase Verification của plan.md.
31
+ - Chỉ muốn cập nhật `test.md` đã có → edit file trực tiếp
32
+
33
+ ---
34
+
35
+ ## Process
36
+
37
+ ### Bước 1: Xác định integration
38
+
39
+ **Nếu có ARGUMENT:**
40
+ - Parse argument: có thể là số thứ tự (`2`, `002`) hoặc slug (`002-implement-todo`)
41
+ - Quét `specs/integrations/*/spec.md`, tìm integration khớp với argument
42
+ - Nếu không tìm thấy → báo lỗi:
43
+ > Không tìm thấy integration khớp với "{argument}". Kiểm tra lại tên hoặc số thứ tự.
44
+ - Nếu tìm thấy → dùng integration đó, bắt đầu luôn
45
+
46
+ **Nếu không có ARGUMENT:**
47
+
48
+ Quét `specs/integrations/`. Liệt kê **tất cả** integrations có `spec.md`, đánh dấu những cái đã có `test.md`:
49
+
50
+ ```
51
+ Integrations:
52
+
53
+ [1] 001-implement-auth — Implement Auth spec✓ test✓
54
+ [2] 002-implement-todo — Implement Todo Management spec✓ test—
55
+
56
+ Chọn số integration:
57
+ ```
58
+
59
+ Nếu không có integration nào → thông báo:
60
+ > Chưa có integration nào. Hãy chạy `/spec-new` trước.
61
+
62
+ Nếu integration đã có `test.md` → hỏi trước khi tiếp tục:
63
+ > `test.md` đã tồn tại cho integration này. Tiếp tục sẽ ghi đè. Tiếp tục không?
64
+
65
+ ---
66
+
67
+ ### Bước 1b: Gate check
68
+
69
+ Đọc frontmatter của `specs/integrations/{slug}/spec.md`.
70
+
71
+ **Check 1 — spec.md phải approved:**
72
+
73
+ Nếu `status` **không phải** `approved`:
74
+
75
+ > ⛔ `spec.md` của integration **{slug}** chưa được approve (status hiện tại: `{status}`).
76
+ >
77
+ > `/spec-test` cần spec.md approved vì cascade frd.md (nguồn của TC) chỉ apply sau khi approve.
78
+ >
79
+ > Để tiếp tục:
80
+ > 1. Review `specs/integrations/{slug}/spec.md`
81
+ > 2. Approve (đổi `status: draft` → `status: approved`)
82
+ >
83
+ > Sau đó chạy lại `/spec-test`.
84
+
85
+ **Dừng hoàn toàn.**
86
+
87
+ **Check 2 — features non-empty:**
88
+
89
+ Đọc `features:` trong frontmatter. Nếu `[]`:
90
+
91
+ > ⛔ Integration **{slug}** không touch feature nào (`features: []`).
92
+ >
93
+ > `/spec-test` cascade lên `feature/{F-XXX}/tsd.md` — không áp dụng cho integration thuần component.
94
+ > Component contract được verify gián tiếp qua feature TC + unit test trong code (xem `templates/main/feature/tsd-template.md`).
95
+ >
96
+ > Đặt verification cho integration này trong:
97
+ > - `tech.md > Implementation Notes` — verification approach
98
+ > - `plan.md > Verification phase` — test tasks cụ thể
99
+ >
100
+ > Không có gì để làm với `/spec-test`. Dừng.
101
+
102
+ Nếu cả 2 check pass → tiếp tục Bước 2.
103
+
104
+ ---
105
+
106
+ ### Bước 2: Load context
107
+
108
+ Load các file sau:
109
+
110
+ - `specs/integrations/{slug}/spec.md` — đọc toàn bộ + frontmatter (`features`)
111
+ - `specs/main/feature/{F-XXX}-{slug}/frd.md` — cho mỗi feature trong frontmatter `features` (source của TC — bắt buộc tồn tại vì cascade từ spec.md đã apply)
112
+ - `specs/main/feature/{F-XXX}-{slug}/tsd.md` — cho mỗi feature trong frontmatter `features` (nếu tồn tại — cần để diff và assign next ID)
113
+ - `specs/integrations/{slug}/tech.md` — đọc nếu tồn tại (optional, dùng để hint environment / data set / NFR perf threshold)
114
+
115
+ Tóm tắt context:
116
+
117
+ ```
118
+ TÔI HIỂU:
119
+ - Integration: {title}
120
+ - Features touched: {từ frontmatter — F-XXX, ...}
121
+ - Mỗi feature có trong frd.md:
122
+ - F-XXX: {N} Flows, {M} US ({K} AC), {P} VR, {Q} FAC
123
+ - tsd.md hiện tại:
124
+ - F-XXX: tồn tại — max(TS)=NNN, max(TC)=MMM (cho operation=update)
125
+ - F-YYY: chưa tồn tại (cho operation=create)
126
+ - tech.md: {tồn tại / chưa — nếu có thì có hint gì cho env/data/perf}
127
+ ```
128
+
129
+ Nếu frd.md của feature nào không tồn tại → báo lỗi và dừng (lỗi cascade từ spec.md trước đó):
130
+ > ⛔ `specs/main/feature/{F-XXX}-{slug}/frd.md` không tồn tại nhưng feature có trong `features:` của spec.md. Cascade từ spec.md có thể đã fail. Kiểm tra lại.
131
+
132
+ ---
133
+
134
+ ### Bước 3: Auto-derive draft
135
+
136
+ **Nguyên tắc:** agent derive **1:1 mechanically** từ frd.md. KHÔNG sáng tạo TC ngoài frd. Phần creative (extra edge cases, exploratory testing) thuộc về QC khi review.
137
+
138
+ #### 3.1 ID assignment
139
+
140
+ Với mỗi feature trong `features:`:
141
+
142
+ - Đọc `feature/{F-XXX}/tsd.md` hiện tại (nếu có) để lấy `max(TS-F{NNN}-seq)` và `max(TC-F{NNN}-seq)`
143
+ - ID mới = `max(seq) + 1`, format 3 chữ số
144
+ - TC dùng **chung sequence** cho Functional / Validation / Feature AC — không reset theo loại
145
+ - ID **stable** — không tái sử dụng khi [REMOVE], không renumber khi [MODIFY]
146
+ - Operation=create (tsd.md chưa tồn tại) → bắt đầu từ `001`
147
+
148
+ #### 3.2 Derivation rules
149
+
150
+ Áp dụng cho mỗi feature, sinh ra Changes block tương ứng:
151
+
152
+ **A. Test Scenarios** — mỗi Flow trong `frd.md > User Flows` → 1 Test Scenario.
153
+
154
+ - TS ID mới = `TS-F{NNN}-{next_seq}`
155
+ - Flow ref: `frd.md > Flow {N}: {name}`
156
+ - Preconditions: derive từ điểm bắt đầu của Mermaid flow
157
+ - Postconditions: derive từ điểm kết thúc happy
158
+ - Paths: liệt kê happy + mỗi edge case trong Mermaid
159
+ - Test cases: list các TC ID sẽ cover TS này (cross-reference TC sinh ở bước B/D)
160
+
161
+ **B. Functional Test Cases** — mỗi AC trong mỗi US → 1 Functional TC.
162
+
163
+ - TC ID mới = `TC-F{NNN}-{next_seq}`
164
+ - Type: `Functional — positive` (mặc định cho AC happy), `Functional — negative` nếu AC mô tả nhánh fail
165
+ - Priority: derive từ US Priority (xem 3.3)
166
+ - Covers: `US-{F_ID}-{seq}`, `AC-{F_ID}-{seq}`
167
+ - Scenario: TS ID của Flow tương ứng (nếu AC nằm trong flow)
168
+ - Preconditions/Steps/Expected: dịch 1:1 từ Given/When/Then của AC
169
+
170
+ **C. Validation Test Cases** — mỗi VR → tối thiểu 2 TC.
171
+
172
+ - 1 positive: input hợp lệ → accept
173
+ - 1+ negative: mỗi nhánh fail là 1 TC riêng (vd VR "email format" → 1 case missing `@`, 1 case missing domain, 1 case có space). Agent infer các nhánh fail từ rule text.
174
+ - TC ID mới = `TC-F{NNN}-{next_seq}` (chung sequence với Functional)
175
+ - Form bảng theo template gốc
176
+ - Covers: `VR-{F_ID}-{seq}`
177
+ - Priority: P1 mặc định (xem 3.3)
178
+
179
+ **D. Feature AC Test Cases** — mỗi FAC → 1 Feature AC TC.
180
+
181
+ - TC ID mới = `TC-F{NNN}-{next_seq}`
182
+ - Type: derive từ nhóm FAC (`e2e` / `consistency` / `NFR` / `data & migration`) — đọc context FAC để phân loại
183
+ - Priority: theo bảng ở 3.3
184
+ - Covers: `FAC-{F_ID}-{seq}`
185
+ - Spans: list US IDs mà FAC liên quan (nếu FAC e2e)
186
+ - Preconditions/Steps/Expected: dịch 1:1 từ Given/When/Then của FAC
187
+
188
+ **E. Traceability Matrix** — row per frd item:
189
+
190
+ - 1 row per Flow → cover by TS
191
+ - 1 row per US → cover by TC (Functional)
192
+ - 1 row per Story AC → cover by TC (Functional)
193
+ - 1 row per VR → cover by TC (Validation, list tất cả positive + negative)
194
+ - 1 row per FAC → cover by TC (Feature AC)
195
+ - Mọi item phải có cover ✅ (vì derive 1:1). Nếu agent không thể derive một item nào → đánh dấu ❌ + ghi lý do ở Gaps section, KHÔNG silent skip.
196
+
197
+ #### 3.3 Priority defaults
198
+
199
+ Mọi TC đều có priority deterministic. QC override khi review (Bước 4).
200
+
201
+ **TC cover US/AC** — inherit từ US Priority:
202
+
203
+ | US Priority (frd) | TC Priority |
204
+ | --- | --- |
205
+ | Must | P0 |
206
+ | Should | P1 |
207
+ | Could | P2 |
208
+
209
+ **TC cover VR** — inherit max priority của các US trong `Refs` column của VR. Nếu Refs trống → P1 default.
210
+
211
+ **TC cover FAC** — theo nhóm FAC:
212
+
213
+ | FAC group | TC Priority |
214
+ | --- | --- |
215
+ | End-to-end liên story | P0 |
216
+ | Cross-story consistency | P1 |
217
+ | NFR — security / data integrity | P0 |
218
+ | NFR — performance / a11y / i18n / browser | P1 |
219
+ | Data & migration | P0 |
220
+
221
+ #### 3.4 Diff vs current tsd.md
222
+
223
+ Với feature có tsd.md hiện tại (operation=update):
224
+
225
+ - Item đã có TC cover → KHÔNG sinh TC mới, giữ nguyên TC cũ
226
+ - Item trong frd nhưng chưa có TC cover → sinh TC mới với marker `[NEW]`
227
+ - TC hiện tại cover item đã bị xóa khỏi frd (orphan) → đánh dấu `[REMOVE]` + ghi lý do (vd: "AC-F001-005 không còn trong frd")
228
+ - Item trong frd đã đổi nội dung mà TC cũ không còn match (vd AC đổi expected outcome) → đánh dấu TC cũ là `[MODIFY {field}]` với field cụ thể
229
+
230
+ Agent compute diff tự động — KHÔNG hỏi user "field nào đã đổi"; đọc 2 file rồi đối chiếu.
231
+
232
+ **No-delta case:** nếu diff giữa frd hiện tại và tsd.md hiện tại = empty cho 1 feature (frd không thêm/đổi item nào mà tsd chưa cover) → **bỏ Changes block của feature đó hoàn toàn**, ghi `no-op` trong Cascade Summary để minh bạch.
233
+
234
+ #### 3.5 Placeholders cần QC fill
235
+
236
+ Agent **không suy đoán** các field sau, dùng placeholder rõ ràng để QC điền ở Bước 4:
237
+
238
+ | Field | Placeholder | Vì sao agent không tự fill |
239
+ | --- | --- | --- |
240
+ | Environments table | Row mặc định: `dev / staging / prod-like` với `data set: TBD`, `mục đích: TBD` | Phụ thuộc setup CI/CD và availability — QC owns |
241
+ | Test Data table | Row `{TBD — fixture}` cho mỗi seed/boundary dataset agent thấy cần | QC chọn fixture source thực tế |
242
+ | Out of Scope | Để trống với note `<!-- QC fill -->` | Quyết định business của QC |
243
+ | Test Strategy > Approach | Bullet generic theo template gốc | Strategy đặc thù integration QC fill |
244
+
245
+ ---
246
+
247
+ ### Bước 4: Write — sinh draft
248
+
249
+ Tổng hợp và viết draft `test.md` theo `templates/integrations/test-template.md`:
250
+
251
+ - **Context** — tóm tắt từ Bước 2
252
+ - **Test Strategy** — placeholder + Environments table với placeholder rows
253
+ - **Changes** — 1 block per feature *có delta*, mỗi block có operation + content theo template gốc `templates/main/feature/tsd-template.md`. Feature no-delta → bỏ block.
254
+ - **Out of Scope** — empty với note QC fill
255
+ - **Open Questions** — list các item mà agent không thể derive deterministic (vd: FAC có wording vague, VR không rõ nhánh fail nào)
256
+ - **Cascade Summary** — table liệt kê **tất cả** feature trong `features:` (kể cả no-delta — ghi `no-op`)
257
+
258
+ Hiển thị **toàn bộ draft** cho QC xem — **chưa ghi file, chưa cascade**.
259
+
260
+ ---
261
+
262
+ ### Bước 5: Review — xác nhận với user
263
+
264
+ > Draft trên đã đúng chưa? QC điểm cần check:
265
+ >
266
+ > 1. **Mechanical derivation** — mỗi Flow / US / AC / VR / FAC trong frd đã có TC cover chưa? (xem Traceability Matrix)
267
+ > 2. **Priority defaults** — có TC nào cần override khỏi default không?
268
+ > 3. **Placeholders** — fill Environments / Test Data / Out of Scope / Strategy Approach.
269
+ > 4. **Extra edge cases** — ngoài AC/VR có scenario nào QC muốn thêm? (vd: exploratory, security boundary, race condition không có trong AC)
270
+ > 5. **Changes markers** — `[NEW]/[MODIFY]/[REMOVE]` có đúng không?
271
+ > 6. **No-delta features** — Cascade Summary có ghi `no-op` đúng cho feature không có delta không?
272
+ >
273
+ > **Sau khi confirm, agent sẽ auto-apply tất cả Changes blocks lên feature tsd.md(s).**
274
+
275
+ Nếu QC yêu cầu chỉnh sửa:
276
+ - Override priority → update draft
277
+ - Add extra TC → assign next ID, mark `[NEW]`
278
+ - Fill placeholder → update draft
279
+ - Remove TC khỏi draft → bỏ block hoặc đổi marker
280
+
281
+ Chỉ tiến hành Bước 6 sau khi QC confirm.
282
+
283
+ ---
284
+
285
+ ### Bước 6: Save + Auto-cascade
286
+
287
+ **[6.1] Ghi `specs/integrations/{slug}/test.md`** với status `approved` (không phải `draft` — human đã confirm ở Bước 5 chính là approval). Frontmatter `features` mirror từ `spec.md`.
288
+
289
+ **[6.2] Auto-apply mỗi Changes block** vào `feature/{F-XXX}/tsd.md` tương ứng. Thứ tự apply: theo thứ tự xuất hiện trong frontmatter `features` (deterministic, không có forward reference giữa các feature tsd.md). Bỏ qua feature có operation `no-op` trong Cascade Summary.
290
+
291
+ Cho từng block:
292
+
293
+ - **Operation=create:**
294
+ - Tạo file `specs/main/feature/{F-XXX}-{slug}/tsd.md`
295
+ - Nội dung = nội dung của Changes block (theo format `templates/main/feature/tsd-template.md`)
296
+ - Frontmatter của tsd.md mới: status `draft` (separate lifecycle với integration test.md)
297
+
298
+ - **Operation=update:**
299
+ - Đọc tsd.md hiện tại
300
+ - Với mỗi TS/TC trong Changes block:
301
+ - `[NEW]` → append/insert vào section tương ứng (giữ thứ tự numeric của ID)
302
+ - `[MODIFY {field}]` → tìm TS/TC bằng ID, update field đã chỉ định, giữ nguyên field khác
303
+ - `[REMOVE]` → xóa TS/TC khỏi tsd.md (ID retire, không tái sử dụng)
304
+ - Cập nhật Traceability Matrix: thêm row cho item mới, update row của item bị MODIFY, KHÔNG xóa row của REMOVE (đánh dấu retire)
305
+ - Ghi lại tsd.md
306
+
307
+ **[6.3] Atomic rollback:** Nếu apply block nào fail (vd `[MODIFY TC-F001-005]` nhưng ID không tồn tại):
308
+ 1. Rollback các block đã apply trước đó về state ban đầu
309
+ 2. **Không** ghi integration test.md
310
+ 3. Báo lỗi cụ thể cho QC fix draft hoặc feature tsd.md hiện tại
311
+
312
+ **[6.4] Thông báo kết quả:**
313
+
314
+ ```
315
+ ✓ specs/integrations/{slug}/test.md đã được tạo (status: approved)
316
+
317
+ Auto-cascade applied:
318
+ ✓ feature/F-XXX-{slug}/tsd.md — {created | updated: +N TS, +M TC, modify K TC, remove L TC}
319
+ ✓ feature/F-YYY-{slug}/tsd.md — no-op (frd không đổi)
320
+
321
+ Bước tiếp theo:
322
+ - QC: review feature tsd.md đã cascade, fill remaining TBD nếu có
323
+ - DEV: có thể run /plan nếu chưa có plan.md (plan.md hiện chưa consume tsd.md — test tasks tự QC manage trong test framework)
324
+ ```
325
+
326
+ ---
327
+
328
+ ## Common Rationalizations
329
+
330
+ | Rationalization | Reality |
331
+ | --- | --- |
332
+ | "TC có thể nghĩ ra khi chạy test" | Không document = không có traceability. AC pass/fail không kiểm tra được nếu không có TC mapping. |
333
+ | "VR positive đủ rồi, negative skip" | Negative case là nơi bug ẩn. Mỗi nhánh fail của VR phải có TC riêng. |
334
+ | "Priority để default hết P1 cho nhanh" | Priority decorative thì cũng phải đúng — derive deterministic từ US Priority/FAC group. P1 hàng loạt = QC chưa nhìn frd. |
335
+ | "Out of Scope để trống cũng được" | Mọi integration đều có thứ không test. Trống = scope creep hoặc gap không kiểm soát. |
336
+
337
+ ## Red Flags
338
+
339
+ - Traceability Matrix có item ❌ mà không có lý do ở Gaps section → agent silent skip
340
+ - TC có Covers trống → không trace được lên frd
341
+ - VR có ít hơn 2 TC (1 positive + 1+ negative) → coverage thiếu
342
+ - Priority hàng loạt giống nhau cho mọi TC → QC chưa override default
343
+ - Test Data toàn `TBD` sau khi QC review → chưa thật sự confirm
344
+ - Changes block có marker `[NEW]` cho TC trùng ID với TC đã có trong tsd.md hiện tại → diff bug
345
+ - Cascade Summary thiếu row cho feature trong `features:` (kể cả no-op) → không minh bạch
346
+
347
+ ## Verification
348
+
349
+ Trước khi QC confirm (Bước 5), kiểm tra:
350
+
351
+ - [ ] Mỗi Flow trong frd có 1 TS tương ứng
352
+ - [ ] Mỗi US AC có TC Functional cover
353
+ - [ ] Mỗi VR có ≥1 positive + ≥1 negative TC
354
+ - [ ] Mỗi FAC có TC Feature AC cover
355
+ - [ ] Traceability Matrix đầy đủ (không ❌ mà không giải thích)
356
+ - [ ] Priority deterministic theo bảng 3.3 (default), QC override visible
357
+ - [ ] ID assignment từ max(seq)+1, không tái sử dụng, không renumber
358
+ - [ ] Markers `[NEW]/[MODIFY {field}]/[REMOVE]` khớp diff vs current tsd.md
359
+ - [ ] Feature no-delta được ghi `no-op` trong Cascade Summary, KHÔNG có Changes block
360
+
361
+ Sau khi QC confirm (Bước 6):
362
+
363
+ - [ ] Auto-apply theo thứ tự features trong frontmatter
364
+ - [ ] Fail-safe: nếu apply fail thì không ghi integration test.md
365
+ - [ ] Mỗi feature tsd.md mới có status `draft` (separate lifecycle)
@@ -0,0 +1,230 @@
1
+ ---
2
+ name: spec-tsd
3
+ description: Tạo tsd.md (Test Spec Document) trực tiếp tại feature level từ frd.md — mechanical derive Test Scenarios + Test Cases. KHÔNG cần integration, không cascade. Dùng cho brownfield onboarding (sau /spec-brownfield-feature) hoặc greenfield bootstrap khi feature đã có frd.md nhưng chưa có tsd.md.
4
+ ---
5
+
6
+ # spec-tsd
7
+
8
+ ## Overview
9
+
10
+ Tạo `specs/main/feature/{F-XXX}-{slug}/tsd.md` trực tiếp từ frd.md của feature đó — **không qua integration**, không cascade.
11
+
12
+ Skill này song hành với `/spec-prd` và `/spec-sad`: skill có acronym suffix (`prd`/`sad`/`tsd`) → tạo main artifact trực tiếp. Phân biệt với `/spec-test` — skill đó tạo `test.md` integration-level và cascade qua Changes blocks.
13
+
14
+ ## When to Use
15
+
16
+ - **Brownfield onboarding** — sau `/spec-brownfield-feature` đã sinh frd.md, cần bootstrap tsd.md để có test coverage tracking ngay từ đầu.
17
+ - **Greenfield deferred** — feature có frd.md từ lâu nhưng tsd.md chưa được tạo (vd: test design bị defer).
18
+ - **Ad-hoc rebuild** — tsd.md drift quá xa khỏi frd.md, muốn regenerate fresh.
19
+
20
+ ## When NOT to Use
21
+
22
+ - Có integration mới và muốn cascade thay đổi frd lên tsd hiện tại → dùng `/spec-test` (changeset patch giữ ID stable)
23
+ - Chỉ muốn sửa vài TC → edit `tsd.md` trực tiếp
24
+ - Feature chưa có frd.md → chạy `/spec-brownfield-feature` (brownfield) hoặc `/spec-new` (greenfield) trước
25
+
26
+ ## Cảnh báo về ID stability
27
+
28
+ `/spec-tsd` **regenerate IDs từ 001** mỗi lần chạy. Nếu tsd.md đã tồn tại và đang được reference (vd: test code có `// covers TC-F001-005`), rebuild sẽ làm vỡ những reference đó.
29
+
30
+ Quy tắc:
31
+ - **tsd.md chưa tồn tại** → an toàn, không có reference, regenerate fresh.
32
+ - **tsd.md tồn tại** → skill hỏi confirm rõ ràng trước khi overwrite. Khuyến nghị: dùng `/spec-test` qua integration changeset để preserve ID stable.
33
+
34
+ ---
35
+
36
+ ## Process
37
+
38
+ ### Bước 1: Xác định feature
39
+
40
+ **Nếu có ARGUMENT:**
41
+ - Parse argument: có thể là feature ID (`F-001`, `001`) hoặc slug (`F-001-auth`, `auth`)
42
+ - Quét `specs/main/feature/*/frd.md`, tìm feature khớp
43
+ - Nếu không tìm thấy → báo lỗi:
44
+ > Không tìm thấy feature khớp với "{argument}". Kiểm tra `specs/main/feature/`.
45
+
46
+ **Nếu không có ARGUMENT:**
47
+
48
+ Quét `specs/main/feature/`. Liệt kê **tất cả** features có `frd.md`, đánh dấu trạng thái tsd:
49
+
50
+ ```
51
+ Features có frd.md:
52
+
53
+ [1] F-001 — auth spec✓ tsd✓
54
+ [2] F-002 — checkout spec✓ tsd—
55
+ [3] F-003 — refund spec✓ tsd— (frd có 5 Flow, 12 US, 8 VR, 3 FAC)
56
+
57
+ Chọn số feature:
58
+ ```
59
+
60
+ Nếu không có feature nào có frd → thông báo:
61
+ > Chưa có feature nào có frd.md. Hãy chạy `/spec-brownfield-feature` hoặc `/spec-new` trước.
62
+
63
+ ---
64
+
65
+ ### Bước 2: Gate check — frd.md tồn tại + warn nếu tsd.md đã có
66
+
67
+ **Check 1 — frd.md tồn tại:**
68
+
69
+ Nếu `specs/main/feature/{F-XXX}-{slug}/frd.md` không tồn tại → dừng:
70
+ > ⛔ `feature/{F-XXX}-{slug}/frd.md` không tồn tại. `/spec-tsd` cần frd làm input.
71
+
72
+ **Check 2 — tsd.md đã tồn tại:**
73
+
74
+ Nếu `specs/main/feature/{F-XXX}-{slug}/tsd.md` đã tồn tại:
75
+
76
+ > ⚠ `tsd.md` đã tồn tại cho feature **{F-XXX} — {slug}**.
77
+ >
78
+ > `/spec-tsd` regenerate IDs từ 001 — nếu có test code đang reference TC-{F_ID}-NNN hoặc TS-{F_ID}-NNN, references sẽ bị vỡ.
79
+ >
80
+ > Khuyến nghị: dùng `/spec-test` qua integration changeset để giữ ID stable.
81
+ >
82
+ > Tiếp tục overwrite? (yes / no — default no)
83
+
84
+ Nếu user chọn no → dừng, suggest `/spec-test`.
85
+ Nếu user chọn yes → backup tsd.md cũ thành `tsd.md.bak.{timestamp}` rồi proceed.
86
+
87
+ ---
88
+
89
+ ### Bước 3: Load context
90
+
91
+ Load các file sau:
92
+
93
+ - `specs/main/feature/{F-XXX}-{slug}/frd.md` — **bắt buộc**, source của TC
94
+ - `specs/main/feature/{F-XXX}-{slug}/fdd.md` — optional, đọc nếu tồn tại để hint Components Used (cho Dependencies section của tsd)
95
+
96
+ Tóm tắt context:
97
+
98
+ ```
99
+ TÔI HIỂU:
100
+ - Feature: {F-XXX} — {slug}
101
+ - Trong frd.md:
102
+ - {N} Flows
103
+ - {M} User Stories ({K} Acceptance Criteria)
104
+ - {P} Verification Rules
105
+ - {Q} Feature Acceptance Criteria
106
+ - tsd.md hiện tại: {chưa có / sẽ overwrite — backup tại tsd.md.bak.{timestamp}}
107
+ - fdd.md: {tồn tại — Components Used: C-XXX, C-YYY / chưa có}
108
+ ```
109
+
110
+ ---
111
+
112
+ ### Bước 4: Auto-derive draft
113
+
114
+ **Nguyên tắc:** mechanical derive 1:1 từ frd.md — same algorithm như `/spec-test` (xem [skills/spec-test/SKILL.md](../spec-test/SKILL.md) Bước 3.1-3.3). Tóm lại:
115
+
116
+ #### 4.1 ID assignment
117
+
118
+ - IDs bắt đầu từ `001` (vì tạo mới hoặc regenerate). TS và TC cùng feature ID `F{NNN}`, TC dùng chung sequence cho Functional / Validation / Feature AC.
119
+ - ID sẽ stable kể từ thời điểm này — lần edit tiếp theo qua `/spec-test` integration phải preserve.
120
+
121
+ #### 4.2 Derivation rules
122
+
123
+ | frd item | tsd output |
124
+ | --- | --- |
125
+ | Mỗi `Flow {N}` trong User Flows | 1 Test Scenario `TS-F{NNN}-{seq}` |
126
+ | Mỗi `AC-F{NNN}-{seq}` trong US | 1 Functional TC `TC-F{NNN}-{seq}` |
127
+ | Mỗi `VR-F{NNN}-{seq}` | 1 positive + 1+ negative Validation TC |
128
+ | Mỗi `FAC-F{NNN}-{seq}` | 1 Feature AC TC |
129
+
130
+ Detail dịch G/W/T → Preconditions/Steps/Expected, infer negative VR branches từ rule text — xem `/spec-test` Bước 3.2.
131
+
132
+ #### 4.3 Priority defaults
133
+
134
+ | Source | Priority |
135
+ | --- | --- |
136
+ | TC cover US Must | P0 |
137
+ | TC cover US Should | P1 |
138
+ | TC cover US Could | P2 |
139
+ | TC cover VR | inherit max priority của Refs (P1 default nếu Refs trống) |
140
+ | TC cover FAC e2e | P0 |
141
+ | TC cover FAC consistency | P1 |
142
+ | TC cover FAC NFR security/data | P0 |
143
+ | TC cover FAC NFR perf/a11y/i18n/browser | P1 |
144
+ | TC cover FAC data & migration | P0 |
145
+
146
+ #### 4.4 Traceability Matrix
147
+
148
+ Row per frd item — Flow / US / Story AC / VR / FAC. Mọi item phải có cover ✅. Item không thể derive → ❌ + ghi lý do ở Gaps section.
149
+
150
+ #### 4.5 Placeholders cần QC fill
151
+
152
+ Agent **không suy đoán**:
153
+
154
+ | Field | Placeholder |
155
+ | --- | --- |
156
+ | Environments table | Row mặc định `dev / staging / prod-like` với data set `TBD`, mục đích `TBD` |
157
+ | Test Data table | Row `{TBD — fixture}` cho mỗi dataset thấy cần |
158
+ | Out of Scope | Để trống với note `<!-- QC fill -->` |
159
+ | Test Strategy > Approach | Bullet generic theo template gốc |
160
+ | Overview | 2-3 câu mô tả feature scope từ frd Overview |
161
+
162
+ #### 4.6 Dependencies section
163
+
164
+ - **FRD reference**: path tới `frd.md` của feature này
165
+ - **Components Used**: copy từ `frd.md > Components Used`. Nếu fdd.md tồn tại → cross-reference C-XXX để đảm bảo đúng.
166
+
167
+ ---
168
+
169
+ ### Bước 5: Review — xác nhận với QC
170
+
171
+ Hiển thị draft đầy đủ — chưa ghi file.
172
+
173
+ > Draft tsd.md trên đã đúng chưa? Check:
174
+ >
175
+ > 1. **Coverage** — Traceability Matrix có đủ row cho mỗi Flow / US / AC / VR / FAC trong frd?
176
+ > 2. **Priority** — defaults theo bảng 4.3, có TC nào cần override?
177
+ > 3. **Placeholders** — fill Environments / Test Data / Out of Scope / Strategy Approach.
178
+ > 4. **Extra edge cases** — ngoài AC/VR có scenario QC muốn thêm?
179
+ >
180
+ > Confirm để ghi file. Reject để revise.
181
+
182
+ ---
183
+
184
+ ### Bước 6: Save
185
+
186
+ Ghi `specs/main/feature/{F-XXX}-{slug}/tsd.md` với status `draft` (feature-level artifact có lifecycle riêng, không phải `approved` — QC còn fill placeholders nên status `draft` cho đến khi đầy đủ).
187
+
188
+ Nếu overwrite — file backup `tsd.md.bak.{timestamp}` đã tạo ở Bước 2.
189
+
190
+ Thông báo kết quả:
191
+
192
+ ```
193
+ ✓ specs/main/feature/{F-XXX}-{slug}/tsd.md đã được tạo (status: draft)
194
+ Coverage: N Flows → N TS, M US/AC → M Functional TC, P VR → ~2P Validation TC, Q FAC → Q Feature AC TC
195
+ {nếu overwrite: backup tại tsd.md.bak.{timestamp}}
196
+
197
+ Bước tiếp theo:
198
+ - QC: fill remaining placeholders (Environments, Test Data, Out of Scope, Strategy)
199
+ - Đổi status: draft → approved khi sẵn sàng
200
+ - Sau này: nếu frd thay đổi → dùng /spec-test qua integration changeset để giữ ID stable
201
+ ```
202
+
203
+ ---
204
+
205
+ ## Common Rationalizations
206
+
207
+ | Rationalization | Reality |
208
+ | --- | --- |
209
+ | "Có frd rồi, viết tsd sau cũng được" | Test coverage không tracked = không biết feature đóng được chưa. tsd làm song song với frd, không sau. |
210
+ | "Rebuild tsd nhanh hơn cập nhật manual" | Đúng cho lần đầu. Lần sau khi đã có test code reference → rebuild sẽ break references. Lúc đó dùng `/spec-test`. |
211
+ | "Brownfield không cần tsd, đã có test code" | Test code là HOW. tsd là WHAT — declarative TC list để track coverage vs frd. Hai layer khác nhau. |
212
+
213
+ ## Red Flags
214
+
215
+ - Traceability Matrix có ❌ mà không có Gaps section giải thích
216
+ - Priority hàng loạt P1 — chưa override theo defaults
217
+ - Test Strategy / Test Data toàn `TBD` sau khi QC review xong
218
+ - Overwrite tsd.md hiện có mà không cảnh báo về ID break
219
+
220
+ ## Verification
221
+
222
+ Trước khi ghi file:
223
+
224
+ - [ ] Mỗi Flow trong frd có 1 TS
225
+ - [ ] Mỗi US AC có TC Functional cover
226
+ - [ ] Mỗi VR có ≥1 positive + ≥1 negative TC
227
+ - [ ] Mỗi FAC có TC Feature AC cover
228
+ - [ ] Priority deterministic theo bảng 4.3
229
+ - [ ] Nếu overwrite: tsd.md.bak.{timestamp} đã được tạo
230
+ - [ ] QC đã confirm draft