@howlil/ez-agents 2.0.0 → 3.0.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 (145) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +157 -110
  3. package/README.zh-CN.md +84 -84
  4. package/agents/ez-plan-checker.md +2 -2
  5. package/agents/ez-research-synthesizer.md +1 -1
  6. package/agents/ez-ui-auditor.md +0 -2
  7. package/agents/ez-ui-checker.md +2 -4
  8. package/agents/ez-ui-researcher.md +0 -2
  9. package/agents/ez-verifier.md +1 -1
  10. package/bin/install.js +211 -211
  11. package/commands/ez/debug.md +1 -1
  12. package/commands/ez/map-codebase.md +1 -1
  13. package/commands/ez/reapply-patches.md +3 -3
  14. package/commands/ez/research-phase.md +1 -1
  15. package/{get-shit-done → ez-agents}/bin/ez-tools.cjs +1 -1
  16. package/{get-shit-done → ez-agents}/bin/lib/assistant-adapter.cjs +205 -205
  17. package/{get-shit-done → ez-agents}/bin/lib/audit-exec.cjs +150 -150
  18. package/{get-shit-done → ez-agents}/bin/lib/auth.cjs +175 -175
  19. package/{get-shit-done → ez-agents}/bin/lib/circuit-breaker.cjs +118 -118
  20. package/{get-shit-done → ez-agents}/bin/lib/commands.cjs +666 -666
  21. package/{get-shit-done → ez-agents}/bin/lib/config.cjs +183 -183
  22. package/{get-shit-done → ez-agents}/bin/lib/core.cjs +495 -495
  23. package/{get-shit-done → ez-agents}/bin/lib/file-lock.cjs +236 -236
  24. package/{get-shit-done → ez-agents}/bin/lib/frontmatter.cjs +299 -299
  25. package/{get-shit-done → ez-agents}/bin/lib/fs-utils.cjs +153 -153
  26. package/{get-shit-done → ez-agents}/bin/lib/git-utils.cjs +203 -203
  27. package/{get-shit-done → ez-agents}/bin/lib/health-check.cjs +163 -163
  28. package/{get-shit-done → ez-agents}/bin/lib/index.cjs +113 -113
  29. package/{get-shit-done → ez-agents}/bin/lib/init.cjs +710 -710
  30. package/{get-shit-done → ez-agents}/bin/lib/logger.cjs +117 -117
  31. package/{get-shit-done → ez-agents}/bin/lib/milestone.cjs +241 -241
  32. package/{get-shit-done → ez-agents}/bin/lib/model-provider.cjs +146 -146
  33. package/{get-shit-done → ez-agents}/bin/lib/phase.cjs +908 -908
  34. package/{get-shit-done → ez-agents}/bin/lib/retry.cjs +119 -119
  35. package/{get-shit-done → ez-agents}/bin/lib/roadmap.cjs +305 -305
  36. package/{get-shit-done → ez-agents}/bin/lib/safe-exec.cjs +128 -128
  37. package/{get-shit-done → ez-agents}/bin/lib/safe-path.cjs +130 -130
  38. package/{get-shit-done → ez-agents}/bin/lib/state.cjs +721 -721
  39. package/{get-shit-done → ez-agents}/bin/lib/temp-file.cjs +239 -239
  40. package/{get-shit-done → ez-agents}/bin/lib/template.cjs +222 -222
  41. package/{get-shit-done → ez-agents}/bin/lib/test-file-lock.cjs +112 -112
  42. package/{get-shit-done → ez-agents}/bin/lib/test-graceful.cjs +93 -93
  43. package/{get-shit-done → ez-agents}/bin/lib/test-logger.cjs +60 -60
  44. package/{get-shit-done → ez-agents}/bin/lib/test-safe-exec.cjs +38 -38
  45. package/{get-shit-done → ez-agents}/bin/lib/test-safe-path.cjs +33 -33
  46. package/{get-shit-done → ez-agents}/bin/lib/test-temp-file.cjs +125 -125
  47. package/{get-shit-done → ez-agents}/bin/lib/timeout-exec.cjs +62 -62
  48. package/{get-shit-done → ez-agents}/bin/lib/verify.cjs +820 -820
  49. package/{get-shit-done → ez-agents}/references/checkpoints.md +776 -776
  50. package/{get-shit-done → ez-agents}/references/questioning.md +162 -162
  51. package/{get-shit-done → ez-agents}/references/tdd.md +263 -263
  52. package/{get-shit-done → ez-agents}/templates/codebase/concerns.md +310 -310
  53. package/{get-shit-done → ez-agents}/templates/codebase/conventions.md +307 -307
  54. package/{get-shit-done → ez-agents}/templates/codebase/integrations.md +280 -280
  55. package/{get-shit-done → ez-agents}/templates/codebase/stack.md +186 -186
  56. package/{get-shit-done → ez-agents}/templates/codebase/testing.md +480 -480
  57. package/{get-shit-done → ez-agents}/templates/config.json +37 -37
  58. package/{get-shit-done → ez-agents}/templates/continue-here.md +78 -78
  59. package/{get-shit-done → ez-agents}/templates/milestone-archive.md +123 -123
  60. package/{get-shit-done → ez-agents}/templates/milestone.md +115 -115
  61. package/{get-shit-done → ez-agents}/templates/requirements.md +231 -231
  62. package/{get-shit-done → ez-agents}/templates/research-project/ARCHITECTURE.md +204 -204
  63. package/{get-shit-done → ez-agents}/templates/research-project/FEATURES.md +147 -147
  64. package/{get-shit-done → ez-agents}/templates/research-project/PITFALLS.md +200 -200
  65. package/{get-shit-done → ez-agents}/templates/research-project/STACK.md +120 -120
  66. package/{get-shit-done → ez-agents}/templates/research-project/SUMMARY.md +170 -170
  67. package/{get-shit-done → ez-agents}/templates/retrospective.md +54 -54
  68. package/{get-shit-done → ez-agents}/templates/roadmap.md +202 -202
  69. package/{get-shit-done → ez-agents}/templates/summary-minimal.md +41 -41
  70. package/{get-shit-done → ez-agents}/templates/summary-standard.md +48 -48
  71. package/{get-shit-done → ez-agents}/templates/summary.md +248 -248
  72. package/{get-shit-done → ez-agents}/templates/user-setup.md +311 -311
  73. package/{get-shit-done → ez-agents}/templates/verification-report.md +322 -322
  74. package/{get-shit-done → ez-agents}/workflows/add-phase.md +112 -112
  75. package/{get-shit-done → ez-agents}/workflows/add-tests.md +351 -351
  76. package/{get-shit-done → ez-agents}/workflows/add-todo.md +158 -158
  77. package/{get-shit-done → ez-agents}/workflows/audit-milestone.md +332 -332
  78. package/{get-shit-done → ez-agents}/workflows/autonomous.md +743 -743
  79. package/{get-shit-done → ez-agents}/workflows/check-todos.md +177 -177
  80. package/{get-shit-done → ez-agents}/workflows/cleanup.md +152 -152
  81. package/{get-shit-done → ez-agents}/workflows/complete-milestone.md +766 -766
  82. package/ez-agents/workflows/debug.md +0 -0
  83. package/{get-shit-done → ez-agents}/workflows/diagnose-issues.md +219 -219
  84. package/{get-shit-done → ez-agents}/workflows/discovery-phase.md +289 -289
  85. package/{get-shit-done → ez-agents}/workflows/discuss-phase.md +762 -762
  86. package/{get-shit-done → ez-agents}/workflows/execute-phase.md +468 -468
  87. package/{get-shit-done → ez-agents}/workflows/execute-plan.md +483 -483
  88. package/{get-shit-done → ez-agents}/workflows/health.md +159 -159
  89. package/{get-shit-done → ez-agents}/workflows/help.md +492 -492
  90. package/{get-shit-done → ez-agents}/workflows/insert-phase.md +130 -130
  91. package/{get-shit-done → ez-agents}/workflows/list-phase-assumptions.md +178 -178
  92. package/{get-shit-done → ez-agents}/workflows/map-codebase.md +316 -316
  93. package/{get-shit-done → ez-agents}/workflows/new-milestone.md +384 -384
  94. package/{get-shit-done → ez-agents}/workflows/new-project.md +1111 -1111
  95. package/{get-shit-done → ez-agents}/workflows/node-repair.md +92 -92
  96. package/{get-shit-done → ez-agents}/workflows/pause-work.md +122 -122
  97. package/{get-shit-done → ez-agents}/workflows/plan-milestone-gaps.md +274 -274
  98. package/{get-shit-done → ez-agents}/workflows/plan-phase.md +651 -651
  99. package/{get-shit-done → ez-agents}/workflows/progress.md +382 -382
  100. package/{get-shit-done → ez-agents}/workflows/quick.md +610 -610
  101. package/{get-shit-done → ez-agents}/workflows/remove-phase.md +155 -155
  102. package/{get-shit-done → ez-agents}/workflows/research-phase.md +74 -74
  103. package/{get-shit-done → ez-agents}/workflows/resume-project.md +307 -307
  104. package/{get-shit-done → ez-agents}/workflows/set-profile.md +81 -81
  105. package/{get-shit-done → ez-agents}/workflows/settings.md +242 -242
  106. package/{get-shit-done → ez-agents}/workflows/stats.md +57 -57
  107. package/{get-shit-done → ez-agents}/workflows/transition.md +544 -544
  108. package/{get-shit-done → ez-agents}/workflows/ui-phase.md +290 -290
  109. package/{get-shit-done → ez-agents}/workflows/ui-review.md +157 -157
  110. package/{get-shit-done → ez-agents}/workflows/update.md +320 -320
  111. package/{get-shit-done → ez-agents}/workflows/validate-phase.md +167 -167
  112. package/{get-shit-done → ez-agents}/workflows/verify-phase.md +243 -243
  113. package/{get-shit-done → ez-agents}/workflows/verify-work.md +5 -5
  114. package/hooks/dist/ez-check-update.js +81 -0
  115. package/hooks/dist/ez-context-monitor.js +141 -0
  116. package/hooks/dist/ez-statusline.js +115 -0
  117. package/package.json +13 -3
  118. package/scripts/build-hooks.js +43 -43
  119. package/scripts/run-tests.cjs +29 -29
  120. /package/{get-shit-done → ez-agents}/references/continuation-format.md +0 -0
  121. /package/{get-shit-done → ez-agents}/references/decimal-phase-calculation.md +0 -0
  122. /package/{get-shit-done → ez-agents}/references/git-integration.md +0 -0
  123. /package/{get-shit-done → ez-agents}/references/git-planning-commit.md +0 -0
  124. /package/{get-shit-done → ez-agents}/references/model-profile-resolution.md +0 -0
  125. /package/{get-shit-done → ez-agents}/references/model-profiles.md +0 -0
  126. /package/{get-shit-done → ez-agents}/references/phase-argument-parsing.md +0 -0
  127. /package/{get-shit-done → ez-agents}/references/planning-config.md +0 -0
  128. /package/{get-shit-done → ez-agents}/references/ui-brand.md +0 -0
  129. /package/{get-shit-done → ez-agents}/references/verification-patterns.md +0 -0
  130. /package/{get-shit-done → ez-agents}/templates/DEBUG.md +0 -0
  131. /package/{get-shit-done → ez-agents}/templates/UAT.md +0 -0
  132. /package/{get-shit-done → ez-agents}/templates/UI-SPEC.md +0 -0
  133. /package/{get-shit-done → ez-agents}/templates/VALIDATION.md +0 -0
  134. /package/{get-shit-done → ez-agents}/templates/codebase/architecture.md +0 -0
  135. /package/{get-shit-done → ez-agents}/templates/codebase/structure.md +0 -0
  136. /package/{get-shit-done → ez-agents}/templates/context.md +0 -0
  137. /package/{get-shit-done → ez-agents}/templates/copilot-instructions.md +0 -0
  138. /package/{get-shit-done → ez-agents}/templates/debug-subagent-prompt.md +0 -0
  139. /package/{get-shit-done → ez-agents}/templates/discovery.md +0 -0
  140. /package/{get-shit-done → ez-agents}/templates/phase-prompt.md +0 -0
  141. /package/{get-shit-done → ez-agents}/templates/planner-subagent-prompt.md +0 -0
  142. /package/{get-shit-done → ez-agents}/templates/project.md +0 -0
  143. /package/{get-shit-done → ez-agents}/templates/research.md +0 -0
  144. /package/{get-shit-done → ez-agents}/templates/state.md +0 -0
  145. /package/{get-shit-done → ez-agents}/templates/summary-complex.md +0 -0
