agentic-orchestrator 0.1.6 → 0.1.8

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 (438) hide show
  1. package/.prettierignore +10 -0
  2. package/.prettierrc.json +24 -0
  3. package/CLAUDE.md +3 -2
  4. package/README.md +71 -48
  5. package/agentic/orchestrator/defaults/policy.defaults.yaml +1 -1
  6. package/agentic/orchestrator/prompts/planner.system.md +1 -0
  7. package/agentic/orchestrator/schemas/agents.schema.json +5 -22
  8. package/agentic/orchestrator/schemas/gates.schema.json +4 -19
  9. package/agentic/orchestrator/schemas/index.schema.json +3 -14
  10. package/agentic/orchestrator/schemas/multi-project.schema.json +2 -8
  11. package/agentic/orchestrator/schemas/plan.schema.json +6 -26
  12. package/agentic/orchestrator/schemas/policy.schema.json +19 -81
  13. package/agentic/orchestrator/schemas/policy.user.schema.json +1 -5
  14. package/agentic/orchestrator/schemas/qa_test_index.schema.json +5 -29
  15. package/agentic/orchestrator/schemas/state.schema.json +11 -61
  16. package/agentic/orchestrator/tools/catalog.json +33 -164
  17. package/agentic/orchestrator/tools/schemas/input/evidence.latest.input.schema.json +1 -3
  18. package/agentic/orchestrator/tools/schemas/input/feature.delete.input.schema.json +1 -5
  19. package/agentic/orchestrator/tools/schemas/input/feature.get_context.input.schema.json +1 -3
  20. package/agentic/orchestrator/tools/schemas/input/feature.init.input.schema.json +1 -4
  21. package/agentic/orchestrator/tools/schemas/input/feature.log_append.input.schema.json +1 -5
  22. package/agentic/orchestrator/tools/schemas/input/feature.ready_to_merge.input.schema.json +1 -6
  23. package/agentic/orchestrator/tools/schemas/input/feature.state_get.input.schema.json +1 -3
  24. package/agentic/orchestrator/tools/schemas/input/feature.state_patch.input.schema.json +1 -5
  25. package/agentic/orchestrator/tools/schemas/input/gates.run.input.schema.json +1 -5
  26. package/agentic/orchestrator/tools/schemas/input/locks.acquire.input.schema.json +1 -5
  27. package/agentic/orchestrator/tools/schemas/input/locks.release.input.schema.json +1 -5
  28. package/agentic/orchestrator/tools/schemas/input/performance.record_outcome.input.schema.json +10 -1
  29. package/agentic/orchestrator/tools/schemas/input/plan.get.input.schema.json +1 -3
  30. package/agentic/orchestrator/tools/schemas/input/plan.submit.input.schema.json +1 -5
  31. package/agentic/orchestrator/tools/schemas/input/plan.update.input.schema.json +1 -6
  32. package/agentic/orchestrator/tools/schemas/input/qa.test_index_get.input.schema.json +1 -3
  33. package/agentic/orchestrator/tools/schemas/input/qa.test_index_update.input.schema.json +1 -6
  34. package/agentic/orchestrator/tools/schemas/input/repo.apply_patch.input.schema.json +1 -5
  35. package/agentic/orchestrator/tools/schemas/input/repo.diff.input.schema.json +1 -3
  36. package/agentic/orchestrator/tools/schemas/input/repo.diff_bundle.input.schema.json +1 -3
  37. package/agentic/orchestrator/tools/schemas/input/repo.ensure_worktree.input.schema.json +1 -4
  38. package/agentic/orchestrator/tools/schemas/input/repo.read_file.input.schema.json +1 -4
  39. package/agentic/orchestrator/tools/schemas/input/repo.search.input.schema.json +1 -4
  40. package/agentic/orchestrator/tools/schemas/input/repo.status.input.schema.json +1 -3
  41. package/agentic/orchestrator/tools/schemas/input/report.feature_summary.input.schema.json +1 -3
  42. package/agentic/orchestrator/tools/schemas/output/collisions.scan.output.schema.json +1 -3
  43. package/agentic/orchestrator/tools/schemas/output/evidence.latest.output.schema.json +1 -4
  44. package/agentic/orchestrator/tools/schemas/output/feature.delete.output.schema.json +4 -20
  45. package/agentic/orchestrator/tools/schemas/output/feature.discover_specs.output.schema.json +2 -7
  46. package/agentic/orchestrator/tools/schemas/output/feature.get_context.output.schema.json +1 -8
  47. package/agentic/orchestrator/tools/schemas/output/feature.init.output.schema.json +1 -5
  48. package/agentic/orchestrator/tools/schemas/output/feature.log_append.output.schema.json +1 -5
  49. package/agentic/orchestrator/tools/schemas/output/feature.ready_to_merge.output.schema.json +1 -6
  50. package/agentic/orchestrator/tools/schemas/output/feature.state_get.output.schema.json +1 -4
  51. package/agentic/orchestrator/tools/schemas/output/feature.state_patch.output.schema.json +1 -5
  52. package/agentic/orchestrator/tools/schemas/output/gates.list.output.schema.json +2 -7
  53. package/agentic/orchestrator/tools/schemas/output/gates.run.output.schema.json +1 -8
  54. package/agentic/orchestrator/tools/schemas/output/locks.acquire.output.schema.json +1 -7
  55. package/agentic/orchestrator/tools/schemas/output/locks.release.output.schema.json +1 -5
  56. package/agentic/orchestrator/tools/schemas/output/performance.get_analytics.output.schema.json +22 -2
  57. package/agentic/orchestrator/tools/schemas/output/plan.get.output.schema.json +1 -4
  58. package/agentic/orchestrator/tools/schemas/output/plan.submit.output.schema.json +1 -5
  59. package/agentic/orchestrator/tools/schemas/output/plan.update.output.schema.json +1 -5
  60. package/agentic/orchestrator/tools/schemas/output/qa.test_index_get.output.schema.json +1 -5
  61. package/agentic/orchestrator/tools/schemas/output/qa.test_index_update.output.schema.json +1 -4
  62. package/agentic/orchestrator/tools/schemas/output/repo.apply_patch.output.schema.json +1 -6
  63. package/agentic/orchestrator/tools/schemas/output/repo.diff.output.schema.json +1 -4
  64. package/agentic/orchestrator/tools/schemas/output/repo.diff_bundle.output.schema.json +1 -7
  65. package/agentic/orchestrator/tools/schemas/output/repo.ensure_worktree.output.schema.json +1 -6
  66. package/agentic/orchestrator/tools/schemas/output/repo.read_file.output.schema.json +1 -5
  67. package/agentic/orchestrator/tools/schemas/output/repo.search.output.schema.json +1 -5
  68. package/agentic/orchestrator/tools/schemas/output/repo.status.output.schema.json +1 -5
  69. package/agentic/orchestrator/tools/schemas/output/report.dashboard.output.schema.json +1 -4
  70. package/apps/control-plane/scripts/validate-architecture-rules.mjs +16 -5
  71. package/apps/control-plane/scripts/validate-docker-mcp-contract.mjs +30 -8
  72. package/apps/control-plane/scripts/validate-mcp-contracts.ts +13 -7
  73. package/apps/control-plane/src/application/adapters/adapter-registry.ts +35 -15
  74. package/apps/control-plane/src/application/multi-project-loader.ts +27 -10
  75. package/apps/control-plane/src/application/services/activity-monitor-service.ts +26 -14
  76. package/apps/control-plane/src/application/services/collision-queue-service.ts +31 -17
  77. package/apps/control-plane/src/application/services/cost-tracking-service.ts +23 -16
  78. package/apps/control-plane/src/application/services/dependency-scheduler-service.ts +12 -4
  79. package/apps/control-plane/src/application/services/feature-deletion-service.ts +94 -58
  80. package/apps/control-plane/src/application/services/feature-lifecycle-service.ts +19 -13
  81. package/apps/control-plane/src/application/services/feature-state-service.ts +29 -19
  82. package/apps/control-plane/src/application/services/gate-interpolation-service.ts +7 -2
  83. package/apps/control-plane/src/application/services/gate-service.ts +64 -41
  84. package/apps/control-plane/src/application/services/instance-isolation-service.ts +1 -1
  85. package/apps/control-plane/src/application/services/issue-tracker-service.ts +49 -38
  86. package/apps/control-plane/src/application/services/lock-service.ts +75 -49
  87. package/apps/control-plane/src/application/services/merge-service.ts +91 -50
  88. package/apps/control-plane/src/application/services/notifier-service.ts +42 -20
  89. package/apps/control-plane/src/application/services/patch-service.ts +73 -44
  90. package/apps/control-plane/src/application/services/performance-analytics-service.ts +8 -6
  91. package/apps/control-plane/src/application/services/plan-service.ts +148 -89
  92. package/apps/control-plane/src/application/services/policy-loader-service.ts +10 -4
  93. package/apps/control-plane/src/application/services/pr-monitor-service.ts +33 -14
  94. package/apps/control-plane/src/application/services/qa-index-service.ts +20 -16
  95. package/apps/control-plane/src/application/services/reactions-service.ts +30 -15
  96. package/apps/control-plane/src/application/services/reporting-service.ts +16 -12
  97. package/apps/control-plane/src/application/services/run-lease-service.ts +138 -81
  98. package/apps/control-plane/src/application/tools/tool-metadata.ts +5 -5
  99. package/apps/control-plane/src/application/tools/tool-router.ts +6 -3
  100. package/apps/control-plane/src/cli/aop.ts +2 -2
  101. package/apps/control-plane/src/cli/attach-command-handler.ts +9 -9
  102. package/apps/control-plane/src/cli/cleanup-command-handler.ts +16 -11
  103. package/apps/control-plane/src/cli/cli-argument-parser.ts +6 -3
  104. package/apps/control-plane/src/cli/dashboard-command-handler.ts +28 -8
  105. package/apps/control-plane/src/cli/delete-command-handler.ts +7 -7
  106. package/apps/control-plane/src/cli/env-file.ts +115 -0
  107. package/apps/control-plane/src/cli/help-command-handler.ts +61 -32
  108. package/apps/control-plane/src/cli/init-command-handler.ts +182 -56
  109. package/apps/control-plane/src/cli/io.ts +7 -3
  110. package/apps/control-plane/src/cli/resume-command-handler.ts +21 -13
  111. package/apps/control-plane/src/cli/retry-command-handler.ts +12 -11
  112. package/apps/control-plane/src/cli/run-command-handler.ts +12 -8
  113. package/apps/control-plane/src/cli/send-command-handler.ts +6 -6
  114. package/apps/control-plane/src/cli/spec-ingestion-service.ts +14 -8
  115. package/apps/control-plane/src/cli/spec-input-resolver.ts +6 -1
  116. package/apps/control-plane/src/cli/spec-utils.ts +2 -2
  117. package/apps/control-plane/src/cli/status-command-handler.ts +13 -12
  118. package/apps/control-plane/src/cli/tooling.ts +3 -3
  119. package/apps/control-plane/src/cli/types.ts +1 -1
  120. package/apps/control-plane/src/core/collisions.ts +27 -10
  121. package/apps/control-plane/src/core/constants.ts +13 -7
  122. package/apps/control-plane/src/core/error-codes.ts +1 -1
  123. package/apps/control-plane/src/core/fs.ts +11 -5
  124. package/apps/control-plane/src/core/gates.ts +53 -27
  125. package/apps/control-plane/src/core/git.ts +18 -6
  126. package/apps/control-plane/src/core/kernel.ts +513 -227
  127. package/apps/control-plane/src/core/patch.ts +7 -3
  128. package/apps/control-plane/src/core/path-layout.ts +5 -1
  129. package/apps/control-plane/src/core/path-rules.ts +19 -5
  130. package/apps/control-plane/src/core/qa-index.ts +26 -12
  131. package/apps/control-plane/src/core/response.ts +9 -6
  132. package/apps/control-plane/src/core/schemas.ts +29 -10
  133. package/apps/control-plane/src/core/tool-caller.ts +1 -1
  134. package/apps/control-plane/src/core/workspace-hooks.ts +5 -5
  135. package/apps/control-plane/src/index.ts +3 -9
  136. package/apps/control-plane/src/interfaces/cli/bootstrap.ts +79 -35
  137. package/apps/control-plane/src/mcp/kernel-tool-executor.ts +7 -3
  138. package/apps/control-plane/src/mcp/mcp-server-adapter.ts +12 -10
  139. package/apps/control-plane/src/mcp/operation-ledger.ts +18 -8
  140. package/apps/control-plane/src/mcp/protocol-contract.ts +2 -2
  141. package/apps/control-plane/src/mcp/runtime-factory.ts +15 -6
  142. package/apps/control-plane/src/mcp/token-auth-verifier.ts +3 -2
  143. package/apps/control-plane/src/mcp/token-claims-validator.ts +11 -7
  144. package/apps/control-plane/src/mcp/tool-authorizer.ts +1 -3
  145. package/apps/control-plane/src/mcp/tool-client.ts +17 -5
  146. package/apps/control-plane/src/mcp/tool-contract-validator.ts +17 -8
  147. package/apps/control-plane/src/mcp/tool-registry-loader.ts +7 -3
  148. package/apps/control-plane/src/mcp/tool-runtime.ts +66 -39
  149. package/apps/control-plane/src/mcp/tools-markdown-generator.ts +6 -1
  150. package/apps/control-plane/src/providers/providers.ts +137 -54
  151. package/apps/control-plane/src/supervisor/build-wave-executor.ts +44 -25
  152. package/apps/control-plane/src/supervisor/planning-wave-executor.ts +46 -33
  153. package/apps/control-plane/src/supervisor/prompt-bundle-loader.ts +1 -1
  154. package/apps/control-plane/src/supervisor/qa-wave-executor.ts +38 -23
  155. package/apps/control-plane/src/supervisor/run-coordinator.ts +71 -36
  156. package/apps/control-plane/src/supervisor/runtime.ts +59 -35
  157. package/apps/control-plane/src/supervisor/session-orchestrator.ts +48 -31
  158. package/apps/control-plane/src/supervisor/types.ts +22 -7
  159. package/apps/control-plane/src/supervisor/worker-decision-loop.ts +30 -20
  160. package/apps/control-plane/test/activity-monitor.spec.ts +54 -30
  161. package/apps/control-plane/test/adapter-registry.spec.ts +5 -5
  162. package/apps/control-plane/test/aop.spec.ts +4 -4
  163. package/apps/control-plane/test/batch-operations.spec.ts +20 -18
  164. package/apps/control-plane/test/bootstrap-attach.spec.ts +52 -19
  165. package/apps/control-plane/test/bootstrap-edge-cases.spec.ts +58 -27
  166. package/apps/control-plane/test/bootstrap.spec.ts +72 -40
  167. package/apps/control-plane/test/cleanup-command.spec.ts +86 -32
  168. package/apps/control-plane/test/cli-helpers.spec.ts +119 -66
  169. package/apps/control-plane/test/cli.spec.ts +1 -1
  170. package/apps/control-plane/test/cli.unit.spec.ts +226 -167
  171. package/apps/control-plane/test/collision-queue.spec.ts +49 -40
  172. package/apps/control-plane/test/collisions.spec.ts +30 -30
  173. package/apps/control-plane/test/core-utils.spec.ts +29 -15
  174. package/apps/control-plane/test/cost-tracking.spec.ts +38 -22
  175. package/apps/control-plane/test/dashboard-api.integration.spec.ts +68 -36
  176. package/apps/control-plane/test/dashboard-client.spec.ts +18 -12
  177. package/apps/control-plane/test/dashboard-command.spec.ts +11 -7
  178. package/apps/control-plane/test/delete-command-handler.spec.ts +49 -41
  179. package/apps/control-plane/test/dependency-scheduler.spec.ts +47 -20
  180. package/apps/control-plane/test/epoch-tracking.spec.ts +9 -9
  181. package/apps/control-plane/test/feature-deletion-service.spec.ts +60 -52
  182. package/apps/control-plane/test/feature-lifecycle.spec.ts +36 -17
  183. package/apps/control-plane/test/gates.spec.ts +101 -81
  184. package/apps/control-plane/test/git-spawn-error.spec.ts +1 -1
  185. package/apps/control-plane/test/helpers.ts +10 -6
  186. package/apps/control-plane/test/incremental-gates.spec.ts +59 -20
  187. package/apps/control-plane/test/init-wizard.spec.ts +328 -68
  188. package/apps/control-plane/test/instance-isolation.spec.ts +43 -10
  189. package/apps/control-plane/test/issue-tracker.spec.ts +368 -128
  190. package/apps/control-plane/test/kernel-collision-replay.spec.ts +50 -29
  191. package/apps/control-plane/test/kernel.branches.spec.ts +64 -40
  192. package/apps/control-plane/test/kernel.coverage.spec.ts +85 -49
  193. package/apps/control-plane/test/kernel.coverage2.spec.ts +109 -65
  194. package/apps/control-plane/test/kernel.spec.ts +134 -51
  195. package/apps/control-plane/test/lock-service.spec.ts +92 -68
  196. package/apps/control-plane/test/mcp-helpers.spec.ts +53 -39
  197. package/apps/control-plane/test/mcp.spec.ts +231 -115
  198. package/apps/control-plane/test/merge-service.spec.ts +142 -94
  199. package/apps/control-plane/test/multi-project.spec.ts +28 -22
  200. package/apps/control-plane/test/notifier-service.spec.ts +136 -92
  201. package/apps/control-plane/test/parallel-gates.spec.ts +51 -35
  202. package/apps/control-plane/test/patch-service.spec.ts +128 -48
  203. package/apps/control-plane/test/performance-analytics.spec.ts +99 -63
  204. package/apps/control-plane/test/plan-service.spec.ts +50 -39
  205. package/apps/control-plane/test/planning-wave-executor.spec.ts +95 -71
  206. package/apps/control-plane/test/policy-loader-service.spec.ts +41 -19
  207. package/apps/control-plane/test/pr-monitor.spec.ts +113 -64
  208. package/apps/control-plane/test/providers.spec.ts +208 -104
  209. package/apps/control-plane/test/qa-index-service.spec.ts +31 -33
  210. package/apps/control-plane/test/qa-index.spec.ts +58 -61
  211. package/apps/control-plane/test/reactions.spec.ts +88 -45
  212. package/apps/control-plane/test/response.spec.ts +5 -5
  213. package/apps/control-plane/test/resume-command.spec.ts +121 -80
  214. package/apps/control-plane/test/run-coordinator.spec.ts +205 -136
  215. package/apps/control-plane/test/schema-date-time.spec.ts +49 -41
  216. package/apps/control-plane/test/service-retry-paths.spec.ts +77 -57
  217. package/apps/control-plane/test/services.spec.ts +147 -129
  218. package/apps/control-plane/test/session-management.spec.ts +136 -74
  219. package/apps/control-plane/test/spec-ingestion.spec.ts +23 -21
  220. package/apps/control-plane/test/spec-input-resolver.spec.ts +11 -10
  221. package/apps/control-plane/test/supervisor-collaborators.spec.ts +168 -121
  222. package/apps/control-plane/test/supervisor.calltool.spec.ts +21 -18
  223. package/apps/control-plane/test/supervisor.spec.ts +67 -43
  224. package/apps/control-plane/test/supervisor.unit.spec.ts +195 -126
  225. package/apps/control-plane/test/token-auth-verifier.spec.ts +29 -14
  226. package/apps/control-plane/test/tool-registry-loader.spec.ts +51 -27
  227. package/apps/control-plane/test/tool-runtime.spec.ts +63 -46
  228. package/apps/control-plane/test/worker-decision-loop.spec.ts +143 -122
  229. package/apps/control-plane/test/workspace-hooks.spec.ts +61 -23
  230. package/apps/control-plane/tsconfig.build.json +2 -7
  231. package/apps/control-plane/tsconfig.json +1 -5
  232. package/apps/control-plane/vitest.config.ts +7 -7
  233. package/config/agentic/orchestrator/adapters.yaml +3 -0
  234. package/config/agentic/orchestrator/agents.yaml +14 -0
  235. package/config/agentic/orchestrator/gates.yaml +28 -0
  236. package/config/agentic/orchestrator/policy.yaml +22 -0
  237. package/config/agentic/orchestrator/prompts/builder.system.md +1 -0
  238. package/config/agentic/orchestrator/prompts/planner.system.md +16 -0
  239. package/config/agentic/orchestrator/prompts/qa.system.md +1 -0
  240. package/dist/apps/control-plane/application/adapters/adapter-registry.js +12 -5
  241. package/dist/apps/control-plane/application/adapters/adapter-registry.js.map +1 -1
  242. package/dist/apps/control-plane/application/multi-project-loader.js +26 -9
  243. package/dist/apps/control-plane/application/multi-project-loader.js.map +1 -1
  244. package/dist/apps/control-plane/application/services/activity-monitor-service.js +7 -7
  245. package/dist/apps/control-plane/application/services/activity-monitor-service.js.map +1 -1
  246. package/dist/apps/control-plane/application/services/collision-queue-service.js +7 -7
  247. package/dist/apps/control-plane/application/services/collision-queue-service.js.map +1 -1
  248. package/dist/apps/control-plane/application/services/cost-tracking-service.js +6 -8
  249. package/dist/apps/control-plane/application/services/cost-tracking-service.js.map +1 -1
  250. package/dist/apps/control-plane/application/services/dependency-scheduler-service.js.map +1 -1
  251. package/dist/apps/control-plane/application/services/feature-deletion-service.js +37 -29
  252. package/dist/apps/control-plane/application/services/feature-deletion-service.js.map +1 -1
  253. package/dist/apps/control-plane/application/services/feature-lifecycle-service.js +10 -10
  254. package/dist/apps/control-plane/application/services/feature-lifecycle-service.js.map +1 -1
  255. package/dist/apps/control-plane/application/services/feature-state-service.js +11 -11
  256. package/dist/apps/control-plane/application/services/feature-state-service.js.map +1 -1
  257. package/dist/apps/control-plane/application/services/gate-interpolation-service.js +3 -1
  258. package/dist/apps/control-plane/application/services/gate-interpolation-service.js.map +1 -1
  259. package/dist/apps/control-plane/application/services/gate-service.js +26 -26
  260. package/dist/apps/control-plane/application/services/gate-service.js.map +1 -1
  261. package/dist/apps/control-plane/application/services/instance-isolation-service.js +1 -1
  262. package/dist/apps/control-plane/application/services/instance-isolation-service.js.map +1 -1
  263. package/dist/apps/control-plane/application/services/issue-tracker-service.js +25 -15
  264. package/dist/apps/control-plane/application/services/issue-tracker-service.js.map +1 -1
  265. package/dist/apps/control-plane/application/services/lock-service.js +32 -32
  266. package/dist/apps/control-plane/application/services/lock-service.js.map +1 -1
  267. package/dist/apps/control-plane/application/services/merge-service.js +41 -27
  268. package/dist/apps/control-plane/application/services/merge-service.js.map +1 -1
  269. package/dist/apps/control-plane/application/services/notifier-service.js +29 -15
  270. package/dist/apps/control-plane/application/services/notifier-service.js.map +1 -1
  271. package/dist/apps/control-plane/application/services/patch-service.js +21 -19
  272. package/dist/apps/control-plane/application/services/patch-service.js.map +1 -1
  273. package/dist/apps/control-plane/application/services/performance-analytics-service.js +4 -4
  274. package/dist/apps/control-plane/application/services/performance-analytics-service.js.map +1 -1
  275. package/dist/apps/control-plane/application/services/plan-service.js +33 -33
  276. package/dist/apps/control-plane/application/services/plan-service.js.map +1 -1
  277. package/dist/apps/control-plane/application/services/policy-loader-service.js.map +1 -1
  278. package/dist/apps/control-plane/application/services/pr-monitor-service.js +23 -11
  279. package/dist/apps/control-plane/application/services/pr-monitor-service.js.map +1 -1
  280. package/dist/apps/control-plane/application/services/qa-index-service.js +11 -11
  281. package/dist/apps/control-plane/application/services/qa-index-service.js.map +1 -1
  282. package/dist/apps/control-plane/application/services/reactions-service.js +13 -9
  283. package/dist/apps/control-plane/application/services/reactions-service.js.map +1 -1
  284. package/dist/apps/control-plane/application/services/reporting-service.js +11 -9
  285. package/dist/apps/control-plane/application/services/reporting-service.js.map +1 -1
  286. package/dist/apps/control-plane/application/services/run-lease-service.js +34 -33
  287. package/dist/apps/control-plane/application/services/run-lease-service.js.map +1 -1
  288. package/dist/apps/control-plane/application/tools/tool-metadata.js +2 -2
  289. package/dist/apps/control-plane/application/tools/tool-router.js.map +1 -1
  290. package/dist/apps/control-plane/cli/attach-command-handler.js +9 -9
  291. package/dist/apps/control-plane/cli/cleanup-command-handler.js +11 -9
  292. package/dist/apps/control-plane/cli/cleanup-command-handler.js.map +1 -1
  293. package/dist/apps/control-plane/cli/cli-argument-parser.js +4 -3
  294. package/dist/apps/control-plane/cli/cli-argument-parser.js.map +1 -1
  295. package/dist/apps/control-plane/cli/dashboard-command-handler.js +23 -7
  296. package/dist/apps/control-plane/cli/dashboard-command-handler.js.map +1 -1
  297. package/dist/apps/control-plane/cli/delete-command-handler.js +7 -7
  298. package/dist/apps/control-plane/cli/env-file.d.ts +4 -0
  299. package/dist/apps/control-plane/cli/env-file.js +89 -0
  300. package/dist/apps/control-plane/cli/env-file.js.map +1 -0
  301. package/dist/apps/control-plane/cli/help-command-handler.js +58 -30
  302. package/dist/apps/control-plane/cli/help-command-handler.js.map +1 -1
  303. package/dist/apps/control-plane/cli/init-command-handler.js +97 -37
  304. package/dist/apps/control-plane/cli/init-command-handler.js.map +1 -1
  305. package/dist/apps/control-plane/cli/io.js +2 -2
  306. package/dist/apps/control-plane/cli/io.js.map +1 -1
  307. package/dist/apps/control-plane/cli/resume-command-handler.js +9 -9
  308. package/dist/apps/control-plane/cli/resume-command-handler.js.map +1 -1
  309. package/dist/apps/control-plane/cli/retry-command-handler.js +12 -11
  310. package/dist/apps/control-plane/cli/retry-command-handler.js.map +1 -1
  311. package/dist/apps/control-plane/cli/run-command-handler.js +12 -8
  312. package/dist/apps/control-plane/cli/run-command-handler.js.map +1 -1
  313. package/dist/apps/control-plane/cli/send-command-handler.js +6 -6
  314. package/dist/apps/control-plane/cli/spec-ingestion-service.js +10 -8
  315. package/dist/apps/control-plane/cli/spec-ingestion-service.js.map +1 -1
  316. package/dist/apps/control-plane/cli/spec-input-resolver.js.map +1 -1
  317. package/dist/apps/control-plane/cli/spec-utils.js.map +1 -1
  318. package/dist/apps/control-plane/cli/status-command-handler.js +8 -8
  319. package/dist/apps/control-plane/cli/status-command-handler.js.map +1 -1
  320. package/dist/apps/control-plane/cli/tooling.js +1 -1
  321. package/dist/apps/control-plane/core/collisions.js +11 -8
  322. package/dist/apps/control-plane/core/collisions.js.map +1 -1
  323. package/dist/apps/control-plane/core/constants.js +13 -7
  324. package/dist/apps/control-plane/core/constants.js.map +1 -1
  325. package/dist/apps/control-plane/core/error-codes.js +1 -1
  326. package/dist/apps/control-plane/core/fs.js.map +1 -1
  327. package/dist/apps/control-plane/core/gates.d.ts +2 -2
  328. package/dist/apps/control-plane/core/gates.js +26 -19
  329. package/dist/apps/control-plane/core/gates.js.map +1 -1
  330. package/dist/apps/control-plane/core/git.js +3 -3
  331. package/dist/apps/control-plane/core/git.js.map +1 -1
  332. package/dist/apps/control-plane/core/kernel.d.ts +1 -0
  333. package/dist/apps/control-plane/core/kernel.js +134 -81
  334. package/dist/apps/control-plane/core/kernel.js.map +1 -1
  335. package/dist/apps/control-plane/core/patch.js +7 -3
  336. package/dist/apps/control-plane/core/patch.js.map +1 -1
  337. package/dist/apps/control-plane/core/path-layout.d.ts +1 -0
  338. package/dist/apps/control-plane/core/path-layout.js +4 -1
  339. package/dist/apps/control-plane/core/path-layout.js.map +1 -1
  340. package/dist/apps/control-plane/core/path-rules.js +3 -1
  341. package/dist/apps/control-plane/core/path-rules.js.map +1 -1
  342. package/dist/apps/control-plane/core/qa-index.js +5 -5
  343. package/dist/apps/control-plane/core/qa-index.js.map +1 -1
  344. package/dist/apps/control-plane/core/response.js +3 -3
  345. package/dist/apps/control-plane/core/response.js.map +1 -1
  346. package/dist/apps/control-plane/core/schemas.js +10 -6
  347. package/dist/apps/control-plane/core/schemas.js.map +1 -1
  348. package/dist/apps/control-plane/core/workspace-hooks.js +3 -3
  349. package/dist/apps/control-plane/index.d.ts +1 -1
  350. package/dist/apps/control-plane/index.js +1 -1
  351. package/dist/apps/control-plane/index.js.map +1 -1
  352. package/dist/apps/control-plane/interfaces/cli/bootstrap.js +40 -23
  353. package/dist/apps/control-plane/interfaces/cli/bootstrap.js.map +1 -1
  354. package/dist/apps/control-plane/mcp/kernel-tool-executor.js +1 -1
  355. package/dist/apps/control-plane/mcp/kernel-tool-executor.js.map +1 -1
  356. package/dist/apps/control-plane/mcp/mcp-server-adapter.js +6 -7
  357. package/dist/apps/control-plane/mcp/mcp-server-adapter.js.map +1 -1
  358. package/dist/apps/control-plane/mcp/operation-ledger.js +5 -5
  359. package/dist/apps/control-plane/mcp/operation-ledger.js.map +1 -1
  360. package/dist/apps/control-plane/mcp/protocol-contract.js +2 -2
  361. package/dist/apps/control-plane/mcp/runtime-factory.js +2 -2
  362. package/dist/apps/control-plane/mcp/runtime-factory.js.map +1 -1
  363. package/dist/apps/control-plane/mcp/token-auth-verifier.js +1 -1
  364. package/dist/apps/control-plane/mcp/token-auth-verifier.js.map +1 -1
  365. package/dist/apps/control-plane/mcp/token-claims-validator.js +5 -5
  366. package/dist/apps/control-plane/mcp/token-claims-validator.js.map +1 -1
  367. package/dist/apps/control-plane/mcp/tool-authorizer.js +1 -3
  368. package/dist/apps/control-plane/mcp/tool-authorizer.js.map +1 -1
  369. package/dist/apps/control-plane/mcp/tool-client.js +2 -2
  370. package/dist/apps/control-plane/mcp/tool-client.js.map +1 -1
  371. package/dist/apps/control-plane/mcp/tool-contract-validator.js +3 -3
  372. package/dist/apps/control-plane/mcp/tool-contract-validator.js.map +1 -1
  373. package/dist/apps/control-plane/mcp/tool-registry-loader.js +1 -1
  374. package/dist/apps/control-plane/mcp/tool-registry-loader.js.map +1 -1
  375. package/dist/apps/control-plane/mcp/tool-runtime.js +17 -17
  376. package/dist/apps/control-plane/mcp/tool-runtime.js.map +1 -1
  377. package/dist/apps/control-plane/mcp/tools-markdown-generator.js +6 -1
  378. package/dist/apps/control-plane/mcp/tools-markdown-generator.js.map +1 -1
  379. package/dist/apps/control-plane/providers/providers.d.ts +3 -2
  380. package/dist/apps/control-plane/providers/providers.js +81 -39
  381. package/dist/apps/control-plane/providers/providers.js.map +1 -1
  382. package/dist/apps/control-plane/supervisor/build-wave-executor.js +12 -12
  383. package/dist/apps/control-plane/supervisor/build-wave-executor.js.map +1 -1
  384. package/dist/apps/control-plane/supervisor/planning-wave-executor.js +19 -16
  385. package/dist/apps/control-plane/supervisor/planning-wave-executor.js.map +1 -1
  386. package/dist/apps/control-plane/supervisor/prompt-bundle-loader.js +1 -1
  387. package/dist/apps/control-plane/supervisor/qa-wave-executor.js +13 -13
  388. package/dist/apps/control-plane/supervisor/qa-wave-executor.js.map +1 -1
  389. package/dist/apps/control-plane/supervisor/run-coordinator.js +37 -20
  390. package/dist/apps/control-plane/supervisor/run-coordinator.js.map +1 -1
  391. package/dist/apps/control-plane/supervisor/runtime.js +25 -21
  392. package/dist/apps/control-plane/supervisor/runtime.js.map +1 -1
  393. package/dist/apps/control-plane/supervisor/session-orchestrator.js +29 -23
  394. package/dist/apps/control-plane/supervisor/session-orchestrator.js.map +1 -1
  395. package/dist/apps/control-plane/supervisor/types.d.ts +3 -3
  396. package/dist/apps/control-plane/supervisor/types.js.map +1 -1
  397. package/dist/apps/control-plane/supervisor/worker-decision-loop.js +14 -16
  398. package/dist/apps/control-plane/supervisor/worker-decision-loop.js.map +1 -1
  399. package/eslint.config.mjs +20 -20
  400. package/example-configurations/README.md +1 -1
  401. package/example-configurations/java/agents.yaml +3 -3
  402. package/example-configurations/java/policy.yaml +1 -1
  403. package/example-configurations/node/agents.yaml +3 -3
  404. package/example-configurations/node/policy.yaml +1 -1
  405. package/package.json +10 -5
  406. package/packages/web-dashboard/next.config.js +2 -2
  407. package/packages/web-dashboard/src/app/api/actions/route.ts +25 -9
  408. package/packages/web-dashboard/src/app/api/events/route.ts +20 -6
  409. package/packages/web-dashboard/src/app/api/features/[id]/checkout/route.ts +88 -37
  410. package/packages/web-dashboard/src/app/api/features/[id]/evidence/[artifact]/route.ts +8 -5
  411. package/packages/web-dashboard/src/app/api/features/[id]/review/route.ts +27 -9
  412. package/packages/web-dashboard/src/app/api/features/[id]/route.ts +5 -2
  413. package/packages/web-dashboard/src/app/api/projects/route.ts +5 -5
  414. package/packages/web-dashboard/src/app/globals.css +10 -2
  415. package/packages/web-dashboard/src/app/page.tsx +100 -37
  416. package/packages/web-dashboard/src/lib/aop-client.ts +68 -37
  417. package/packages/web-dashboard/src/lib/multi-project-config.ts +28 -7
  418. package/packages/web-dashboard/src/lib/orchestrator-tools.ts +59 -36
  419. package/packages/web-dashboard/tsconfig.json +3 -11
  420. package/scripts/nx-safe.mjs +10 -10
  421. package/spec-files/completed/agentic_orchestrator_cli_delete_command_spec.md +5 -0
  422. package/spec-files/completed/agentic_orchestrator_feature_gaps_closure_spec.md +189 -90
  423. package/spec-files/completed/agentic_orchestrator_init_policy_ux_simplification_spec.md +49 -16
  424. package/spec-files/completed/agentic_orchestrator_mcp_formalization_spec.md +24 -1
  425. package/spec-files/completed/agentic_orchestrator_single_global_orchestrator_spec.md +9 -0
  426. package/spec-files/completed/agentic_orchestrator_spec.md +171 -75
  427. package/spec-files/completed/agentic_orchestrator_validator_hardening_spec.md +25 -17
  428. package/spec-files/outstanding/agentic_orchestrator_artifact_database_publishing_spec.md +40 -5
  429. package/spec-files/outstanding/agentic_orchestrator_enterprise_governance_dashboard_spec.md +23 -12
  430. package/spec-files/outstanding/agentic_orchestrator_knowledge_canary_spec.md +16 -4
  431. package/spec-files/outstanding/agentic_orchestrator_observability_integrity_diagnostics_spec.md +42 -2
  432. package/spec-files/outstanding/agentic_orchestrator_performance_improvements_spec.md +209 -130
  433. package/spec-files/outstanding/agentic_orchestrator_planning_review_quality_spec.md +56 -3
  434. package/spec-files/outstanding/agentic_orchestrator_productization_commercial_spec.md +77 -10
  435. package/spec-files/outstanding/agentic_orchestrator_provider_auth_bootstrap_spec.md +384 -0
  436. package/spec-files/outstanding/agentic_orchestrator_quality_adoption_execution_spec.md +29 -14
  437. package/spec-files/progress.md +186 -175
  438. package/tsconfig.json +2 -8
