mindforge-cc 2.0.0 → 2.1.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.
Files changed (323) hide show
  1. package/.agent/bin/lib/commands.cjs +959 -0
  2. package/.agent/bin/lib/config.cjs +421 -0
  3. package/.agent/bin/lib/core.cjs +1166 -0
  4. package/.agent/bin/lib/frontmatter.cjs +307 -0
  5. package/.agent/bin/lib/init.cjs +1336 -0
  6. package/.agent/bin/lib/milestone.cjs +252 -0
  7. package/.agent/bin/lib/model-profiles.cjs +68 -0
  8. package/.agent/bin/lib/phase.cjs +888 -0
  9. package/.agent/bin/lib/profile-output.cjs +952 -0
  10. package/.agent/bin/lib/profile-pipeline.cjs +539 -0
  11. package/.agent/bin/lib/roadmap.cjs +329 -0
  12. package/.agent/bin/lib/security.cjs +356 -0
  13. package/.agent/bin/lib/state.cjs +969 -0
  14. package/.agent/bin/lib/template.cjs +222 -0
  15. package/.agent/bin/lib/uat.cjs +189 -0
  16. package/.agent/bin/lib/verify.cjs +851 -0
  17. package/.agent/bin/lib/workstream.cjs +491 -0
  18. package/.agent/bin/mindforge-tools.cjs +897 -0
  19. package/.agent/file-manifest.json +219 -0
  20. package/.agent/hooks/mindforge-check-update.js +114 -0
  21. package/.agent/hooks/mindforge-context-monitor.js +156 -0
  22. package/.agent/hooks/mindforge-prompt-guard.js +96 -0
  23. package/.agent/hooks/mindforge-statusline.js +119 -0
  24. package/.agent/hooks/mindforge-workflow-guard.js +94 -0
  25. package/.agent/mindforge/add-backlog.md +32 -0
  26. package/.agent/mindforge/agent.md +31 -0
  27. package/.agent/mindforge/discuss-phase.md +1 -1
  28. package/.agent/mindforge/do.md +31 -0
  29. package/.agent/mindforge/help.md +1 -1
  30. package/.agent/mindforge/learn.md +3 -2
  31. package/.agent/mindforge/note.md +35 -0
  32. package/.agent/mindforge/plant-seed.md +31 -0
  33. package/.agent/mindforge/research.md +3 -2
  34. package/.agent/mindforge/review-backlog.md +34 -0
  35. package/.agent/mindforge/session-report.md +39 -0
  36. package/.agent/mindforge/steer.md +1 -1
  37. package/.agent/mindforge/ui-phase.md +34 -0
  38. package/.agent/mindforge/ui-review.md +36 -0
  39. package/.agent/mindforge/validate-phase.md +31 -0
  40. package/.agent/mindforge/workstreams.md +35 -0
  41. package/.agent/settings.json +38 -0
  42. package/.agent/skills/mindforge-add-backlog/SKILL.md +72 -0
  43. package/.agent/skills/mindforge-add-phase/SKILL.md +39 -0
  44. package/.agent/skills/mindforge-add-tests/SKILL.md +28 -0
  45. package/.agent/skills/mindforge-add-todo/SKILL.md +42 -0
  46. package/.agent/skills/mindforge-audit-milestone/SKILL.md +29 -0
  47. package/.agent/skills/mindforge-audit-uat/SKILL.md +20 -0
  48. package/.agent/skills/mindforge-autonomous/SKILL.md +33 -0
  49. package/.agent/skills/mindforge-check-todos/SKILL.md +40 -0
  50. package/.agent/skills/mindforge-cleanup/SKILL.md +19 -0
  51. package/.agent/skills/mindforge-complete-milestone/SKILL.md +131 -0
  52. package/.agent/skills/mindforge-debug/SKILL.md +163 -0
  53. package/.agent/skills/mindforge-discuss-phase/SKILL.md +54 -0
  54. package/.agent/skills/mindforge-do/SKILL.md +26 -0
  55. package/.agent/skills/mindforge-execute-phase/SKILL.md +49 -0
  56. package/.agent/skills/mindforge-fast/SKILL.md +23 -0
  57. package/.agent/skills/mindforge-forensics/SKILL.md +49 -0
  58. package/.agent/skills/mindforge-health/SKILL.md +17 -0
  59. package/.agent/skills/mindforge-help/SKILL.md +23 -0
  60. package/.agent/skills/mindforge-insert-phase/SKILL.md +28 -0
  61. package/.agent/skills/mindforge-join-discord/SKILL.md +19 -0
  62. package/.agent/skills/mindforge-list-phase-assumptions/SKILL.md +41 -0
  63. package/.agent/skills/mindforge-list-workspaces/SKILL.md +17 -0
  64. package/.agent/skills/mindforge-manager/SKILL.md +32 -0
  65. package/.agent/skills/mindforge-map-codebase/SKILL.md +64 -0
  66. package/.agent/skills/mindforge-milestone-summary/SKILL.md +44 -0
  67. package/.agent/skills/mindforge-new-milestone/SKILL.md +38 -0
  68. package/.agent/skills/mindforge-new-project/SKILL.md +36 -0
  69. package/.agent/skills/mindforge-new-workspace/SKILL.md +39 -0
  70. package/.agent/skills/mindforge-next/SKILL.md +19 -0
  71. package/.agent/skills/mindforge-note/SKILL.md +29 -0
  72. package/.agent/skills/mindforge-pause-work/SKILL.md +35 -0
  73. package/.agent/skills/mindforge-plan-milestone-gaps/SKILL.md +28 -0
  74. package/.agent/skills/mindforge-plan-phase/SKILL.md +37 -0
  75. package/.agent/skills/mindforge-plant-seed/SKILL.md +22 -0
  76. package/.agent/skills/mindforge-pr-branch/SKILL.md +21 -0
  77. package/.agent/skills/mindforge-profile-user/SKILL.md +38 -0
  78. package/.agent/skills/mindforge-progress/SKILL.md +19 -0
  79. package/.agent/skills/mindforge-quick/SKILL.md +38 -0
  80. package/.agent/skills/mindforge-reapply-patches/SKILL.md +124 -0
  81. package/.agent/skills/mindforge-remove-phase/SKILL.md +26 -0
  82. package/.agent/skills/mindforge-remove-workspace/SKILL.md +22 -0
  83. package/.agent/skills/mindforge-research-phase/SKILL.md +186 -0
  84. package/.agent/skills/mindforge-resume-work/SKILL.md +35 -0
  85. package/.agent/skills/mindforge-review/SKILL.md +31 -0
  86. package/.agent/skills/mindforge-review-backlog/SKILL.md +58 -0
  87. package/.agent/skills/mindforge-session-report/SKILL.md +16 -0
  88. package/.agent/skills/mindforge-set-profile/SKILL.md +9 -0
  89. package/.agent/skills/mindforge-settings/SKILL.md +32 -0
  90. package/.agent/skills/mindforge-ship/SKILL.md +16 -0
  91. package/.agent/skills/mindforge-stats/SKILL.md +16 -0
  92. package/.agent/skills/mindforge-thread/SKILL.md +123 -0
  93. package/.agent/skills/mindforge-ui-phase/SKILL.md +24 -0
  94. package/.agent/skills/mindforge-ui-review/SKILL.md +24 -0
  95. package/.agent/skills/mindforge-update/SKILL.md +35 -0
  96. package/.agent/skills/mindforge-validate-phase/SKILL.md +26 -0
  97. package/.agent/skills/mindforge-verify-work/SKILL.md +30 -0
  98. package/.agent/skills/mindforge-workstreams/SKILL.md +65 -0
  99. package/.agent/workflows/mindforge-add-phase.md +112 -0
  100. package/.agent/workflows/mindforge-add-tests.md +351 -0
  101. package/.agent/workflows/mindforge-add-todo.md +158 -0
  102. package/.agent/workflows/mindforge-audit-milestone.md +332 -0
  103. package/.agent/workflows/mindforge-audit-uat.md +109 -0
  104. package/.agent/workflows/mindforge-autonomous.md +815 -0
  105. package/.agent/workflows/mindforge-check-todos.md +177 -0
  106. package/.agent/workflows/mindforge-cleanup.md +152 -0
  107. package/.agent/workflows/mindforge-complete-milestone.md +766 -0
  108. package/.agent/workflows/mindforge-diagnose-issues.md +220 -0
  109. package/.agent/workflows/mindforge-discovery-phase.md +289 -0
  110. package/.agent/workflows/mindforge-discuss-phase-assumptions.md +645 -0
  111. package/.agent/workflows/mindforge-discuss-phase.md +1047 -0
  112. package/.agent/workflows/mindforge-do.md +104 -0
  113. package/.agent/workflows/mindforge-execute-phase.md +838 -0
  114. package/.agent/workflows/mindforge-execute-plan.md +509 -0
  115. package/.agent/workflows/mindforge-fast.md +105 -0
  116. package/.agent/workflows/mindforge-forensics.md +265 -0
  117. package/.agent/workflows/mindforge-health.md +181 -0
  118. package/.agent/workflows/mindforge-help.md +606 -0
  119. package/.agent/workflows/mindforge-insert-phase.md +130 -0
  120. package/.agent/workflows/mindforge-list-phase-assumptions.md +178 -0
  121. package/.agent/workflows/mindforge-list-workspaces.md +56 -0
  122. package/.agent/workflows/mindforge-manager.md +360 -0
  123. package/.agent/workflows/mindforge-map-codebase.md +370 -0
  124. package/.agent/workflows/mindforge-milestone-summary.md +223 -0
  125. package/.agent/workflows/mindforge-new-milestone.md +469 -0
  126. package/.agent/workflows/mindforge-new-project.md +1226 -0
  127. package/.agent/workflows/mindforge-new-workspace.md +237 -0
  128. package/.agent/workflows/mindforge-next.md +97 -0
  129. package/.agent/workflows/mindforge-node-repair.md +92 -0
  130. package/.agent/workflows/mindforge-note.md +156 -0
  131. package/.agent/workflows/mindforge-pause-work.md +176 -0
  132. package/.agent/workflows/mindforge-plan-milestone-gaps.md +273 -0
  133. package/.agent/workflows/mindforge-plan-phase.md +848 -0
  134. package/.agent/workflows/mindforge-plant-seed.md +169 -0
  135. package/.agent/workflows/mindforge-pr-branch.md +129 -0
  136. package/.agent/workflows/mindforge-profile-user.md +450 -0
  137. package/.agent/workflows/mindforge-progress.md +507 -0
  138. package/.agent/workflows/mindforge-quick.md +732 -0
  139. package/.agent/workflows/mindforge-remove-phase.md +155 -0
  140. package/.agent/workflows/mindforge-remove-workspace.md +90 -0
  141. package/.agent/workflows/mindforge-research-phase.md +74 -0
  142. package/.agent/workflows/mindforge-resume-project.md +325 -0
  143. package/.agent/workflows/mindforge-review.md +228 -0
  144. package/.agent/workflows/mindforge-session-report.md +146 -0
  145. package/.agent/workflows/mindforge-settings.md +283 -0
  146. package/.agent/workflows/mindforge-ship.md +228 -0
  147. package/.agent/workflows/mindforge-stats.md +60 -0
  148. package/.agent/workflows/mindforge-transition.md +671 -0
  149. package/.agent/workflows/mindforge-ui-phase.md +290 -0
  150. package/.agent/workflows/mindforge-ui-review.md +157 -0
  151. package/.agent/workflows/mindforge-update.md +323 -0
  152. package/.agent/workflows/mindforge-validate-phase.md +167 -0
  153. package/.agent/workflows/mindforge-verify-phase.md +254 -0
  154. package/.agent/workflows/mindforge-verify-work.md +623 -0
  155. package/.claude/commands/mindforge/add-backlog.md +32 -0
  156. package/.claude/commands/mindforge/agent.md +31 -0
  157. package/.claude/commands/mindforge/approve.md +27 -15
  158. package/.claude/commands/mindforge/audit.md +30 -26
  159. package/.claude/commands/mindforge/auto.md +29 -18
  160. package/.claude/commands/mindforge/benchmark.md +26 -29
  161. package/.claude/commands/mindforge/browse.md +24 -22
  162. package/.claude/commands/mindforge/complete-milestone.md +28 -14
  163. package/.claude/commands/mindforge/costs.md +26 -9
  164. package/.claude/commands/mindforge/cross-review.md +27 -13
  165. package/.claude/commands/mindforge/dashboard.md +35 -98
  166. package/.claude/commands/mindforge/debug.md +34 -126
  167. package/.claude/commands/mindforge/discuss-phase.md +36 -138
  168. package/.claude/commands/mindforge/do.md +31 -0
  169. package/.claude/commands/mindforge/execute-phase.md +37 -190
  170. package/.claude/commands/mindforge/health.md +27 -17
  171. package/.claude/commands/mindforge/help.md +25 -19
  172. package/.claude/commands/mindforge/init-org.md +37 -131
  173. package/.claude/commands/mindforge/init-project.md +40 -155
  174. package/.claude/commands/mindforge/install-skill.md +32 -15
  175. package/.claude/commands/mindforge/learn.md +36 -142
  176. package/.claude/commands/mindforge/map-codebase.md +36 -298
  177. package/.claude/commands/mindforge/marketplace.md +33 -120
  178. package/.claude/commands/mindforge/metrics.md +29 -18
  179. package/.claude/commands/mindforge/migrate.md +33 -40
  180. package/.claude/commands/mindforge/milestone.md +35 -12
  181. package/.claude/commands/mindforge/new-runtime.md +25 -15
  182. package/.claude/commands/mindforge/next.md +34 -105
  183. package/.claude/commands/mindforge/note.md +35 -0
  184. package/.claude/commands/mindforge/plan-phase.md +34 -125
  185. package/.claude/commands/mindforge/plant-seed.md +31 -0
  186. package/.claude/commands/mindforge/plugins.md +30 -36
  187. package/.claude/commands/mindforge/pr-review.md +32 -41
  188. package/.claude/commands/mindforge/profile-team.md +26 -19
  189. package/.claude/commands/mindforge/publish-skill.md +28 -17
  190. package/.claude/commands/mindforge/qa.md +27 -12
  191. package/.claude/commands/mindforge/quick.md +35 -135
  192. package/.claude/commands/mindforge/release.md +27 -8
  193. package/.claude/commands/mindforge/remember.md +25 -10
  194. package/.claude/commands/mindforge/research.md +27 -9
  195. package/.claude/commands/mindforge/retrospective.md +28 -22
  196. package/.claude/commands/mindforge/review-backlog.md +34 -0
  197. package/.claude/commands/mindforge/review.md +37 -157
  198. package/.claude/commands/mindforge/security-scan.md +34 -233
  199. package/.claude/commands/mindforge/session-report.md +39 -0
  200. package/.claude/commands/mindforge/ship.md +34 -100
  201. package/.claude/commands/mindforge/skills.md +36 -141
  202. package/.claude/commands/mindforge/status.md +30 -104
  203. package/.claude/commands/mindforge/steer.md +25 -10
  204. package/.claude/commands/mindforge/sync-confluence.md +28 -9
  205. package/.claude/commands/mindforge/sync-jira.md +32 -12
  206. package/.claude/commands/mindforge/tokens.md +25 -6
  207. package/.claude/commands/mindforge/ui-phase.md +34 -0
  208. package/.claude/commands/mindforge/ui-review.md +36 -0
  209. package/.claude/commands/mindforge/update.md +33 -42
  210. package/.claude/commands/mindforge/validate-phase.md +31 -0
  211. package/.claude/commands/mindforge/verify-phase.md +30 -62
  212. package/.claude/commands/mindforge/workspace.md +28 -25
  213. package/.claude/commands/mindforge/workstreams.md +35 -0
  214. package/.mindforge/memory/decision-library.jsonl +0 -0
  215. package/.mindforge/memory/knowledge-base.jsonl +7 -0
  216. package/.mindforge/memory/pattern-library.jsonl +1 -0
  217. package/.mindforge/memory/team-preferences.jsonl +4 -0
  218. package/.mindforge/personas/advisor-researcher.md +89 -0
  219. package/.mindforge/personas/analyst.md +112 -52
  220. package/.mindforge/personas/architect.md +100 -67
  221. package/.mindforge/personas/assumptions-analyzer-extend.md +87 -0
  222. package/.mindforge/personas/assumptions-analyzer.md +109 -0
  223. package/.mindforge/personas/codebase-mapper-extend.md +93 -0
  224. package/.mindforge/personas/codebase-mapper.md +770 -0
  225. package/.mindforge/personas/coverage-specialist.md +104 -0
  226. package/.mindforge/personas/debug-specialist.md +118 -52
  227. package/.mindforge/personas/debugger.md +97 -0
  228. package/.mindforge/personas/decision-architect.md +102 -0
  229. package/.mindforge/personas/developer.md +97 -85
  230. package/.mindforge/personas/executor.md +88 -0
  231. package/.mindforge/personas/integration-checker.md +92 -0
  232. package/.mindforge/personas/nyquist-auditor.md +84 -0
  233. package/.mindforge/personas/phase-researcher.md +107 -0
  234. package/.mindforge/personas/plan-checker.md +92 -0
  235. package/.mindforge/personas/planner.md +105 -0
  236. package/.mindforge/personas/project-researcher.md +99 -0
  237. package/.mindforge/personas/qa-engineer.md +113 -61
  238. package/.mindforge/personas/release-manager.md +102 -64
  239. package/.mindforge/personas/research-agent.md +109 -24
  240. package/.mindforge/personas/research-synthesizer.md +101 -0
  241. package/.mindforge/personas/roadmapper-extend.md +100 -0
  242. package/.mindforge/personas/roadmapper.md +103 -0
  243. package/.mindforge/personas/security-reviewer.md +114 -91
  244. package/.mindforge/personas/tech-writer.md +118 -51
  245. package/.mindforge/personas/ui-auditor.md +94 -0
  246. package/.mindforge/personas/ui-checker.md +89 -0
  247. package/.mindforge/personas/ui-researcher.md +99 -0
  248. package/.mindforge/personas/user-profiler.md +93 -0
  249. package/.mindforge/personas/verifier.md +101 -0
  250. package/.planning/ROADMAP.md +10 -0
  251. package/.planning/browser-daemon.log +32 -0
  252. package/.planning/phases/01-migrate-gsd-to-mindforge/.gitkeep +0 -0
  253. package/CHANGELOG.md +41 -0
  254. package/MINDFORGE.md +2 -0
  255. package/README.md +40 -3
  256. package/bin/installer-core.js +3 -4
  257. package/docs/PERSONAS.md +611 -0
  258. package/docs/commands-reference.md +1 -0
  259. package/docs/{Context → context}/Master-Context.md +6 -13
  260. package/docs/references/checkpoints.md +778 -0
  261. package/docs/{reference → references}/commands.md +53 -43
  262. package/docs/references/continuation-format.md +249 -0
  263. package/docs/references/decimal-phase-calculation.md +64 -0
  264. package/docs/references/git-integration.md +295 -0
  265. package/docs/references/git-planning-commit.md +38 -0
  266. package/docs/references/model-profile-resolution.md +36 -0
  267. package/docs/references/model-profiles.md +139 -0
  268. package/docs/references/phase-argument-parsing.md +61 -0
  269. package/docs/references/planning-config.md +202 -0
  270. package/docs/references/questioning.md +162 -0
  271. package/docs/references/tdd.md +263 -0
  272. package/docs/references/ui-brand.md +160 -0
  273. package/docs/references/user-profiling.md +681 -0
  274. package/docs/references/verification-patterns.md +612 -0
  275. package/docs/references/workstream-flag.md +58 -0
  276. package/docs/skills-authoring-guide.md +1 -1
  277. package/docs/templates/Agents/CLAUDE-MD.md +122 -0
  278. package/docs/templates/Agents/COPILOT-INSTRUCTIONS.md +7 -0
  279. package/docs/templates/Agents/DEBUGGER-PROMPT.md +91 -0
  280. package/docs/templates/Agents/PLANNER-PROMPT.md +117 -0
  281. package/docs/templates/Execution/CONTINUE-HERE.md +78 -0
  282. package/docs/templates/Execution/DISCUSSION-LOG.md +63 -0
  283. package/docs/templates/Execution/PHASE-PROMPT.md +610 -0
  284. package/docs/templates/Execution/STATE.md +176 -0
  285. package/docs/templates/Execution/SUMMARY-COMPLEX.md +59 -0
  286. package/docs/templates/Execution/SUMMARY-MINIMAL.md +41 -0
  287. package/docs/templates/Execution/SUMMARY-STANDARD.md +48 -0
  288. package/docs/templates/Execution/SUMMARY.md +248 -0
  289. package/docs/templates/Profile/DEV-PREFERENCES.md +21 -0
  290. package/docs/templates/Profile/USER-PROFILE.md +146 -0
  291. package/docs/templates/Profile/USER-SETUP.md +311 -0
  292. package/docs/templates/Project/DISCOVERY.md +146 -0
  293. package/docs/templates/Project/MILESTONE-ARCHIVE.md +123 -0
  294. package/docs/templates/Project/MILESTONE.md +115 -0
  295. package/docs/templates/Project/PROJECT.md +206 -0
  296. package/docs/templates/Project/REQUIREMENTS.md +231 -0
  297. package/docs/templates/Project/RETROSPECTIVE.md +54 -0
  298. package/docs/templates/Project/ROADMAP.md +202 -0
  299. package/docs/templates/Quality/DEBUG.md +164 -0
  300. package/docs/templates/Quality/UAT.md +280 -0
  301. package/docs/templates/Quality/UI-SPEC.md +100 -0
  302. package/docs/templates/Quality/VALIDATION.md +76 -0
  303. package/docs/templates/Quality/VERIFICATION-REPORT.md +322 -0
  304. package/docs/templates/System/CONFIG.json +43 -0
  305. package/docs/templates/System/CONTEXT.md +352 -0
  306. package/docs/templates/codebase/architecture.md +255 -0
  307. package/docs/templates/codebase/concerns.md +310 -0
  308. package/docs/templates/codebase/conventions.md +307 -0
  309. package/docs/templates/codebase/integrations.md +280 -0
  310. package/docs/templates/codebase/stack.md +186 -0
  311. package/docs/templates/codebase/structure.md +285 -0
  312. package/docs/templates/codebase/testing.md +480 -0
  313. package/docs/templates/research/ARCHITECTURE.md +204 -0
  314. package/docs/templates/research/FEATURES.md +147 -0
  315. package/docs/templates/research/PITFALLS.md +200 -0
  316. package/docs/templates/research/STACK.md +120 -0
  317. package/docs/templates/research/SUMMARY.md +170 -0
  318. package/docs/user-guide.md +1 -1
  319. package/package.json +7 -2
  320. /package/docs/{reference → references}/audit-events.md +0 -0
  321. /package/docs/{reference → references}/config-reference.md +0 -0
  322. /package/docs/{reference → references}/sdk-api.md +0 -0
  323. /package/docs/{reference → references}/skills-api.md +0 -0
