oh-my-codex 0.18.6 → 0.18.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Cargo.lock +6 -6
- package/Cargo.toml +1 -1
- package/README.md +59 -10
- package/crates/omx-sparkshell/tests/execution.rs +1 -1
- package/dist/agents/__tests__/definitions.test.js +11 -0
- package/dist/agents/__tests__/definitions.test.js.map +1 -1
- package/dist/agents/__tests__/native-config.test.js +56 -6
- package/dist/agents/__tests__/native-config.test.js.map +1 -1
- package/dist/agents/definitions.d.ts +10 -0
- package/dist/agents/definitions.d.ts.map +1 -1
- package/dist/agents/definitions.js +5 -1
- package/dist/agents/definitions.js.map +1 -1
- package/dist/agents/native-config.d.ts +5 -1
- package/dist/agents/native-config.d.ts.map +1 -1
- package/dist/agents/native-config.js +19 -4
- package/dist/agents/native-config.js.map +1 -1
- package/dist/autopilot/__tests__/fsm.test.d.ts +2 -0
- package/dist/autopilot/__tests__/fsm.test.d.ts.map +1 -0
- package/dist/autopilot/__tests__/fsm.test.js +75 -0
- package/dist/autopilot/__tests__/fsm.test.js.map +1 -0
- package/dist/autopilot/__tests__/ralplan-gate.test.d.ts +2 -0
- package/dist/autopilot/__tests__/ralplan-gate.test.d.ts.map +1 -0
- package/dist/autopilot/__tests__/ralplan-gate.test.js +79 -0
- package/dist/autopilot/__tests__/ralplan-gate.test.js.map +1 -0
- package/dist/autopilot/deep-interview-gate.d.ts +18 -0
- package/dist/autopilot/deep-interview-gate.d.ts.map +1 -0
- package/dist/autopilot/deep-interview-gate.js +256 -0
- package/dist/autopilot/deep-interview-gate.js.map +1 -0
- package/dist/autopilot/fsm.d.ts +13 -0
- package/dist/autopilot/fsm.d.ts.map +1 -0
- package/dist/autopilot/fsm.js +70 -0
- package/dist/autopilot/fsm.js.map +1 -0
- package/dist/autopilot/ralplan-gate.d.ts +17 -0
- package/dist/autopilot/ralplan-gate.d.ts.map +1 -0
- package/dist/autopilot/ralplan-gate.js +61 -0
- package/dist/autopilot/ralplan-gate.js.map +1 -0
- package/dist/cli/__tests__/codex-plugin-layout.test.js +512 -1
- package/dist/cli/__tests__/codex-plugin-layout.test.js.map +1 -1
- package/dist/cli/__tests__/doctor-warning-copy.test.js +39 -0
- package/dist/cli/__tests__/doctor-warning-copy.test.js.map +1 -1
- package/dist/cli/__tests__/index.test.js +83 -7
- package/dist/cli/__tests__/index.test.js.map +1 -1
- package/dist/cli/__tests__/launch-fallback.test.js +175 -6
- package/dist/cli/__tests__/launch-fallback.test.js.map +1 -1
- package/dist/cli/__tests__/package-bin-contract.test.js +8 -4
- package/dist/cli/__tests__/package-bin-contract.test.js.map +1 -1
- package/dist/cli/__tests__/question.test.js +100 -0
- package/dist/cli/__tests__/question.test.js.map +1 -1
- package/dist/cli/__tests__/ralph-goal-mode-contract.test.js +13 -0
- package/dist/cli/__tests__/ralph-goal-mode-contract.test.js.map +1 -1
- package/dist/cli/__tests__/ralph.test.js +14 -0
- package/dist/cli/__tests__/ralph.test.js.map +1 -1
- package/dist/cli/__tests__/setup-install-mode.test.js +89 -0
- package/dist/cli/__tests__/setup-install-mode.test.js.map +1 -1
- package/dist/cli/__tests__/setup-refresh.test.js +83 -0
- package/dist/cli/__tests__/setup-refresh.test.js.map +1 -1
- package/dist/cli/__tests__/state.test.js +21 -0
- package/dist/cli/__tests__/state.test.js.map +1 -1
- package/dist/cli/__tests__/team.test.js +2 -2
- package/dist/cli/__tests__/team.test.js.map +1 -1
- package/dist/cli/__tests__/update.test.js +110 -2
- package/dist/cli/__tests__/update.test.js.map +1 -1
- package/dist/cli/doctor.d.ts.map +1 -1
- package/dist/cli/doctor.js +8 -1
- package/dist/cli/doctor.js.map +1 -1
- package/dist/cli/index.d.ts +14 -3
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +298 -50
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/plugin-marketplace.d.ts +14 -2
- package/dist/cli/plugin-marketplace.d.ts.map +1 -1
- package/dist/cli/plugin-marketplace.js +62 -15
- package/dist/cli/plugin-marketplace.js.map +1 -1
- package/dist/cli/question.d.ts.map +1 -1
- package/dist/cli/question.js +36 -5
- package/dist/cli/question.js.map +1 -1
- package/dist/cli/ralph.d.ts.map +1 -1
- package/dist/cli/ralph.js +3 -1
- package/dist/cli/ralph.js.map +1 -1
- package/dist/cli/setup-preferences.d.ts +2 -0
- package/dist/cli/setup-preferences.d.ts.map +1 -1
- package/dist/cli/setup-preferences.js +4 -0
- package/dist/cli/setup-preferences.js.map +1 -1
- package/dist/cli/setup.d.ts +3 -0
- package/dist/cli/setup.d.ts.map +1 -1
- package/dist/cli/setup.js +166 -27
- package/dist/cli/setup.js.map +1 -1
- package/dist/cli/state.d.ts.map +1 -1
- package/dist/cli/state.js +8 -1
- package/dist/cli/state.js.map +1 -1
- package/dist/cli/tmux-hook.d.ts.map +1 -1
- package/dist/cli/tmux-hook.js +16 -0
- package/dist/cli/tmux-hook.js.map +1 -1
- package/dist/cli/update.d.ts +2 -0
- package/dist/cli/update.d.ts.map +1 -1
- package/dist/cli/update.js +47 -3
- package/dist/cli/update.js.map +1 -1
- package/dist/config/__tests__/deep-interview.test.js +7 -6
- package/dist/config/__tests__/deep-interview.test.js.map +1 -1
- package/dist/config/__tests__/generator-notify.test.js +1 -0
- package/dist/config/__tests__/generator-notify.test.js.map +1 -1
- package/dist/config/deep-interview.d.ts.map +1 -1
- package/dist/config/deep-interview.js +14 -4
- package/dist/config/deep-interview.js.map +1 -1
- package/dist/config/generator.d.ts +2 -2
- package/dist/config/generator.d.ts.map +1 -1
- package/dist/config/generator.js +2 -2
- package/dist/config/generator.js.map +1 -1
- package/dist/config/team-mode.d.ts +12 -0
- package/dist/config/team-mode.d.ts.map +1 -0
- package/dist/config/team-mode.js +91 -0
- package/dist/config/team-mode.js.map +1 -0
- package/dist/hooks/__tests__/agents-overlay.test.js +88 -0
- package/dist/hooks/__tests__/agents-overlay.test.js.map +1 -1
- package/dist/hooks/__tests__/autopilot-skill-contract.test.js +8 -0
- package/dist/hooks/__tests__/autopilot-skill-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/code-review-skill-contract.test.js +8 -0
- package/dist/hooks/__tests__/code-review-skill-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/deep-interview-contract.test.js +10 -0
- package/dist/hooks/__tests__/deep-interview-contract.test.js.map +1 -1
- package/dist/hooks/__tests__/keyword-detector.test.js +1072 -14
- package/dist/hooks/__tests__/keyword-detector.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-fallback-watcher.test.js +64 -1
- package/dist/hooks/__tests__/notify-fallback-watcher.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js +189 -0
- package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-team-leader-nudge.test.js +35 -2
- package/dist/hooks/__tests__/notify-hook-team-leader-nudge.test.js.map +1 -1
- package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js +3 -3
- package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js.map +1 -1
- package/dist/hooks/__tests__/session.test.js +25 -0
- package/dist/hooks/__tests__/session.test.js.map +1 -1
- package/dist/hooks/__tests__/skill-guidance-contract.test.js +21 -0
- package/dist/hooks/__tests__/skill-guidance-contract.test.js.map +1 -1
- package/dist/hooks/agents-overlay.d.ts.map +1 -1
- package/dist/hooks/agents-overlay.js +36 -50
- package/dist/hooks/agents-overlay.js.map +1 -1
- package/dist/hooks/deep-interview-config-instruction.js +1 -1
- package/dist/hooks/deep-interview-config-instruction.js.map +1 -1
- package/dist/hooks/extensibility/__tests__/plugin-runner.test.js +31 -0
- package/dist/hooks/extensibility/__tests__/plugin-runner.test.js.map +1 -1
- package/dist/hooks/extensibility/plugin-runner.js +17 -21
- package/dist/hooks/extensibility/plugin-runner.js.map +1 -1
- package/dist/hooks/keyword-detector.d.ts +1 -0
- package/dist/hooks/keyword-detector.d.ts.map +1 -1
- package/dist/hooks/keyword-detector.js +428 -32
- package/dist/hooks/keyword-detector.js.map +1 -1
- package/dist/hooks/keyword-registry.d.ts.map +1 -1
- package/dist/hooks/keyword-registry.js +1 -0
- package/dist/hooks/keyword-registry.js.map +1 -1
- package/dist/hooks/prompt-guidance-contract.d.ts.map +1 -1
- package/dist/hooks/prompt-guidance-contract.js +6 -0
- package/dist/hooks/prompt-guidance-contract.js.map +1 -1
- package/dist/hooks/session.d.ts +3 -0
- package/dist/hooks/session.d.ts.map +1 -1
- package/dist/hooks/session.js +13 -5
- package/dist/hooks/session.js.map +1 -1
- package/dist/hud/__tests__/authority.test.js +469 -31
- package/dist/hud/__tests__/authority.test.js.map +1 -1
- package/dist/hud/__tests__/hud-tmux-injection.test.js +2 -1
- package/dist/hud/__tests__/hud-tmux-injection.test.js.map +1 -1
- package/dist/hud/__tests__/index.test.js +210 -2
- package/dist/hud/__tests__/index.test.js.map +1 -1
- package/dist/hud/__tests__/reconcile.test.js +588 -28
- package/dist/hud/__tests__/reconcile.test.js.map +1 -1
- package/dist/hud/__tests__/render.test.js +61 -0
- package/dist/hud/__tests__/render.test.js.map +1 -1
- package/dist/hud/__tests__/state.test.js +208 -0
- package/dist/hud/__tests__/state.test.js.map +1 -1
- package/dist/hud/__tests__/tmux.test.js +314 -22
- package/dist/hud/__tests__/tmux.test.js.map +1 -1
- package/dist/hud/authority.d.ts +5 -0
- package/dist/hud/authority.d.ts.map +1 -1
- package/dist/hud/authority.js +337 -30
- package/dist/hud/authority.js.map +1 -1
- package/dist/hud/index.d.ts +20 -2
- package/dist/hud/index.d.ts.map +1 -1
- package/dist/hud/index.js +103 -26
- package/dist/hud/index.js.map +1 -1
- package/dist/hud/reconcile.d.ts +3 -3
- package/dist/hud/reconcile.d.ts.map +1 -1
- package/dist/hud/reconcile.js +129 -20
- package/dist/hud/reconcile.js.map +1 -1
- package/dist/hud/render.d.ts.map +1 -1
- package/dist/hud/render.js +35 -0
- package/dist/hud/render.js.map +1 -1
- package/dist/hud/state.d.ts.map +1 -1
- package/dist/hud/state.js +64 -50
- package/dist/hud/state.js.map +1 -1
- package/dist/hud/tmux.d.ts +26 -6
- package/dist/hud/tmux.d.ts.map +1 -1
- package/dist/hud/tmux.js +173 -38
- package/dist/hud/tmux.js.map +1 -1
- package/dist/hud/types.d.ts +11 -0
- package/dist/hud/types.d.ts.map +1 -1
- package/dist/hud/types.js.map +1 -1
- package/dist/mcp/__tests__/hermes-bridge.test.js +203 -7
- package/dist/mcp/__tests__/hermes-bridge.test.js.map +1 -1
- package/dist/mcp/__tests__/state-paths.test.js +71 -1
- package/dist/mcp/__tests__/state-paths.test.js.map +1 -1
- package/dist/mcp/__tests__/state-server.test.js +13 -1
- package/dist/mcp/__tests__/state-server.test.js.map +1 -1
- package/dist/mcp/hermes-bridge.d.ts +12 -2
- package/dist/mcp/hermes-bridge.d.ts.map +1 -1
- package/dist/mcp/hermes-bridge.js +83 -9
- package/dist/mcp/hermes-bridge.js.map +1 -1
- package/dist/mcp/state-paths.d.ts +32 -0
- package/dist/mcp/state-paths.d.ts.map +1 -1
- package/dist/mcp/state-paths.js +113 -17
- package/dist/mcp/state-paths.js.map +1 -1
- package/dist/mcp/state-server.d.ts +4 -4
- package/dist/modes/__tests__/base-autoresearch-contract.test.js +7 -1
- package/dist/modes/__tests__/base-autoresearch-contract.test.js.map +1 -1
- package/dist/pipeline/__tests__/stages.test.js +130 -0
- package/dist/pipeline/__tests__/stages.test.js.map +1 -1
- package/dist/pipeline/orchestrator.js +1 -1
- package/dist/pipeline/orchestrator.js.map +1 -1
- package/dist/pipeline/stages/ralplan.d.ts +1 -0
- package/dist/pipeline/stages/ralplan.d.ts.map +1 -1
- package/dist/pipeline/stages/ralplan.js +14 -5
- package/dist/pipeline/stages/ralplan.js.map +1 -1
- package/dist/question/__tests__/deep-interview.test.js +160 -2
- package/dist/question/__tests__/deep-interview.test.js.map +1 -1
- package/dist/question/__tests__/policy.test.js +63 -3
- package/dist/question/__tests__/policy.test.js.map +1 -1
- package/dist/question/__tests__/renderer.test.js +191 -2
- package/dist/question/__tests__/renderer.test.js.map +1 -1
- package/dist/question/__tests__/state.test.js +94 -3
- package/dist/question/__tests__/state.test.js.map +1 -1
- package/dist/question/__tests__/ui.test.js +4 -0
- package/dist/question/__tests__/ui.test.js.map +1 -1
- package/dist/question/autopilot-wait.d.ts +12 -2
- package/dist/question/autopilot-wait.d.ts.map +1 -1
- package/dist/question/autopilot-wait.js +158 -47
- package/dist/question/autopilot-wait.js.map +1 -1
- package/dist/question/deep-interview.d.ts.map +1 -1
- package/dist/question/deep-interview.js +22 -6
- package/dist/question/deep-interview.js.map +1 -1
- package/dist/question/policy.d.ts.map +1 -1
- package/dist/question/policy.js +2 -5
- package/dist/question/policy.js.map +1 -1
- package/dist/question/renderer.d.ts +12 -0
- package/dist/question/renderer.d.ts.map +1 -1
- package/dist/question/renderer.js +87 -3
- package/dist/question/renderer.js.map +1 -1
- package/dist/question/state.d.ts +8 -1
- package/dist/question/state.d.ts.map +1 -1
- package/dist/question/state.js +54 -14
- package/dist/question/state.js.map +1 -1
- package/dist/question/types.d.ts +1 -1
- package/dist/question/types.d.ts.map +1 -1
- package/dist/question/ui.d.ts +1 -0
- package/dist/question/ui.d.ts.map +1 -1
- package/dist/question/ui.js +1 -0
- package/dist/question/ui.js.map +1 -1
- package/dist/ralplan/__tests__/runtime.test.js +191 -0
- package/dist/ralplan/__tests__/runtime.test.js.map +1 -1
- package/dist/ralplan/consensus-gate.d.ts +9 -1
- package/dist/ralplan/consensus-gate.d.ts.map +1 -1
- package/dist/ralplan/consensus-gate.js +84 -2
- package/dist/ralplan/consensus-gate.js.map +1 -1
- package/dist/ralplan/runtime.d.ts +9 -0
- package/dist/ralplan/runtime.d.ts.map +1 -1
- package/dist/ralplan/runtime.js +32 -11
- package/dist/ralplan/runtime.js.map +1 -1
- package/dist/scripts/__tests__/codex-native-hook.test.js +2315 -280
- package/dist/scripts/__tests__/codex-native-hook.test.js.map +1 -1
- package/dist/scripts/__tests__/notify-state-io.test.js +72 -1
- package/dist/scripts/__tests__/notify-state-io.test.js.map +1 -1
- package/dist/scripts/__tests__/notify-tmux-injection.test.d.ts +2 -0
- package/dist/scripts/__tests__/notify-tmux-injection.test.d.ts.map +1 -0
- package/dist/scripts/__tests__/notify-tmux-injection.test.js +57 -0
- package/dist/scripts/__tests__/notify-tmux-injection.test.js.map +1 -0
- package/dist/scripts/__tests__/run-test-files.test.js +74 -0
- package/dist/scripts/__tests__/run-test-files.test.js.map +1 -1
- package/dist/scripts/__tests__/verify-native-agents.test.js +65 -0
- package/dist/scripts/__tests__/verify-native-agents.test.js.map +1 -1
- package/dist/scripts/codex-native-hook.d.ts.map +1 -1
- package/dist/scripts/codex-native-hook.js +431 -56
- package/dist/scripts/codex-native-hook.js.map +1 -1
- package/dist/scripts/codex-native-pre-post.d.ts.map +1 -1
- package/dist/scripts/codex-native-pre-post.js +79 -1
- package/dist/scripts/codex-native-pre-post.js.map +1 -1
- package/dist/scripts/eval/eval-parity-smoke.js +1 -1
- package/dist/scripts/eval/eval-parity-smoke.js.map +1 -1
- package/dist/scripts/hook-payload-guard.d.ts +9 -0
- package/dist/scripts/hook-payload-guard.d.ts.map +1 -0
- package/dist/scripts/hook-payload-guard.js +111 -0
- package/dist/scripts/hook-payload-guard.js.map +1 -0
- package/dist/scripts/notify-fallback-watcher.js +8 -1
- package/dist/scripts/notify-fallback-watcher.js.map +1 -1
- package/dist/scripts/notify-hook/__tests__/payload-guard.test.d.ts +2 -0
- package/dist/scripts/notify-hook/__tests__/payload-guard.test.d.ts.map +1 -0
- package/dist/scripts/notify-hook/__tests__/payload-guard.test.js +39 -0
- package/dist/scripts/notify-hook/__tests__/payload-guard.test.js.map +1 -0
- package/dist/scripts/notify-hook/auto-nudge.d.ts.map +1 -1
- package/dist/scripts/notify-hook/auto-nudge.js +3 -1
- package/dist/scripts/notify-hook/auto-nudge.js.map +1 -1
- package/dist/scripts/notify-hook/ralph-session-resume.d.ts.map +1 -1
- package/dist/scripts/notify-hook/ralph-session-resume.js +3 -10
- package/dist/scripts/notify-hook/ralph-session-resume.js.map +1 -1
- package/dist/scripts/notify-hook/state-io.d.ts.map +1 -1
- package/dist/scripts/notify-hook/state-io.js +62 -38
- package/dist/scripts/notify-hook/state-io.js.map +1 -1
- package/dist/scripts/notify-hook/team-leader-nudge.d.ts.map +1 -1
- package/dist/scripts/notify-hook/team-leader-nudge.js +7 -0
- package/dist/scripts/notify-hook/team-leader-nudge.js.map +1 -1
- package/dist/scripts/notify-hook/team-worker-stop.d.ts.map +1 -1
- package/dist/scripts/notify-hook/team-worker-stop.js +234 -86
- package/dist/scripts/notify-hook/team-worker-stop.js.map +1 -1
- package/dist/scripts/notify-hook/tmux-injection.d.ts +7 -0
- package/dist/scripts/notify-hook/tmux-injection.d.ts.map +1 -1
- package/dist/scripts/notify-hook/tmux-injection.js +24 -18
- package/dist/scripts/notify-hook/tmux-injection.js.map +1 -1
- package/dist/scripts/notify-hook.js +86 -13
- package/dist/scripts/notify-hook.js.map +1 -1
- package/dist/scripts/run-test-files.js +193 -22
- package/dist/scripts/run-test-files.js.map +1 -1
- package/dist/scripts/sync-plugin-mirror.d.ts.map +1 -1
- package/dist/scripts/sync-plugin-mirror.js +61 -3
- package/dist/scripts/sync-plugin-mirror.js.map +1 -1
- package/dist/scripts/verify-native-agents.d.ts.map +1 -1
- package/dist/scripts/verify-native-agents.js +58 -1
- package/dist/scripts/verify-native-agents.js.map +1 -1
- package/dist/state/__tests__/operations.test.js +1125 -1
- package/dist/state/__tests__/operations.test.js.map +1 -1
- package/dist/state/__tests__/skill-active.test.js +46 -1
- package/dist/state/__tests__/skill-active.test.js.map +1 -1
- package/dist/state/__tests__/workflow-transition.test.js +98 -7
- package/dist/state/__tests__/workflow-transition.test.js.map +1 -1
- package/dist/state/operations.d.ts.map +1 -1
- package/dist/state/operations.js +159 -2
- package/dist/state/operations.js.map +1 -1
- package/dist/state/skill-active.js +6 -8
- package/dist/state/skill-active.js.map +1 -1
- package/dist/state/workflow-transition-reconcile.d.ts +6 -0
- package/dist/state/workflow-transition-reconcile.d.ts.map +1 -1
- package/dist/state/workflow-transition-reconcile.js +38 -15
- package/dist/state/workflow-transition-reconcile.js.map +1 -1
- package/dist/state/workflow-transition.d.ts.map +1 -1
- package/dist/state/workflow-transition.js +10 -3
- package/dist/state/workflow-transition.js.map +1 -1
- package/dist/subagents/__tests__/tracker.test.js +139 -0
- package/dist/subagents/__tests__/tracker.test.js.map +1 -1
- package/dist/subagents/tracker.d.ts +3 -0
- package/dist/subagents/tracker.d.ts.map +1 -1
- package/dist/subagents/tracker.js +41 -4
- package/dist/subagents/tracker.js.map +1 -1
- package/dist/team/__tests__/coordination-protocol.test.d.ts +2 -0
- package/dist/team/__tests__/coordination-protocol.test.d.ts.map +1 -0
- package/dist/team/__tests__/coordination-protocol.test.js +173 -0
- package/dist/team/__tests__/coordination-protocol.test.js.map +1 -0
- package/dist/team/__tests__/runtime.test.js +52 -3
- package/dist/team/__tests__/runtime.test.js.map +1 -1
- package/dist/team/__tests__/scaling.test.js +9 -4
- package/dist/team/__tests__/scaling.test.js.map +1 -1
- package/dist/team/__tests__/state.test.js +83 -0
- package/dist/team/__tests__/state.test.js.map +1 -1
- package/dist/team/__tests__/tmux-session.test.js +240 -2
- package/dist/team/__tests__/tmux-session.test.js.map +1 -1
- package/dist/team/__tests__/worker-bootstrap.test.js +84 -0
- package/dist/team/__tests__/worker-bootstrap.test.js.map +1 -1
- package/dist/team/__tests__/worker-runtime-identity.test.js +4 -2
- package/dist/team/__tests__/worker-runtime-identity.test.js.map +1 -1
- package/dist/team/coordination-protocol.d.ts +14 -0
- package/dist/team/coordination-protocol.d.ts.map +1 -0
- package/dist/team/coordination-protocol.js +244 -0
- package/dist/team/coordination-protocol.js.map +1 -0
- package/dist/team/runtime.d.ts +1 -0
- package/dist/team/runtime.d.ts.map +1 -1
- package/dist/team/runtime.js +19 -3
- package/dist/team/runtime.js.map +1 -1
- package/dist/team/scaling.d.ts.map +1 -1
- package/dist/team/scaling.js +3 -2
- package/dist/team/scaling.js.map +1 -1
- package/dist/team/state/tasks.d.ts.map +1 -1
- package/dist/team/state/tasks.js +24 -0
- package/dist/team/state/tasks.js.map +1 -1
- package/dist/team/state/types.d.ts +21 -1
- package/dist/team/state/types.d.ts.map +1 -1
- package/dist/team/state/types.js.map +1 -1
- package/dist/team/state.d.ts +17 -1
- package/dist/team/state.d.ts.map +1 -1
- package/dist/team/state.js +12 -5
- package/dist/team/state.js.map +1 -1
- package/dist/team/team-ops.d.ts +1 -1
- package/dist/team/team-ops.d.ts.map +1 -1
- package/dist/team/team-ops.js.map +1 -1
- package/dist/team/tmux-session.d.ts +2 -0
- package/dist/team/tmux-session.d.ts.map +1 -1
- package/dist/team/tmux-session.js +161 -13
- package/dist/team/tmux-session.js.map +1 -1
- package/dist/team/worker-bootstrap.d.ts.map +1 -1
- package/dist/team/worker-bootstrap.js +63 -0
- package/dist/team/worker-bootstrap.js.map +1 -1
- package/dist/utils/__tests__/agents-model-table.test.js +4 -2
- package/dist/utils/__tests__/agents-model-table.test.js.map +1 -1
- package/dist/utils/agents-model-table.d.ts.map +1 -1
- package/dist/utils/agents-model-table.js +3 -0
- package/dist/utils/agents-model-table.js.map +1 -1
- package/dist/verification/__tests__/ci-rust-gates.test.js +81 -1
- package/dist/verification/__tests__/ci-rust-gates.test.js.map +1 -1
- package/package.json +8 -8
- package/plugins/oh-my-codex/.codex-plugin/plugin.json +1 -1
- package/plugins/oh-my-codex/hooks/codex-native-hook.mjs +334 -21
- package/plugins/oh-my-codex/hooks/hooks.json +1 -2
- package/plugins/oh-my-codex/skills/autopilot/SKILL.md +13 -6
- package/plugins/oh-my-codex/skills/code-review/SKILL.md +7 -7
- package/plugins/oh-my-codex/skills/deep-interview/SKILL.md +9 -4
- package/plugins/oh-my-codex/skills/ralph/SKILL.md +22 -22
- package/plugins/oh-my-codex/skills/ralplan/SKILL.md +12 -0
- package/plugins/oh-my-codex/skills/team/SKILL.md +16 -0
- package/plugins/oh-my-codex/skills/ultraqa/SKILL.md +9 -0
- package/plugins/oh-my-codex/skills/worker/SKILL.md +14 -0
- package/skills/autopilot/SKILL.md +13 -6
- package/skills/code-review/SKILL.md +7 -7
- package/skills/deep-interview/SKILL.md +9 -4
- package/skills/ralph/SKILL.md +22 -22
- package/skills/ralplan/SKILL.md +12 -0
- package/skills/team/SKILL.md +16 -0
- package/skills/ultraqa/SKILL.md +9 -0
- package/skills/worker/SKILL.md +14 -0
- package/src/scripts/__tests__/codex-native-hook.test.ts +4435 -2083
- package/src/scripts/__tests__/notify-state-io.test.ts +95 -0
- package/src/scripts/__tests__/notify-tmux-injection.test.ts +82 -0
- package/src/scripts/__tests__/run-test-files.test.ts +102 -0
- package/src/scripts/__tests__/verify-native-agents.test.ts +75 -0
- package/src/scripts/codex-native-hook.ts +536 -51
- package/src/scripts/codex-native-pre-post.ts +80 -0
- package/src/scripts/demo-team-e2e.sh +10 -7
- package/src/scripts/eval/eval-parity-smoke.ts +1 -1
- package/src/scripts/hook-payload-guard.ts +113 -0
- package/src/scripts/notify-fallback-watcher.ts +8 -1
- package/src/scripts/notify-hook/__tests__/payload-guard.test.ts +41 -0
- package/src/scripts/notify-hook/auto-nudge.ts +3 -1
- package/src/scripts/notify-hook/ralph-session-resume.ts +2 -8
- package/src/scripts/notify-hook/state-io.ts +75 -37
- package/src/scripts/notify-hook/team-leader-nudge.ts +7 -0
- package/src/scripts/notify-hook/team-worker-stop.ts +193 -52
- package/src/scripts/notify-hook/tmux-injection.ts +35 -19
- package/src/scripts/notify-hook.ts +105 -6
- package/src/scripts/run-test-files.ts +192 -22
- package/src/scripts/sync-plugin-mirror.ts +98 -9
- package/src/scripts/verify-native-agents.ts +65 -1
|
@@ -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, shouldSourceTeamWorkerShellRc, 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, classifyWorkerStartupInjectSafety, checkWorkerStartupInjectSafety, dismissTrustPromptIfPresent, evaluateStartupDirectTriggerSafetyCapture, mitigateCopyModeUnderlineArtifacts, } from '../tmux-session.js';
|
|
9
|
+
import { buildClientAttachedReconcileHookName, assertTeamWorkerCliBinaryAvailable, buildWorkerProcessLaunchSpec, buildReconcileHudResizeArgs, buildRegisterClientAttachedReconcileArgs, buildRegisterResizeHookArgs, buildResizeHookName, buildResizeHookTarget, buildScheduleDelayedHudResizeArgs, buildUnregisterClientAttachedReconcileArgs, buildUnregisterResizeHookArgs, buildWorkerStartupCommand, trustWorkerMiseConfigIfAvailable, writeWorkerStartupScriptCommand, shouldSourceTeamWorkerShellRc, buildHudPaneTarget, chooseTeamLeaderPaneId, createTeamSession, enableMouseScrolling, isMsysOrGitBash, isNativeWindows, isTmuxAvailable, isWorkerPaneOpen, restoreStandaloneHudPane, translatePathForMsys, isWsl2, isWorkerAlive, killWorker, killWorkerByPaneId, teardownWorkerPanes, listTeamSessions, resolveTeamWorkerCli, resolveTeamWorkerLaunchMode, resolveWorkerCliForSend, resolveTeamWorkerCliPlan, buildWorkerSubmitPlan, sanitizeTeamName, shouldAttemptAdaptiveRetry, sendToWorker, sendToWorkerStdin, sleepFractionalSeconds, translateWorkerLaunchArgsForCli, waitForWorkerReady, waitForWorkerReadyAsync, paneIsBootstrapping, classifyWorkerStartupInjectSafety, checkWorkerStartupInjectSafety, dismissTrustPromptIfPresent, evaluateStartupDirectTriggerSafetyCapture, 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';
|
|
@@ -972,6 +972,89 @@ describe('buildWorkerStartupCommand', () => {
|
|
|
972
972
|
delete process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
|
|
973
973
|
}
|
|
974
974
|
});
|
|
975
|
+
it('does not use startup scripts on win32/MSYS so existing tmux path translation remains in force', () => {
|
|
976
|
+
const originalPlatform = Object.getOwnPropertyDescriptor(process, 'platform');
|
|
977
|
+
const prevMsystem = process.env.MSYSTEM;
|
|
978
|
+
try {
|
|
979
|
+
Object.defineProperty(process, 'platform', { value: 'win32', configurable: true });
|
|
980
|
+
process.env.MSYSTEM = 'MINGW64';
|
|
981
|
+
assert.equal(writeWorkerStartupScriptCommand('alpha', 1, ['--model', 'gpt-5'], 'C:\\repo', { OMX_TEAM_STATE_ROOT: 'C:\\repo\\.omx\\state' }), null);
|
|
982
|
+
}
|
|
983
|
+
finally {
|
|
984
|
+
if (originalPlatform)
|
|
985
|
+
Object.defineProperty(process, 'platform', originalPlatform);
|
|
986
|
+
if (typeof prevMsystem === 'string')
|
|
987
|
+
process.env.MSYSTEM = prevMsystem;
|
|
988
|
+
else
|
|
989
|
+
delete process.env.MSYSTEM;
|
|
990
|
+
}
|
|
991
|
+
});
|
|
992
|
+
it('writes a short worker startup script under team runtime state when available', async () => {
|
|
993
|
+
const wd = await mkdtemp(join(tmpdir(), 'omx-worker-startup-script-'));
|
|
994
|
+
const stateRoot = join(wd, '.omx', 'state');
|
|
995
|
+
const prevShell = process.env.SHELL;
|
|
996
|
+
const prevBypass = process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
|
|
997
|
+
process.env.SHELL = '/bin/bash';
|
|
998
|
+
process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT = '0';
|
|
999
|
+
try {
|
|
1000
|
+
const cmd = writeWorkerStartupScriptCommand('alpha', 1, ['--model', 'gpt-5'], wd, {
|
|
1001
|
+
OMX_TEAM_STATE_ROOT: stateRoot,
|
|
1002
|
+
OMX_TEAM_LEADER_CWD: wd,
|
|
1003
|
+
}, 'gemini');
|
|
1004
|
+
assert.equal(cmd, `exec /bin/sh '${stateRoot}/team/alpha/runtime/worker-1-startup.sh'`);
|
|
1005
|
+
const script = await readFile(join(stateRoot, 'team', 'alpha', 'runtime', 'worker-1-startup.sh'), 'utf-8');
|
|
1006
|
+
assert.match(script, /^#!\/bin\/sh/m);
|
|
1007
|
+
assert.match(script, new RegExp(`cd '${wd.replace(/'/g, `'\\\\''`)}'`));
|
|
1008
|
+
assert.match(script, /export OMX_TEAM_STATE_ROOT=/);
|
|
1009
|
+
assert.match(script, /exec '\/bin\/bash' -c /);
|
|
1010
|
+
assert.doesNotMatch(cmd ?? '', /OMX_TEAM_STATE_ROOT=/, 'tmux command should point at script instead of inlining env');
|
|
1011
|
+
}
|
|
1012
|
+
finally {
|
|
1013
|
+
if (typeof prevShell === 'string')
|
|
1014
|
+
process.env.SHELL = prevShell;
|
|
1015
|
+
else
|
|
1016
|
+
delete process.env.SHELL;
|
|
1017
|
+
if (typeof prevBypass === 'string')
|
|
1018
|
+
process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT = prevBypass;
|
|
1019
|
+
else
|
|
1020
|
+
delete process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
|
|
1021
|
+
await rm(wd, { recursive: true, force: true });
|
|
1022
|
+
}
|
|
1023
|
+
});
|
|
1024
|
+
it('trusts worktree .mise.toml before worker launch when mise is available', async () => {
|
|
1025
|
+
const wd = await mkdtemp(join(tmpdir(), 'omx-worker-mise-trust-'));
|
|
1026
|
+
const fakeBin = join(wd, 'bin');
|
|
1027
|
+
const logPath = join(wd, 'mise.log');
|
|
1028
|
+
const previousPath = process.env.PATH;
|
|
1029
|
+
try {
|
|
1030
|
+
await mkdir(fakeBin, { recursive: true });
|
|
1031
|
+
await writeFile(join(wd, '.mise.toml'), '[tools]\nnode = "latest"\n');
|
|
1032
|
+
await writeFile(join(fakeBin, 'mise'), `#!/bin/sh\nprintf '%s\\n' "$*" >> '${logPath}'\nexit 0\n`);
|
|
1033
|
+
await chmod(join(fakeBin, 'mise'), 0o755);
|
|
1034
|
+
process.env.PATH = `${fakeBin}:${previousPath ?? ''}`;
|
|
1035
|
+
assert.equal(trustWorkerMiseConfigIfAvailable(wd), true);
|
|
1036
|
+
assert.match(await readFile(logPath, 'utf-8'), new RegExp(`trust --yes ${wd.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&')}\\/\\.mise\\.toml`));
|
|
1037
|
+
}
|
|
1038
|
+
finally {
|
|
1039
|
+
if (typeof previousPath === 'string')
|
|
1040
|
+
process.env.PATH = previousPath;
|
|
1041
|
+
else
|
|
1042
|
+
delete process.env.PATH;
|
|
1043
|
+
await rm(wd, { recursive: true, force: true });
|
|
1044
|
+
}
|
|
1045
|
+
});
|
|
1046
|
+
it('fails soft when .mise.toml exists but mise is unavailable', async () => {
|
|
1047
|
+
const wd = await mkdtemp(join(tmpdir(), 'omx-worker-mise-missing-'));
|
|
1048
|
+
try {
|
|
1049
|
+
await writeFile(join(wd, '.mise.toml'), '[tools]\nnode = "latest"\n');
|
|
1050
|
+
withEmptyPath(() => {
|
|
1051
|
+
assert.equal(trustWorkerMiseConfigIfAvailable(wd), false);
|
|
1052
|
+
});
|
|
1053
|
+
}
|
|
1054
|
+
finally {
|
|
1055
|
+
await rm(wd, { recursive: true, force: true });
|
|
1056
|
+
}
|
|
1057
|
+
});
|
|
975
1058
|
it('inherits only allowlisted ambient proxy env vars for tmux startup commands', () => {
|
|
976
1059
|
const prevShell = process.env.SHELL;
|
|
977
1060
|
const prevBypass = process.env.OMX_BYPASS_DEFAULT_SYSTEM_PROMPT;
|
|
@@ -3165,6 +3248,90 @@ esac
|
|
|
3165
3248
|
await rm(cwd, { recursive: true, force: true });
|
|
3166
3249
|
}
|
|
3167
3250
|
});
|
|
3251
|
+
it('degrades HUD run-shell resize failures to warnings during team startup', async () => {
|
|
3252
|
+
const cwd = await mkdtemp(join(tmpdir(), 'omx-team-runshell-fallback-'));
|
|
3253
|
+
const prevTmux = process.env.TMUX;
|
|
3254
|
+
const prevTmuxPane = process.env.TMUX_PANE;
|
|
3255
|
+
const prevWorkerCli = process.env.OMX_TEAM_WORKER_CLI;
|
|
3256
|
+
const prevWarn = console.warn;
|
|
3257
|
+
const warnings = [];
|
|
3258
|
+
try {
|
|
3259
|
+
await withMockTmuxFixture('omx-tmux-runshell-fallback-', (logPath) => `#!/bin/sh
|
|
3260
|
+
set -eu
|
|
3261
|
+
printf '%s\n' "$*" >> "${logPath}"
|
|
3262
|
+
case "\${1:-}" in
|
|
3263
|
+
-V)
|
|
3264
|
+
echo "tmux 3.4"
|
|
3265
|
+
exit 0
|
|
3266
|
+
;;
|
|
3267
|
+
display-message)
|
|
3268
|
+
case "$*" in
|
|
3269
|
+
*"#{window_width}"*) echo "120" ;;
|
|
3270
|
+
*) echo "leader:0 %1" ;;
|
|
3271
|
+
esac
|
|
3272
|
+
exit 0
|
|
3273
|
+
;;
|
|
3274
|
+
list-panes)
|
|
3275
|
+
case "$*" in
|
|
3276
|
+
*"pane_current_command"*) printf "%%1\\tnode\\t'codex'\\n" ;;
|
|
3277
|
+
*) printf "%%1\\n" ;;
|
|
3278
|
+
esac
|
|
3279
|
+
exit 0
|
|
3280
|
+
;;
|
|
3281
|
+
split-window)
|
|
3282
|
+
case "$*" in
|
|
3283
|
+
*" -h "*) echo "%2" ;;
|
|
3284
|
+
*) echo "%3" ;;
|
|
3285
|
+
esac
|
|
3286
|
+
exit 0
|
|
3287
|
+
;;
|
|
3288
|
+
run-shell)
|
|
3289
|
+
echo "Unsupported tmux compatibility command: run-shell" >&2
|
|
3290
|
+
exit 1
|
|
3291
|
+
;;
|
|
3292
|
+
set-option|resize-pane|select-layout|set-window-option|select-pane|set-hook|send-keys)
|
|
3293
|
+
exit 0
|
|
3294
|
+
;;
|
|
3295
|
+
*)
|
|
3296
|
+
exit 0
|
|
3297
|
+
;;
|
|
3298
|
+
esac
|
|
3299
|
+
`, async ({ logPath }) => {
|
|
3300
|
+
const fakeBinDir = join(logPath, '..');
|
|
3301
|
+
const geminiPath = join(fakeBinDir, 'gemini');
|
|
3302
|
+
await writeFile(geminiPath, '#!/bin/sh\nexit 0\n');
|
|
3303
|
+
await chmod(geminiPath, 0o755);
|
|
3304
|
+
process.env.TMUX = 'leader-session,stub,0';
|
|
3305
|
+
process.env.TMUX_PANE = '%1';
|
|
3306
|
+
process.env.OMX_TEAM_WORKER_CLI = 'gemini';
|
|
3307
|
+
console.warn = (...args) => { warnings.push(args.map(String).join(' ')); };
|
|
3308
|
+
const session = createTeamSession('Run Shell Fallback', 1, cwd);
|
|
3309
|
+
assert.equal(session.hudPaneId, '%3');
|
|
3310
|
+
assert.match(warnings.join('\n'), /HUD resize/);
|
|
3311
|
+
assert.match(warnings.join('\n'), /Unsupported tmux compatibility command: run-shell/);
|
|
3312
|
+
const tmuxLog = await readFile(logPath, 'utf-8');
|
|
3313
|
+
assert.match(tmuxLog, /run-shell -b sleep/);
|
|
3314
|
+
assert.doesNotMatch(tmuxLog, /kill-pane -t %2/);
|
|
3315
|
+
assert.doesNotMatch(tmuxLog, /kill-pane -t %3/);
|
|
3316
|
+
});
|
|
3317
|
+
}
|
|
3318
|
+
finally {
|
|
3319
|
+
console.warn = prevWarn;
|
|
3320
|
+
if (typeof prevTmux === 'string')
|
|
3321
|
+
process.env.TMUX = prevTmux;
|
|
3322
|
+
else
|
|
3323
|
+
delete process.env.TMUX;
|
|
3324
|
+
if (typeof prevTmuxPane === 'string')
|
|
3325
|
+
process.env.TMUX_PANE = prevTmuxPane;
|
|
3326
|
+
else
|
|
3327
|
+
delete process.env.TMUX_PANE;
|
|
3328
|
+
if (typeof prevWorkerCli === 'string')
|
|
3329
|
+
process.env.OMX_TEAM_WORKER_CLI = prevWorkerCli;
|
|
3330
|
+
else
|
|
3331
|
+
delete process.env.OMX_TEAM_WORKER_CLI;
|
|
3332
|
+
await rm(cwd, { recursive: true, force: true });
|
|
3333
|
+
}
|
|
3334
|
+
});
|
|
3168
3335
|
});
|
|
3169
3336
|
describe('native Windows HUD reconciliation', () => {
|
|
3170
3337
|
it('allows team startup on native Windows when current tmux client is reachable without TMUX env vars', async () => {
|
|
@@ -3244,7 +3411,7 @@ esac
|
|
|
3244
3411
|
assert.equal(session.leaderPaneId, '%1');
|
|
3245
3412
|
assert.equal(session.hudPaneId, '%3');
|
|
3246
3413
|
const tmuxLog = await readFile(logPath, 'utf-8');
|
|
3247
|
-
assert.match(tmuxLog, /display-message -p
|
|
3414
|
+
assert.match(tmuxLog, /display-message -p #\{session_name\}:#\{window_index\} #\{pane_id\}/);
|
|
3248
3415
|
assert.match(tmuxLog, /powershell\.exe -NoLogo -NoProfile -ExecutionPolicy Bypass -EncodedCommand/);
|
|
3249
3416
|
assert.doesNotMatch(tmuxLog, /\/bin\/sh -lc/);
|
|
3250
3417
|
assert.match(tmuxLog, new RegExp(`resize-pane -t %3 -y ${HUD_TMUX_TEAM_HEIGHT_LINES}`));
|
|
@@ -3592,6 +3759,51 @@ esac
|
|
|
3592
3759
|
await rm(cwd, { recursive: true, force: true });
|
|
3593
3760
|
}
|
|
3594
3761
|
});
|
|
3762
|
+
it('reuses an existing standalone HUD pane across repeated restore calls', async () => {
|
|
3763
|
+
const cwd = await mkdtemp(join(tmpdir(), 'omx-standalone-reuse-hud-'));
|
|
3764
|
+
try {
|
|
3765
|
+
await withMockTmuxFixture('omx-tmux-reuse-standalone-hud-', (logPath) => {
|
|
3766
|
+
const statePath = `${logPath}.state`;
|
|
3767
|
+
return `#!/bin/sh
|
|
3768
|
+
set -eu
|
|
3769
|
+
printf '%s\\n' "$*" >> "${logPath}"
|
|
3770
|
+
case "\${1:-}" in
|
|
3771
|
+
list-panes)
|
|
3772
|
+
printf '%%11\\tzsh\\tzsh\\n'
|
|
3773
|
+
if [ -f "${statePath}" ]; then
|
|
3774
|
+
printf "%%44\\tnode\\texec env OMX_TMUX_HUD_OWNER=1 OMX_TMUX_HUD_LEADER_PANE='%%11' /node /omx.js hud --watch\\n"
|
|
3775
|
+
fi
|
|
3776
|
+
exit 0
|
|
3777
|
+
;;
|
|
3778
|
+
split-window)
|
|
3779
|
+
: > "${statePath}"
|
|
3780
|
+
echo "%44"
|
|
3781
|
+
exit 0
|
|
3782
|
+
;;
|
|
3783
|
+
run-shell|select-pane|resize-pane|set-hook|kill-pane)
|
|
3784
|
+
exit 0
|
|
3785
|
+
;;
|
|
3786
|
+
*)
|
|
3787
|
+
exit 0
|
|
3788
|
+
;;
|
|
3789
|
+
esac
|
|
3790
|
+
`;
|
|
3791
|
+
}, async ({ logPath }) => {
|
|
3792
|
+
const firstPaneId = restoreStandaloneHudPane('%11', cwd);
|
|
3793
|
+
const secondPaneId = restoreStandaloneHudPane('%11', cwd);
|
|
3794
|
+
assert.equal(firstPaneId, '%44');
|
|
3795
|
+
assert.equal(secondPaneId, '%44');
|
|
3796
|
+
const tmuxLog = await readFile(logPath, 'utf-8');
|
|
3797
|
+
const splitCount = (tmuxLog.match(/(^|\n)split-window /g) ?? []).length;
|
|
3798
|
+
assert.equal(splitCount, 1);
|
|
3799
|
+
assert.doesNotMatch(tmuxLog, /kill-pane -t %44/);
|
|
3800
|
+
assert.match(tmuxLog, /list-panes -t %11 -F #\{pane_id\}\t#\{pane_current_command\}\t#\{pane_start_command\}/);
|
|
3801
|
+
});
|
|
3802
|
+
}
|
|
3803
|
+
finally {
|
|
3804
|
+
await rm(cwd, { recursive: true, force: true });
|
|
3805
|
+
}
|
|
3806
|
+
});
|
|
3595
3807
|
it('restores standalone HUD panes with an absolute OMX entry path after cwd drift', async () => {
|
|
3596
3808
|
const cwd = await mkdtemp(join(tmpdir(), 'omx-standalone-relative-hud-'));
|
|
3597
3809
|
const startupCwd = await mkdtemp(join(tmpdir(), 'omx-standalone-relative-start-'));
|
|
@@ -3793,6 +4005,32 @@ describe('isWorkerAlive', () => {
|
|
|
3793
4005
|
assert.equal(isWorkerAlive('omx-team-x', 1), false);
|
|
3794
4006
|
});
|
|
3795
4007
|
});
|
|
4008
|
+
it('treats an existing non-dead pane id as live even when pane_pid is unavailable', async () => {
|
|
4009
|
+
await withMockTmuxFixture('omx-pane-id-liveness-', (logPath) => `#!/bin/sh
|
|
4010
|
+
set -eu
|
|
4011
|
+
printf '%s\n' "$*" >> "${logPath}"
|
|
4012
|
+
case "\${1:-}" in
|
|
4013
|
+
-V)
|
|
4014
|
+
echo "tmux 3.4"
|
|
4015
|
+
exit 0
|
|
4016
|
+
;;
|
|
4017
|
+
list-panes)
|
|
4018
|
+
if [ "$2" = "-a" ]; then
|
|
4019
|
+
printf "%%77 0 \\n%%88 1 \\n"
|
|
4020
|
+
exit 0
|
|
4021
|
+
fi
|
|
4022
|
+
exit 1
|
|
4023
|
+
;;
|
|
4024
|
+
*)
|
|
4025
|
+
exit 1
|
|
4026
|
+
;;
|
|
4027
|
+
esac
|
|
4028
|
+
`, async () => {
|
|
4029
|
+
assert.equal(isWorkerAlive('ignored-session', 1, '%77'), true);
|
|
4030
|
+
assert.equal(isWorkerPaneOpen('ignored-session', 1, '%77'), true);
|
|
4031
|
+
assert.equal(isWorkerAlive('ignored-session', 2, '%88'), false);
|
|
4032
|
+
});
|
|
4033
|
+
});
|
|
3796
4034
|
});
|
|
3797
4035
|
describe('isWsl2', () => {
|
|
3798
4036
|
it('returns true when WSL_DISTRO_NAME is set', () => {
|