@@ -5,14 +5,21 @@ import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
5
5
 
6
6
  const resolveProjectRootMock = vi.hoisted(() => vi.fn(async () => '/tmp'));
7
7
  const readDashboardStatusMock = vi.hoisted(() =>
8
- vi.fn(async () => ({ index: { active: [], blocked: [], merged: [], blocked_queue: [] }, features: [] }))
8
+ vi.fn(async () => ({
9
+ index: { active: [], blocked: [], merged: [], blocked_queue: [] },
10
+ features: [],
11
+ })),
9
12
  );
10
13
  const readFeatureStateMock = vi.hoisted(() => vi.fn(async () => null));
11
14
  const getAopRootMock = vi.hoisted(() => vi.fn(() => process.cwd()));
12
- const approveFeatureReviewMock = vi.hoisted(() => vi.fn(async () => ({ ok: true, data: { merged: true } })));
13
- const denyFeatureReviewMock = vi.hoisted(() => vi.fn(async () => ({ ok: true, data: { blocked: true } })));
15
+ const approveFeatureReviewMock = vi.hoisted(() =>
16
+ vi.fn(async () => ({ ok: true, data: { merged: true } })),
17
+ );
18
+ const denyFeatureReviewMock = vi.hoisted(() =>
19
+ vi.fn(async () => ({ ok: true, data: { blocked: true } })),
20
+ );
14
21
  const requestFeatureChangesMock = vi.hoisted(() =>
15
- vi.fn(async () => ({ ok: true, data: { delivered: true } }))
22
+ vi.fn(async () => ({ ok: true, data: { delivered: true } })),
16
23
  );