File without changes
@@ -1,219 +1,219 @@
1
- <purpose>
2
- Orchestrate parallel debug agents to investigate UAT gaps and find root causes.
3
-
4
- After UAT finds gaps, spawn one debug agent per gap. Each agent investigates autonomously with symptoms pre-filled from UAT. Collect root causes, update UAT.md gaps with diagnosis, then hand off to plan-phase --gaps with actual diagnoses.
5
-
6
- Orchestrator stays lean: parse gaps, spawn agents, collect results, update UAT.
7
- </purpose>
8
-
9
- <paths>
10
- DEBUG_DIR=.planning/debug
11
-
12
- Debug files use the `.planning/debug/` path (hidden directory with leading dot).
13
- </paths>
14
-
15
- <core_principle>
16
- **Diagnose before planning fixes.**
17
-
18
- UAT tells us WHAT is broken (symptoms). Debug agents find WHY (root cause). plan-phase --gaps then creates targeted fixes based on actual causes, not guesses.
19
-
20
- Without diagnosis: "Comment doesn't refresh" → guess at fix → maybe wrong
21
- With diagnosis: "Comment doesn't refresh" → "useEffect missing dependency" → precise fix
22
- </core_principle>
23
-
24
- <process>
25
-
26
- <step name="parse_gaps">
27
- **Extract gaps from UAT.md:**
28
-
29
- Read the "Gaps" section (YAML format):
30
- ```yaml
31
- - truth: "Comment appears immediately after submission"
32
- status: failed
33
- reason: "User reported: works but doesn't show until I refresh the page"
34
- severity: major
35
- test: 2
36
- artifacts: []
37
- missing: []
38
- ```
39
-
40
- For each gap, also read the corresponding test from "Tests" section to get full context.
41
-
42
- Build gap list:
43
- ```
44
- gaps = [
45
- {truth: "Comment appears immediately...", severity: "major", test_num: 2, reason: "..."},
46
- {truth: "Reply button positioned correctly...", severity: "minor", test_num: 5, reason: "..."},
47
- ...
48
- ]
49
- ```
50
- </step>
51
-
52
- <step name="report_plan">
53
- **Report diagnosis plan to user:**
54
-
55
- ```
56
- ## Diagnosing {N} Gaps
57
-
58
- Spawning parallel debug agents to investigate root causes:
59
-
60
- | Gap (Truth) | Severity |
61
- |-------------|----------|
62
- | Comment appears immediately after submission | major |
63
- | Reply button positioned correctly | minor |
64
- | Delete removes comment | blocker |
65
-
66
- Each agent will:
67
- 1. Create DEBUG-{slug}.md with symptoms pre-filled
68
- 2. Investigate autonomously (read code, form hypotheses, test)
69
- 3. Return root cause
70
-
71
- This runs in parallel - all gaps investigated simultaneously.
72
- ```
73
- </step>
74
-
75
- <step name="spawn_agents">
76
- **Spawn debug agents in parallel:**
77
-
78
- For each gap, fill the debug-subagent-prompt template and spawn:
79
-
80
- ```
81
- Task(
82
- prompt=filled_debug_subagent_prompt + "\n\n<files_to_read>\n- {phase_dir}/{phase_num}-UAT.md\n- .planning/STATE.md\n</files_to_read>",
83
- subagent_type="ez-debugger",
84
- description="Debug: {truth_short}"
85
- )
86
- ```
87
-
88
- **All agents spawn in single message** (parallel execution).
89
-
90
- Template placeholders:
91
- - `{truth}`: The expected behavior that failed
92
- - `{expected}`: From UAT test
93
- - `{actual}`: Verbatim user description from reason field
94
- - `{errors}`: Any error messages from UAT (or "None reported")
95
- - `{reproduction}`: "Test {test_num} in UAT"
96
- - `{timeline}`: "Discovered during UAT"
97
- - `{goal}`: `find_root_cause_only` (UAT flow - plan-phase --gaps handles fixes)
98
- - `{slug}`: Generated from truth
99
- </step>
100
-
101
- <step name="collect_results">
102
- **Collect root causes from agents:**
103
-
104
- Each agent returns with:
105
- ```
106
- ## ROOT CAUSE FOUND
107
-
108
- **Debug Session:** ${DEBUG_DIR}/{slug}.md
109
-
110
- **Root Cause:** {specific cause with evidence}
111
-
112
- **Evidence Summary:**
113
- - {key finding 1}
114
- - {key finding 2}
115
- - {key finding 3}
116
-
117
- **Files Involved:**
118
- - {file1}: {what's wrong}
119
- - {file2}: {related issue}
120
-
121
- **Suggested Fix Direction:** {brief hint for plan-phase --gaps}
122
- ```
123
-
124
- Parse each return to extract:
125
- - root_cause: The diagnosed cause
126
- - files: Files involved
127
- - debug_path: Path to debug session file
128
- - suggested_fix: Hint for gap closure plan
129
-
130
- If agent returns `## INVESTIGATION INCONCLUSIVE`:
131
- - root_cause: "Investigation inconclusive - manual review needed"
132
- - Note which issue needs manual attention
133
- - Include remaining possibilities from agent return
134
- </step>
135
-
136
- <step name="update_uat">
137
- **Update UAT.md gaps with diagnosis:**
138
-
139
- For each gap in the Gaps section, add artifacts and missing fields:
140
-
141
- ```yaml
142
- - truth: "Comment appears immediately after submission"
143
- status: failed
144
- reason: "User reported: works but doesn't show until I refresh the page"
145
- severity: major
146
- test: 2
147
- root_cause: "useEffect in CommentList.tsx missing commentCount dependency"
148
- artifacts:
149
- - path: "src/components/CommentList.tsx"
150
- issue: "useEffect missing dependency"
151
- missing:
152
- - "Add commentCount to useEffect dependency array"
153
- - "Trigger re-render when new comment added"
154
- debug_session: .planning/debug/comment-not-refreshing.md
155
- ```
156
-
157
- Update status in frontmatter to "diagnosed".
158
-
159
- Commit the updated UAT.md:
160
- ```bash
161
- node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" commit "docs({phase_num}): add root causes from diagnosis" --files ".planning/phases/XX-name/{phase_num}-UAT.md"
162
- ```
163
- </step>
164
-
165
- <step name="report_results">
166
- **Report diagnosis results and hand off:**
167
-
168
- Display:
169
- ```
170
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
171
- GSD ► DIAGNOSIS COMPLETE
172
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
173
-
174
- | Gap (Truth) | Root Cause | Files |
175
- |-------------|------------|-------|
176
- | Comment appears immediately | useEffect missing dependency | CommentList.tsx |
177
- | Reply button positioned correctly | CSS flex order incorrect | ReplyButton.tsx |
178
- | Delete removes comment | API missing auth header | api/comments.ts |
179
-
180
- Debug sessions: ${DEBUG_DIR}/
181
-
182
- Proceeding to plan fixes...
183
- ```
184
-
185
- Return to verify-work orchestrator for automatic planning.
186
- Do NOT offer manual next steps - verify-work handles the rest.
187
- </step>
188
-
189
- </process>
190
-
191
- <context_efficiency>
192
- Agents start with symptoms pre-filled from UAT (no symptom gathering).
193
- Agents only diagnose—plan-phase --gaps handles fixes (no fix application).
194
- </context_efficiency>
195
-
196
- <failure_handling>
197
- **Agent fails to find root cause:**
198
- - Mark gap as "needs manual review"
199
- - Continue with other gaps
200
- - Report incomplete diagnosis
201
-
202
- **Agent times out:**
203
- - Check DEBUG-{slug}.md for partial progress
204
- - Can resume with /ez:debug
205
-
206
- **All agents fail:**
207
- - Something systemic (permissions, git, etc.)
208
- - Report for manual investigation
209
- - Fall back to plan-phase --gaps without root causes (less precise)
210
- </failure_handling>
211
-
212
- <success_criteria>
213
- - [ ] Gaps parsed from UAT.md
214
- - [ ] Debug agents spawned in parallel
215
- - [ ] Root causes collected from all agents
216
- - [ ] UAT.md gaps updated with artifacts and missing
217
- - [ ] Debug sessions saved to ${DEBUG_DIR}/
218
- - [ ] Hand off to verify-work for automatic planning
219
- </success_criteria>
1
+ <purpose>
2
+ Orchestrate parallel debug agents to investigate UAT gaps and find root causes.
3
+
4
+ After UAT finds gaps, spawn one debug agent per gap. Each agent investigates autonomously with symptoms pre-filled from UAT. Collect root causes, update UAT.md gaps with diagnosis, then hand off to plan-phase --gaps with actual diagnoses.
5
+
6
+ Orchestrator stays lean: parse gaps, spawn agents, collect results, update UAT.
7
+ </purpose>
8
+
9
+ <paths>
10
+ DEBUG_DIR=.planning/debug
11
+
12
+ Debug files use the `.planning/debug/` path (hidden directory with leading dot).
13
+ </paths>
14
+
15
+ <core_principle>
16
+ **Diagnose before planning fixes.**
17
+
18
+ UAT tells us WHAT is broken (symptoms). Debug agents find WHY (root cause). plan-phase --gaps then creates targeted fixes based on actual causes, not guesses.
19
+
20
+ Without diagnosis: "Comment doesn't refresh" → guess at fix → maybe wrong
21
+ With diagnosis: "Comment doesn't refresh" → "useEffect missing dependency" → precise fix
22
+ </core_principle>
23
+
24
+ <process>
25
+
26
+ <step name="parse_gaps">
27
+ **Extract gaps from UAT.md:**
28
+
29
+ Read the "Gaps" section (YAML format):
30
+ ```yaml
31
+ - truth: "Comment appears immediately after submission"
32
+ status: failed
33
+ reason: "User reported: works but doesn't show until I refresh the page"
34
+ severity: major
35
+ test: 2
36
+ artifacts: []
37
+ missing: []
38
+ ```
39
+
40
+ For each gap, also read the corresponding test from "Tests" section to get full context.
41
+
42
+ Build gap list:
43
+ ```
44
+ gaps = [
45
+ {truth: "Comment appears immediately...", severity: "major", test_num: 2, reason: "..."},
46
+ {truth: "Reply button positioned correctly...", severity: "minor", test_num: 5, reason: "..."},
47
+ ...
48
+ ]
49
+ ```
50
+ </step>
51
+
52
+ <step name="report_plan">
53
+ **Report diagnosis plan to user:**
54
+
55
+ ```
56
+ ## Diagnosing {N} Gaps
57
+
58
+ Spawning parallel debug agents to investigate root causes:
59
+
60
+ | Gap (Truth) | Severity |
61
+ |-------------|----------|
62
+ | Comment appears immediately after submission | major |
63
+ | Reply button positioned correctly | minor |
64
+ | Delete removes comment | blocker |
65
+
66
+ Each agent will:
67
+ 1. Create DEBUG-{slug}.md with symptoms pre-filled
68
+ 2. Investigate autonomously (read code, form hypotheses, test)
69
+ 3. Return root cause
70
+
71
+ This runs in parallel - all gaps investigated simultaneously.
72
+ ```
73
+ </step>
74
+
75
+ <step name="spawn_agents">
76
+ **Spawn debug agents in parallel:**
77
+
78
+ For each gap, fill the debug-subagent-prompt template and spawn:
79
+
80
+ ```
81
+ Task(
82
+ prompt=filled_debug_subagent_prompt + "\n\n<files_to_read>\n- {phase_dir}/{phase_num}-UAT.md\n- .planning/STATE.md\n</files_to_read>",
83
+ subagent_type="ez-debugger",
84
+ description="Debug: {truth_short}"
85
+ )
86
+ ```
87
+
88
+ **All agents spawn in single message** (parallel execution).
89
+
90
+ Template placeholders:
91
+ - `{truth}`: The expected behavior that failed
92
+ - `{expected}`: From UAT test
93
+ - `{actual}`: Verbatim user description from reason field
94
+ - `{errors}`: Any error messages from UAT (or "None reported")
95
+ - `{reproduction}`: "Test {test_num} in UAT"
96
+ - `{timeline}`: "Discovered during UAT"
97
+ - `{goal}`: `find_root_cause_only` (UAT flow - plan-phase --gaps handles fixes)
98
+ - `{slug}`: Generated from truth
99
+ </step>
100
+
101
+ <step name="collect_results">
102
+ **Collect root causes from agents:**
103
+
104
+ Each agent returns with:
105
+ ```
106
+ ## ROOT CAUSE FOUND
107
+
108
+ **Debug Session:** ${DEBUG_DIR}/{slug}.md
109
+
110
+ **Root Cause:** {specific cause with evidence}
111
+
112
+ **Evidence Summary:**
113
+ - {key finding 1}
114
+ - {key finding 2}
115
+ - {key finding 3}
116
+
117
+ **Files Involved:**
118
+ - {file1}: {what's wrong}
119
+ - {file2}: {related issue}
120
+
121
+ **Suggested Fix Direction:** {brief hint for plan-phase --gaps}
122
+ ```
123
+
124
+ Parse each return to extract:
125
+ - root_cause: The diagnosed cause
126
+ - files: Files involved
127
+ - debug_path: Path to debug session file
128
+ - suggested_fix: Hint for gap closure plan
129
+
130
+ If agent returns `## INVESTIGATION INCONCLUSIVE`:
131
+ - root_cause: "Investigation inconclusive - manual review needed"
132
+ - Note which issue needs manual attention
133
+ - Include remaining possibilities from agent return
134
+ </step>
135
+
136
+ <step name="update_uat">
137
+ **Update UAT.md gaps with diagnosis:**
138
+
139
+ For each gap in the Gaps section, add artifacts and missing fields:
140
+
141
+ ```yaml
142
+ - truth: "Comment appears immediately after submission"
143
+ status: failed
144
+ reason: "User reported: works but doesn't show until I refresh the page"
145
+ severity: major
146
+ test: 2
147
+ root_cause: "useEffect in CommentList.tsx missing commentCount dependency"
148
+ artifacts:
149
+ - path: "src/components/CommentList.tsx"
150
+ issue: "useEffect missing dependency"
151
+ missing:
152
+ - "Add commentCount to useEffect dependency array"
153
+ - "Trigger re-render when new comment added"
154
+ debug_session: .planning/debug/comment-not-refreshing.md
155
+ ```
156
+
157
+ Update status in frontmatter to "diagnosed".
158
+
159
+ Commit the updated UAT.md:
160
+ ```bash
161
+ node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" commit "docs({phase_num}): add root causes from diagnosis" --files ".planning/phases/XX-name/{phase_num}-UAT.md"
162
+ ```
163
+ </step>
164
+
165
+ <step name="report_results">
166
+ **Report diagnosis results and hand off:**
167
+
168
+ Display:
169
+ ```
170
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
171
+ GSD ► DIAGNOSIS COMPLETE
172
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
173
+
174
+ | Gap (Truth) | Root Cause | Files |
175
+ |-------------|------------|-------|
176
+ | Comment appears immediately | useEffect missing dependency | CommentList.tsx |
177
+ | Reply button positioned correctly | CSS flex order incorrect | ReplyButton.tsx |
178
+ | Delete removes comment | API missing auth header | api/comments.ts |
179
+
180
+ Debug sessions: ${DEBUG_DIR}/
181
+
182
+ Proceeding to plan fixes...
183
+ ```
184
+
185
+ Return to verify-work orchestrator for automatic planning.
186
+ Do NOT offer manual next steps - verify-work handles the rest.
187
+ </step>
188
+
189
+ </process>
190
+
191
+ <context_efficiency>
192
+ Agents start with symptoms pre-filled from UAT (no symptom gathering).
193
+ Agents only diagnose—plan-phase --gaps handles fixes (no fix application).
194
+ </context_efficiency>
195
+
196
+ <failure_handling>
197
+ **Agent fails to find root cause:**
198
+ - Mark gap as "needs manual review"
199
+ - Continue with other gaps
200
+ - Report incomplete diagnosis
201
+
202
+ **Agent times out:**
203
+ - Check DEBUG-{slug}.md for partial progress
204
+ - Can resume with /ez:debug
205
+
206
+ **All agents fail:**
207
+ - Something systemic (permissions, git, etc.)
208
+ - Report for manual investigation
209
+ - Fall back to plan-phase --gaps without root causes (less precise)
210
+ </failure_handling>
211
+
212
+ <success_criteria>
213
+ - [ ] Gaps parsed from UAT.md
214
+ - [ ] Debug agents spawned in parallel
215
+ - [ ] Root causes collected from all agents
216
+ - [ ] UAT.md gaps updated with artifacts and missing
217
+ - [ ] Debug sessions saved to ${DEBUG_DIR}/
218
+ - [ ] Hand off to verify-work for automatic planning
219
+ </success_criteria>