gsd-pi 2.41.0-dev.0acbce9 → 2.41.0-dev.5a170d0

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 (291) hide show
  1. package/README.md +1 -1
  2. package/dist/cli-web-branch.d.ts +6 -0
  3. package/dist/cli-web-branch.js +17 -0
  4. package/dist/onboarding.js +2 -1
  5. package/dist/resources/extensions/gsd/auto/loop.js +89 -1
  6. package/dist/resources/extensions/gsd/auto/phases.js +28 -10
  7. package/dist/resources/extensions/gsd/auto/session.js +6 -0
  8. package/dist/resources/extensions/gsd/auto-dashboard.js +8 -2
  9. package/dist/resources/extensions/gsd/auto-dispatch.js +19 -2
  10. package/dist/resources/extensions/gsd/auto-post-unit.js +7 -0
  11. package/dist/resources/extensions/gsd/auto-recovery.js +12 -4
  12. package/dist/resources/extensions/gsd/auto-start.js +8 -3
  13. package/dist/resources/extensions/gsd/auto-worktree.js +147 -13
  14. package/dist/resources/extensions/gsd/auto.js +64 -2
  15. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +199 -164
  16. package/dist/resources/extensions/gsd/bootstrap/journal-tools.js +62 -0
  17. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +2 -0
  18. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +16 -0
  19. package/dist/resources/extensions/gsd/bootstrap/tool-call-loop-guard.js +7 -2
  20. package/dist/resources/extensions/gsd/commands/catalog.js +40 -1
  21. package/dist/resources/extensions/gsd/commands/handlers/core.js +1 -0
  22. package/dist/resources/extensions/gsd/commands/handlers/ops.js +5 -0
  23. package/dist/resources/extensions/gsd/commands/handlers/workflow.js +146 -0
  24. package/dist/resources/extensions/gsd/context-injector.js +74 -0
  25. package/dist/resources/extensions/gsd/context-store.js +4 -3
  26. package/dist/resources/extensions/gsd/custom-execution-policy.js +47 -0
  27. package/dist/resources/extensions/gsd/custom-verification.js +145 -0
  28. package/dist/resources/extensions/gsd/custom-workflow-engine.js +164 -0
  29. package/dist/resources/extensions/gsd/dashboard-overlay.js +1 -0
  30. package/dist/resources/extensions/gsd/db-writer.js +5 -2
  31. package/dist/resources/extensions/gsd/definition-loader.js +352 -0
  32. package/dist/resources/extensions/gsd/detection.js +1 -1
  33. package/dist/resources/extensions/gsd/dev-execution-policy.js +24 -0
  34. package/dist/resources/extensions/gsd/dev-workflow-engine.js +82 -0
  35. package/dist/resources/extensions/gsd/doctor.js +11 -1
  36. package/dist/resources/extensions/gsd/engine-resolver.js +40 -0
  37. package/dist/resources/extensions/gsd/engine-types.js +8 -0
  38. package/dist/resources/extensions/gsd/execution-policy.js +8 -0
  39. package/dist/resources/extensions/gsd/exit-command.js +12 -2
  40. package/dist/resources/extensions/gsd/export.js +9 -13
  41. package/dist/resources/extensions/gsd/extension-manifest.json +2 -2
  42. package/dist/resources/extensions/gsd/files.js +28 -11
  43. package/dist/resources/extensions/gsd/forensics.js +10 -3
  44. package/dist/resources/extensions/gsd/git-service.js +5 -1
  45. package/dist/resources/extensions/gsd/graph.js +225 -0
  46. package/dist/resources/extensions/gsd/gsd-db.js +25 -8
  47. package/dist/resources/extensions/gsd/guided-flow-queue.js +1 -1
  48. package/dist/resources/extensions/gsd/guided-flow.js +7 -3
  49. package/dist/resources/extensions/gsd/journal.js +85 -0
  50. package/dist/resources/extensions/gsd/md-importer.js +5 -0
  51. package/dist/resources/extensions/gsd/milestone-ids.js +1 -1
  52. package/dist/resources/extensions/gsd/native-git-bridge.js +2 -2
  53. package/dist/resources/extensions/gsd/post-unit-hooks.js +24 -412
  54. package/dist/resources/extensions/gsd/preferences-types.js +1 -0
  55. package/dist/resources/extensions/gsd/preferences.js +1 -0
  56. package/dist/resources/extensions/gsd/prompt-loader.js +34 -4
  57. package/dist/resources/extensions/gsd/prompts/complete-milestone.md +11 -10
  58. package/dist/resources/extensions/gsd/prompts/discuss-headless.md +2 -2
  59. package/dist/resources/extensions/gsd/prompts/discuss.md +1 -1
  60. package/dist/resources/extensions/gsd/prompts/queue.md +1 -1
  61. package/dist/resources/extensions/gsd/repo-identity.js +46 -2
  62. package/dist/resources/extensions/gsd/rule-registry.js +489 -0
  63. package/dist/resources/extensions/gsd/rule-types.js +6 -0
  64. package/dist/resources/extensions/gsd/run-manager.js +134 -0
  65. package/dist/resources/extensions/gsd/service-tier.js +138 -0
  66. package/dist/resources/extensions/gsd/structured-data-formatter.js +2 -1
  67. package/dist/resources/extensions/gsd/templates/decisions.md +2 -2
  68. package/dist/resources/extensions/gsd/workflow-engine.js +7 -0
  69. package/dist/resources/extensions/gsd/workflow-templates.js +13 -1
  70. package/dist/resources/extensions/gsd/worktree-manager.js +20 -6
  71. package/dist/resources/extensions/gsd/worktree-resolver.js +19 -2
  72. package/dist/resources/extensions/subagent/index.js +7 -3
  73. package/dist/resources/extensions/voice/index.js +4 -4
  74. package/dist/resources/skills/create-workflow/SKILL.md +103 -0
  75. package/dist/resources/skills/create-workflow/references/feature-patterns.md +128 -0
  76. package/dist/resources/skills/create-workflow/references/verification-policies.md +76 -0
  77. package/dist/resources/skills/create-workflow/references/yaml-schema-v1.md +46 -0
  78. package/dist/resources/skills/create-workflow/templates/blog-post-pipeline.yaml +60 -0
  79. package/dist/resources/skills/create-workflow/templates/code-audit.yaml +60 -0
  80. package/dist/resources/skills/create-workflow/templates/release-checklist.yaml +66 -0
  81. package/dist/resources/skills/create-workflow/templates/workflow-definition.yaml +32 -0
  82. package/dist/resources/skills/create-workflow/workflows/create-from-scratch.md +104 -0
  83. package/dist/resources/skills/create-workflow/workflows/create-from-template.md +72 -0
  84. package/dist/web/standalone/.next/BUILD_ID +1 -1
  85. package/dist/web/standalone/.next/app-path-routes-manifest.json +16 -16
  86. package/dist/web/standalone/.next/build-manifest.json +3 -3
  87. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  88. package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
  89. package/dist/web/standalone/.next/server/app/_global-error.html +2 -2
  90. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  91. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  92. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  93. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  94. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  95. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  96. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  97. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  98. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  99. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  100. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  101. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  102. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  103. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  104. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  105. package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
  106. package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
  107. package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
  108. package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
  109. package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
  110. package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
  111. package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
  112. package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
  113. package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
  114. package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
  115. package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
  116. package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +1 -1
  117. package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +1 -1
  118. package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
  119. package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
  120. package/dist/web/standalone/.next/server/app/index.html +1 -1
  121. package/dist/web/standalone/.next/server/app/index.rsc +1 -1
  122. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  123. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
  124. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  125. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  126. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  127. package/dist/web/standalone/.next/server/app-paths-manifest.json +16 -16
  128. package/dist/web/standalone/.next/server/chunks/229.js +3 -3
  129. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  130. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  131. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  132. package/dist/web/standalone/.next/server/pages/500.html +2 -2
  133. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  134. package/dist/web/standalone/.next/static/chunks/4024.c195dc1fdd2adbea.js +9 -0
  135. package/dist/web/standalone/.next/static/chunks/{webpack-9afaaebf6042a1d7.js → webpack-fa307370fcf9fb2c.js} +1 -1
  136. package/dist/web-mode.d.ts +2 -0
  137. package/dist/web-mode.js +29 -7
  138. package/package.json +1 -1
  139. package/packages/native/src/__tests__/text.test.mjs +33 -0
  140. package/packages/pi-coding-agent/dist/core/discovery-cache.test.js +3 -1
  141. package/packages/pi-coding-agent/dist/core/discovery-cache.test.js.map +1 -1
  142. package/packages/pi-coding-agent/dist/modes/interactive/components/login-dialog.d.ts.map +1 -1
  143. package/packages/pi-coding-agent/dist/modes/interactive/components/login-dialog.js +10 -7
  144. package/packages/pi-coding-agent/dist/modes/interactive/components/login-dialog.js.map +1 -1
  145. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  146. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +4 -0
  147. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  148. package/packages/pi-coding-agent/src/core/discovery-cache.test.ts +4 -2
  149. package/packages/pi-coding-agent/src/modes/interactive/components/login-dialog.ts +11 -7
  150. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +5 -0
  151. package/src/resources/extensions/gsd/auto/loop-deps.ts +5 -1
  152. package/src/resources/extensions/gsd/auto/loop.ts +101 -1
  153. package/src/resources/extensions/gsd/auto/phases.ts +30 -10
  154. package/src/resources/extensions/gsd/auto/session.ts +6 -0
  155. package/src/resources/extensions/gsd/auto/types.ts +4 -0
  156. package/src/resources/extensions/gsd/auto-dashboard.ts +9 -2
  157. package/src/resources/extensions/gsd/auto-dispatch.ts +25 -5
  158. package/src/resources/extensions/gsd/auto-post-unit.ts +8 -0
  159. package/src/resources/extensions/gsd/auto-recovery.ts +12 -4
  160. package/src/resources/extensions/gsd/auto-start.ts +8 -3
  161. package/src/resources/extensions/gsd/auto-worktree.ts +162 -18
  162. package/src/resources/extensions/gsd/auto.ts +71 -2
  163. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +209 -162
  164. package/src/resources/extensions/gsd/bootstrap/journal-tools.ts +62 -0
  165. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +2 -0
  166. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +13 -0
  167. package/src/resources/extensions/gsd/bootstrap/tool-call-loop-guard.ts +9 -2
  168. package/src/resources/extensions/gsd/commands/catalog.ts +40 -1
  169. package/src/resources/extensions/gsd/commands/handlers/core.ts +1 -0
  170. package/src/resources/extensions/gsd/commands/handlers/ops.ts +5 -0
  171. package/src/resources/extensions/gsd/commands/handlers/workflow.ts +164 -0
  172. package/src/resources/extensions/gsd/context-injector.ts +100 -0
  173. package/src/resources/extensions/gsd/context-store.ts +4 -3
  174. package/src/resources/extensions/gsd/custom-execution-policy.ts +73 -0
  175. package/src/resources/extensions/gsd/custom-verification.ts +180 -0
  176. package/src/resources/extensions/gsd/custom-workflow-engine.ts +216 -0
  177. package/src/resources/extensions/gsd/dashboard-overlay.ts +1 -0
  178. package/src/resources/extensions/gsd/db-writer.ts +6 -2
  179. package/src/resources/extensions/gsd/definition-loader.ts +462 -0
  180. package/src/resources/extensions/gsd/detection.ts +1 -1
  181. package/src/resources/extensions/gsd/dev-execution-policy.ts +51 -0
  182. package/src/resources/extensions/gsd/dev-workflow-engine.ts +110 -0
  183. package/src/resources/extensions/gsd/doctor.ts +12 -1
  184. package/src/resources/extensions/gsd/engine-resolver.ts +57 -0
  185. package/src/resources/extensions/gsd/engine-types.ts +71 -0
  186. package/src/resources/extensions/gsd/execution-policy.ts +43 -0
  187. package/src/resources/extensions/gsd/exit-command.ts +14 -2
  188. package/src/resources/extensions/gsd/export.ts +8 -15
  189. package/src/resources/extensions/gsd/extension-manifest.json +2 -2
  190. package/src/resources/extensions/gsd/files.ts +29 -12
  191. package/src/resources/extensions/gsd/forensics.ts +9 -3
  192. package/src/resources/extensions/gsd/git-service.ts +5 -4
  193. package/src/resources/extensions/gsd/graph.ts +312 -0
  194. package/src/resources/extensions/gsd/gsd-db.ts +37 -8
  195. package/src/resources/extensions/gsd/guided-flow-queue.ts +1 -1
  196. package/src/resources/extensions/gsd/guided-flow.ts +7 -3
  197. package/src/resources/extensions/gsd/journal.ts +134 -0
  198. package/src/resources/extensions/gsd/md-importer.ts +6 -0
  199. package/src/resources/extensions/gsd/milestone-ids.ts +1 -1
  200. package/src/resources/extensions/gsd/native-git-bridge.ts +2 -2
  201. package/src/resources/extensions/gsd/post-unit-hooks.ts +24 -462
  202. package/src/resources/extensions/gsd/preferences-types.ts +3 -0
  203. package/src/resources/extensions/gsd/preferences.ts +1 -0
  204. package/src/resources/extensions/gsd/prompt-loader.ts +35 -4
  205. package/src/resources/extensions/gsd/prompts/complete-milestone.md +11 -10
  206. package/src/resources/extensions/gsd/prompts/discuss-headless.md +2 -2
  207. package/src/resources/extensions/gsd/prompts/discuss.md +1 -1
  208. package/src/resources/extensions/gsd/prompts/queue.md +1 -1
  209. package/src/resources/extensions/gsd/repo-identity.ts +47 -2
  210. package/src/resources/extensions/gsd/rule-registry.ts +599 -0
  211. package/src/resources/extensions/gsd/rule-types.ts +68 -0
  212. package/src/resources/extensions/gsd/run-manager.ts +180 -0
  213. package/src/resources/extensions/gsd/service-tier.ts +171 -0
  214. package/src/resources/extensions/gsd/structured-data-formatter.ts +3 -1
  215. package/src/resources/extensions/gsd/templates/decisions.md +2 -2
  216. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +103 -120
  217. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +85 -0
  218. package/src/resources/extensions/gsd/tests/auto-secrets-gate.test.ts +2 -2
  219. package/src/resources/extensions/gsd/tests/auto-worktree-milestone-merge.test.ts +202 -0
  220. package/src/resources/extensions/gsd/tests/bundled-workflow-defs.test.ts +180 -0
  221. package/src/resources/extensions/gsd/tests/captures.test.ts +12 -1
  222. package/src/resources/extensions/gsd/tests/commands-workflow-custom.test.ts +283 -0
  223. package/src/resources/extensions/gsd/tests/context-injector.test.ts +313 -0
  224. package/src/resources/extensions/gsd/tests/context-store.test.ts +10 -5
  225. package/src/resources/extensions/gsd/tests/continue-here.test.ts +20 -20
  226. package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +540 -0
  227. package/src/resources/extensions/gsd/tests/custom-verification.test.ts +382 -0
  228. package/src/resources/extensions/gsd/tests/custom-workflow-engine.test.ts +339 -0
  229. package/src/resources/extensions/gsd/tests/dashboard-custom-engine.test.ts +87 -0
  230. package/src/resources/extensions/gsd/tests/db-writer.test.ts +10 -0
  231. package/src/resources/extensions/gsd/tests/definition-loader.test.ts +778 -0
  232. package/src/resources/extensions/gsd/tests/dev-engine-wrapper.test.ts +318 -0
  233. package/src/resources/extensions/gsd/tests/doctor-completion-deferral.test.ts +15 -10
  234. package/src/resources/extensions/gsd/tests/doctor-fixlevel.test.ts +5 -4
  235. package/src/resources/extensions/gsd/tests/doctor-roadmap-summary-atomicity.test.ts +167 -0
  236. package/src/resources/extensions/gsd/tests/doctor-task-done-missing-summary-slice-loop.test.ts +174 -0
  237. package/src/resources/extensions/gsd/tests/e2e-workflow-pipeline-integration.test.ts +476 -0
  238. package/src/resources/extensions/gsd/tests/engine-interfaces-contract.test.ts +271 -0
  239. package/src/resources/extensions/gsd/tests/exit-command.test.ts +55 -0
  240. package/src/resources/extensions/gsd/tests/graph-operations.test.ts +599 -0
  241. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +8 -1
  242. package/src/resources/extensions/gsd/tests/gsd-tools.test.ts +7 -7
  243. package/src/resources/extensions/gsd/tests/iterate-engine-integration.test.ts +429 -0
  244. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +513 -0
  245. package/src/resources/extensions/gsd/tests/journal-query-tool.test.ts +147 -0
  246. package/src/resources/extensions/gsd/tests/journal.test.ts +386 -0
  247. package/src/resources/extensions/gsd/tests/md-importer.test.ts +31 -1
  248. package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -2
  249. package/src/resources/extensions/gsd/tests/milestone-id-reservation.test.ts +1 -1
  250. package/src/resources/extensions/gsd/tests/parsers.test.ts +110 -0
  251. package/src/resources/extensions/gsd/tests/preferences.test.ts +47 -25
  252. package/src/resources/extensions/gsd/tests/prompt-db.test.ts +3 -1
  253. package/src/resources/extensions/gsd/tests/repo-identity-worktree.test.ts +61 -1
  254. package/src/resources/extensions/gsd/tests/routing-history.test.ts +11 -22
  255. package/src/resources/extensions/gsd/tests/rule-registry.test.ts +413 -0
  256. package/src/resources/extensions/gsd/tests/run-manager.test.ts +229 -0
  257. package/src/resources/extensions/gsd/tests/service-tier.test.ts +98 -0
  258. package/src/resources/extensions/gsd/tests/skill-lifecycle.test.ts +2 -2
  259. package/src/resources/extensions/gsd/tests/stalled-tool-recovery.test.ts +102 -0
  260. package/src/resources/extensions/gsd/tests/structured-data-formatter.test.ts +4 -3
  261. package/src/resources/extensions/gsd/tests/tool-call-loop-guard.test.ts +45 -0
  262. package/src/resources/extensions/gsd/tests/tool-naming.test.ts +117 -0
  263. package/src/resources/extensions/gsd/tests/triage-dispatch.test.ts +6 -1
  264. package/src/resources/extensions/gsd/tests/windows-path-normalization.test.ts +99 -0
  265. package/src/resources/extensions/gsd/tests/worktree-db-integration.test.ts +1 -0
  266. package/src/resources/extensions/gsd/tests/worktree-db.test.ts +4 -0
  267. package/src/resources/extensions/gsd/tests/worktree-health-dispatch.test.ts +178 -0
  268. package/src/resources/extensions/gsd/tests/worktree-manager.test.ts +195 -105
  269. package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +78 -3
  270. package/src/resources/extensions/gsd/tests/worktree-symlink-removal.test.ts +140 -0
  271. package/src/resources/extensions/gsd/tests/worktree-sync-milestones.test.ts +74 -0
  272. package/src/resources/extensions/gsd/types.ts +3 -0
  273. package/src/resources/extensions/gsd/workflow-engine.ts +38 -0
  274. package/src/resources/extensions/gsd/workflow-templates.ts +12 -1
  275. package/src/resources/extensions/gsd/worktree-manager.ts +21 -6
  276. package/src/resources/extensions/gsd/worktree-resolver.ts +30 -9
  277. package/src/resources/extensions/subagent/index.ts +7 -3
  278. package/src/resources/extensions/voice/index.ts +4 -4
  279. package/src/resources/skills/create-workflow/SKILL.md +103 -0
  280. package/src/resources/skills/create-workflow/references/feature-patterns.md +128 -0
  281. package/src/resources/skills/create-workflow/references/verification-policies.md +76 -0
  282. package/src/resources/skills/create-workflow/references/yaml-schema-v1.md +46 -0
  283. package/src/resources/skills/create-workflow/templates/blog-post-pipeline.yaml +60 -0
  284. package/src/resources/skills/create-workflow/templates/code-audit.yaml +60 -0
  285. package/src/resources/skills/create-workflow/templates/release-checklist.yaml +66 -0
  286. package/src/resources/skills/create-workflow/templates/workflow-definition.yaml +32 -0
  287. package/src/resources/skills/create-workflow/workflows/create-from-scratch.md +104 -0
  288. package/src/resources/skills/create-workflow/workflows/create-from-template.md +72 -0
  289. package/dist/web/standalone/.next/static/chunks/4024.279c423e4661ece1.js +0 -9
  290. /package/dist/web/standalone/.next/static/{SwbKZ7JPNFlEmU4f8pKEv → K7GYOOPvQWX6TKYEKhODM}/_buildManifest.js +0 -0
  291. /package/dist/web/standalone/.next/static/{SwbKZ7JPNFlEmU4f8pKEv → K7GYOOPvQWX6TKYEKhODM}/_ssgManifest.js +0 -0