17
24
  const execFileMock = vi.hoisted(() => vi.fn());
18
25
 
@@ -20,24 +27,27 @@ vi.mock('../../../packages/web-dashboard/src/lib/aop-client.js', () => ({
20
27
  resolveProjectRoot: resolveProjectRootMock,
21
28
  readDashboardStatus: readDashboardStatusMock,
22
29
  readFeatureState: readFeatureStateMock,
23
- getAopRoot: getAopRootMock
30
+ getAopRoot: getAopRootMock,
24
31
  }));
25
32
 
26
33
  vi.mock('../../../packages/web-dashboard/src/lib/orchestrator-tools.js', () => ({
27
34
  approveFeatureReview: approveFeatureReviewMock,
28
35
  denyFeatureReview: denyFeatureReviewMock,
29
- requestFeatureChanges: requestFeatureChangesMock
36
+ requestFeatureChanges: requestFeatureChangesMock,
30
37
  }));
31
38
 
32
39
  vi.mock('node:child_process', () => ({
33
40
  execFile: (...args: unknown[]) => {
34
- const callback = args[args.length - 1] as (err: null | Error, result?: { stdout: string; stderr: string }) => void;
41
+ const callback = args[args.length - 1] as (
42
+ err: null | Error,
43
+ result?: { stdout: string; stderr: string },
44
+ ) => void;
35
45
  const call = execFileMock(...args.slice(0, -1)) as Promise<{ stdout: string; stderr: string }>;
36
46
  void call.then(
37
47
  (result) => callback(null, result),
38
- (error: Error) => callback(error)
48
+ (error: Error) => callback(error),
39
49
  );
40
- }
50
+ },
41
51
  }));
