@howlil/ez-agents 3.4.1 → 3.5.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 (162) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +84 -20
  3. package/agents/ez-observer-agent.md +260 -0
  4. package/agents/ez-release-agent.md +333 -0
  5. package/agents/ez-requirements-agent.md +377 -0
  6. package/agents/ez-scrum-master-agent.md +242 -0
  7. package/agents/ez-tech-lead-agent.md +267 -0
  8. package/bin/install.js +3221 -3230
  9. package/commands/ez/arch-review.md +102 -0
  10. package/commands/ez/execute-phase.md +11 -0
  11. package/commands/ez/export-session.md +79 -0
  12. package/commands/ez/gather-requirements.md +117 -0
  13. package/commands/ez/git-workflow.md +72 -0
  14. package/commands/ez/hotfix.md +120 -0
  15. package/commands/ez/import-session.md +82 -0
  16. package/commands/ez/join-discord.md +18 -18
  17. package/commands/ez/list-sessions.md +96 -0
  18. package/commands/ez/package-manager.md +316 -0
  19. package/commands/ez/plan-phase.md +9 -1
  20. package/commands/ez/preflight.md +79 -0
  21. package/commands/ez/progress.md +13 -1
  22. package/commands/ez/release.md +153 -0
  23. package/commands/ez/resume.md +107 -0
  24. package/commands/ez/standup.md +85 -0
  25. package/ez-agents/bin/ez-tools.cjs +1095 -716
  26. package/ez-agents/bin/lib/assistant-adapter.cjs +264 -264
  27. package/ez-agents/bin/lib/audit-exec.cjs +7 -2
  28. package/ez-agents/bin/lib/bdd-validator.cjs +622 -0
  29. package/ez-agents/bin/lib/circuit-breaker.cjs +118 -118
  30. package/ez-agents/bin/lib/config.cjs +190 -190
  31. package/ez-agents/bin/lib/content-scanner.cjs +238 -0
  32. package/ez-agents/bin/lib/context-cache.cjs +154 -0
  33. package/ez-agents/bin/lib/context-errors.cjs +71 -0
  34. package/ez-agents/bin/lib/context-manager.cjs +220 -0
  35. package/ez-agents/bin/lib/discussion-synthesizer.cjs +458 -0
  36. package/ez-agents/bin/lib/file-access.cjs +207 -0
  37. package/ez-agents/bin/lib/file-lock.cjs +236 -236
  38. package/ez-agents/bin/lib/frontmatter.cjs +299 -299
  39. package/ez-agents/bin/lib/fs-utils.cjs +153 -153
  40. package/ez-agents/bin/lib/git-errors.cjs +83 -0
  41. package/ez-agents/bin/lib/git-utils.cjs +118 -0
  42. package/ez-agents/bin/lib/git-workflow-engine.cjs +1157 -0
  43. package/ez-agents/bin/lib/index.cjs +157 -113
  44. package/ez-agents/bin/lib/init.cjs +757 -757
  45. package/ez-agents/bin/lib/lockfile-validator.cjs +227 -0
  46. package/ez-agents/bin/lib/logger.cjs +124 -124
  47. package/ez-agents/bin/lib/memory-compression.cjs +256 -0
  48. package/ez-agents/bin/lib/metrics-tracker.cjs +406 -0
  49. package/ez-agents/bin/lib/milestone.cjs +241 -241
  50. package/ez-agents/bin/lib/model-provider.cjs +241 -241
  51. package/ez-agents/bin/lib/package-manager-detector.cjs +203 -0
  52. package/ez-agents/bin/lib/package-manager-executor.cjs +385 -0
  53. package/ez-agents/bin/lib/package-manager-service.cjs +216 -0
  54. package/ez-agents/bin/lib/phase.cjs +925 -925
  55. package/ez-agents/bin/lib/planning-write.cjs +107 -107
  56. package/ez-agents/bin/lib/release-validator.cjs +614 -0
  57. package/ez-agents/bin/lib/retry.cjs +119 -119
  58. package/ez-agents/bin/lib/roadmap.cjs +306 -306
  59. package/ez-agents/bin/lib/safe-exec.cjs +128 -128
  60. package/ez-agents/bin/lib/safe-path.cjs +130 -130
  61. package/ez-agents/bin/lib/session-chain.cjs +304 -0
  62. package/ez-agents/bin/lib/session-errors.cjs +81 -0
  63. package/ez-agents/bin/lib/session-export.cjs +251 -0
  64. package/ez-agents/bin/lib/session-import.cjs +262 -0
  65. package/ez-agents/bin/lib/session-manager.cjs +280 -0
  66. package/ez-agents/bin/lib/state.cjs +736 -736
  67. package/ez-agents/bin/lib/temp-file.cjs +239 -239
  68. package/ez-agents/bin/lib/template.cjs +223 -223
  69. package/ez-agents/bin/lib/test-file-lock.cjs +112 -112
  70. package/ez-agents/bin/lib/test-graceful.cjs +93 -93
  71. package/ez-agents/bin/lib/test-logger.cjs +60 -60
  72. package/ez-agents/bin/lib/test-safe-exec.cjs +38 -38
  73. package/ez-agents/bin/lib/test-safe-path.cjs +33 -33
  74. package/ez-agents/bin/lib/test-temp-file.cjs +125 -125
  75. package/ez-agents/bin/lib/tier-manager.cjs +428 -0
  76. package/ez-agents/bin/lib/timeout-exec.cjs +63 -63
  77. package/ez-agents/bin/lib/url-fetch.cjs +170 -0
  78. package/ez-agents/bin/lib/verify.cjs +15 -1
  79. package/ez-agents/references/checkpoints.md +776 -776
  80. package/ez-agents/references/continuation-format.md +249 -249
  81. package/ez-agents/references/metrics-schema.md +118 -0
  82. package/ez-agents/references/planning-config.md +140 -0
  83. package/ez-agents/references/questioning.md +162 -162
  84. package/ez-agents/references/tdd.md +263 -263
  85. package/ez-agents/references/tier-strategy.md +103 -0
  86. package/ez-agents/templates/bdd-feature.md +173 -0
  87. package/ez-agents/templates/codebase/concerns.md +310 -310
  88. package/ez-agents/templates/codebase/conventions.md +307 -307
  89. package/ez-agents/templates/codebase/integrations.md +280 -280
  90. package/ez-agents/templates/codebase/stack.md +186 -186
  91. package/ez-agents/templates/codebase/testing.md +480 -480
  92. package/ez-agents/templates/config.json +37 -37
  93. package/ez-agents/templates/continue-here.md +78 -78
  94. package/ez-agents/templates/discussion.md +68 -0
  95. package/ez-agents/templates/incident-runbook.md +205 -0
  96. package/ez-agents/templates/milestone-archive.md +123 -123
  97. package/ez-agents/templates/milestone.md +115 -115
  98. package/ez-agents/templates/release-checklist.md +133 -0
  99. package/ez-agents/templates/requirements.md +231 -231
  100. package/ez-agents/templates/research-project/ARCHITECTURE.md +204 -204
  101. package/ez-agents/templates/research-project/FEATURES.md +147 -147
  102. package/ez-agents/templates/research-project/PITFALLS.md +200 -200
  103. package/ez-agents/templates/research-project/STACK.md +120 -120
  104. package/ez-agents/templates/research-project/SUMMARY.md +170 -170
  105. package/ez-agents/templates/retrospective.md +54 -54
  106. package/ez-agents/templates/roadmap.md +202 -202
  107. package/ez-agents/templates/rollback-plan.md +201 -0
  108. package/ez-agents/templates/summary-minimal.md +41 -41
  109. package/ez-agents/templates/summary-standard.md +48 -48
  110. package/ez-agents/templates/summary.md +248 -248
  111. package/ez-agents/templates/user-setup.md +311 -311
  112. package/ez-agents/templates/verification-report.md +322 -322
  113. package/ez-agents/workflows/add-phase.md +112 -112
  114. package/ez-agents/workflows/add-tests.md +351 -351
  115. package/ez-agents/workflows/add-todo.md +158 -158
  116. package/ez-agents/workflows/arch-review.md +54 -0
  117. package/ez-agents/workflows/audit-milestone.md +332 -332
  118. package/ez-agents/workflows/autonomous.md +131 -30
  119. package/ez-agents/workflows/check-todos.md +177 -177
  120. package/ez-agents/workflows/cleanup.md +152 -152
  121. package/ez-agents/workflows/complete-milestone.md +766 -766
  122. package/ez-agents/workflows/diagnose-issues.md +219 -219
  123. package/ez-agents/workflows/discovery-phase.md +289 -289
  124. package/ez-agents/workflows/discuss-phase.md +762 -762
  125. package/ez-agents/workflows/execute-phase.md +513 -468
  126. package/ez-agents/workflows/execute-plan.md +483 -483
  127. package/ez-agents/workflows/export-session.md +255 -0
  128. package/ez-agents/workflows/gather-requirements.md +206 -0
  129. package/ez-agents/workflows/health.md +159 -159
  130. package/ez-agents/workflows/help.md +584 -492
  131. package/ez-agents/workflows/hotfix.md +291 -0
  132. package/ez-agents/workflows/import-session.md +303 -0
  133. package/ez-agents/workflows/insert-phase.md +130 -130
  134. package/ez-agents/workflows/list-phase-assumptions.md +178 -178
  135. package/ez-agents/workflows/map-codebase.md +316 -316
  136. package/ez-agents/workflows/new-milestone.md +339 -10
  137. package/ez-agents/workflows/new-project.md +293 -299
  138. package/ez-agents/workflows/node-repair.md +92 -92
  139. package/ez-agents/workflows/pause-work.md +122 -122
  140. package/ez-agents/workflows/plan-milestone-gaps.md +274 -274
  141. package/ez-agents/workflows/plan-phase.md +673 -651
  142. package/ez-agents/workflows/progress.md +372 -382
  143. package/ez-agents/workflows/quick.md +610 -610
  144. package/ez-agents/workflows/release.md +253 -0
  145. package/ez-agents/workflows/remove-phase.md +155 -155
  146. package/ez-agents/workflows/research-phase.md +74 -74
  147. package/ez-agents/workflows/resume-project.md +307 -307
  148. package/ez-agents/workflows/resume-session.md +215 -0
  149. package/ez-agents/workflows/set-profile.md +81 -81
  150. package/ez-agents/workflows/settings.md +242 -242
  151. package/ez-agents/workflows/standup.md +64 -0
  152. package/ez-agents/workflows/stats.md +57 -57
  153. package/ez-agents/workflows/transition.md +544 -544
  154. package/ez-agents/workflows/ui-phase.md +290 -290
  155. package/ez-agents/workflows/ui-review.md +157 -157
  156. package/ez-agents/workflows/update.md +320 -320
  157. package/ez-agents/workflows/validate-phase.md +167 -167
  158. package/ez-agents/workflows/verify-phase.md +243 -243
  159. package/ez-agents/workflows/verify-work.md +584 -584
  160. package/package.json +10 -4
  161. package/scripts/build-hooks.js +43 -43
  162. package/scripts/run-tests.cjs +29 -29
