oh-my-codex 0.15.0 → 0.15.2

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 (533) hide show
  1. package/Cargo.lock +5 -5
  2. package/Cargo.toml +1 -1
  3. package/README.md +36 -5
  4. package/crates/omx-explore/src/main.rs +222 -12
  5. package/dist/agents/__tests__/native-config.test.js +40 -0
  6. package/dist/agents/__tests__/native-config.test.js.map +1 -1
  7. package/dist/agents/native-config.d.ts +1 -0
  8. package/dist/agents/native-config.d.ts.map +1 -1
  9. package/dist/agents/native-config.js +6 -1
  10. package/dist/agents/native-config.js.map +1 -1
  11. package/dist/agents/policy.d.ts +1 -0
  12. package/dist/agents/policy.d.ts.map +1 -1
  13. package/dist/agents/policy.js +4 -0
  14. package/dist/agents/policy.js.map +1 -1
  15. package/dist/cli/__tests__/autoresearch-guided.test.js +37 -13
  16. package/dist/cli/__tests__/autoresearch-guided.test.js.map +1 -1
  17. package/dist/cli/__tests__/codex-plugin-layout.test.js +1 -1
  18. package/dist/cli/__tests__/codex-plugin-layout.test.js.map +1 -1
  19. package/dist/cli/__tests__/doctor-team.test.js +46 -1
  20. package/dist/cli/__tests__/doctor-team.test.js.map +1 -1
  21. package/dist/cli/__tests__/doctor-warning-copy.test.js +225 -111
  22. package/dist/cli/__tests__/doctor-warning-copy.test.js.map +1 -1
  23. package/dist/cli/__tests__/exec.test.js +96 -1
  24. package/dist/cli/__tests__/exec.test.js.map +1 -1
  25. package/dist/cli/__tests__/explore.test.js +15 -2
  26. package/dist/cli/__tests__/explore.test.js.map +1 -1
  27. package/dist/cli/__tests__/index.test.js +292 -3
  28. package/dist/cli/__tests__/index.test.js.map +1 -1
  29. package/dist/cli/__tests__/launch-fallback.test.js +223 -0
  30. package/dist/cli/__tests__/launch-fallback.test.js.map +1 -1
  31. package/dist/cli/__tests__/mcp-parity.test.js +86 -0
  32. package/dist/cli/__tests__/mcp-parity.test.js.map +1 -1
  33. package/dist/cli/__tests__/package-bin-contract.test.js +23 -0
  34. package/dist/cli/__tests__/package-bin-contract.test.js.map +1 -1
  35. package/dist/cli/__tests__/question.test.js +76 -11
  36. package/dist/cli/__tests__/question.test.js.map +1 -1
  37. package/dist/cli/__tests__/setup-agents-overwrite.test.js +140 -1
  38. package/dist/cli/__tests__/setup-agents-overwrite.test.js.map +1 -1
  39. package/dist/cli/__tests__/setup-install-mode.test.js +310 -4
  40. package/dist/cli/__tests__/setup-install-mode.test.js.map +1 -1
  41. package/dist/cli/__tests__/setup-prompts-overwrite.test.js +78 -19
  42. package/dist/cli/__tests__/setup-prompts-overwrite.test.js.map +1 -1
  43. package/dist/cli/__tests__/setup-refresh.test.js +79 -2
  44. package/dist/cli/__tests__/setup-refresh.test.js.map +1 -1
  45. package/dist/cli/__tests__/sidecar.test.d.ts +2 -0
  46. package/dist/cli/__tests__/sidecar.test.d.ts.map +1 -0
  47. package/dist/cli/__tests__/sidecar.test.js +24 -0
  48. package/dist/cli/__tests__/sidecar.test.js.map +1 -0
  49. package/dist/cli/__tests__/team.test.js +54 -7
  50. package/dist/cli/__tests__/team.test.js.map +1 -1
  51. package/dist/cli/autoresearch-guided.d.ts.map +1 -1
  52. package/dist/cli/autoresearch-guided.js +12 -4
  53. package/dist/cli/autoresearch-guided.js.map +1 -1
  54. package/dist/cli/codex-home.d.ts +4 -6
  55. package/dist/cli/codex-home.d.ts.map +1 -1
  56. package/dist/cli/codex-home.js +9 -41
  57. package/dist/cli/codex-home.js.map +1 -1
  58. package/dist/cli/doctor.d.ts +1 -1
  59. package/dist/cli/doctor.d.ts.map +1 -1
  60. package/dist/cli/doctor.js +509 -279
  61. package/dist/cli/doctor.js.map +1 -1
  62. package/dist/cli/index.d.ts +6 -4
  63. package/dist/cli/index.d.ts.map +1 -1
  64. package/dist/cli/index.js +284 -25
  65. package/dist/cli/index.js.map +1 -1
  66. package/dist/cli/omx.js +3 -1
  67. package/dist/cli/omx.js.map +1 -1
  68. package/dist/cli/plugin-marketplace.d.ts +13 -0
  69. package/dist/cli/plugin-marketplace.d.ts.map +1 -0
  70. package/dist/cli/plugin-marketplace.js +77 -0
  71. package/dist/cli/plugin-marketplace.js.map +1 -0
  72. package/dist/cli/question.d.ts +1 -1
  73. package/dist/cli/question.d.ts.map +1 -1
  74. package/dist/cli/question.js +26 -12
  75. package/dist/cli/question.js.map +1 -1
  76. package/dist/cli/setup-preferences.d.ts +20 -0
  77. package/dist/cli/setup-preferences.d.ts.map +1 -0
  78. package/dist/cli/setup-preferences.js +71 -0
  79. package/dist/cli/setup-preferences.js.map +1 -0
  80. package/dist/cli/setup.d.ts +7 -5
  81. package/dist/cli/setup.d.ts.map +1 -1
  82. package/dist/cli/setup.js +271 -152
  83. package/dist/cli/setup.js.map +1 -1
  84. package/dist/cli/team.d.ts +1 -0
  85. package/dist/cli/team.d.ts.map +1 -1
  86. package/dist/cli/team.js +70 -15
  87. package/dist/cli/team.js.map +1 -1
  88. package/dist/config/__tests__/generator-idempotent.test.js +100 -3
  89. package/dist/config/__tests__/generator-idempotent.test.js.map +1 -1
  90. package/dist/config/__tests__/generator-notify.test.js +6 -5
  91. package/dist/config/__tests__/generator-notify.test.js.map +1 -1
  92. package/dist/config/__tests__/generator-status-line-presets.test.d.ts +2 -0
  93. package/dist/config/__tests__/generator-status-line-presets.test.d.ts.map +1 -0
  94. package/dist/config/__tests__/generator-status-line-presets.test.js +203 -0
  95. package/dist/config/__tests__/generator-status-line-presets.test.js.map +1 -0
  96. package/dist/config/__tests__/models.test.js +23 -1
  97. package/dist/config/__tests__/models.test.js.map +1 -1
  98. package/dist/config/generator.d.ts +9 -1
  99. package/dist/config/generator.d.ts.map +1 -1
  100. package/dist/config/generator.js +184 -16
  101. package/dist/config/generator.js.map +1 -1
  102. package/dist/config/models.d.ts +5 -1
  103. package/dist/config/models.d.ts.map +1 -1
  104. package/dist/config/models.js +12 -2
  105. package/dist/config/models.js.map +1 -1
  106. package/dist/exec/followup.d.ts +44 -0
  107. package/dist/exec/followup.d.ts.map +1 -0
  108. package/dist/exec/followup.js +349 -0
  109. package/dist/exec/followup.js.map +1 -0
  110. package/dist/hooks/__tests__/autopilot-skill-contract.test.d.ts +2 -0
  111. package/dist/hooks/__tests__/autopilot-skill-contract.test.d.ts.map +1 -0
  112. package/dist/hooks/__tests__/autopilot-skill-contract.test.js +37 -0
  113. package/dist/hooks/__tests__/autopilot-skill-contract.test.js.map +1 -0
  114. package/dist/hooks/__tests__/codebase-map.test.js +63 -1
  115. package/dist/hooks/__tests__/codebase-map.test.js.map +1 -1
  116. package/dist/hooks/__tests__/consensus-execution-handoff.test.d.ts +1 -1
  117. package/dist/hooks/__tests__/consensus-execution-handoff.test.js +5 -5
  118. package/dist/hooks/__tests__/consensus-execution-handoff.test.js.map +1 -1
  119. package/dist/hooks/__tests__/deep-interview-contract.test.js +12 -9
  120. package/dist/hooks/__tests__/deep-interview-contract.test.js.map +1 -1
  121. package/dist/hooks/__tests__/keyword-detector.test.js +25 -18
  122. package/dist/hooks/__tests__/keyword-detector.test.js.map +1 -1
  123. package/dist/hooks/__tests__/notify-hook-all-workers-idle.test.js +23 -2
  124. package/dist/hooks/__tests__/notify-hook-all-workers-idle.test.js.map +1 -1
  125. package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js +45 -2
  126. package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js.map +1 -1
  127. package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.js +17 -0
  128. package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.js.map +1 -1
  129. package/dist/hooks/__tests__/notify-hook-managed-tmux.test.js +121 -0
  130. package/dist/hooks/__tests__/notify-hook-managed-tmux.test.js.map +1 -1
  131. package/dist/hooks/__tests__/notify-hook-regression-205.test.js +4 -4
  132. package/dist/hooks/__tests__/notify-hook-regression-205.test.js.map +1 -1
  133. package/dist/hooks/__tests__/notify-hook-team-dispatch.test.js +103 -0
  134. package/dist/hooks/__tests__/notify-hook-team-dispatch.test.js.map +1 -1
  135. package/dist/hooks/__tests__/notify-hook-team-leader-nudge.test.js +2 -2
  136. package/dist/hooks/__tests__/notify-hook-team-leader-nudge.test.js.map +1 -1
  137. package/dist/hooks/__tests__/notify-hook-team-tmux-guard.test.js +27 -13
  138. package/dist/hooks/__tests__/notify-hook-team-tmux-guard.test.js.map +1 -1
  139. package/dist/hooks/__tests__/notify-hook-team-worker-fail-closed.test.d.ts +2 -0
  140. package/dist/hooks/__tests__/notify-hook-team-worker-fail-closed.test.d.ts.map +1 -0
  141. package/dist/hooks/__tests__/notify-hook-team-worker-fail-closed.test.js +35 -0
  142. package/dist/hooks/__tests__/notify-hook-team-worker-fail-closed.test.js.map +1 -0
  143. package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js +215 -0
  144. package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js.map +1 -1
  145. package/dist/hooks/__tests__/notify-hook-worker-idle.test.js +70 -3
  146. package/dist/hooks/__tests__/notify-hook-worker-idle.test.js.map +1 -1
  147. package/dist/hooks/__tests__/pre-context-gate-skills.test.js +5 -0
  148. package/dist/hooks/__tests__/pre-context-gate-skills.test.js.map +1 -1
  149. package/dist/hooks/__tests__/prompt-guidance-fragments.test.js +3 -2
  150. package/dist/hooks/__tests__/prompt-guidance-fragments.test.js.map +1 -1
  151. package/dist/hooks/__tests__/prompt-guidance-wave-two.test.js +9 -0
  152. package/dist/hooks/__tests__/prompt-guidance-wave-two.test.js.map +1 -1
  153. package/dist/hooks/__tests__/prompt-refactor-contract.test.d.ts +2 -0
  154. package/dist/hooks/__tests__/prompt-refactor-contract.test.d.ts.map +1 -0
  155. package/dist/hooks/__tests__/prompt-refactor-contract.test.js +22 -0
  156. package/dist/hooks/__tests__/prompt-refactor-contract.test.js.map +1 -0
  157. package/dist/hooks/codebase-map.d.ts.map +1 -1
  158. package/dist/hooks/codebase-map.js +83 -6
  159. package/dist/hooks/codebase-map.js.map +1 -1
  160. package/dist/hooks/keyword-detector.d.ts +1 -1
  161. package/dist/hooks/keyword-detector.d.ts.map +1 -1
  162. package/dist/hooks/keyword-detector.js +35 -4
  163. package/dist/hooks/keyword-detector.js.map +1 -1
  164. package/dist/hooks/prompt-guidance-contract.d.ts +6 -0
  165. package/dist/hooks/prompt-guidance-contract.d.ts.map +1 -1
  166. package/dist/hooks/prompt-guidance-contract.js +117 -13
  167. package/dist/hooks/prompt-guidance-contract.js.map +1 -1
  168. package/dist/hooks/session.d.ts +2 -0
  169. package/dist/hooks/session.d.ts.map +1 -1
  170. package/dist/hooks/session.js +6 -0
  171. package/dist/hooks/session.js.map +1 -1
  172. package/dist/hud/__tests__/index.test.js +4 -4
  173. package/dist/hud/__tests__/index.test.js.map +1 -1
  174. package/dist/hud/__tests__/state.test.js +4 -0
  175. package/dist/hud/__tests__/state.test.js.map +1 -1
  176. package/dist/hud/__tests__/types.test.js +27 -0
  177. package/dist/hud/__tests__/types.test.js.map +1 -1
  178. package/dist/hud/state.d.ts.map +1 -1
  179. package/dist/hud/state.js +8 -0
  180. package/dist/hud/state.js.map +1 -1
  181. package/dist/hud/types.d.ts +9 -0
  182. package/dist/hud/types.d.ts.map +1 -1
  183. package/dist/hud/types.js +3 -0
  184. package/dist/hud/types.js.map +1 -1
  185. package/dist/mcp/__tests__/bootstrap.test.js +23 -5
  186. package/dist/mcp/__tests__/bootstrap.test.js.map +1 -1
  187. package/dist/mcp/__tests__/server-lifecycle.test.js +50 -7
  188. package/dist/mcp/__tests__/server-lifecycle.test.js.map +1 -1
  189. package/dist/mcp/__tests__/state-server.test.js +70 -12
  190. package/dist/mcp/__tests__/state-server.test.js.map +1 -1
  191. package/dist/mcp/bootstrap.d.ts +10 -1
  192. package/dist/mcp/bootstrap.d.ts.map +1 -1
  193. package/dist/mcp/bootstrap.js +71 -26
  194. package/dist/mcp/bootstrap.js.map +1 -1
  195. package/dist/mcp/state-server.d.ts +5 -11
  196. package/dist/mcp/state-server.d.ts.map +1 -1
  197. package/dist/mcp/state-server.js +16 -432
  198. package/dist/mcp/state-server.js.map +1 -1
  199. package/dist/modes/__tests__/base-autoresearch-contract.test.js +1 -1
  200. package/dist/modes/__tests__/base-autoresearch-contract.test.js.map +1 -1
  201. package/dist/pipeline/__tests__/orchestrator.test.js +89 -5
  202. package/dist/pipeline/__tests__/orchestrator.test.js.map +1 -1
  203. package/dist/pipeline/__tests__/stages.test.js +98 -1
  204. package/dist/pipeline/__tests__/stages.test.js.map +1 -1
  205. package/dist/pipeline/index.d.ts +5 -3
  206. package/dist/pipeline/index.d.ts.map +1 -1
  207. package/dist/pipeline/index.js +4 -3
  208. package/dist/pipeline/index.js.map +1 -1
  209. package/dist/pipeline/orchestrator.d.ts +7 -6
  210. package/dist/pipeline/orchestrator.d.ts.map +1 -1
  211. package/dist/pipeline/orchestrator.js +90 -11
  212. package/dist/pipeline/orchestrator.js.map +1 -1
  213. package/dist/pipeline/review-verdict.d.ts +3 -0
  214. package/dist/pipeline/review-verdict.d.ts.map +1 -0
  215. package/dist/pipeline/review-verdict.js +14 -0
  216. package/dist/pipeline/review-verdict.js.map +1 -0
  217. package/dist/pipeline/stages/code-review.d.ts +33 -0
  218. package/dist/pipeline/stages/code-review.d.ts.map +1 -0
  219. package/dist/pipeline/stages/code-review.js +51 -0
  220. package/dist/pipeline/stages/code-review.js.map +1 -0
  221. package/dist/pipeline/stages/ralph-verify.d.ts +12 -2
  222. package/dist/pipeline/stages/ralph-verify.d.ts.map +1 -1
  223. package/dist/pipeline/stages/ralph-verify.js +24 -6
  224. package/dist/pipeline/stages/ralph-verify.js.map +1 -1
  225. package/dist/pipeline/stages/ralplan.d.ts +1 -1
  226. package/dist/pipeline/stages/ralplan.d.ts.map +1 -1
  227. package/dist/pipeline/stages/ralplan.js +21 -1
  228. package/dist/pipeline/stages/ralplan.js.map +1 -1
  229. package/dist/pipeline/types.d.ts +14 -7
  230. package/dist/pipeline/types.d.ts.map +1 -1
  231. package/dist/pipeline/types.js +2 -2
  232. package/dist/planning/__tests__/artifacts.test.js +152 -1
  233. package/dist/planning/__tests__/artifacts.test.js.map +1 -1
  234. package/dist/planning/artifacts.d.ts +9 -0
  235. package/dist/planning/artifacts.d.ts.map +1 -1
  236. package/dist/planning/artifacts.js +60 -1
  237. package/dist/planning/artifacts.js.map +1 -1
  238. package/dist/question/__tests__/client.test.js +23 -3
  239. package/dist/question/__tests__/client.test.js.map +1 -1
  240. package/dist/question/__tests__/renderer.test.js +148 -37
  241. package/dist/question/__tests__/renderer.test.js.map +1 -1
  242. package/dist/question/__tests__/types.test.js +21 -0
  243. package/dist/question/__tests__/types.test.js.map +1 -1
  244. package/dist/question/__tests__/ui.test.js +155 -7
  245. package/dist/question/__tests__/ui.test.js.map +1 -1
  246. package/dist/question/client.d.ts +14 -4
  247. package/dist/question/client.d.ts.map +1 -1
  248. package/dist/question/client.js.map +1 -1
  249. package/dist/question/renderer.d.ts +11 -1
  250. package/dist/question/renderer.d.ts.map +1 -1
  251. package/dist/question/renderer.js +102 -7
  252. package/dist/question/renderer.js.map +1 -1
  253. package/dist/question/state.d.ts +2 -2
  254. package/dist/question/state.d.ts.map +1 -1
  255. package/dist/question/state.js +26 -17
  256. package/dist/question/state.js.map +1 -1
  257. package/dist/question/types.d.ts +25 -1
  258. package/dist/question/types.d.ts.map +1 -1
  259. package/dist/question/types.js +48 -13
  260. package/dist/question/types.js.map +1 -1
  261. package/dist/question/ui.d.ts +15 -2
  262. package/dist/question/ui.d.ts.map +1 -1
  263. package/dist/question/ui.js +268 -162
  264. package/dist/question/ui.js.map +1 -1
  265. package/dist/scripts/__tests__/codex-native-hook.test.js +415 -94
  266. package/dist/scripts/__tests__/codex-native-hook.test.js.map +1 -1
  267. package/dist/scripts/__tests__/generate-release-body.test.js +36 -0
  268. package/dist/scripts/__tests__/generate-release-body.test.js.map +1 -1
  269. package/dist/scripts/__tests__/prompt-inventory.test.d.ts +2 -0
  270. package/dist/scripts/__tests__/prompt-inventory.test.d.ts.map +1 -0
  271. package/dist/scripts/__tests__/prompt-inventory.test.js +56 -0
  272. package/dist/scripts/__tests__/prompt-inventory.test.js.map +1 -0
  273. package/dist/scripts/codex-native-hook.d.ts.map +1 -1
  274. package/dist/scripts/codex-native-hook.js +232 -54
  275. package/dist/scripts/codex-native-hook.js.map +1 -1
  276. package/dist/scripts/codex-native-pre-post.d.ts.map +1 -1
  277. package/dist/scripts/codex-native-pre-post.js +12 -9
  278. package/dist/scripts/codex-native-pre-post.js.map +1 -1
  279. package/dist/scripts/generate-release-body.d.ts.map +1 -1
  280. package/dist/scripts/generate-release-body.js +12 -3
  281. package/dist/scripts/generate-release-body.js.map +1 -1
  282. package/dist/scripts/notify-hook/__tests__/team-worker-posttooluse.test.d.ts +2 -0
  283. package/dist/scripts/notify-hook/__tests__/team-worker-posttooluse.test.d.ts.map +1 -0
  284. package/dist/scripts/notify-hook/__tests__/team-worker-posttooluse.test.js +153 -0
  285. package/dist/scripts/notify-hook/__tests__/team-worker-posttooluse.test.js.map +1 -0
  286. package/dist/scripts/notify-hook/managed-tmux.d.ts +4 -2
  287. package/dist/scripts/notify-hook/managed-tmux.d.ts.map +1 -1
  288. package/dist/scripts/notify-hook/managed-tmux.js +188 -6
  289. package/dist/scripts/notify-hook/managed-tmux.js.map +1 -1
  290. package/dist/scripts/notify-hook/process-runner.d.ts.map +1 -1
  291. package/dist/scripts/notify-hook/process-runner.js +7 -3
  292. package/dist/scripts/notify-hook/process-runner.js.map +1 -1
  293. package/dist/scripts/notify-hook/team-dispatch.d.ts.map +1 -1
  294. package/dist/scripts/notify-hook/team-dispatch.js +96 -11
  295. package/dist/scripts/notify-hook/team-dispatch.js.map +1 -1
  296. package/dist/scripts/notify-hook/team-tmux-guard.js +3 -3
  297. package/dist/scripts/notify-hook/team-worker-posttooluse.d.ts +34 -0
  298. package/dist/scripts/notify-hook/team-worker-posttooluse.d.ts.map +1 -0
  299. package/dist/scripts/notify-hook/team-worker-posttooluse.js +434 -0
  300. package/dist/scripts/notify-hook/team-worker-posttooluse.js.map +1 -0
  301. package/dist/scripts/notify-hook/team-worker.d.ts +1 -1
  302. package/dist/scripts/notify-hook/team-worker.d.ts.map +1 -1
  303. package/dist/scripts/notify-hook/team-worker.js +3 -43
  304. package/dist/scripts/notify-hook/team-worker.js.map +1 -1
  305. package/dist/scripts/notify-hook/tmux-injection.d.ts.map +1 -1
  306. package/dist/scripts/notify-hook/tmux-injection.js +25 -4
  307. package/dist/scripts/notify-hook/tmux-injection.js.map +1 -1
  308. package/dist/scripts/notify-hook.js +36 -5
  309. package/dist/scripts/notify-hook.js.map +1 -1
  310. package/dist/scripts/prompt-inventory.d.ts +29 -0
  311. package/dist/scripts/prompt-inventory.d.ts.map +1 -0
  312. package/dist/scripts/prompt-inventory.js +178 -0
  313. package/dist/scripts/prompt-inventory.js.map +1 -0
  314. package/dist/scripts/run-test-files.js +1 -0
  315. package/dist/scripts/run-test-files.js.map +1 -1
  316. package/dist/sidecar/__tests__/boundary.test.d.ts +2 -0
  317. package/dist/sidecar/__tests__/boundary.test.d.ts.map +1 -0
  318. package/dist/sidecar/__tests__/boundary.test.js +48 -0
  319. package/dist/sidecar/__tests__/boundary.test.js.map +1 -0
  320. package/dist/sidecar/__tests__/collector.test.d.ts +2 -0
  321. package/dist/sidecar/__tests__/collector.test.d.ts.map +1 -0
  322. package/dist/sidecar/__tests__/collector.test.js +162 -0
  323. package/dist/sidecar/__tests__/collector.test.js.map +1 -0
  324. package/dist/sidecar/__tests__/render.test.d.ts +2 -0
  325. package/dist/sidecar/__tests__/render.test.d.ts.map +1 -0
  326. package/dist/sidecar/__tests__/render.test.js +67 -0
  327. package/dist/sidecar/__tests__/render.test.js.map +1 -0
  328. package/dist/sidecar/__tests__/tmux.test.d.ts +2 -0
  329. package/dist/sidecar/__tests__/tmux.test.d.ts.map +1 -0
  330. package/dist/sidecar/__tests__/tmux.test.js +30 -0
  331. package/dist/sidecar/__tests__/tmux.test.js.map +1 -0
  332. package/dist/sidecar/__tests__/watch.test.d.ts +2 -0
  333. package/dist/sidecar/__tests__/watch.test.d.ts.map +1 -0
  334. package/dist/sidecar/__tests__/watch.test.js +42 -0
  335. package/dist/sidecar/__tests__/watch.test.js.map +1 -0
  336. package/dist/sidecar/collector.d.ts +4 -0
  337. package/dist/sidecar/collector.d.ts.map +1 -0
  338. package/dist/sidecar/collector.js +377 -0
  339. package/dist/sidecar/collector.js.map +1 -0
  340. package/dist/sidecar/index.d.ts +25 -0
  341. package/dist/sidecar/index.d.ts.map +1 -0
  342. package/dist/sidecar/index.js +165 -0
  343. package/dist/sidecar/index.js.map +1 -0
  344. package/dist/sidecar/render.d.ts +3 -0
  345. package/dist/sidecar/render.d.ts.map +1 -0
  346. package/dist/sidecar/render.js +72 -0
  347. package/dist/sidecar/render.js.map +1 -0
  348. package/dist/sidecar/tmux.d.ts +13 -0
  349. package/dist/sidecar/tmux.d.ts.map +1 -0
  350. package/dist/sidecar/tmux.js +44 -0
  351. package/dist/sidecar/tmux.js.map +1 -0
  352. package/dist/sidecar/types.d.ts +125 -0
  353. package/dist/sidecar/types.d.ts.map +1 -0
  354. package/dist/sidecar/types.js +2 -0
  355. package/dist/sidecar/types.js.map +1 -0
  356. package/dist/state/__tests__/operations.test.js +50 -22
  357. package/dist/state/__tests__/operations.test.js.map +1 -1
  358. package/dist/state/__tests__/workflow-transition.test.js +9 -1
  359. package/dist/state/__tests__/workflow-transition.test.js.map +1 -1
  360. package/dist/state/operations.d.ts +1 -1
  361. package/dist/state/operations.d.ts.map +1 -1
  362. package/dist/state/operations.js +19 -7
  363. package/dist/state/operations.js.map +1 -1
  364. package/dist/state/workflow-transition.d.ts.map +1 -1
  365. package/dist/state/workflow-transition.js +1 -0
  366. package/dist/state/workflow-transition.js.map +1 -1
  367. package/dist/team/__tests__/commit-hygiene.test.d.ts +2 -0
  368. package/dist/team/__tests__/commit-hygiene.test.d.ts.map +1 -0
  369. package/dist/team/__tests__/commit-hygiene.test.js +93 -0
  370. package/dist/team/__tests__/commit-hygiene.test.js.map +1 -0
  371. package/dist/team/__tests__/delegation-policy.test.d.ts +2 -0
  372. package/dist/team/__tests__/delegation-policy.test.d.ts.map +1 -0
  373. package/dist/team/__tests__/delegation-policy.test.js +69 -0
  374. package/dist/team/__tests__/delegation-policy.test.js.map +1 -0
  375. package/dist/team/__tests__/events.test.js +54 -4
  376. package/dist/team/__tests__/events.test.js.map +1 -1
  377. package/dist/team/__tests__/hook-primary-e2e-contract.test.d.ts +2 -0
  378. package/dist/team/__tests__/hook-primary-e2e-contract.test.d.ts.map +1 -0
  379. package/dist/team/__tests__/hook-primary-e2e-contract.test.js +78 -0
  380. package/dist/team/__tests__/hook-primary-e2e-contract.test.js.map +1 -0
  381. package/dist/team/__tests__/model-contract.test.js +16 -0
  382. package/dist/team/__tests__/model-contract.test.js.map +1 -1
  383. package/dist/team/__tests__/repo-aware-decomposition.test.d.ts +2 -0
  384. package/dist/team/__tests__/repo-aware-decomposition.test.d.ts.map +1 -0
  385. package/dist/team/__tests__/repo-aware-decomposition.test.js +95 -0
  386. package/dist/team/__tests__/repo-aware-decomposition.test.js.map +1 -0
  387. package/dist/team/__tests__/runtime.test.js +623 -14
  388. package/dist/team/__tests__/runtime.test.js.map +1 -1
  389. package/dist/team/__tests__/state-root.test.js +177 -1
  390. package/dist/team/__tests__/state-root.test.js.map +1 -1
  391. package/dist/team/__tests__/state.test.js +110 -0
  392. package/dist/team/__tests__/state.test.js.map +1 -1
  393. package/dist/team/__tests__/tmux-session.test.js +399 -2
  394. package/dist/team/__tests__/tmux-session.test.js.map +1 -1
  395. package/dist/team/__tests__/worker-bootstrap.test.js +94 -0
  396. package/dist/team/__tests__/worker-bootstrap.test.js.map +1 -1
  397. package/dist/team/commit-hygiene.d.ts +22 -3
  398. package/dist/team/commit-hygiene.d.ts.map +1 -1
  399. package/dist/team/commit-hygiene.js +134 -2
  400. package/dist/team/commit-hygiene.js.map +1 -1
  401. package/dist/team/contracts.d.ts +1 -1
  402. package/dist/team/contracts.d.ts.map +1 -1
  403. package/dist/team/contracts.js +2 -0
  404. package/dist/team/contracts.js.map +1 -1
  405. package/dist/team/dag-schema.d.ts +38 -0
  406. package/dist/team/dag-schema.d.ts.map +1 -0
  407. package/dist/team/dag-schema.js +221 -0
  408. package/dist/team/dag-schema.js.map +1 -0
  409. package/dist/team/delegation-policy.d.ts +3 -0
  410. package/dist/team/delegation-policy.d.ts.map +1 -0
  411. package/dist/team/delegation-policy.js +82 -0
  412. package/dist/team/delegation-policy.js.map +1 -0
  413. package/dist/team/model-contract.d.ts +3 -1
  414. package/dist/team/model-contract.d.ts.map +1 -1
  415. package/dist/team/model-contract.js +44 -5
  416. package/dist/team/model-contract.js.map +1 -1
  417. package/dist/team/repo-aware-decomposition.d.ts +60 -0
  418. package/dist/team/repo-aware-decomposition.d.ts.map +1 -0
  419. package/dist/team/repo-aware-decomposition.js +229 -0
  420. package/dist/team/repo-aware-decomposition.js.map +1 -0
  421. package/dist/team/runtime.d.ts +27 -0
  422. package/dist/team/runtime.d.ts.map +1 -1
  423. package/dist/team/runtime.js +172 -52
  424. package/dist/team/runtime.js.map +1 -1
  425. package/dist/team/state/tasks.d.ts.map +1 -1
  426. package/dist/team/state/tasks.js +33 -0
  427. package/dist/team/state/tasks.js.map +1 -1
  428. package/dist/team/state/types.d.ts +23 -1
  429. package/dist/team/state/types.d.ts.map +1 -1
  430. package/dist/team/state/types.js.map +1 -1
  431. package/dist/team/state-root.d.ts +35 -0
  432. package/dist/team/state-root.d.ts.map +1 -1
  433. package/dist/team/state-root.js +281 -1
  434. package/dist/team/state-root.js.map +1 -1
  435. package/dist/team/state.d.ts +27 -1
  436. package/dist/team/state.d.ts.map +1 -1
  437. package/dist/team/state.js +6 -0
  438. package/dist/team/state.js.map +1 -1
  439. package/dist/team/tmux-session.d.ts +1 -0
  440. package/dist/team/tmux-session.d.ts.map +1 -1
  441. package/dist/team/tmux-session.js +105 -6
  442. package/dist/team/tmux-session.js.map +1 -1
  443. package/dist/team/worker-bootstrap.d.ts +3 -0
  444. package/dist/team/worker-bootstrap.d.ts.map +1 -1
  445. package/dist/team/worker-bootstrap.js +77 -4
  446. package/dist/team/worker-bootstrap.js.map +1 -1
  447. package/dist/utils/agents-md.d.ts +3 -0
  448. package/dist/utils/agents-md.d.ts.map +1 -1
  449. package/dist/utils/agents-md.js +25 -0
  450. package/dist/utils/agents-md.js.map +1 -1
  451. package/package.json +3 -2
  452. package/plugins/oh-my-codex/.codex-plugin/plugin.json +2 -2
  453. package/plugins/oh-my-codex/skills/ai-slop-cleaner/SKILL.md +1 -1
  454. package/plugins/oh-my-codex/skills/analyze/SKILL.md +1 -1
  455. package/plugins/oh-my-codex/skills/autopilot/SKILL.md +134 -205
  456. package/plugins/oh-my-codex/skills/code-review/SKILL.md +4 -4
  457. package/plugins/oh-my-codex/skills/deep-interview/SKILL.md +14 -7
  458. package/plugins/oh-my-codex/skills/doctor/SKILL.md +1 -1
  459. package/plugins/oh-my-codex/skills/help/SKILL.md +1 -1
  460. package/plugins/oh-my-codex/skills/omx-setup/SKILL.md +41 -10
  461. package/plugins/oh-my-codex/skills/plan/SKILL.md +12 -14
  462. package/plugins/oh-my-codex/skills/ralph/SKILL.md +2 -4
  463. package/plugins/oh-my-codex/skills/ralplan/SKILL.md +5 -9
  464. package/plugins/oh-my-codex/skills/security-review/SKILL.md +4 -4
  465. package/plugins/oh-my-codex/skills/team/SKILL.md +2 -5
  466. package/plugins/oh-my-codex/skills/ultraqa/SKILL.md +2 -5
  467. package/plugins/oh-my-codex/skills/ultrawork/SKILL.md +2 -3
  468. package/prompts/analyst.md +2 -2
  469. package/prompts/api-reviewer.md +2 -2
  470. package/prompts/architect.md +2 -2
  471. package/prompts/build-fixer.md +2 -2
  472. package/prompts/code-reviewer.md +15 -5
  473. package/prompts/code-simplifier.md +1 -1
  474. package/prompts/critic.md +35 -83
  475. package/prompts/debugger.md +2 -2
  476. package/prompts/dependency-expert.md +2 -2
  477. package/prompts/designer.md +2 -2
  478. package/prompts/executor.md +40 -114
  479. package/prompts/explore-harness.md +1 -1
  480. package/prompts/explore.md +37 -90
  481. package/prompts/git-master.md +2 -2
  482. package/prompts/information-architect.md +1 -1
  483. package/prompts/performance-reviewer.md +2 -2
  484. package/prompts/planner.md +35 -62
  485. package/prompts/product-analyst.md +2 -2
  486. package/prompts/product-manager.md +2 -2
  487. package/prompts/qa-tester.md +2 -2
  488. package/prompts/quality-reviewer.md +2 -2
  489. package/prompts/quality-strategist.md +2 -2
  490. package/prompts/researcher.md +46 -78
  491. package/prompts/security-reviewer.md +2 -2
  492. package/prompts/sisyphus-lite.md +2 -2
  493. package/prompts/style-reviewer.md +2 -2
  494. package/prompts/team-executor.md +1 -1
  495. package/prompts/test-engineer.md +2 -2
  496. package/prompts/ux-researcher.md +2 -2
  497. package/prompts/verifier.md +29 -34
  498. package/prompts/vision.md +2 -2
  499. package/prompts/writer.md +2 -2
  500. package/skills/ai-slop-cleaner/SKILL.md +1 -1
  501. package/skills/analyze/SKILL.md +1 -1
  502. package/skills/autopilot/SKILL.md +134 -205
  503. package/skills/build-fix/SKILL.md +4 -4
  504. package/skills/code-review/SKILL.md +4 -4
  505. package/skills/deep-interview/SKILL.md +14 -7
  506. package/skills/doctor/SKILL.md +1 -1
  507. package/skills/help/SKILL.md +1 -1
  508. package/skills/omx-setup/SKILL.md +41 -10
  509. package/skills/plan/SKILL.md +12 -14
  510. package/skills/ralph/SKILL.md +2 -4
  511. package/skills/ralplan/SKILL.md +5 -9
  512. package/skills/security-review/SKILL.md +4 -4
  513. package/skills/team/SKILL.md +2 -5
  514. package/skills/ultraqa/SKILL.md +2 -5
  515. package/skills/ultrawork/SKILL.md +2 -3
  516. package/src/scripts/__tests__/codex-native-hook.test.ts +502 -94
  517. package/src/scripts/__tests__/generate-release-body.test.ts +41 -0
  518. package/src/scripts/__tests__/prompt-inventory.test.ts +64 -0
  519. package/src/scripts/codex-native-hook.ts +293 -61
  520. package/src/scripts/codex-native-pre-post.ts +10 -8
  521. package/src/scripts/generate-release-body.ts +13 -2
  522. package/src/scripts/notify-hook/__tests__/team-worker-posttooluse.test.ts +180 -0
  523. package/src/scripts/notify-hook/managed-tmux.ts +196 -9
  524. package/src/scripts/notify-hook/process-runner.ts +7 -3
  525. package/src/scripts/notify-hook/team-dispatch.ts +103 -11
  526. package/src/scripts/notify-hook/team-tmux-guard.ts +3 -3
  527. package/src/scripts/notify-hook/team-worker-posttooluse.ts +536 -0
  528. package/src/scripts/notify-hook/team-worker.ts +4 -48
  529. package/src/scripts/notify-hook/tmux-injection.ts +24 -6
  530. package/src/scripts/notify-hook.ts +36 -5
  531. package/src/scripts/prompt-inventory.ts +218 -0
  532. package/src/scripts/run-test-files.ts +1 -0
  533. package/templates/AGENTS.md +34 -95