42
52
 
43
53
  import { POST as actionsPost } from '../../../packages/web-dashboard/src/app/api/actions/route.js';
@@ -75,9 +85,9 @@ describe('dashboard api integration', () => {
75
85
  phase: 'ready_to_merge',
76
86
  branch: 'feature/feature_checkout',
77
87
  worktree_path: path.join(repoRoot, '.worktrees', 'feature_checkout'),
78
- pr: null
79
- }
80
- ]
88
+ pr: null,
89
+ },
90
+ ],
81
91
  });
82
92
  });
83
93
 
@@ -92,9 +102,9 @@ describe('dashboard api integration', () => {
92
102
  body: JSON.stringify({
93
103
  action: 'review.approve',
94
104
  feature_id: 'feature_checkout',
95
- approval_token: 'approved'
96
- })
97
- })
105
+ approval_token: 'approved',
106
+ }),
107
+ }),
98
108
  );
99
109
 
100
110
  expect(response.status).toBe(200);
@@ -103,7 +113,7 @@ describe('dashboard api integration', () => {
103
113
  'approved',
104
114
  'merge_commit',
105
115
  undefined,
106
- repoRoot
116
+ repoRoot,
107
117
  );
108
118
  });
109
119
 
@@ -114,13 +124,17 @@ describe('dashboard api integration', () => {
114
124
  body: JSON.stringify({
115
125
  action: 'review.request_changes',
116
126
  feature_id: 'feature_checkout',
117
- message: 'Please address CI failures'
118
- })
119
- })
127
+ message: 'Please address CI failures',
128
+ }),
129
+ }),
120
130
  );