@@ -1,351 +1,351 @@
1
- <purpose>
2
- Generate unit and E2E tests for a completed phase based on its SUMMARY.md, CONTEXT.md, and implementation. Classifies each changed file into TDD (unit), E2E (browser), or Skip categories, presents a test plan for user approval, then generates tests following RED-GREEN conventions.
3
-
4
- Users currently hand-craft `/ez:quick` prompts for test generation after each phase. This workflow standardizes the process with proper classification, quality gates, and gap reporting.
5
- </purpose>
6
-
7
- <required_reading>
8
- Read all files referenced by the invoking prompt's execution_context before starting.
9
- </required_reading>
10
-
11
- <process>
12
-
13
- <step name="parse_arguments">
14
- Parse `$ARGUMENTS` for:
15
- - Phase number (integer, decimal, or letter-suffix) → store as `$PHASE_ARG`
16
- - Remaining text after phase number → store as `$EXTRA_INSTRUCTIONS` (optional)
17
-
18
- Example: `/ez:add-tests 12 focus on edge cases` → `$PHASE_ARG=12`, `$EXTRA_INSTRUCTIONS="focus on edge cases"`
19
-
20
- If no phase argument provided:
21
-
22
- ```
23
- ERROR: Phase number required
24
- Usage: /ez:add-tests <phase> [additional instructions]
25
- Example: /ez:add-tests 12
26
- Example: /ez:add-tests 12 focus on edge cases in the pricing module
27
- ```
28
-
29
- Exit.
30
- </step>
31
-
32
- <step name="init_context">
33
- Load phase operation context:
34
-
35
- ```bash
36
- INIT=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init phase-op "${PHASE_ARG}")
37
- if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
38
- ```
39
-
40
- Extract from init JSON: `phase_dir`, `phase_number`, `phase_name`.
41
-
42
- Verify the phase directory exists. If not:
43
- ```
44
- ERROR: Phase directory not found for phase ${PHASE_ARG}
45
- Ensure the phase exists in .planning/phases/
46
- ```
47
- Exit.
48
-
49
- Read the phase artifacts (in order of priority):
50
- 1. `${phase_dir}/*-SUMMARY.md` — what was implemented, files changed
51
- 2. `${phase_dir}/CONTEXT.md` — acceptance criteria, decisions
52
- 3. `${phase_dir}/*-VERIFICATION.md` — user-verified scenarios (if UAT was done)
53
-
54
- If no SUMMARY.md exists:
55
- ```
56
- ERROR: No SUMMARY.md found for phase ${PHASE_ARG}
57
- This command works on completed phases. Run /ez:execute-phase first.
58
- ```
59
- Exit.
60
-
61
- Present banner:
62
- ```
63
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
64
- EZ ► ADD TESTS — Phase ${phase_number}: ${phase_name}
65
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
66
- ```
67
- </step>
68
-
69
- <step name="analyze_implementation">
70
- Extract the list of files modified by the phase from SUMMARY.md ("Files Changed" or equivalent section).
71
-
72
- For each file, classify into one of three categories:
73
-
74
- | Category | Criteria | Test Type |
75
- |----------|----------|-----------|
76
- | **TDD** | Pure functions where `expect(fn(input)).toBe(output)` is writable | Unit tests |
77
- | **E2E** | UI behavior verifiable by browser automation | Playwright/E2E tests |
78
- | **Skip** | Not meaningfully testable or already covered | None |
79
-
80
- **TDD classification — apply when:**
81
- - Business logic: calculations, pricing, tax rules, validation
82
- - Data transformations: mapping, filtering, aggregation, formatting
83
- - Parsers: CSV, JSON, XML, custom format parsing
84
- - Validators: input validation, schema validation, business rules
85
- - State machines: status transitions, workflow steps
86
- - Utilities: string manipulation, date handling, number formatting
87
-
88
- **E2E classification — apply when:**
89
- - Keyboard shortcuts: key bindings, modifier keys, chord sequences
90
- - Navigation: page transitions, routing, breadcrumbs, back/forward
91
- - Form interactions: submit, validation errors, field focus, autocomplete
92
- - Selection: row selection, multi-select, shift-click ranges
93
- - Drag and drop: reordering, moving between containers
94
- - Modal dialogs: open, close, confirm, cancel
95
- - Data grids: sorting, filtering, inline editing, column resize
96
-
97
- **Skip classification — apply when:**
98
- - UI layout/styling: CSS classes, visual appearance, responsive breakpoints
99
- - Configuration: config files, environment variables, feature flags
100
- - Glue code: dependency injection setup, middleware registration, routing tables
101
- - Migrations: database migrations, schema changes
102
- - Simple CRUD: basic create/read/update/delete with no business logic
103
- - Type definitions: records, DTOs, interfaces with no logic
104
-
105
- Read each file to verify classification. Don't classify based on filename alone.
106
- </step>
107
-
108
- <step name="present_classification">
109
- Present the classification to the user for confirmation before proceeding:
110
-
111
- ```
112
- AskUserQuestion(
113
- header: "Test Classification",
114
- question: |
115
- ## Files classified for testing
116
-
117
- ### TDD (Unit Tests) — {N} files
118
- {list of files with brief reason}
119
-
120
- ### E2E (Browser Tests) — {M} files
121
- {list of files with brief reason}
122
-
123
- ### Skip — {K} files
124
- {list of files with brief reason}
125
-
126
- {if $EXTRA_INSTRUCTIONS: "Additional instructions: ${EXTRA_INSTRUCTIONS}"}
127
-
128
- How would you like to proceed?
129
- options:
130
- - "Approve and generate test plan"
131
- - "Adjust classification (I'll specify changes)"
132
- - "Cancel"
133
- )
134
- ```
135
-
136
- If user selects "Adjust classification": apply their changes and re-present.
137
- If user selects "Cancel": exit gracefully.
138
- </step>
139
-
140
- <step name="discover_test_structure">
141
- Before generating the test plan, discover the project's existing test structure:
142
-
143
- ```bash
144
- # Find existing test directories
145
- find . -type d -name "*test*" -o -name "*spec*" -o -name "*__tests__*" 2>/dev/null | head -20
146
- # Find existing test files for convention matching
147
- find . -type f \( -name "*.test.*" -o -name "*.spec.*" -o -name "*Tests.fs" -o -name "*Test.fs" \) 2>/dev/null | head -20
148
- # Check for test runners
149
- ls package.json *.sln 2>/dev/null
150
- ```
151
-
152
- Identify:
153
- - Test directory structure (where unit tests live, where E2E tests live)
154
- - Naming conventions (`.test.ts`, `.spec.ts`, `*Tests.fs`, etc.)
155
- - Test runner commands (how to execute unit tests, how to execute E2E tests)
156
- - Test framework (xUnit, NUnit, Jest, Playwright, etc.)
157
-
158
- If test structure is ambiguous, ask the user:
159
- ```
160
- AskUserQuestion(
161
- header: "Test Structure",
162
- question: "I found multiple test locations. Where should I create tests?",
163
- options: [list discovered locations]
164
- )
165
- ```
166
- </step>
167
-
168
- <step name="generate_test_plan">
169
- For each approved file, create a detailed test plan.
170
-
171
- **For TDD files**, plan tests following RED-GREEN-REFACTOR:
172
- 1. Identify testable functions/methods in the file
173
- 2. For each function: list input scenarios, expected outputs, edge cases
174
- 3. Note: since code already exists, tests may pass immediately — that's OK, but verify they test the RIGHT behavior
175
-
176
- **For E2E files**, plan tests following RED-GREEN gates:
177
- 1. Identify user scenarios from CONTEXT.md/VERIFICATION.md
178
- 2. For each scenario: describe the user action, expected outcome, assertions
179
- 3. Note: RED gate means confirming the test would fail if the feature were broken
180
-
181
- Present the complete test plan:
182
-
183
- ```
184
- AskUserQuestion(
185
- header: "Test Plan",
186
- question: |
187
- ## Test Generation Plan
188
-
189
- ### Unit Tests ({N} tests across {M} files)
190
- {for each file: test file path, list of test cases}
191
-
192
- ### E2E Tests ({P} tests across {Q} files)
193
- {for each file: test file path, list of test scenarios}
194
-
195
- ### Test Commands
196
- - Unit: {discovered test command}
197
- - E2E: {discovered e2e command}
198
-
199
- Ready to generate?
200
- options:
201
- - "Generate all"
202
- - "Cherry-pick (I'll specify which)"
203
- - "Adjust plan"
204
- )
205
- ```
206
-
207
- If "Cherry-pick": ask user which tests to include.
208
- If "Adjust plan": apply changes and re-present.
209
- </step>
210
-
211
- <step name="execute_tdd_generation">
212
- For each approved TDD test:
213
-
214
- 1. **Create test file** following discovered project conventions (directory, naming, imports)
215
-
216
- 2. **Write test** with clear arrange/act/assert structure:
217
- ```
218
- // Arrange — set up inputs and expected outputs
219
- // Act — call the function under test
220
- // Assert — verify the output matches expectations
221
- ```
222
-
223
- 3. **Run the test**:
224
- ```bash
225
- {discovered test command}
226
- ```
227
-
228
- 4. **Evaluate result:**
229
- - **Test passes**: Good — the implementation satisfies the test. Verify the test checks meaningful behavior (not just that it compiles).
230
- - **Test fails with assertion error**: This may be a genuine bug discovered by the test. Flag it:
231
- ```
232
- ⚠️ Potential bug found: {test name}
233
- Expected: {expected}
234
- Actual: {actual}
235
- File: {implementation file}
236
- ```
237
- Do NOT fix the implementation — this is a test-generation command, not a fix command. Record the finding.
238
- - **Test fails with error (import, syntax, etc.)**: This is a test error. Fix the test and re-run.
239
- </step>
240
-
241
- <step name="execute_e2e_generation">
242
- For each approved E2E test:
243
-
244
- 1. **Check for existing tests** covering the same scenario:
245
- ```bash
246
- grep -r "{scenario keyword}" {e2e test directory} 2>/dev/null
247
- ```
248
- If found, extend rather than duplicate.
249
-
250
- 2. **Create test file** targeting the user scenario from CONTEXT.md/VERIFICATION.md
251
-
252
- 3. **Run the E2E test**:
253
- ```bash
254
- {discovered e2e command}
255
- ```
256
-
257
- 4. **Evaluate result:**
258
- - **GREEN (passes)**: Record success
259
- - **RED (fails)**: Determine if it's a test issue or a genuine application bug. Flag bugs:
260
- ```
261
- ⚠️ E2E failure: {test name}
262
- Scenario: {description}
263
- Error: {error message}
264
- ```
265
- - **Cannot run**: Report blocker. Do NOT mark as complete.
266
- ```
267
- 🛑 E2E blocker: {reason tests cannot run}
268
- ```
269
-
270
- **No-skip rule:** If E2E tests cannot execute (missing dependencies, environment issues), report the blocker and mark the test as incomplete. Never mark success without actually running the test.
271
- </step>
272
-
273
- <step name="summary_and_commit">
274
- Create a test coverage report and present to user:
275
-
276
- ```
277
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
278
- EZ ► TEST GENERATION COMPLETE
279
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
280
-
281
- ## Results
282
-
283
- | Category | Generated | Passing | Failing | Blocked |
284
- |----------|-----------|---------|---------|---------|
285
- | Unit | {N} | {n1} | {n2} | {n3} |
286
- | E2E | {M} | {m1} | {m2} | {m3} |
287
-
288
- ## Files Created/Modified
289
- {list of test files with paths}
290
-
291
- ## Coverage Gaps
292
- {areas that couldn't be tested and why}
293
-
294
- ## Bugs Discovered
295
- {any assertion failures that indicate implementation bugs}
296
- ```
297
-
298
- Record test generation in project state:
299
- ```bash
300
- node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" state-snapshot
301
- ```
302
-
303
- If there are passing tests to commit:
304
-
305
- ```bash
306
- git add {test files}
307
- git commit -m "test(phase-${phase_number}): add unit and E2E tests from add-tests command"
308
- ```
309
-
310
- Present next steps:
311
-
312
- ```
313
- ---
314
-
315
- ## ▶ Next Up
316
-
317
- {if bugs discovered:}
318
- **Fix discovered bugs:** `/ez:quick fix the {N} test failures discovered in phase ${phase_number}`
319
-
320
- {if blocked tests:}
321
- **Resolve test blockers:** {description of what's needed}
322
-
323
- {otherwise:}
324
- **All tests passing!** Phase ${phase_number} is fully tested.
325
-
326
- ---
327
-
328
- **Also available:**
329
- - `/ez:add-tests {next_phase}` — test another phase
330
- - `/ez:verify-work {phase_number}` — run UAT verification
331
-
332
- ---
333
- ```
334
- </step>
335
-
336
- </process>
337
-
338
- <success_criteria>
339
- - [ ] Phase artifacts loaded (SUMMARY.md, CONTEXT.md, optionally VERIFICATION.md)
340
- - [ ] All changed files classified into TDD/E2E/Skip categories
341
- - [ ] Classification presented to user and approved
342
- - [ ] Project test structure discovered (directories, conventions, runners)
343
- - [ ] Test plan presented to user and approved
344
- - [ ] TDD tests generated with arrange/act/assert structure
345
- - [ ] E2E tests generated targeting user scenarios
346
- - [ ] All tests executed — no untested tests marked as passing
347
- - [ ] Bugs discovered by tests flagged (not fixed)
348
- - [ ] Test files committed with proper message
349
- - [ ] Coverage gaps documented
350
- - [ ] Next steps presented to user
351
- </success_criteria>
1
+ <purpose>
2
+ Generate unit and E2E tests for a completed phase based on its SUMMARY.md, CONTEXT.md, and implementation. Classifies each changed file into TDD (unit), E2E (browser), or Skip categories, presents a test plan for user approval, then generates tests following RED-GREEN conventions.
3
+
4
+ Users currently hand-craft `/ez:quick` prompts for test generation after each phase. This workflow standardizes the process with proper classification, quality gates, and gap reporting.
5
+ </purpose>
6
+
7
+ <required_reading>
8
+ Read all files referenced by the invoking prompt's execution_context before starting.
9
+ </required_reading>
10
+
11
+ <process>
12
+
13
+ <step name="parse_arguments">
14
+ Parse `$ARGUMENTS` for:
15
+ - Phase number (integer, decimal, or letter-suffix) → store as `$PHASE_ARG`
16
+ - Remaining text after phase number → store as `$EXTRA_INSTRUCTIONS` (optional)
17
+
18
+ Example: `/ez:add-tests 12 focus on edge cases` → `$PHASE_ARG=12`, `$EXTRA_INSTRUCTIONS="focus on edge cases"`
19
+
20
+ If no phase argument provided:
21
+
22
+ ```
23
+ ERROR: Phase number required
24
+ Usage: /ez:add-tests <phase> [additional instructions]
25
+ Example: /ez:add-tests 12
26
+ Example: /ez:add-tests 12 focus on edge cases in the pricing module
27
+ ```
28
+
29
+ Exit.
30
+ </step>
31
+
32
+ <step name="init_context">
33
+ Load phase operation context:
34
+
35
+ ```bash
36
+ INIT=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init phase-op "${PHASE_ARG}")
37
+ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
38
+ ```
39
+
40
+ Extract from init JSON: `phase_dir`, `phase_number`, `phase_name`.
41
+
42
+ Verify the phase directory exists. If not:
43
+ ```
44
+ ERROR: Phase directory not found for phase ${PHASE_ARG}
45
+ Ensure the phase exists in .planning/phases/
46
+ ```
47
+ Exit.
48
+
49
+ Read the phase artifacts (in order of priority):
50
+ 1. `${phase_dir}/*-SUMMARY.md` — what was implemented, files changed
51
+ 2. `${phase_dir}/CONTEXT.md` — acceptance criteria, decisions
52
+ 3. `${phase_dir}/*-VERIFICATION.md` — user-verified scenarios (if UAT was done)
53
+
54
+ If no SUMMARY.md exists:
55
+ ```
56
+ ERROR: No SUMMARY.md found for phase ${PHASE_ARG}
57
+ This command works on completed phases. Run /ez:execute-phase first.
58
+ ```
59
+ Exit.
60
+
61
+ Present banner:
62
+ ```
63
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
64
+ EZ ► ADD TESTS — Phase ${phase_number}: ${phase_name}
65
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
66
+ ```
67
+ </step>
68
+
69
+ <step name="analyze_implementation">
70
+ Extract the list of files modified by the phase from SUMMARY.md ("Files Changed" or equivalent section).
71
+
72
+ For each file, classify into one of three categories:
73
+
74
+ | Category | Criteria | Test Type |
75
+ |----------|----------|-----------|
76
+ | **TDD** | Pure functions where `expect(fn(input)).toBe(output)` is writable | Unit tests |
77
+ | **E2E** | UI behavior verifiable by browser automation | Playwright/E2E tests |
78
+ | **Skip** | Not meaningfully testable or already covered | None |
79
+
80
+ **TDD classification — apply when:**
81
+ - Business logic: calculations, pricing, tax rules, validation
82
+ - Data transformations: mapping, filtering, aggregation, formatting
83
+ - Parsers: CSV, JSON, XML, custom format parsing
84
+ - Validators: input validation, schema validation, business rules
85
+ - State machines: status transitions, workflow steps
86
+ - Utilities: string manipulation, date handling, number formatting
87
+
88
+ **E2E classification — apply when:**
89
+ - Keyboard shortcuts: key bindings, modifier keys, chord sequences
90
+ - Navigation: page transitions, routing, breadcrumbs, back/forward
91
+ - Form interactions: submit, validation errors, field focus, autocomplete
92
+ - Selection: row selection, multi-select, shift-click ranges
93
+ - Drag and drop: reordering, moving between containers
94
+ - Modal dialogs: open, close, confirm, cancel
95
+ - Data grids: sorting, filtering, inline editing, column resize
96
+
97
+ **Skip classification — apply when:**
98
+ - UI layout/styling: CSS classes, visual appearance, responsive breakpoints
99
+ - Configuration: config files, environment variables, feature flags
100
+ - Glue code: dependency injection setup, middleware registration, routing tables
101
+ - Migrations: database migrations, schema changes
102
+ - Simple CRUD: basic create/read/update/delete with no business logic
103
+ - Type definitions: records, DTOs, interfaces with no logic
104
+
105
+ Read each file to verify classification. Don't classify based on filename alone.
106
+ </step>
107
+
108
+ <step name="present_classification">
109
+ Present the classification to the user for confirmation before proceeding:
110
+
111
+ ```
112
+ AskUserQuestion(
113
+ header: "Test Classification",
114
+ question: |
115
+ ## Files classified for testing
116
+
117
+ ### TDD (Unit Tests) — {N} files
118
+ {list of files with brief reason}
119
+
120
+ ### E2E (Browser Tests) — {M} files
121
+ {list of files with brief reason}
122
+
123
+ ### Skip — {K} files
124
+ {list of files with brief reason}
125
+
126
+ {if $EXTRA_INSTRUCTIONS: "Additional instructions: ${EXTRA_INSTRUCTIONS}"}
127
+
128
+ How would you like to proceed?
129
+ options:
130
+ - "Approve and generate test plan"
131
+ - "Adjust classification (I'll specify changes)"
132
+ - "Cancel"
133
+ )
134
+ ```
135
+
136
+ If user selects "Adjust classification": apply their changes and re-present.
137
+ If user selects "Cancel": exit gracefully.
138
+ </step>
139
+
140
+ <step name="discover_test_structure">
141
+ Before generating the test plan, discover the project's existing test structure:
142
+
143
+ ```bash
144
+ # Find existing test directories
145
+ find . -type d -name "*test*" -o -name "*spec*" -o -name "*__tests__*" 2>/dev/null | head -20
146
+ # Find existing test files for convention matching
147
+ find . -type f \( -name "*.test.*" -o -name "*.spec.*" -o -name "*Tests.fs" -o -name "*Test.fs" \) 2>/dev/null | head -20
148
+ # Check for test runners
149
+ ls package.json *.sln 2>/dev/null
150
+ ```
151
+
152
+ Identify:
153
+ - Test directory structure (where unit tests live, where E2E tests live)
154
+ - Naming conventions (`.test.ts`, `.spec.ts`, `*Tests.fs`, etc.)
155
+ - Test runner commands (how to execute unit tests, how to execute E2E tests)
156
+ - Test framework (xUnit, NUnit, Jest, Playwright, etc.)
157
+
158
+ If test structure is ambiguous, ask the user:
159
+ ```
160
+ AskUserQuestion(
161
+ header: "Test Structure",
162
+ question: "I found multiple test locations. Where should I create tests?",
163
+ options: [list discovered locations]
164
+ )
165
+ ```
166
+ </step>
167
+
168
+ <step name="generate_test_plan">
169
+ For each approved file, create a detailed test plan.
170
+
171
+ **For TDD files**, plan tests following RED-GREEN-REFACTOR:
172
+ 1. Identify testable functions/methods in the file
173
+ 2. For each function: list input scenarios, expected outputs, edge cases
174
+ 3. Note: since code already exists, tests may pass immediately — that's OK, but verify they test the RIGHT behavior
175
+
176
+ **For E2E files**, plan tests following RED-GREEN gates:
177
+ 1. Identify user scenarios from CONTEXT.md/VERIFICATION.md
178
+ 2. For each scenario: describe the user action, expected outcome, assertions
179
+ 3. Note: RED gate means confirming the test would fail if the feature were broken
180
+
181
+ Present the complete test plan:
182
+
183
+ ```
184
+ AskUserQuestion(
185
+ header: "Test Plan",
186
+ question: |
187
+ ## Test Generation Plan
188
+
189
+ ### Unit Tests ({N} tests across {M} files)
190
+ {for each file: test file path, list of test cases}
191
+
192
+ ### E2E Tests ({P} tests across {Q} files)
193
+ {for each file: test file path, list of test scenarios}
194
+
195
+ ### Test Commands
196
+ - Unit: {discovered test command}
197
+ - E2E: {discovered e2e command}
198
+
199
+ Ready to generate?
200
+ options:
201
+ - "Generate all"
202
+ - "Cherry-pick (I'll specify which)"
203
+ - "Adjust plan"
204
+ )
205
+ ```
206
+
207
+ If "Cherry-pick": ask user which tests to include.
208
+ If "Adjust plan": apply changes and re-present.
209
+ </step>
210
+
211
+ <step name="execute_tdd_generation">
212
+ For each approved TDD test:
213
+
214
+ 1. **Create test file** following discovered project conventions (directory, naming, imports)
215
+
216
+ 2. **Write test** with clear arrange/act/assert structure:
217
+ ```
218
+ // Arrange — set up inputs and expected outputs
219
+ // Act — call the function under test
220
+ // Assert — verify the output matches expectations
221
+ ```
222
+
223
+ 3. **Run the test**:
224
+ ```bash
225
+ {discovered test command}
226
+ ```
227
+
228
+ 4. **Evaluate result:**
229
+ - **Test passes**: Good — the implementation satisfies the test. Verify the test checks meaningful behavior (not just that it compiles).
230
+ - **Test fails with assertion error**: This may be a genuine bug discovered by the test. Flag it:
231
+ ```
232
+ ⚠️ Potential bug found: {test name}
233
+ Expected: {expected}
234
+ Actual: {actual}
235
+ File: {implementation file}
236
+ ```
237
+ Do NOT fix the implementation — this is a test-generation command, not a fix command. Record the finding.
238
+ - **Test fails with error (import, syntax, etc.)**: This is a test error. Fix the test and re-run.
239
+ </step>
240
+
241
+ <step name="execute_e2e_generation">
242
+ For each approved E2E test:
243
+
244
+ 1. **Check for existing tests** covering the same scenario:
245
+ ```bash
246
+ grep -r "{scenario keyword}" {e2e test directory} 2>/dev/null
247
+ ```
248
+ If found, extend rather than duplicate.
249
+
250
+ 2. **Create test file** targeting the user scenario from CONTEXT.md/VERIFICATION.md
251
+
252
+ 3. **Run the E2E test**:
253
+ ```bash
254
+ {discovered e2e command}
255
+ ```
256
+
257
+ 4. **Evaluate result:**
258
+ - **GREEN (passes)**: Record success
259
+ - **RED (fails)**: Determine if it's a test issue or a genuine application bug. Flag bugs:
260
+ ```
261
+ ⚠️ E2E failure: {test name}
262
+ Scenario: {description}
263
+ Error: {error message}
264
+ ```
265
+ - **Cannot run**: Report blocker. Do NOT mark as complete.
266
+ ```
267
+ 🛑 E2E blocker: {reason tests cannot run}
268
+ ```
269
+
270
+ **No-skip rule:** If E2E tests cannot execute (missing dependencies, environment issues), report the blocker and mark the test as incomplete. Never mark success without actually running the test.
271
+ </step>
272
+
273
+ <step name="summary_and_commit">
274
+ Create a test coverage report and present to user:
275
+
276
+ ```
277
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
278
+ EZ ► TEST GENERATION COMPLETE
279
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
280
+
281
+ ## Results
282
+
283
+ | Category | Generated | Passing | Failing | Blocked |
284
+ |----------|-----------|---------|---------|---------|
285
+ | Unit | {N} | {n1} | {n2} | {n3} |
286
+ | E2E | {M} | {m1} | {m2} | {m3} |
287
+
288
+ ## Files Created/Modified
289
+ {list of test files with paths}
290
+
291
+ ## Coverage Gaps
292
+ {areas that couldn't be tested and why}
293
+
294
+ ## Bugs Discovered
295
+ {any assertion failures that indicate implementation bugs}
296
+ ```
297
+
298
+ Record test generation in project state:
299
+ ```bash
300
+ node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" state-snapshot
301
+ ```
302
+
303
+ If there are passing tests to commit:
304
+
305
+ ```bash
306
+ git add {test files}
307
+ git commit -m "test(phase-${phase_number}): add unit and E2E tests from add-tests command"
308
+ ```
309
+
310
+ Present next steps:
311
+
312
+ ```
313
+ ---
314
+
315
+ ## ▶ Next Up
316
+
317
+ {if bugs discovered:}
318
+ **Fix discovered bugs:** `/ez:quick fix the {N} test failures discovered in phase ${phase_number}`
319
+
320
+ {if blocked tests:}
321
+ **Resolve test blockers:** {description of what's needed}
322
+
323
+ {otherwise:}
324
+ **All tests passing!** Phase ${phase_number} is fully tested.
325
+
326
+ ---
327
+
328
+ **Also available:**
329
+ - `/ez:add-tests {next_phase}` — test another phase
330
+ - `/ez:verify-work {phase_number}` — run UAT verification
331
+
332
+ ---
333
+ ```
334
+ </step>
335
+
336
+ </process>
337
+
338
+ <success_criteria>
339
+ - [ ] Phase artifacts loaded (SUMMARY.md, CONTEXT.md, optionally VERIFICATION.md)
340
+ - [ ] All changed files classified into TDD/E2E/Skip categories
341
+ - [ ] Classification presented to user and approved
342
+ - [ ] Project test structure discovered (directories, conventions, runners)
343
+ - [ ] Test plan presented to user and approved
344
+ - [ ] TDD tests generated with arrange/act/assert structure
345
+ - [ ] E2E tests generated targeting user scenarios
346
+ - [ ] All tests executed — no untested tests marked as passing
347
+ - [ ] Bugs discovered by tests flagged (not fixed)
348
+ - [ ] Test files committed with proper message
349
+ - [ ] Coverage gaps documented
350
+ - [ ] Next steps presented to user
351
+ </success_criteria>