@jokerized/getresearchdone 0.4.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 (711) hide show
  1. package/.claude-plugin/plugin.json +103 -0
  2. package/README.md +211 -0
  3. package/agents/grd-baseline-assessor.md +684 -0
  4. package/agents/grd-code-reviewer.md +300 -0
  5. package/agents/grd-codebase-mapper.md +355 -0
  6. package/agents/grd-critique-agent.md +119 -0
  7. package/agents/grd-debugger.md +519 -0
  8. package/agents/grd-deep-diver.md +737 -0
  9. package/agents/grd-eval-planner.md +913 -0
  10. package/agents/grd-eval-reporter.md +717 -0
  11. package/agents/grd-executor.md +683 -0
  12. package/agents/grd-feasibility-analyst.md +624 -0
  13. package/agents/grd-integration-checker.md +367 -0
  14. package/agents/grd-knowledge-miner.md +81 -0
  15. package/agents/grd-migrator.md +88 -0
  16. package/agents/grd-phase-researcher.md +697 -0
  17. package/agents/grd-plan-checker.md +443 -0
  18. package/agents/grd-planner.md +1532 -0
  19. package/agents/grd-product-owner.md +562 -0
  20. package/agents/grd-project-researcher.md +513 -0
  21. package/agents/grd-research-synthesizer.md +273 -0
  22. package/agents/grd-roadmapper.md +798 -0
  23. package/agents/grd-surveyor.md +566 -0
  24. package/agents/grd-verifier.md +893 -0
  25. package/bin/gd.js +4 -0
  26. package/bin/gd.ts +227 -0
  27. package/bin/grd-manifest.js +4 -0
  28. package/bin/grd-manifest.ts +286 -0
  29. package/bin/grd-mcp-server.js +4 -0
  30. package/bin/grd-mcp-server.ts +124 -0
  31. package/bin/grd-tools.js +4 -0
  32. package/bin/grd-tools.ts +2471 -0
  33. package/bin/postinstall.js +4 -0
  34. package/bin/postinstall.ts +80 -0
  35. package/commands/add-phase.md +123 -0
  36. package/commands/add-todo.md +87 -0
  37. package/commands/assess-baseline.md +289 -0
  38. package/commands/autopilot.md +100 -0
  39. package/commands/autoplan.md +55 -0
  40. package/commands/check-todos.md +87 -0
  41. package/commands/compare-methods.md +262 -0
  42. package/commands/complete-milestone.md +225 -0
  43. package/commands/debug.md +372 -0
  44. package/commands/deep-dive.md +288 -0
  45. package/commands/discover.md +281 -0
  46. package/commands/discuss-phase.md +188 -0
  47. package/commands/discuss.md +55 -0
  48. package/commands/eval-report.md +310 -0
  49. package/commands/evolve.md +79 -0
  50. package/commands/execute-phase.md +1017 -0
  51. package/commands/feasibility.md +292 -0
  52. package/commands/help.md +407 -0
  53. package/commands/init.md +1508 -0
  54. package/commands/insert-phase.md +113 -0
  55. package/commands/iterate.md +327 -0
  56. package/commands/list-phase-assumptions.md +217 -0
  57. package/commands/long-term-roadmap.md +202 -0
  58. package/commands/map-codebase.md +111 -0
  59. package/commands/migrate.md +159 -0
  60. package/commands/new-milestone.md +169 -0
  61. package/commands/pause-work.md +83 -0
  62. package/commands/plan-milestone-gaps.md +373 -0
  63. package/commands/plan-phase.md +655 -0
  64. package/commands/principles.md +328 -0
  65. package/commands/product-plan.md +319 -0
  66. package/commands/progress.md +481 -0
  67. package/commands/quick.md +167 -0
  68. package/commands/reapply-patches.md +154 -0
  69. package/commands/remove-phase.md +97 -0
  70. package/commands/requirement.md +96 -0
  71. package/commands/resume-project.md +113 -0
  72. package/commands/settings.md +1144 -0
  73. package/commands/survey.md +242 -0
  74. package/commands/sync.md +246 -0
  75. package/commands/tracker-setup.md +322 -0
  76. package/commands/update.md +202 -0
  77. package/commands/verify-phase.md +335 -0
  78. package/commands/verify-work.md +701 -0
  79. package/commands/wireup.md +29 -0
  80. package/dist/bin/gd.d.ts +3 -0
  81. package/dist/bin/gd.d.ts.map +1 -0
  82. package/dist/bin/gd.js +178 -0
  83. package/dist/bin/gd.js.map +1 -0
  84. package/dist/bin/grd-manifest.d.ts +3 -0
  85. package/dist/bin/grd-manifest.d.ts.map +1 -0
  86. package/dist/bin/grd-manifest.js +202 -0
  87. package/dist/bin/grd-manifest.js.map +1 -0
  88. package/dist/bin/grd-mcp-server.d.ts +3 -0
  89. package/dist/bin/grd-mcp-server.d.ts.map +1 -0
  90. package/dist/bin/grd-mcp-server.js +71 -0
  91. package/dist/bin/grd-mcp-server.js.map +1 -0
  92. package/dist/bin/grd-tools.d.ts +3 -0
  93. package/dist/bin/grd-tools.d.ts.map +1 -0
  94. package/dist/bin/grd-tools.js +1680 -0
  95. package/dist/bin/grd-tools.js.map +1 -0
  96. package/dist/bin/postinstall.d.ts +3 -0
  97. package/dist/bin/postinstall.d.ts.map +1 -0
  98. package/dist/bin/postinstall.js +61 -0
  99. package/dist/bin/postinstall.js.map +1 -0
  100. package/dist/lib/autopilot-milestone.d.ts +2 -0
  101. package/dist/lib/autopilot-milestone.d.ts.map +1 -0
  102. package/dist/lib/autopilot-milestone.js +94 -0
  103. package/dist/lib/autopilot-milestone.js.map +1 -0
  104. package/dist/lib/autopilot-pipeline.d.ts +2 -0
  105. package/dist/lib/autopilot-pipeline.d.ts.map +1 -0
  106. package/dist/lib/autopilot-pipeline.js +830 -0
  107. package/dist/lib/autopilot-pipeline.js.map +1 -0
  108. package/dist/lib/autopilot-waves.d.ts +2 -0
  109. package/dist/lib/autopilot-waves.d.ts.map +1 -0
  110. package/dist/lib/autopilot-waves.js +266 -0
  111. package/dist/lib/autopilot-waves.js.map +1 -0
  112. package/dist/lib/autopilot.d.ts +2 -0
  113. package/dist/lib/autopilot.d.ts.map +1 -0
  114. package/dist/lib/autopilot.js +1314 -0
  115. package/dist/lib/autopilot.js.map +1 -0
  116. package/dist/lib/autoplan.d.ts +2 -0
  117. package/dist/lib/autoplan.d.ts.map +1 -0
  118. package/dist/lib/autoplan.js +198 -0
  119. package/dist/lib/autoplan.js.map +1 -0
  120. package/dist/lib/autoresearch.d.ts +2 -0
  121. package/dist/lib/autoresearch.d.ts.map +1 -0
  122. package/dist/lib/autoresearch.js +626 -0
  123. package/dist/lib/autoresearch.js.map +1 -0
  124. package/dist/lib/backend.d.ts +2 -0
  125. package/dist/lib/backend.d.ts.map +1 -0
  126. package/dist/lib/backend.js +1036 -0
  127. package/dist/lib/backend.js.map +1 -0
  128. package/dist/lib/benchmark.d.ts +99 -0
  129. package/dist/lib/benchmark.d.ts.map +1 -0
  130. package/dist/lib/benchmark.js +278 -0
  131. package/dist/lib/benchmark.js.map +1 -0
  132. package/dist/lib/citations.d.ts +2 -0
  133. package/dist/lib/citations.d.ts.map +1 -0
  134. package/dist/lib/citations.js +642 -0
  135. package/dist/lib/citations.js.map +1 -0
  136. package/dist/lib/cleanup.d.ts +2 -0
  137. package/dist/lib/cleanup.d.ts.map +1 -0
  138. package/dist/lib/cleanup.js +1222 -0
  139. package/dist/lib/cleanup.js.map +1 -0
  140. package/dist/lib/cli/adapters.d.ts +10 -0
  141. package/dist/lib/cli/adapters.d.ts.map +1 -0
  142. package/dist/lib/cli/adapters.js +27 -0
  143. package/dist/lib/cli/adapters.js.map +1 -0
  144. package/dist/lib/cli/agent.d.ts +17 -0
  145. package/dist/lib/cli/agent.d.ts.map +1 -0
  146. package/dist/lib/cli/agent.js +53 -0
  147. package/dist/lib/cli/agent.js.map +1 -0
  148. package/dist/lib/cli/index.d.ts +21 -0
  149. package/dist/lib/cli/index.d.ts.map +1 -0
  150. package/dist/lib/cli/index.js +264 -0
  151. package/dist/lib/cli/index.js.map +1 -0
  152. package/dist/lib/cli/output.d.ts +20 -0
  153. package/dist/lib/cli/output.d.ts.map +1 -0
  154. package/dist/lib/cli/output.js +22 -0
  155. package/dist/lib/cli/output.js.map +1 -0
  156. package/dist/lib/cli/scan-dispatch.d.ts +9 -0
  157. package/dist/lib/cli/scan-dispatch.d.ts.map +1 -0
  158. package/dist/lib/cli/scan-dispatch.js +107 -0
  159. package/dist/lib/cli/scan-dispatch.js.map +1 -0
  160. package/dist/lib/cli/tools.d.ts +16 -0
  161. package/dist/lib/cli/tools.d.ts.map +1 -0
  162. package/dist/lib/cli/tools.js +168 -0
  163. package/dist/lib/cli/tools.js.map +1 -0
  164. package/dist/lib/commands/_dashboard-parsers.d.ts +2 -0
  165. package/dist/lib/commands/_dashboard-parsers.d.ts.map +1 -0
  166. package/dist/lib/commands/_dashboard-parsers.js +192 -0
  167. package/dist/lib/commands/_dashboard-parsers.js.map +1 -0
  168. package/dist/lib/commands/analysis.d.ts +2 -0
  169. package/dist/lib/commands/analysis.d.ts.map +1 -0
  170. package/dist/lib/commands/analysis.js +1418 -0
  171. package/dist/lib/commands/analysis.js.map +1 -0
  172. package/dist/lib/commands/assumptions.d.ts +2 -0
  173. package/dist/lib/commands/assumptions.d.ts.map +1 -0
  174. package/dist/lib/commands/assumptions.js +166 -0
  175. package/dist/lib/commands/assumptions.js.map +1 -0
  176. package/dist/lib/commands/blame.d.ts +2 -0
  177. package/dist/lib/commands/blame.d.ts.map +1 -0
  178. package/dist/lib/commands/blame.js +133 -0
  179. package/dist/lib/commands/blame.js.map +1 -0
  180. package/dist/lib/commands/budget.d.ts +2 -0
  181. package/dist/lib/commands/budget.d.ts.map +1 -0
  182. package/dist/lib/commands/budget.js +100 -0
  183. package/dist/lib/commands/budget.js.map +1 -0
  184. package/dist/lib/commands/check-plans.d.ts +2 -0
  185. package/dist/lib/commands/check-plans.d.ts.map +1 -0
  186. package/dist/lib/commands/check-plans.js +190 -0
  187. package/dist/lib/commands/check-plans.js.map +1 -0
  188. package/dist/lib/commands/config.d.ts +2 -0
  189. package/dist/lib/commands/config.d.ts.map +1 -0
  190. package/dist/lib/commands/config.js +188 -0
  191. package/dist/lib/commands/config.js.map +1 -0
  192. package/dist/lib/commands/dashboard.d.ts +2 -0
  193. package/dist/lib/commands/dashboard.d.ts.map +1 -0
  194. package/dist/lib/commands/dashboard.js +466 -0
  195. package/dist/lib/commands/dashboard.js.map +1 -0
  196. package/dist/lib/commands/estimate.d.ts +2 -0
  197. package/dist/lib/commands/estimate.d.ts.map +1 -0
  198. package/dist/lib/commands/estimate.js +148 -0
  199. package/dist/lib/commands/estimate.js.map +1 -0
  200. package/dist/lib/commands/eval-diff.d.ts +2 -0
  201. package/dist/lib/commands/eval-diff.d.ts.map +1 -0
  202. package/dist/lib/commands/eval-diff.js +213 -0
  203. package/dist/lib/commands/eval-diff.js.map +1 -0
  204. package/dist/lib/commands/freshness.d.ts +2 -0
  205. package/dist/lib/commands/freshness.d.ts.map +1 -0
  206. package/dist/lib/commands/freshness.js +163 -0
  207. package/dist/lib/commands/freshness.js.map +1 -0
  208. package/dist/lib/commands/health.d.ts +2 -0
  209. package/dist/lib/commands/health.d.ts.map +1 -0
  210. package/dist/lib/commands/health.js +435 -0
  211. package/dist/lib/commands/health.js.map +1 -0
  212. package/dist/lib/commands/index.d.ts +2 -0
  213. package/dist/lib/commands/index.d.ts.map +1 -0
  214. package/dist/lib/commands/index.js +128 -0
  215. package/dist/lib/commands/index.js.map +1 -0
  216. package/dist/lib/commands/install.d.ts +56 -0
  217. package/dist/lib/commands/install.d.ts.map +1 -0
  218. package/dist/lib/commands/install.js +214 -0
  219. package/dist/lib/commands/install.js.map +1 -0
  220. package/dist/lib/commands/knowhow-aggregator.d.ts +2 -0
  221. package/dist/lib/commands/knowhow-aggregator.d.ts.map +1 -0
  222. package/dist/lib/commands/knowhow-aggregator.js +279 -0
  223. package/dist/lib/commands/knowhow-aggregator.js.map +1 -0
  224. package/dist/lib/commands/knowledge-search.d.ts +2 -0
  225. package/dist/lib/commands/knowledge-search.d.ts.map +1 -0
  226. package/dist/lib/commands/knowledge-search.js +113 -0
  227. package/dist/lib/commands/knowledge-search.js.map +1 -0
  228. package/dist/lib/commands/long-term-roadmap.d.ts +2 -0
  229. package/dist/lib/commands/long-term-roadmap.d.ts.map +1 -0
  230. package/dist/lib/commands/long-term-roadmap.js +272 -0
  231. package/dist/lib/commands/long-term-roadmap.js.map +1 -0
  232. package/dist/lib/commands/patterns.d.ts +91 -0
  233. package/dist/lib/commands/patterns.d.ts.map +1 -0
  234. package/dist/lib/commands/patterns.js +391 -0
  235. package/dist/lib/commands/patterns.js.map +1 -0
  236. package/dist/lib/commands/phase-info.d.ts +2 -0
  237. package/dist/lib/commands/phase-info.d.ts.map +1 -0
  238. package/dist/lib/commands/phase-info.js +509 -0
  239. package/dist/lib/commands/phase-info.js.map +1 -0
  240. package/dist/lib/commands/plan-lint.d.ts +56 -0
  241. package/dist/lib/commands/plan-lint.d.ts.map +1 -0
  242. package/dist/lib/commands/plan-lint.js +481 -0
  243. package/dist/lib/commands/plan-lint.js.map +1 -0
  244. package/dist/lib/commands/plan-phase.d.ts +53 -0
  245. package/dist/lib/commands/plan-phase.d.ts.map +1 -0
  246. package/dist/lib/commands/plan-phase.js +288 -0
  247. package/dist/lib/commands/plan-phase.js.map +1 -0
  248. package/dist/lib/commands/progress.d.ts +2 -0
  249. package/dist/lib/commands/progress.d.ts.map +1 -0
  250. package/dist/lib/commands/progress.js +266 -0
  251. package/dist/lib/commands/progress.js.map +1 -0
  252. package/dist/lib/commands/quality.d.ts +2 -0
  253. package/dist/lib/commands/quality.d.ts.map +1 -0
  254. package/dist/lib/commands/quality.js +80 -0
  255. package/dist/lib/commands/quality.js.map +1 -0
  256. package/dist/lib/commands/rollback.d.ts +2 -0
  257. package/dist/lib/commands/rollback.d.ts.map +1 -0
  258. package/dist/lib/commands/rollback.js +145 -0
  259. package/dist/lib/commands/rollback.js.map +1 -0
  260. package/dist/lib/commands/scan.d.ts +25 -0
  261. package/dist/lib/commands/scan.d.ts.map +1 -0
  262. package/dist/lib/commands/scan.js +28 -0
  263. package/dist/lib/commands/scan.js.map +1 -0
  264. package/dist/lib/commands/search.d.ts +2 -0
  265. package/dist/lib/commands/search.d.ts.map +1 -0
  266. package/dist/lib/commands/search.js +212 -0
  267. package/dist/lib/commands/search.js.map +1 -0
  268. package/dist/lib/commands/select-candidate.d.ts +128 -0
  269. package/dist/lib/commands/select-candidate.d.ts.map +1 -0
  270. package/dist/lib/commands/select-candidate.js +518 -0
  271. package/dist/lib/commands/select-candidate.js.map +1 -0
  272. package/dist/lib/commands/singularity.d.ts +2 -0
  273. package/dist/lib/commands/singularity.d.ts.map +1 -0
  274. package/dist/lib/commands/singularity.js +185 -0
  275. package/dist/lib/commands/singularity.js.map +1 -0
  276. package/dist/lib/commands/slug-timestamp.d.ts +2 -0
  277. package/dist/lib/commands/slug-timestamp.d.ts.map +1 -0
  278. package/dist/lib/commands/slug-timestamp.js +54 -0
  279. package/dist/lib/commands/slug-timestamp.js.map +1 -0
  280. package/dist/lib/commands/tail.d.ts +2 -0
  281. package/dist/lib/commands/tail.d.ts.map +1 -0
  282. package/dist/lib/commands/tail.js +100 -0
  283. package/dist/lib/commands/tail.js.map +1 -0
  284. package/dist/lib/commands/todo.d.ts +2 -0
  285. package/dist/lib/commands/todo.d.ts.map +1 -0
  286. package/dist/lib/commands/todo.js +200 -0
  287. package/dist/lib/commands/todo.js.map +1 -0
  288. package/dist/lib/commands/watch.d.ts +2 -0
  289. package/dist/lib/commands/watch.d.ts.map +1 -0
  290. package/dist/lib/commands/watch.js +72 -0
  291. package/dist/lib/commands/watch.js.map +1 -0
  292. package/dist/lib/complexity.d.ts +55 -0
  293. package/dist/lib/complexity.d.ts.map +1 -0
  294. package/dist/lib/complexity.js +80 -0
  295. package/dist/lib/complexity.js.map +1 -0
  296. package/dist/lib/context/agents.d.ts +2 -0
  297. package/dist/lib/context/agents.d.ts.map +1 -0
  298. package/dist/lib/context/agents.js +344 -0
  299. package/dist/lib/context/agents.js.map +1 -0
  300. package/dist/lib/context/base.d.ts +2 -0
  301. package/dist/lib/context/base.d.ts.map +1 -0
  302. package/dist/lib/context/base.js +81 -0
  303. package/dist/lib/context/base.js.map +1 -0
  304. package/dist/lib/context/execute.d.ts +2 -0
  305. package/dist/lib/context/execute.d.ts.map +1 -0
  306. package/dist/lib/context/execute.js +753 -0
  307. package/dist/lib/context/execute.js.map +1 -0
  308. package/dist/lib/context/index.d.ts +2 -0
  309. package/dist/lib/context/index.d.ts.map +1 -0
  310. package/dist/lib/context/index.js +88 -0
  311. package/dist/lib/context/index.js.map +1 -0
  312. package/dist/lib/context/progress.d.ts +2 -0
  313. package/dist/lib/context/progress.d.ts.map +1 -0
  314. package/dist/lib/context/progress.js +178 -0
  315. package/dist/lib/context/progress.js.map +1 -0
  316. package/dist/lib/context/project.d.ts +2 -0
  317. package/dist/lib/context/project.d.ts.map +1 -0
  318. package/dist/lib/context/project.js +413 -0
  319. package/dist/lib/context/project.js.map +1 -0
  320. package/dist/lib/context/research.d.ts +2 -0
  321. package/dist/lib/context/research.d.ts.map +1 -0
  322. package/dist/lib/context/research.js +466 -0
  323. package/dist/lib/context/research.js.map +1 -0
  324. package/dist/lib/dead-ends.d.ts +28 -0
  325. package/dist/lib/dead-ends.d.ts.map +1 -0
  326. package/dist/lib/dead-ends.js +451 -0
  327. package/dist/lib/dead-ends.js.map +1 -0
  328. package/dist/lib/deps.d.ts +2 -0
  329. package/dist/lib/deps.d.ts.map +1 -0
  330. package/dist/lib/deps.js +630 -0
  331. package/dist/lib/deps.js.map +1 -0
  332. package/dist/lib/discussion.d.ts +2 -0
  333. package/dist/lib/discussion.d.ts.map +1 -0
  334. package/dist/lib/discussion.js +1041 -0
  335. package/dist/lib/discussion.js.map +1 -0
  336. package/dist/lib/drift.d.ts +36 -0
  337. package/dist/lib/drift.d.ts.map +1 -0
  338. package/dist/lib/drift.js +481 -0
  339. package/dist/lib/drift.js.map +1 -0
  340. package/dist/lib/evolve/_dimensions-features.d.ts +2 -0
  341. package/dist/lib/evolve/_dimensions-features.d.ts.map +1 -0
  342. package/dist/lib/evolve/_dimensions-features.js +369 -0
  343. package/dist/lib/evolve/_dimensions-features.js.map +1 -0
  344. package/dist/lib/evolve/_dimensions.d.ts +2 -0
  345. package/dist/lib/evolve/_dimensions.d.ts.map +1 -0
  346. package/dist/lib/evolve/_dimensions.js +358 -0
  347. package/dist/lib/evolve/_dimensions.js.map +1 -0
  348. package/dist/lib/evolve/_product-ideation.d.ts +2 -0
  349. package/dist/lib/evolve/_product-ideation.d.ts.map +1 -0
  350. package/dist/lib/evolve/_product-ideation.js +281 -0
  351. package/dist/lib/evolve/_product-ideation.js.map +1 -0
  352. package/dist/lib/evolve/_prompts.d.ts +2 -0
  353. package/dist/lib/evolve/_prompts.d.ts.map +1 -0
  354. package/dist/lib/evolve/_prompts.js +153 -0
  355. package/dist/lib/evolve/_prompts.js.map +1 -0
  356. package/dist/lib/evolve/cli.d.ts +2 -0
  357. package/dist/lib/evolve/cli.d.ts.map +1 -0
  358. package/dist/lib/evolve/cli.js +224 -0
  359. package/dist/lib/evolve/cli.js.map +1 -0
  360. package/dist/lib/evolve/discovery.d.ts +2 -0
  361. package/dist/lib/evolve/discovery.d.ts.map +1 -0
  362. package/dist/lib/evolve/discovery.js +391 -0
  363. package/dist/lib/evolve/discovery.js.map +1 -0
  364. package/dist/lib/evolve/index.d.ts +2 -0
  365. package/dist/lib/evolve/index.d.ts.map +1 -0
  366. package/dist/lib/evolve/index.js +88 -0
  367. package/dist/lib/evolve/index.js.map +1 -0
  368. package/dist/lib/evolve/orchestrator.d.ts +2 -0
  369. package/dist/lib/evolve/orchestrator.d.ts.map +1 -0
  370. package/dist/lib/evolve/orchestrator.js +851 -0
  371. package/dist/lib/evolve/orchestrator.js.map +1 -0
  372. package/dist/lib/evolve/scoring.d.ts +2 -0
  373. package/dist/lib/evolve/scoring.d.ts.map +1 -0
  374. package/dist/lib/evolve/scoring.js +118 -0
  375. package/dist/lib/evolve/scoring.js.map +1 -0
  376. package/dist/lib/evolve/state.d.ts +2 -0
  377. package/dist/lib/evolve/state.d.ts.map +1 -0
  378. package/dist/lib/evolve/state.js +264 -0
  379. package/dist/lib/evolve/state.js.map +1 -0
  380. package/dist/lib/evolve/types.d.ts +249 -0
  381. package/dist/lib/evolve/types.d.ts.map +1 -0
  382. package/dist/lib/evolve/types.js +3 -0
  383. package/dist/lib/evolve/types.js.map +1 -0
  384. package/dist/lib/frontmatter.d.ts +2 -0
  385. package/dist/lib/frontmatter.d.ts.map +1 -0
  386. package/dist/lib/frontmatter.js +513 -0
  387. package/dist/lib/frontmatter.js.map +1 -0
  388. package/dist/lib/gates.d.ts +2 -0
  389. package/dist/lib/gates.d.ts.map +1 -0
  390. package/dist/lib/gates.js +578 -0
  391. package/dist/lib/gates.js.map +1 -0
  392. package/dist/lib/genome.d.ts +10 -0
  393. package/dist/lib/genome.d.ts.map +1 -0
  394. package/dist/lib/genome.js +368 -0
  395. package/dist/lib/genome.js.map +1 -0
  396. package/dist/lib/got.d.ts +2 -0
  397. package/dist/lib/got.d.ts.map +1 -0
  398. package/dist/lib/got.js +280 -0
  399. package/dist/lib/got.js.map +1 -0
  400. package/dist/lib/invariants.d.ts +2 -0
  401. package/dist/lib/invariants.d.ts.map +1 -0
  402. package/dist/lib/invariants.js +298 -0
  403. package/dist/lib/invariants.js.map +1 -0
  404. package/dist/lib/knowledge.d.ts +2 -0
  405. package/dist/lib/knowledge.d.ts.map +1 -0
  406. package/dist/lib/knowledge.js +658 -0
  407. package/dist/lib/knowledge.js.map +1 -0
  408. package/dist/lib/long-term-roadmap.d.ts +2 -0
  409. package/dist/lib/long-term-roadmap.d.ts.map +1 -0
  410. package/dist/lib/long-term-roadmap.js +602 -0
  411. package/dist/lib/long-term-roadmap.js.map +1 -0
  412. package/dist/lib/markdown-split.d.ts +2 -0
  413. package/dist/lib/markdown-split.d.ts.map +1 -0
  414. package/dist/lib/markdown-split.js +199 -0
  415. package/dist/lib/markdown-split.js.map +1 -0
  416. package/dist/lib/mcp-server.d.ts +2 -0
  417. package/dist/lib/mcp-server.d.ts.map +1 -0
  418. package/dist/lib/mcp-server.js +2424 -0
  419. package/dist/lib/mcp-server.js.map +1 -0
  420. package/dist/lib/metrics.d.ts +16 -0
  421. package/dist/lib/metrics.d.ts.map +1 -0
  422. package/dist/lib/metrics.js +48 -0
  423. package/dist/lib/metrics.js.map +1 -0
  424. package/dist/lib/overstory.d.ts +2 -0
  425. package/dist/lib/overstory.d.ts.map +1 -0
  426. package/dist/lib/overstory.js +211 -0
  427. package/dist/lib/overstory.js.map +1 -0
  428. package/dist/lib/parallel.d.ts +2 -0
  429. package/dist/lib/parallel.d.ts.map +1 -0
  430. package/dist/lib/parallel.js +349 -0
  431. package/dist/lib/parallel.js.map +1 -0
  432. package/dist/lib/paths.d.ts +2 -0
  433. package/dist/lib/paths.d.ts.map +1 -0
  434. package/dist/lib/paths.js +254 -0
  435. package/dist/lib/paths.js.map +1 -0
  436. package/dist/lib/phase-complete-llm.d.ts +22 -0
  437. package/dist/lib/phase-complete-llm.d.ts.map +1 -0
  438. package/dist/lib/phase-complete-llm.js +331 -0
  439. package/dist/lib/phase-complete-llm.js.map +1 -0
  440. package/dist/lib/phase-complete.d.ts +46 -0
  441. package/dist/lib/phase-complete.d.ts.map +1 -0
  442. package/dist/lib/phase-complete.js +278 -0
  443. package/dist/lib/phase-complete.js.map +1 -0
  444. package/dist/lib/phase-io.d.ts +2 -0
  445. package/dist/lib/phase-io.d.ts.map +1 -0
  446. package/dist/lib/phase-io.js +126 -0
  447. package/dist/lib/phase-io.js.map +1 -0
  448. package/dist/lib/phase.d.ts +2 -0
  449. package/dist/lib/phase.d.ts.map +1 -0
  450. package/dist/lib/phase.js +1344 -0
  451. package/dist/lib/phase.js.map +1 -0
  452. package/dist/lib/plan-tournament.d.ts +63 -0
  453. package/dist/lib/plan-tournament.d.ts.map +1 -0
  454. package/dist/lib/plan-tournament.js +353 -0
  455. package/dist/lib/plan-tournament.js.map +1 -0
  456. package/dist/lib/refinement.d.ts +74 -0
  457. package/dist/lib/refinement.d.ts.map +1 -0
  458. package/dist/lib/refinement.js +283 -0
  459. package/dist/lib/refinement.js.map +1 -0
  460. package/dist/lib/requirements.d.ts +2 -0
  461. package/dist/lib/requirements.d.ts.map +1 -0
  462. package/dist/lib/requirements.js +355 -0
  463. package/dist/lib/requirements.js.map +1 -0
  464. package/dist/lib/research-bundle.d.ts +2 -0
  465. package/dist/lib/research-bundle.d.ts.map +1 -0
  466. package/dist/lib/research-bundle.js +246 -0
  467. package/dist/lib/research-bundle.js.map +1 -0
  468. package/dist/lib/roadmap.d.ts +2 -0
  469. package/dist/lib/roadmap.d.ts.map +1 -0
  470. package/dist/lib/roadmap.js +541 -0
  471. package/dist/lib/roadmap.js.map +1 -0
  472. package/dist/lib/sample.d.ts +16 -0
  473. package/dist/lib/sample.d.ts.map +1 -0
  474. package/dist/lib/sample.js +20 -0
  475. package/dist/lib/sample.js.map +1 -0
  476. package/dist/lib/scaffold.d.ts +2 -0
  477. package/dist/lib/scaffold.d.ts.map +1 -0
  478. package/dist/lib/scaffold.js +355 -0
  479. package/dist/lib/scaffold.js.map +1 -0
  480. package/dist/lib/scan/_utils.d.ts +11 -0
  481. package/dist/lib/scan/_utils.d.ts.map +1 -0
  482. package/dist/lib/scan/_utils.js +36 -0
  483. package/dist/lib/scan/_utils.js.map +1 -0
  484. package/dist/lib/scan/base64.d.ts +15 -0
  485. package/dist/lib/scan/base64.d.ts.map +1 -0
  486. package/dist/lib/scan/base64.js +66 -0
  487. package/dist/lib/scan/base64.js.map +1 -0
  488. package/dist/lib/scan/ignorefile.d.ts +30 -0
  489. package/dist/lib/scan/ignorefile.d.ts.map +1 -0
  490. package/dist/lib/scan/ignorefile.js +101 -0
  491. package/dist/lib/scan/ignorefile.js.map +1 -0
  492. package/dist/lib/scan/injection.d.ts +14 -0
  493. package/dist/lib/scan/injection.d.ts.map +1 -0
  494. package/dist/lib/scan/injection.js +39 -0
  495. package/dist/lib/scan/injection.js.map +1 -0
  496. package/dist/lib/scan/patterns.d.ts +17 -0
  497. package/dist/lib/scan/patterns.d.ts.map +1 -0
  498. package/dist/lib/scan/patterns.js +123 -0
  499. package/dist/lib/scan/patterns.js.map +1 -0
  500. package/dist/lib/scan/strip-markdown.d.ts +7 -0
  501. package/dist/lib/scan/strip-markdown.d.ts.map +1 -0
  502. package/dist/lib/scan/strip-markdown.js +38 -0
  503. package/dist/lib/scan/strip-markdown.js.map +1 -0
  504. package/dist/lib/scan/types.d.ts +23 -0
  505. package/dist/lib/scan/types.d.ts.map +1 -0
  506. package/dist/lib/scan/types.js +3 -0
  507. package/dist/lib/scan/types.js.map +1 -0
  508. package/dist/lib/scheduler-wait.d.ts +2 -0
  509. package/dist/lib/scheduler-wait.d.ts.map +1 -0
  510. package/dist/lib/scheduler-wait.js +59 -0
  511. package/dist/lib/scheduler-wait.js.map +1 -0
  512. package/dist/lib/scheduler.d.ts +254 -0
  513. package/dist/lib/scheduler.d.ts.map +1 -0
  514. package/dist/lib/scheduler.js +1147 -0
  515. package/dist/lib/scheduler.js.map +1 -0
  516. package/dist/lib/state.d.ts +2 -0
  517. package/dist/lib/state.d.ts.map +1 -0
  518. package/dist/lib/state.js +744 -0
  519. package/dist/lib/state.js.map +1 -0
  520. package/dist/lib/think.d.ts +18 -0
  521. package/dist/lib/think.d.ts.map +1 -0
  522. package/dist/lib/think.js +317 -0
  523. package/dist/lib/think.js.map +1 -0
  524. package/dist/lib/tracker.d.ts +2 -0
  525. package/dist/lib/tracker.d.ts.map +1 -0
  526. package/dist/lib/tracker.js +1121 -0
  527. package/dist/lib/tracker.js.map +1 -0
  528. package/dist/lib/types.d.ts +1514 -0
  529. package/dist/lib/types.d.ts.map +1 -0
  530. package/dist/lib/types.js +4 -0
  531. package/dist/lib/types.js.map +1 -0
  532. package/dist/lib/utils.d.ts +2 -0
  533. package/dist/lib/utils.d.ts.map +1 -0
  534. package/dist/lib/utils.js +1363 -0
  535. package/dist/lib/utils.js.map +1 -0
  536. package/dist/lib/verify.d.ts +2 -0
  537. package/dist/lib/verify.d.ts.map +1 -0
  538. package/dist/lib/verify.js +1153 -0
  539. package/dist/lib/verify.js.map +1 -0
  540. package/dist/lib/wireup/autofix.d.ts +2 -0
  541. package/dist/lib/wireup/autofix.d.ts.map +1 -0
  542. package/dist/lib/wireup/autofix.js +188 -0
  543. package/dist/lib/wireup/autofix.js.map +1 -0
  544. package/dist/lib/wireup/cli.d.ts +2 -0
  545. package/dist/lib/wireup/cli.d.ts.map +1 -0
  546. package/dist/lib/wireup/cli.js +194 -0
  547. package/dist/lib/wireup/cli.js.map +1 -0
  548. package/dist/lib/wireup/detection.d.ts +47 -0
  549. package/dist/lib/wireup/detection.d.ts.map +1 -0
  550. package/dist/lib/wireup/detection.js +410 -0
  551. package/dist/lib/wireup/detection.js.map +1 -0
  552. package/dist/lib/wireup/discovery.d.ts +2 -0
  553. package/dist/lib/wireup/discovery.d.ts.map +1 -0
  554. package/dist/lib/wireup/discovery.js +934 -0
  555. package/dist/lib/wireup/discovery.js.map +1 -0
  556. package/dist/lib/wireup/execution.d.ts +2 -0
  557. package/dist/lib/wireup/execution.d.ts.map +1 -0
  558. package/dist/lib/wireup/execution.js +573 -0
  559. package/dist/lib/wireup/execution.js.map +1 -0
  560. package/dist/lib/wireup/index.d.ts +2 -0
  561. package/dist/lib/wireup/index.d.ts.map +1 -0
  562. package/dist/lib/wireup/index.js +85 -0
  563. package/dist/lib/wireup/index.js.map +1 -0
  564. package/dist/lib/wireup/orchestrator.d.ts +2 -0
  565. package/dist/lib/wireup/orchestrator.d.ts.map +1 -0
  566. package/dist/lib/wireup/orchestrator.js +366 -0
  567. package/dist/lib/wireup/orchestrator.js.map +1 -0
  568. package/dist/lib/wireup/report.d.ts +47 -0
  569. package/dist/lib/wireup/report.d.ts.map +1 -0
  570. package/dist/lib/wireup/report.js +201 -0
  571. package/dist/lib/wireup/report.js.map +1 -0
  572. package/dist/lib/wireup/scenarios.d.ts +2 -0
  573. package/dist/lib/wireup/scenarios.d.ts.map +1 -0
  574. package/dist/lib/wireup/scenarios.js +516 -0
  575. package/dist/lib/wireup/scenarios.js.map +1 -0
  576. package/dist/lib/wireup/state.d.ts +2 -0
  577. package/dist/lib/wireup/state.d.ts.map +1 -0
  578. package/dist/lib/wireup/state.js +102 -0
  579. package/dist/lib/wireup/state.js.map +1 -0
  580. package/dist/lib/wireup/types.d.ts +376 -0
  581. package/dist/lib/wireup/types.d.ts.map +1 -0
  582. package/dist/lib/wireup/types.js +3 -0
  583. package/dist/lib/wireup/types.js.map +1 -0
  584. package/dist/lib/worktree.d.ts +2 -0
  585. package/dist/lib/worktree.d.ts.map +1 -0
  586. package/dist/lib/worktree.js +999 -0
  587. package/dist/lib/worktree.js.map +1 -0
  588. package/lib/autopilot-milestone.ts +136 -0
  589. package/lib/autopilot-pipeline.ts +1179 -0
  590. package/lib/autopilot-waves.ts +361 -0
  591. package/lib/autopilot.ts +1874 -0
  592. package/lib/autoplan.ts +280 -0
  593. package/lib/autoresearch.js +4 -0
  594. package/lib/autoresearch.ts +886 -0
  595. package/lib/backend.ts +1252 -0
  596. package/lib/benchmark.ts +341 -0
  597. package/lib/citations.ts +760 -0
  598. package/lib/cleanup.ts +1588 -0
  599. package/lib/cli/adapters.ts +41 -0
  600. package/lib/cli/agent.ts +83 -0
  601. package/lib/cli/index.ts +273 -0
  602. package/lib/cli/output.ts +33 -0
  603. package/lib/cli/scan-dispatch.ts +130 -0
  604. package/lib/cli/tools.ts +198 -0
  605. package/lib/commands/_dashboard-parsers.ts +275 -0
  606. package/lib/commands/analysis.ts +1851 -0
  607. package/lib/commands/assumptions.ts +232 -0
  608. package/lib/commands/blame.ts +174 -0
  609. package/lib/commands/budget.ts +148 -0
  610. package/lib/commands/check-plans.ts +233 -0
  611. package/lib/commands/config.ts +287 -0
  612. package/lib/commands/dashboard.ts +680 -0
  613. package/lib/commands/estimate.ts +204 -0
  614. package/lib/commands/eval-diff.ts +252 -0
  615. package/lib/commands/freshness.ts +213 -0
  616. package/lib/commands/health.ts +607 -0
  617. package/lib/commands/index.ts +266 -0
  618. package/lib/commands/install.ts +307 -0
  619. package/lib/commands/knowhow-aggregator.ts +345 -0
  620. package/lib/commands/knowledge-search.ts +153 -0
  621. package/lib/commands/long-term-roadmap.ts +390 -0
  622. package/lib/commands/patterns.ts +465 -0
  623. package/lib/commands/phase-info.ts +698 -0
  624. package/lib/commands/plan-lint.ts +546 -0
  625. package/lib/commands/plan-phase.ts +375 -0
  626. package/lib/commands/progress.ts +319 -0
  627. package/lib/commands/quality.ts +138 -0
  628. package/lib/commands/rollback.ts +195 -0
  629. package/lib/commands/scan.ts +72 -0
  630. package/lib/commands/search.ts +300 -0
  631. package/lib/commands/select-candidate.ts +687 -0
  632. package/lib/commands/singularity.ts +222 -0
  633. package/lib/commands/slug-timestamp.ts +74 -0
  634. package/lib/commands/tail.ts +129 -0
  635. package/lib/commands/todo.ts +273 -0
  636. package/lib/commands/watch.ts +80 -0
  637. package/lib/complexity.ts +117 -0
  638. package/lib/context/agents.ts +505 -0
  639. package/lib/context/base.ts +123 -0
  640. package/lib/context/execute.ts +977 -0
  641. package/lib/context/index.ts +110 -0
  642. package/lib/context/progress.ts +278 -0
  643. package/lib/context/project.ts +531 -0
  644. package/lib/context/research.ts +646 -0
  645. package/lib/dead-ends.ts +506 -0
  646. package/lib/deps.ts +773 -0
  647. package/lib/discussion.ts +1275 -0
  648. package/lib/drift.ts +519 -0
  649. package/lib/evolve/_dimensions-features.ts +525 -0
  650. package/lib/evolve/_dimensions.ts +511 -0
  651. package/lib/evolve/_product-ideation.ts +405 -0
  652. package/lib/evolve/_prompts.ts +178 -0
  653. package/lib/evolve/cli.ts +330 -0
  654. package/lib/evolve/discovery.ts +571 -0
  655. package/lib/evolve/index.ts +105 -0
  656. package/lib/evolve/orchestrator.ts +1139 -0
  657. package/lib/evolve/scoring.ts +167 -0
  658. package/lib/evolve/state.ts +330 -0
  659. package/lib/evolve/types.ts +290 -0
  660. package/lib/frontmatter.ts +615 -0
  661. package/lib/gates.ts +695 -0
  662. package/lib/genome.ts +402 -0
  663. package/lib/got.js +4 -0
  664. package/lib/got.ts +361 -0
  665. package/lib/invariants.ts +378 -0
  666. package/lib/knowledge.ts +768 -0
  667. package/lib/long-term-roadmap.ts +806 -0
  668. package/lib/markdown-split.ts +273 -0
  669. package/lib/mcp-server.ts +3292 -0
  670. package/lib/metrics.ts +49 -0
  671. package/lib/overstory.ts +270 -0
  672. package/lib/parallel.ts +570 -0
  673. package/lib/paths.ts +293 -0
  674. package/lib/phase-complete-llm.ts +376 -0
  675. package/lib/phase-complete.ts +366 -0
  676. package/lib/phase-io.ts +101 -0
  677. package/lib/phase.ts +1981 -0
  678. package/lib/plan-tournament.ts +426 -0
  679. package/lib/refinement.ts +349 -0
  680. package/lib/requirements.ts +469 -0
  681. package/lib/research-bundle.ts +300 -0
  682. package/lib/roadmap.ts +775 -0
  683. package/lib/scaffold.ts +480 -0
  684. package/lib/scan/_utils.ts +37 -0
  685. package/lib/scan/base64.ts +90 -0
  686. package/lib/scan/ignorefile.ts +109 -0
  687. package/lib/scan/injection.ts +67 -0
  688. package/lib/scan/patterns.ts +139 -0
  689. package/lib/scan/strip-markdown.ts +39 -0
  690. package/lib/scan/types.ts +28 -0
  691. package/lib/scheduler-wait.ts +58 -0
  692. package/lib/scheduler.ts +1370 -0
  693. package/lib/state.ts +1000 -0
  694. package/lib/think.ts +365 -0
  695. package/lib/tracker.ts +1591 -0
  696. package/lib/types.ts +1663 -0
  697. package/lib/utils.ts +1479 -0
  698. package/lib/verify.ts +1434 -0
  699. package/lib/wireup/autofix.ts +241 -0
  700. package/lib/wireup/cli.ts +278 -0
  701. package/lib/wireup/detection.ts +542 -0
  702. package/lib/wireup/discovery.ts +1063 -0
  703. package/lib/wireup/execution.ts +686 -0
  704. package/lib/wireup/index.ts +117 -0
  705. package/lib/wireup/orchestrator.ts +519 -0
  706. package/lib/wireup/report.ts +286 -0
  707. package/lib/wireup/scenarios.ts +616 -0
  708. package/lib/wireup/state.ts +139 -0
  709. package/lib/wireup/types.ts +436 -0
  710. package/lib/worktree.ts +1309 -0
  711. package/package.json +67 -0