121
131
 
122
132
  expect(response.status).toBe(200);
123
- expect(requestFeatureChangesMock).toHaveBeenCalledWith('feature_checkout', 'Please address CI failures', repoRoot);
133
+ expect(requestFeatureChangesMock).toHaveBeenCalledWith(
134
+ 'feature_checkout',
135
+ 'Please address CI failures',
136
+ repoRoot,
137
+ );
124
138
  });
125
139
 
126
140
  it('GIVEN_review_deny_without_reason_WHEN_posted_THEN_returns_400', async () => {
@@ -129,9 +143,9 @@ describe('dashboard api integration', () => {
129
143
  method: 'POST',
130
144
  body: JSON.stringify({
131
145
  action: 'review.deny',
132
- feature_id: 'feature_checkout'
133
- })
134
- })
146
+ feature_id: 'feature_checkout',
147
+ }),
148
+ }),
135
149
  );
136
150
 
137
151
  const body = (await response.json()) as { ok: boolean; error: { code: string } };
@@ -148,7 +162,7 @@ describe('dashboard api integration', () => {
148
162
  phase: 'ready_to_merge',
149
163
  branch: 'feature/feature_checkout',
150
164
  worktree_path: path.join(repoRoot, '.worktrees', 'feature_checkout'),
151
- pr: null
165
+ pr: null,
152
166
  });