@@ -0,0 +1,623 @@
1
+ <purpose>
2
+ Validate built features through conversational testing with persistent state. Creates UAT.md that tracks test progress, survives /clear, and feeds gaps into /mindforge-plan-phase --gaps.
3
+
4
+ User tests, the agent records. One test at a time. Plain text responses.
5
+ </purpose>
6
+
7
+ <philosophy>
8
+ **Show expected, ask if reality matches.**
9
+
10
+ the agent presents what SHOULD happen. User confirms or describes what's different.
11
+ - "yes" / "y" / "next" / empty → pass
12
+ - Anything else → logged as issue, severity inferred
13
+
14
+ No Pass/Fail buttons. No severity questions. Just: "Here's what should happen. Does it?"
15
+ </philosophy>
16
+
17
+ <template>
18
+ @.agent/templates/UAT.md
19
+ </template>
20
+
21
+ <process>
22
+
23
+ <step name="initialize" priority="first">
24
+ If $ARGUMENTS contains a phase number, load context:
25
+
26
+ ```bash
27
+ INIT=$(node ".agent/bin/mindforge-tools.cjs" init verify-work "${PHASE_ARG}")
28
+ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
29
+ ```
30
+
31
+ Parse JSON for: `planner_model`, `checker_model`, `commit_docs`, `phase_found`, `phase_dir`, `phase_number`, `phase_name`, `has_verification`.
32
+ </step>
33
+
34
+ <step name="check_active_session">
35
+ **First: Check for active UAT sessions**
36
+
37
+ ```bash
38
+ find .planning/phases -name "*-UAT.md" -type f 2>/dev/null | head -5
39
+ ```
40
+
41
+ **If active sessions exist AND no $ARGUMENTS provided:**
42
+
43
+ Read each file's frontmatter (status, phase) and Current Test section.
44
+
45
+ Display inline:
46
+
47
+ ```
48
+ ## Active UAT Sessions
49
+
50
+ | # | Phase | Status | Current Test | Progress |
51
+ |---|-------|--------|--------------|----------|
52
+ | 1 | 04-comments | testing | 3. Reply to Comment | 2/6 |
53
+ | 2 | 05-auth | testing | 1. Login Form | 0/4 |
54
+
55
+ Reply with a number to resume, or provide a phase number to start new.
56
+ ```
57
+
58
+ Wait for user response.
59
+
60
+ - If user replies with number (1, 2) → Load that file, go to `resume_from_file`
61
+ - If user replies with phase number → Treat as new session, go to `create_uat_file`
62
+
63
+ **If active sessions exist AND $ARGUMENTS provided:**
64
+
65
+ Check if session exists for that phase. If yes, offer to resume or restart.
66
+ If no, continue to `create_uat_file`.
67
+
68
+ **If no active sessions AND no $ARGUMENTS:**
69
+
70
+ ```
71
+ No active UAT sessions.
72
+
73
+ Provide a phase number to start testing (e.g., /mindforge-verify-work 4)
74
+ ```
75
+
76
+ **If no active sessions AND $ARGUMENTS provided:**
77
+
78
+ Continue to `create_uat_file`.
79
+ </step>
80
+
81
+ <step name="find_summaries">
82
+ **Find what to test:**
83
+
84
+ Use `phase_dir` from init (or run init if not already done).
85
+
86
+ ```bash
87
+ ls "$phase_dir"/*-SUMMARY.md 2>/dev/null
88
+ ```
89
+
90
+ Read each SUMMARY.md to extract testable deliverables.
91
+ </step>
92
+
93
+ <step name="extract_tests">
94
+ **Extract testable deliverables from SUMMARY.md:**
95
+
96
+ Parse for:
97
+ 1. **Accomplishments** - Features/functionality added
98
+ 2. **User-facing changes** - UI, workflows, interactions
99
+
100
+ Focus on USER-OBSERVABLE outcomes, not implementation details.
101
+
102
+ For each deliverable, create a test:
103
+ - name: Brief test name
104
+ - expected: What the user should see/experience (specific, observable)
105
+
106
+ Examples:
107
+ - Accomplishment: "Added comment threading with infinite nesting"
108
+ → Test: "Reply to a Comment"
109
+ → Expected: "Clicking Reply opens inline composer below comment. Submitting shows reply nested under parent with visual indentation."
110
+
111
+ Skip internal/non-observable items (refactors, type changes, etc.).
112
+
113
+ **Cold-start smoke test injection:**
114
+
115
+ After extracting tests from SUMMARYs, scan the SUMMARY files for modified/created file paths. If ANY path matches these patterns:
116
+
117
+ `server.ts`, `server.js`, `app.ts`, `app.js`, `index.ts`, `index.js`, `main.ts`, `main.js`, `database/*`, `db/*`, `seed/*`, `seeds/*`, `migrations/*`, `startup*`, `docker-compose*`, `Dockerfile*`
118
+
119
+ Then **prepend** this test to the test list:
120
+
121
+ - name: "Cold Start Smoke Test"
122
+ - expected: "Kill any running server/service. Clear ephemeral state (temp DBs, caches, lock files). Start the application from scratch. Server boots without errors, any seed/migration completes, and a primary query (health check, homepage load, or basic API call) returns live data."
123
+
124
+ This catches bugs that only manifest on fresh start — race conditions in startup sequences, silent seed failures, missing environment setup — which pass against warm state but break in production.
125
+ </step>
126
+
127
+ <step name="create_uat_file">
128
+ **Create UAT file with all tests:**
129
+
130
+ ```bash
131
+ mkdir -p "$PHASE_DIR"
132
+ ```
133
+
134
+ Build test list from extracted deliverables.
135
+
136
+ Create file:
137
+
138
+ ```markdown
139
+ ---
140
+ status: testing
141
+ phase: XX-name
142
+ source: [list of SUMMARY.md files]
143
+ started: [ISO timestamp]
144
+ updated: [ISO timestamp]
145
+ ---
146
+
147
+ ## Current Test
148
+ <!-- OVERWRITE each test - shows where we are -->
149
+
150
+ number: 1
151
+ name: [first test name]
152
+ expected: |
153
+ [what user should observe]
154
+ awaiting: user response
155
+
156
+ ## Tests
157
+
158
+ ### 1. [Test Name]
159
+ expected: [observable behavior]
160
+ result: [pending]
161
+
162
+ ### 2. [Test Name]
163
+ expected: [observable behavior]
164
+ result: [pending]
165
+
166
+ ...
167
+
168
+ ## Summary
169
+
170
+ total: [N]
171
+ passed: 0
172
+ issues: 0
173
+ pending: [N]
174
+ skipped: 0
175
+
176
+ ## Gaps
177
+
178
+ [none yet]
179
+ ```
180
+
181
+ Write to `.planning/phases/XX-name/{phase_num}-UAT.md`
182
+
183
+ Proceed to `present_test`.
184
+ </step>
185
+
186
+ <step name="present_test">
187
+ **Present current test to user:**
188
+
189
+ Read Current Test section from UAT file.
190
+
191
+ Display using checkpoint box format:
192
+
193
+ ```
194
+ ╔══════════════════════════════════════════════════════════════╗
195
+ ║ CHECKPOINT: Verification Required ║
196
+ ╚══════════════════════════════════════════════════════════════╝
197
+
198
+ **Test {number}: {name}**
199
+
200
+ {expected}
201
+
202
+ ──────────────────────────────────────────────────────────────
203
+ → Type "pass" or describe what's wrong
204
+ ──────────────────────────────────────────────────────────────
205
+ ```
206
+
207
+ Wait for user response (plain text, no AskUserQuestion).
208
+ </step>
209
+
210
+ <step name="process_response">
211
+ **Process user response and update file:**
212
+
213
+ **If response indicates pass:**
214
+ - Empty response, "yes", "y", "ok", "pass", "next", "approved", "✓"
215
+
216
+ Update Tests section:
217
+ ```
218
+ ### {N}. {name}
219
+ expected: {expected}
220
+ result: pass
221
+ ```
222
+
223
+ **If response indicates skip:**
224
+ - "skip", "can't test", "n/a"
225
+
226
+ Update Tests section:
227
+ ```
228
+ ### {N}. {name}
229
+ expected: {expected}
230
+ result: skipped
231
+ reason: [user's reason if provided]
232
+ ```
233
+
234
+ **If response indicates blocked:**
235
+ - "blocked", "can't test - server not running", "need physical device", "need release build"
236
+ - Or any response containing: "server", "blocked", "not running", "physical device", "release build"
237
+
238
+ Infer blocked_by tag from response:
239
+ - Contains: server, not running, gateway, API → `server`
240
+ - Contains: physical, device, hardware, real phone → `physical-device`
241
+ - Contains: release, preview, build, EAS → `release-build`
242
+ - Contains: stripe, twilio, third-party, configure → `third-party`
243
+ - Contains: depends on, prior phase, prerequisite → `prior-phase`
244
+ - Default: `other`
245
+
246
+ Update Tests section:
247
+ ```
248
+ ### {N}. {name}
249
+ expected: {expected}
250
+ result: blocked
251
+ blocked_by: {inferred tag}
252
+ reason: "{verbatim user response}"
253
+ ```
254
+
255
+ Note: Blocked tests do NOT go into the Gaps section (they aren't code issues — they're prerequisite gates).
256
+
257
+ **If response is anything else:**
258
+ - Treat as issue description
259
+
260
+ Infer severity from description:
261
+ - Contains: crash, error, exception, fails, broken, unusable → blocker
262
+ - Contains: doesn't work, wrong, missing, can't → major
263
+ - Contains: slow, weird, off, minor, small → minor
264
+ - Contains: color, font, spacing, alignment, visual → cosmetic
265
+ - Default if unclear: major
266
+
267
+ Update Tests section:
268
+ ```
269
+ ### {N}. {name}
270
+ expected: {expected}
271
+ result: issue
272
+ reported: "{verbatim user response}"
273
+ severity: {inferred}
274
+ ```
275
+
276
+ Append to Gaps section (structured YAML for plan-phase --gaps):
277
+ ```yaml
278
+ - truth: "{expected behavior from test}"
279
+ status: failed
280
+ reason: "User reported: {verbatim user response}"
281
+ severity: {inferred}
282
+ test: {N}
283
+ artifacts: [] # Filled by diagnosis
284
+ missing: [] # Filled by diagnosis
285
+ ```
286
+
287
+ **After any response:**
288
+
289
+ Update Summary counts.
290
+ Update frontmatter.updated timestamp.
291
+
292
+ If more tests remain → Update Current Test, go to `present_test`
293
+ If no more tests → Go to `complete_session`
294
+ </step>
295
+
296
+ <step name="resume_from_file">
297
+ **Resume testing from UAT file:**
298
+
299
+ Read the full UAT file.
300
+
301
+ Find first test with `result: [pending]`.
302
+
303
+ Announce:
304
+ ```
305
+ Resuming: Phase {phase} UAT
306
+ Progress: {passed + issues + skipped}/{total}
307
+ Issues found so far: {issues count}
308
+
309
+ Continuing from Test {N}...
310
+ ```
311
+
312
+ Update Current Test section with the pending test.
313
+ Proceed to `present_test`.
314
+ </step>
315
+
316
+ <step name="complete_session">
317
+ **Complete testing and commit:**
318
+
319
+ **Determine final status:**
320
+
321
+ Count results:
322
+ - `pending_count`: tests with `result: [pending]`
323
+ - `blocked_count`: tests with `result: blocked`
324
+ - `skipped_no_reason`: tests with `result: skipped` and no `reason` field
325
+
326
+ ```
327
+ if pending_count > 0 OR blocked_count > 0 OR skipped_no_reason > 0:
328
+ status: partial
329
+ # Session ended but not all tests resolved
330
+ else:
331
+ status: complete
332
+ # All tests have a definitive result (pass, issue, or skipped-with-reason)
333
+ ```
334
+
335
+ Update frontmatter:
336
+ - status: {computed status}
337
+ - updated: [now]
338
+
339
+ Clear Current Test section:
340
+ ```
341
+ ## Current Test
342
+
343
+ [testing complete]
344
+ ```
345
+
346
+ Commit the UAT file:
347
+ ```bash
348
+ node ".agent/bin/mindforge-tools.cjs" commit "test({phase_num}): complete UAT - {passed} passed, {issues} issues" --files ".planning/phases/XX-name/{phase_num}-UAT.md"
349
+ ```
350
+
351
+ Present summary:
352
+ ```
353
+ ## UAT Complete: Phase {phase}
354
+
355
+ | Result | Count |
356
+ |--------|-------|
357
+ | Passed | {N} |
358
+ | Issues | {N} |
359
+ | Skipped| {N} |
360
+
361
+ [If issues > 0:]
362
+ ### Issues Found
363
+
364
+ [List from Issues section]
365
+ ```
366
+
367
+ **If issues > 0:** Proceed to `diagnose_issues`
368
+
369
+ **If issues == 0:**
370
+ ```
371
+ All tests passed. Ready to continue.
372
+
373
+ - `/mindforge-plan-phase {next}` — Plan next phase
374
+ - `/mindforge-execute-phase {next}` — Execute next phase
375
+ - `/mindforge-ui-review {phase}` — visual quality audit (if frontend files were modified)
376
+ ```
377
+ </step>
378
+
379
+ <step name="diagnose_issues">
380
+ **Diagnose root causes before planning fixes:**
381
+
382
+ ```
383
+ ---
384
+
385
+ {N} issues found. Diagnosing root causes...
386
+
387
+ Spawning parallel debug agents to investigate each issue.
388
+ ```
389
+
390
+ - Load diagnose-issues workflow
391
+ - Follow @.agent/workflows/mindforge-diagnose-issues.md
392
+ - Spawn parallel debug agents for each issue
393
+ - Collect root causes
394
+ - Update UAT.md with root causes
395
+ - Proceed to `plan_gap_closure`
396
+
397
+ Diagnosis runs automatically - no user prompt. Parallel agents investigate simultaneously, so overhead is minimal and fixes are more accurate.
398
+ </step>
399
+
400
+ <step name="plan_gap_closure">
401
+ **Auto-plan fixes from diagnosed gaps:**
402
+
403
+ Display:
404
+ ```
405
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
406
+ MindForge ► PLANNING FIXES
407
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
408
+
409
+ ◆ Spawning planner for gap closure...
410
+ ```
411
+
412
+ Spawn mindforge-planner in --gaps mode:
413
+
414
+ ```
415
+ Task(
416
+ prompt="""
417
+ <planning_context>
418
+
419
+ **Phase:** {phase_number}
420
+ **Mode:** gap_closure
421
+
422
+ <files_to_read>
423
+ - {phase_dir}/{phase_num}-UAT.md (UAT with diagnoses)
424
+ - .planning/STATE.md (Project State)
425
+ - .planning/ROADMAP.md (Roadmap)
426
+ </files_to_read>
427
+
428
+ </planning_context>
429
+
430
+ <downstream_consumer>
431
+ Output consumed by /mindforge-execute-phase
432
+ Plans must be executable prompts.
433
+ </downstream_consumer>
434
+ """,
435
+ subagent_type="mindforge-planner",
436
+ model="{planner_model}",
437
+ description="Plan gap fixes for Phase {phase}"
438
+ )
439
+ ```
440
+
441
+ On return:
442
+ - **PLANNING COMPLETE:** Proceed to `verify_gap_plans`
443
+ - **PLANNING INCONCLUSIVE:** Report and offer manual intervention
444
+ </step>
445
+
446
+ <step name="verify_gap_plans">
447
+ **Verify fix plans with checker:**
448
+
449
+ Display:
450
+ ```
451
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
452
+ MindForge ► VERIFYING FIX PLANS
453
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
454
+
455
+ ◆ Spawning plan checker...
456
+ ```
457
+
458
+ Initialize: `iteration_count = 1`
459
+
460
+ Spawn mindforge-plan-checker:
461
+
462
+ ```
463
+ Task(
464
+ prompt="""
465
+ <verification_context>
466
+
467
+ **Phase:** {phase_number}
468
+ **Phase Goal:** Close diagnosed gaps from UAT
469
+
470
+ <files_to_read>
471
+ - {phase_dir}/*-PLAN.md (Plans to verify)
472
+ </files_to_read>
473
+
474
+ </verification_context>
475
+
476
+ <expected_output>
477
+ Return one of:
478
+ - ## VERIFICATION PASSED — all checks pass
479
+ - ## ISSUES FOUND — structured issue list
480
+ </expected_output>
481
+ """,
482
+ subagent_type="mindforge-plan-checker",
483
+ model="{checker_model}",
484
+ description="Verify Phase {phase} fix plans"
485
+ )
486
+ ```
487
+
488
+ On return:
489
+ - **VERIFICATION PASSED:** Proceed to `present_ready`
490
+ - **ISSUES FOUND:** Proceed to `revision_loop`
491
+ </step>
492
+
493
+ <step name="revision_loop">
494
+ **Iterate planner ↔ checker until plans pass (max 3):**
495
+
496
+ **If iteration_count < 3:**
497
+
498
+ Display: `Sending back to planner for revision... (iteration {N}/3)`
499
+
500
+ Spawn mindforge-planner with revision context:
501
+
502
+ ```
503
+ Task(
504
+ prompt="""
505
+ <revision_context>
506
+
507
+ **Phase:** {phase_number}
508
+ **Mode:** revision
509
+
510
+ <files_to_read>
511
+ - {phase_dir}/*-PLAN.md (Existing plans)
512
+ </files_to_read>
513
+
514
+ **Checker issues:**
515
+ {structured_issues_from_checker}
516
+
517
+ </revision_context>
518
+
519
+ <instructions>
520
+ Read existing PLAN.md files. Make targeted updates to address checker issues.
521
+ Do NOT replan from scratch unless issues are fundamental.
522
+ </instructions>
523
+ """,
524
+ subagent_type="mindforge-planner",
525
+ model="{planner_model}",
526
+ description="Revise Phase {phase} plans"
527
+ )
528
+ ```
529
+
530
+ After planner returns → spawn checker again (verify_gap_plans logic)
531
+ Increment iteration_count
532
+
533
+ **If iteration_count >= 3:**
534
+
535
+ Display: `Max iterations reached. {N} issues remain.`
536
+
537
+ Offer options:
538
+ 1. Force proceed (execute despite issues)
539
+ 2. Provide guidance (user gives direction, retry)
540
+ 3. Abandon (exit, user runs /mindforge-plan-phase manually)
541
+
542
+ Wait for user response.
543
+ </step>
544
+
545
+ <step name="present_ready">
546
+ **Present completion and next steps:**
547
+
548
+ ```
549
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
550
+ MindForge ► FIXES READY ✓
551
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
552
+
553
+ **Phase {X}: {Name}** — {N} gap(s) diagnosed, {M} fix plan(s) created
554
+
555
+ | Gap | Root Cause | Fix Plan |
556
+ |-----|------------|----------|
557
+ | {truth 1} | {root_cause} | {phase}-04 |
558
+ | {truth 2} | {root_cause} | {phase}-04 |
559
+
560
+ Plans verified and ready for execution.
561
+
562
+ ───────────────────────────────────────────────────────────────
563
+
564
+ ## ▶ Next Up
565
+
566
+ **Execute fixes** — run fix plans
567
+
568
+ `/clear` then `/mindforge-execute-phase {phase} --gaps-only`
569
+
570
+ ───────────────────────────────────────────────────────────────
571
+ ```
572
+ </step>
573
+
574
+ </process>
575
+
576
+ <update_rules>
577
+ **Batched writes for efficiency:**
578
+
579
+ Keep results in memory. Write to file only when:
580
+ 1. **Issue found** — Preserve the problem immediately
581
+ 2. **Session complete** — Final write before commit
582
+ 3. **Checkpoint** — Every 5 passed tests (safety net)
583
+
584
+ | Section | Rule | When Written |
585
+ |---------|------|--------------|
586
+ | Frontmatter.status | OVERWRITE | Start, complete |
587
+ | Frontmatter.updated | OVERWRITE | On any file write |
588
+ | Current Test | OVERWRITE | On any file write |
589
+ | Tests.{N}.result | OVERWRITE | On any file write |
590
+ | Summary | OVERWRITE | On any file write |
591
+ | Gaps | APPEND | When issue found |
592
+
593
+ On context reset: File shows last checkpoint. Resume from there.
594
+ </update_rules>
595
+
596
+ <severity_inference>
597
+ **Infer severity from user's natural language:**
598
+
599
+ | User says | Infer |
600
+ |-----------|-------|
601
+ | "crashes", "error", "exception", "fails completely" | blocker |
602
+ | "doesn't work", "nothing happens", "wrong behavior" | major |
603
+ | "works but...", "slow", "weird", "minor issue" | minor |
604
+ | "color", "spacing", "alignment", "looks off" | cosmetic |
605
+
606
+ Default to **major** if unclear. User can correct if needed.
607
+
608
+ **Never ask "how severe is this?"** - just infer and move on.
609
+ </severity_inference>
610
+
611
+ <success_criteria>
612
+ - [ ] UAT file created with all tests from SUMMARY.md
613
+ - [ ] Tests presented one at a time with expected behavior
614
+ - [ ] User responses processed as pass/issue/skip
615
+ - [ ] Severity inferred from description (never asked)
616
+ - [ ] Batched writes: on issue, every 5 passes, or completion
617
+ - [ ] Committed on completion
618
+ - [ ] If issues: parallel debug agents diagnose root causes
619
+ - [ ] If issues: mindforge-planner creates fix plans (gap_closure mode)
620
+ - [ ] If issues: mindforge-plan-checker verifies fix plans
621
+ - [ ] If issues: revision loop until plans pass (max 3 iterations)
622
+ - [ ] Ready for `/mindforge-execute-phase --gaps-only` when complete
623
+ </success_criteria>
@@ -0,0 +1,32 @@
1
+ ---
2
+ name: mindforge:add-backlog
3
+ description: Capture ideas in a "parking lot" to keep them out of the active phase sequence
4
+ argument-hint: <description>
5
+ allowed-tools:
6
+ - view_file
7
+ - write_to_file
8
+ - replace_file_content
9
+ - multi_replace_file_content
10
+ ---
11
+
12
+ <objective>
13
+ Capture an idea, task, or feature request in a "parking lot" section of the ROADMAP.md to prevent it from cluttering the active development phases.
14
+ </objective>
15
+
16
+ <execution_context>
17
+ .claude/commands/mindforge/add-backlog.md
18
+ </execution_context>
19
+
20
+ <context>
21
+ Arguments: $ARGUMENTS (The description of the backlog item)
22
+ Target File: ROADMAP.md
23
+ State: Uses 999.x numbering scheme for backlog items.
24
+ </context>
25
+
26
+ <process>
27
+ 1. **Read ROADMAP.md**: Locate the `## Backlog` or `## Future Milestones` section.
28
+ 2. **Initialize if missing**: If no backlog section exists, create `## Backlog` at the end of the file.
29
+ 3. **Determine numbering**: Find the last `999.x` item. If none, start with `999.1`.
30
+ 4. **Append item**: Add the new backlog item with the determined number and the provided description.
31
+ 5. **Confirm**: Notify the user that the item has been parked in the backlog.
32
+ </process>
@@ -0,0 +1,31 @@
1
+ ---
2
+ name: mindforge:agent
3
+ description: Spawn or invoke a specialized enterprise persona from the MindForge library
4
+ argument-hint: "[persona-name] [prompt]"
5
+ allowed-tools:
6
+ - list_dir
7
+ - view_file
8
+ ---
9
+
10
+ <objective>
11
+ Provide an on-demand mechanism to "spawn" any of the 13+ standardized MindForge personas. This allows the user to switch the AI assistant's context, role, and process to a specific specialized mode (e.g., Roadmapper, Security Reviewer, Analyst).
12
+ </objective>
13
+
14
+ <execution_context>
15
+ .claude/commands/mindforge/agent.md
16
+ </execution_context>
17
+
18
+ <context>
19
+ Personas Directory: `.mindforge/personas/`
20
+ State: Loads the persona's XML-tagged structure into the active system context.
21
+ </context>
22
+
23
+ <process>
24
+ 1. **List Personas**: If no arguments are provided, list all available `.md` files in `.mindforge/personas/` with their name and description (parsed from YAML).
25
+ 2. **Load Persona**: If a name is provided:
26
+ - Locate `.mindforge/personas/[name].md`.
27
+ - Read the file content.
28
+ - Present the persona's role and success criteria to the user.
29
+ 3. **Switch Mode**: Instruct the AI (through the current session context) to adopt the role, philosophy, and process defined in the loaded file.
30
+ 4. **Initial Task**: If a prompt is provided as the second argument, immediately execute that prompt using the newly adopted persona.
31
+ </process>