@@ -6,7 +6,7 @@ import { PassThrough } from 'node:stream';
6
6
  import { chmod, mkdir, mkdtemp, readFile, rm, writeFile } from 'fs/promises';
7
7
  import { join } from 'path';
8
8
  import { tmpdir } from 'os';
9
- import { buildClientAttachedReconcileHookName, assertTeamWorkerCliBinaryAvailable, buildWorkerProcessLaunchSpec, buildReconcileHudResizeArgs, buildRegisterClientAttachedReconcileArgs, buildRegisterResizeHookArgs, buildResizeHookName, buildResizeHookTarget, buildScheduleDelayedHudResizeArgs, buildUnregisterClientAttachedReconcileArgs, buildUnregisterResizeHookArgs, buildWorkerStartupCommand, buildHudPaneTarget, chooseTeamLeaderPaneId, createTeamSession, enableMouseScrolling, isMsysOrGitBash, isNativeWindows, isTmuxAvailable, restoreStandaloneHudPane, translatePathForMsys, isWsl2, isWorkerAlive, killWorker, killWorkerByPaneId, teardownWorkerPanes, listTeamSessions, resolveTeamWorkerCli, resolveTeamWorkerLaunchMode, resolveWorkerCliForSend, resolveTeamWorkerCliPlan, buildWorkerSubmitPlan, sanitizeTeamName, shouldAttemptAdaptiveRetry, sendToWorker, sendToWorkerStdin, sleepFractionalSeconds, translateWorkerLaunchArgsForCli, waitForWorkerReady, paneIsBootstrapping, dismissTrustPromptIfPresent, mitigateCopyModeUnderlineArtifacts, } from '../tmux-session.js';
9
+ import { buildClientAttachedReconcileHookName, assertTeamWorkerCliBinaryAvailable, buildWorkerProcessLaunchSpec, buildReconcileHudResizeArgs, buildRegisterClientAttachedReconcileArgs, buildRegisterResizeHookArgs, buildResizeHookName, buildResizeHookTarget, buildScheduleDelayedHudResizeArgs, buildUnregisterClientAttachedReconcileArgs, buildUnregisterResizeHookArgs, buildWorkerStartupCommand, buildHudPaneTarget, chooseTeamLeaderPaneId, createTeamSession, enableMouseScrolling, isMsysOrGitBash, isNativeWindows, isTmuxAvailable, restoreStandaloneHudPane, translatePathForMsys, isWsl2, isWorkerAlive, killWorker, killWorkerByPaneId, teardownWorkerPanes, listTeamSessions, resolveTeamWorkerCli, resolveTeamWorkerLaunchMode, resolveWorkerCliForSend, resolveTeamWorkerCliPlan, buildWorkerSubmitPlan, sanitizeTeamName, shouldAttemptAdaptiveRetry, sendToWorker, sendToWorkerStdin, sleepFractionalSeconds, translateWorkerLaunchArgsForCli, waitForWorkerReady, waitForWorkerReadyAsync, paneIsBootstrapping, dismissTrustPromptIfPresent, mitigateCopyModeUnderlineArtifacts, } from '../tmux-session.js';
10
10
  import { HUD_RESIZE_RECONCILE_DELAY_SECONDS, HUD_TMUX_TEAM_HEIGHT_LINES } from '../../hud/constants.js';