153
167
 
154
168
  execFileMock.mockImplementation(async (_file: string, args: string[]) => {
@@ -174,11 +188,14 @@ describe('dashboard api integration', () => {
174
188
  const checkoutResponse = await checkoutPost(
175
189
  new Request('http://localhost/api/features/feature_checkout/checkout?project=alpha', {
176
190
  method: 'POST',
177
- body: JSON.stringify({ action: 'checkout', stash_changes: false })
191
+ body: JSON.stringify({ action: 'checkout', stash_changes: false }),
178
192
  }),
179
- { params: { id: 'feature_checkout' } }
193
+ { params: { id: 'feature_checkout' } },
180
194
  );
181
- const checkoutBody = (await checkoutResponse.json()) as { ok: boolean; data: { previous_branch: string } };
195
+ const checkoutBody = (await checkoutResponse.json()) as {
196
+ ok: boolean;
197
+ data: { previous_branch: string };
198
+ };
182
199
  expect(checkoutResponse.status).toBe(200);
183
200
  expect(checkoutBody.ok).toBe(true);
184
201
  expect(checkoutBody.data.previous_branch).toBe('main');
@@ -189,11 +206,14 @@ describe('dashboard api integration', () => {
189
206
  const restoreResponse = await checkoutPost(
190
207
  new Request('http://localhost/api/features/feature_checkout/checkout?project=alpha', {
191
208
  method: 'POST',
192
- body: JSON.stringify({ action: 'restore' })
209
+ body: JSON.stringify({ action: 'restore' }),
193
210
  }),
194
- { params: { id: 'feature_checkout' } }
211
+ { params: { id: 'feature_checkout' } },
195
212
  );
196
- const restoreBody = (await restoreResponse.json()) as { ok: boolean; data: { restored_to: string } };
213
+ const restoreBody = (await restoreResponse.json()) as {
214
+ ok: boolean;
215
+ data: { restored_to: string };
216
+ };
197
217
  expect(restoreResponse.status).toBe(200);
198
218
  expect(restoreBody.ok).toBe(true);
199
219
  expect(restoreBody.data.restored_to).toBe('main');
@@ -215,22 +235,34 @@ describe('dashboard api integration', () => {
215
235
  it('GIVEN_multi_project_config_WHEN_projects_endpoint_called_THEN_returns_switchable_projects', async () => {
216
236
  const projectAlpha = path.join(repoRoot, 'project-alpha');
217
237
  const projectBeta = path.join(repoRoot, 'project-beta');
218
- await fs.mkdir(path.join(repoRoot, 'agentic', 'orchestrator', 'schemas'), { recursive: true });
238
+ await fs.mkdir(path.join(repoRoot, 'config', 'agentic', 'orchestrator', 'schemas'), {
239
+ recursive: true,
240
+ });
219
241
  await fs.copyFile(
220
- path.resolve(import.meta.dirname, '../../../agentic/orchestrator/schemas/multi-project.schema.json'),
221
- path.join(repoRoot, 'agentic', 'orchestrator', 'schemas', 'multi-project.schema.json')
242
+ path.resolve(
243
+ import.meta.dirname,
244
+ '../../../agentic/orchestrator/schemas/multi-project.schema.json',
245
+ ),
246
+ path.join(
247
+ repoRoot,
248
+ 'config',
249
+ 'agentic',
250
+ 'orchestrator',
251
+ 'schemas',
252
+ 'multi-project.schema.json',
253
+ ),
222
254
  );
223
255
  await fs.writeFile(
224
- path.join(repoRoot, 'agentic', 'orchestrator', 'multi-project.yaml'),
256
+ path.join(repoRoot, 'config', 'agentic', 'orchestrator', 'multi-project.yaml'),
225
257
  [
226
258
  'version: "1.0"',
227
259
  'projects:',
228
260
  ` - name: alpha`,
229
261
  ` path: ${projectAlpha}`,
230
262
  ` - name: beta`,
231
- ` path: ${projectBeta}`
263
+ ` path: ${projectBeta}`,
232
264
  ].join('\n'),
233
- 'utf8'
265
+ 'utf8',
234
266
  );
235
267
 
236
268
  const response = await projectsGet();
@@ -2,7 +2,7 @@ import fs from 'node:fs/promises';
2
2
  import os from 'node:os';
3
3
  import path from 'node:path';
4
4
  import { afterEach, describe, expect, it } from 'vitest';
5
- import { readDashboardStatus } from '../../../packages/web-dashboard/src/lib/aop-client.js';
5
+ import { readDashboardStatus } from '@/lib/aop-client.js';
6
6
 
7
7
  async function writeState(repoRoot: string, featureId: string, frontMatter: string): Promise<void> {
8
8
  const featureDir = path.join(repoRoot, '.aop', 'features', featureId);
@@ -25,7 +25,7 @@ describe('dashboard aop client mapping', () => {
25
25
  await fs.writeFile(
26
26
  path.join(repoRoot, '.aop', 'features', 'index.json'),
27
27
  JSON.stringify({ active: ['feature_a'], blocked: [], merged: [], blocked_queue: [] }),
28
- 'utf8'
28
+ 'utf8',
29
29
  );
30
30
  await writeState(
31
31
  repoRoot,
@@ -37,8 +37,8 @@ describe('dashboard aop client mapping', () => {
37
37
  'branch: feature_a',
38
38
  'worktree_path: /tmp/worktrees/feature_a',
39
39
  'gate_profile: default',
40
- 'last_updated: 2026-03-03T00:00:00Z'
41
- ].join('\n')
40
+ 'last_updated: 2026-03-03T00:00:00Z',
41
+ ].join('\n'),
42
42
  );
43
43
 
44
44
  const payload = await readDashboardStatus(repoRoot);
@@ -46,7 +46,7 @@ describe('dashboard aop client mapping', () => {
46
46
  expect(payload.features[0]).toMatchObject({
47
47
  feature_id: 'feature_a',
48
48
  status: 'unknown_status',
49
- phase: 'planning'
49
+ phase: 'planning',
50
50
  });
51
51
  });
52
52
 
@@ -57,7 +57,7 @@ describe('dashboard aop client mapping', () => {
57
57
  await fs.writeFile(
58
58
  path.join(repoRoot, '.aop', 'features', 'index.json'),
59
59
  JSON.stringify({ active: ['feature_pr'], blocked: [], merged: [], blocked_queue: [] }),
60
- 'utf8'
60
+ 'utf8',
61
61
  );
62
62
  await writeState(
63
63
  repoRoot,
@@ -78,8 +78,8 @@ describe('dashboard aop client mapping', () => {
78
78
  ' merge_ready: true',
79
79
  ' pending_review_threads: 0',
80
80
  ' has_conflicts: false',
81
- ' merge_score: 100'
82
- ].join('\n')
81
+ ' merge_score: 100',
82
+ ].join('\n'),
83
83
  );
84
84
 
85
85
  const payload = await readDashboardStatus(repoRoot);
@@ -87,7 +87,7 @@ describe('dashboard aop client mapping', () => {
87
87
  number: 42,
88
88
  ci_status: 'passing',
89
89
  review_decision: 'approved',
90
- merge_score: 100
90
+ merge_score: 100,
91
91
  });
92
92
  });
93
93
 
@@ -101,16 +101,22 @@ describe('dashboard aop client mapping', () => {
101
101
  active: [],
102
102
  blocked: [],
103
103
  merged: [],
104
- blocked_queue: [{ feature_id: 'feature_q', detected_at: '2026-03-03T00:00:00Z', collision_fingerprint: 'abc' }]
104
+ blocked_queue: [
105
+ {
106
+ feature_id: 'feature_q',
107
+ detected_at: '2026-03-03T00:00:00Z',
108
+ collision_fingerprint: 'abc',
109
+ },
110
+ ],
105
111
  }),
106
- 'utf8'
112
+ 'utf8',
107
113
  );
108
114
 
109
115
  const payload = await readDashboardStatus(repoRoot);
110
116
  expect(payload.features).toHaveLength(1);
111
117
  expect(payload.features[0]).toMatchObject({
112
118
  feature_id: 'feature_q',
113
- phase: 'blocked'
119
+ phase: 'blocked',
114
120
  });
115
121
  });
116
122
  });
@@ -28,12 +28,12 @@ describe('DashboardCommandHandler', () => {
28
28
  'npm',
29
29
  ['run', '--workspace', '@aop/web-dashboard', 'build'],
30
30
  expect.any(Object),
31
- expect.any(Function)
31
+ expect.any(Function),
32
32
  );
33
33
  expect(spawn).toHaveBeenCalledWith(
34
34
  'npm',
35
35
  ['run', '--workspace', '@aop/web-dashboard', 'start'],
36
- expect.objectContaining({ detached: true })
36
+ expect.objectContaining({ detached: true }),
37
37
  );
38
38
  expect(mockChild.unref).toHaveBeenCalled();
39
39
  expect(result).toMatchObject({ ok: true, data: { port: 3000, background: true, built: true } });
@@ -43,7 +43,9 @@ describe('DashboardCommandHandler', () => {
43
43
  const { spawn } = await import('node:child_process');
44
44
  const mockChild = {
45
45
  on: vi.fn((event: string, cb: () => void) => {
46
- if (event === 'close') { setTimeout(cb, 0); }
46
+ if (event === 'close') {
47
+ setTimeout(cb, 0);
48
+ }
47
49
  return mockChild;
48
50
  }),
49
51
  } as unknown as ChildProcess;
@@ -55,7 +57,7 @@ describe('DashboardCommandHandler', () => {
55
57
  expect(spawn).toHaveBeenCalledWith(
56
58
  'npm',
57
59
  ['run', '--workspace', '@aop/web-dashboard', 'start'],
58
- expect.objectContaining({ stdio: 'inherit' })
60
+ expect.objectContaining({ stdio: 'inherit' }),
59
61
  );
60
62
  expect(result).toMatchObject({ ok: true, data: { port: 3000, mode: 'production' } });
61
63
  });
@@ -75,7 +77,7 @@ describe('DashboardCommandHandler', () => {
75
77
  expect(spawn).toHaveBeenCalledWith(
76
78
  'npm',
77
79
  ['run', '--workspace', '@aop/web-dashboard', 'start'],
78
- expect.objectContaining({ env: expect.objectContaining({ PORT: '4000' }) })
80
+ expect.objectContaining({ env: expect.objectContaining({ PORT: '4000' }) }),
79
81
  );
80
82
  expect(result).toMatchObject({ ok: true, data: { port: 4000 } });
81
83
  });
@@ -84,7 +86,9 @@ describe('DashboardCommandHandler', () => {
84
86
  const { spawn } = await import('node:child_process');
85
87
  const mockChild = {
86
88
  on: vi.fn((event: string, cb: () => void) => {
87
- if (event === 'close') { setTimeout(cb, 0); }
89
+ if (event === 'close') {
90
+ setTimeout(cb, 0);
91
+ }
88
92
  return mockChild;
89
93
  }),
90
94
  } as unknown as ChildProcess;
@@ -96,7 +100,7 @@ describe('DashboardCommandHandler', () => {
96
100
  expect(spawn).toHaveBeenCalledWith(
97
101
  'npm',
98
102
  ['run', '--workspace', '@aop/web-dashboard', 'dev'],
99
- expect.objectContaining({ stdio: 'inherit' })
103
+ expect.objectContaining({ stdio: 'inherit' }),
100
104
  );
101
105
  expect(result).toMatchObject({ ok: true, data: { mode: 'dev' } });
102
106
  });
@@ -5,9 +5,11 @@ import { TOOLS } from '../src/core/constants.js';
5
5
 
6
6
  type ToolClientCall = ReturnType<typeof vi.fn>;
7
7
 
8
- function makeHandler(callImpl: ToolClientCall = vi.fn(async () => ({ ok: true, data: { feature_id: 'feature_a' } }))) {
8
+ function makeHandler(
9
+ callImpl: ToolClientCall = vi.fn(async () => ({ ok: true, data: { feature_id: 'feature_a' } })),
10
+ ) {
9
11
  const toolClient = {
10
- call: callImpl
12
+ call: callImpl,
11
13
  };
12
14
  const handler = new DeleteCommandHandler(toolClient as never, 'run:test');
13
15
  return { handler, toolClient };
@@ -15,12 +17,15 @@ function makeHandler(callImpl: ToolClientCall = vi.fn(async () => ({ ok: true, d
15
17
 
16
18
  describe('DeleteCommandHandler', () => {
17
19
  it('GIVEN_valid_defaults_WHEN_execute_called_THEN_calls_feature_delete_in_preview_mode', async () => {
18
- const call = vi.fn(async () => ({ ok: true, data: { feature_id: 'feature_a', dry_run: true } }));
20
+ const call = vi.fn(async () => ({
21
+ ok: true,
22
+ data: { feature_id: 'feature_a', dry_run: true },
23
+ }));
19
24
  const { handler, toolClient } = makeHandler(call);
20
25
 
21
26
  const result = await handler.execute({
22
27
  command: 'delete',
23
- feature_id: 'feature_a'
28
+ feature_id: 'feature_a',
24
29
  });
25
30
 
26
31
  expect(toolClient.call).toHaveBeenCalledWith(
@@ -31,40 +36,43 @@ describe('DeleteCommandHandler', () => {
31
36
  confirm: false,
32
37
  remove_worktree: true,
33
38
  remove_branch: 'none',
34
- operation_id: expect.any(String)
39
+ operation_id: expect.any(String),
35
40
  }),
36
41
  expect.objectContaining({
37
42
  run_id: 'run:test',
38
- actor_type: 'system'
39
- })
43
+ actor_type: 'system',
44
+ }),
40
45
  );
41
46
  expect(result).toMatchObject({
42
47
  ok: true,
43
48
  data: {
44
49
  command: 'delete',
45
50
  feature_id: 'feature_a',
46
- dry_run: true
47
- }
51
+ dry_run: true,
52
+ },
48
53
  });
49
54
  });
50
55
 
51
56
  it('GIVEN_yes_without_dry_run_WHEN_execute_called_THEN_runs_destructive_mode_by_default', async () => {
52
- const call = vi.fn(async () => ({ ok: true, data: { feature_id: 'feature_a', dry_run: false } }));
57
+ const call = vi.fn(async () => ({
58
+ ok: true,
59
+ data: { feature_id: 'feature_a', dry_run: false },
60
+ }));
53
61
  const { handler, toolClient } = makeHandler(call);
54
62
 
55
63
  await handler.execute({
56
64
  command: 'delete',
57
65
  feature_id: 'feature_a',
58
- yes: true
66
+ yes: true,
59
67
  });
60
68
 
61
69
  expect(toolClient.call).toHaveBeenCalledWith(
62
70
  TOOLS.FEATURE_DELETE,
63
71
  expect.objectContaining({
64
72
  dry_run: false,
65
- confirm: true
73
+ confirm: true,
66
74
  }),
67
- expect.any(Object)
75
+ expect.any(Object),
68
76
  );
69
77
  });
70
78
 
@@ -78,7 +86,7 @@ describe('DeleteCommandHandler', () => {
78
86
  yes: true,
79
87
  dry_run: true,
80
88
  remove_worktree: false,
81
- remove_branch: 'force'
89
+ remove_branch: 'force',
82
90
  });
83
91
 
84
92
  expect(toolClient.call).toHaveBeenCalledWith(
@@ -87,9 +95,9 @@ describe('DeleteCommandHandler', () => {
87
95
  dry_run: true,
88
96
  confirm: true,
89
97
  remove_worktree: false,
90
- remove_branch: 'force'
98
+ remove_branch: 'force',
91
99
  }),
92
- expect.any(Object)
100
+ expect.any(Object),
93
101
  );
94
102
  });
95
103
 
@@ -98,13 +106,13 @@ describe('DeleteCommandHandler', () => {
98
106
 
99
107
  await expect(
100
108
  handler.execute({
101
- command: 'delete'
102
- })
109
+ command: 'delete',
110
+ }),
103
111
  ).rejects.toMatchObject({
104
112
  code: ERROR_CODES.INVALID_CLI_ARGS,
105
113
  details: expect.objectContaining({
106
- reason: '--feature-id is required for delete'
107
- })
114
+ reason: '--feature-id is required for delete',
115
+ }),
108
116
  });
109
117
  });
110
118
 
@@ -114,13 +122,13 @@ describe('DeleteCommandHandler', () => {
114
122
  await expect(
115
123
  handler.execute({
116
124
  command: 'delete',
117
- feature_id: 'FeatureBad'
118
- })
125
+ feature_id: 'FeatureBad',
126
+ }),
119
127
  ).rejects.toMatchObject({
120
128
  code: ERROR_CODES.INVALID_CLI_ARGS,
121
129
  details: expect.objectContaining({
122
- reason: 'Invalid --feature-id value'
123
- })
130
+ reason: 'Invalid --feature-id value',
131
+ }),
124
132
  });
125
133
  });
126
134
 
@@ -131,13 +139,13 @@ describe('DeleteCommandHandler', () => {
131
139
  handler.execute({
132
140
  command: 'delete',
133
141
  feature_id: 'feature_a',
134
- remove_branch: 'hard'
135
- })
142
+ remove_branch: 'hard',
143
+ }),
136
144
  ).rejects.toMatchObject({
137
145
  code: ERROR_CODES.INVALID_CLI_ARGS,
138
146
  details: expect.objectContaining({
139
- reason: 'Invalid --remove-branch value'
140
- })
147
+ reason: 'Invalid --remove-branch value',
148
+ }),
141
149
  });
142
150
  });
143
151
 
@@ -149,13 +157,13 @@ describe('DeleteCommandHandler', () => {
149
157
  command: 'delete',
150
158
  feature_id: 'feature_a',
151
159
  dry_run: false,
152
- yes: false
153
- })
160
+ yes: false,
161
+ }),
154
162
  ).rejects.toMatchObject({
155
163
  code: ERROR_CODES.INVALID_CLI_ARGS,
156
164
  details: expect.objectContaining({
157
- reason: 'Destructive delete requires --yes'
158
- })
165
+ reason: 'Destructive delete requires --yes',
166
+ }),
159
167
  });