@@ -0,0 +1,382 @@
1
+ /**
2
+ * custom-verification.test.ts — Tests for runCustomVerification().
3
+ *
4
+ * Tests all four verification policies (content-heuristic, shell-command,
5
+ * prompt-verify, human-review) plus edge cases (no policy, missing file).
6
+ * Each test creates a temp run directory with a DEFINITION.yaml and
7
+ * optional test artifacts.
8
+ */
9
+
10
+ import { describe, it } from "node:test";
11
+ import assert from "node:assert/strict";
12
+ import { mkdtempSync, writeFileSync, mkdirSync } from "node:fs";
13
+ import { join } from "node:path";
14
+ import { tmpdir } from "node:os";
15
+ import { stringify } from "yaml";
16
+ import { runCustomVerification } from "../custom-verification.ts";
17
+ import type { WorkflowDefinition } from "../definition-loader.ts";
18
+
19
+ /** Create a temp run directory with the given definition and optional files. */
20
+ function makeTempRun(
21
+ def: WorkflowDefinition,
22
+ files?: Record<string, string>,
23
+ ): string {
24
+ const runDir = mkdtempSync(join(tmpdir(), "cv-test-"));
25
+ writeFileSync(join(runDir, "DEFINITION.yaml"), stringify(def), "utf-8");
26
+
27
+ if (files) {
28
+ for (const [relPath, content] of Object.entries(files)) {
29
+ const absPath = join(runDir, relPath);
30
+ // Ensure parent directories exist
31
+ const parentDir = join(absPath, "..");
32
+ mkdirSync(parentDir, { recursive: true });
33
+ writeFileSync(absPath, content, "utf-8");
34
+ }
35
+ }
36
+
37
+ return runDir;
38
+ }
39
+
40
+ /** Minimal valid workflow definition factory. */
41
+ function makeDef(
42
+ steps: WorkflowDefinition["steps"],
43
+ ): WorkflowDefinition {
44
+ return {
45
+ version: 1,
46
+ name: "test-workflow",
47
+ steps,
48
+ };
49
+ }
50
+
51
+ // ─── content-heuristic tests ────────────────────────────────────────────
52
+
53
+ describe("content-heuristic policy", () => {
54
+ it("returns 'continue' when file exists and meets size/pattern", () => {
55
+ const def = makeDef([
56
+ {
57
+ id: "step-1",
58
+ name: "Generate report",
59
+ prompt: "Generate a report",
60
+ requires: [],
61
+ produces: ["report.md"],
62
+ verify: {
63
+ policy: "content-heuristic",
64
+ minSize: 10,
65
+ pattern: "# Report",
66
+ },
67
+ },
68
+ ]);
69
+
70
+ const runDir = makeTempRun(def, {
71
+ "report.md": "# Report\n\nThis is a valid report with sufficient content.",
72
+ });
73
+
74
+ const result = runCustomVerification(runDir, "step-1");
75
+ assert.equal(result, "continue");
76
+ });
77
+
78
+ it("returns 'pause' when produces file is missing", () => {
79
+ const def = makeDef([
80
+ {
81
+ id: "step-1",
82
+ name: "Generate report",
83
+ prompt: "Generate a report",
84
+ requires: [],
85
+ produces: ["report.md"],
86
+ verify: { policy: "content-heuristic" },
87
+ },
88
+ ]);
89
+
90
+ // No files created — report.md doesn't exist
91
+ const runDir = makeTempRun(def);
92
+
93
+ const result = runCustomVerification(runDir, "step-1");
94
+ assert.equal(result, "pause");
95
+ });
96
+
97
+ it("returns 'pause' when file exists but below minSize", () => {
98
+ const def = makeDef([
99
+ {
100
+ id: "step-1",
101
+ name: "Generate report",
102
+ prompt: "Generate a report",
103
+ requires: [],
104
+ produces: ["report.md"],
105
+ verify: {
106
+ policy: "content-heuristic",
107
+ minSize: 1000,
108
+ },
109
+ },
110
+ ]);
111
+
112
+ const runDir = makeTempRun(def, {
113
+ "report.md": "tiny",
114
+ });
115
+
116
+ const result = runCustomVerification(runDir, "step-1");
117
+ assert.equal(result, "pause");
118
+ });
119
+
120
+ it("returns 'pause' when file exists but pattern does not match", () => {
121
+ const def = makeDef([
122
+ {
123
+ id: "step-1",
124
+ name: "Generate report",
125
+ prompt: "Generate a report",
126
+ requires: [],
127
+ produces: ["report.md"],
128
+ verify: {
129
+ policy: "content-heuristic",
130
+ pattern: "^# Summary",
131
+ },
132
+ },
133
+ ]);
134
+
135
+ const runDir = makeTempRun(def, {
136
+ "report.md": "This has no heading at all.",
137
+ });
138
+
139
+ const result = runCustomVerification(runDir, "step-1");
140
+ assert.equal(result, "pause");
141
+ });
142
+
143
+ it("returns 'continue' when produces is empty", () => {
144
+ const def = makeDef([
145
+ {
146
+ id: "step-1",
147
+ name: "Think step",
148
+ prompt: "Think about the problem",
149
+ requires: [],
150
+ produces: [],
151
+ verify: { policy: "content-heuristic" },
152
+ },
153
+ ]);
154
+
155
+ const runDir = makeTempRun(def);
156
+
157
+ const result = runCustomVerification(runDir, "step-1");
158
+ assert.equal(result, "continue");
159
+ });
160
+
161
+ it("returns 'continue' when file exists with no minSize or pattern checks", () => {
162
+ const def = makeDef([
163
+ {
164
+ id: "step-1",
165
+ name: "Generate output",
166
+ prompt: "Generate output",
167
+ requires: [],
168
+ produces: ["output.txt"],
169
+ verify: { policy: "content-heuristic" },
170
+ },
171
+ ]);
172
+
173
+ const runDir = makeTempRun(def, {
174
+ "output.txt": "",
175
+ });
176
+
177
+ const result = runCustomVerification(runDir, "step-1");
178
+ assert.equal(result, "continue");
179
+ });
180
+ });
181
+
182
+ // ─── shell-command tests ────────────────────────────────────────────────
183
+
184
+ describe("shell-command policy", () => {
185
+ it("returns 'continue' when command exits 0", () => {
186
+ const def = makeDef([
187
+ {
188
+ id: "step-1",
189
+ name: "Build artifact",
190
+ prompt: "Build the artifact",
191
+ requires: [],
192
+ produces: ["artifact.txt"],
193
+ verify: {
194
+ policy: "shell-command",
195
+ command: "test -f artifact.txt",
196
+ },
197
+ },
198
+ ]);
199
+
200
+ const runDir = makeTempRun(def, {
201
+ "artifact.txt": "content",
202
+ });
203
+
204
+ const result = runCustomVerification(runDir, "step-1");
205
+ assert.equal(result, "continue");
206
+ });
207
+
208
+ it("returns 'retry' when command exits non-zero", () => {
209
+ const def = makeDef([
210
+ {
211
+ id: "step-1",
212
+ name: "Build artifact",
213
+ prompt: "Build the artifact",
214
+ requires: [],
215
+ produces: ["artifact.txt"],
216
+ verify: {
217
+ policy: "shell-command",
218
+ command: "test -f nonexistent-file.txt",
219
+ },
220
+ },
221
+ ]);
222
+
223
+ const runDir = makeTempRun(def);
224
+
225
+ const result = runCustomVerification(runDir, "step-1");
226
+ assert.equal(result, "retry");
227
+ });
228
+ });
229
+
230
+ // ─── prompt-verify tests ────────────────────────────────────────────────
231
+
232
+ describe("prompt-verify policy", () => {
233
+ it("returns 'pause'", () => {
234
+ const def = makeDef([
235
+ {
236
+ id: "step-1",
237
+ name: "Creative step",
238
+ prompt: "Write something creative",
239
+ requires: [],
240
+ produces: ["creative.md"],
241
+ verify: {
242
+ policy: "prompt-verify",
243
+ prompt: "Does the creative output meet the brief?",
244
+ },
245
+ },
246
+ ]);
247
+
248
+ const runDir = makeTempRun(def);
249
+
250
+ const result = runCustomVerification(runDir, "step-1");
251
+ assert.equal(result, "pause");
252
+ });
253
+ });
254
+
255
+ // ─── human-review tests ─────────────────────────────────────────────────
256
+
257
+ describe("human-review policy", () => {
258
+ it("returns 'pause'", () => {
259
+ const def = makeDef([
260
+ {
261
+ id: "step-1",
262
+ name: "Review step",
263
+ prompt: "Prepare for review",
264
+ requires: [],
265
+ produces: ["review-doc.md"],
266
+ verify: { policy: "human-review" },
267
+ },
268
+ ]);
269
+
270
+ const runDir = makeTempRun(def);
271
+
272
+ const result = runCustomVerification(runDir, "step-1");
273
+ assert.equal(result, "pause");
274
+ });
275
+ });
276
+
277
+ // ─── no verify policy tests ─────────────────────────────────────────────
278
+
279
+ describe("no verify policy", () => {
280
+ it("returns 'continue' when step has no verify field", () => {
281
+ const def = makeDef([
282
+ {
283
+ id: "step-1",
284
+ name: "Simple step",
285
+ prompt: "Do something simple",
286
+ requires: [],
287
+ produces: [],
288
+ // No verify field
289
+ },
290
+ ]);
291
+
292
+ const runDir = makeTempRun(def);
293
+
294
+ const result = runCustomVerification(runDir, "step-1");
295
+ assert.equal(result, "continue");
296
+ });
297
+
298
+ it("returns 'continue' when step ID is not found in definition", () => {
299
+ const def = makeDef([
300
+ {
301
+ id: "step-1",
302
+ name: "Only step",
303
+ prompt: "Only step",
304
+ requires: [],
305
+ produces: [],
306
+ },
307
+ ]);
308
+
309
+ const runDir = makeTempRun(def);
310
+
311
+ const result = runCustomVerification(runDir, "nonexistent-step");
312
+ assert.equal(result, "continue");
313
+ });
314
+ });
315
+
316
+ // ─── missing DEFINITION.yaml ────────────────────────────────────────────
317
+
318
+ describe("error handling", () => {
319
+ it("throws when DEFINITION.yaml is missing", () => {
320
+ const runDir = mkdtempSync(join(tmpdir(), "cv-test-nodef-"));
321
+ // No DEFINITION.yaml written
322
+
323
+ assert.throws(
324
+ () => runCustomVerification(runDir, "step-1"),
325
+ /ENOENT/,
326
+ );
327
+ });
328
+ });
329
+
330
+ // ─── CustomExecutionPolicy integration ──────────────────────────────────
331
+
332
+ describe("CustomExecutionPolicy.verify() integration", () => {
333
+ it("extracts stepId from unitId and calls runCustomVerification", async () => {
334
+ // Import the policy class
335
+ const { CustomExecutionPolicy } = await import("../custom-execution-policy.ts");
336
+
337
+ const def = makeDef([
338
+ {
339
+ id: "analyze",
340
+ name: "Analyze",
341
+ prompt: "Analyze the data",
342
+ requires: [],
343
+ produces: ["analysis.md"],
344
+ verify: { policy: "content-heuristic" },
345
+ },
346
+ ]);
347
+
348
+ const runDir = makeTempRun(def, {
349
+ "analysis.md": "Analysis complete.",
350
+ });
351
+
352
+ const policy = new CustomExecutionPolicy(runDir);
353
+ const result = await policy.verify("custom-step", "my-workflow/analyze", {
354
+ basePath: "/tmp",
355
+ });
356
+ assert.equal(result, "continue");
357
+ });
358
+
359
+ it("returns 'pause' when content-heuristic fails via policy", async () => {
360
+ const { CustomExecutionPolicy } = await import("../custom-execution-policy.ts");
361
+
362
+ const def = makeDef([
363
+ {
364
+ id: "generate",
365
+ name: "Generate",
366
+ prompt: "Generate output",
367
+ requires: [],
368
+ produces: ["output.md"],
369
+ verify: { policy: "content-heuristic" },
370
+ },
371
+ ]);
372
+
373
+ // No output.md created
374
+ const runDir = makeTempRun(def);
375
+
376
+ const policy = new CustomExecutionPolicy(runDir);
377
+ const result = await policy.verify("custom-step", "my-workflow/generate", {
378
+ basePath: "/tmp",
379
+ });
380
+ assert.equal(result, "pause");
381
+ });
382
+ });