@jstn-sdk/rcs 0.1.0 → 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1736) hide show
  1. package/README.md +142 -102
  2. package/dist/agents/definitions.d.ts.map +1 -1
  3. package/dist/agents/definitions.js +0 -101
  4. package/dist/agents/definitions.js.map +1 -1
  5. package/dist/blueprint/runtime.d.ts +52 -0
  6. package/dist/blueprint/runtime.d.ts.map +1 -0
  7. package/dist/{ralplan → blueprint}/runtime.js +19 -19
  8. package/dist/blueprint/runtime.js.map +1 -0
  9. package/dist/catalog/reader.d.ts.map +1 -1
  10. package/dist/catalog/reader.js +8 -2
  11. package/dist/catalog/reader.js.map +1 -1
  12. package/dist/catalog/schema.js +1 -1
  13. package/dist/catalog/schema.js.map +1 -1
  14. package/dist/cli/forge.d.ts +17 -0
  15. package/dist/cli/{ralph.d.ts.map → forge.d.ts.map} +1 -1
  16. package/dist/cli/{ralph.js → forge.js} +82 -82
  17. package/dist/cli/{ralph.js.map → forge.js.map} +1 -1
  18. package/dist/cli/index.d.ts +1 -1
  19. package/dist/cli/index.js +15 -15
  20. package/dist/cli/setup.d.ts.map +1 -1
  21. package/dist/cli/setup.js +2 -3
  22. package/dist/cli/setup.js.map +1 -1
  23. package/dist/cli/star-prompt.js +2 -2
  24. package/dist/cli/star-prompt.js.map +1 -1
  25. package/dist/cli/state.js +1 -1
  26. package/dist/cli/team.d.ts.map +1 -1
  27. package/dist/cli/team.js +3 -2
  28. package/dist/cli/team.js.map +1 -1
  29. package/dist/cli/tmux-hook.d.ts.map +1 -1
  30. package/dist/cli/tmux-hook.js +9 -1
  31. package/dist/cli/tmux-hook.js.map +1 -1
  32. package/dist/config/generator.d.ts +1 -1
  33. package/dist/config/generator.d.ts.map +1 -1
  34. package/dist/config/generator.js +1 -1
  35. package/dist/config/generator.js.map +1 -1
  36. package/dist/forge/contract.d.ts +17 -0
  37. package/dist/{ralph → forge}/contract.d.ts.map +1 -1
  38. package/dist/{ralph → forge}/contract.js +16 -16
  39. package/dist/{ralph → forge}/contract.js.map +1 -1
  40. package/dist/{ralph → forge}/persistence.d.ts +5 -5
  41. package/dist/{ralph → forge}/persistence.d.ts.map +1 -1
  42. package/dist/{ralph → forge}/persistence.js +7 -6
  43. package/dist/forge/persistence.js.map +1 -0
  44. package/dist/hooks/agents-overlay.d.ts +1 -1
  45. package/dist/hooks/agents-overlay.d.ts.map +1 -1
  46. package/dist/hooks/agents-overlay.js +37 -31
  47. package/dist/hooks/agents-overlay.js.map +1 -1
  48. package/dist/hooks/extensibility/dispatcher.d.ts.map +1 -1
  49. package/dist/hooks/extensibility/dispatcher.js +82 -14
  50. package/dist/hooks/extensibility/dispatcher.js.map +1 -1
  51. package/dist/hooks/keyword-detector.d.ts +8 -8
  52. package/dist/hooks/keyword-detector.d.ts.map +1 -1
  53. package/dist/hooks/keyword-detector.js +94 -64
  54. package/dist/hooks/keyword-detector.js.map +1 -1
  55. package/dist/hooks/keyword-registry.d.ts.map +1 -1
  56. package/dist/hooks/keyword-registry.js +9 -11
  57. package/dist/hooks/keyword-registry.js.map +1 -1
  58. package/dist/hooks/prompt-guidance-contract.d.ts.map +1 -1
  59. package/dist/hooks/prompt-guidance-contract.js +10 -21
  60. package/dist/hooks/prompt-guidance-contract.js.map +1 -1
  61. package/dist/hooks/task-size-detector.js +2 -2
  62. package/dist/hooks/task-size-detector.js.map +1 -1
  63. package/dist/hooks/triage-state.d.ts +1 -1
  64. package/dist/hooks/triage-state.js +1 -1
  65. package/dist/hud/colors.d.ts +2 -2
  66. package/dist/hud/colors.js +2 -2
  67. package/dist/hud/render.js +21 -21
  68. package/dist/hud/render.js.map +1 -1
  69. package/dist/hud/state.d.ts +3 -3
  70. package/dist/hud/state.d.ts.map +1 -1
  71. package/dist/hud/state.js +18 -15
  72. package/dist/hud/state.js.map +1 -1
  73. package/dist/hud/types.d.ts +6 -6
  74. package/dist/hud/types.d.ts.map +1 -1
  75. package/dist/mcp/bootstrap.d.ts.map +1 -1
  76. package/dist/mcp/bootstrap.js +36 -2
  77. package/dist/mcp/bootstrap.js.map +1 -1
  78. package/dist/mcp/state-paths.d.ts +1 -0
  79. package/dist/mcp/state-paths.d.ts.map +1 -1
  80. package/dist/mcp/state-paths.js +4 -1
  81. package/dist/mcp/state-paths.js.map +1 -1
  82. package/dist/mcp/state-server.d.ts +4 -4
  83. package/dist/mcp/state-server.js +2 -2
  84. package/dist/mcp/state-server.js.map +1 -1
  85. package/dist/modes/base.d.ts +2 -2
  86. package/dist/modes/base.d.ts.map +1 -1
  87. package/dist/modes/base.js +29 -26
  88. package/dist/modes/base.js.map +1 -1
  89. package/dist/notifications/reply-listener.d.ts.map +1 -1
  90. package/dist/notifications/reply-listener.js +7 -1
  91. package/dist/notifications/reply-listener.js.map +1 -1
  92. package/dist/notifications/tmux.d.ts.map +1 -1
  93. package/dist/notifications/tmux.js +39 -6
  94. package/dist/notifications/tmux.js.map +1 -1
  95. package/dist/pipeline/index.d.ts +7 -6
  96. package/dist/pipeline/index.d.ts.map +1 -1
  97. package/dist/pipeline/index.js +5 -4
  98. package/dist/pipeline/index.js.map +1 -1
  99. package/dist/pipeline/orchestrator.d.ts +5 -5
  100. package/dist/pipeline/orchestrator.js +25 -25
  101. package/dist/pipeline/orchestrator.js.map +1 -1
  102. package/dist/pipeline/stages/blueprint.d.ts +25 -0
  103. package/dist/pipeline/stages/blueprint.d.ts.map +1 -0
  104. package/dist/pipeline/stages/{ralplan.js → blueprint.js} +16 -16
  105. package/dist/pipeline/stages/blueprint.js.map +1 -0
  106. package/dist/pipeline/stages/code-review.d.ts +2 -2
  107. package/dist/pipeline/stages/code-review.js +6 -6
  108. package/dist/pipeline/stages/code-review.js.map +1 -1
  109. package/dist/pipeline/stages/forge-verify.d.ts +50 -0
  110. package/dist/pipeline/stages/forge-verify.d.ts.map +1 -0
  111. package/dist/pipeline/stages/{ralph-verify.js → forge-verify.js} +21 -24
  112. package/dist/pipeline/stages/forge-verify.js.map +1 -0
  113. package/dist/pipeline/stages/team-exec.d.ts +1 -1
  114. package/dist/pipeline/stages/team-exec.js +19 -19
  115. package/dist/pipeline/stages/team-exec.js.map +1 -1
  116. package/dist/pipeline/types.d.ts +12 -12
  117. package/dist/pipeline/types.d.ts.map +1 -1
  118. package/dist/pipeline/types.js +1 -1
  119. package/dist/planning/artifacts.d.ts +3 -4
  120. package/dist/planning/artifacts.d.ts.map +1 -1
  121. package/dist/planning/artifacts.js +2 -3
  122. package/dist/planning/artifacts.js.map +1 -1
  123. package/dist/question/policy.js +1 -1
  124. package/dist/runtime/bridge.d.ts.map +1 -1
  125. package/dist/runtime/bridge.js +70 -13
  126. package/dist/runtime/bridge.js.map +1 -1
  127. package/dist/scripts/codex-native-hook.js +30 -30
  128. package/dist/scripts/codex-native-hook.js.map +1 -1
  129. package/dist/scripts/eval/eval-cross-server-party-flow.d.ts +3 -0
  130. package/dist/scripts/eval/eval-cross-server-party-flow.d.ts.map +1 -0
  131. package/dist/scripts/eval/eval-cross-server-party-flow.js +12 -0
  132. package/dist/scripts/eval/eval-cross-server-party-flow.js.map +1 -0
  133. package/dist/scripts/eval/eval-gui-onboarding-clarity.d.ts +3 -0
  134. package/dist/scripts/eval/eval-gui-onboarding-clarity.d.ts.map +1 -0
  135. package/dist/scripts/eval/eval-gui-onboarding-clarity.js +17 -0
  136. package/dist/scripts/eval/eval-gui-onboarding-clarity.js.map +1 -0
  137. package/dist/scripts/eval/eval-liveops-reward-loop-balance.d.ts +3 -0
  138. package/dist/scripts/eval/eval-liveops-reward-loop-balance.d.ts.map +1 -0
  139. package/dist/scripts/eval/eval-liveops-reward-loop-balance.js +12 -0
  140. package/dist/scripts/eval/eval-liveops-reward-loop-balance.js.map +1 -0
  141. package/dist/scripts/eval/eval-profile-datastore-recovery.d.ts +3 -0
  142. package/dist/scripts/eval/eval-profile-datastore-recovery.d.ts.map +1 -0
  143. package/dist/scripts/eval/eval-profile-datastore-recovery.js +17 -0
  144. package/dist/scripts/eval/eval-profile-datastore-recovery.js.map +1 -0
  145. package/dist/scripts/eval/eval-remote-contract-hardening.d.ts +3 -0
  146. package/dist/scripts/eval/eval-remote-contract-hardening.d.ts.map +1 -0
  147. package/dist/scripts/eval/eval-remote-contract-hardening.js +17 -0
  148. package/dist/scripts/eval/eval-remote-contract-hardening.js.map +1 -0
  149. package/dist/scripts/notify-fallback-watcher.js +140 -139
  150. package/dist/scripts/notify-fallback-watcher.js.map +1 -1
  151. package/dist/scripts/notify-hook/forge-session-resume.d.ts +23 -0
  152. package/dist/scripts/notify-hook/{ralph-session-resume.d.ts.map → forge-session-resume.d.ts.map} +1 -1
  153. package/dist/scripts/notify-hook/{ralph-session-resume.js → forge-session-resume.js} +37 -36
  154. package/dist/scripts/notify-hook/{ralph-session-resume.js.map → forge-session-resume.js.map} +1 -1
  155. package/dist/scripts/notify-hook/team-dispatch.d.ts.map +1 -1
  156. package/dist/scripts/notify-hook/team-dispatch.js +34 -4
  157. package/dist/scripts/notify-hook/team-dispatch.js.map +1 -1
  158. package/dist/scripts/notify-hook/visual-verdict.js +3 -3
  159. package/dist/scripts/notify-hook.js +9 -9
  160. package/dist/scripts/run-test-files.js +1 -1
  161. package/dist/scripts/run-test-files.js.map +1 -1
  162. package/dist/scripts/surface-taxonomy.d.ts +23 -0
  163. package/dist/scripts/surface-taxonomy.d.ts.map +1 -0
  164. package/dist/scripts/surface-taxonomy.js +271 -0
  165. package/dist/scripts/surface-taxonomy.js.map +1 -0
  166. package/dist/scripts/sync-plugin-mirror.d.ts.map +1 -1
  167. package/dist/scripts/sync-plugin-mirror.js +5 -4
  168. package/dist/scripts/sync-plugin-mirror.js.map +1 -1
  169. package/dist/scripts/tmux-hook-engine.d.ts +1 -1
  170. package/dist/scripts/tmux-hook-engine.d.ts.map +1 -1
  171. package/dist/scripts/tmux-hook-engine.js +29 -20
  172. package/dist/scripts/tmux-hook-engine.js.map +1 -1
  173. package/dist/state/operations.d.ts +1 -1
  174. package/dist/state/operations.d.ts.map +1 -1
  175. package/dist/state/operations.js +18 -18
  176. package/dist/state/operations.js.map +1 -1
  177. package/dist/state/skill-active.d.ts +13 -1
  178. package/dist/state/skill-active.d.ts.map +1 -1
  179. package/dist/state/skill-active.js +38 -17
  180. package/dist/state/skill-active.js.map +1 -1
  181. package/dist/state/workflow-transition.d.ts +6 -5
  182. package/dist/state/workflow-transition.d.ts.map +1 -1
  183. package/dist/state/workflow-transition.js +27 -15
  184. package/dist/state/workflow-transition.js.map +1 -1
  185. package/dist/team/contracts.d.ts +1 -1
  186. package/dist/team/contracts.js +2 -2
  187. package/dist/team/followup-planner.d.ts +2 -2
  188. package/dist/team/followup-planner.d.ts.map +1 -1
  189. package/dist/team/followup-planner.js +16 -14
  190. package/dist/team/followup-planner.js.map +1 -1
  191. package/dist/team/idle-nudge.d.ts.map +1 -1
  192. package/dist/team/idle-nudge.js +3 -2
  193. package/dist/team/idle-nudge.js.map +1 -1
  194. package/dist/team/leader-activity.js +1 -1
  195. package/dist/team/model-contract.d.ts.map +1 -1
  196. package/dist/team/model-contract.js +4 -1
  197. package/dist/team/model-contract.js.map +1 -1
  198. package/dist/team/orchestrator.js +4 -4
  199. package/dist/team/orchestrator.js.map +1 -1
  200. package/dist/team/role-router.js +3 -3
  201. package/dist/team/role-router.js.map +1 -1
  202. package/dist/team/state/dispatch.d.ts.map +1 -1
  203. package/dist/team/state/dispatch.js +4 -1
  204. package/dist/team/state/dispatch.js.map +1 -1
  205. package/dist/team/tmux-session.d.ts +4 -0
  206. package/dist/team/tmux-session.d.ts.map +1 -1
  207. package/dist/team/tmux-session.js +42 -9
  208. package/dist/team/tmux-session.js.map +1 -1
  209. package/dist/team/worktree.d.ts +1 -1
  210. package/dist/utils/platform-command.d.ts.map +1 -1
  211. package/dist/utils/platform-command.js +9 -0
  212. package/dist/utils/platform-command.js.map +1 -1
  213. package/dist/verification/verifier.d.ts +1 -1
  214. package/dist/verification/verifier.js +2 -2
  215. package/docs/STATE_MODEL.md +24 -24
  216. package/docs/agents.html +8 -16
  217. package/docs/archive/README.md +15 -0
  218. package/docs/{prompt-migration-changelog.md → archive/prompt-migration-changelog.md} +0 -11
  219. package/docs/{release-body-0.9.0.md → archive/release-body-0.9.0.md} +6 -24
  220. package/docs/{release-body-0.9.1.md → archive/release-body-0.9.1.md} +3 -3
  221. package/docs/codex-native-hooks.md +4 -4
  222. package/docs/contracts/forge-cancel-contract.md +20 -0
  223. package/docs/contracts/forge-state-contract.md +52 -0
  224. package/docs/contracts/multi-state-transition-contract.md +5 -5
  225. package/docs/contracts/multi-state-transition-review.md +3 -3
  226. package/docs/contracts/repo-aware-team-dag-decomposition.md +1 -1
  227. package/docs/contracts/rust-runtime-thin-adapter-contract.md +1 -1
  228. package/docs/contracts/team-startup-dispatch-latency.md +1 -1
  229. package/docs/getting-started.html +6 -1
  230. package/docs/guidance-schema.md +6 -3
  231. package/docs/index.html +55 -4
  232. package/docs/integrations.html +4 -3
  233. package/docs/issues/team-forge-followup-team.md +38 -0
  234. package/docs/openclaw-integration.md +2 -2
  235. package/docs/prompt-guidance-contract.md +11 -11
  236. package/docs/prs/{dev-deprecate-team-ralph.md → dev-deprecate-team-forge.md} +27 -27
  237. package/docs/prs/{dev-fix-ralph-live-pane-invariant.md → dev-fix-forge-live-pane-invariant.md} +7 -7
  238. package/docs/prs/{dev-team-ralph-workflow-positioning.md → dev-team-forge-workflow-positioning.md} +7 -7
  239. package/docs/qa/forge-persistence-gate.md +20 -0
  240. package/docs/qa/rust-runtime-thin-adapter-gate.md +31 -40
  241. package/docs/readme/README.de.md +13 -0
  242. package/docs/readme/README.el.md +13 -0
  243. package/docs/readme/README.es.md +13 -0
  244. package/docs/readme/README.fr.md +13 -0
  245. package/docs/readme/README.it.md +13 -0
  246. package/docs/readme/README.ja.md +13 -0
  247. package/docs/readme/README.ko.md +13 -0
  248. package/docs/readme/README.pl.md +13 -0
  249. package/docs/readme/README.pt.md +13 -0
  250. package/docs/readme/README.ru.md +13 -0
  251. package/docs/readme/README.tr.md +13 -0
  252. package/docs/readme/README.uk.md +13 -0
  253. package/docs/readme/README.vi.md +13 -0
  254. package/docs/readme/README.zh-TW.md +13 -0
  255. package/docs/readme/README.zh.md +13 -0
  256. package/docs/readme/rcs-cover.svg +75 -0
  257. package/docs/reference/canonical-vocabulary.md +106 -0
  258. package/docs/reference/forge-parity-matrix.md +26 -0
  259. package/docs/reference/forge-upstream-baseline.md +32 -0
  260. package/docs/reference/rcs-config-schema-routing.md +5 -5
  261. package/docs/reference/roblox-pre-action-protocol.md +4 -0
  262. package/docs/reference/roblox-taxonomy-migration-plan.md +46 -0
  263. package/docs/reference/roblox-workspace-standard.md +83 -0
  264. package/docs/reference/robloxstudio-mcp-compatibility.md +117 -0
  265. package/docs/reference/semantic-design-system.md +110 -0
  266. package/docs/reference/surface-map.md +131 -0
  267. package/docs/reference/team-allocation-rebalance-policy.md +1 -1
  268. package/docs/release-notes-v0.1.0.md +1 -1
  269. package/docs/release-notes-v0.1.1.md +49 -0
  270. package/docs/reports/open-prs-dev-readiness-2026-04-09.md +2 -2
  271. package/docs/shared/agent-tiers.md +3 -3
  272. package/docs/skills.html +10 -12
  273. package/docs/troubleshooting.md +1 -1
  274. package/package.json +20 -13
  275. package/plugins/roblox-ai-os-creator-skills/.codex-plugin/plugin.json +1 -1
  276. package/plugins/roblox-ai-os-creator-skills/docs/reference/roblox-pre-action-protocol.md +4 -0
  277. package/plugins/roblox-ai-os-creator-skills/skills/ai-slop-cleaner/SKILL.md +14 -7
  278. package/plugins/roblox-ai-os-creator-skills/skills/analyze/SKILL.md +9 -2
  279. package/plugins/roblox-ai-os-creator-skills/skills/ask-claude/SKILL.md +7 -0
  280. package/plugins/roblox-ai-os-creator-skills/skills/ask-gemini/SKILL.md +7 -0
  281. package/plugins/roblox-ai-os-creator-skills/skills/autoforge/SKILL.md +7 -0
  282. package/plugins/roblox-ai-os-creator-skills/skills/autopilot/SKILL.md +48 -41
  283. package/plugins/roblox-ai-os-creator-skills/skills/autoresearch/SKILL.md +8 -1
  284. package/plugins/roblox-ai-os-creator-skills/skills/blueprint/SKILL.md +227 -9
  285. package/plugins/roblox-ai-os-creator-skills/skills/blueprint-loop/SKILL.md +7 -0
  286. package/plugins/roblox-ai-os-creator-skills/skills/blueprint-psych/SKILL.md +7 -0
  287. package/plugins/roblox-ai-os-creator-skills/skills/blueprint-retention/SKILL.md +7 -0
  288. package/plugins/roblox-ai-os-creator-skills/skills/blueprint-social/SKILL.md +7 -0
  289. package/plugins/roblox-ai-os-creator-skills/skills/brief/SKILL.md +7 -0
  290. package/plugins/roblox-ai-os-creator-skills/skills/brief-audience/SKILL.md +7 -0
  291. package/plugins/roblox-ai-os-creator-skills/skills/brief-motivation/SKILL.md +7 -0
  292. package/plugins/roblox-ai-os-creator-skills/skills/cancel/SKILL.md +59 -52
  293. package/plugins/roblox-ai-os-creator-skills/skills/code-review/SKILL.md +30 -24
  294. package/plugins/roblox-ai-os-creator-skills/skills/configure-notifications/SKILL.md +7 -0
  295. package/plugins/roblox-ai-os-creator-skills/skills/crew/SKILL.md +7 -0
  296. package/plugins/roblox-ai-os-creator-skills/skills/deep-interview/SKILL.md +25 -18
  297. package/plugins/roblox-ai-os-creator-skills/skills/doctor/SKILL.md +7 -0
  298. package/plugins/roblox-ai-os-creator-skills/skills/forge/SKILL.md +174 -11
  299. package/plugins/roblox-ai-os-creator-skills/skills/forge-community/SKILL.md +7 -0
  300. package/plugins/roblox-ai-os-creator-skills/skills/forge-daily-loop/SKILL.md +7 -0
  301. package/plugins/roblox-ai-os-creator-skills/skills/forge-event-loop/SKILL.md +7 -0
  302. package/plugins/roblox-ai-os-creator-skills/skills/forge-fomo/SKILL.md +7 -0
  303. package/plugins/roblox-ai-os-creator-skills/skills/forge-mastery/SKILL.md +7 -0
  304. package/plugins/roblox-ai-os-creator-skills/skills/forge-progression/SKILL.md +7 -0
  305. package/plugins/roblox-ai-os-creator-skills/skills/forge-reward-loop/SKILL.md +7 -0
  306. package/plugins/roblox-ai-os-creator-skills/skills/forge-status/SKILL.md +7 -0
  307. package/plugins/roblox-ai-os-creator-skills/skills/help/SKILL.md +8 -1
  308. package/plugins/roblox-ai-os-creator-skills/skills/hud/SKILL.md +16 -9
  309. package/plugins/roblox-ai-os-creator-skills/skills/note/SKILL.md +8 -1
  310. package/plugins/roblox-ai-os-creator-skills/skills/pipeline/SKILL.md +18 -11
  311. package/plugins/roblox-ai-os-creator-skills/skills/plan/SKILL.md +36 -29
  312. package/plugins/roblox-ai-os-creator-skills/skills/rcs-setup/SKILL.md +8 -1
  313. package/plugins/roblox-ai-os-creator-skills/skills/security-review/SKILL.md +120 -236
  314. package/plugins/roblox-ai-os-creator-skills/skills/skill/SKILL.md +20 -13
  315. package/plugins/roblox-ai-os-creator-skills/skills/team/SKILL.md +17 -11
  316. package/plugins/roblox-ai-os-creator-skills/skills/trace/SKILL.md +7 -0
  317. package/plugins/roblox-ai-os-creator-skills/skills/ultraqa/SKILL.md +10 -3
  318. package/plugins/roblox-ai-os-creator-skills/skills/ultrawork/SKILL.md +19 -12
  319. package/plugins/roblox-ai-os-creator-skills/skills/{visual-ralph → visual-forge}/SKILL.md +36 -27
  320. package/plugins/roblox-ai-os-creator-skills/skills/visual-verdict/SKILL.md +9 -2
  321. package/plugins/roblox-ai-os-creator-skills/skills/wiki/SKILL.md +10 -3
  322. package/plugins/roblox-ai-os-creator-skills/skills/worker/SKILL.md +16 -7
  323. package/plugins/roblox-ai-os-creator-skills/templates/roblox/pre-action-plan.md +1 -0
  324. package/prompts/analyst.md +7 -0
  325. package/prompts/architect.md +11 -4
  326. package/prompts/build-fixer.md +7 -0
  327. package/prompts/code-reviewer.md +9 -2
  328. package/prompts/code-simplifier.md +4 -0
  329. package/prompts/critic.md +13 -6
  330. package/prompts/debugger.md +8 -1
  331. package/prompts/dependency-expert.md +8 -1
  332. package/prompts/designer.md +20 -10
  333. package/prompts/executor.md +7 -0
  334. package/prompts/explore-harness.md +7 -0
  335. package/prompts/explore.md +7 -0
  336. package/prompts/git-master.md +8 -1
  337. package/prompts/planner.md +10 -3
  338. package/prompts/researcher.md +7 -0
  339. package/prompts/security-reviewer.md +76 -92
  340. package/prompts/sisyphus-lite.md +7 -0
  341. package/prompts/team-executor.md +7 -0
  342. package/prompts/team-orchestrator.md +9 -2
  343. package/prompts/test-engineer.md +11 -3
  344. package/prompts/verifier.md +7 -0
  345. package/prompts/vision.md +9 -2
  346. package/prompts/writer.md +11 -4
  347. package/skills/.agents/skills/roblox-animations/SKILL.md +220 -0
  348. package/skills/.agents/skills/roblox-datastores/SKILL.md +219 -0
  349. package/skills/.agents/skills/roblox-gui/SKILL.md +192 -0
  350. package/skills/.agents/skills/roblox-monetization/SKILL.md +208 -0
  351. package/skills/.agents/skills/roblox-performance/SKILL.md +230 -0
  352. package/skills/.agents/skills/roblox-remote-events/SKILL.md +199 -0
  353. package/skills/.agents/skills/roblox-security/SKILL.md +236 -0
  354. package/skills/ai-slop-cleaner/SKILL.md +14 -7
  355. package/skills/analyze/SKILL.md +9 -2
  356. package/skills/ask-claude/SKILL.md +7 -0
  357. package/skills/ask-gemini/SKILL.md +7 -0
  358. package/skills/autoforge/SKILL.md +7 -0
  359. package/skills/autopilot/SKILL.md +48 -41
  360. package/skills/autoresearch/SKILL.md +8 -1
  361. package/skills/blueprint/SKILL.md +227 -9
  362. package/skills/blueprint-loop/SKILL.md +7 -0
  363. package/skills/blueprint-psych/SKILL.md +7 -0
  364. package/skills/blueprint-retention/SKILL.md +7 -0
  365. package/skills/blueprint-social/SKILL.md +7 -0
  366. package/skills/brief/SKILL.md +7 -0
  367. package/skills/brief-audience/SKILL.md +7 -0
  368. package/skills/brief-motivation/SKILL.md +7 -0
  369. package/skills/build-fix/SKILL.md +9 -2
  370. package/skills/cancel/SKILL.md +59 -52
  371. package/skills/code-review/SKILL.md +30 -24
  372. package/skills/configure-notifications/SKILL.md +7 -0
  373. package/skills/crew/SKILL.md +7 -0
  374. package/skills/deep-interview/SKILL.md +25 -18
  375. package/skills/deepsearch/SKILL.md +7 -0
  376. package/skills/doctor/SKILL.md +7 -0
  377. package/skills/ecomode/SKILL.md +9 -2
  378. package/skills/forge/SKILL.md +174 -11
  379. package/skills/forge-community/SKILL.md +7 -0
  380. package/skills/forge-daily-loop/SKILL.md +7 -0
  381. package/skills/forge-event-loop/SKILL.md +7 -0
  382. package/skills/forge-fomo/SKILL.md +7 -0
  383. package/skills/{ralph-init → forge-init}/SKILL.md +20 -13
  384. package/skills/forge-mastery/SKILL.md +7 -0
  385. package/skills/forge-progression/SKILL.md +7 -0
  386. package/skills/forge-reward-loop/SKILL.md +7 -0
  387. package/skills/forge-status/SKILL.md +7 -0
  388. package/skills/git-master/SKILL.md +7 -0
  389. package/skills/help/SKILL.md +8 -1
  390. package/skills/hud/SKILL.md +16 -9
  391. package/skills/note/SKILL.md +8 -1
  392. package/skills/pipeline/SKILL.md +18 -11
  393. package/skills/plan/SKILL.md +36 -29
  394. package/skills/rcs-setup/SKILL.md +8 -1
  395. package/skills/review/SKILL.md +7 -0
  396. package/skills/security-review/SKILL.md +120 -236
  397. package/skills/skill/SKILL.md +20 -13
  398. package/skills/skills-lock.json +47 -0
  399. package/skills/swarm/SKILL.md +8 -1
  400. package/skills/tdd/SKILL.md +7 -0
  401. package/skills/team/SKILL.md +17 -11
  402. package/skills/trace/SKILL.md +7 -0
  403. package/skills/ultraqa/SKILL.md +10 -3
  404. package/skills/ultrawork/SKILL.md +19 -12
  405. package/skills/{visual-ralph → visual-forge}/SKILL.md +36 -27
  406. package/skills/visual-verdict/SKILL.md +9 -2
  407. package/skills/web-clone/SKILL.md +14 -7
  408. package/skills/wiki/SKILL.md +10 -3
  409. package/skills/worker/SKILL.md +16 -7
  410. package/src/scripts/__tests__/codex-native-hook.test.ts +386 -319
  411. package/src/scripts/__tests__/run-test-files.test.ts +6 -4
  412. package/src/scripts/__tests__/verify-native-agents.test.ts +16 -16
  413. package/src/scripts/codex-native-hook.ts +34 -34
  414. package/src/scripts/eval/eval-cross-server-party-flow.ts +14 -0
  415. package/src/scripts/eval/eval-gui-onboarding-clarity.ts +20 -0
  416. package/src/scripts/eval/eval-liveops-reward-loop-balance.ts +14 -0
  417. package/src/scripts/eval/eval-profile-datastore-recovery.ts +20 -0
  418. package/src/scripts/eval/eval-remote-contract-hardening.ts +20 -0
  419. package/src/scripts/notify-fallback-watcher.ts +147 -146
  420. package/src/scripts/notify-hook/__tests__/team-worker-posttooluse.test.ts +24 -10
  421. package/src/scripts/notify-hook/{ralph-session-resume.ts → forge-session-resume.ts} +45 -43
  422. package/src/scripts/notify-hook/team-dispatch.ts +31 -4
  423. package/src/scripts/notify-hook/visual-verdict.ts +3 -3
  424. package/src/scripts/notify-hook.ts +10 -10
  425. package/src/scripts/run-test-files.ts +1 -1
  426. package/src/scripts/surface-taxonomy.ts +316 -0
  427. package/src/scripts/sync-plugin-mirror.ts +5 -4
  428. package/src/scripts/tmux-hook-engine.ts +31 -19
  429. package/templates/AGENTS.md +24 -15
  430. package/templates/catalog-manifest.json +5 -88
  431. package/templates/roblox/pre-action-plan.md +1 -0
  432. package/templates/roblox/robloxstudio-mcp.codex.json +18 -0
  433. package/templates/roblox/robloxstudio-mcp.windows.json +22 -0
  434. package/dist/adapt/__tests__/foundation.test.d.ts +0 -2
  435. package/dist/adapt/__tests__/foundation.test.d.ts.map +0 -1
  436. package/dist/adapt/__tests__/foundation.test.js +0 -171
  437. package/dist/adapt/__tests__/foundation.test.js.map +0 -1
  438. package/dist/adapt/__tests__/hermes.test.d.ts +0 -2
  439. package/dist/adapt/__tests__/hermes.test.d.ts.map +0 -1
  440. package/dist/adapt/__tests__/hermes.test.js +0 -137
  441. package/dist/adapt/__tests__/hermes.test.js.map +0 -1
  442. package/dist/agents/__tests__/definitions.test.d.ts +0 -2
  443. package/dist/agents/__tests__/definitions.test.d.ts.map +0 -1
  444. package/dist/agents/__tests__/definitions.test.js +0 -62
  445. package/dist/agents/__tests__/definitions.test.js.map +0 -1
  446. package/dist/agents/__tests__/native-config.test.d.ts +0 -2
  447. package/dist/agents/__tests__/native-config.test.d.ts.map +0 -1
  448. package/dist/agents/__tests__/native-config.test.js +0 -278
  449. package/dist/agents/__tests__/native-config.test.js.map +0 -1
  450. package/dist/autoresearch/__tests__/contracts.test.d.ts +0 -2
  451. package/dist/autoresearch/__tests__/contracts.test.d.ts.map +0 -1
  452. package/dist/autoresearch/__tests__/contracts.test.js +0 -127
  453. package/dist/autoresearch/__tests__/contracts.test.js.map +0 -1
  454. package/dist/autoresearch/__tests__/runtime-parity-extra.test.d.ts +0 -2
  455. package/dist/autoresearch/__tests__/runtime-parity-extra.test.d.ts.map +0 -1
  456. package/dist/autoresearch/__tests__/runtime-parity-extra.test.js +0 -356
  457. package/dist/autoresearch/__tests__/runtime-parity-extra.test.js.map +0 -1
  458. package/dist/autoresearch/__tests__/runtime.test.d.ts +0 -2
  459. package/dist/autoresearch/__tests__/runtime.test.d.ts.map +0 -1
  460. package/dist/autoresearch/__tests__/runtime.test.js +0 -218
  461. package/dist/autoresearch/__tests__/runtime.test.js.map +0 -1
  462. package/dist/autoresearch/__tests__/skill-validation.test.d.ts +0 -2
  463. package/dist/autoresearch/__tests__/skill-validation.test.d.ts.map +0 -1
  464. package/dist/autoresearch/__tests__/skill-validation.test.js +0 -91
  465. package/dist/autoresearch/__tests__/skill-validation.test.js.map +0 -1
  466. package/dist/catalog/__tests__/generator.test.d.ts +0 -2
  467. package/dist/catalog/__tests__/generator.test.d.ts.map +0 -1
  468. package/dist/catalog/__tests__/generator.test.js +0 -49
  469. package/dist/catalog/__tests__/generator.test.js.map +0 -1
  470. package/dist/catalog/__tests__/plugin-bundle-ssot.test.d.ts +0 -2
  471. package/dist/catalog/__tests__/plugin-bundle-ssot.test.d.ts.map +0 -1
  472. package/dist/catalog/__tests__/plugin-bundle-ssot.test.js +0 -83
  473. package/dist/catalog/__tests__/plugin-bundle-ssot.test.js.map +0 -1
  474. package/dist/catalog/__tests__/schema.test.d.ts +0 -2
  475. package/dist/catalog/__tests__/schema.test.d.ts.map +0 -1
  476. package/dist/catalog/__tests__/schema.test.js +0 -91
  477. package/dist/catalog/__tests__/schema.test.js.map +0 -1
  478. package/dist/cli/__tests__/adapt-help.test.d.ts +0 -2
  479. package/dist/cli/__tests__/adapt-help.test.d.ts.map +0 -1
  480. package/dist/cli/__tests__/adapt-help.test.js +0 -37
  481. package/dist/cli/__tests__/adapt-help.test.js.map +0 -1
  482. package/dist/cli/__tests__/adapt.test.d.ts +0 -2
  483. package/dist/cli/__tests__/adapt.test.d.ts.map +0 -1
  484. package/dist/cli/__tests__/adapt.test.js +0 -62
  485. package/dist/cli/__tests__/adapt.test.js.map +0 -1
  486. package/dist/cli/__tests__/agents-init.test.d.ts +0 -2
  487. package/dist/cli/__tests__/agents-init.test.d.ts.map +0 -1
  488. package/dist/cli/__tests__/agents-init.test.js +0 -184
  489. package/dist/cli/__tests__/agents-init.test.js.map +0 -1
  490. package/dist/cli/__tests__/agents.test.d.ts +0 -2
  491. package/dist/cli/__tests__/agents.test.d.ts.map +0 -1
  492. package/dist/cli/__tests__/agents.test.js +0 -137
  493. package/dist/cli/__tests__/agents.test.js.map +0 -1
  494. package/dist/cli/__tests__/ask.test.d.ts +0 -2
  495. package/dist/cli/__tests__/ask.test.d.ts.map +0 -1
  496. package/dist/cli/__tests__/ask.test.js +0 -265
  497. package/dist/cli/__tests__/ask.test.js.map +0 -1
  498. package/dist/cli/__tests__/autoresearch-guided.test.d.ts +0 -2
  499. package/dist/cli/__tests__/autoresearch-guided.test.d.ts.map +0 -1
  500. package/dist/cli/__tests__/autoresearch-guided.test.js +0 -365
  501. package/dist/cli/__tests__/autoresearch-guided.test.js.map +0 -1
  502. package/dist/cli/__tests__/autoresearch.test.d.ts +0 -2
  503. package/dist/cli/__tests__/autoresearch.test.d.ts.map +0 -1
  504. package/dist/cli/__tests__/autoresearch.test.js +0 -203
  505. package/dist/cli/__tests__/autoresearch.test.js.map +0 -1
  506. package/dist/cli/__tests__/catalog-contract.test.d.ts +0 -2
  507. package/dist/cli/__tests__/catalog-contract.test.d.ts.map +0 -1
  508. package/dist/cli/__tests__/catalog-contract.test.js +0 -18
  509. package/dist/cli/__tests__/catalog-contract.test.js.map +0 -1
  510. package/dist/cli/__tests__/cleanup.test.d.ts +0 -2
  511. package/dist/cli/__tests__/cleanup.test.d.ts.map +0 -1
  512. package/dist/cli/__tests__/cleanup.test.js +0 -419
  513. package/dist/cli/__tests__/cleanup.test.js.map +0 -1
  514. package/dist/cli/__tests__/codex-plugin-layout.test.d.ts +0 -2
  515. package/dist/cli/__tests__/codex-plugin-layout.test.d.ts.map +0 -1
  516. package/dist/cli/__tests__/codex-plugin-layout.test.js +0 -210
  517. package/dist/cli/__tests__/codex-plugin-layout.test.js.map +0 -1
  518. package/dist/cli/__tests__/doctor-context-window-warning.test.d.ts +0 -2
  519. package/dist/cli/__tests__/doctor-context-window-warning.test.d.ts.map +0 -1
  520. package/dist/cli/__tests__/doctor-context-window-warning.test.js +0 -122
  521. package/dist/cli/__tests__/doctor-context-window-warning.test.js.map +0 -1
  522. package/dist/cli/__tests__/doctor-invalid-config.test.d.ts +0 -2
  523. package/dist/cli/__tests__/doctor-invalid-config.test.d.ts.map +0 -1
  524. package/dist/cli/__tests__/doctor-invalid-config.test.js +0 -52
  525. package/dist/cli/__tests__/doctor-invalid-config.test.js.map +0 -1
  526. package/dist/cli/__tests__/doctor-team.test.d.ts +0 -2
  527. package/dist/cli/__tests__/doctor-team.test.d.ts.map +0 -1
  528. package/dist/cli/__tests__/doctor-team.test.js +0 -299
  529. package/dist/cli/__tests__/doctor-team.test.js.map +0 -1
  530. package/dist/cli/__tests__/doctor-warning-copy.test.d.ts +0 -2
  531. package/dist/cli/__tests__/doctor-warning-copy.test.d.ts.map +0 -1
  532. package/dist/cli/__tests__/doctor-warning-copy.test.js +0 -438
  533. package/dist/cli/__tests__/doctor-warning-copy.test.js.map +0 -1
  534. package/dist/cli/__tests__/error-handling-warnings.test.d.ts +0 -2
  535. package/dist/cli/__tests__/error-handling-warnings.test.d.ts.map +0 -1
  536. package/dist/cli/__tests__/error-handling-warnings.test.js +0 -52
  537. package/dist/cli/__tests__/error-handling-warnings.test.js.map +0 -1
  538. package/dist/cli/__tests__/exec.test.d.ts +0 -2
  539. package/dist/cli/__tests__/exec.test.d.ts.map +0 -1
  540. package/dist/cli/__tests__/exec.test.js +0 -213
  541. package/dist/cli/__tests__/exec.test.js.map +0 -1
  542. package/dist/cli/__tests__/explore-windows-diagnostics.test.d.ts +0 -2
  543. package/dist/cli/__tests__/explore-windows-diagnostics.test.d.ts.map +0 -1
  544. package/dist/cli/__tests__/explore-windows-diagnostics.test.js +0 -17
  545. package/dist/cli/__tests__/explore-windows-diagnostics.test.js.map +0 -1
  546. package/dist/cli/__tests__/explore.test.d.ts +0 -2
  547. package/dist/cli/__tests__/explore.test.d.ts.map +0 -1
  548. package/dist/cli/__tests__/explore.test.js +0 -1090
  549. package/dist/cli/__tests__/explore.test.js.map +0 -1
  550. package/dist/cli/__tests__/hooks.test.d.ts +0 -2
  551. package/dist/cli/__tests__/hooks.test.d.ts.map +0 -1
  552. package/dist/cli/__tests__/hooks.test.js +0 -55
  553. package/dist/cli/__tests__/hooks.test.js.map +0 -1
  554. package/dist/cli/__tests__/index.test.d.ts +0 -2
  555. package/dist/cli/__tests__/index.test.d.ts.map +0 -1
  556. package/dist/cli/__tests__/index.test.js +0 -2259
  557. package/dist/cli/__tests__/index.test.js.map +0 -1
  558. package/dist/cli/__tests__/launch-fallback.test.d.ts +0 -2
  559. package/dist/cli/__tests__/launch-fallback.test.d.ts.map +0 -1
  560. package/dist/cli/__tests__/launch-fallback.test.js +0 -661
  561. package/dist/cli/__tests__/launch-fallback.test.js.map +0 -1
  562. package/dist/cli/__tests__/lifecycle-notifications.test.d.ts +0 -2
  563. package/dist/cli/__tests__/lifecycle-notifications.test.d.ts.map +0 -1
  564. package/dist/cli/__tests__/lifecycle-notifications.test.js +0 -48
  565. package/dist/cli/__tests__/lifecycle-notifications.test.js.map +0 -1
  566. package/dist/cli/__tests__/list.test.d.ts +0 -2
  567. package/dist/cli/__tests__/list.test.d.ts.map +0 -1
  568. package/dist/cli/__tests__/list.test.js +0 -38
  569. package/dist/cli/__tests__/list.test.js.map +0 -1
  570. package/dist/cli/__tests__/mcp-parity.test.d.ts +0 -2
  571. package/dist/cli/__tests__/mcp-parity.test.d.ts.map +0 -1
  572. package/dist/cli/__tests__/mcp-parity.test.js +0 -228
  573. package/dist/cli/__tests__/mcp-parity.test.js.map +0 -1
  574. package/dist/cli/__tests__/mcp-serve.test.d.ts +0 -2
  575. package/dist/cli/__tests__/mcp-serve.test.d.ts.map +0 -1
  576. package/dist/cli/__tests__/mcp-serve.test.js +0 -64
  577. package/dist/cli/__tests__/mcp-serve.test.js.map +0 -1
  578. package/dist/cli/__tests__/native-assets.test.d.ts +0 -2
  579. package/dist/cli/__tests__/native-assets.test.d.ts.map +0 -1
  580. package/dist/cli/__tests__/native-assets.test.js +0 -308
  581. package/dist/cli/__tests__/native-assets.test.js.map +0 -1
  582. package/dist/cli/__tests__/native-hook-dispatch-contract.test.d.ts +0 -2
  583. package/dist/cli/__tests__/native-hook-dispatch-contract.test.d.ts.map +0 -1
  584. package/dist/cli/__tests__/native-hook-dispatch-contract.test.js +0 -11
  585. package/dist/cli/__tests__/native-hook-dispatch-contract.test.js.map +0 -1
  586. package/dist/cli/__tests__/nested-help-routing.test.d.ts +0 -2
  587. package/dist/cli/__tests__/nested-help-routing.test.d.ts.map +0 -1
  588. package/dist/cli/__tests__/nested-help-routing.test.js +0 -96
  589. package/dist/cli/__tests__/nested-help-routing.test.js.map +0 -1
  590. package/dist/cli/__tests__/package-bin-contract.test.d.ts +0 -2
  591. package/dist/cli/__tests__/package-bin-contract.test.d.ts.map +0 -1
  592. package/dist/cli/__tests__/package-bin-contract.test.js +0 -177
  593. package/dist/cli/__tests__/package-bin-contract.test.js.map +0 -1
  594. package/dist/cli/__tests__/packaged-explore-harness-lock.d.ts +0 -3
  595. package/dist/cli/__tests__/packaged-explore-harness-lock.d.ts.map +0 -1
  596. package/dist/cli/__tests__/packaged-explore-harness-lock.js +0 -67
  597. package/dist/cli/__tests__/packaged-explore-harness-lock.js.map +0 -1
  598. package/dist/cli/__tests__/packaged-script-resolution.test.d.ts +0 -2
  599. package/dist/cli/__tests__/packaged-script-resolution.test.d.ts.map +0 -1
  600. package/dist/cli/__tests__/packaged-script-resolution.test.js +0 -19
  601. package/dist/cli/__tests__/packaged-script-resolution.test.js.map +0 -1
  602. package/dist/cli/__tests__/prompt-skill-sanitization.test.d.ts +0 -2
  603. package/dist/cli/__tests__/prompt-skill-sanitization.test.d.ts.map +0 -1
  604. package/dist/cli/__tests__/prompt-skill-sanitization.test.js +0 -48
  605. package/dist/cli/__tests__/prompt-skill-sanitization.test.js.map +0 -1
  606. package/dist/cli/__tests__/question.test.d.ts +0 -2
  607. package/dist/cli/__tests__/question.test.d.ts.map +0 -1
  608. package/dist/cli/__tests__/question.test.js +0 -633
  609. package/dist/cli/__tests__/question.test.js.map +0 -1
  610. package/dist/cli/__tests__/ralph-deslop-contract.test.d.ts +0 -2
  611. package/dist/cli/__tests__/ralph-deslop-contract.test.d.ts.map +0 -1
  612. package/dist/cli/__tests__/ralph-deslop-contract.test.js +0 -28
  613. package/dist/cli/__tests__/ralph-deslop-contract.test.js.map +0 -1
  614. package/dist/cli/__tests__/ralph-prd-deep-interview.test.d.ts +0 -2
  615. package/dist/cli/__tests__/ralph-prd-deep-interview.test.d.ts.map +0 -1
  616. package/dist/cli/__tests__/ralph-prd-deep-interview.test.js +0 -24
  617. package/dist/cli/__tests__/ralph-prd-deep-interview.test.js.map +0 -1
  618. package/dist/cli/__tests__/ralph-prd-smoke.test.d.ts +0 -2
  619. package/dist/cli/__tests__/ralph-prd-smoke.test.d.ts.map +0 -1
  620. package/dist/cli/__tests__/ralph-prd-smoke.test.js +0 -167
  621. package/dist/cli/__tests__/ralph-prd-smoke.test.js.map +0 -1
  622. package/dist/cli/__tests__/ralph.test.d.ts +0 -2
  623. package/dist/cli/__tests__/ralph.test.d.ts.map +0 -1
  624. package/dist/cli/__tests__/ralph.test.js +0 -256
  625. package/dist/cli/__tests__/ralph.test.js.map +0 -1
  626. package/dist/cli/__tests__/resume.test.d.ts +0 -2
  627. package/dist/cli/__tests__/resume.test.d.ts.map +0 -1
  628. package/dist/cli/__tests__/resume.test.js +0 -84
  629. package/dist/cli/__tests__/resume.test.js.map +0 -1
  630. package/dist/cli/__tests__/session-scoped-runtime.test.d.ts +0 -2
  631. package/dist/cli/__tests__/session-scoped-runtime.test.d.ts.map +0 -1
  632. package/dist/cli/__tests__/session-scoped-runtime.test.js +0 -146
  633. package/dist/cli/__tests__/session-scoped-runtime.test.js.map +0 -1
  634. package/dist/cli/__tests__/session-search-help.test.d.ts +0 -2
  635. package/dist/cli/__tests__/session-search-help.test.d.ts.map +0 -1
  636. package/dist/cli/__tests__/session-search-help.test.js +0 -76
  637. package/dist/cli/__tests__/session-search-help.test.js.map +0 -1
  638. package/dist/cli/__tests__/session-search.test.d.ts +0 -2
  639. package/dist/cli/__tests__/session-search.test.d.ts.map +0 -1
  640. package/dist/cli/__tests__/session-search.test.js +0 -77
  641. package/dist/cli/__tests__/session-search.test.js.map +0 -1
  642. package/dist/cli/__tests__/setup-agents-overwrite.test.d.ts +0 -2
  643. package/dist/cli/__tests__/setup-agents-overwrite.test.d.ts.map +0 -1
  644. package/dist/cli/__tests__/setup-agents-overwrite.test.js +0 -457
  645. package/dist/cli/__tests__/setup-agents-overwrite.test.js.map +0 -1
  646. package/dist/cli/__tests__/setup-gh-star.test.d.ts +0 -2
  647. package/dist/cli/__tests__/setup-gh-star.test.d.ts.map +0 -1
  648. package/dist/cli/__tests__/setup-gh-star.test.js +0 -67
  649. package/dist/cli/__tests__/setup-gh-star.test.js.map +0 -1
  650. package/dist/cli/__tests__/setup-hooks-shared-ownership.test.d.ts +0 -2
  651. package/dist/cli/__tests__/setup-hooks-shared-ownership.test.d.ts.map +0 -1
  652. package/dist/cli/__tests__/setup-hooks-shared-ownership.test.js +0 -189
  653. package/dist/cli/__tests__/setup-hooks-shared-ownership.test.js.map +0 -1
  654. package/dist/cli/__tests__/setup-install-mode.test.d.ts +0 -2
  655. package/dist/cli/__tests__/setup-install-mode.test.d.ts.map +0 -1
  656. package/dist/cli/__tests__/setup-install-mode.test.js +0 -873
  657. package/dist/cli/__tests__/setup-install-mode.test.js.map +0 -1
  658. package/dist/cli/__tests__/setup-prompts-overwrite.test.d.ts +0 -2
  659. package/dist/cli/__tests__/setup-prompts-overwrite.test.d.ts.map +0 -1
  660. package/dist/cli/__tests__/setup-prompts-overwrite.test.js +0 -191
  661. package/dist/cli/__tests__/setup-prompts-overwrite.test.js.map +0 -1
  662. package/dist/cli/__tests__/setup-refresh.test.d.ts +0 -2
  663. package/dist/cli/__tests__/setup-refresh.test.d.ts.map +0 -1
  664. package/dist/cli/__tests__/setup-refresh.test.js +0 -591
  665. package/dist/cli/__tests__/setup-refresh.test.js.map +0 -1
  666. package/dist/cli/__tests__/setup-scope.test.d.ts +0 -2
  667. package/dist/cli/__tests__/setup-scope.test.d.ts.map +0 -1
  668. package/dist/cli/__tests__/setup-scope.test.js +0 -340
  669. package/dist/cli/__tests__/setup-scope.test.js.map +0 -1
  670. package/dist/cli/__tests__/setup-skill-validation.test.d.ts +0 -2
  671. package/dist/cli/__tests__/setup-skill-validation.test.d.ts.map +0 -1
  672. package/dist/cli/__tests__/setup-skill-validation.test.js +0 -44
  673. package/dist/cli/__tests__/setup-skill-validation.test.js.map +0 -1
  674. package/dist/cli/__tests__/setup-skills-overwrite.test.d.ts +0 -2
  675. package/dist/cli/__tests__/setup-skills-overwrite.test.d.ts.map +0 -1
  676. package/dist/cli/__tests__/setup-skills-overwrite.test.js +0 -295
  677. package/dist/cli/__tests__/setup-skills-overwrite.test.js.map +0 -1
  678. package/dist/cli/__tests__/sidecar.test.d.ts +0 -2
  679. package/dist/cli/__tests__/sidecar.test.d.ts.map +0 -1
  680. package/dist/cli/__tests__/sidecar.test.js +0 -24
  681. package/dist/cli/__tests__/sidecar.test.js.map +0 -1
  682. package/dist/cli/__tests__/sparkshell-cli.test.d.ts +0 -2
  683. package/dist/cli/__tests__/sparkshell-cli.test.d.ts.map +0 -1
  684. package/dist/cli/__tests__/sparkshell-cli.test.js +0 -400
  685. package/dist/cli/__tests__/sparkshell-cli.test.js.map +0 -1
  686. package/dist/cli/__tests__/sparkshell-packaging.test.d.ts +0 -2
  687. package/dist/cli/__tests__/sparkshell-packaging.test.d.ts.map +0 -1
  688. package/dist/cli/__tests__/sparkshell-packaging.test.js +0 -74
  689. package/dist/cli/__tests__/sparkshell-packaging.test.js.map +0 -1
  690. package/dist/cli/__tests__/star-prompt.test.d.ts +0 -2
  691. package/dist/cli/__tests__/star-prompt.test.d.ts.map +0 -1
  692. package/dist/cli/__tests__/star-prompt.test.js +0 -172
  693. package/dist/cli/__tests__/star-prompt.test.js.map +0 -1
  694. package/dist/cli/__tests__/state.test.d.ts +0 -2
  695. package/dist/cli/__tests__/state.test.d.ts.map +0 -1
  696. package/dist/cli/__tests__/state.test.js +0 -46
  697. package/dist/cli/__tests__/state.test.js.map +0 -1
  698. package/dist/cli/__tests__/team-decompose.test.d.ts +0 -2
  699. package/dist/cli/__tests__/team-decompose.test.d.ts.map +0 -1
  700. package/dist/cli/__tests__/team-decompose.test.js +0 -133
  701. package/dist/cli/__tests__/team-decompose.test.js.map +0 -1
  702. package/dist/cli/__tests__/team.test.d.ts +0 -2
  703. package/dist/cli/__tests__/team.test.d.ts.map +0 -1
  704. package/dist/cli/__tests__/team.test.js +0 -1820
  705. package/dist/cli/__tests__/team.test.js.map +0 -1
  706. package/dist/cli/__tests__/uninstall.test.d.ts +0 -2
  707. package/dist/cli/__tests__/uninstall.test.d.ts.map +0 -1
  708. package/dist/cli/__tests__/uninstall.test.js +0 -766
  709. package/dist/cli/__tests__/uninstall.test.js.map +0 -1
  710. package/dist/cli/__tests__/update.test.d.ts +0 -2
  711. package/dist/cli/__tests__/update.test.d.ts.map +0 -1
  712. package/dist/cli/__tests__/update.test.js +0 -589
  713. package/dist/cli/__tests__/update.test.js.map +0 -1
  714. package/dist/cli/__tests__/version-sync-contract.test.d.ts +0 -2
  715. package/dist/cli/__tests__/version-sync-contract.test.d.ts.map +0 -1
  716. package/dist/cli/__tests__/version-sync-contract.test.js +0 -41
  717. package/dist/cli/__tests__/version-sync-contract.test.js.map +0 -1
  718. package/dist/cli/__tests__/version.test.d.ts +0 -2
  719. package/dist/cli/__tests__/version.test.d.ts.map +0 -1
  720. package/dist/cli/__tests__/version.test.js +0 -21
  721. package/dist/cli/__tests__/version.test.js.map +0 -1
  722. package/dist/cli/__tests__/windows-popup-loop-contract.test.d.ts +0 -2
  723. package/dist/cli/__tests__/windows-popup-loop-contract.test.d.ts.map +0 -1
  724. package/dist/cli/__tests__/windows-popup-loop-contract.test.js +0 -31
  725. package/dist/cli/__tests__/windows-popup-loop-contract.test.js.map +0 -1
  726. package/dist/cli/ralph.d.ts +0 -17
  727. package/dist/compat/__tests__/doctor-contract.test.d.ts +0 -2
  728. package/dist/compat/__tests__/doctor-contract.test.d.ts.map +0 -1
  729. package/dist/compat/__tests__/doctor-contract.test.js +0 -108
  730. package/dist/compat/__tests__/doctor-contract.test.js.map +0 -1
  731. package/dist/compat/__tests__/rust-runtime-compat.test.d.ts +0 -2
  732. package/dist/compat/__tests__/rust-runtime-compat.test.d.ts.map +0 -1
  733. package/dist/compat/__tests__/rust-runtime-compat.test.js +0 -218
  734. package/dist/compat/__tests__/rust-runtime-compat.test.js.map +0 -1
  735. package/dist/config/__tests__/codex-hooks.test.d.ts +0 -2
  736. package/dist/config/__tests__/codex-hooks.test.d.ts.map +0 -1
  737. package/dist/config/__tests__/codex-hooks.test.js +0 -77
  738. package/dist/config/__tests__/codex-hooks.test.js.map +0 -1
  739. package/dist/config/__tests__/generator-idempotent.test.d.ts +0 -2
  740. package/dist/config/__tests__/generator-idempotent.test.d.ts.map +0 -1
  741. package/dist/config/__tests__/generator-idempotent.test.js +0 -882
  742. package/dist/config/__tests__/generator-idempotent.test.js.map +0 -1
  743. package/dist/config/__tests__/generator-notify.test.d.ts +0 -2
  744. package/dist/config/__tests__/generator-notify.test.d.ts.map +0 -1
  745. package/dist/config/__tests__/generator-notify.test.js +0 -343
  746. package/dist/config/__tests__/generator-notify.test.js.map +0 -1
  747. package/dist/config/__tests__/generator-status-line-presets.test.d.ts +0 -2
  748. package/dist/config/__tests__/generator-status-line-presets.test.d.ts.map +0 -1
  749. package/dist/config/__tests__/generator-status-line-presets.test.js +0 -203
  750. package/dist/config/__tests__/generator-status-line-presets.test.js.map +0 -1
  751. package/dist/config/__tests__/mcp-registry.test.d.ts +0 -2
  752. package/dist/config/__tests__/mcp-registry.test.d.ts.map +0 -1
  753. package/dist/config/__tests__/mcp-registry.test.js +0 -190
  754. package/dist/config/__tests__/mcp-registry.test.js.map +0 -1
  755. package/dist/config/__tests__/models.test.d.ts +0 -2
  756. package/dist/config/__tests__/models.test.d.ts.map +0 -1
  757. package/dist/config/__tests__/models.test.js +0 -224
  758. package/dist/config/__tests__/models.test.js.map +0 -1
  759. package/dist/config/__tests__/wiki-config-contract.test.d.ts +0 -2
  760. package/dist/config/__tests__/wiki-config-contract.test.d.ts.map +0 -1
  761. package/dist/config/__tests__/wiki-config-contract.test.js +0 -19
  762. package/dist/config/__tests__/wiki-config-contract.test.js.map +0 -1
  763. package/dist/document-refresh/__tests__/enforcer.test.d.ts +0 -2
  764. package/dist/document-refresh/__tests__/enforcer.test.d.ts.map +0 -1
  765. package/dist/document-refresh/__tests__/enforcer.test.js +0 -128
  766. package/dist/document-refresh/__tests__/enforcer.test.js.map +0 -1
  767. package/dist/hooks/__tests__/agents-overlay.test.d.ts +0 -8
  768. package/dist/hooks/__tests__/agents-overlay.test.d.ts.map +0 -1
  769. package/dist/hooks/__tests__/agents-overlay.test.js +0 -644
  770. package/dist/hooks/__tests__/agents-overlay.test.js.map +0 -1
  771. package/dist/hooks/__tests__/analyze-routing-contract.test.d.ts +0 -2
  772. package/dist/hooks/__tests__/analyze-routing-contract.test.d.ts.map +0 -1
  773. package/dist/hooks/__tests__/analyze-routing-contract.test.js +0 -45
  774. package/dist/hooks/__tests__/analyze-routing-contract.test.js.map +0 -1
  775. package/dist/hooks/__tests__/analyze-skill-contract.test.d.ts +0 -2
  776. package/dist/hooks/__tests__/analyze-skill-contract.test.d.ts.map +0 -1
  777. package/dist/hooks/__tests__/analyze-skill-contract.test.js +0 -48
  778. package/dist/hooks/__tests__/analyze-skill-contract.test.js.map +0 -1
  779. package/dist/hooks/__tests__/anti-slop-workflow.test.d.ts +0 -2
  780. package/dist/hooks/__tests__/anti-slop-workflow.test.d.ts.map +0 -1
  781. package/dist/hooks/__tests__/anti-slop-workflow.test.js +0 -146
  782. package/dist/hooks/__tests__/anti-slop-workflow.test.js.map +0 -1
  783. package/dist/hooks/__tests__/autopilot-skill-contract.test.d.ts +0 -2
  784. package/dist/hooks/__tests__/autopilot-skill-contract.test.d.ts.map +0 -1
  785. package/dist/hooks/__tests__/autopilot-skill-contract.test.js +0 -37
  786. package/dist/hooks/__tests__/autopilot-skill-contract.test.js.map +0 -1
  787. package/dist/hooks/__tests__/clawhip-event-contract.test.d.ts +0 -2
  788. package/dist/hooks/__tests__/clawhip-event-contract.test.d.ts.map +0 -1
  789. package/dist/hooks/__tests__/clawhip-event-contract.test.js +0 -37
  790. package/dist/hooks/__tests__/clawhip-event-contract.test.js.map +0 -1
  791. package/dist/hooks/__tests__/code-review-skill-contract.test.d.ts +0 -2
  792. package/dist/hooks/__tests__/code-review-skill-contract.test.d.ts.map +0 -1
  793. package/dist/hooks/__tests__/code-review-skill-contract.test.js +0 -56
  794. package/dist/hooks/__tests__/code-review-skill-contract.test.js.map +0 -1
  795. package/dist/hooks/__tests__/codebase-map.test.d.ts +0 -8
  796. package/dist/hooks/__tests__/codebase-map.test.d.ts.map +0 -1
  797. package/dist/hooks/__tests__/codebase-map.test.js +0 -218
  798. package/dist/hooks/__tests__/codebase-map.test.js.map +0 -1
  799. package/dist/hooks/__tests__/consensus-execution-handoff.test.d.ts +0 -18
  800. package/dist/hooks/__tests__/consensus-execution-handoff.test.d.ts.map +0 -1
  801. package/dist/hooks/__tests__/consensus-execution-handoff.test.js +0 -234
  802. package/dist/hooks/__tests__/consensus-execution-handoff.test.js.map +0 -1
  803. package/dist/hooks/__tests__/debugger-log-recency-contract.test.d.ts +0 -2
  804. package/dist/hooks/__tests__/debugger-log-recency-contract.test.d.ts.map +0 -1
  805. package/dist/hooks/__tests__/debugger-log-recency-contract.test.js +0 -20
  806. package/dist/hooks/__tests__/debugger-log-recency-contract.test.js.map +0 -1
  807. package/dist/hooks/__tests__/deep-interview-contract.test.d.ts +0 -2
  808. package/dist/hooks/__tests__/deep-interview-contract.test.d.ts.map +0 -1
  809. package/dist/hooks/__tests__/deep-interview-contract.test.js +0 -213
  810. package/dist/hooks/__tests__/deep-interview-contract.test.js.map +0 -1
  811. package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.d.ts +0 -2
  812. package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.d.ts.map +0 -1
  813. package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.js +0 -43
  814. package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.js.map +0 -1
  815. package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.d.ts +0 -2
  816. package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.d.ts.map +0 -1
  817. package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.js +0 -38
  818. package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.js.map +0 -1
  819. package/dist/hooks/__tests__/explore-routing.test.d.ts +0 -2
  820. package/dist/hooks/__tests__/explore-routing.test.d.ts.map +0 -1
  821. package/dist/hooks/__tests__/explore-routing.test.js +0 -43
  822. package/dist/hooks/__tests__/explore-routing.test.js.map +0 -1
  823. package/dist/hooks/__tests__/explore-sparkshell-guidance-contract.test.d.ts +0 -2
  824. package/dist/hooks/__tests__/explore-sparkshell-guidance-contract.test.d.ts.map +0 -1
  825. package/dist/hooks/__tests__/explore-sparkshell-guidance-contract.test.js +0 -69
  826. package/dist/hooks/__tests__/explore-sparkshell-guidance-contract.test.js.map +0 -1
  827. package/dist/hooks/__tests__/keyword-detector.test.d.ts +0 -2
  828. package/dist/hooks/__tests__/keyword-detector.test.d.ts.map +0 -1
  829. package/dist/hooks/__tests__/keyword-detector.test.js +0 -1716
  830. package/dist/hooks/__tests__/keyword-detector.test.js.map +0 -1
  831. package/dist/hooks/__tests__/notify-fallback-watcher.test.d.ts +0 -2
  832. package/dist/hooks/__tests__/notify-fallback-watcher.test.d.ts.map +0 -1
  833. package/dist/hooks/__tests__/notify-fallback-watcher.test.js +0 -3898
  834. package/dist/hooks/__tests__/notify-fallback-watcher.test.js.map +0 -1
  835. package/dist/hooks/__tests__/notify-hook-all-workers-idle.test.d.ts +0 -2
  836. package/dist/hooks/__tests__/notify-hook-all-workers-idle.test.d.ts.map +0 -1
  837. package/dist/hooks/__tests__/notify-hook-all-workers-idle.test.js +0 -786
  838. package/dist/hooks/__tests__/notify-hook-all-workers-idle.test.js.map +0 -1
  839. package/dist/hooks/__tests__/notify-hook-auto-nudge.test.d.ts +0 -2
  840. package/dist/hooks/__tests__/notify-hook-auto-nudge.test.d.ts.map +0 -1
  841. package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js +0 -2397
  842. package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js.map +0 -1
  843. package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.d.ts +0 -2
  844. package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.d.ts.map +0 -1
  845. package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.js +0 -160
  846. package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.js.map +0 -1
  847. package/dist/hooks/__tests__/notify-hook-managed-tmux.test.d.ts +0 -2
  848. package/dist/hooks/__tests__/notify-hook-managed-tmux.test.d.ts.map +0 -1
  849. package/dist/hooks/__tests__/notify-hook-managed-tmux.test.js +0 -1178
  850. package/dist/hooks/__tests__/notify-hook-managed-tmux.test.js.map +0 -1
  851. package/dist/hooks/__tests__/notify-hook-modules.test.d.ts +0 -9
  852. package/dist/hooks/__tests__/notify-hook-modules.test.d.ts.map +0 -1
  853. package/dist/hooks/__tests__/notify-hook-modules.test.js +0 -529
  854. package/dist/hooks/__tests__/notify-hook-modules.test.js.map +0 -1
  855. package/dist/hooks/__tests__/notify-hook-native-dispatch-contract.test.d.ts +0 -2
  856. package/dist/hooks/__tests__/notify-hook-native-dispatch-contract.test.d.ts.map +0 -1
  857. package/dist/hooks/__tests__/notify-hook-native-dispatch-contract.test.js +0 -14
  858. package/dist/hooks/__tests__/notify-hook-native-dispatch-contract.test.js.map +0 -1
  859. package/dist/hooks/__tests__/notify-hook-ralph-resume.test.d.ts +0 -2
  860. package/dist/hooks/__tests__/notify-hook-ralph-resume.test.d.ts.map +0 -1
  861. package/dist/hooks/__tests__/notify-hook-ralph-resume.test.js +0 -682
  862. package/dist/hooks/__tests__/notify-hook-ralph-resume.test.js.map +0 -1
  863. package/dist/hooks/__tests__/notify-hook-regression-205.test.d.ts +0 -9
  864. package/dist/hooks/__tests__/notify-hook-regression-205.test.d.ts.map +0 -1
  865. package/dist/hooks/__tests__/notify-hook-regression-205.test.js +0 -255
  866. package/dist/hooks/__tests__/notify-hook-regression-205.test.js.map +0 -1
  867. package/dist/hooks/__tests__/notify-hook-session-idle-dedupe.test.d.ts +0 -2
  868. package/dist/hooks/__tests__/notify-hook-session-idle-dedupe.test.d.ts.map +0 -1
  869. package/dist/hooks/__tests__/notify-hook-session-idle-dedupe.test.js +0 -162
  870. package/dist/hooks/__tests__/notify-hook-session-idle-dedupe.test.js.map +0 -1
  871. package/dist/hooks/__tests__/notify-hook-session-scope.test.d.ts +0 -2
  872. package/dist/hooks/__tests__/notify-hook-session-scope.test.d.ts.map +0 -1
  873. package/dist/hooks/__tests__/notify-hook-session-scope.test.js +0 -301
  874. package/dist/hooks/__tests__/notify-hook-session-scope.test.js.map +0 -1
  875. package/dist/hooks/__tests__/notify-hook-team-dispatch.test.d.ts +0 -2
  876. package/dist/hooks/__tests__/notify-hook-team-dispatch.test.d.ts.map +0 -1
  877. package/dist/hooks/__tests__/notify-hook-team-dispatch.test.js +0 -1510
  878. package/dist/hooks/__tests__/notify-hook-team-dispatch.test.js.map +0 -1
  879. package/dist/hooks/__tests__/notify-hook-team-leader-nudge.test.d.ts +0 -2
  880. package/dist/hooks/__tests__/notify-hook-team-leader-nudge.test.d.ts.map +0 -1
  881. package/dist/hooks/__tests__/notify-hook-team-leader-nudge.test.js +0 -2879
  882. package/dist/hooks/__tests__/notify-hook-team-leader-nudge.test.js.map +0 -1
  883. package/dist/hooks/__tests__/notify-hook-team-tmux-guard.test.d.ts +0 -2
  884. package/dist/hooks/__tests__/notify-hook-team-tmux-guard.test.d.ts.map +0 -1
  885. package/dist/hooks/__tests__/notify-hook-team-tmux-guard.test.js +0 -228
  886. package/dist/hooks/__tests__/notify-hook-team-tmux-guard.test.js.map +0 -1
  887. package/dist/hooks/__tests__/notify-hook-team-worker-fail-closed.test.d.ts +0 -2
  888. package/dist/hooks/__tests__/notify-hook-team-worker-fail-closed.test.d.ts.map +0 -1
  889. package/dist/hooks/__tests__/notify-hook-team-worker-fail-closed.test.js +0 -35
  890. package/dist/hooks/__tests__/notify-hook-team-worker-fail-closed.test.js.map +0 -1
  891. package/dist/hooks/__tests__/notify-hook-tmux-heal.test.d.ts +0 -2
  892. package/dist/hooks/__tests__/notify-hook-tmux-heal.test.d.ts.map +0 -1
  893. package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js +0 -1589
  894. package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js.map +0 -1
  895. package/dist/hooks/__tests__/notify-hook-tmux-scrollback.test.d.ts +0 -10
  896. package/dist/hooks/__tests__/notify-hook-tmux-scrollback.test.d.ts.map +0 -1
  897. package/dist/hooks/__tests__/notify-hook-tmux-scrollback.test.js +0 -0
  898. package/dist/hooks/__tests__/notify-hook-tmux-scrollback.test.js.map +0 -1
  899. package/dist/hooks/__tests__/notify-hook-visual-verdict.test.d.ts +0 -11
  900. package/dist/hooks/__tests__/notify-hook-visual-verdict.test.d.ts.map +0 -1
  901. package/dist/hooks/__tests__/notify-hook-visual-verdict.test.js +0 -266
  902. package/dist/hooks/__tests__/notify-hook-visual-verdict.test.js.map +0 -1
  903. package/dist/hooks/__tests__/notify-hook-worker-idle.test.d.ts +0 -2
  904. package/dist/hooks/__tests__/notify-hook-worker-idle.test.d.ts.map +0 -1
  905. package/dist/hooks/__tests__/notify-hook-worker-idle.test.js +0 -895
  906. package/dist/hooks/__tests__/notify-hook-worker-idle.test.js.map +0 -1
  907. package/dist/hooks/__tests__/openclaw-setup-contract.test.d.ts +0 -2
  908. package/dist/hooks/__tests__/openclaw-setup-contract.test.d.ts.map +0 -1
  909. package/dist/hooks/__tests__/openclaw-setup-contract.test.js +0 -61
  910. package/dist/hooks/__tests__/openclaw-setup-contract.test.js.map +0 -1
  911. package/dist/hooks/__tests__/pre-context-gate-skills.test.d.ts +0 -2
  912. package/dist/hooks/__tests__/pre-context-gate-skills.test.d.ts.map +0 -1
  913. package/dist/hooks/__tests__/pre-context-gate-skills.test.js +0 -40
  914. package/dist/hooks/__tests__/pre-context-gate-skills.test.js.map +0 -1
  915. package/dist/hooks/__tests__/prompt-guidance-catalog.test.d.ts +0 -2
  916. package/dist/hooks/__tests__/prompt-guidance-catalog.test.d.ts.map +0 -1
  917. package/dist/hooks/__tests__/prompt-guidance-catalog.test.js +0 -11
  918. package/dist/hooks/__tests__/prompt-guidance-catalog.test.js.map +0 -1
  919. package/dist/hooks/__tests__/prompt-guidance-contract.test.d.ts +0 -2
  920. package/dist/hooks/__tests__/prompt-guidance-contract.test.d.ts.map +0 -1
  921. package/dist/hooks/__tests__/prompt-guidance-contract.test.js +0 -38
  922. package/dist/hooks/__tests__/prompt-guidance-contract.test.js.map +0 -1
  923. package/dist/hooks/__tests__/prompt-guidance-fragments.test.d.ts +0 -2
  924. package/dist/hooks/__tests__/prompt-guidance-fragments.test.d.ts.map +0 -1
  925. package/dist/hooks/__tests__/prompt-guidance-fragments.test.js +0 -48
  926. package/dist/hooks/__tests__/prompt-guidance-fragments.test.js.map +0 -1
  927. package/dist/hooks/__tests__/prompt-guidance-scenarios.test.d.ts +0 -2
  928. package/dist/hooks/__tests__/prompt-guidance-scenarios.test.d.ts.map +0 -1
  929. package/dist/hooks/__tests__/prompt-guidance-scenarios.test.js +0 -11
  930. package/dist/hooks/__tests__/prompt-guidance-scenarios.test.js.map +0 -1
  931. package/dist/hooks/__tests__/prompt-guidance-test-helpers.d.ts +0 -5
  932. package/dist/hooks/__tests__/prompt-guidance-test-helpers.d.ts.map +0 -1
  933. package/dist/hooks/__tests__/prompt-guidance-test-helpers.js +0 -34
  934. package/dist/hooks/__tests__/prompt-guidance-test-helpers.js.map +0 -1
  935. package/dist/hooks/__tests__/prompt-guidance-wave-two.test.d.ts +0 -2
  936. package/dist/hooks/__tests__/prompt-guidance-wave-two.test.d.ts.map +0 -1
  937. package/dist/hooks/__tests__/prompt-guidance-wave-two.test.js +0 -65
  938. package/dist/hooks/__tests__/prompt-guidance-wave-two.test.js.map +0 -1
  939. package/dist/hooks/__tests__/prompt-orchestration-boundary.test.d.ts +0 -2
  940. package/dist/hooks/__tests__/prompt-orchestration-boundary.test.d.ts.map +0 -1
  941. package/dist/hooks/__tests__/prompt-orchestration-boundary.test.js +0 -38
  942. package/dist/hooks/__tests__/prompt-orchestration-boundary.test.js.map +0 -1
  943. package/dist/hooks/__tests__/prompt-refactor-contract.test.d.ts +0 -2
  944. package/dist/hooks/__tests__/prompt-refactor-contract.test.d.ts.map +0 -1
  945. package/dist/hooks/__tests__/prompt-refactor-contract.test.js +0 -22
  946. package/dist/hooks/__tests__/prompt-refactor-contract.test.js.map +0 -1
  947. package/dist/hooks/__tests__/prompt-team-routing.test.d.ts +0 -2
  948. package/dist/hooks/__tests__/prompt-team-routing.test.d.ts.map +0 -1
  949. package/dist/hooks/__tests__/prompt-team-routing.test.js +0 -49
  950. package/dist/hooks/__tests__/prompt-team-routing.test.js.map +0 -1
  951. package/dist/hooks/__tests__/session.test.d.ts +0 -2
  952. package/dist/hooks/__tests__/session.test.d.ts.map +0 -1
  953. package/dist/hooks/__tests__/session.test.js +0 -322
  954. package/dist/hooks/__tests__/session.test.js.map +0 -1
  955. package/dist/hooks/__tests__/skill-guidance-contract.test.d.ts +0 -2
  956. package/dist/hooks/__tests__/skill-guidance-contract.test.d.ts.map +0 -1
  957. package/dist/hooks/__tests__/skill-guidance-contract.test.js +0 -29
  958. package/dist/hooks/__tests__/skill-guidance-contract.test.js.map +0 -1
  959. package/dist/hooks/__tests__/task-size-detector.test.d.ts +0 -2
  960. package/dist/hooks/__tests__/task-size-detector.test.d.ts.map +0 -1
  961. package/dist/hooks/__tests__/task-size-detector.test.js +0 -330
  962. package/dist/hooks/__tests__/task-size-detector.test.js.map +0 -1
  963. package/dist/hooks/__tests__/team-runtime-gating-docs-contract.test.d.ts +0 -2
  964. package/dist/hooks/__tests__/team-runtime-gating-docs-contract.test.d.ts.map +0 -1
  965. package/dist/hooks/__tests__/team-runtime-gating-docs-contract.test.js +0 -28
  966. package/dist/hooks/__tests__/team-runtime-gating-docs-contract.test.js.map +0 -1
  967. package/dist/hooks/__tests__/tmux-hook-engine-types-sync.test.d.ts +0 -2
  968. package/dist/hooks/__tests__/tmux-hook-engine-types-sync.test.d.ts.map +0 -1
  969. package/dist/hooks/__tests__/tmux-hook-engine-types-sync.test.js +0 -24
  970. package/dist/hooks/__tests__/tmux-hook-engine-types-sync.test.js.map +0 -1
  971. package/dist/hooks/__tests__/tmux-hook-engine.test.d.ts +0 -2
  972. package/dist/hooks/__tests__/tmux-hook-engine.test.d.ts.map +0 -1
  973. package/dist/hooks/__tests__/tmux-hook-engine.test.js +0 -403
  974. package/dist/hooks/__tests__/tmux-hook-engine.test.js.map +0 -1
  975. package/dist/hooks/__tests__/triage-config.test.d.ts +0 -2
  976. package/dist/hooks/__tests__/triage-config.test.d.ts.map +0 -1
  977. package/dist/hooks/__tests__/triage-config.test.js +0 -211
  978. package/dist/hooks/__tests__/triage-config.test.js.map +0 -1
  979. package/dist/hooks/__tests__/triage-heuristic.test.d.ts +0 -2
  980. package/dist/hooks/__tests__/triage-heuristic.test.d.ts.map +0 -1
  981. package/dist/hooks/__tests__/triage-heuristic.test.js +0 -285
  982. package/dist/hooks/__tests__/triage-heuristic.test.js.map +0 -1
  983. package/dist/hooks/__tests__/triage-state.test.d.ts +0 -2
  984. package/dist/hooks/__tests__/triage-state.test.d.ts.map +0 -1
  985. package/dist/hooks/__tests__/triage-state.test.js +0 -426
  986. package/dist/hooks/__tests__/triage-state.test.js.map +0 -1
  987. package/dist/hooks/__tests__/visual-ralph-skill.test.d.ts +0 -2
  988. package/dist/hooks/__tests__/visual-ralph-skill.test.d.ts.map +0 -1
  989. package/dist/hooks/__tests__/visual-ralph-skill.test.js +0 -44
  990. package/dist/hooks/__tests__/visual-ralph-skill.test.js.map +0 -1
  991. package/dist/hooks/__tests__/visual-verdict-loop.test.d.ts +0 -2
  992. package/dist/hooks/__tests__/visual-verdict-loop.test.d.ts.map +0 -1
  993. package/dist/hooks/__tests__/visual-verdict-loop.test.js +0 -35
  994. package/dist/hooks/__tests__/visual-verdict-loop.test.js.map +0 -1
  995. package/dist/hooks/__tests__/wiki-docs-contract.test.d.ts +0 -2
  996. package/dist/hooks/__tests__/wiki-docs-contract.test.d.ts.map +0 -1
  997. package/dist/hooks/__tests__/wiki-docs-contract.test.js +0 -34
  998. package/dist/hooks/__tests__/wiki-docs-contract.test.js.map +0 -1
  999. package/dist/hooks/code-simplifier/__tests__/index.test.d.ts +0 -2
  1000. package/dist/hooks/code-simplifier/__tests__/index.test.d.ts.map +0 -1
  1001. package/dist/hooks/code-simplifier/__tests__/index.test.js +0 -187
  1002. package/dist/hooks/code-simplifier/__tests__/index.test.js.map +0 -1
  1003. package/dist/hooks/extensibility/__tests__/dispatcher.test.d.ts +0 -2
  1004. package/dist/hooks/extensibility/__tests__/dispatcher.test.d.ts.map +0 -1
  1005. package/dist/hooks/extensibility/__tests__/dispatcher.test.js +0 -242
  1006. package/dist/hooks/extensibility/__tests__/dispatcher.test.js.map +0 -1
  1007. package/dist/hooks/extensibility/__tests__/events.test.d.ts +0 -2
  1008. package/dist/hooks/extensibility/__tests__/events.test.d.ts.map +0 -1
  1009. package/dist/hooks/extensibility/__tests__/events.test.js +0 -125
  1010. package/dist/hooks/extensibility/__tests__/events.test.js.map +0 -1
  1011. package/dist/hooks/extensibility/__tests__/example-hook-plugins.test.d.ts +0 -2
  1012. package/dist/hooks/extensibility/__tests__/example-hook-plugins.test.d.ts.map +0 -1
  1013. package/dist/hooks/extensibility/__tests__/example-hook-plugins.test.js +0 -153
  1014. package/dist/hooks/extensibility/__tests__/example-hook-plugins.test.js.map +0 -1
  1015. package/dist/hooks/extensibility/__tests__/loader.test.d.ts +0 -2
  1016. package/dist/hooks/extensibility/__tests__/loader.test.d.ts.map +0 -1
  1017. package/dist/hooks/extensibility/__tests__/loader.test.js +0 -254
  1018. package/dist/hooks/extensibility/__tests__/loader.test.js.map +0 -1
  1019. package/dist/hooks/extensibility/__tests__/logging.test.d.ts +0 -2
  1020. package/dist/hooks/extensibility/__tests__/logging.test.d.ts.map +0 -1
  1021. package/dist/hooks/extensibility/__tests__/logging.test.js +0 -74
  1022. package/dist/hooks/extensibility/__tests__/logging.test.js.map +0 -1
  1023. package/dist/hooks/extensibility/__tests__/plugin-runner.test.d.ts +0 -2
  1024. package/dist/hooks/extensibility/__tests__/plugin-runner.test.d.ts.map +0 -1
  1025. package/dist/hooks/extensibility/__tests__/plugin-runner.test.js +0 -202
  1026. package/dist/hooks/extensibility/__tests__/plugin-runner.test.js.map +0 -1
  1027. package/dist/hooks/extensibility/__tests__/runtime.test.d.ts +0 -2
  1028. package/dist/hooks/extensibility/__tests__/runtime.test.d.ts.map +0 -1
  1029. package/dist/hooks/extensibility/__tests__/runtime.test.js +0 -198
  1030. package/dist/hooks/extensibility/__tests__/runtime.test.js.map +0 -1
  1031. package/dist/hooks/extensibility/__tests__/sdk-public-surface.test.d.ts +0 -2
  1032. package/dist/hooks/extensibility/__tests__/sdk-public-surface.test.d.ts.map +0 -1
  1033. package/dist/hooks/extensibility/__tests__/sdk-public-surface.test.js +0 -32
  1034. package/dist/hooks/extensibility/__tests__/sdk-public-surface.test.js.map +0 -1
  1035. package/dist/hooks/extensibility/__tests__/sdk.test.d.ts +0 -2
  1036. package/dist/hooks/extensibility/__tests__/sdk.test.d.ts.map +0 -1
  1037. package/dist/hooks/extensibility/__tests__/sdk.test.js +0 -479
  1038. package/dist/hooks/extensibility/__tests__/sdk.test.js.map +0 -1
  1039. package/dist/hud/__tests__/authority.test.d.ts +0 -2
  1040. package/dist/hud/__tests__/authority.test.d.ts.map +0 -1
  1041. package/dist/hud/__tests__/authority.test.js +0 -56
  1042. package/dist/hud/__tests__/authority.test.js.map +0 -1
  1043. package/dist/hud/__tests__/colors.test.d.ts +0 -2
  1044. package/dist/hud/__tests__/colors.test.d.ts.map +0 -1
  1045. package/dist/hud/__tests__/colors.test.js +0 -92
  1046. package/dist/hud/__tests__/colors.test.js.map +0 -1
  1047. package/dist/hud/__tests__/hud-tmux-injection.test.d.ts +0 -10
  1048. package/dist/hud/__tests__/hud-tmux-injection.test.d.ts.map +0 -1
  1049. package/dist/hud/__tests__/hud-tmux-injection.test.js +0 -150
  1050. package/dist/hud/__tests__/hud-tmux-injection.test.js.map +0 -1
  1051. package/dist/hud/__tests__/index.test.d.ts +0 -2
  1052. package/dist/hud/__tests__/index.test.d.ts.map +0 -1
  1053. package/dist/hud/__tests__/index.test.js +0 -180
  1054. package/dist/hud/__tests__/index.test.js.map +0 -1
  1055. package/dist/hud/__tests__/reconcile.test.d.ts +0 -2
  1056. package/dist/hud/__tests__/reconcile.test.d.ts.map +0 -1
  1057. package/dist/hud/__tests__/reconcile.test.js +0 -125
  1058. package/dist/hud/__tests__/reconcile.test.js.map +0 -1
  1059. package/dist/hud/__tests__/render.test.d.ts +0 -2
  1060. package/dist/hud/__tests__/render.test.d.ts.map +0 -1
  1061. package/dist/hud/__tests__/render.test.js +0 -573
  1062. package/dist/hud/__tests__/render.test.js.map +0 -1
  1063. package/dist/hud/__tests__/state.test.d.ts +0 -2
  1064. package/dist/hud/__tests__/state.test.d.ts.map +0 -1
  1065. package/dist/hud/__tests__/state.test.js +0 -618
  1066. package/dist/hud/__tests__/state.test.js.map +0 -1
  1067. package/dist/hud/__tests__/types.test.d.ts +0 -2
  1068. package/dist/hud/__tests__/types.test.d.ts.map +0 -1
  1069. package/dist/hud/__tests__/types.test.js +0 -79
  1070. package/dist/hud/__tests__/types.test.js.map +0 -1
  1071. package/dist/hud/__tests__/watch.test.d.ts +0 -2
  1072. package/dist/hud/__tests__/watch.test.d.ts.map +0 -1
  1073. package/dist/hud/__tests__/watch.test.js +0 -63
  1074. package/dist/hud/__tests__/watch.test.js.map +0 -1
  1075. package/dist/mcp/__tests__/bootstrap.test.d.ts +0 -2
  1076. package/dist/mcp/__tests__/bootstrap.test.d.ts.map +0 -1
  1077. package/dist/mcp/__tests__/bootstrap.test.js +0 -207
  1078. package/dist/mcp/__tests__/bootstrap.test.js.map +0 -1
  1079. package/dist/mcp/__tests__/code-intel-server.test.d.ts +0 -2
  1080. package/dist/mcp/__tests__/code-intel-server.test.d.ts.map +0 -1
  1081. package/dist/mcp/__tests__/code-intel-server.test.js +0 -70
  1082. package/dist/mcp/__tests__/code-intel-server.test.js.map +0 -1
  1083. package/dist/mcp/__tests__/memory-server.test.d.ts +0 -2
  1084. package/dist/mcp/__tests__/memory-server.test.d.ts.map +0 -1
  1085. package/dist/mcp/__tests__/memory-server.test.js +0 -36
  1086. package/dist/mcp/__tests__/memory-server.test.js.map +0 -1
  1087. package/dist/mcp/__tests__/memory-validation.test.d.ts +0 -2
  1088. package/dist/mcp/__tests__/memory-validation.test.d.ts.map +0 -1
  1089. package/dist/mcp/__tests__/memory-validation.test.js +0 -29
  1090. package/dist/mcp/__tests__/memory-validation.test.js.map +0 -1
  1091. package/dist/mcp/__tests__/path-traversal.test.d.ts +0 -2
  1092. package/dist/mcp/__tests__/path-traversal.test.d.ts.map +0 -1
  1093. package/dist/mcp/__tests__/path-traversal.test.js +0 -83
  1094. package/dist/mcp/__tests__/path-traversal.test.js.map +0 -1
  1095. package/dist/mcp/__tests__/server-lifecycle.test.d.ts +0 -2
  1096. package/dist/mcp/__tests__/server-lifecycle.test.d.ts.map +0 -1
  1097. package/dist/mcp/__tests__/server-lifecycle.test.js +0 -260
  1098. package/dist/mcp/__tests__/server-lifecycle.test.js.map +0 -1
  1099. package/dist/mcp/__tests__/state-paths.test.d.ts +0 -2
  1100. package/dist/mcp/__tests__/state-paths.test.d.ts.map +0 -1
  1101. package/dist/mcp/__tests__/state-paths.test.js +0 -209
  1102. package/dist/mcp/__tests__/state-paths.test.js.map +0 -1
  1103. package/dist/mcp/__tests__/state-server-ralph-phase.test.d.ts +0 -2
  1104. package/dist/mcp/__tests__/state-server-ralph-phase.test.d.ts.map +0 -1
  1105. package/dist/mcp/__tests__/state-server-ralph-phase.test.js +0 -109
  1106. package/dist/mcp/__tests__/state-server-ralph-phase.test.js.map +0 -1
  1107. package/dist/mcp/__tests__/state-server-schema.test.d.ts +0 -2
  1108. package/dist/mcp/__tests__/state-server-schema.test.d.ts.map +0 -1
  1109. package/dist/mcp/__tests__/state-server-schema.test.js +0 -29
  1110. package/dist/mcp/__tests__/state-server-schema.test.js.map +0 -1
  1111. package/dist/mcp/__tests__/state-server-team-tools.test.d.ts +0 -2
  1112. package/dist/mcp/__tests__/state-server-team-tools.test.d.ts.map +0 -1
  1113. package/dist/mcp/__tests__/state-server-team-tools.test.js +0 -35
  1114. package/dist/mcp/__tests__/state-server-team-tools.test.js.map +0 -1
  1115. package/dist/mcp/__tests__/state-server.test.d.ts +0 -2
  1116. package/dist/mcp/__tests__/state-server.test.d.ts.map +0 -1
  1117. package/dist/mcp/__tests__/state-server.test.js +0 -965
  1118. package/dist/mcp/__tests__/state-server.test.js.map +0 -1
  1119. package/dist/mcp/__tests__/trace-server.test.d.ts +0 -2
  1120. package/dist/mcp/__tests__/trace-server.test.d.ts.map +0 -1
  1121. package/dist/mcp/__tests__/trace-server.test.js +0 -119
  1122. package/dist/mcp/__tests__/trace-server.test.js.map +0 -1
  1123. package/dist/mcp/__tests__/wiki-server.test.d.ts +0 -2
  1124. package/dist/mcp/__tests__/wiki-server.test.d.ts.map +0 -1
  1125. package/dist/mcp/__tests__/wiki-server.test.js +0 -30
  1126. package/dist/mcp/__tests__/wiki-server.test.js.map +0 -1
  1127. package/dist/modes/__tests__/base-autoresearch-contract.test.d.ts +0 -2
  1128. package/dist/modes/__tests__/base-autoresearch-contract.test.d.ts.map +0 -1
  1129. package/dist/modes/__tests__/base-autoresearch-contract.test.js +0 -123
  1130. package/dist/modes/__tests__/base-autoresearch-contract.test.js.map +0 -1
  1131. package/dist/modes/__tests__/base-multi-state-compat.test.d.ts +0 -2
  1132. package/dist/modes/__tests__/base-multi-state-compat.test.d.ts.map +0 -1
  1133. package/dist/modes/__tests__/base-multi-state-compat.test.js +0 -38
  1134. package/dist/modes/__tests__/base-multi-state-compat.test.js.map +0 -1
  1135. package/dist/modes/__tests__/base-ralph-contract.test.d.ts +0 -2
  1136. package/dist/modes/__tests__/base-ralph-contract.test.d.ts.map +0 -1
  1137. package/dist/modes/__tests__/base-ralph-contract.test.js +0 -64
  1138. package/dist/modes/__tests__/base-ralph-contract.test.js.map +0 -1
  1139. package/dist/modes/__tests__/base-session-scope.test.d.ts +0 -2
  1140. package/dist/modes/__tests__/base-session-scope.test.d.ts.map +0 -1
  1141. package/dist/modes/__tests__/base-session-scope.test.js +0 -98
  1142. package/dist/modes/__tests__/base-session-scope.test.js.map +0 -1
  1143. package/dist/modes/__tests__/base-tmux-pane.test.d.ts +0 -2
  1144. package/dist/modes/__tests__/base-tmux-pane.test.d.ts.map +0 -1
  1145. package/dist/modes/__tests__/base-tmux-pane.test.js +0 -39
  1146. package/dist/modes/__tests__/base-tmux-pane.test.js.map +0 -1
  1147. package/dist/notifications/__tests__/config.test.d.ts +0 -2
  1148. package/dist/notifications/__tests__/config.test.d.ts.map +0 -1
  1149. package/dist/notifications/__tests__/config.test.js +0 -269
  1150. package/dist/notifications/__tests__/config.test.js.map +0 -1
  1151. package/dist/notifications/__tests__/custom-alias-enablement.test.d.ts +0 -2
  1152. package/dist/notifications/__tests__/custom-alias-enablement.test.d.ts.map +0 -1
  1153. package/dist/notifications/__tests__/custom-alias-enablement.test.js +0 -84
  1154. package/dist/notifications/__tests__/custom-alias-enablement.test.js.map +0 -1
  1155. package/dist/notifications/__tests__/dispatch-cooldown.test.d.ts +0 -5
  1156. package/dist/notifications/__tests__/dispatch-cooldown.test.d.ts.map +0 -1
  1157. package/dist/notifications/__tests__/dispatch-cooldown.test.js +0 -100
  1158. package/dist/notifications/__tests__/dispatch-cooldown.test.js.map +0 -1
  1159. package/dist/notifications/__tests__/dispatcher.test.d.ts +0 -2
  1160. package/dist/notifications/__tests__/dispatcher.test.d.ts.map +0 -1
  1161. package/dist/notifications/__tests__/dispatcher.test.js +0 -202
  1162. package/dist/notifications/__tests__/dispatcher.test.js.map +0 -1
  1163. package/dist/notifications/__tests__/formatter.test.d.ts +0 -2
  1164. package/dist/notifications/__tests__/formatter.test.d.ts.map +0 -1
  1165. package/dist/notifications/__tests__/formatter.test.js +0 -270
  1166. package/dist/notifications/__tests__/formatter.test.js.map +0 -1
  1167. package/dist/notifications/__tests__/hook-config.test.d.ts +0 -5
  1168. package/dist/notifications/__tests__/hook-config.test.d.ts.map +0 -1
  1169. package/dist/notifications/__tests__/hook-config.test.js +0 -139
  1170. package/dist/notifications/__tests__/hook-config.test.js.map +0 -1
  1171. package/dist/notifications/__tests__/idle-cooldown.test.d.ts +0 -5
  1172. package/dist/notifications/__tests__/idle-cooldown.test.d.ts.map +0 -1
  1173. package/dist/notifications/__tests__/idle-cooldown.test.js +0 -209
  1174. package/dist/notifications/__tests__/idle-cooldown.test.js.map +0 -1
  1175. package/dist/notifications/__tests__/index.test.d.ts +0 -2
  1176. package/dist/notifications/__tests__/index.test.d.ts.map +0 -1
  1177. package/dist/notifications/__tests__/index.test.js +0 -188
  1178. package/dist/notifications/__tests__/index.test.js.map +0 -1
  1179. package/dist/notifications/__tests__/lifecycle-dedupe.test.d.ts +0 -2
  1180. package/dist/notifications/__tests__/lifecycle-dedupe.test.d.ts.map +0 -1
  1181. package/dist/notifications/__tests__/lifecycle-dedupe.test.js +0 -86
  1182. package/dist/notifications/__tests__/lifecycle-dedupe.test.js.map +0 -1
  1183. package/dist/notifications/__tests__/notifier.test.d.ts +0 -2
  1184. package/dist/notifications/__tests__/notifier.test.d.ts.map +0 -1
  1185. package/dist/notifications/__tests__/notifier.test.js +0 -239
  1186. package/dist/notifications/__tests__/notifier.test.js.map +0 -1
  1187. package/dist/notifications/__tests__/profiles.test.d.ts +0 -2
  1188. package/dist/notifications/__tests__/profiles.test.d.ts.map +0 -1
  1189. package/dist/notifications/__tests__/profiles.test.js +0 -404
  1190. package/dist/notifications/__tests__/profiles.test.js.map +0 -1
  1191. package/dist/notifications/__tests__/reply-config.test.d.ts +0 -2
  1192. package/dist/notifications/__tests__/reply-config.test.d.ts.map +0 -1
  1193. package/dist/notifications/__tests__/reply-config.test.js +0 -79
  1194. package/dist/notifications/__tests__/reply-config.test.js.map +0 -1
  1195. package/dist/notifications/__tests__/reply-listener.test.d.ts +0 -2
  1196. package/dist/notifications/__tests__/reply-listener.test.d.ts.map +0 -1
  1197. package/dist/notifications/__tests__/reply-listener.test.js +0 -723
  1198. package/dist/notifications/__tests__/reply-listener.test.js.map +0 -1
  1199. package/dist/notifications/__tests__/session-idle-tail-dedupe.test.d.ts +0 -2
  1200. package/dist/notifications/__tests__/session-idle-tail-dedupe.test.d.ts.map +0 -1
  1201. package/dist/notifications/__tests__/session-idle-tail-dedupe.test.js +0 -93
  1202. package/dist/notifications/__tests__/session-idle-tail-dedupe.test.js.map +0 -1
  1203. package/dist/notifications/__tests__/session-registry.test.d.ts +0 -2
  1204. package/dist/notifications/__tests__/session-registry.test.d.ts.map +0 -1
  1205. package/dist/notifications/__tests__/session-registry.test.js +0 -234
  1206. package/dist/notifications/__tests__/session-registry.test.js.map +0 -1
  1207. package/dist/notifications/__tests__/session-status.test.d.ts +0 -2
  1208. package/dist/notifications/__tests__/session-status.test.d.ts.map +0 -1
  1209. package/dist/notifications/__tests__/session-status.test.js +0 -249
  1210. package/dist/notifications/__tests__/session-status.test.js.map +0 -1
  1211. package/dist/notifications/__tests__/temp-mode.test.d.ts +0 -2
  1212. package/dist/notifications/__tests__/temp-mode.test.d.ts.map +0 -1
  1213. package/dist/notifications/__tests__/temp-mode.test.js +0 -172
  1214. package/dist/notifications/__tests__/temp-mode.test.js.map +0 -1
  1215. package/dist/notifications/__tests__/template-engine.test.d.ts +0 -5
  1216. package/dist/notifications/__tests__/template-engine.test.d.ts.map +0 -1
  1217. package/dist/notifications/__tests__/template-engine.test.js +0 -158
  1218. package/dist/notifications/__tests__/template-engine.test.js.map +0 -1
  1219. package/dist/notifications/__tests__/tmux-detector.test.d.ts +0 -2
  1220. package/dist/notifications/__tests__/tmux-detector.test.d.ts.map +0 -1
  1221. package/dist/notifications/__tests__/tmux-detector.test.js +0 -208
  1222. package/dist/notifications/__tests__/tmux-detector.test.js.map +0 -1
  1223. package/dist/notifications/__tests__/tmux.test.d.ts +0 -2
  1224. package/dist/notifications/__tests__/tmux.test.d.ts.map +0 -1
  1225. package/dist/notifications/__tests__/tmux.test.js +0 -285
  1226. package/dist/notifications/__tests__/tmux.test.js.map +0 -1
  1227. package/dist/notifications/__tests__/verbosity.test.d.ts +0 -2
  1228. package/dist/notifications/__tests__/verbosity.test.d.ts.map +0 -1
  1229. package/dist/notifications/__tests__/verbosity.test.js +0 -237
  1230. package/dist/notifications/__tests__/verbosity.test.js.map +0 -1
  1231. package/dist/openclaw/__tests__/config.test.d.ts +0 -6
  1232. package/dist/openclaw/__tests__/config.test.d.ts.map +0 -1
  1233. package/dist/openclaw/__tests__/config.test.js +0 -344
  1234. package/dist/openclaw/__tests__/config.test.js.map +0 -1
  1235. package/dist/openclaw/__tests__/dispatcher.test.d.ts +0 -5
  1236. package/dist/openclaw/__tests__/dispatcher.test.d.ts.map +0 -1
  1237. package/dist/openclaw/__tests__/dispatcher.test.js +0 -169
  1238. package/dist/openclaw/__tests__/dispatcher.test.js.map +0 -1
  1239. package/dist/openclaw/__tests__/index.test.d.ts +0 -6
  1240. package/dist/openclaw/__tests__/index.test.d.ts.map +0 -1
  1241. package/dist/openclaw/__tests__/index.test.js +0 -382
  1242. package/dist/openclaw/__tests__/index.test.js.map +0 -1
  1243. package/dist/pipeline/__tests__/orchestrator.test.d.ts +0 -2
  1244. package/dist/pipeline/__tests__/orchestrator.test.d.ts.map +0 -1
  1245. package/dist/pipeline/__tests__/orchestrator.test.js +0 -505
  1246. package/dist/pipeline/__tests__/orchestrator.test.js.map +0 -1
  1247. package/dist/pipeline/__tests__/stages.test.d.ts +0 -2
  1248. package/dist/pipeline/__tests__/stages.test.d.ts.map +0 -1
  1249. package/dist/pipeline/__tests__/stages.test.js +0 -754
  1250. package/dist/pipeline/__tests__/stages.test.js.map +0 -1
  1251. package/dist/pipeline/stages/ralph-verify.d.ts +0 -53
  1252. package/dist/pipeline/stages/ralph-verify.d.ts.map +0 -1
  1253. package/dist/pipeline/stages/ralph-verify.js.map +0 -1
  1254. package/dist/pipeline/stages/ralplan.d.ts +0 -25
  1255. package/dist/pipeline/stages/ralplan.d.ts.map +0 -1
  1256. package/dist/pipeline/stages/ralplan.js.map +0 -1
  1257. package/dist/planning/__tests__/artifacts.test.d.ts +0 -2
  1258. package/dist/planning/__tests__/artifacts.test.d.ts.map +0 -1
  1259. package/dist/planning/__tests__/artifacts.test.js +0 -544
  1260. package/dist/planning/__tests__/artifacts.test.js.map +0 -1
  1261. package/dist/question/__tests__/client.test.d.ts +0 -2
  1262. package/dist/question/__tests__/client.test.d.ts.map +0 -1
  1263. package/dist/question/__tests__/client.test.js +0 -90
  1264. package/dist/question/__tests__/client.test.js.map +0 -1
  1265. package/dist/question/__tests__/deep-interview.test.d.ts +0 -2
  1266. package/dist/question/__tests__/deep-interview.test.d.ts.map +0 -1
  1267. package/dist/question/__tests__/deep-interview.test.js +0 -209
  1268. package/dist/question/__tests__/deep-interview.test.js.map +0 -1
  1269. package/dist/question/__tests__/policy.test.d.ts +0 -2
  1270. package/dist/question/__tests__/policy.test.d.ts.map +0 -1
  1271. package/dist/question/__tests__/policy.test.js +0 -107
  1272. package/dist/question/__tests__/policy.test.js.map +0 -1
  1273. package/dist/question/__tests__/renderer.test.d.ts +0 -2
  1274. package/dist/question/__tests__/renderer.test.d.ts.map +0 -1
  1275. package/dist/question/__tests__/renderer.test.js +0 -707
  1276. package/dist/question/__tests__/renderer.test.js.map +0 -1
  1277. package/dist/question/__tests__/state.test.d.ts +0 -2
  1278. package/dist/question/__tests__/state.test.d.ts.map +0 -1
  1279. package/dist/question/__tests__/state.test.js +0 -102
  1280. package/dist/question/__tests__/state.test.js.map +0 -1
  1281. package/dist/question/__tests__/types.test.d.ts +0 -2
  1282. package/dist/question/__tests__/types.test.d.ts.map +0 -1
  1283. package/dist/question/__tests__/types.test.js +0 -65
  1284. package/dist/question/__tests__/types.test.js.map +0 -1
  1285. package/dist/question/__tests__/ui.test.d.ts +0 -2
  1286. package/dist/question/__tests__/ui.test.d.ts.map +0 -1
  1287. package/dist/question/__tests__/ui.test.js +0 -446
  1288. package/dist/question/__tests__/ui.test.js.map +0 -1
  1289. package/dist/ralph/__tests__/persistence.test.d.ts +0 -2
  1290. package/dist/ralph/__tests__/persistence.test.d.ts.map +0 -1
  1291. package/dist/ralph/__tests__/persistence.test.js +0 -116
  1292. package/dist/ralph/__tests__/persistence.test.js.map +0 -1
  1293. package/dist/ralph/contract.d.ts +0 -17
  1294. package/dist/ralph/persistence.js.map +0 -1
  1295. package/dist/ralplan/__tests__/runtime.test.d.ts +0 -2
  1296. package/dist/ralplan/__tests__/runtime.test.d.ts.map +0 -1
  1297. package/dist/ralplan/__tests__/runtime.test.js +0 -165
  1298. package/dist/ralplan/__tests__/runtime.test.js.map +0 -1
  1299. package/dist/ralplan/runtime.d.ts +0 -52
  1300. package/dist/ralplan/runtime.d.ts.map +0 -1
  1301. package/dist/ralplan/runtime.js.map +0 -1
  1302. package/dist/runtime/__tests__/bridge.test.d.ts +0 -2
  1303. package/dist/runtime/__tests__/bridge.test.d.ts.map +0 -1
  1304. package/dist/runtime/__tests__/bridge.test.js +0 -194
  1305. package/dist/runtime/__tests__/bridge.test.js.map +0 -1
  1306. package/dist/runtime/__tests__/run-loop.test.d.ts +0 -2
  1307. package/dist/runtime/__tests__/run-loop.test.d.ts.map +0 -1
  1308. package/dist/runtime/__tests__/run-loop.test.js +0 -35
  1309. package/dist/runtime/__tests__/run-loop.test.js.map +0 -1
  1310. package/dist/runtime/__tests__/run-outcome.test.d.ts +0 -2
  1311. package/dist/runtime/__tests__/run-outcome.test.d.ts.map +0 -1
  1312. package/dist/runtime/__tests__/run-outcome.test.js +0 -102
  1313. package/dist/runtime/__tests__/run-outcome.test.js.map +0 -1
  1314. package/dist/runtime/__tests__/run-state.test.d.ts +0 -2
  1315. package/dist/runtime/__tests__/run-state.test.d.ts.map +0 -1
  1316. package/dist/runtime/__tests__/run-state.test.js +0 -37
  1317. package/dist/runtime/__tests__/run-state.test.js.map +0 -1
  1318. package/dist/scripts/__tests__/codex-native-hook.test.d.ts +0 -2
  1319. package/dist/scripts/__tests__/codex-native-hook.test.d.ts.map +0 -1
  1320. package/dist/scripts/__tests__/codex-native-hook.test.js +0 -6788
  1321. package/dist/scripts/__tests__/codex-native-hook.test.js.map +0 -1
  1322. package/dist/scripts/__tests__/generate-release-body.test.d.ts +0 -2
  1323. package/dist/scripts/__tests__/generate-release-body.test.d.ts.map +0 -1
  1324. package/dist/scripts/__tests__/generate-release-body.test.js +0 -233
  1325. package/dist/scripts/__tests__/generate-release-body.test.js.map +0 -1
  1326. package/dist/scripts/__tests__/hook-derived-watcher.test.d.ts +0 -2
  1327. package/dist/scripts/__tests__/hook-derived-watcher.test.d.ts.map +0 -1
  1328. package/dist/scripts/__tests__/hook-derived-watcher.test.js +0 -195
  1329. package/dist/scripts/__tests__/hook-derived-watcher.test.js.map +0 -1
  1330. package/dist/scripts/__tests__/postinstall.test.d.ts +0 -2
  1331. package/dist/scripts/__tests__/postinstall.test.d.ts.map +0 -1
  1332. package/dist/scripts/__tests__/postinstall.test.js +0 -92
  1333. package/dist/scripts/__tests__/postinstall.test.js.map +0 -1
  1334. package/dist/scripts/__tests__/prompt-inventory.test.d.ts +0 -2
  1335. package/dist/scripts/__tests__/prompt-inventory.test.d.ts.map +0 -1
  1336. package/dist/scripts/__tests__/prompt-inventory.test.js +0 -56
  1337. package/dist/scripts/__tests__/prompt-inventory.test.js.map +0 -1
  1338. package/dist/scripts/__tests__/run-test-files.test.d.ts +0 -2
  1339. package/dist/scripts/__tests__/run-test-files.test.d.ts.map +0 -1
  1340. package/dist/scripts/__tests__/run-test-files.test.js +0 -62
  1341. package/dist/scripts/__tests__/run-test-files.test.js.map +0 -1
  1342. package/dist/scripts/__tests__/smoke-packed-install.test.d.ts +0 -2
  1343. package/dist/scripts/__tests__/smoke-packed-install.test.d.ts.map +0 -1
  1344. package/dist/scripts/__tests__/smoke-packed-install.test.js +0 -135
  1345. package/dist/scripts/__tests__/smoke-packed-install.test.js.map +0 -1
  1346. package/dist/scripts/__tests__/test-reply-listener-live.test.d.ts +0 -2
  1347. package/dist/scripts/__tests__/test-reply-listener-live.test.d.ts.map +0 -1
  1348. package/dist/scripts/__tests__/test-reply-listener-live.test.js +0 -82
  1349. package/dist/scripts/__tests__/test-reply-listener-live.test.js.map +0 -1
  1350. package/dist/scripts/__tests__/verify-native-agents.test.d.ts +0 -2
  1351. package/dist/scripts/__tests__/verify-native-agents.test.d.ts.map +0 -1
  1352. package/dist/scripts/__tests__/verify-native-agents.test.js +0 -166
  1353. package/dist/scripts/__tests__/verify-native-agents.test.js.map +0 -1
  1354. package/dist/scripts/eval/eval-candidate-handoff.d.ts +0 -2
  1355. package/dist/scripts/eval/eval-candidate-handoff.d.ts.map +0 -1
  1356. package/dist/scripts/eval/eval-candidate-handoff.js +0 -11
  1357. package/dist/scripts/eval/eval-candidate-handoff.js.map +0 -1
  1358. package/dist/scripts/eval/eval-cli-discoverability.d.ts +0 -3
  1359. package/dist/scripts/eval/eval-cli-discoverability.d.ts.map +0 -1
  1360. package/dist/scripts/eval/eval-cli-discoverability.js +0 -37
  1361. package/dist/scripts/eval/eval-cli-discoverability.js.map +0 -1
  1362. package/dist/scripts/eval/eval-fresh-run-tagging.d.ts +0 -2
  1363. package/dist/scripts/eval/eval-fresh-run-tagging.d.ts.map +0 -1
  1364. package/dist/scripts/eval/eval-fresh-run-tagging.js +0 -11
  1365. package/dist/scripts/eval/eval-fresh-run-tagging.js.map +0 -1
  1366. package/dist/scripts/eval/eval-help-consistency.d.ts +0 -2
  1367. package/dist/scripts/eval/eval-help-consistency.d.ts.map +0 -1
  1368. package/dist/scripts/eval/eval-help-consistency.js +0 -12
  1369. package/dist/scripts/eval/eval-help-consistency.js.map +0 -1
  1370. package/dist/scripts/eval/eval-in-action-cat-shellout-demo.d.ts +0 -2
  1371. package/dist/scripts/eval/eval-in-action-cat-shellout-demo.d.ts.map +0 -1
  1372. package/dist/scripts/eval/eval-in-action-cat-shellout-demo.js +0 -31
  1373. package/dist/scripts/eval/eval-in-action-cat-shellout-demo.js.map +0 -1
  1374. package/dist/scripts/eval/eval-parity-smoke.d.ts +0 -2
  1375. package/dist/scripts/eval/eval-parity-smoke.d.ts.map +0 -1
  1376. package/dist/scripts/eval/eval-parity-smoke.js +0 -23
  1377. package/dist/scripts/eval/eval-parity-smoke.js.map +0 -1
  1378. package/dist/scripts/eval/eval-parity-sweep.d.ts +0 -2
  1379. package/dist/scripts/eval/eval-parity-sweep.d.ts.map +0 -1
  1380. package/dist/scripts/eval/eval-parity-sweep.js +0 -29
  1381. package/dist/scripts/eval/eval-parity-sweep.js.map +0 -1
  1382. package/dist/scripts/eval/eval-resume-dirty-guard.d.ts +0 -2
  1383. package/dist/scripts/eval/eval-resume-dirty-guard.d.ts.map +0 -1
  1384. package/dist/scripts/eval/eval-resume-dirty-guard.js +0 -11
  1385. package/dist/scripts/eval/eval-resume-dirty-guard.js.map +0 -1
  1386. package/dist/scripts/eval/eval-security-path-traversal.d.ts +0 -3
  1387. package/dist/scripts/eval/eval-security-path-traversal.d.ts.map +0 -1
  1388. package/dist/scripts/eval/eval-security-path-traversal.js +0 -35
  1389. package/dist/scripts/eval/eval-security-path-traversal.js.map +0 -1
  1390. package/dist/scripts/notify-hook/__tests__/operational-events.test.d.ts +0 -2
  1391. package/dist/scripts/notify-hook/__tests__/operational-events.test.d.ts.map +0 -1
  1392. package/dist/scripts/notify-hook/__tests__/operational-events.test.js +0 -24
  1393. package/dist/scripts/notify-hook/__tests__/operational-events.test.js.map +0 -1
  1394. package/dist/scripts/notify-hook/__tests__/team-worker-posttooluse.test.d.ts +0 -2
  1395. package/dist/scripts/notify-hook/__tests__/team-worker-posttooluse.test.d.ts.map +0 -1
  1396. package/dist/scripts/notify-hook/__tests__/team-worker-posttooluse.test.js +0 -153
  1397. package/dist/scripts/notify-hook/__tests__/team-worker-posttooluse.test.js.map +0 -1
  1398. package/dist/scripts/notify-hook/ralph-session-resume.d.ts +0 -22
  1399. package/dist/session-history/__tests__/search.test.d.ts +0 -2
  1400. package/dist/session-history/__tests__/search.test.d.ts.map +0 -1
  1401. package/dist/session-history/__tests__/search.test.js +0 -150
  1402. package/dist/session-history/__tests__/search.test.js.map +0 -1
  1403. package/dist/sidecar/__tests__/boundary.test.d.ts +0 -2
  1404. package/dist/sidecar/__tests__/boundary.test.d.ts.map +0 -1
  1405. package/dist/sidecar/__tests__/boundary.test.js +0 -48
  1406. package/dist/sidecar/__tests__/boundary.test.js.map +0 -1
  1407. package/dist/sidecar/__tests__/collector.test.d.ts +0 -2
  1408. package/dist/sidecar/__tests__/collector.test.d.ts.map +0 -1
  1409. package/dist/sidecar/__tests__/collector.test.js +0 -162
  1410. package/dist/sidecar/__tests__/collector.test.js.map +0 -1
  1411. package/dist/sidecar/__tests__/render.test.d.ts +0 -2
  1412. package/dist/sidecar/__tests__/render.test.d.ts.map +0 -1
  1413. package/dist/sidecar/__tests__/render.test.js +0 -67
  1414. package/dist/sidecar/__tests__/render.test.js.map +0 -1
  1415. package/dist/sidecar/__tests__/tmux.test.d.ts +0 -2
  1416. package/dist/sidecar/__tests__/tmux.test.d.ts.map +0 -1
  1417. package/dist/sidecar/__tests__/tmux.test.js +0 -30
  1418. package/dist/sidecar/__tests__/tmux.test.js.map +0 -1
  1419. package/dist/sidecar/__tests__/watch.test.d.ts +0 -2
  1420. package/dist/sidecar/__tests__/watch.test.d.ts.map +0 -1
  1421. package/dist/sidecar/__tests__/watch.test.js +0 -42
  1422. package/dist/sidecar/__tests__/watch.test.js.map +0 -1
  1423. package/dist/state/__tests__/mode-state-context.test.d.ts +0 -2
  1424. package/dist/state/__tests__/mode-state-context.test.d.ts.map +0 -1
  1425. package/dist/state/__tests__/mode-state-context.test.js +0 -35
  1426. package/dist/state/__tests__/mode-state-context.test.js.map +0 -1
  1427. package/dist/state/__tests__/operations-ralph-phase.test.d.ts +0 -2
  1428. package/dist/state/__tests__/operations-ralph-phase.test.d.ts.map +0 -1
  1429. package/dist/state/__tests__/operations-ralph-phase.test.js +0 -103
  1430. package/dist/state/__tests__/operations-ralph-phase.test.js.map +0 -1
  1431. package/dist/state/__tests__/operations.test.d.ts +0 -2
  1432. package/dist/state/__tests__/operations.test.d.ts.map +0 -1
  1433. package/dist/state/__tests__/operations.test.js +0 -439
  1434. package/dist/state/__tests__/operations.test.js.map +0 -1
  1435. package/dist/state/__tests__/path-traversal.test.d.ts +0 -2
  1436. package/dist/state/__tests__/path-traversal.test.d.ts.map +0 -1
  1437. package/dist/state/__tests__/path-traversal.test.js +0 -49
  1438. package/dist/state/__tests__/path-traversal.test.js.map +0 -1
  1439. package/dist/state/__tests__/skill-active.test.d.ts +0 -2
  1440. package/dist/state/__tests__/skill-active.test.d.ts.map +0 -1
  1441. package/dist/state/__tests__/skill-active.test.js +0 -160
  1442. package/dist/state/__tests__/skill-active.test.js.map +0 -1
  1443. package/dist/state/__tests__/workflow-transition.test.d.ts +0 -2
  1444. package/dist/state/__tests__/workflow-transition.test.d.ts.map +0 -1
  1445. package/dist/state/__tests__/workflow-transition.test.js +0 -77
  1446. package/dist/state/__tests__/workflow-transition.test.js.map +0 -1
  1447. package/dist/subagents/__tests__/tracker.test.d.ts +0 -2
  1448. package/dist/subagents/__tests__/tracker.test.d.ts.map +0 -1
  1449. package/dist/subagents/__tests__/tracker.test.js +0 -47
  1450. package/dist/subagents/__tests__/tracker.test.js.map +0 -1
  1451. package/dist/team/__tests__/allocation-policy.test.d.ts +0 -2
  1452. package/dist/team/__tests__/allocation-policy.test.d.ts.map +0 -1
  1453. package/dist/team/__tests__/allocation-policy.test.js +0 -111
  1454. package/dist/team/__tests__/allocation-policy.test.js.map +0 -1
  1455. package/dist/team/__tests__/api-interop.test.d.ts +0 -2
  1456. package/dist/team/__tests__/api-interop.test.d.ts.map +0 -1
  1457. package/dist/team/__tests__/api-interop.test.js +0 -2262
  1458. package/dist/team/__tests__/api-interop.test.js.map +0 -1
  1459. package/dist/team/__tests__/commit-hygiene.test.d.ts +0 -2
  1460. package/dist/team/__tests__/commit-hygiene.test.d.ts.map +0 -1
  1461. package/dist/team/__tests__/commit-hygiene.test.js +0 -93
  1462. package/dist/team/__tests__/commit-hygiene.test.js.map +0 -1
  1463. package/dist/team/__tests__/cross-rebase-smoke.test.d.ts +0 -2
  1464. package/dist/team/__tests__/cross-rebase-smoke.test.d.ts.map +0 -1
  1465. package/dist/team/__tests__/cross-rebase-smoke.test.js +0 -161
  1466. package/dist/team/__tests__/cross-rebase-smoke.test.js.map +0 -1
  1467. package/dist/team/__tests__/current-task-baseline.test.d.ts +0 -2
  1468. package/dist/team/__tests__/current-task-baseline.test.d.ts.map +0 -1
  1469. package/dist/team/__tests__/current-task-baseline.test.js +0 -87
  1470. package/dist/team/__tests__/current-task-baseline.test.js.map +0 -1
  1471. package/dist/team/__tests__/delegation-policy.test.d.ts +0 -2
  1472. package/dist/team/__tests__/delegation-policy.test.d.ts.map +0 -1
  1473. package/dist/team/__tests__/delegation-policy.test.js +0 -69
  1474. package/dist/team/__tests__/delegation-policy.test.js.map +0 -1
  1475. package/dist/team/__tests__/delivery-e2e-smoke.test.d.ts +0 -2
  1476. package/dist/team/__tests__/delivery-e2e-smoke.test.d.ts.map +0 -1
  1477. package/dist/team/__tests__/delivery-e2e-smoke.test.js +0 -679
  1478. package/dist/team/__tests__/delivery-e2e-smoke.test.js.map +0 -1
  1479. package/dist/team/__tests__/events.test.d.ts +0 -2
  1480. package/dist/team/__tests__/events.test.d.ts.map +0 -1
  1481. package/dist/team/__tests__/events.test.js +0 -313
  1482. package/dist/team/__tests__/events.test.js.map +0 -1
  1483. package/dist/team/__tests__/followup-planner.test.d.ts +0 -2
  1484. package/dist/team/__tests__/followup-planner.test.d.ts.map +0 -1
  1485. package/dist/team/__tests__/followup-planner.test.js +0 -84
  1486. package/dist/team/__tests__/followup-planner.test.js.map +0 -1
  1487. package/dist/team/__tests__/hardening-e2e.test.d.ts +0 -2
  1488. package/dist/team/__tests__/hardening-e2e.test.d.ts.map +0 -1
  1489. package/dist/team/__tests__/hardening-e2e.test.js +0 -98
  1490. package/dist/team/__tests__/hardening-e2e.test.js.map +0 -1
  1491. package/dist/team/__tests__/hook-primary-e2e-contract.test.d.ts +0 -2
  1492. package/dist/team/__tests__/hook-primary-e2e-contract.test.d.ts.map +0 -1
  1493. package/dist/team/__tests__/hook-primary-e2e-contract.test.js +0 -78
  1494. package/dist/team/__tests__/hook-primary-e2e-contract.test.js.map +0 -1
  1495. package/dist/team/__tests__/idle-nudge.test.d.ts +0 -2
  1496. package/dist/team/__tests__/idle-nudge.test.d.ts.map +0 -1
  1497. package/dist/team/__tests__/idle-nudge.test.js +0 -230
  1498. package/dist/team/__tests__/idle-nudge.test.js.map +0 -1
  1499. package/dist/team/__tests__/leader-activity.test.d.ts +0 -2
  1500. package/dist/team/__tests__/leader-activity.test.d.ts.map +0 -1
  1501. package/dist/team/__tests__/leader-activity.test.js +0 -261
  1502. package/dist/team/__tests__/leader-activity.test.js.map +0 -1
  1503. package/dist/team/__tests__/mcp-comm.test.d.ts +0 -2
  1504. package/dist/team/__tests__/mcp-comm.test.d.ts.map +0 -1
  1505. package/dist/team/__tests__/mcp-comm.test.js +0 -289
  1506. package/dist/team/__tests__/mcp-comm.test.js.map +0 -1
  1507. package/dist/team/__tests__/model-contract.test.d.ts +0 -2
  1508. package/dist/team/__tests__/model-contract.test.d.ts.map +0 -1
  1509. package/dist/team/__tests__/model-contract.test.js +0 -171
  1510. package/dist/team/__tests__/model-contract.test.js.map +0 -1
  1511. package/dist/team/__tests__/orchestrator.test.d.ts +0 -2
  1512. package/dist/team/__tests__/orchestrator.test.d.ts.map +0 -1
  1513. package/dist/team/__tests__/orchestrator.test.js +0 -111
  1514. package/dist/team/__tests__/orchestrator.test.js.map +0 -1
  1515. package/dist/team/__tests__/phase-controller.test.d.ts +0 -2
  1516. package/dist/team/__tests__/phase-controller.test.d.ts.map +0 -1
  1517. package/dist/team/__tests__/phase-controller.test.js +0 -50
  1518. package/dist/team/__tests__/phase-controller.test.js.map +0 -1
  1519. package/dist/team/__tests__/rebalance-policy.test.d.ts +0 -2
  1520. package/dist/team/__tests__/rebalance-policy.test.d.ts.map +0 -1
  1521. package/dist/team/__tests__/rebalance-policy.test.js +0 -168
  1522. package/dist/team/__tests__/rebalance-policy.test.js.map +0 -1
  1523. package/dist/team/__tests__/repo-aware-decomposition.test.d.ts +0 -2
  1524. package/dist/team/__tests__/repo-aware-decomposition.test.d.ts.map +0 -1
  1525. package/dist/team/__tests__/repo-aware-decomposition.test.js +0 -136
  1526. package/dist/team/__tests__/repo-aware-decomposition.test.js.map +0 -1
  1527. package/dist/team/__tests__/role-router.test.d.ts +0 -2
  1528. package/dist/team/__tests__/role-router.test.d.ts.map +0 -1
  1529. package/dist/team/__tests__/role-router.test.js +0 -263
  1530. package/dist/team/__tests__/role-router.test.js.map +0 -1
  1531. package/dist/team/__tests__/runtime-cli.test.d.ts +0 -2
  1532. package/dist/team/__tests__/runtime-cli.test.d.ts.map +0 -1
  1533. package/dist/team/__tests__/runtime-cli.test.js +0 -304
  1534. package/dist/team/__tests__/runtime-cli.test.js.map +0 -1
  1535. package/dist/team/__tests__/runtime.test.d.ts +0 -2
  1536. package/dist/team/__tests__/runtime.test.d.ts.map +0 -1
  1537. package/dist/team/__tests__/runtime.test.js +0 -5734
  1538. package/dist/team/__tests__/runtime.test.js.map +0 -1
  1539. package/dist/team/__tests__/scaling.test.d.ts +0 -2
  1540. package/dist/team/__tests__/scaling.test.d.ts.map +0 -1
  1541. package/dist/team/__tests__/scaling.test.js +0 -1005
  1542. package/dist/team/__tests__/scaling.test.js.map +0 -1
  1543. package/dist/team/__tests__/shutdown-fallback.test.d.ts +0 -2
  1544. package/dist/team/__tests__/shutdown-fallback.test.d.ts.map +0 -1
  1545. package/dist/team/__tests__/shutdown-fallback.test.js +0 -125
  1546. package/dist/team/__tests__/shutdown-fallback.test.js.map +0 -1
  1547. package/dist/team/__tests__/state-root.test.d.ts +0 -2
  1548. package/dist/team/__tests__/state-root.test.d.ts.map +0 -1
  1549. package/dist/team/__tests__/state-root.test.js +0 -195
  1550. package/dist/team/__tests__/state-root.test.js.map +0 -1
  1551. package/dist/team/__tests__/state.test.d.ts +0 -2
  1552. package/dist/team/__tests__/state.test.d.ts.map +0 -1
  1553. package/dist/team/__tests__/state.test.js +0 -1859
  1554. package/dist/team/__tests__/state.test.js.map +0 -1
  1555. package/dist/team/__tests__/team-identity.test.d.ts +0 -2
  1556. package/dist/team/__tests__/team-identity.test.d.ts.map +0 -1
  1557. package/dist/team/__tests__/team-identity.test.js +0 -166
  1558. package/dist/team/__tests__/team-identity.test.js.map +0 -1
  1559. package/dist/team/__tests__/team-ops-contract.test.d.ts +0 -2
  1560. package/dist/team/__tests__/team-ops-contract.test.d.ts.map +0 -1
  1561. package/dist/team/__tests__/team-ops-contract.test.js +0 -96
  1562. package/dist/team/__tests__/team-ops-contract.test.js.map +0 -1
  1563. package/dist/team/__tests__/tmux-claude-workers-demo.test.d.ts +0 -2
  1564. package/dist/team/__tests__/tmux-claude-workers-demo.test.d.ts.map +0 -1
  1565. package/dist/team/__tests__/tmux-claude-workers-demo.test.js +0 -191
  1566. package/dist/team/__tests__/tmux-claude-workers-demo.test.js.map +0 -1
  1567. package/dist/team/__tests__/tmux-session.test.d.ts +0 -2
  1568. package/dist/team/__tests__/tmux-session.test.d.ts.map +0 -1
  1569. package/dist/team/__tests__/tmux-session.test.js +0 -3785
  1570. package/dist/team/__tests__/tmux-session.test.js.map +0 -1
  1571. package/dist/team/__tests__/tmux-test-fixture.d.ts +0 -20
  1572. package/dist/team/__tests__/tmux-test-fixture.d.ts.map +0 -1
  1573. package/dist/team/__tests__/tmux-test-fixture.js +0 -152
  1574. package/dist/team/__tests__/tmux-test-fixture.js.map +0 -1
  1575. package/dist/team/__tests__/tmux-test-fixture.test.d.ts +0 -2
  1576. package/dist/team/__tests__/tmux-test-fixture.test.d.ts.map +0 -1
  1577. package/dist/team/__tests__/tmux-test-fixture.test.js +0 -113
  1578. package/dist/team/__tests__/tmux-test-fixture.test.js.map +0 -1
  1579. package/dist/team/__tests__/worker-bootstrap.test.d.ts +0 -2
  1580. package/dist/team/__tests__/worker-bootstrap.test.d.ts.map +0 -1
  1581. package/dist/team/__tests__/worker-bootstrap.test.js +0 -685
  1582. package/dist/team/__tests__/worker-bootstrap.test.js.map +0 -1
  1583. package/dist/team/__tests__/worker-runtime-identity.test.d.ts +0 -2
  1584. package/dist/team/__tests__/worker-runtime-identity.test.d.ts.map +0 -1
  1585. package/dist/team/__tests__/worker-runtime-identity.test.js +0 -250
  1586. package/dist/team/__tests__/worker-runtime-identity.test.js.map +0 -1
  1587. package/dist/team/__tests__/worktree.test.d.ts +0 -2
  1588. package/dist/team/__tests__/worktree.test.d.ts.map +0 -1
  1589. package/dist/team/__tests__/worktree.test.js +0 -317
  1590. package/dist/team/__tests__/worktree.test.js.map +0 -1
  1591. package/dist/utils/__tests__/agents-md.test.d.ts +0 -2
  1592. package/dist/utils/__tests__/agents-md.test.d.ts.map +0 -1
  1593. package/dist/utils/__tests__/agents-md.test.js +0 -52
  1594. package/dist/utils/__tests__/agents-md.test.js.map +0 -1
  1595. package/dist/utils/__tests__/agents-model-table.test.d.ts +0 -2
  1596. package/dist/utils/__tests__/agents-model-table.test.d.ts.map +0 -1
  1597. package/dist/utils/__tests__/agents-model-table.test.js +0 -104
  1598. package/dist/utils/__tests__/agents-model-table.test.js.map +0 -1
  1599. package/dist/utils/__tests__/dep-versions.test.d.ts +0 -2
  1600. package/dist/utils/__tests__/dep-versions.test.d.ts.map +0 -1
  1601. package/dist/utils/__tests__/dep-versions.test.js +0 -46
  1602. package/dist/utils/__tests__/dep-versions.test.js.map +0 -1
  1603. package/dist/utils/__tests__/package.test.d.ts +0 -2
  1604. package/dist/utils/__tests__/package.test.d.ts.map +0 -1
  1605. package/dist/utils/__tests__/package.test.js +0 -21
  1606. package/dist/utils/__tests__/package.test.js.map +0 -1
  1607. package/dist/utils/__tests__/paths.test.d.ts +0 -2
  1608. package/dist/utils/__tests__/paths.test.d.ts.map +0 -1
  1609. package/dist/utils/__tests__/paths.test.js +0 -541
  1610. package/dist/utils/__tests__/paths.test.js.map +0 -1
  1611. package/dist/utils/__tests__/platform-command.test.d.ts +0 -2
  1612. package/dist/utils/__tests__/platform-command.test.d.ts.map +0 -1
  1613. package/dist/utils/__tests__/platform-command.test.js +0 -410
  1614. package/dist/utils/__tests__/platform-command.test.js.map +0 -1
  1615. package/dist/utils/__tests__/repo-deps.test.d.ts +0 -2
  1616. package/dist/utils/__tests__/repo-deps.test.d.ts.map +0 -1
  1617. package/dist/utils/__tests__/repo-deps.test.js +0 -71
  1618. package/dist/utils/__tests__/repo-deps.test.js.map +0 -1
  1619. package/dist/verification/__tests__/ci-rust-gates.test.d.ts +0 -2
  1620. package/dist/verification/__tests__/ci-rust-gates.test.d.ts.map +0 -1
  1621. package/dist/verification/__tests__/ci-rust-gates.test.js +0 -89
  1622. package/dist/verification/__tests__/ci-rust-gates.test.js.map +0 -1
  1623. package/dist/verification/__tests__/dev-merge-issue-close-workflow.test.d.ts +0 -2
  1624. package/dist/verification/__tests__/dev-merge-issue-close-workflow.test.d.ts.map +0 -1
  1625. package/dist/verification/__tests__/dev-merge-issue-close-workflow.test.js +0 -54
  1626. package/dist/verification/__tests__/dev-merge-issue-close-workflow.test.js.map +0 -1
  1627. package/dist/verification/__tests__/explore-harness-release-workflow.test.d.ts +0 -2
  1628. package/dist/verification/__tests__/explore-harness-release-workflow.test.d.ts.map +0 -1
  1629. package/dist/verification/__tests__/explore-harness-release-workflow.test.js +0 -73
  1630. package/dist/verification/__tests__/explore-harness-release-workflow.test.js.map +0 -1
  1631. package/dist/verification/__tests__/native-release-manifest.test.d.ts +0 -2
  1632. package/dist/verification/__tests__/native-release-manifest.test.d.ts.map +0 -1
  1633. package/dist/verification/__tests__/native-release-manifest.test.js +0 -80
  1634. package/dist/verification/__tests__/native-release-manifest.test.js.map +0 -1
  1635. package/dist/verification/__tests__/pr-check-workflow.test.d.ts +0 -2
  1636. package/dist/verification/__tests__/pr-check-workflow.test.d.ts.map +0 -1
  1637. package/dist/verification/__tests__/pr-check-workflow.test.js +0 -27
  1638. package/dist/verification/__tests__/pr-check-workflow.test.js.map +0 -1
  1639. package/dist/verification/__tests__/ralph-persistence-gate.test.d.ts +0 -2
  1640. package/dist/verification/__tests__/ralph-persistence-gate.test.d.ts.map +0 -1
  1641. package/dist/verification/__tests__/ralph-persistence-gate.test.js +0 -55
  1642. package/dist/verification/__tests__/ralph-persistence-gate.test.js.map +0 -1
  1643. package/dist/verification/__tests__/rust-runtime-thin-adapter-gate.test.d.ts +0 -2
  1644. package/dist/verification/__tests__/rust-runtime-thin-adapter-gate.test.d.ts.map +0 -1
  1645. package/dist/verification/__tests__/rust-runtime-thin-adapter-gate.test.js +0 -32
  1646. package/dist/verification/__tests__/rust-runtime-thin-adapter-gate.test.js.map +0 -1
  1647. package/dist/verification/__tests__/verifier.test.d.ts +0 -2
  1648. package/dist/verification/__tests__/verifier.test.d.ts.map +0 -1
  1649. package/dist/verification/__tests__/verifier.test.js +0 -113
  1650. package/dist/verification/__tests__/verifier.test.js.map +0 -1
  1651. package/dist/visual/__tests__/verdict.test.d.ts +0 -2
  1652. package/dist/visual/__tests__/verdict.test.d.ts.map +0 -1
  1653. package/dist/visual/__tests__/verdict.test.js +0 -81
  1654. package/dist/visual/__tests__/verdict.test.js.map +0 -1
  1655. package/dist/wiki/__tests__/cjk-tokenize.test.d.ts +0 -12
  1656. package/dist/wiki/__tests__/cjk-tokenize.test.d.ts.map +0 -1
  1657. package/dist/wiki/__tests__/cjk-tokenize.test.js +0 -139
  1658. package/dist/wiki/__tests__/cjk-tokenize.test.js.map +0 -1
  1659. package/dist/wiki/__tests__/crlf-parse.test.d.ts +0 -2
  1660. package/dist/wiki/__tests__/crlf-parse.test.d.ts.map +0 -1
  1661. package/dist/wiki/__tests__/crlf-parse.test.js +0 -24
  1662. package/dist/wiki/__tests__/crlf-parse.test.js.map +0 -1
  1663. package/dist/wiki/__tests__/escape-newline.test.d.ts +0 -2
  1664. package/dist/wiki/__tests__/escape-newline.test.d.ts.map +0 -1
  1665. package/dist/wiki/__tests__/escape-newline.test.js +0 -45
  1666. package/dist/wiki/__tests__/escape-newline.test.js.map +0 -1
  1667. package/dist/wiki/__tests__/ingest.test.d.ts +0 -5
  1668. package/dist/wiki/__tests__/ingest.test.d.ts.map +0 -1
  1669. package/dist/wiki/__tests__/ingest.test.js +0 -181
  1670. package/dist/wiki/__tests__/ingest.test.js.map +0 -1
  1671. package/dist/wiki/__tests__/lint.test.d.ts +0 -5
  1672. package/dist/wiki/__tests__/lint.test.d.ts.map +0 -1
  1673. package/dist/wiki/__tests__/lint.test.js +0 -163
  1674. package/dist/wiki/__tests__/lint.test.js.map +0 -1
  1675. package/dist/wiki/__tests__/query.test.d.ts +0 -5
  1676. package/dist/wiki/__tests__/query.test.d.ts.map +0 -1
  1677. package/dist/wiki/__tests__/query.test.js +0 -141
  1678. package/dist/wiki/__tests__/query.test.js.map +0 -1
  1679. package/dist/wiki/__tests__/reserved-file-guard.test.d.ts +0 -2
  1680. package/dist/wiki/__tests__/reserved-file-guard.test.d.ts.map +0 -1
  1681. package/dist/wiki/__tests__/reserved-file-guard.test.js +0 -44
  1682. package/dist/wiki/__tests__/reserved-file-guard.test.js.map +0 -1
  1683. package/dist/wiki/__tests__/session-hooks.test.d.ts +0 -5
  1684. package/dist/wiki/__tests__/session-hooks.test.d.ts.map +0 -1
  1685. package/dist/wiki/__tests__/session-hooks.test.js +0 -36
  1686. package/dist/wiki/__tests__/session-hooks.test.js.map +0 -1
  1687. package/dist/wiki/__tests__/slug-nonascii.test.d.ts +0 -2
  1688. package/dist/wiki/__tests__/slug-nonascii.test.d.ts.map +0 -1
  1689. package/dist/wiki/__tests__/slug-nonascii.test.js +0 -30
  1690. package/dist/wiki/__tests__/slug-nonascii.test.js.map +0 -1
  1691. package/dist/wiki/__tests__/storage.test.d.ts +0 -5
  1692. package/dist/wiki/__tests__/storage.test.d.ts.map +0 -1
  1693. package/dist/wiki/__tests__/storage.test.js +0 -278
  1694. package/dist/wiki/__tests__/storage.test.js.map +0 -1
  1695. package/dist/wiki/__tests__/test-helpers.d.ts +0 -31
  1696. package/dist/wiki/__tests__/test-helpers.d.ts.map +0 -1
  1697. package/dist/wiki/__tests__/test-helpers.js +0 -108
  1698. package/dist/wiki/__tests__/test-helpers.js.map +0 -1
  1699. package/docs/contracts/ralph-cancel-contract.md +0 -23
  1700. package/docs/contracts/ralph-state-contract.md +0 -95
  1701. package/docs/issues/team-ralph-followup-team.md +0 -38
  1702. package/docs/qa/ralph-persistence-gate.md +0 -59
  1703. package/docs/reference/ralph-parity-matrix.md +0 -25
  1704. package/docs/reference/ralph-upstream-baseline.md +0 -34
  1705. package/plugins/roblox-ai-os-creator-skills/skills/ralph/SKILL.md +0 -269
  1706. package/plugins/roblox-ai-os-creator-skills/skills/ralplan/SKILL.md +0 -162
  1707. package/prompts/api-reviewer.md +0 -113
  1708. package/prompts/information-architect.md +0 -226
  1709. package/prompts/performance-reviewer.md +0 -109
  1710. package/prompts/product-analyst.md +0 -304
  1711. package/prompts/product-manager.md +0 -245
  1712. package/prompts/qa-tester.md +0 -124
  1713. package/prompts/quality-reviewer.md +0 -123
  1714. package/prompts/quality-strategist.md +0 -274
  1715. package/prompts/style-reviewer.md +0 -102
  1716. package/prompts/ux-researcher.md +0 -327
  1717. package/skills/frontend-ui-ux/SKILL.md +0 -34
  1718. package/skills/ralph/SKILL.md +0 -269
  1719. package/skills/ralplan/SKILL.md +0 -162
  1720. package/src/scripts/eval/eval-adaptive-sort-optimization.py +0 -24
  1721. package/src/scripts/eval/eval-candidate-handoff.ts +0 -8
  1722. package/src/scripts/eval/eval-cli-discoverability.ts +0 -40
  1723. package/src/scripts/eval/eval-fresh-run-tagging.ts +0 -8
  1724. package/src/scripts/eval/eval-help-consistency.ts +0 -11
  1725. package/src/scripts/eval/eval-in-action-cat-shellout-demo.ts +0 -31
  1726. package/src/scripts/eval/eval-ml-kaggle-model-optimization.py +0 -29
  1727. package/src/scripts/eval/eval-noisy-bayesopt-highdim.py +0 -44
  1728. package/src/scripts/eval/eval-noisy-latent-subspace-discovery.py +0 -44
  1729. package/src/scripts/eval/eval-parity-smoke.ts +0 -20
  1730. package/src/scripts/eval/eval-parity-sweep.ts +0 -26
  1731. package/src/scripts/eval/eval-resume-dirty-guard.ts +0 -8
  1732. package/src/scripts/eval/eval-security-path-traversal.ts +0 -38
  1733. package/src/scripts/run-autoresearch-showcase.sh +0 -75
  1734. /package/docs/{migration-mainline-post-v0.4.4.md → archive/migration-mainline-post-v0.4.4.md} +0 -0
  1735. /package/docs/{qa-plan-0.4.2.md → archive/qa-plan-0.4.2.md} +0 -0
  1736. /package/docs/{qa-report-0.4.2.md → archive/qa-report-0.4.2.md} +0 -0