160
168
  });
161
169
 
@@ -165,21 +173,21 @@ describe('DeleteCommandHandler', () => {
165
173
  error: {
166
174
  code: ERROR_CODES.RUN_ALREADY_ACTIVE,
167
175
  message: 'run active',
168
- details: { stale: false }
169
- }
176
+ details: { stale: false },
177
+ },
170
178
  }));
171
179
  const { handler } = makeHandler(call);
172
180
 
173
181
  await expect(
174
182
  handler.execute({
175
183
  command: 'delete',
176
- feature_id: 'feature_a'
177
- })
184
+ feature_id: 'feature_a',
185
+ }),
178
186
  ).rejects.toMatchObject({
179
187
  code: ERROR_CODES.RUN_ALREADY_ACTIVE,
180
188
  details: {
181
- stale: false
182
- }
189
+ stale: false,
190
+ },
183
191
  });
184
192
  });
185
193
 
@@ -189,14 +197,14 @@ describe('DeleteCommandHandler', () => {
189
197
 
190
198
  const result = await handler.execute({
191
199
  command: 'delete',
192
- feature_id: 'feature_a'
200
+ feature_id: 'feature_a',
193
201
  });
194
202
 
195
203
  expect(result).toEqual({
196
204
  ok: true,
197
205
  data: {
198
- command: 'delete'
199
- }
206
+ command: 'delete',
207
+ },
200
208
  });
201
209
  });
202
210
  });