@howlil/ez-agents 3.4.1 → 3.4.2

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 (102) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +7 -18
  3. package/bin/install.js +52 -10
  4. package/commands/ez/join-discord.md +18 -18
  5. package/ez-agents/bin/lib/assistant-adapter.cjs +264 -264
  6. package/ez-agents/bin/lib/audit-exec.cjs +7 -2
  7. package/ez-agents/bin/lib/circuit-breaker.cjs +118 -118
  8. package/ez-agents/bin/lib/config.cjs +190 -190
  9. package/ez-agents/bin/lib/file-lock.cjs +236 -236
  10. package/ez-agents/bin/lib/frontmatter.cjs +299 -299
  11. package/ez-agents/bin/lib/fs-utils.cjs +153 -153
  12. package/ez-agents/bin/lib/git-utils.cjs +203 -203
  13. package/ez-agents/bin/lib/index.cjs +113 -113
  14. package/ez-agents/bin/lib/init.cjs +757 -757
  15. package/ez-agents/bin/lib/logger.cjs +47 -17
  16. package/ez-agents/bin/lib/milestone.cjs +241 -241
  17. package/ez-agents/bin/lib/model-provider.cjs +241 -241
  18. package/ez-agents/bin/lib/phase.cjs +925 -925
  19. package/ez-agents/bin/lib/planning-write.cjs +107 -107
  20. package/ez-agents/bin/lib/retry.cjs +119 -119
  21. package/ez-agents/bin/lib/roadmap.cjs +306 -306
  22. package/ez-agents/bin/lib/safe-exec.cjs +90 -4
  23. package/ez-agents/bin/lib/safe-path.cjs +130 -130
  24. package/ez-agents/bin/lib/state.cjs +736 -736
  25. package/ez-agents/bin/lib/temp-file.cjs +239 -239
  26. package/ez-agents/bin/lib/template.cjs +223 -223
  27. package/ez-agents/bin/lib/test-file-lock.cjs +112 -112
  28. package/ez-agents/bin/lib/test-graceful.cjs +93 -93
  29. package/ez-agents/bin/lib/test-logger.cjs +60 -60
  30. package/ez-agents/bin/lib/test-safe-exec.cjs +38 -38
  31. package/ez-agents/bin/lib/test-safe-path.cjs +33 -33
  32. package/ez-agents/bin/lib/test-temp-file.cjs +125 -125
  33. package/ez-agents/bin/lib/timeout-exec.cjs +63 -63
  34. package/ez-agents/bin/lib/verify.cjs +15 -1
  35. package/ez-agents/references/checkpoints.md +776 -776
  36. package/ez-agents/references/continuation-format.md +249 -249
  37. package/ez-agents/references/questioning.md +162 -162
  38. package/ez-agents/references/tdd.md +263 -263
  39. package/ez-agents/templates/codebase/concerns.md +310 -310
  40. package/ez-agents/templates/codebase/conventions.md +307 -307
  41. package/ez-agents/templates/codebase/integrations.md +280 -280
  42. package/ez-agents/templates/codebase/stack.md +186 -186
  43. package/ez-agents/templates/codebase/testing.md +480 -480
  44. package/ez-agents/templates/config.json +37 -37
  45. package/ez-agents/templates/continue-here.md +78 -78
  46. package/ez-agents/templates/milestone-archive.md +123 -123
  47. package/ez-agents/templates/milestone.md +115 -115
  48. package/ez-agents/templates/requirements.md +231 -231
  49. package/ez-agents/templates/research-project/ARCHITECTURE.md +204 -204
  50. package/ez-agents/templates/research-project/FEATURES.md +147 -147
  51. package/ez-agents/templates/research-project/PITFALLS.md +200 -200
  52. package/ez-agents/templates/research-project/STACK.md +120 -120
  53. package/ez-agents/templates/research-project/SUMMARY.md +170 -170
  54. package/ez-agents/templates/retrospective.md +54 -54
  55. package/ez-agents/templates/roadmap.md +202 -202
  56. package/ez-agents/templates/summary-minimal.md +41 -41
  57. package/ez-agents/templates/summary-standard.md +48 -48
  58. package/ez-agents/templates/summary.md +248 -248
  59. package/ez-agents/templates/user-setup.md +311 -311
  60. package/ez-agents/templates/verification-report.md +322 -322
  61. package/ez-agents/workflows/add-phase.md +112 -112
  62. package/ez-agents/workflows/add-tests.md +351 -351
  63. package/ez-agents/workflows/add-todo.md +158 -158
  64. package/ez-agents/workflows/audit-milestone.md +332 -332
  65. package/ez-agents/workflows/autonomous.md +743 -743
  66. package/ez-agents/workflows/check-todos.md +177 -177
  67. package/ez-agents/workflows/cleanup.md +152 -152
  68. package/ez-agents/workflows/complete-milestone.md +766 -766
  69. package/ez-agents/workflows/diagnose-issues.md +219 -219
  70. package/ez-agents/workflows/discovery-phase.md +289 -289
  71. package/ez-agents/workflows/discuss-phase.md +762 -762
  72. package/ez-agents/workflows/execute-phase.md +468 -468
  73. package/ez-agents/workflows/execute-plan.md +483 -483
  74. package/ez-agents/workflows/health.md +159 -159
  75. package/ez-agents/workflows/help.md +492 -492
  76. package/ez-agents/workflows/insert-phase.md +130 -130
  77. package/ez-agents/workflows/list-phase-assumptions.md +178 -178
  78. package/ez-agents/workflows/map-codebase.md +316 -316
  79. package/ez-agents/workflows/new-milestone.md +384 -384
  80. package/ez-agents/workflows/new-project.md +1113 -1113
  81. package/ez-agents/workflows/node-repair.md +92 -92
  82. package/ez-agents/workflows/pause-work.md +122 -122
  83. package/ez-agents/workflows/plan-milestone-gaps.md +274 -274
  84. package/ez-agents/workflows/plan-phase.md +651 -651
  85. package/ez-agents/workflows/progress.md +382 -382
  86. package/ez-agents/workflows/quick.md +610 -610
  87. package/ez-agents/workflows/remove-phase.md +155 -155
  88. package/ez-agents/workflows/research-phase.md +74 -74
  89. package/ez-agents/workflows/resume-project.md +307 -307
  90. package/ez-agents/workflows/set-profile.md +81 -81
  91. package/ez-agents/workflows/settings.md +242 -242
  92. package/ez-agents/workflows/stats.md +57 -57
  93. package/ez-agents/workflows/transition.md +544 -544
  94. package/ez-agents/workflows/ui-phase.md +290 -290
  95. package/ez-agents/workflows/ui-review.md +157 -157
  96. package/ez-agents/workflows/update.md +320 -320
  97. package/ez-agents/workflows/validate-phase.md +167 -167
  98. package/ez-agents/workflows/verify-phase.md +243 -243
  99. package/ez-agents/workflows/verify-work.md +584 -584
  100. package/package.json +2 -3
  101. package/scripts/build-hooks.js +43 -43
  102. package/scripts/run-tests.cjs +29 -29
@@ -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
- EZ ► 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
+ EZ ► 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>