@@ -1,1820 +0,0 @@
1
- import { execFileSync } from 'node:child_process';
2
- import { afterEach, beforeEach, describe, it } from 'node:test';
3
- import assert from 'node:assert/strict';
4
- import { existsSync } from 'node:fs';
5
- import { chmod, mkdir, mkdtemp, readFile, rm, writeFile } from 'node:fs/promises';
6
- import { spawn } from 'node:child_process';
7
- import { join } from 'node:path';
8
- import { tmpdir } from 'node:os';
9
- import { fileURLToPath } from 'node:url';
10
- import { buildLeaderMonitoringHints, parseTeamStartArgs, teamCommand } from '../team.js';
11
- import { readModeState } from '../../modes/base.js';
12
- import { DEFAULT_MAX_WORKERS } from '../../team/state.js';
13
- import { appendTeamEvent, createTask, initTeamState, readTeamConfig, saveTeamConfig, updateWorkerHeartbeat, writeMonitorSnapshot, writeTaskApproval, writeWorkerStatus, } from '../../team/state.js';
14
- import { isRealTmuxAvailable, withTempTmuxSession } from '../../team/__tests__/tmux-test-fixture.js';
15
- const RCS_CLI_PATH = fileURLToPath(new URL('../rcs.js', import.meta.url));
16
- const ORIGINAL_RCS_TEAM_WORKER = process.env.RCS_TEAM_WORKER;
17
- const ORIGINAL_RCS_TEAM_STATE_ROOT = process.env.RCS_TEAM_STATE_ROOT;
18
- beforeEach(() => {
19
- delete process.env.RCS_TEAM_WORKER;
20
- delete process.env.RCS_TEAM_STATE_ROOT;
21
- });
22
- afterEach(() => {
23
- if (typeof ORIGINAL_RCS_TEAM_WORKER === 'string')
24
- process.env.RCS_TEAM_WORKER = ORIGINAL_RCS_TEAM_WORKER;
25
- else
26
- delete process.env.RCS_TEAM_WORKER;
27
- if (typeof ORIGINAL_RCS_TEAM_STATE_ROOT === 'string')
28
- process.env.RCS_TEAM_STATE_ROOT = ORIGINAL_RCS_TEAM_STATE_ROOT;
29
- else
30
- delete process.env.RCS_TEAM_STATE_ROOT;
31
- });
32
- function withoutTeamTestWorkerEnv(fn) {
33
- const previousTeamWorker = process.env.RCS_TEAM_WORKER;
34
- const previousTeamStateRoot = process.env.RCS_TEAM_STATE_ROOT;
35
- delete process.env.RCS_TEAM_WORKER;
36
- delete process.env.RCS_TEAM_STATE_ROOT;
37
- let restoreImmediately = true;
38
- const restore = () => {
39
- if (typeof previousTeamWorker === 'string')
40
- process.env.RCS_TEAM_WORKER = previousTeamWorker;
41
- else
42
- delete process.env.RCS_TEAM_WORKER;
43
- if (typeof previousTeamStateRoot === 'string')
44
- process.env.RCS_TEAM_STATE_ROOT = previousTeamStateRoot;
45
- else
46
- delete process.env.RCS_TEAM_STATE_ROOT;
47
- };
48
- try {
49
- const result = fn();
50
- if (result instanceof Promise) {
51
- restoreImmediately = false;
52
- return result.finally(restore);
53
- }
54
- return result;
55
- }
56
- finally {
57
- if (restoreImmediately)
58
- restore();
59
- }
60
- }
61
- function withMockPromptModeCodexAllowed(fn) {
62
- const previous = process.env.RCS_TEST_ALLOW_NONTTY_CODEX_PROMPT;
63
- process.env.RCS_TEST_ALLOW_NONTTY_CODEX_PROMPT = '1';
64
- let restoreImmediately = true;
65
- const restore = () => {
66
- if (typeof previous === 'string')
67
- process.env.RCS_TEST_ALLOW_NONTTY_CODEX_PROMPT = previous;
68
- else
69
- delete process.env.RCS_TEST_ALLOW_NONTTY_CODEX_PROMPT;
70
- };
71
- try {
72
- const result = fn();
73
- if (result instanceof Promise) {
74
- restoreImmediately = false;
75
- return result.finally(restore);
76
- }
77
- return result;
78
- }
79
- finally {
80
- if (restoreImmediately)
81
- restore();
82
- }
83
- }
84
- async function runNodeCli(args, options) {
85
- return await new Promise((resolve, reject) => {
86
- const child = spawn(process.execPath, [RCS_CLI_PATH, ...args], {
87
- cwd: options.cwd,
88
- env: options.env,
89
- stdio: ['ignore', 'pipe', 'pipe'],
90
- });
91
- let stdout = '';
92
- let stderr = '';
93
- child.stdout.setEncoding('utf-8');
94
- child.stderr.setEncoding('utf-8');
95
- child.stdout.on('data', (chunk) => {
96
- stdout += chunk;
97
- });
98
- child.stderr.on('data', (chunk) => {
99
- stderr += chunk;
100
- });
101
- child.on('error', reject);
102
- child.on('close', (code, signal) => {
103
- resolve({ code, signal, stdout, stderr });
104
- });
105
- });
106
- }
107
- function skipUnlessTmux(t) {
108
- if (!isRealTmuxAvailable()) {
109
- t.skip('tmux is not available in this environment');
110
- }
111
- }
112
- function runFixtureTmux(fixture, args) {
113
- return execFileSync('tmux', args, {
114
- encoding: 'utf-8',
115
- env: {
116
- ...process.env,
117
- TMUX: fixture.env.TMUX,
118
- TMUX_PANE: fixture.leaderPaneId,
119
- },
120
- }).trim();
121
- }
122
- function fixturePaneExists(fixture, paneId) {
123
- try {
124
- runFixtureTmux(fixture, ['display-message', '-p', '-t', paneId, '#{pane_id}']);
125
- return true;
126
- }
127
- catch {
128
- return false;
129
- }
130
- }
131
- async function waitForFileText(filePath, timeoutMs = 5_000) {
132
- const deadline = Date.now() + timeoutMs;
133
- while (Date.now() < deadline) {
134
- if (existsSync(filePath)) {
135
- const text = await readFile(filePath, 'utf-8');
136
- if (text.trim() !== '')
137
- return text;
138
- }
139
- await new Promise((resolve) => setTimeout(resolve, 50));
140
- }
141
- throw new Error(`timed out waiting for ${filePath}`);
142
- }
143
- describe('parseTeamStartArgs', () => {
144
- it('parses default team start args with automatic detached worktrees', () => {
145
- const result = parseTeamStartArgs(['2:executor', 'build', 'feature']);
146
- assert.deepEqual(result.worktreeMode, { enabled: true, detached: true, name: null });
147
- assert.equal(result.parsed.workerCount, 2);
148
- assert.equal(result.parsed.agentType, 'executor');
149
- assert.equal(result.parsed.task, 'build feature');
150
- assert.equal(result.parsed.teamName, 'build-feature');
151
- });
152
- it('parses detached worktree mode and strips the flag', () => {
153
- const result = parseTeamStartArgs(['--worktree', '3:debugger', 'fix', 'bug']);
154
- assert.deepEqual(result.worktreeMode, { enabled: true, detached: true, name: null });
155
- assert.equal(result.parsed.workerCount, 3);
156
- assert.equal(result.parsed.agentType, 'debugger');
157
- assert.equal(result.parsed.task, 'fix bug');
158
- assert.equal(result.parsed.teamName, 'fix-bug');
159
- });
160
- it('keeps explicit --worktree detached mode as a legacy-compatible override', () => {
161
- const result = parseTeamStartArgs(['--worktree', '3:debugger', 'fix', 'bug']);
162
- assert.deepEqual(result.worktreeMode, { enabled: true, detached: true, name: null });
163
- assert.equal(result.parsed.workerCount, 3);
164
- assert.equal(result.parsed.agentType, 'debugger');
165
- });
166
- it('rejects deprecated rcs team ralph syntax', () => {
167
- assert.throws(() => parseTeamStartArgs(['ralph', '--worktree=feature/demo', '4:executor', 'ship', 'it']), /Deprecated usage: `rcs team ralph \.\.\.` has been removed/);
168
- });
169
- it('accepts the maximum supported worker count', () => {
170
- const result = parseTeamStartArgs([`${DEFAULT_MAX_WORKERS}:executor`, 'ship', 'it']);
171
- assert.equal(result.parsed.workerCount, DEFAULT_MAX_WORKERS);
172
- });
173
- it('rejects worker count above the supported maximum', () => {
174
- assert.throws(() => parseTeamStartArgs([`${DEFAULT_MAX_WORKERS + 1}:executor`, 'ship', 'it']), new RegExp(`Expected 1-${DEFAULT_MAX_WORKERS}`));
175
- });
176
- it('reuses the approved team launch hint for a short English follow-up', async () => {
177
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-followup-en-'));
178
- const previousCwd = process.cwd();
179
- try {
180
- process.chdir(wd);
181
- await mkdir(join(wd, '.rcs', 'plans'), { recursive: true });
182
- await writeFile(join(wd, '.rcs', 'plans', 'prd-issue-831.md'), '# Approved plan\n\nLaunch via rcs team 3:executor "Execute approved issue 831 plan"\n');
183
- await writeFile(join(wd, '.rcs', 'plans', 'test-spec-issue-831.md'), '# Test spec\n');
184
- const result = parseTeamStartArgs(['team']);
185
- assert.equal(result.parsed.task, 'Execute approved issue 831 plan');
186
- assert.equal(result.parsed.workerCount, 3);
187
- assert.equal(result.parsed.agentType, 'executor');
188
- assert.equal(result.parsed.explicitWorkerCount, true);
189
- assert.equal(result.parsed.allowRepoAwareDagHandoff, true);
190
- }
191
- finally {
192
- process.chdir(previousCwd);
193
- await rm(wd, { recursive: true, force: true });
194
- }
195
- });
196
- it('reuses the approved team launch hint for a short Korean follow-up', async () => {
197
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-followup-ko-'));
198
- const previousCwd = process.cwd();
199
- try {
200
- process.chdir(wd);
201
- await mkdir(join(wd, '.rcs', 'plans'), { recursive: true });
202
- await writeFile(join(wd, '.rcs', 'plans', 'prd-issue-831.md'), '# Approved plan\n\nLaunch via rcs team 3:executor "Execute approved issue 831 plan"\n');
203
- await writeFile(join(wd, '.rcs', 'plans', 'test-spec-issue-831.md'), '# Test spec\n');
204
- const result = parseTeamStartArgs(['team으로', '해줘']);
205
- assert.equal(result.parsed.task, 'Execute approved issue 831 plan');
206
- assert.equal(result.parsed.workerCount, 3);
207
- }
208
- finally {
209
- process.chdir(previousCwd);
210
- await rm(wd, { recursive: true, force: true });
211
- }
212
- });
213
- it('fails closed for a short team follow-up when the selected PRD lists multiple team launch hints', async () => {
214
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-followup-ambiguous-'));
215
- const previousCwd = process.cwd();
216
- try {
217
- process.chdir(wd);
218
- await mkdir(join(wd, '.rcs', 'plans'), { recursive: true });
219
- await writeFile(join(wd, '.rcs', 'plans', 'prd-issue-831-ambiguous.md'), [
220
- '# Approved plan',
221
- '',
222
- 'Launch via rcs team 3:executor "Execute approved issue 831 plan"',
223
- 'Launch via rcs team 5:debugger "Execute alternate issue 831 plan"',
224
- ].join('\n'));
225
- await writeFile(join(wd, '.rcs', 'plans', 'test-spec-issue-831-ambiguous.md'), '# Test spec\n');
226
- assert.throws(() => parseTeamStartArgs(['team']), /approved_execution_hint_ambiguous:team/);
227
- }
228
- finally {
229
- process.chdir(previousCwd);
230
- await rm(wd, { recursive: true, force: true });
231
- }
232
- });
233
- it('does not opt normal team startup into repo-aware DAG handoff even when a stale sidecar exists', async () => {
234
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-dag-normal-'));
235
- const previousCwd = process.cwd();
236
- try {
237
- process.chdir(wd);
238
- await mkdir(join(wd, '.rcs', 'plans'), { recursive: true });
239
- await writeFile(join(wd, '.rcs', 'plans', 'prd-issue-831.md'), '# Approved plan\n\nLaunch via rcs team 3:executor "Execute approved issue 831 plan"\n');
240
- await writeFile(join(wd, '.rcs', 'plans', 'test-spec-issue-831.md'), '# Test spec\n');
241
- await writeFile(join(wd, '.rcs', 'plans', 'team-dag-issue-831.json'), '{"schema_version":1,"nodes":[{"id":"impl","subject":"Impl","description":"Impl"}]}\n');
242
- const result = parseTeamStartArgs(['3:executor', 'fix', 'unrelated', 'bug']);
243
- assert.equal(result.parsed.task, 'fix unrelated bug');
244
- assert.equal(result.parsed.allowRepoAwareDagHandoff, false);
245
- }
246
- finally {
247
- process.chdir(previousCwd);
248
- await rm(wd, { recursive: true, force: true });
249
- }
250
- });
251
- it('opts into repo-aware DAG handoff when the invocation matches the approved launch hint', async () => {
252
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-dag-approved-'));
253
- const previousCwd = process.cwd();
254
- try {
255
- process.chdir(wd);
256
- await mkdir(join(wd, '.rcs', 'plans'), { recursive: true });
257
- await writeFile(join(wd, '.rcs', 'plans', 'prd-issue-831.md'), '# Approved plan\n\nLaunch via rcs team 3:executor "Execute approved issue 831 plan"\n');
258
- await writeFile(join(wd, '.rcs', 'plans', 'test-spec-issue-831.md'), '# Test spec\n');
259
- const result = parseTeamStartArgs(['3:executor', 'Execute', 'approved', 'issue', '831', 'plan']);
260
- assert.equal(result.parsed.allowRepoAwareDagHandoff, true);
261
- }
262
- finally {
263
- process.chdir(previousCwd);
264
- await rm(wd, { recursive: true, force: true });
265
- }
266
- });
267
- it('attaches approved repository context summary only for matching team launches', async () => {
268
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-context-approved-'));
269
- const previousCwd = process.cwd();
270
- try {
271
- process.chdir(wd);
272
- await mkdir(join(wd, '.rcs', 'plans'), { recursive: true });
273
- await writeFile(join(wd, '.rcs', 'plans', 'prd-issue-2039.md'), '# Approved plan\n\nLaunch via rcs team 3:executor "Execute approved issue 2039 plan"\n');
274
- await writeFile(join(wd, '.rcs', 'plans', 'test-spec-issue-2039.md'), '# Test spec\n');
275
- await writeFile(join(wd, '.rcs', 'plans', 'repo-context-issue-2039.md'), 'Key boundary: latest approved handoff only.\n');
276
- const approved = parseTeamStartArgs(['3:executor', 'Execute', 'approved', 'issue', '2039', 'plan']);
277
- assert.equal(approved.parsed.approvedRepositoryContextSummary?.content, 'Key boundary: latest approved handoff only.');
278
- const unrelated = parseTeamStartArgs(['3:executor', 'fix', 'unrelated', 'bug']);
279
- assert.equal(unrelated.parsed.approvedRepositoryContextSummary, undefined);
280
- }
281
- finally {
282
- process.chdir(previousCwd);
283
- await rm(wd, { recursive: true, force: true });
284
- }
285
- });
286
- it('preserves explicit team staffing overrides while reusing the approved plan task', async () => {
287
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-followup-override-'));
288
- const previousCwd = process.cwd();
289
- try {
290
- process.chdir(wd);
291
- await mkdir(join(wd, '.rcs', 'plans'), { recursive: true });
292
- await writeFile(join(wd, '.rcs', 'plans', 'prd-issue-831.md'), '# Approved plan\n\nLaunch via rcs team 3:executor "Execute approved issue 831 plan"\n');
293
- await writeFile(join(wd, '.rcs', 'plans', 'test-spec-issue-831.md'), '# Test spec\n');
294
- const result = parseTeamStartArgs(['2:debugger', 'team']);
295
- assert.equal(result.parsed.task, 'Execute approved issue 831 plan');
296
- assert.equal(result.parsed.workerCount, 2);
297
- assert.equal(result.parsed.agentType, 'debugger');
298
- assert.equal(result.parsed.explicitWorkerCount, true);
299
- assert.equal(result.parsed.explicitAgentType, true);
300
- }
301
- finally {
302
- process.chdir(previousCwd);
303
- await rm(wd, { recursive: true, force: true });
304
- }
305
- });
306
- });
307
- describe('teamCommand shutdown --force parsing', () => {
308
- it('parses --force flag from shutdown args', () => {
309
- const teamArgs = ['shutdown', 'my-team', '--force'];
310
- const force = teamArgs.includes('--force');
311
- assert.equal(force, true);
312
- });
313
- it('does not set force when --force is absent', () => {
314
- const teamArgs = ['shutdown', 'my-team'];
315
- const force = teamArgs.includes('--force');
316
- assert.equal(force, false);
317
- });
318
- it('parses --force regardless of position after subcommand', () => {
319
- const teamArgs = ['shutdown', '--force', 'my-team'];
320
- const force = teamArgs.includes('--force');
321
- assert.equal(force, true);
322
- });
323
- it('persists cancelled team mode state on shutdown even when no team mode state existed beforehand', async () => {
324
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-shutdown-mode-state-'));
325
- const previousCwd = process.cwd();
326
- const originalLog = console.log;
327
- const originalWarn = console.warn;
328
- const logs = [];
329
- const warns = [];
330
- try {
331
- process.chdir(wd);
332
- await mkdir(join(wd, '.rcs', 'state'), { recursive: true });
333
- await writeFile(join(wd, '.rcs', 'state', 'session.json'), JSON.stringify({ session_id: 'sess-team-shutdown-state' }));
334
- await initTeamState('team-shutdown-mode-state', 'persist cancelled team mode state after shutdown', 'executor', 1, wd);
335
- console.log = (...args) => logs.push(args.map(String).join(' '));
336
- console.warn = (...args) => warns.push(args.map(String).join(' '));
337
- await teamCommand(['shutdown', 'team-shutdown-mode-state', '--force']);
338
- const state = await readModeState('team', wd);
339
- assert.ok(state);
340
- assert.equal(state?.active, false);
341
- assert.equal(state?.current_phase, 'cancelled');
342
- assert.equal(state?.team_name, 'team-shutdown-mode-state');
343
- assert.equal(warns.length, 0);
344
- assert.ok(logs.some((line) => line.includes('Team shutdown complete: team-shutdown-mode-state')));
345
- }
346
- finally {
347
- console.log = originalLog;
348
- console.warn = originalWarn;
349
- process.chdir(previousCwd);
350
- await rm(wd, { recursive: true, force: true });
351
- }
352
- });
353
- it('persists cancelled session-scoped team mode state on shutdown', async () => {
354
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-shutdown-session-mode-state-'));
355
- const previousCwd = process.cwd();
356
- const teamName = 'team-shutdown-scoped';
357
- try {
358
- process.chdir(wd);
359
- const stateDir = join(wd, '.rcs', 'state');
360
- const sessionId = 'sess-team-shutdown-scoped';
361
- const scopedStateDir = join(stateDir, 'sessions', sessionId);
362
- await mkdir(scopedStateDir, { recursive: true });
363
- await writeFile(join(stateDir, 'session.json'), JSON.stringify({ session_id: sessionId }));
364
- await writeFile(join(scopedStateDir, 'team-state.json'), JSON.stringify({
365
- active: true,
366
- mode: 'team',
367
- current_phase: 'team-exec',
368
- team_name: teamName,
369
- }, null, 2));
370
- await initTeamState(teamName, 'persist cancelled session-scoped team mode state after shutdown', 'executor', 1, wd);
371
- await teamCommand(['shutdown', teamName, '--force']);
372
- const scopedState = JSON.parse(await readFile(join(scopedStateDir, 'team-state.json'), 'utf-8'));
373
- assert.equal(scopedState.active, false);
374
- assert.equal(scopedState.current_phase, 'cancelled');
375
- assert.equal(scopedState.team_name, teamName);
376
- assert.ok(typeof scopedState.completed_at === 'string' && scopedState.completed_at.length > 0);
377
- }
378
- finally {
379
- process.chdir(previousCwd);
380
- await rm(wd, { recursive: true, force: true });
381
- }
382
- });
383
- it('does not create session-scoped team mode state on shutdown when only root team mode state exists', async () => {
384
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-shutdown-root-mode-only-'));
385
- const previousCwd = process.cwd();
386
- const teamName = 'team-shutdown-root-only';
387
- const sessionId = 'sess-team-shutdown-root-only';
388
- try {
389
- process.chdir(wd);
390
- const stateDir = join(wd, '.rcs', 'state');
391
- const scopedStatePath = join(stateDir, 'sessions', sessionId, 'team-state.json');
392
- await mkdir(stateDir, { recursive: true });
393
- await writeFile(join(stateDir, 'session.json'), JSON.stringify({ session_id: sessionId }));
394
- await writeFile(join(stateDir, 'team-state.json'), JSON.stringify({
395
- active: true,
396
- mode: 'team',
397
- current_phase: 'team-exec',
398
- team_name: teamName,
399
- }, null, 2));
400
- await initTeamState(teamName, 'shutdown should not create scoped team mode state from a root-only mode state', 'executor', 1, wd);
401
- await teamCommand(['shutdown', teamName, '--force']);
402
- assert.equal(existsSync(scopedStatePath), false);
403
- const rootState = JSON.parse(await readFile(join(stateDir, 'team-state.json'), 'utf-8'));
404
- assert.equal(rootState.active, false);
405
- assert.equal(rootState.current_phase, 'cancelled');
406
- assert.equal(rootState.team_name, teamName);
407
- }
408
- finally {
409
- process.chdir(previousCwd);
410
- await rm(wd, { recursive: true, force: true });
411
- }
412
- });
413
- it('does not create session-scoped team mode state on shutdown when a stale session.json remains', async () => {
414
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-shutdown-stale-session-json-'));
415
- const previousCwd = process.cwd();
416
- const teamName = 'team-shutdown-stale-session';
417
- const staleSessionId = 'sess-team-shutdown-stale';
418
- try {
419
- process.chdir(wd);
420
- const stateDir = join(wd, '.rcs', 'state');
421
- const staleSessionDir = join(stateDir, 'sessions', staleSessionId);
422
- const scopedStatePath = join(staleSessionDir, 'team-state.json');
423
- await mkdir(staleSessionDir, { recursive: true });
424
- await writeFile(join(stateDir, 'session.json'), JSON.stringify({ session_id: staleSessionId }));
425
- await writeFile(join(staleSessionDir, 'hud-state.json'), JSON.stringify({ turn_count: 12 }, null, 2));
426
- await writeFile(join(stateDir, 'team-state.json'), JSON.stringify({
427
- active: true,
428
- mode: 'team',
429
- current_phase: 'team-exec',
430
- team_name: teamName,
431
- }, null, 2));
432
- await initTeamState(teamName, 'shutdown should ignore stale session.json when only root team mode state exists', 'executor', 1, wd);
433
- await teamCommand(['shutdown', teamName, '--force']);
434
- assert.equal(existsSync(scopedStatePath), false);
435
- const rootState = JSON.parse(await readFile(join(stateDir, 'team-state.json'), 'utf-8'));
436
- assert.equal(rootState.active, false);
437
- assert.equal(rootState.current_phase, 'cancelled');
438
- assert.equal(rootState.team_name, teamName);
439
- }
440
- finally {
441
- process.chdir(previousCwd);
442
- await rm(wd, { recursive: true, force: true });
443
- }
444
- });
445
- it('parses --confirm-issues from shutdown args', () => {
446
- const teamArgs = ['shutdown', 'my-team', '--confirm-issues'];
447
- const confirmIssues = teamArgs.includes('--confirm-issues');
448
- assert.equal(confirmIssues, true);
449
- });
450
- it('keeps the shutdown CLI alive while tearing down a shared leader tmux session', async () => {
451
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-shutdown-shared-cli-'));
452
- const binDir = join(wd, 'bin');
453
- const tmuxLogPath = join(wd, 'tmux.log');
454
- const tmuxPath = join(binDir, 'tmux');
455
- const previousPath = process.env.PATH;
456
- await mkdir(binDir, { recursive: true });
457
- await writeFile(tmuxPath, `#!/bin/sh
458
- set -eu
459
- printf '%s\\n' "$*" >> "${tmuxLogPath}"
460
- case "$1" in
461
- -V)
462
- echo "tmux 3.4"
463
- exit 0
464
- ;;
465
- list-panes)
466
- case "$*" in
467
- *"-F #{pane_dead} #{pane_pid}"*)
468
- exit 1
469
- ;;
470
- *"-t leader:0 -F #{pane_id}"*"#{pane_current_command}"*)
471
- printf "%%11\\tzsh\\tzsh\\n%%12\\tnode\\tnode /tmp/bin/rcs.js hud --watch\\n%%13\\tcodex\\tcodex\\n%%14\\tcodex\\tcodex\\n"
472
- exit 0
473
- ;;
474
- *"-t leader:0 -F #{pane_id}"*)
475
- printf "%%11\\n%%12\\n%%13\\n%%14\\n"
476
- exit 0
477
- ;;
478
- *)
479
- exit 1
480
- ;;
481
- esac
482
- ;;
483
- split-window)
484
- printf '%%44\\n'
485
- exit 0
486
- ;;
487
- kill-pane)
488
- # Shared-session runtime coverage should validate pane-targeted teardown
489
- # only. Detached leader-wrapper signal behavior is covered separately in
490
- # cli/index detached-session tests.
491
- exit 0
492
- ;;
493
- resize-pane|select-pane|has-session|show-options|show-hooks|set-hook|set-option)
494
- exit 0
495
- ;;
496
- *)
497
- exit 0
498
- ;;
499
- esac
500
- `);
501
- await chmod(tmuxPath, 0o755);
502
- try {
503
- await initTeamState('shared-shutdown-cli', 'shared shutdown cli test', 'executor', 2, wd);
504
- const config = await readTeamConfig('shared-shutdown-cli', wd);
505
- assert.ok(config);
506
- if (!config)
507
- return;
508
- config.tmux_session = 'leader:0';
509
- config.leader_pane_id = '%11';
510
- config.hud_pane_id = '%12';
511
- config.workers[0].pane_id = '%13';
512
- config.workers[1].pane_id = '%14';
513
- await saveTeamConfig(config, wd);
514
- const result = await runNodeCli(['team', 'shutdown', 'shared-shutdown-cli', '--force'], {
515
- cwd: wd,
516
- env: {
517
- ...process.env,
518
- PATH: `${binDir}:${previousPath ?? ''}`,
519
- RCS_TEAM_STATE_ROOT: join(wd, '.rcs', 'state'),
520
- },
521
- });
522
- assert.equal(result.signal, null, `shutdown CLI received signal ${result.signal ?? 'none'}\n${result.stderr}`);
523
- assert.equal(result.code, 0, `shutdown CLI exit=${result.code}\nstdout:\n${result.stdout}\nstderr:\n${result.stderr}`);
524
- assert.match(result.stdout, /Team shutdown complete: shared-shutdown-cli/);
525
- assert.equal(existsSync(join(wd, '.rcs', 'state', 'team', 'shared-shutdown-cli')), false);
526
- const tmuxLog = await readFile(tmuxLogPath, 'utf-8');
527
- assert.match(tmuxLog, /kill-pane -t %12/);
528
- assert.match(tmuxLog, /kill-pane -t %13/);
529
- assert.match(tmuxLog, /kill-pane -t %14/);
530
- assert.doesNotMatch(tmuxLog, /kill-pane -t %11/);
531
- }
532
- finally {
533
- if (typeof previousPath === 'string')
534
- process.env.PATH = previousPath;
535
- else
536
- delete process.env.PATH;
537
- await rm(wd, { recursive: true, force: true });
538
- }
539
- });
540
- it('keeps the shutdown command alive when executed inside the leader pane PTY', { concurrency: false }, async (t) => {
541
- skipUnlessTmux(t);
542
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-shutdown-shared-in-pane-'));
543
- try {
544
- await withTempTmuxSession(async (fixture) => {
545
- const teamName = 'shared-shutdown-in-pane';
546
- const teamStateRoot = join(wd, '.rcs', 'state');
547
- const hudPaneId = runFixtureTmux(fixture, ['split-window', '-d', '-P', '-F', '#{pane_id}', '-t', fixture.windowTarget, 'sleep 300']);
548
- const workerPaneOne = runFixtureTmux(fixture, ['split-window', '-d', '-P', '-F', '#{pane_id}', '-t', fixture.windowTarget, 'sleep 300']);
549
- const workerPaneTwo = runFixtureTmux(fixture, ['split-window', '-d', '-P', '-F', '#{pane_id}', '-t', fixture.windowTarget, 'sleep 300']);
550
- await initTeamState(teamName, 'shared shutdown in-pane test', 'executor', 2, wd);
551
- const config = await readTeamConfig(teamName, wd);
552
- assert.ok(config);
553
- if (!config)
554
- return;
555
- config.tmux_session = fixture.windowTarget;
556
- config.leader_pane_id = fixture.leaderPaneId;
557
- config.hud_pane_id = hudPaneId;
558
- config.workers[0].pane_id = workerPaneOne;
559
- config.workers[1].pane_id = workerPaneTwo;
560
- await saveTeamConfig(config, wd);
561
- const result = await runNodeCli(['team', 'shutdown', teamName, '--force'], {
562
- cwd: wd,
563
- env: {
564
- ...process.env,
565
- RCS_AUTO_UPDATE: '0',
566
- RCS_TEAM_STATE_ROOT: teamStateRoot,
567
- TMUX: fixture.env.TMUX,
568
- TMUX_PANE: fixture.leaderPaneId,
569
- },
570
- });
571
- assert.equal(result.signal, null, `shutdown CLI received signal ${result.signal ?? 'none'}\n${result.stderr}`);
572
- assert.equal(result.code, 0, `shutdown CLI exit=${result.code}\nstdout:\n${result.stdout}\nstderr:\n${result.stderr}`);
573
- const stdout = result.stdout;
574
- assert.match(stdout, new RegExp(`Team shutdown complete: ${teamName}`));
575
- assert.equal(existsSync(join(teamStateRoot, 'team', teamName)), false);
576
- assert.equal(fixturePaneExists(fixture, fixture.leaderPaneId), true, 'leader pane should remain alive');
577
- // Exact HUD/worker-pane teardown is covered in runtime shutdown tests.
578
- // This CLI test owns the stable operator contract: the command must not
579
- // die by signal, it must exit 0, and explicit shutdown must remove team
580
- // state while preserving leader survival in a real tmux client context.
581
- });
582
- }
583
- finally {
584
- await rm(wd, { recursive: true, force: true });
585
- }
586
- });
587
- });
588
- describe('teamCommand api', () => {
589
- it('builds leader monitoring hints that keep team status visible while ON', () => {
590
- const hints = buildLeaderMonitoringHints('My Team');
591
- assert.equal(hints[0], 'leader_check: rcs team status my-team');
592
- assert.match(hints[1] ?? '', /while ON, keep checking state/);
593
- assert.match(hints[1] ?? '', /sleep 30 && rcs team status my-team/);
594
- });
595
- it('prints team-specific help for rcs team --help', async () => {
596
- const logs = [];
597
- const originalLog = console.log;
598
- try {
599
- console.log = (...args) => logs.push(args.map(String).join(' '));
600
- await teamCommand(['--help']);
601
- assert.equal(logs.length, 1);
602
- assert.match(logs[0] ?? '', /Usage: rcs team \[N:agent-type\]/);
603
- assert.match(logs[0] ?? '', /rcs team api <operation>/);
604
- assert.match(logs[0] ?? '', /dedicated worktrees automatically by default/);
605
- assert.match(logs[0] ?? '', /--worktree is deprecated/);
606
- assert.match(logs[0] ?? '', /tmux-runtime surface by default/);
607
- assert.match(logs[0] ?? '', /Codex App or plain outside-tmux sessions/);
608
- assert.match(logs[0] ?? '', /native Codex subagents for small in-session fanout/);
609
- }
610
- finally {
611
- console.log = originalLog;
612
- }
613
- });
614
- it('prints team-specific help for rcs team help alias', async () => {
615
- const logs = [];
616
- const originalLog = console.log;
617
- try {
618
- console.log = (...args) => logs.push(args.map(String).join(' '));
619
- await teamCommand(['help']);
620
- assert.equal(logs.length, 1);
621
- assert.match(logs[0] ?? '', /Usage: rcs team \[N:agent-type\]/);
622
- assert.match(logs[0] ?? '', /rcs team api <operation>/);
623
- assert.match(logs[0] ?? '', /dedicated worktrees automatically by default/);
624
- assert.match(logs[0] ?? '', /--worktree is deprecated/);
625
- assert.match(logs[0] ?? '', /tmux-runtime surface by default/);
626
- assert.match(logs[0] ?? '', /Codex App or plain outside-tmux sessions/);
627
- }
628
- finally {
629
- console.log = originalLog;
630
- }
631
- });
632
- it('prints team-api-specific help for rcs team api --help', async () => {
633
- const logs = [];
634
- const originalLog = console.log;
635
- try {
636
- console.log = (...args) => logs.push(args.map(String).join(' '));
637
- await teamCommand(['api', '--help']);
638
- assert.equal(logs.length, 1);
639
- assert.match(logs[0] ?? '', /Usage: rcs team api <operation>/);
640
- assert.match(logs[0] ?? '', /send-message/);
641
- assert.match(logs[0] ?? '', /transition-task-status/);
642
- assert.match(logs[0] ?? '', /read-idle-state/);
643
- assert.match(logs[0] ?? '', /read-stall-state/);
644
- }
645
- finally {
646
- console.log = originalLog;
647
- }
648
- });
649
- it('prints team-api-specific help for rcs team api help alias', async () => {
650
- const logs = [];
651
- const originalLog = console.log;
652
- try {
653
- console.log = (...args) => logs.push(args.map(String).join(' '));
654
- await teamCommand(['api', 'help']);
655
- assert.equal(logs.length, 1);
656
- assert.match(logs[0] ?? '', /Usage: rcs team api <operation>/);
657
- assert.match(logs[0] ?? '', /send-message/);
658
- assert.match(logs[0] ?? '', /transition-task-status/);
659
- }
660
- finally {
661
- console.log = originalLog;
662
- }
663
- });
664
- it('prints operation-specific help for rcs team api <operation> --help', async () => {
665
- const logs = [];
666
- const originalLog = console.log;
667
- try {
668
- console.log = (...args) => logs.push(args.map(String).join(' '));
669
- await teamCommand(['api', 'send-message', '--help']);
670
- assert.equal(logs.length, 1);
671
- assert.match(logs[0] ?? '', /Usage: rcs team api send-message --input <json> \[--json\]/);
672
- assert.match(logs[0] ?? '', /Required input fields/);
673
- assert.match(logs[0] ?? '', /from_worker/);
674
- assert.match(logs[0] ?? '', /to_worker/);
675
- assert.match(logs[0] ?? '', /body/);
676
- }
677
- finally {
678
- console.log = originalLog;
679
- }
680
- });
681
- it('prints operation-specific help for rcs team api <operation> help alias', async () => {
682
- const logs = [];
683
- const originalLog = console.log;
684
- try {
685
- console.log = (...args) => logs.push(args.map(String).join(' '));
686
- await teamCommand(['api', 'claim-task', 'help']);
687
- assert.equal(logs.length, 1);
688
- assert.match(logs[0] ?? '', /Usage: rcs team api claim-task --input <json> \[--json\]/);
689
- assert.match(logs[0] ?? '', /expected_version/);
690
- }
691
- finally {
692
- console.log = originalLog;
693
- }
694
- });
695
- it('prints event query help for rcs team api read-events help alias', async () => {
696
- const logs = [];
697
- const originalLog = console.log;
698
- try {
699
- console.log = (...args) => logs.push(args.map(String).join(' '));
700
- await teamCommand(['api', 'read-events', 'help']);
701
- assert.equal(logs.length, 1);
702
- assert.match(logs[0] ?? '', /Usage: rcs team api read-events --input <json> \[--json\]/);
703
- assert.match(logs[0] ?? '', /after_event_id/);
704
- assert.match(logs[0] ?? '', /wakeable_only/);
705
- assert.match(logs[0] ?? '', /worker_idle/);
706
- }
707
- finally {
708
- console.log = originalLog;
709
- }
710
- });
711
- it('executes read-events via CLI api with canonical JSON results', async () => {
712
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-api-read-events-'));
713
- const previousCwd = process.cwd();
714
- const logs = [];
715
- const originalLog = console.log;
716
- try {
717
- process.chdir(wd);
718
- await initTeamState('api-read-events', 'api event test', 'executor', 1, wd);
719
- await appendTeamEvent('api-read-events', {
720
- type: 'worker_idle',
721
- worker: 'worker-1',
722
- task_id: '1',
723
- prev_state: 'working',
724
- }, wd);
725
- console.log = (...args) => logs.push(args.map(String).join(' '));
726
- await teamCommand([
727
- 'api',
728
- 'read-events',
729
- '--input',
730
- JSON.stringify({
731
- team_name: 'api-read-events',
732
- type: 'worker_idle',
733
- worker: 'worker-1',
734
- task_id: '1',
735
- }),
736
- '--json',
737
- ]);
738
- assert.equal(logs.length, 1);
739
- const envelope = JSON.parse(logs[0]);
740
- assert.equal(envelope.command, 'rcs team api read-events');
741
- assert.equal(envelope.ok, true);
742
- assert.equal(envelope.operation, 'read-events');
743
- assert.equal(envelope.data?.count, 1);
744
- assert.equal(envelope.data?.events?.[0]?.type, 'worker_state_changed');
745
- assert.equal(envelope.data?.events?.[0]?.source_type, 'worker_idle');
746
- assert.equal(envelope.data?.events?.[0]?.worker, 'worker-1');
747
- assert.equal(envelope.data?.events?.[0]?.task_id, '1');
748
- }
749
- finally {
750
- console.log = originalLog;
751
- process.chdir(previousCwd);
752
- await rm(wd, { recursive: true, force: true });
753
- }
754
- });
755
- it('executes read-idle-state via CLI api with structured JSON results', async () => {
756
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-api-read-idle-state-'));
757
- const previousCwd = process.cwd();
758
- const logs = [];
759
- const originalLog = console.log;
760
- try {
761
- process.chdir(wd);
762
- await initTeamState('api-read-idle', 'api idle state test', 'executor', 2, wd);
763
- await writeMonitorSnapshot('api-read-idle', {
764
- taskStatusById: {},
765
- workerAliveByName: { 'worker-1': true, 'worker-2': true },
766
- workerStateByName: { 'worker-1': 'idle', 'worker-2': 'working' },
767
- workerTurnCountByName: { 'worker-1': 2, 'worker-2': 4 },
768
- workerTaskIdByName: { 'worker-1': '', 'worker-2': '1' },
769
- mailboxNotifiedByMessageId: {},
770
- completedEventTaskIds: {},
771
- }, wd);
772
- await appendTeamEvent('api-read-idle', {
773
- type: 'worker_idle',
774
- worker: 'worker-1',
775
- task_id: '1',
776
- prev_state: 'working',
777
- }, wd);
778
- console.log = (...args) => logs.push(args.map(String).join(' '));
779
- await teamCommand([
780
- 'api',
781
- 'read-idle-state',
782
- '--input',
783
- JSON.stringify({ team_name: 'api-read-idle' }),
784
- '--json',
785
- ]);
786
- assert.equal(logs.length, 1);
787
- const envelope = JSON.parse(logs[0]);
788
- assert.equal(envelope.command, 'rcs team api read-idle-state');
789
- assert.equal(envelope.ok, true);
790
- assert.equal(envelope.operation, 'read-idle-state');
791
- assert.equal(envelope.data?.all_workers_idle, false);
792
- assert.equal(envelope.data?.idle_worker_count, 1);
793
- assert.deepEqual(envelope.data?.idle_workers, ['worker-1']);
794
- assert.deepEqual(envelope.data?.non_idle_workers, ['worker-2']);
795
- assert.equal(envelope.data?.last_idle_transition_by_worker?.['worker-1']?.source_type, 'worker_idle');
796
- }
797
- finally {
798
- console.log = originalLog;
799
- process.chdir(previousCwd);
800
- await rm(wd, { recursive: true, force: true });
801
- }
802
- });
803
- it('executes read-stall-state via CLI api with structured JSON results', async () => {
804
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-api-read-stall-state-'));
805
- const previousCwd = process.cwd();
806
- const previousTeamStateRoot = process.env.RCS_TEAM_STATE_ROOT;
807
- const logs = [];
808
- const originalLog = console.log;
809
- try {
810
- delete process.env.RCS_TEAM_STATE_ROOT;
811
- process.chdir(wd);
812
- await initTeamState('api-read-stall', 'api stall state test', 'executor', 2, wd);
813
- const task = await createTask('api-read-stall', {
814
- subject: 'Pending work',
815
- description: 'Needs leader attention',
816
- status: 'pending',
817
- }, wd);
818
- await writeWorkerStatus('api-read-stall', 'worker-1', {
819
- state: 'working',
820
- current_task_id: task.id,
821
- updated_at: '2026-03-10T10:00:00.000Z',
822
- }, wd);
823
- await writeWorkerStatus('api-read-stall', 'worker-2', {
824
- state: 'idle',
825
- updated_at: '2026-03-10T10:00:00.000Z',
826
- }, wd);
827
- await updateWorkerHeartbeat('api-read-stall', 'worker-1', {
828
- alive: true,
829
- pid: 201,
830
- turn_count: 1,
831
- last_turn_at: '2026-03-10T10:00:00.000Z',
832
- }, wd);
833
- await updateWorkerHeartbeat('api-read-stall', 'worker-2', {
834
- alive: true,
835
- pid: 202,
836
- turn_count: 1,
837
- last_turn_at: '2026-03-10T10:00:00.000Z',
838
- }, wd);
839
- console.log = (...args) => logs.push(args.map(String).join(' '));
840
- await teamCommand([
841
- 'api',
842
- 'get-summary',
843
- '--input',
844
- JSON.stringify({ team_name: 'api-read-stall' }),
845
- '--json',
846
- ]);
847
- logs.length = 0;
848
- await updateWorkerHeartbeat('api-read-stall', 'worker-1', {
849
- alive: true,
850
- pid: 201,
851
- turn_count: 8,
852
- last_turn_at: '2026-03-10T10:05:00.000Z',
853
- }, wd);
854
- await writeMonitorSnapshot('api-read-stall', {
855
- taskStatusById: { [task.id]: 'pending' },
856
- workerAliveByName: { 'worker-1': true, 'worker-2': true },
857
- workerStateByName: { 'worker-1': 'idle', 'worker-2': 'idle' },
858
- workerTurnCountByName: { 'worker-1': 8, 'worker-2': 1 },
859
- workerTaskIdByName: { 'worker-1': task.id, 'worker-2': '' },
860
- mailboxNotifiedByMessageId: {},
861
- completedEventTaskIds: {},
862
- }, wd);
863
- await mkdir(join(wd, '.rcs', 'state', 'team', 'api-read-stall'), { recursive: true });
864
- await writeFile(join(wd, '.rcs', 'state', 'team', 'api-read-stall', 'leader-attention.json'), JSON.stringify({
865
- team_name: 'api-read-stall',
866
- updated_at: '2026-03-10T10:05:00.000Z',
867
- source: 'native_stop',
868
- leader_decision_state: 'still_actionable',
869
- leader_attention_pending: true,
870
- leader_attention_reason: 'leader_session_stopped',
871
- attention_reasons: ['leader_session_stopped'],
872
- leader_stale: false,
873
- leader_session_active: false,
874
- leader_session_id: 'leader-session-1',
875
- leader_session_stopped_at: '2026-03-10T10:05:00.000Z',
876
- unread_leader_message_count: 1,
877
- work_remaining: true,
878
- stalled_for_ms: null,
879
- }, null, 2));
880
- await teamCommand([
881
- 'api',
882
- 'read-stall-state',
883
- '--input',
884
- JSON.stringify({ team_name: 'api-read-stall' }),
885
- '--json',
886
- ]);
887
- assert.equal(logs.length, 1);
888
- const envelope = JSON.parse(logs[0]);
889
- assert.equal(envelope.command, 'rcs team api read-stall-state');
890
- assert.equal(envelope.ok, true);
891
- assert.equal(envelope.operation, 'read-stall-state');
892
- assert.equal(envelope.data?.team_stalled, true);
893
- assert.equal(envelope.data?.leader_stale, true);
894
- assert.deepEqual(envelope.data?.stalled_workers, ['worker-1']);
895
- assert.match((envelope.data?.reasons ?? []).join(' '), /leader_attention_pending:leader_session_stopped/);
896
- }
897
- finally {
898
- if (typeof previousTeamStateRoot === 'string')
899
- process.env.RCS_TEAM_STATE_ROOT = previousTeamStateRoot;
900
- else
901
- delete process.env.RCS_TEAM_STATE_ROOT;
902
- console.log = originalLog;
903
- process.chdir(previousCwd);
904
- await rm(wd, { recursive: true, force: true });
905
- }
906
- });
907
- it('executes CLI interop operation with stable JSON envelope', async () => {
908
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-api-'));
909
- const previousCwd = process.cwd();
910
- const logs = [];
911
- const originalLog = console.log;
912
- try {
913
- process.chdir(wd);
914
- await initTeamState('api-team', 'api test', 'executor', 1, wd);
915
- console.log = (...args) => logs.push(args.map(String).join(' '));
916
- await teamCommand([
917
- 'api',
918
- 'send-message',
919
- '--input',
920
- JSON.stringify({
921
- team_name: 'api-team',
922
- from_worker: 'worker-1',
923
- to_worker: 'leader-fixed',
924
- body: 'ACK',
925
- }),
926
- '--json',
927
- ]);
928
- assert.equal(logs.length, 1);
929
- const envelope = JSON.parse(logs[0]);
930
- assert.equal(envelope.schema_version, '1.0');
931
- assert.equal(typeof envelope.timestamp, 'string');
932
- assert.equal(envelope.command, 'rcs team api send-message');
933
- assert.equal(envelope.ok, true);
934
- assert.equal(envelope.operation, 'send-message');
935
- assert.equal(envelope.data?.message?.body, 'ACK');
936
- }
937
- finally {
938
- console.log = originalLog;
939
- process.chdir(previousCwd);
940
- await rm(wd, { recursive: true, force: true });
941
- }
942
- });
943
- it('returns deterministic JSON errors for invalid api usage with --json', async () => {
944
- const logs = [];
945
- const originalLog = console.log;
946
- try {
947
- console.log = (...args) => logs.push(args.map(String).join(' '));
948
- process.exitCode = 0;
949
- await teamCommand(['api', 'unknown-operation', '--json']);
950
- assert.equal(logs.length, 1);
951
- const envelope = JSON.parse(logs[0]);
952
- assert.equal(envelope.schema_version, '1.0');
953
- assert.equal(typeof envelope.timestamp, 'string');
954
- assert.equal(envelope.command, 'rcs team api');
955
- assert.equal(envelope.ok, false);
956
- assert.equal(envelope.operation, 'unknown');
957
- assert.equal(envelope.error?.code, 'invalid_input');
958
- assert.match(envelope.error?.message ?? '', /Usage: rcs team api/);
959
- assert.equal(process.exitCode, 1);
960
- }
961
- finally {
962
- console.log = originalLog;
963
- process.exitCode = 0;
964
- }
965
- });
966
- it('supports claim-safe lifecycle via CLI api (create -> claim -> transition)', async () => {
967
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-api-lifecycle-'));
968
- const previousCwd = process.cwd();
969
- const logs = [];
970
- const originalLog = console.log;
971
- try {
972
- process.chdir(wd);
973
- await initTeamState('lifecycle-team', 'lifecycle test', 'executor', 1, wd);
974
- console.log = (...args) => logs.push(args.map(String).join(' '));
975
- await teamCommand([
976
- 'api',
977
- 'create-task',
978
- '--input',
979
- JSON.stringify({
980
- team_name: 'lifecycle-team',
981
- subject: 'Lifecycle task',
982
- description: 'Created through CLI interop',
983
- }),
984
- '--json',
985
- ]);
986
- const created = JSON.parse(logs.at(-1) ?? '{}');
987
- assert.equal(created.ok, true);
988
- const taskId = created.data?.task?.id;
989
- assert.equal(typeof taskId, 'string');
990
- await teamCommand([
991
- 'api',
992
- 'claim-task',
993
- '--input',
994
- JSON.stringify({
995
- team_name: 'lifecycle-team',
996
- task_id: taskId,
997
- worker: 'worker-1',
998
- expected_version: 1,
999
- }),
1000
- '--json',
1001
- ]);
1002
- const claimed = JSON.parse(logs.at(-1) ?? '{}');
1003
- assert.equal(claimed.ok, true);
1004
- const claimToken = claimed.data?.claimToken;
1005
- assert.equal(typeof claimToken, 'string');
1006
- await teamCommand([
1007
- 'api',
1008
- 'transition-task-status',
1009
- '--input',
1010
- JSON.stringify({
1011
- team_name: 'lifecycle-team',
1012
- task_id: taskId,
1013
- from: 'in_progress',
1014
- to: 'completed',
1015
- claim_token: claimToken,
1016
- }),
1017
- '--json',
1018
- ]);
1019
- const transitioned = JSON.parse(logs.at(-1) ?? '{}');
1020
- assert.equal(transitioned.ok, true);
1021
- assert.equal(transitioned.data?.ok, true);
1022
- assert.equal(transitioned.data?.task?.status, 'completed');
1023
- }
1024
- finally {
1025
- console.log = originalLog;
1026
- process.chdir(previousCwd);
1027
- await rm(wd, { recursive: true, force: true });
1028
- }
1029
- });
1030
- it('accepts new canonical event types via CLI api append-event', async () => {
1031
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-api-event-'));
1032
- const previousCwd = process.cwd();
1033
- const logs = [];
1034
- const originalLog = console.log;
1035
- try {
1036
- process.chdir(wd);
1037
- await initTeamState('event-team', 'event test', 'executor', 1, wd);
1038
- console.log = (...args) => logs.push(args.map(String).join(' '));
1039
- await teamCommand([
1040
- 'api',
1041
- 'append-event',
1042
- '--input',
1043
- JSON.stringify({
1044
- team_name: 'event-team',
1045
- type: 'leader_notification_deferred',
1046
- worker: 'worker-1',
1047
- to_worker: 'leader-fixed',
1048
- source_type: 'worker_idle',
1049
- reason: 'leader_pane_missing_no_injection',
1050
- }),
1051
- '--json',
1052
- ]);
1053
- const envelope = JSON.parse(logs.at(-1) ?? '{}');
1054
- assert.equal(envelope.ok, true);
1055
- assert.equal(envelope.data?.event?.type, 'leader_notification_deferred');
1056
- assert.equal(envelope.data?.event?.to_worker, 'leader-fixed');
1057
- assert.equal(envelope.data?.event?.source_type, 'worker_idle');
1058
- assert.equal(envelope.data?.event?.reason, 'leader_pane_missing_no_injection');
1059
- }
1060
- finally {
1061
- console.log = originalLog;
1062
- process.chdir(previousCwd);
1063
- await rm(wd, { recursive: true, force: true });
1064
- }
1065
- });
1066
- });
1067
- describe('teamCommand status', () => {
1068
- it('prints pane ids and raw inspect hints when tmux panes are recorded', async () => {
1069
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-status-panes-'));
1070
- const previousCwd = process.cwd();
1071
- const logs = [];
1072
- const originalLog = console.log;
1073
- try {
1074
- process.chdir(wd);
1075
- const config = await withoutTeamTestWorkerEnv(() => initTeamState('pane-team', 'inspect worker panes', 'executor', 2, wd));
1076
- await withoutTeamTestWorkerEnv(() => createTask('pane-team', {
1077
- subject: 'Recover worker-1 progress',
1078
- description: 'Inspect worker-1 pane',
1079
- status: 'pending',
1080
- version: 3,
1081
- requires_code_change: true,
1082
- role: 'debugger',
1083
- owner: 'worker-1',
1084
- }, wd));
1085
- await withoutTeamTestWorkerEnv(() => createTask('pane-team', {
1086
- subject: 'Recover worker-2 progress',
1087
- description: 'Inspect worker-2 pane',
1088
- status: 'pending',
1089
- version: 4,
1090
- requires_code_change: false,
1091
- blocked_by: ['1'],
1092
- depends_on: ['1'],
1093
- role: 'test-engineer',
1094
- owner: 'worker-2',
1095
- result: 'waiting on worker-1',
1096
- error: 'blocked by dependency',
1097
- }, wd));
1098
- await writeFile(join(wd, '.rcs', 'state', 'team', 'pane-team', 'tasks', 'task-1.json'), `${JSON.stringify({
1099
- ...JSON.parse(await readFile(join(wd, '.rcs', 'state', 'team', 'pane-team', 'tasks', 'task-1.json'), 'utf-8')),
1100
- created_at: '2026-03-10T23:55:00.000Z',
1101
- claim: {
1102
- owner: 'worker-1',
1103
- token: 'claim-token-1',
1104
- leased_until: '2026-03-11T00:10:00.000Z',
1105
- },
1106
- }, null, 2)}\n`);
1107
- await writeFile(join(wd, '.rcs', 'state', 'team', 'pane-team', 'tasks', 'task-2.json'), `${JSON.stringify({
1108
- ...JSON.parse(await readFile(join(wd, '.rcs', 'state', 'team', 'pane-team', 'tasks', 'task-2.json'), 'utf-8')),
1109
- created_at: '2026-03-10T23:56:00.000Z',
1110
- completed_at: '2026-03-11T00:06:00.000Z',
1111
- }, null, 2)}\n`);
1112
- config.workers[0].worker_cli = 'codex';
1113
- config.workers[1].worker_cli = 'gemini';
1114
- config.workers[0].pid = 101;
1115
- config.workers[1].pid = 102;
1116
- config.workers[0].assigned_tasks = ['1'];
1117
- config.workers[1].assigned_tasks = ['2', '3'];
1118
- config.leader_pane_id = '%10';
1119
- config.hud_pane_id = '%11';
1120
- config.workers[0].pane_id = '%21';
1121
- config.workers[1].pane_id = '%22';
1122
- config.workers[0].working_dir = '/tmp/pane-team/worker-1';
1123
- config.workers[1].working_dir = '/tmp/pane-team/worker-2';
1124
- config.workers[0].worktree_repo_root = '/tmp/pane-team/repo';
1125
- config.workers[1].worktree_repo_root = '/tmp/pane-team/repo';
1126
- config.workers[0].team_state_root = '/tmp/pane-team/.rcs/state';
1127
- config.workers[1].team_state_root = '/tmp/pane-team/.rcs/state';
1128
- config.workers[0].worktree_path = '/tmp/pane-team/worktrees/worker-1';
1129
- config.workers[1].worktree_path = '/tmp/pane-team/worktrees/worker-2';
1130
- config.workers[0].worktree_branch = 'feat/pane-team-worker-1';
1131
- config.workers[1].worktree_branch = 'feat/pane-team-worker-2';
1132
- config.workers[0].worktree_detached = false;
1133
- config.workers[1].worktree_detached = true;
1134
- config.workers[0].worktree_created = true;
1135
- config.workers[1].worktree_created = false;
1136
- await writeWorkerStatus('pane-team', 'worker-1', {
1137
- state: 'working',
1138
- current_task_id: '1',
1139
- reason: 'recovering progress',
1140
- updated_at: '2026-03-11T00:00:00.000Z',
1141
- }, wd);
1142
- await writeWorkerStatus('pane-team', 'worker-2', {
1143
- state: 'blocked',
1144
- current_task_id: '2',
1145
- reason: 'waiting for dependency 1',
1146
- updated_at: '2026-03-11T00:00:00.000Z',
1147
- }, wd);
1148
- await updateWorkerHeartbeat('pane-team', 'worker-1', {
1149
- pid: 101,
1150
- last_turn_at: '2026-03-11T00:01:00.000Z',
1151
- turn_count: 3,
1152
- alive: false,
1153
- }, wd);
1154
- await updateWorkerHeartbeat('pane-team', 'worker-2', {
1155
- pid: 102,
1156
- last_turn_at: '2026-03-11T00:02:00.000Z',
1157
- turn_count: 4,
1158
- alive: false,
1159
- }, wd);
1160
- await writeTaskApproval('pane-team', {
1161
- task_id: '1',
1162
- required: true,
1163
- status: 'approved',
1164
- reviewer: 'leader-fixed',
1165
- decision_reason: 'Looks good',
1166
- decided_at: '2026-03-11T00:05:00.000Z',
1167
- }, wd);
1168
- const manifestPath = join(wd, '.rcs', 'state', 'team', 'pane-team', 'manifest.v2.json');
1169
- const manifest = JSON.parse(await readFile(manifestPath, 'utf-8'));
1170
- manifest.leader_pane_id = config.leader_pane_id;
1171
- manifest.hud_pane_id = config.hud_pane_id;
1172
- manifest.workers = config.workers.map((worker) => ({
1173
- ...worker,
1174
- pane_id: worker.pane_id,
1175
- }));
1176
- await writeFile(join(wd, '.rcs', 'state', 'team', 'pane-team', 'config.json'), `${JSON.stringify(config, null, 2)}\n`);
1177
- await writeFile(manifestPath, `${JSON.stringify(manifest, null, 2)}\n`);
1178
- console.log = (...args) => logs.push(args.map(String).join(' '));
1179
- await withoutTeamTestWorkerEnv(() => teamCommand(['status', 'pane-team']));
1180
- const output = logs.join('\n');
1181
- assert.match(output, /panes: leader=%10 hud=%11/);
1182
- assert.match(output, /worker_panes: worker-1=%21 worker-2=%22/);
1183
- assert.match(output, /inspect_hint: raw tmux capture commands are quota-free/);
1184
- assert.match(output, /inspect_leader: tmux capture-pane -p -t %10 -S -400/);
1185
- assert.match(output, /inspect_hud: tmux capture-pane -p -t %11 -S -400/);
1186
- assert.match(output, /inspect_worker-1: tmux capture-pane -p -t %21 -S -400/);
1187
- assert.match(output, /inspect_worker-2: tmux capture-pane -p -t %22 -S -400/);
1188
- assert.match(output, /inspect_summary: .*command=tmux capture-pane -p -t %21 -S -400/);
1189
- assert.doesNotMatch(output
1190
- .split('\n')
1191
- .filter((line) => !line.includes('--model-inspect'))
1192
- .join('\n'), /rcs sparkshell/);
1193
- logs.length = 0;
1194
- await withoutTeamTestWorkerEnv(() => teamCommand(['status', 'pane-team', '--model-inspect']));
1195
- const modelInspectOutput = logs.join('\n');
1196
- assert.match(modelInspectOutput, /inspect_summary: .*command=rcs sparkshell --tmux-pane %21 --tail-lines 400/);
1197
- }
1198
- finally {
1199
- console.log = originalLog;
1200
- process.chdir(previousCwd);
1201
- await rm(wd, { recursive: true, force: true });
1202
- }
1203
- });
1204
- it('returns pane ids and sparkshell hint in JSON mode', async () => {
1205
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-status-json-'));
1206
- const previousCwd = process.cwd();
1207
- const previousTeamStateRoot = process.env.RCS_TEAM_STATE_ROOT;
1208
- const logs = [];
1209
- const originalLog = console.log;
1210
- try {
1211
- delete process.env.RCS_TEAM_STATE_ROOT;
1212
- process.chdir(wd);
1213
- const config = await withoutTeamTestWorkerEnv(() => initTeamState('pane-json-team', 'inspect worker panes', 'executor', 1, wd));
1214
- await withoutTeamTestWorkerEnv(() => createTask('pane-json-team', {
1215
- subject: 'Recover worker-1 progress',
1216
- description: 'Inspect worker-1 pane',
1217
- status: 'pending',
1218
- version: 7,
1219
- requires_code_change: true,
1220
- role: 'debugger',
1221
- owner: 'worker-1',
1222
- }, wd));
1223
- await writeFile(join(wd, '.rcs', 'state', 'team', 'pane-json-team', 'tasks', 'task-1.json'), `${JSON.stringify({
1224
- ...JSON.parse(await readFile(join(wd, '.rcs', 'state', 'team', 'pane-json-team', 'tasks', 'task-1.json'), 'utf-8')),
1225
- created_at: '2026-03-10T23:57:00.000Z',
1226
- claim: {
1227
- owner: 'worker-1',
1228
- token: 'claim-token-1',
1229
- leased_until: '2026-03-11T00:11:00.000Z',
1230
- },
1231
- }, null, 2)}\n`);
1232
- config.workers[0].worker_cli = 'claude';
1233
- config.workers[0].pid = 201;
1234
- config.workers[0].assigned_tasks = ['1', 'extra-2'];
1235
- config.leader_pane_id = '%30';
1236
- config.hud_pane_id = '%31';
1237
- config.workers[0].pane_id = '%41';
1238
- config.workers[0].working_dir = '/tmp/pane-json-team/worker-1';
1239
- config.workers[0].worktree_repo_root = '/tmp/pane-json-team/repo';
1240
- config.workers[0].team_state_root = '/tmp/pane-json-team/.rcs/state';
1241
- config.workers[0].worktree_path = '/tmp/pane-json-team/worktrees/worker-1';
1242
- config.workers[0].worktree_branch = 'feat/pane-json-team-worker-1';
1243
- config.workers[0].worktree_detached = false;
1244
- config.workers[0].worktree_created = true;
1245
- await writeWorkerStatus('pane-json-team', 'worker-1', {
1246
- state: 'working',
1247
- current_task_id: '1',
1248
- reason: 'recovering progress',
1249
- updated_at: '2026-03-11T00:00:00.000Z',
1250
- }, wd);
1251
- await updateWorkerHeartbeat('pane-json-team', 'worker-1', {
1252
- pid: 201,
1253
- last_turn_at: '2026-03-11T00:03:00.000Z',
1254
- turn_count: 5,
1255
- alive: false,
1256
- }, wd);
1257
- await writeTaskApproval('pane-json-team', {
1258
- task_id: '1',
1259
- required: true,
1260
- status: 'approved',
1261
- reviewer: 'leader-fixed',
1262
- decision_reason: 'Looks good',
1263
- decided_at: '2026-03-11T00:05:00.000Z',
1264
- }, wd);
1265
- const manifestPath = join(wd, '.rcs', 'state', 'team', 'pane-json-team', 'manifest.v2.json');
1266
- const manifest = JSON.parse(await readFile(manifestPath, 'utf-8'));
1267
- manifest.leader_pane_id = config.leader_pane_id;
1268
- manifest.hud_pane_id = config.hud_pane_id;
1269
- manifest.workers = config.workers.map((worker) => ({
1270
- ...worker,
1271
- pane_id: worker.pane_id,
1272
- }));
1273
- await writeFile(join(wd, '.rcs', 'state', 'team', 'pane-json-team', 'config.json'), `${JSON.stringify(config, null, 2)}\n`);
1274
- await writeFile(manifestPath, `${JSON.stringify(manifest, null, 2)}\n`);
1275
- console.log = (...args) => logs.push(args.map(String).join(' '));
1276
- await withoutTeamTestWorkerEnv(() => teamCommand(['status', 'pane-json-team', '--json']));
1277
- const payload = JSON.parse(logs.at(-1) ?? '{}');
1278
- const expectedWd = process.platform === 'darwin' && wd.startsWith('/var/')
1279
- ? `/private${wd}`
1280
- : wd;
1281
- assert.equal(payload.schema_version, '1.0');
1282
- assert.equal(typeof payload.timestamp, 'string');
1283
- assert.equal(payload.command, 'rcs team status');
1284
- assert.equal(payload.team_name, 'pane-json-team');
1285
- assert.equal(payload.status, 'ok');
1286
- assert.deepEqual(payload.dead_workers, ['worker-1']);
1287
- assert.deepEqual(payload.non_reporting_workers, []);
1288
- assert.deepEqual(payload.panes?.recommended_inspect_targets, ['worker-1']);
1289
- assert.deepEqual(payload.panes?.recommended_inspect_reasons, { 'worker-1': 'dead_worker' });
1290
- assert.deepEqual(payload.panes?.recommended_inspect_clis, { 'worker-1': 'claude' });
1291
- assert.deepEqual(payload.panes?.recommended_inspect_roles, { 'worker-1': 'executor' });
1292
- assert.deepEqual(payload.panes?.recommended_inspect_indexes, { 'worker-1': 1 });
1293
- assert.deepEqual(payload.panes?.recommended_inspect_alive, { 'worker-1': false });
1294
- assert.deepEqual(payload.panes?.recommended_inspect_turn_counts, { 'worker-1': 5 });
1295
- assert.deepEqual(payload.panes?.recommended_inspect_turns_without_progress, { 'worker-1': 0 });
1296
- assert.deepEqual(payload.panes?.recommended_inspect_last_turn_at, { 'worker-1': '2026-03-11T00:03:00.000Z' });
1297
- assert.deepEqual(payload.panes?.recommended_inspect_status_updated_at, { 'worker-1': '2026-03-11T00:00:00.000Z' });
1298
- assert.deepEqual(payload.panes?.recommended_inspect_pids, { 'worker-1': 201 });
1299
- assert.deepEqual(payload.panes?.recommended_inspect_worktree_paths, { 'worker-1': '/tmp/pane-json-team/worktrees/worker-1' });
1300
- assert.deepEqual(payload.panes?.recommended_inspect_worktree_repo_roots, { 'worker-1': '/tmp/pane-json-team/repo' });
1301
- assert.deepEqual(payload.panes?.recommended_inspect_worktree_branches, { 'worker-1': 'feat/pane-json-team-worker-1' });
1302
- assert.deepEqual(payload.panes?.recommended_inspect_worktree_detached, { 'worker-1': false });
1303
- assert.deepEqual(payload.panes?.recommended_inspect_worktree_created, { 'worker-1': true });
1304
- assert.deepEqual(payload.panes?.recommended_inspect_team_state_roots, { 'worker-1': '/tmp/pane-json-team/.rcs/state' });
1305
- assert.deepEqual(payload.panes?.recommended_inspect_workdirs, { 'worker-1': '/tmp/pane-json-team/worker-1' });
1306
- assert.deepEqual(payload.panes?.recommended_inspect_assigned_tasks, { 'worker-1': ['1', 'extra-2'] });
1307
- assert.deepEqual(payload.panes?.recommended_inspect_task_statuses, { 'worker-1': 'pending' });
1308
- assert.deepEqual(payload.panes?.recommended_inspect_task_results, { 'worker-1': null });
1309
- assert.deepEqual(payload.panes?.recommended_inspect_task_errors, { 'worker-1': null });
1310
- assert.deepEqual(payload.panes?.recommended_inspect_task_versions, { 'worker-1': 1 });
1311
- assert.deepEqual(payload.panes?.recommended_inspect_task_created_at, { 'worker-1': '2026-03-10T23:57:00.000Z' });
1312
- assert.deepEqual(payload.panes?.recommended_inspect_task_completed_at, { 'worker-1': null });
1313
- assert.deepEqual(payload.panes?.recommended_inspect_task_depends_on, { 'worker-1': [] });
1314
- assert.deepEqual(payload.panes?.recommended_inspect_task_claim_present, { 'worker-1': true });
1315
- assert.deepEqual(payload.panes?.recommended_inspect_task_claim_owners, { 'worker-1': 'worker-1' });
1316
- assert.deepEqual(payload.panes?.recommended_inspect_task_claim_tokens, { 'worker-1': 'claim-token-1' });
1317
- assert.deepEqual(payload.panes?.recommended_inspect_task_claim_leases, { 'worker-1': '2026-03-11T00:11:00.000Z' });
1318
- assert.deepEqual(payload.panes?.recommended_inspect_approval_required, { 'worker-1': true });
1319
- assert.deepEqual(payload.panes?.recommended_inspect_requires_code_change, { 'worker-1': true });
1320
- assert.deepEqual(payload.panes?.recommended_inspect_descriptions, { 'worker-1': 'Inspect worker-1 pane' });
1321
- assert.deepEqual(payload.panes?.recommended_inspect_blocked_by, { 'worker-1': [] });
1322
- assert.deepEqual(payload.panes?.recommended_inspect_task_roles, { 'worker-1': 'debugger' });
1323
- assert.deepEqual(payload.panes?.recommended_inspect_task_owners, { 'worker-1': 'worker-1' });
1324
- assert.deepEqual(payload.panes?.recommended_inspect_approval_statuses, { 'worker-1': 'approved' });
1325
- assert.deepEqual(payload.panes?.recommended_inspect_approval_reviewers, { 'worker-1': 'leader-fixed' });
1326
- assert.deepEqual(payload.panes?.recommended_inspect_approval_reasons, { 'worker-1': 'Looks good' });
1327
- assert.deepEqual(payload.panes?.recommended_inspect_approval_decided_at, { 'worker-1': '2026-03-11T00:05:00.000Z' });
1328
- assert.deepEqual(payload.panes?.recommended_inspect_approval_record_present, { 'worker-1': true });
1329
- assert.deepEqual(payload.panes?.recommended_inspect_states, { 'worker-1': 'working' });
1330
- assert.deepEqual(payload.panes?.recommended_inspect_state_reasons, { 'worker-1': 'recovering progress' });
1331
- assert.deepEqual(payload.panes?.recommended_inspect_tasks, { 'worker-1': '1' });
1332
- assert.deepEqual(payload.panes?.recommended_inspect_subjects, { 'worker-1': 'Recover worker-1 progress' });
1333
- assert.deepEqual(payload.panes?.recommended_inspect_task_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/tasks/task-1.json` });
1334
- assert.deepEqual(payload.panes?.recommended_inspect_approval_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/approvals/task-1.json` });
1335
- assert.deepEqual(payload.panes?.recommended_inspect_worker_state_dirs, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1` });
1336
- assert.deepEqual(payload.panes?.recommended_inspect_worker_status_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1/status.json` });
1337
- assert.deepEqual(payload.panes?.recommended_inspect_worker_heartbeat_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1/heartbeat.json` });
1338
- assert.deepEqual(payload.panes?.recommended_inspect_worker_identity_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1/identity.json` });
1339
- assert.deepEqual(payload.panes?.recommended_inspect_worker_inbox_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1/inbox.md` });
1340
- assert.deepEqual(payload.panes?.recommended_inspect_worker_mailbox_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/mailbox/worker-1.json` });
1341
- assert.deepEqual(payload.panes?.recommended_inspect_worker_shutdown_request_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1/shutdown-request.json` });
1342
- assert.deepEqual(payload.panes?.recommended_inspect_worker_shutdown_ack_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1/shutdown-ack.json` });
1343
- assert.deepEqual(payload.panes?.recommended_inspect_team_dir_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team` });
1344
- assert.deepEqual(payload.panes?.recommended_inspect_team_config_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/config.json` });
1345
- assert.deepEqual(payload.panes?.recommended_inspect_team_manifest_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/manifest.v2.json` });
1346
- assert.deepEqual(payload.panes?.recommended_inspect_team_events_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/events/events.ndjson` });
1347
- assert.deepEqual(payload.panes?.recommended_inspect_team_dispatch_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/dispatch/requests.json` });
1348
- assert.deepEqual(payload.panes?.recommended_inspect_team_phase_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/phase.json` });
1349
- assert.deepEqual(payload.panes?.recommended_inspect_team_monitor_snapshot_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/monitor-snapshot.json` });
1350
- assert.deepEqual(payload.panes?.recommended_inspect_team_summary_snapshot_paths, { 'worker-1': `${expectedWd}/.rcs/state/team/pane-json-team/summary-snapshot.json` });
1351
- assert.deepEqual(payload.panes?.recommended_inspect_panes, { 'worker-1': '%41' });
1352
- assert.equal(payload.panes?.recommended_inspect_command, 'rcs sparkshell --tmux-pane %41 --tail-lines 400');
1353
- assert.deepEqual(payload.panes?.recommended_inspect_commands, ['rcs sparkshell --tmux-pane %41 --tail-lines 400']);
1354
- assert.equal(payload.panes?.recommended_inspect_summary, 'target=worker-1 pane=%41 cli=claude role=executor alive=false turn_count=5 turns_without_progress=0 reason=dead_worker state=working task=1 subject=Recover worker-1 progress command=rcs sparkshell --tmux-pane %41 --tail-lines 400');
1355
- assert.deepEqual(payload.panes?.recommended_inspect_items, [{
1356
- target: 'worker-1',
1357
- pane_id: '%41',
1358
- worker_cli: 'claude',
1359
- role: 'executor',
1360
- index: 1,
1361
- alive: false,
1362
- turn_count: 5,
1363
- turns_without_progress: 0,
1364
- last_turn_at: '2026-03-11T00:03:00.000Z',
1365
- status_updated_at: '2026-03-11T00:00:00.000Z',
1366
- pid: 201,
1367
- worktree_repo_root: '/tmp/pane-json-team/repo',
1368
- worktree_path: '/tmp/pane-json-team/worktrees/worker-1',
1369
- worktree_branch: 'feat/pane-json-team-worker-1',
1370
- worktree_detached: false,
1371
- worktree_created: true,
1372
- team_state_root: '/tmp/pane-json-team/.rcs/state',
1373
- working_dir: '/tmp/pane-json-team/worker-1',
1374
- assigned_tasks: ['1', 'extra-2'],
1375
- task_status: 'pending',
1376
- task_result: null,
1377
- task_error: null,
1378
- task_version: 1,
1379
- task_created_at: '2026-03-10T23:57:00.000Z',
1380
- task_completed_at: null,
1381
- task_depends_on: [],
1382
- task_claim_present: true,
1383
- task_claim_owner: 'worker-1',
1384
- task_claim_token: 'claim-token-1',
1385
- task_claim_leased_until: '2026-03-11T00:11:00.000Z',
1386
- task_claim_lock_path: `${expectedWd}/.rcs/state/team/pane-json-team/claims/task-1.lock`,
1387
- approval_required: true,
1388
- requires_code_change: true,
1389
- task_description: 'Inspect worker-1 pane',
1390
- blocked_by: [],
1391
- task_role: 'debugger',
1392
- task_owner: 'worker-1',
1393
- approval_status: 'approved',
1394
- approval_reviewer: 'leader-fixed',
1395
- approval_reason: 'Looks good',
1396
- approval_decided_at: '2026-03-11T00:05:00.000Z',
1397
- approval_record_present: true,
1398
- reason: 'dead_worker',
1399
- state: 'working',
1400
- state_reason: 'recovering progress',
1401
- task_id: '1',
1402
- task_subject: 'Recover worker-1 progress',
1403
- task_path: `${expectedWd}/.rcs/state/team/pane-json-team/tasks/task-1.json`,
1404
- approval_path: `${expectedWd}/.rcs/state/team/pane-json-team/approvals/task-1.json`,
1405
- worker_state_dir: `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1`,
1406
- worker_status_path: `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1/status.json`,
1407
- worker_heartbeat_path: `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1/heartbeat.json`,
1408
- worker_identity_path: `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1/identity.json`,
1409
- worker_inbox_path: `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1/inbox.md`,
1410
- worker_mailbox_path: `${expectedWd}/.rcs/state/team/pane-json-team/mailbox/worker-1.json`,
1411
- worker_shutdown_request_path: `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1/shutdown-request.json`,
1412
- worker_shutdown_ack_path: `${expectedWd}/.rcs/state/team/pane-json-team/workers/worker-1/shutdown-ack.json`,
1413
- team_dir_path: `${expectedWd}/.rcs/state/team/pane-json-team`,
1414
- team_config_path: `${expectedWd}/.rcs/state/team/pane-json-team/config.json`,
1415
- team_manifest_path: `${expectedWd}/.rcs/state/team/pane-json-team/manifest.v2.json`,
1416
- team_events_path: `${expectedWd}/.rcs/state/team/pane-json-team/events/events.ndjson`,
1417
- team_dispatch_path: `${expectedWd}/.rcs/state/team/pane-json-team/dispatch/requests.json`,
1418
- team_phase_path: `${expectedWd}/.rcs/state/team/pane-json-team/phase.json`,
1419
- team_monitor_snapshot_path: `${expectedWd}/.rcs/state/team/pane-json-team/monitor-snapshot.json`,
1420
- team_summary_snapshot_path: `${expectedWd}/.rcs/state/team/pane-json-team/summary-snapshot.json`,
1421
- command: 'rcs sparkshell --tmux-pane %41 --tail-lines 400',
1422
- }]);
1423
- assert.equal(payload.panes?.leader_pane_id, '%30');
1424
- assert.equal(payload.panes?.hud_pane_id, '%31');
1425
- assert.deepEqual(payload.panes?.worker_panes, { 'worker-1': '%41' });
1426
- assert.equal(payload.panes?.sparkshell_hint, 'rcs sparkshell --tmux-pane <pane-id> --tail-lines 400');
1427
- assert.deepEqual(payload.panes?.sparkshell_commands, {
1428
- leader: 'rcs sparkshell --tmux-pane %30 --tail-lines 400',
1429
- hud: 'rcs sparkshell --tmux-pane %31 --tail-lines 400',
1430
- 'worker-1': 'rcs sparkshell --tmux-pane %41 --tail-lines 400',
1431
- });
1432
- }
1433
- finally {
1434
- if (typeof previousTeamStateRoot === 'string')
1435
- process.env.RCS_TEAM_STATE_ROOT = previousTeamStateRoot;
1436
- else
1437
- delete process.env.RCS_TEAM_STATE_ROOT;
1438
- console.log = originalLog;
1439
- process.chdir(previousCwd);
1440
- await rm(wd, { recursive: true, force: true });
1441
- }
1442
- });
1443
- it('prints workspace_mode in text status output when present', async () => {
1444
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-status-workspace-mode-'));
1445
- const previousCwd = process.cwd();
1446
- const logs = [];
1447
- const originalLog = console.log;
1448
- try {
1449
- process.chdir(wd);
1450
- const config = await withoutTeamTestWorkerEnv(() => initTeamState('workspace-mode-team', 'inspect workspace mode', 'executor', 1, wd));
1451
- config.workspace_mode = 'worktree';
1452
- const teamDir = join(wd, '.rcs', 'state', 'team', 'workspace-mode-team');
1453
- const configPath = join(teamDir, 'config.json');
1454
- const manifestPath = join(teamDir, 'manifest.v2.json');
1455
- await mkdir(teamDir, { recursive: true });
1456
- await writeFile(configPath, JSON.stringify(config, null, 2));
1457
- const manifest = JSON.parse(await readFile(manifestPath, 'utf8'));
1458
- manifest.workspace_mode = 'worktree';
1459
- await writeFile(manifestPath, JSON.stringify(manifest, null, 2));
1460
- console.log = (...args) => logs.push(args.map(String).join(' '));
1461
- await withoutTeamTestWorkerEnv(() => teamCommand(['status', 'workspace-mode-team']));
1462
- assert.ok(logs.some((line) => /workspace_mode: worktree/.test(line)));
1463
- }
1464
- finally {
1465
- console.log = originalLog;
1466
- process.chdir(previousCwd);
1467
- await rm(wd, { recursive: true, force: true });
1468
- }
1469
- });
1470
- it('returns workspace_mode in JSON status output when present', async () => {
1471
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-status-json-workspace-mode-'));
1472
- const previousCwd = process.cwd();
1473
- const logs = [];
1474
- const originalLog = console.log;
1475
- try {
1476
- process.chdir(wd);
1477
- const config = await withoutTeamTestWorkerEnv(() => initTeamState('workspace-mode-json-team', 'inspect workspace mode', 'executor', 1, wd));
1478
- config.workspace_mode = 'worktree';
1479
- const teamDir = join(wd, '.rcs', 'state', 'team', 'workspace-mode-json-team');
1480
- const configPath = join(teamDir, 'config.json');
1481
- const manifestPath = join(teamDir, 'manifest.v2.json');
1482
- await mkdir(teamDir, { recursive: true });
1483
- await writeFile(configPath, JSON.stringify(config, null, 2));
1484
- const manifest = JSON.parse(await readFile(manifestPath, 'utf8'));
1485
- manifest.workspace_mode = 'worktree';
1486
- await writeFile(manifestPath, JSON.stringify(manifest, null, 2));
1487
- console.log = (...args) => logs.push(args.map(String).join(' '));
1488
- await withoutTeamTestWorkerEnv(() => teamCommand(['status', 'workspace-mode-json-team', '--json']));
1489
- const payload = JSON.parse(logs[0] ?? '{}');
1490
- assert.equal(payload.status, 'ok');
1491
- assert.equal(payload.workspace_mode, 'worktree');
1492
- }
1493
- finally {
1494
- console.log = originalLog;
1495
- process.chdir(previousCwd);
1496
- await rm(wd, { recursive: true, force: true });
1497
- }
1498
- });
1499
- it('returns a missing envelope in JSON mode when team state is absent', async () => {
1500
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-status-missing-'));
1501
- const previousCwd = process.cwd();
1502
- const logs = [];
1503
- const originalLog = console.log;
1504
- try {
1505
- process.chdir(wd);
1506
- console.log = (...args) => logs.push(args.map(String).join(' '));
1507
- await withoutTeamTestWorkerEnv(() => teamCommand(['status', 'missing-team', '--json']));
1508
- const payload = JSON.parse(logs.at(-1) ?? '{}');
1509
- assert.equal(payload.schema_version, '1.0');
1510
- assert.equal(typeof payload.timestamp, 'string');
1511
- assert.equal(payload.command, 'rcs team status');
1512
- assert.equal(payload.team_name, 'missing-team');
1513
- assert.equal(payload.status, 'missing');
1514
- }
1515
- finally {
1516
- console.log = originalLog;
1517
- process.chdir(previousCwd);
1518
- await rm(wd, { recursive: true, force: true });
1519
- }
1520
- });
1521
- it('records leader runtime activity when team status is read', async () => {
1522
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-status-activity-'));
1523
- const previousCwd = process.cwd();
1524
- const logs = [];
1525
- const originalLog = console.log;
1526
- try {
1527
- process.chdir(wd);
1528
- await withoutTeamTestWorkerEnv(() => initTeamState('activity-team', 'inspect activity', 'executor', 1, wd));
1529
- console.log = (...args) => logs.push(args.map(String).join(' '));
1530
- await withoutTeamTestWorkerEnv(() => teamCommand(['status', 'activity-team', '--json']));
1531
- const activity = JSON.parse(await readFile(join(wd, '.rcs', 'state', 'leader-runtime-activity.json'), 'utf-8'));
1532
- assert.equal(activity.last_source, 'team_status');
1533
- assert.equal(activity.last_team_name, 'activity-team');
1534
- assert.ok(typeof activity.last_activity_at === 'string' && activity.last_activity_at.length > 0);
1535
- assert.ok(typeof activity.last_team_status_at === 'string' && activity.last_team_status_at.length > 0);
1536
- }
1537
- finally {
1538
- console.log = originalLog;
1539
- process.chdir(previousCwd);
1540
- await rm(wd, { recursive: true, force: true });
1541
- }
1542
- });
1543
- it('supports custom tail lines for generated raw inspect commands', async () => {
1544
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-status-tail-lines-'));
1545
- const previousCwd = process.cwd();
1546
- const logs = [];
1547
- const originalLog = console.log;
1548
- try {
1549
- process.chdir(wd);
1550
- const config = await withoutTeamTestWorkerEnv(() => initTeamState('pane-tail-team', 'inspect worker panes', 'executor', 1, wd));
1551
- config.workers[0].pane_id = '%51';
1552
- const manifestPath = join(wd, '.rcs', 'state', 'team', 'pane-tail-team', 'manifest.v2.json');
1553
- const manifest = JSON.parse(await readFile(manifestPath, 'utf-8'));
1554
- manifest.workers = config.workers.map((worker) => ({
1555
- ...worker,
1556
- pane_id: worker.pane_id,
1557
- }));
1558
- await writeFile(join(wd, '.rcs', 'state', 'team', 'pane-tail-team', 'config.json'), `${JSON.stringify(config, null, 2)}\n`);
1559
- await writeFile(manifestPath, `${JSON.stringify(manifest, null, 2)}\n`);
1560
- console.log = (...args) => logs.push(args.map(String).join(' '));
1561
- await withoutTeamTestWorkerEnv(() => teamCommand(['status', 'pane-tail-team', '--tail-lines', '600']));
1562
- assert.match(logs.join('\n'), /inspect_worker-1: tmux capture-pane -p -t %51 -S -600/);
1563
- logs.length = 0;
1564
- await withoutTeamTestWorkerEnv(() => teamCommand(['status', 'pane-tail-team', '--model-inspect', '--tail-lines', '600']));
1565
- assert.match(logs.join('\n'), /inspect_worker-1: rcs sparkshell --tmux-pane %51 --tail-lines 600/);
1566
- logs.length = 0;
1567
- await withoutTeamTestWorkerEnv(() => teamCommand(['status', 'pane-tail-team', '--json', '--tail-lines=550']));
1568
- const payload = JSON.parse(logs.at(-1) ?? '{}');
1569
- assert.equal(payload.tail_lines, 550);
1570
- assert.equal(payload.panes?.sparkshell_commands?.['worker-1'], 'rcs sparkshell --tmux-pane %51 --tail-lines 550');
1571
- }
1572
- finally {
1573
- console.log = originalLog;
1574
- process.chdir(previousCwd);
1575
- await rm(wd, { recursive: true, force: true });
1576
- }
1577
- });
1578
- });
1579
- describe('teamCommand await', () => {
1580
- it('returns next canonical event for a team in JSON mode', async () => {
1581
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-await-'));
1582
- const previousCwd = process.cwd();
1583
- const logs = [];
1584
- const originalLog = console.log;
1585
- try {
1586
- process.chdir(wd);
1587
- await initTeamState('await-team', 'await test', 'executor', 1, wd);
1588
- console.log = (...args) => logs.push(args.map(String).join(' '));
1589
- const waitPromise = teamCommand(['await', 'await-team', '--json', '--timeout-ms', '500']);
1590
- setTimeout(() => {
1591
- void appendTeamEvent('await-team', {
1592
- type: 'worker_state_changed',
1593
- worker: 'worker-1',
1594
- state: 'blocked',
1595
- prev_state: 'working',
1596
- reason: 'needs_follow_up',
1597
- }, wd);
1598
- }, 50);
1599
- await waitPromise;
1600
- const payload = JSON.parse(logs.at(-1) ?? '{}');
1601
- assert.equal(payload.team_name, 'await-team');
1602
- assert.equal(payload.status, 'event');
1603
- assert.equal(typeof payload.cursor, 'string');
1604
- assert.equal(payload.event?.type, 'worker_state_changed');
1605
- assert.equal(payload.event?.state, 'blocked');
1606
- assert.equal(payload.event?.prev_state, 'working');
1607
- assert.equal(payload.event?.reason, 'needs_follow_up');
1608
- }
1609
- finally {
1610
- console.log = originalLog;
1611
- process.chdir(previousCwd);
1612
- await rm(wd, { recursive: true, force: true });
1613
- }
1614
- });
1615
- it('returns a dead-worker event for the prompt-launch smoke path instead of timing out', async () => {
1616
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-await-prompt-dead-'));
1617
- const binDir = join(wd, 'bin');
1618
- const fakeCodexPath = join(binDir, 'codex');
1619
- const previousCwd = process.cwd();
1620
- const previousPath = process.env.PATH;
1621
- const previousTmux = process.env.TMUX;
1622
- const previousLaunchMode = process.env.RCS_TEAM_WORKER_LAUNCH_MODE;
1623
- const previousWorkerCli = process.env.RCS_TEAM_WORKER_CLI;
1624
- const logs = [];
1625
- const stderr = [];
1626
- const originalLog = console.log;
1627
- const originalStderrWrite = process.stderr.write.bind(process.stderr);
1628
- const teamTask = 'issue 662 prompt dead worker smoke';
1629
- const teamName = parseTeamStartArgs(['1:executor', teamTask]).parsed.teamName;
1630
- await mkdir(binDir, { recursive: true });
1631
- await writeFile(fakeCodexPath, `#!/usr/bin/env node
1632
- setTimeout(() => process.exit(0), 0);
1633
- process.stdin.resume();
1634
- process.on('SIGTERM', () => process.exit(0));
1635
- `);
1636
- await chmod(fakeCodexPath, 0o755);
1637
- try {
1638
- process.chdir(wd);
1639
- process.env.PATH = `${binDir}:${previousPath ?? ''}`;
1640
- delete process.env.TMUX;
1641
- process.env.RCS_TEAM_WORKER_LAUNCH_MODE = 'prompt';
1642
- process.env.RCS_TEAM_WORKER_CLI = 'codex';
1643
- console.log = (...args) => logs.push(args.map(String).join(' '));
1644
- process.stderr.write = ((chunk) => {
1645
- stderr.push(String(chunk));
1646
- return true;
1647
- });
1648
- await withMockPromptModeCodexAllowed(() => withoutTeamTestWorkerEnv(() => teamCommand(['1:executor', teamTask])));
1649
- const startedState = await readModeState('team', wd);
1650
- const runtimeTeamName = String(startedState?.team_name ?? teamName);
1651
- let statusOutput = '';
1652
- for (let attempt = 0; attempt < 50; attempt += 1) {
1653
- logs.length = 0;
1654
- stderr.length = 0;
1655
- await withoutTeamTestWorkerEnv(() => teamCommand(['status', runtimeTeamName]));
1656
- statusOutput = logs.join('\n');
1657
- if (/phase=failed/.test(statusOutput))
1658
- break;
1659
- await new Promise((resolve) => setTimeout(resolve, 20));
1660
- }
1661
- assert.match(statusOutput, /phase=failed/);
1662
- assert.doesNotMatch(stderr.join('\n'), /ESRCH/);
1663
- logs.length = 0;
1664
- await withoutTeamTestWorkerEnv(() => teamCommand(['await', runtimeTeamName, '--json', '--timeout-ms', '250']));
1665
- const payload = JSON.parse(logs.at(-1) ?? '{}');
1666
- assert.equal(payload.team_name, runtimeTeamName);
1667
- assert.equal(payload.status, 'event');
1668
- assert.equal(payload.event?.type, 'worker_stopped');
1669
- assert.equal(payload.event?.worker, 'worker-1');
1670
- }
1671
- finally {
1672
- console.log = originalLog;
1673
- process.stderr.write = originalStderrWrite;
1674
- process.chdir(previousCwd);
1675
- if (typeof previousPath === 'string')
1676
- process.env.PATH = previousPath;
1677
- else
1678
- delete process.env.PATH;
1679
- if (typeof previousTmux === 'string')
1680
- process.env.TMUX = previousTmux;
1681
- else
1682
- delete process.env.TMUX;
1683
- if (typeof previousLaunchMode === 'string')
1684
- process.env.RCS_TEAM_WORKER_LAUNCH_MODE = previousLaunchMode;
1685
- else
1686
- delete process.env.RCS_TEAM_WORKER_LAUNCH_MODE;
1687
- if (typeof previousWorkerCli === 'string')
1688
- process.env.RCS_TEAM_WORKER_CLI = previousWorkerCli;
1689
- else
1690
- delete process.env.RCS_TEAM_WORKER_CLI;
1691
- await rm(wd, { recursive: true, force: true });
1692
- }
1693
- });
1694
- it('initializes and rehydrates active team mode state on start and resume', async () => {
1695
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-mode-state-'));
1696
- const binDir = join(wd, 'bin');
1697
- const fakeCodexPath = join(binDir, 'codex');
1698
- const previousCwd = process.cwd();
1699
- const previousPath = process.env.PATH;
1700
- const previousTmux = process.env.TMUX;
1701
- const previousLaunchMode = process.env.RCS_TEAM_WORKER_LAUNCH_MODE;
1702
- const previousWorkerCli = process.env.RCS_TEAM_WORKER_CLI;
1703
- const teamTask = 'issue 771 rehydrate team mode state';
1704
- const teamName = parseTeamStartArgs(['1:executor', teamTask]).parsed.teamName;
1705
- await mkdir(binDir, { recursive: true });
1706
- await writeFile(fakeCodexPath, `#!/usr/bin/env node
1707
- setTimeout(() => process.exit(0), 3000);
1708
- process.stdin.resume();
1709
- process.on('SIGTERM', () => process.exit(0));
1710
- `);
1711
- await chmod(fakeCodexPath, 0o755);
1712
- try {
1713
- process.chdir(wd);
1714
- process.env.PATH = `${binDir}:${previousPath ?? ''}`;
1715
- delete process.env.TMUX;
1716
- process.env.RCS_TEAM_WORKER_LAUNCH_MODE = 'prompt';
1717
- process.env.RCS_TEAM_WORKER_CLI = 'codex';
1718
- await withMockPromptModeCodexAllowed(() => withoutTeamTestWorkerEnv(() => teamCommand(['1:executor', teamTask])));
1719
- const startedState = await readModeState('team', wd);
1720
- const runtimeTeamName = String(startedState?.team_name ?? teamName);
1721
- assert.equal(startedState?.active, true);
1722
- assert.equal(startedState?.team_name, runtimeTeamName);
1723
- assert.equal(startedState?.display_name, teamName);
1724
- assert.equal(startedState?.current_phase, 'team-exec');
1725
- await rm(join(wd, '.rcs', 'state', 'team-state.json'), { force: true });
1726
- assert.equal(await readModeState('team', wd), null);
1727
- await withoutTeamTestWorkerEnv(() => teamCommand(['resume', runtimeTeamName]));
1728
- const resumedState = await readModeState('team', wd);
1729
- assert.equal(resumedState?.active, true);
1730
- assert.equal(resumedState?.team_name, runtimeTeamName);
1731
- assert.equal(resumedState?.current_phase, 'team-exec');
1732
- }
1733
- finally {
1734
- process.chdir(previousCwd);
1735
- if (typeof previousPath === 'string')
1736
- process.env.PATH = previousPath;
1737
- else
1738
- delete process.env.PATH;
1739
- if (typeof previousTmux === 'string')
1740
- process.env.TMUX = previousTmux;
1741
- else
1742
- delete process.env.TMUX;
1743
- if (typeof previousLaunchMode === 'string')
1744
- process.env.RCS_TEAM_WORKER_LAUNCH_MODE = previousLaunchMode;
1745
- else
1746
- delete process.env.RCS_TEAM_WORKER_LAUNCH_MODE;
1747
- if (typeof previousWorkerCli === 'string')
1748
- process.env.RCS_TEAM_WORKER_CLI = previousWorkerCli;
1749
- else
1750
- delete process.env.RCS_TEAM_WORKER_CLI;
1751
- await rm(wd, { recursive: true, force: true });
1752
- }
1753
- });
1754
- it('does not resurrect active team mode state when canonical team phase is terminal on resume', async () => {
1755
- const wd = await mkdtemp(join(tmpdir(), 'rcs-team-mode-terminal-'));
1756
- const binDir = join(wd, 'bin');
1757
- const fakeCodexPath = join(binDir, 'codex');
1758
- const previousCwd = process.cwd();
1759
- const previousPath = process.env.PATH;
1760
- const previousTmux = process.env.TMUX;
1761
- const previousLaunchMode = process.env.RCS_TEAM_WORKER_LAUNCH_MODE;
1762
- const previousWorkerCli = process.env.RCS_TEAM_WORKER_CLI;
1763
- const teamTask = 'issue 772 terminal team mode state';
1764
- const teamName = parseTeamStartArgs(['1:executor', teamTask]).parsed.teamName;
1765
- await mkdir(binDir, { recursive: true });
1766
- await writeFile(fakeCodexPath, `#!/usr/bin/env node
1767
- setTimeout(() => process.exit(0), 3000);
1768
- process.stdin.resume();
1769
- process.on('SIGTERM', () => process.exit(0));
1770
- `);
1771
- await chmod(fakeCodexPath, 0o755);
1772
- try {
1773
- process.chdir(wd);
1774
- process.env.PATH = `${binDir}:${previousPath ?? ''}`;
1775
- delete process.env.TMUX;
1776
- process.env.RCS_TEAM_WORKER_LAUNCH_MODE = 'prompt';
1777
- process.env.RCS_TEAM_WORKER_CLI = 'codex';
1778
- await withMockPromptModeCodexAllowed(() => withoutTeamTestWorkerEnv(() => teamCommand(['1:executor', teamTask])));
1779
- const startedState = await readModeState('team', wd);
1780
- const runtimeTeamName = String(startedState?.team_name ?? teamName);
1781
- await writeFile(join(wd, '.rcs', 'state', 'team', runtimeTeamName, 'phase.json'), JSON.stringify({
1782
- current_phase: 'complete',
1783
- max_fix_attempts: 3,
1784
- current_fix_attempt: 0,
1785
- transitions: [],
1786
- updated_at: new Date().toISOString(),
1787
- }, null, 2));
1788
- await rm(join(wd, '.rcs', 'state', 'team-state.json'), { force: true });
1789
- await withoutTeamTestWorkerEnv(() => teamCommand(['resume', runtimeTeamName]));
1790
- const resumedState = await readModeState('team', wd);
1791
- assert.equal(resumedState?.active, false);
1792
- assert.equal(resumedState?.team_name, runtimeTeamName);
1793
- assert.equal(resumedState?.current_phase, 'complete');
1794
- }
1795
- finally {
1796
- process.chdir(previousCwd);
1797
- if (typeof previousPath === 'string')
1798
- process.env.PATH = previousPath;
1799
- else
1800
- delete process.env.PATH;
1801
- if (typeof previousTmux === 'string')
1802
- process.env.TMUX = previousTmux;
1803
- else
1804
- delete process.env.TMUX;
1805
- if (typeof previousLaunchMode === 'string')
1806
- process.env.RCS_TEAM_WORKER_LAUNCH_MODE = previousLaunchMode;
1807
- else
1808
- delete process.env.RCS_TEAM_WORKER_LAUNCH_MODE;
1809
- if (typeof previousWorkerCli === 'string')
1810
- process.env.RCS_TEAM_WORKER_CLI = previousWorkerCli;
1811
- else
1812
- delete process.env.RCS_TEAM_WORKER_CLI;
1813
- await rm(wd, { recursive: true, force: true });
1814
- }
1815
- });
1816
- it('rejects legacy rcs team ralph launches at command entry', async () => {
1817
- await assert.rejects(() => withoutTeamTestWorkerEnv(() => teamCommand(['ralph', '1:executor', 'issue 742 linked ralph launch'])), /Deprecated usage: `rcs team ralph \.\.\.` has been removed/);
1818
- });
1819
- });
1820
- //# sourceMappingURL=team.test.js.map