@@ -0,0 +1,701 @@
1
+ ---
2
+ description: Validate built features through conversational testing with metrics
3
+ argument-hint: <phase number>
4
+ ---
5
+
6
+ <purpose>
7
+ Validate built features through conversational testing with persistent state and quantitative metrics. Creates UAT.md that tracks test progress, survives /clear, and feeds gaps into /grd:plan-phase --gaps.
8
+
9
+ User tests, Claude records. One test at a time. Plain text responses.
10
+
11
+ GRD addition: After standard UAT tests, also checks quantitative metrics from EVAL.md if available. Metric tests present expected values and let users verify actuals.
12
+ </purpose>
13
+
14
+ <philosophy>
15
+ **Show expected, ask if reality matches.**
16
+
17
+ Claude presents what SHOULD happen. User confirms or describes what's different.
18
+ - "yes" / "y" / "next" / empty → pass
19
+ - Anything else → logged as issue, severity inferred
20
+
21
+ No Pass/Fail buttons. No severity questions. Just: "Here's what should happen. Does it?"
22
+
23
+ **R&D extension:** For quantitative metrics, present expected ranges and actual values. User confirms if results are acceptable or flags concerns.
24
+ </philosophy>
25
+
26
+ <template>
27
+ @${CLAUDE_PLUGIN_ROOT}/templates/UAT.md
28
+ </template>
29
+
30
+ <process>
31
+
32
+ <step name="initialize" priority="first">
33
+ If $ARGUMENTS contains a phase number, load context:
34
+
35
+ ```bash
36
+ INIT=$(node ${CLAUDE_PLUGIN_ROOT}/bin/grd-tools.js init verify-work "${PHASE_ARG}")
37
+ ```
38
+
39
+ Parse JSON for: `planner_model`, `checker_model`, `commit_docs`, `phase_found`, `phase_dir`, `phase_number`, `phase_name`, `has_verification`, `has_eval`.
40
+ </step>
41
+
42
+ <step name="check_active_session">
43
+ **First: Check for active UAT sessions**
44
+
45
+ ```bash
46
+ find ${phases_dir} -name "*-UAT.md" -type f 2>/dev/null | head -5
47
+ ```
48
+
49
+ **If active sessions exist AND no $ARGUMENTS provided:**
50
+
51
+ Read each file's frontmatter (status, phase) and Current Test section.
52
+
53
+ Display inline:
54
+
55
+ ```
56
+ ## Active UAT Sessions
57
+
58
+ | # | Phase | Status | Current Test | Progress |
59
+ |---|-------|--------|--------------|----------|
60
+ | 1 | 04-model | testing | 3. Forward Pass | 2/6 |
61
+ | 2 | 05-training | testing | 1. Training Loop | 0/4 |
62
+
63
+ Reply with a number to resume, or provide a phase number to start new.
64
+ ```
65
+
66
+ Wait for user response.
67
+
68
+ - If user replies with number (1, 2) → Load that file, go to `resume_from_file`
69
+ - If user replies with phase number → Treat as new session, go to `create_uat_file`
70
+
71
+ **If active sessions exist AND $ARGUMENTS provided:**
72
+
73
+ Check if session exists for that phase. If yes, offer to resume or restart.
74
+ If no, continue to `create_uat_file`.
75
+
76
+ **If no active sessions AND no $ARGUMENTS:**
77
+
78
+ ```
79
+ No active UAT sessions.
80
+
81
+ Provide a phase number to start testing (e.g., /grd:verify-work 4)
82
+ ```
83
+
84
+ **If no active sessions AND $ARGUMENTS provided:**
85
+
86
+ Continue to `create_uat_file`.
87
+ </step>
88
+
89
+ <step name="find_summaries">
90
+ **Find what to test:**
91
+
92
+ Use `phase_dir` from init (or run init if not already done).
93
+
94
+ ```bash
95
+ ls "$phase_dir"/*-SUMMARY.md 2>/dev/null
96
+ ```
97
+
98
+ Read each SUMMARY.md to extract testable deliverables.
99
+
100
+ **GRD: Also check for EVAL.md:**
101
+ ```bash
102
+ ls "$phase_dir"/*-EVAL.md 2>/dev/null
103
+ ```
104
+
105
+ If EVAL.md exists, extract quantitative test criteria (metrics, baselines, targets).
106
+ </step>
107
+
108
+ <step name="extract_tests">
109
+ **Extract testable deliverables from SUMMARY.md:**
110
+
111
+ Parse for:
112
+ 1. **Accomplishments** - Features/functionality added
113
+ 2. **User-facing changes** - UI, workflows, interactions
114
+ 3. **Experiment results** - Model metrics, evaluation outcomes (GRD-specific)
115
+
116
+ Focus on USER-OBSERVABLE outcomes and MEASURABLE metrics, not implementation details.
117
+
118
+ For each deliverable, create a test:
119
+ - name: Brief test name
120
+ - expected: What the user should see/experience (specific, observable)
121
+
122
+ **GRD-specific tests from EVAL.md (if exists):**
123
+ - name: Metric name
124
+ - expected: "Metric X should be >= Y (baseline: Z)"
125
+ - type: metric (distinguish from functional tests)
126
+ - verify_command: Command to run to check the metric
127
+
128
+ Examples:
129
+ - Accomplishment: "Implemented attention mechanism with learned positional encoding"
130
+ → Test: "Model Forward Pass"
131
+ → Expected: "Running forward pass on sample input produces output with expected shape"
132
+
133
+ - Eval metric: "accuracy: 0.856 (target: >= 0.85)"
134
+ → Test: "Model Accuracy"
135
+ → Expected: "Accuracy >= 0.85 (baseline: 0.78, target: 0.85). Run: `python src/eval/evaluate.py`"
136
+ → Type: metric
137
+
138
+ Skip internal/non-observable items (refactors, type changes, etc.).
139
+ </step>
140
+
141
+ <step name="create_uat_file">
142
+ **Create UAT file with all tests:**
143
+
144
+ ```bash
145
+ mkdir -p "$PHASE_DIR"
146
+ ```
147
+
148
+ Build test list from extracted deliverables.
149
+
150
+ Create file:
151
+
152
+ ```markdown
153
+ ---
154
+ status: testing
155
+ phase: XX-name
156
+ source: [list of SUMMARY.md files]
157
+ eval_source: [EVAL.md if exists, null otherwise]
158
+ started: [ISO timestamp]
159
+ updated: [ISO timestamp]
160
+ ---
161
+
162
+ ## Current Test
163
+ <!-- OVERWRITE each test - shows where we are -->
164
+
165
+ number: 1
166
+ name: [first test name]
167
+ expected: |
168
+ [what user should observe]
169
+ awaiting: user response
170
+
171
+ ## Tests
172
+
173
+ ### 1. [Test Name]
174
+ expected: [observable behavior]
175
+ result: [pending]
176
+
177
+ ### 2. [Test Name]
178
+ expected: [observable behavior]
179
+ result: [pending]
180
+
181
+ ...
182
+
183
+ ### M. [Metric Test Name] (metric)
184
+ expected: [metric >= target (baseline: X)]
185
+ verify_command: [command to run]
186
+ result: [pending]
187
+
188
+ ## Summary
189
+
190
+ total: [N]
191
+ passed: 0
192
+ issues: 0
193
+ pending: [N]
194
+ skipped: 0
195
+ metrics_checked: 0
196
+ metrics_passed: 0
197
+
198
+ ## Gaps
199
+
200
+ [none yet]
201
+ ```
202
+
203
+ Write to `${phase_dir}/{phase}-UAT.md`
204
+
205
+ Proceed to `present_test`.
206
+ </step>
207
+
208
+ <step name="present_test">
209
+ **Present current test to user:**
210
+
211
+ Read Current Test section from UAT file.
212
+
213
+ **For functional tests:**
214
+
215
+ Display using checkpoint box format:
216
+
217
+ ```
218
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
219
+ CHECKPOINT: Verification Required
220
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
221
+
222
+ **Test {number}: {name}**
223
+
224
+ {expected}
225
+
226
+ ──────────────────────────────────────────────────────
227
+ → Type "pass" or describe what's wrong
228
+ ──────────────────────────────────────────────────────
229
+ ```
230
+
231
+ **For metric tests (GRD-specific):**
232
+
233
+ ```
234
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
235
+ CHECKPOINT: Metric Verification
236
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
237
+
238
+ **Test {number}: {name}** (metric)
239
+
240
+ {expected}
241
+
242
+ **To verify, run:**
243
+ {verify_command}
244
+
245
+ ──────────────────────────────────────────────────────
246
+ → Type "pass {actual_value}" or describe the issue
247
+ ──────────────────────────────────────────────────────
248
+ ```
249
+
250
+ Wait for user response (plain text, no AskUserQuestion).
251
+ </step>
252
+
253
+ <step name="process_response">
254
+ **Process user response and update file:**
255
+
256
+ **If response indicates pass:**
257
+ - Empty response, "yes", "y", "ok", "pass", "next", "approved"
258
+
259
+ Update Tests section:
260
+ ```
261
+ ### {N}. {name}
262
+ expected: {expected}
263
+ result: pass
264
+ ```
265
+
266
+ For metric tests with value provided (e.g., "pass 0.862"):
267
+ ```
268
+ ### {N}. {name} (metric)
269
+ expected: {expected}
270
+ result: pass
271
+ actual_value: {value from user}
272
+ delta_from_baseline: {+/- delta}
273
+ ```
274
+
275
+ **If response indicates skip:**
276
+ - "skip", "can't test", "n/a"
277
+
278
+ Update Tests section:
279
+ ```
280
+ ### {N}. {name}
281
+ expected: {expected}
282
+ result: skipped
283
+ reason: [user's reason if provided]
284
+ ```
285
+
286
+ **If response is anything else:**
287
+ - Treat as issue description
288
+
289
+ Infer severity from description:
290
+ - Contains: crash, error, exception, fails, broken, unusable → blocker
291
+ - Contains: doesn't work, wrong, missing, can't → major
292
+ - Contains: slow, weird, off, minor, small → minor
293
+ - Contains: color, font, spacing, alignment, visual → cosmetic
294
+ - Contains: below target, metric worse, regression, lower than → metric_miss (GRD-specific)
295
+ - Default if unclear: major
296
+
297
+ Update Tests section:
298
+ ```
299
+ ### {N}. {name}
300
+ expected: {expected}
301
+ result: issue
302
+ reported: "{verbatim user response}"
303
+ severity: {inferred}
304
+ ```
305
+
306
+ Append to Gaps section (structured YAML for plan-phase --gaps):
307
+ ```yaml
308
+ - truth: "{expected behavior from test}"
309
+ status: failed
310
+ reason: "User reported: {verbatim user response}"
311
+ severity: {inferred}
312
+ test: {N}
313
+ type: {functional | metric}
314
+ actual_value: {if metric test, value reported}
315
+ artifacts: [] # Filled by diagnosis
316
+ missing: [] # Filled by diagnosis
317
+ ```
318
+
319
+ **After any response:**
320
+
321
+ Update Summary counts (including metrics_checked and metrics_passed for metric tests).
322
+ Update frontmatter.updated timestamp.
323
+
324
+ If more tests remain → Update Current Test, go to `present_test`
325
+ If no more tests → Go to `complete_session`
326
+ </step>
327
+
328
+ <step name="resume_from_file">
329
+ **Resume testing from UAT file:**
330
+
331
+ Read the full UAT file.
332
+
333
+ Find first test with `result: [pending]`.
334
+
335
+ Announce:
336
+ ```
337
+ Resuming: Phase {phase} UAT
338
+ Progress: {passed + issues + skipped}/{total}
339
+ Issues found so far: {issues count}
340
+ Metrics: {metrics_passed}/{metrics_checked} passed
341
+
342
+ Continuing from Test {N}...
343
+ ```
344
+
345
+ Update Current Test section with the pending test.
346
+ Proceed to `present_test`.
347
+ </step>
348
+
349
+ <step name="complete_session">
350
+ **Complete testing and commit:**
351
+
352
+ Update frontmatter:
353
+ - status: complete
354
+ - updated: [now]
355
+
356
+ Clear Current Test section:
357
+ ```
358
+ ## Current Test
359
+
360
+ [testing complete]
361
+ ```
362
+
363
+ Commit the UAT file:
364
+ ```bash
365
+ node ${CLAUDE_PLUGIN_ROOT}/bin/grd-tools.js commit "test({phase}): complete UAT - {passed} passed, {issues} issues, {metrics_passed}/{metrics_checked} metrics" --files "${phase_dir}/{phase}-UAT.md"
366
+ ```
367
+
368
+ Present summary:
369
+ ```
370
+ ## UAT Complete: Phase {phase}
371
+
372
+ | Result | Count |
373
+ |--------|-------|
374
+ | Passed | {N} |
375
+ | Issues | {N} |
376
+ | Skipped| {N} |
377
+ | Metrics Checked | {N} |
378
+ | Metrics Passed | {N} |
379
+
380
+ [If metric issues:]
381
+ ### Metric Results
382
+
383
+ | Metric | Baseline | Target | Actual | Status |
384
+ |--------|----------|--------|--------|--------|
385
+ | {name} | {baseline} | {target} | {actual} | PASS/FAIL |
386
+
387
+ [If issues > 0:]
388
+ ### Issues Found
389
+
390
+ [List from Issues section]
391
+ ```
392
+
393
+ **If issues > 0:** Proceed to `diagnose_issues`
394
+
395
+ **If issues == 0:**
396
+ ```
397
+ All tests passed. Ready to continue.
398
+
399
+ - `/grd:plan-phase {next}` — Plan next phase
400
+ - `/grd:execute-phase {next}` — Execute next phase
401
+ - `/grd:eval-report {phase}` — Generate detailed evaluation report
402
+ - `/grd:iterate {phase}` — If metrics need improvement
403
+ ```
404
+ </step>
405
+
406
+ <step name="diagnose_issues">
407
+ **Diagnose root causes before planning fixes:**
408
+
409
+ ```
410
+ ---
411
+
412
+ {N} issues found. Diagnosing root causes...
413
+
414
+ Spawning parallel debug agents to investigate each issue.
415
+ ```
416
+
417
+ Resolve debugger model:
418
+ ```bash
419
+ DEBUGGER_MODEL=$(node ${CLAUDE_PLUGIN_ROOT}/bin/grd-tools.js resolve-model grd-debugger --raw)
420
+ ```
421
+
422
+ For each gap, spawn a grd-debugger agent with symptoms pre-filled:
423
+
424
+ ```
425
+ Task(
426
+ prompt="""
427
+ <objective>
428
+ Investigate issue: {slug}
429
+
430
+ **Summary:** {truth}
431
+ </objective>
432
+
433
+ <symptoms>
434
+ expected: {expected}
435
+ actual: {reported}
436
+ errors: {errors or "None reported"}
437
+ reproduction: Test {test_num} in UAT
438
+ timeline: Discovered during UAT
439
+ </symptoms>
440
+
441
+ <phase_context>
442
+ @${phase_dir}/*-CONTEXT.md
443
+ </phase_context>
444
+
445
+ <mode>
446
+ symptoms_prefilled: true
447
+ goal: find_root_cause_only
448
+ </mode>
449
+
450
+ <debug_file>
451
+ Create: .planning/debug/{slug}.md
452
+ </debug_file>
453
+ """,
454
+ subagent_type="grd:grd-debugger",
455
+ model="{debugger_model}",
456
+ description="Debug: {truth_short}"
457
+ )
458
+ ```
459
+
460
+ **All agents spawn in single message** (parallel execution).
461
+
462
+ Collect root causes from all agents. Update UAT.md gaps with root_cause, artifacts, and missing fields.
463
+
464
+ ```bash
465
+ node ${CLAUDE_PLUGIN_ROOT}/bin/grd-tools.js commit "docs({phase}): add root causes from diagnosis" --files "${phase_dir}/{phase}-UAT.md"
466
+ ```
467
+
468
+ Display diagnosis summary, then proceed to `plan_gap_closure`.
469
+ </step>
470
+
471
+ <step name="plan_gap_closure">
472
+ **Auto-plan fixes from diagnosed gaps:**
473
+
474
+ Display:
475
+ ```
476
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
477
+ GRD ► PLANNING FIXES
478
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
479
+
480
+ Spawning planner for gap closure...
481
+ ```
482
+
483
+ Resolve planner model:
484
+ ```bash
485
+ PLANNER_MODEL=$(node ${CLAUDE_PLUGIN_ROOT}/bin/grd-tools.js resolve-model grd-planner --raw)
486
+ ```
487
+
488
+ Spawn grd-planner in --gaps mode:
489
+
490
+ ```
491
+ Task(
492
+ prompt="""
493
+ <planning_context>
494
+
495
+ **Phase:** {phase_number}
496
+ **Mode:** gap_closure
497
+
498
+ **UAT with diagnoses:**
499
+ @${phase_dir}/{phase}-UAT.md
500
+
501
+ **Project State:**
502
+ @.planning/STATE.md
503
+
504
+ **Roadmap:**
505
+ @.planning/ROADMAP.md
506
+
507
+ **Phase Context:**
508
+ @${phase_dir}/*-CONTEXT.md
509
+
510
+ </planning_context>
511
+
512
+ <paths>
513
+ research_dir: ${research_dir}
514
+ phase_dir: ${phase_dir}
515
+ </paths>
516
+
517
+ <downstream_consumer>
518
+ Output consumed by /grd:execute-phase
519
+ Plans must be executable prompts.
520
+ </downstream_consumer>
521
+ """,
522
+ subagent_type="grd:grd-planner",
523
+ model="{planner_model}",
524
+ description="Plan gap fixes for Phase {phase}"
525
+ )
526
+ ```
527
+
528
+ On return:
529
+ - **PLANNING COMPLETE:** Proceed to `verify_gap_plans`
530
+ - **PLANNING INCONCLUSIVE:** Report and offer manual intervention
531
+ </step>
532
+
533
+ <step name="verify_gap_plans">
534
+ **Verify fix plans with checker:**
535
+
536
+ Display:
537
+ ```
538
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
539
+ GRD ► VERIFYING FIX PLANS
540
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
541
+
542
+ Spawning plan checker...
543
+ ```
544
+
545
+ Initialize: `iteration_count = 1`
546
+
547
+ Resolve checker model:
548
+ ```bash
549
+ CHECKER_MODEL=$(node ${CLAUDE_PLUGIN_ROOT}/bin/grd-tools.js resolve-model grd-plan-checker --raw)
550
+ ```
551
+
552
+ Spawn grd-plan-checker:
553
+
554
+ ```
555
+ Task(
556
+ prompt="""
557
+ <verification_context>
558
+
559
+ **Phase:** {phase_number}
560
+ **Phase Goal:** Close diagnosed gaps from UAT
561
+
562
+ **Plans to verify:**
563
+ @${phase_dir}/*-PLAN.md
564
+
565
+ **Phase Context:**
566
+ @${phase_dir}/*-CONTEXT.md
567
+
568
+ </verification_context>
569
+
570
+ <paths>
571
+ research_dir: ${research_dir}
572
+ phase_dir: ${phase_dir}
573
+ </paths>
574
+
575
+ <expected_output>
576
+ Return one of:
577
+ - ## VERIFICATION PASSED — all checks pass
578
+ - ## ISSUES FOUND — structured issue list
579
+ </expected_output>
580
+ """,
581
+ subagent_type="grd:grd-plan-checker",
582
+ model="{checker_model}",
583
+ description="Verify Phase {phase} fix plans"
584
+ )
585
+ ```
586
+
587
+ On return:
588
+ - **VERIFICATION PASSED:** Proceed to `present_ready`
589
+ - **ISSUES FOUND:** Proceed to `revision_loop`
590
+ </step>
591
+
592
+ <step name="revision_loop">
593
+ **Iterate planner <-> checker until plans pass (max 3):**
594
+
595
+ **If iteration_count < 3:**
596
+
597
+ Display: `Sending back to planner for revision... (iteration {N}/3)`
598
+
599
+ Spawn grd-planner with revision context, then spawn checker again.
600
+ Increment iteration_count.
601
+
602
+ **If iteration_count >= 3:**
603
+
604
+ Display: `Max iterations reached. {N} issues remain.`
605
+
606
+ Offer options:
607
+ 1. Force proceed (execute despite issues)
608
+ 2. Provide guidance (user gives direction, retry)
609
+ 3. Abandon (exit, user runs /grd:plan-phase manually)
610
+
611
+ Wait for user response.
612
+ </step>
613
+
614
+ <step name="present_ready">
615
+ **Present completion and next steps:**
616
+
617
+ ```
618
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
619
+ GRD ► FIXES READY
620
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
621
+
622
+ **Phase {X}: {Name}** — {N} gap(s) diagnosed, {M} fix plan(s) created
623
+
624
+ | Gap | Type | Root Cause | Fix Plan |
625
+ |-----|------|------------|----------|
626
+ | {truth 1} | functional | {root_cause} | {phase}-04 |
627
+ | {truth 2} | metric | {root_cause} | {phase}-05 |
628
+
629
+ Plans verified and ready for execution.
630
+
631
+ ───────────────────────────────────────────────────────────────
632
+
633
+ ## Next Up
634
+
635
+ **Execute fixes** — run fix plans
636
+
637
+ `/clear` then `/grd:execute-phase {phase} --gaps-only`
638
+
639
+ ───────────────────────────────────────────────────────────────
640
+
641
+ **For metric gaps, also consider:**
642
+ - `/grd:iterate {phase}` — Full iteration loop (re-survey, re-plan, re-execute)
643
+ - `/grd:eval-report {phase}` — Detailed metric analysis before fixing
644
+ ───────────────────────────────────────────────────────────────
645
+ ```
646
+ </step>
647
+
648
+ </process>
649
+
650
+ <update_rules>
651
+ **Batched writes for efficiency:**
652
+
653
+ Keep results in memory. Write to file only when:
654
+ 1. **Issue found** — Preserve the problem immediately
655
+ 2. **Session complete** — Final write before commit
656
+ 3. **Checkpoint** — Every 5 passed tests (safety net)
657
+
658
+ | Section | Rule | When Written |
659
+ |---------|------|--------------|
660
+ | Frontmatter.status | OVERWRITE | Start, complete |
661
+ | Frontmatter.updated | OVERWRITE | On any file write |
662
+ | Current Test | OVERWRITE | On any file write |
663
+ | Tests.{N}.result | OVERWRITE | On any file write |
664
+ | Summary | OVERWRITE | On any file write |
665
+ | Gaps | APPEND | When issue found |
666
+
667
+ On context reset: File shows last checkpoint. Resume from there.
668
+ </update_rules>
669
+
670
+ <severity_inference>
671
+ **Infer severity from user's natural language:**
672
+
673
+ | User says | Infer |
674
+ |-----------|-------|
675
+ | "crashes", "error", "exception", "fails completely" | blocker |
676
+ | "doesn't work", "nothing happens", "wrong behavior" | major |
677
+ | "works but...", "slow", "weird", "minor issue" | minor |
678
+ | "color", "spacing", "alignment", "looks off" | cosmetic |
679
+ | "below target", "metric worse", "regression", "accuracy dropped" | metric_miss |
680
+
681
+ Default to **major** if unclear. User can correct if needed.
682
+
683
+ **Never ask "how severe is this?"** - just infer and move on.
684
+ </severity_inference>
685
+
686
+ <success_criteria>
687
+ - [ ] UAT file created with all tests from SUMMARY.md
688
+ - [ ] Metric tests extracted from EVAL.md if available
689
+ - [ ] Tests presented one at a time with expected behavior
690
+ - [ ] Metric tests include verify_command and expected range
691
+ - [ ] User responses processed as pass/issue/skip
692
+ - [ ] Metric actual values recorded when provided
693
+ - [ ] Severity inferred from description (never asked)
694
+ - [ ] Batched writes: on issue, every 5 passes, or completion
695
+ - [ ] Committed on completion with metric summary
696
+ - [ ] If issues: parallel grd-debugger agents diagnose root causes
697
+ - [ ] If issues: grd-planner creates fix plans (gap_closure mode)
698
+ - [ ] If issues: grd-plan-checker verifies fix plans
699
+ - [ ] If issues: revision loop until plans pass (max 3 iterations)
700
+ - [ ] Ready for `/grd:execute-phase --gaps-only` when complete
701
+ </success_criteria>