11
11
  import * as tmuxSessionModule from '../tmux-session.js';
12
12
  import { OMX_ENTRY_PATH_ENV, OMX_STARTUP_CWD_ENV } from '../../utils/paths.js';
@@ -773,6 +773,28 @@ describe('buildWorkerStartupCommand', () => {
773
773
  delete process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
774
774
  }
775
775
  });
776
+ it('accepts MacPorts zsh as a supported worker shell without falling back', () => {
777
+ const prevShell = process.env.SHELL;
778
+ const prevBypass = process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
779
+ process.env.SHELL = '/opt/local/bin/zsh';
780
+ process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT = '0';
781
+ try {
782
+ const cmd = withMockedExistsSync((candidate) => candidate === '/opt/local/bin/zsh', () => buildWorkerStartupCommand('alpha', 2));
783
+ assert.match(cmd, /'\/opt\/local\/bin\/zsh' -c/);
784
+ assert.doesNotMatch(cmd, /'\/bin\/sh' -c/);
785
+ assert.match(cmd, /source ~\/\.zshrc/);
786
+ }
787
+ finally {
788
+ if (typeof prevShell === 'string')
789
+ process.env.SHELL = prevShell;
790
+ else
791
+ delete process.env.SHELL;
792
+ if (typeof prevBypass === 'string')
793
+ process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT = prevBypass;
794
+ else
795
+ delete process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
796
+ }
797
+ });
776
798
  it('uses bash with ~/.bashrc and preserves launch args', () => {
777
799
  const prevShell = process.env.SHELL;
778
800
  process.env.SHELL = '/bin/bash';
@@ -1907,6 +1929,48 @@ describe('team worker launch mode helpers', () => {
1907
1929
  await rm(fakeRoot, { recursive: true, force: true });
1908
1930
  }
1909
1931
  });
1932
+ it('buildWorkerProcessLaunchSpec preserves ambient CODEX_HOME so Codex workers keep provider websocket metadata', async () => {
1933
+ const prevBypass = process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
1934
+ const prevCodexHome = process.env.CODEX_HOME;
1935
+ const prevProviderEnv = process.env.CUSTOM_PROVIDER_API_KEY;
1936
+ const codexHome = await mkdtemp(join(tmpdir(), 'omx-team-provider-websocket-'));
1937
+ process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT = '0';
1938
+ process.env.CODEX_HOME = codexHome;
1939
+ process.env.CUSTOM_PROVIDER_API_KEY = 'test-secret';
1940
+ try {
1941
+ await writeFile(join(codexHome, 'config.toml'), [
1942
+ 'model = "gpt-5.5"',
1943
+ 'model_provider = "custom_provider"',
1944
+ '',
1945
+ '[model_providers.custom_provider]',
1946
+ 'name = "custom_provider"',
1947
+ 'base_url = "http://localhost:3000/v1"',
1948
+ 'wire_api = "responses"',
1949
+ 'supports_websockets = true',
1950
+ 'requires_openai_auth = true',
1951
+ 'env_key = "CUSTOM_PROVIDER_API_KEY"',
1952
+ '',
1953
+ ].join('\n'));
1954
+ const spec = buildWorkerProcessLaunchSpec('websocket-team', 1, [], '/tmp/workspace', {}, 'codex');
1955
+ assert.equal(spec.env.CODEX_HOME, codexHome);
1956
+ assert.equal(spec.env.CUSTOM_PROVIDER_API_KEY, 'test-secret');
1957
+ }
1958
+ finally {
1959
+ if (typeof prevBypass === 'string')
1960
+ process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT = prevBypass;
1961
+ else
1962
+ delete process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
1963
+ if (typeof prevCodexHome === 'string')
1964
+ process.env.CODEX_HOME = prevCodexHome;
1965
+ else
1966
+ delete process.env.CODEX_HOME;
1967
+ if (typeof prevProviderEnv === 'string')
1968
+ process.env.CUSTOM_PROVIDER_API_KEY = prevProviderEnv;
1969
+ else
1970
+ delete process.env.CUSTOM_PROVIDER_API_KEY;
1971
+ await rm(codexHome, { recursive: true, force: true });
1972
+ }
1973
+ });
1910
1974
  it('buildWorkerProcessLaunchSpec injects the active provider env_key from CODEX_HOME config.toml', async () => {
1911
1975
  const prevBypass = process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
1912
1976
  const prevCodexHome = process.env.CODEX_HOME;
@@ -1946,6 +2010,60 @@ describe('team worker launch mode helpers', () => {
1946
2010
  await rm(codexHome, { recursive: true, force: true });
1947
2011
  }
1948
2012
  });
2013
+ it('buildWorkerProcessLaunchSpec uses CLI model_provider override for Codex provider env injection', async () => {
2014
+ const prevBypass = process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
2015
+ const prevCodexHome = process.env.CODEX_HOME;
2016
+ const prevDefaultProviderEnv = process.env.DEFAULT_PROVIDER_API_KEY;
2017
+ const prevCheapProviderEnv = process.env.CHEAP_PROVIDER_API_KEY;
2018
+ const codexHome = await mkdtemp(join(tmpdir(), 'omx-team-provider-cli-override-'));
2019
+ process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT = '0';
2020
+ process.env.CODEX_HOME = codexHome;
2021
+ process.env.DEFAULT_PROVIDER_API_KEY = 'default-secret';
2022
+ process.env.CHEAP_PROVIDER_API_KEY = 'cheap-secret';
2023
+ try {
2024
+ await writeFile(join(codexHome, 'config.toml'), [
2025
+ 'model_provider = "default_provider"',
2026
+ '',
2027
+ '[model_providers.default_provider]',
2028
+ 'name = "default_provider"',
2029
+ 'base_url = "http://localhost:3000/v1"',
2030
+ 'wire_api = "responses"',
2031
+ 'requires_openai_auth = true',
2032
+ 'env_key = "DEFAULT_PROVIDER_API_KEY"',
2033
+ '',
2034
+ '[model_providers.cheapRouter]',
2035
+ 'name = "cheapRouter"',
2036
+ 'base_url = "http://localhost:4000/v1"',
2037
+ 'wire_api = "responses"',
2038
+ 'requires_openai_auth = true',
2039
+ 'env_key = "CHEAP_PROVIDER_API_KEY"',
2040
+ '',
2041
+ ].join('\n'));
2042
+ const spec = buildWorkerProcessLaunchSpec('provider-override-team', 1, ['-c', 'model_provider="cheapRouter"', '--model', 'gpt-5.5'], '/tmp/workspace', {}, 'codex');
2043
+ assert.equal(spec.env.CHEAP_PROVIDER_API_KEY, 'cheap-secret');
2044
+ assert.equal(spec.env.DEFAULT_PROVIDER_API_KEY, undefined);
2045
+ assert.deepEqual(spec.args.slice(0, 4), ['-c', 'model_provider="cheapRouter"', '--model', 'gpt-5.5']);
2046
+ }
2047
+ finally {
2048
+ if (typeof prevBypass === 'string')
2049
+ process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT = prevBypass;
2050
+ else
2051
+ delete process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
2052
+ if (typeof prevCodexHome === 'string')
2053
+ process.env.CODEX_HOME = prevCodexHome;
2054
+ else
2055
+ delete process.env.CODEX_HOME;
2056
+ if (typeof prevDefaultProviderEnv === 'string')
2057
+ process.env.DEFAULT_PROVIDER_API_KEY = prevDefaultProviderEnv;
2058
+ else
2059
+ delete process.env.DEFAULT_PROVIDER_API_KEY;
2060
+ if (typeof prevCheapProviderEnv === 'string')
2061
+ process.env.CHEAP_PROVIDER_API_KEY = prevCheapProviderEnv;
2062
+ else
2063
+ delete process.env.CHEAP_PROVIDER_API_KEY;
2064
+ await rm(codexHome, { recursive: true, force: true });
2065
+ }
2066
+ });
1949
2067
  it('buildWorkerProcessLaunchSpec does not inject the active provider env_key for non-codex workers', async () => {
1950
2068
  const prevBypass = process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
1951
2069
  const prevCodexHome = process.env.CODEX_HOME;
@@ -1968,6 +2086,7 @@ describe('team worker launch mode helpers', () => {
1968
2086
  ].join('\n'));
1969
2087
  const spec = buildWorkerProcessLaunchSpec('delta-team', 1, [], '/tmp/workspace', {}, 'claude');
1970
2088
  assert.equal(spec.workerCli, 'claude');
2089
+ assert.equal(spec.env.CODEX_HOME, undefined);
1971
2090
  assert.equal(spec.env.CUSTOM_PROVIDER_API_KEY, undefined);
1972
2091
  }
1973
2092
  finally {
@@ -2294,7 +2413,7 @@ EOF
2294
2413
  ;;
2295
2414
  esac
2296
2415
  `, async ({ logPath }) => {
2297
- assert.equal(waitForWorkerReady('omx-team-x', 1, 1_000), true);
2416
+ assert.equal(waitForWorkerReady('omx-team-x', 1, 5_000), true);
2298
2417
  const log = await readFile(logPath, 'utf-8');
2299
2418
  assert.match(log, /send-keys -t omx-team-x:1 -l -- 2/);
2300
2419
  assert.match(log, /send-keys -t omx-team-x:1 C-m/);
@@ -2337,6 +2456,284 @@ esac
2337
2456
  });
2338
2457
  });
2339
2458
  });
2459
+ describe('waitForWorkerReadyAsync parity', () => {
2460
+ it('uses visible capture-pane argv without tail flags', async () => {
2461
+ await withMockTmuxFixture('omx-tmux-worker-ready-async-visible-capture-', (logPath) => `#!/bin/sh
2462
+ set -eu
2463
+ printf '%s\n' "$*" >> "${logPath}"
2464
+ case "$1" in
2465
+ capture-pane)
2466
+ cat <<'EOF'
2467
+ ${READY_HELPER_CAPTURE}
2468
+ EOF
2469
+ exit 0
2470
+ ;;
2471
+ *)
2472
+ exit 0
2473
+ ;;
2474
+ esac
2475
+ `, async ({ logPath }) => {
2476
+ assert.equal(await waitForWorkerReadyAsync('omx-team-x', 1, 1_000), true);
2477
+ const log = await readFile(logPath, 'utf-8');
2478
+ assert.match(log, /capture-pane -t omx-team-x:1 -p/);
2479
+ assert.doesNotMatch(log, /capture-pane -t omx-team-x:1 -p -S/);
2480
+ });
2481
+ });
2482
+ it('falls back to recent scrollback only when visible slice shows a live Codex viewport', async () => {
2483
+ await withMockTmuxFixture('omx-tmux-worker-ready-async-scrollback-fallback-', (logPath) => `#!/bin/sh
2484
+ set -eu
2485
+ printf '%s\n' "$*" >> "${logPath}"
2486
+ case "$1" in
2487
+ capture-pane)
2488
+ if printf '%s\n' "$*" | grep -q -- ' -S -80'; then
2489
+ cat <<'EOF'
2490
+ ${VIEWPORT_SCROLLBACK_READY_CAPTURE}
2491
+ EOF
2492
+ else
2493
+ cat <<'EOF'
2494
+ ${VIEWPORT_WITHOUT_VISIBLE_PROMPT_CAPTURE}
2495
+ EOF
2496
+ fi
2497
+ exit 0
2498
+ ;;
2499
+ *)
2500
+ exit 0
2501
+ ;;
2502
+ esac
2503
+ `, async ({ logPath }) => {
2504
+ assert.equal(await waitForWorkerReadyAsync('omx-team-x', 1, 1_000), true);
2505
+ const log = await readFile(logPath, 'utf-8');
2506
+ assert.match(log, /capture-pane -t omx-team-x:1 -p/);
2507
+ assert.match(log, /capture-pane -t omx-team-x:1 -p -S -80/);
2508
+ });
2509
+ await withMockTmuxFixture('omx-tmux-worker-ready-async-no-scrollback-status-', (logPath) => `#!/bin/sh
2510
+ set -eu
2511
+ printf '%s\n' "$*" >> "${logPath}"
2512
+ case "$1" in
2513
+ capture-pane)
2514
+ printf 'gpt-5 50%% left\n'
2515
+ exit 0
2516
+ ;;
2517
+ *)
2518
+ exit 0
2519
+ ;;
2520
+ esac
2521
+ `, async ({ logPath }) => {
2522
+ assert.equal(await waitForWorkerReadyAsync('omx-team-x', 1, 250), false);
2523
+ const log = await readFile(logPath, 'utf-8');
2524
+ assert.match(log, /capture-pane -t omx-team-x:1 -p/);
2525
+ assert.doesNotMatch(log, /capture-pane -t omx-team-x:1 -p -S -80/);
2526
+ });
2527
+ });
2528
+ it('auto-accepts trust prompts and then observes readiness', async () => {
2529
+ const previousAutoTrust = process.env.OMX_TEAM_AUTO_TRUST;
2530
+ delete process.env.OMX_TEAM_AUTO_TRUST;
2531
+ try {
2532
+ await withMockTmuxFixture('omx-tmux-worker-ready-async-trust-', (logPath) => `#!/bin/sh
2533
+ set -eu
2534
+ state_dir="$(dirname "${logPath}")"
2535
+ accepted_file="$state_dir/accepted"
2536
+ printf '%s\n' "$*" >> "${logPath}"
2537
+ case "$1" in
2538
+ capture-pane)
2539
+ if [ -f "$accepted_file" ]; then
2540
+ cat <<'EOF'
2541
+ ${READY_HELPER_CAPTURE}
2542
+ EOF
2543
+ else
2544
+ cat <<'EOF'
2545
+ Do you trust the contents of this directory?
2546
+ Press enter to continue
2547
+ EOF
2548
+ fi
2549
+ exit 0
2550
+ ;;
2551
+ send-keys)
2552
+ if [ "\${4:-}" = "C-m" ]; then
2553
+ : > "$accepted_file"
2554
+ fi
2555
+ exit 0
2556
+ ;;
2557
+ *)
2558
+ exit 0
2559
+ ;;
2560
+ esac
2561
+ `, async ({ logPath }) => {
2562
+ assert.equal(await waitForWorkerReadyAsync('omx-team-x', 1, 5_000), true);
2563
+ const log = await readFile(logPath, 'utf-8');
2564
+ assert.match(log, /send-keys -t omx-team-x:1 C-m/);
2565
+ });
2566
+ }
2567
+ finally {
2568
+ if (typeof previousAutoTrust === 'string')
2569
+ process.env.OMX_TEAM_AUTO_TRUST = previousAutoTrust;
2570
+ else
2571
+ delete process.env.OMX_TEAM_AUTO_TRUST;
2572
+ }
2573
+ });
2574
+ it('auto-accepts the Claude bypass prompt and then observes readiness', async () => {
2575
+ const previousAutoAccept = process.env.OMX_TEAM_AUTO_ACCEPT_BYPASS;
2576
+ delete process.env.OMX_TEAM_AUTO_ACCEPT_BYPASS;
2577
+ try {
2578
+ await withMockTmuxFixture('omx-tmux-worker-ready-async-claude-bypass-', (logPath) => `#!/bin/sh
2579
+ set -eu
2580
+ state_dir="$(dirname "${logPath}")"
2581
+ accepted_file="$state_dir/accepted"
2582
+ printf '%s\n' "$*" >> "${logPath}"
2583
+ case "$1" in
2584
+ capture-pane)
2585
+ if [ -f "$accepted_file" ]; then
2586
+ cat <<'EOF'
2587
+ ${READY_HELPER_CAPTURE}
2588
+ EOF
2589
+ else
2590
+ cat <<'EOF'
2591
+ ${CLAUDE_BYPASS_PROMPT_CAPTURE}
2592
+ EOF
2593
+ fi
2594
+ exit 0
2595
+ ;;
2596
+ send-keys)
2597
+ if [ "\${4:-}" = "-l" ] && [ "\${6:-}" = "2" ]; then
2598
+ : > "$accepted_file"
2599
+ fi
2600
+ exit 0
2601
+ ;;
2602
+ *)
2603
+ exit 0
2604
+ ;;
2605
+ esac
2606
+ `, async ({ logPath }) => {
2607
+ assert.equal(await waitForWorkerReadyAsync('omx-team-x', 1, 5_000), true);
2608
+ const log = await readFile(logPath, 'utf-8');
2609
+ assert.match(log, /send-keys -t omx-team-x:1 -l -- 2/);
2610
+ });
2611
+ }
2612
+ finally {
2613
+ if (typeof previousAutoAccept === 'string')
2614
+ process.env.OMX_TEAM_AUTO_ACCEPT_BYPASS = previousAutoAccept;
2615
+ else
2616
+ delete process.env.OMX_TEAM_AUTO_ACCEPT_BYPASS;
2617
+ }
2618
+ });
2619
+ it('returns false on timeout or tmux command failure', async () => {
2620
+ await withMockTmuxFixture('omx-tmux-worker-ready-async-capture-failure-', (logPath) => `#!/bin/sh
2621
+ set -eu
2622
+ printf '%s\n' "$*" >> "${logPath}"
2623
+ case "$1" in
2624
+ capture-pane)
2625
+ exit 1
2626
+ ;;
2627
+ *)
2628
+ exit 0
2629
+ ;;
2630
+ esac
2631
+ `, async () => {
2632
+ assert.equal(await waitForWorkerReadyAsync('omx-team-x', 1, 1), false);
2633
+ });
2634
+ await withEmptyPath(async () => {
2635
+ assert.equal(await waitForWorkerReadyAsync('omx-team-x', 1, 1), false);
2636
+ });
2637
+ });
2638
+ });
2639
+ describe('createTeamSession tmux instance tagging', () => {
2640
+ it('tags leader, worker, and HUD panes with pane-scoped instance ownership', async () => {
2641
+ const cwd = await mkdtemp(join(tmpdir(), 'omx-team-pane-tags-'));
2642
+ const prevTmux = process.env.TMUX;
2643
+ const prevTmuxPane = process.env.TMUX_PANE;
2644
+ const prevSessionId = process.env.OMX_SESSION_ID;
2645
+ const prevWorkerCli = process.env.OMX_TEAM_WORKER_CLI;
2646
+ try {
2647
+ await withMockTmuxFixture('omx-tmux-pane-tags-', (logPath) => `#!/bin/sh
2648
+ set -eu
2649
+ printf '%s\n' "$*" >> "${logPath}"
2650
+ case "\${1:-}" in
2651
+ -V)
2652
+ echo "tmux 3.4"
2653
+ exit 0
2654
+ ;;
2655
+ display-message)
2656
+ case "$*" in
2657
+ *"#{window_width}"*)
2658
+ echo "120"
2659
+ ;;
2660
+ *)
2661
+ echo "shared:0 %1"
2662
+ ;;
2663
+ esac
2664
+ exit 0
2665
+ ;;
2666
+ list-panes)
2667
+ case "$*" in
2668
+ *"pane_current_command"*)
2669
+ printf "%%1\\tnode\\t'codex'\\n"
2670
+ ;;
2671
+ *)
2672
+ printf "%%1\\n"
2673
+ ;;
2674
+ esac
2675
+ exit 0
2676
+ ;;
2677
+ split-window)
2678
+ case "$*" in
2679
+ *" -h "*)
2680
+ echo "%2"
2681
+ ;;
2682
+ *)
2683
+ echo "%3"
2684
+ ;;
2685
+ esac
2686
+ exit 0
2687
+ ;;
2688
+ set-option|resize-pane|select-layout|set-window-option|select-pane|set-hook|run-shell)
2689
+ exit 0
2690
+ ;;
2691
+ *)
2692
+ exit 0
2693
+ ;;
2694
+ esac
2695
+ `, async ({ logPath }) => {
2696
+ const fakeBinDir = join(logPath, '..');
2697
+ const geminiPath = join(fakeBinDir, 'gemini');
2698
+ await writeFile(geminiPath, '#!/bin/sh\nexit 0\n');
2699
+ await chmod(geminiPath, 0o755);
2700
+ process.env.TMUX = '1';
2701
+ process.env.TMUX_PANE = '%1';
2702
+ process.env.OMX_SESSION_ID = 'omx-pane-scope';
2703
+ process.env.OMX_TEAM_WORKER_CLI = 'gemini';
2704
+ const session = createTeamSession('Pane Tags', 1, cwd);
2705
+ assert.equal(session.name, 'shared:0');
2706
+ assert.equal(session.leaderPaneId, '%1');
2707
+ assert.deepEqual(session.workerPaneIds, ['%2']);
2708
+ assert.equal(session.hudPaneId, '%3');
2709
+ const tmuxLog = await readFile(logPath, 'utf-8');
2710
+ assert.match(tmuxLog, /set-option -t shared @omx_instance_id omx-pane-scope/);
2711
+ assert.match(tmuxLog, /set-option -p -t %1 @omx_pane_instance_id omx-pane-scope/);
2712
+ assert.match(tmuxLog, /set-option -p -t %2 @omx_pane_instance_id omx-pane-scope/);
2713
+ assert.match(tmuxLog, /set-option -p -t %3 @omx_pane_instance_id omx-pane-scope/);
2714
+ });
2715
+ }
2716
+ finally {
2717
+ if (typeof prevTmux === 'string')
2718
+ process.env.TMUX = prevTmux;
2719
+ else
2720
+ delete process.env.TMUX;
2721
+ if (typeof prevTmuxPane === 'string')
2722
+ process.env.TMUX_PANE = prevTmuxPane;
2723
+ else
2724
+ delete process.env.TMUX_PANE;
2725
+ if (typeof prevSessionId === 'string')
2726
+ process.env.OMX_SESSION_ID = prevSessionId;
2727
+ else
2728
+ delete process.env.OMX_SESSION_ID;
2729
+ if (typeof prevWorkerCli === 'string')
2730
+ process.env.OMX_TEAM_WORKER_CLI = prevWorkerCli;
2731
+ else
2732
+ delete process.env.OMX_TEAM_WORKER_CLI;
2733
+ await rm(cwd, { recursive: true, force: true });
2734
+ }
2735
+ });
2736
+ });
2340
2737
  describe('native Windows HUD reconciliation', () => {
2341
2738
  it('allows team startup on native Windows when current tmux client is reachable without TMUX env vars', async () => {
2342
2739
  const cwd = await mkdtemp(join(tmpdir(), 'omx-team-win32-no-env-'));