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,6 +6,7 @@ import { join } from 'node:path';
|
|
|
6
6
|
|
|
7
7
|
import {
|
|
8
8
|
getScopedStatePath,
|
|
9
|
+
readCurrentSessionId,
|
|
9
10
|
readScopedJsonIfExists,
|
|
10
11
|
resolveScopedStateDir,
|
|
11
12
|
writeScopedJson,
|
|
@@ -70,4 +71,98 @@ describe('notify-hook state I/O session authority', () => {
|
|
|
70
71
|
await rm(wd, { recursive: true, force: true });
|
|
71
72
|
}
|
|
72
73
|
});
|
|
74
|
+
|
|
75
|
+
it('resolves current session from authoritative team state root without cwd inference', async () => {
|
|
76
|
+
const wd = await mkdtemp(join(tmpdir(), 'omx-notify-state-io-team-root-'));
|
|
77
|
+
try {
|
|
78
|
+
const teamStateRoot = join(wd, 'team-state-root');
|
|
79
|
+
await mkdir(join(teamStateRoot, 'sessions', 'sess-team-root'), { recursive: true });
|
|
80
|
+
await writeFile(
|
|
81
|
+
join(teamStateRoot, 'session.json'),
|
|
82
|
+
JSON.stringify({ session_id: 'sess-team-root', cwd: join(wd, 'source-repo') }, null, 2),
|
|
83
|
+
'utf-8',
|
|
84
|
+
);
|
|
85
|
+
await writeFile(
|
|
86
|
+
join(teamStateRoot, 'hud-state.json'),
|
|
87
|
+
JSON.stringify({ turn_count: 99 }, null, 2),
|
|
88
|
+
'utf-8',
|
|
89
|
+
);
|
|
90
|
+
await writeFile(
|
|
91
|
+
join(teamStateRoot, 'sessions', 'sess-team-root', 'hud-state.json'),
|
|
92
|
+
JSON.stringify({ turn_count: 4 }, null, 2),
|
|
93
|
+
'utf-8',
|
|
94
|
+
);
|
|
95
|
+
|
|
96
|
+
assert.equal(await resolveScopedStateDir(teamStateRoot), join(teamStateRoot, 'sessions', 'sess-team-root'));
|
|
97
|
+
const value = await readScopedJsonIfExists(teamStateRoot, 'hud-state.json', undefined, null);
|
|
98
|
+
assert.equal(value?.turn_count, 4);
|
|
99
|
+
} finally {
|
|
100
|
+
await rm(wd, { recursive: true, force: true });
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
it('prefers OMX_SESSION_ID over stale session.json for notify state writes', async () => {
|
|
105
|
+
const wd = await mkdtemp(join(tmpdir(), 'omx-notify-state-io-env-'));
|
|
106
|
+
const previousSessionId = process.env.OMX_SESSION_ID;
|
|
107
|
+
try {
|
|
108
|
+
const stateDir = join(wd, '.omx', 'state');
|
|
109
|
+
await mkdir(join(stateDir, 'sessions', 'sess-env'), { recursive: true });
|
|
110
|
+
await mkdir(join(stateDir, 'sessions', 'sess-stale'), { recursive: true });
|
|
111
|
+
await writeFile(
|
|
112
|
+
join(stateDir, 'session.json'),
|
|
113
|
+
JSON.stringify({ session_id: 'sess-stale', cwd: join(wd, '..', 'other-worktree') }, null, 2),
|
|
114
|
+
'utf-8',
|
|
115
|
+
);
|
|
116
|
+
process.env.OMX_SESSION_ID = 'sess-env';
|
|
117
|
+
|
|
118
|
+
assert.equal(await readCurrentSessionId(stateDir), 'sess-env');
|
|
119
|
+
assert.equal(await resolveScopedStateDir(stateDir), join(stateDir, 'sessions', 'sess-env'));
|
|
120
|
+
|
|
121
|
+
await writeScopedJson(stateDir, 'hud-state.json', undefined, { turn_count: 7 });
|
|
122
|
+
const value = JSON.parse(
|
|
123
|
+
await readFile(join(stateDir, 'sessions', 'sess-env', 'hud-state.json'), 'utf-8'),
|
|
124
|
+
) as { turn_count?: unknown };
|
|
125
|
+
assert.equal(value.turn_count, 7);
|
|
126
|
+
} finally {
|
|
127
|
+
if (typeof previousSessionId === 'string') process.env.OMX_SESSION_ID = previousSessionId;
|
|
128
|
+
else delete process.env.OMX_SESSION_ID;
|
|
129
|
+
await rm(wd, { recursive: true, force: true });
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
it('maps native Codex session aliases to the canonical OMX session', async () => {
|
|
134
|
+
const wd = await mkdtemp(join(tmpdir(), 'omx-notify-state-io-native-alias-'));
|
|
135
|
+
const previousOmxSessionId = process.env.OMX_SESSION_ID;
|
|
136
|
+
const previousCodexSessionId = process.env.CODEX_SESSION_ID;
|
|
137
|
+
try {
|
|
138
|
+
const stateDir = join(wd, '.omx', 'state');
|
|
139
|
+
await mkdir(join(stateDir, 'sessions', 'omx-canonical'), { recursive: true });
|
|
140
|
+
await writeFile(
|
|
141
|
+
join(stateDir, 'session.json'),
|
|
142
|
+
JSON.stringify({
|
|
143
|
+
session_id: 'omx-canonical',
|
|
144
|
+
native_session_id: 'codex-native',
|
|
145
|
+
cwd: wd,
|
|
146
|
+
}, null, 2),
|
|
147
|
+
'utf-8',
|
|
148
|
+
);
|
|
149
|
+
delete process.env.OMX_SESSION_ID;
|
|
150
|
+
process.env.CODEX_SESSION_ID = 'codex-native';
|
|
151
|
+
|
|
152
|
+
assert.equal(await readCurrentSessionId(stateDir), 'omx-canonical');
|
|
153
|
+
assert.equal(await resolveScopedStateDir(stateDir), join(stateDir, 'sessions', 'omx-canonical'));
|
|
154
|
+
|
|
155
|
+
await writeScopedJson(stateDir, 'hud-state.json', undefined, { turn_count: 11 });
|
|
156
|
+
const value = JSON.parse(
|
|
157
|
+
await readFile(join(stateDir, 'sessions', 'omx-canonical', 'hud-state.json'), 'utf-8'),
|
|
158
|
+
) as { turn_count?: unknown };
|
|
159
|
+
assert.equal(value.turn_count, 11);
|
|
160
|
+
} finally {
|
|
161
|
+
if (typeof previousOmxSessionId === 'string') process.env.OMX_SESSION_ID = previousOmxSessionId;
|
|
162
|
+
else delete process.env.OMX_SESSION_ID;
|
|
163
|
+
if (typeof previousCodexSessionId === 'string') process.env.CODEX_SESSION_ID = previousCodexSessionId;
|
|
164
|
+
else delete process.env.CODEX_SESSION_ID;
|
|
165
|
+
await rm(wd, { recursive: true, force: true });
|
|
166
|
+
}
|
|
167
|
+
});
|
|
73
168
|
});
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { describe, it } from 'node:test';
|
|
2
|
+
import assert from 'node:assert/strict';
|
|
3
|
+
import { mkdir, mkdtemp, rm, writeFile } from 'node:fs/promises';
|
|
4
|
+
import { tmpdir } from 'node:os';
|
|
5
|
+
import { join } from 'node:path';
|
|
6
|
+
|
|
7
|
+
import { readVisibleAllowedModes } from '../notify-hook/tmux-injection.js';
|
|
8
|
+
|
|
9
|
+
describe('notify-hook tmux injection canonical skill gating', () => {
|
|
10
|
+
it('reads canonical skill-active state from authoritative team state root', async () => {
|
|
11
|
+
const wd = await mkdtemp(join(tmpdir(), 'omx-notify-tmux-team-root-'));
|
|
12
|
+
try {
|
|
13
|
+
const teamStateRoot = join(wd, 'team-state-root');
|
|
14
|
+
const sessionId = 'sess-team-root';
|
|
15
|
+
await mkdir(join(teamStateRoot, 'sessions', sessionId), { recursive: true });
|
|
16
|
+
await writeFile(
|
|
17
|
+
join(teamStateRoot, 'session.json'),
|
|
18
|
+
JSON.stringify({ session_id: sessionId, cwd: join(wd, 'source-repo') }, null, 2),
|
|
19
|
+
'utf-8',
|
|
20
|
+
);
|
|
21
|
+
await writeFile(
|
|
22
|
+
join(teamStateRoot, 'sessions', sessionId, 'skill-active-state.json'),
|
|
23
|
+
JSON.stringify({
|
|
24
|
+
version: 1,
|
|
25
|
+
active: true,
|
|
26
|
+
skill: 'ralplan',
|
|
27
|
+
phase: 'draft',
|
|
28
|
+
session_id: sessionId,
|
|
29
|
+
active_skills: [{ skill: 'ralplan', active: true, phase: 'draft', session_id: sessionId }],
|
|
30
|
+
}, null, 2),
|
|
31
|
+
'utf-8',
|
|
32
|
+
);
|
|
33
|
+
|
|
34
|
+
const visible = await readVisibleAllowedModes(
|
|
35
|
+
join(wd, 'source-repo'),
|
|
36
|
+
teamStateRoot,
|
|
37
|
+
{},
|
|
38
|
+
['ralplan', 'deep-interview'],
|
|
39
|
+
);
|
|
40
|
+
|
|
41
|
+
assert.equal(visible.canonicalPresent, true);
|
|
42
|
+
assert.equal(visible.sessionScoped, true);
|
|
43
|
+
assert.equal(visible.preferredMode, 'ralplan');
|
|
44
|
+
assert.deepEqual([...visible.allowedSet ?? []], ['ralplan']);
|
|
45
|
+
} finally {
|
|
46
|
+
await rm(wd, { recursive: true, force: true });
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
it('treats missing session canonical state as session-scoped inactive instead of root fallback', async () => {
|
|
51
|
+
const wd = await mkdtemp(join(tmpdir(), 'omx-notify-tmux-missing-canonical-'));
|
|
52
|
+
try {
|
|
53
|
+
const stateDir = join(wd, '.omx', 'state');
|
|
54
|
+
const sessionId = 'sess-current';
|
|
55
|
+
await mkdir(join(stateDir, 'sessions', sessionId), { recursive: true });
|
|
56
|
+
await writeFile(
|
|
57
|
+
join(stateDir, 'session.json'),
|
|
58
|
+
JSON.stringify({ session_id: sessionId, cwd: wd }, null, 2),
|
|
59
|
+
'utf-8',
|
|
60
|
+
);
|
|
61
|
+
await writeFile(
|
|
62
|
+
join(stateDir, 'skill-active-state.json'),
|
|
63
|
+
JSON.stringify({
|
|
64
|
+
version: 1,
|
|
65
|
+
active: true,
|
|
66
|
+
skill: 'ralplan',
|
|
67
|
+
active_skills: [{ skill: 'ralplan', active: true }],
|
|
68
|
+
}, null, 2),
|
|
69
|
+
'utf-8',
|
|
70
|
+
);
|
|
71
|
+
|
|
72
|
+
const visible = await readVisibleAllowedModes(wd, stateDir, {}, ['ralplan']);
|
|
73
|
+
|
|
74
|
+
assert.equal(visible.canonicalPresent, false);
|
|
75
|
+
assert.equal(visible.sessionScoped, true);
|
|
76
|
+
assert.equal(visible.preferredMode, null);
|
|
77
|
+
assert.equal(visible.allowedSet, null);
|
|
78
|
+
} finally {
|
|
79
|
+
await rm(wd, { recursive: true, force: true });
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
});
|
|
@@ -79,6 +79,108 @@ describe('run-test-files diagnostics', () => {
|
|
|
79
79
|
}
|
|
80
80
|
});
|
|
81
81
|
|
|
82
|
+
|
|
83
|
+
it('script-level force exit terminates a completed test child that blocks process exit', () => {
|
|
84
|
+
const wd = mkdtempSync(join(tmpdir(), 'omx-run-test-files-'));
|
|
85
|
+
try {
|
|
86
|
+
const testsDir = join(wd, '__tests__');
|
|
87
|
+
mkdirSync(testsDir, { recursive: true });
|
|
88
|
+
const testPath = join(testsDir, 'exit-block.test.js');
|
|
89
|
+
writeFileSync(
|
|
90
|
+
testPath,
|
|
91
|
+
[
|
|
92
|
+
"import { test } from 'node:test';",
|
|
93
|
+
`test(${JSON.stringify(testPath)}, () => { process.on('exit', () => { while (true) {} }); });`,
|
|
94
|
+
'',
|
|
95
|
+
].join('\n'),
|
|
96
|
+
);
|
|
97
|
+
|
|
98
|
+
const result = runCompiledRunner(
|
|
99
|
+
wd,
|
|
100
|
+
{
|
|
101
|
+
OMX_NODE_TEST_FORCE_EXIT: '1',
|
|
102
|
+
OMX_NODE_TEST_FORCE_EXIT_GRACE_MS: '100',
|
|
103
|
+
OMX_NODE_TEST_RUNNER_TIMEOUT_MS: '2000',
|
|
104
|
+
},
|
|
105
|
+
4_000,
|
|
106
|
+
);
|
|
107
|
+
|
|
108
|
+
assert.equal(result.status, 0, result.stderr || result.stdout);
|
|
109
|
+
assert.match(result.stdout, /ok 1 - .*exit-block\.test\.js/);
|
|
110
|
+
assert.match(result.stderr, /TAP ok 1 with no later failures/);
|
|
111
|
+
} finally {
|
|
112
|
+
rmSync(wd, { recursive: true, force: true });
|
|
113
|
+
}
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
it('cancels script-level force exit when a later TAP failure appears', () => {
|
|
117
|
+
const wd = mkdtempSync(join(tmpdir(), 'omx-run-test-files-'));
|
|
118
|
+
try {
|
|
119
|
+
const testsDir = join(wd, '__tests__');
|
|
120
|
+
mkdirSync(testsDir, { recursive: true });
|
|
121
|
+
writeFileSync(
|
|
122
|
+
join(testsDir, 'late-fail.test.js'),
|
|
123
|
+
[
|
|
124
|
+
"import { test } from 'node:test';",
|
|
125
|
+
"import assert from 'node:assert/strict';",
|
|
126
|
+
"test('passes first', () => {});",
|
|
127
|
+
"test('fails shortly after the first ok line', async () => {",
|
|
128
|
+
" await new Promise((resolve) => setTimeout(resolve, 25));",
|
|
129
|
+
" assert.equal(1, 2);",
|
|
130
|
+
"});",
|
|
131
|
+
'',
|
|
132
|
+
].join('\n'),
|
|
133
|
+
);
|
|
134
|
+
|
|
135
|
+
const result = runCompiledRunner(
|
|
136
|
+
wd,
|
|
137
|
+
{
|
|
138
|
+
OMX_NODE_TEST_FORCE_EXIT: '1',
|
|
139
|
+
OMX_NODE_TEST_FORCE_EXIT_GRACE_MS: '200',
|
|
140
|
+
OMX_NODE_TEST_RUNNER_TIMEOUT_MS: '2000',
|
|
141
|
+
},
|
|
142
|
+
4_000,
|
|
143
|
+
);
|
|
144
|
+
|
|
145
|
+
assert.notEqual(result.status, 0);
|
|
146
|
+
assert.match(result.stdout, /not ok|# fail [1-9]/);
|
|
147
|
+
} finally {
|
|
148
|
+
rmSync(wd, { recursive: true, force: true });
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
|
|
152
|
+
it('preserves failing test status when script-level force exit is enabled', () => {
|
|
153
|
+
const wd = mkdtempSync(join(tmpdir(), 'omx-run-test-files-'));
|
|
154
|
+
try {
|
|
155
|
+
const testsDir = join(wd, '__tests__');
|
|
156
|
+
mkdirSync(testsDir, { recursive: true });
|
|
157
|
+
writeFileSync(
|
|
158
|
+
join(testsDir, 'fail.test.js'),
|
|
159
|
+
[
|
|
160
|
+
"import { test } from 'node:test';",
|
|
161
|
+
"import assert from 'node:assert/strict';",
|
|
162
|
+
"test('fails', () => { assert.equal(1, 2); });",
|
|
163
|
+
'',
|
|
164
|
+
].join('\n'),
|
|
165
|
+
);
|
|
166
|
+
|
|
167
|
+
const result = runCompiledRunner(
|
|
168
|
+
wd,
|
|
169
|
+
{
|
|
170
|
+
OMX_NODE_TEST_FORCE_EXIT: '1',
|
|
171
|
+
OMX_NODE_TEST_FORCE_EXIT_GRACE_MS: '100',
|
|
172
|
+
OMX_NODE_TEST_RUNNER_TIMEOUT_MS: '2000',
|
|
173
|
+
},
|
|
174
|
+
4_000,
|
|
175
|
+
);
|
|
176
|
+
|
|
177
|
+
assert.notEqual(result.status, 0);
|
|
178
|
+
assert.match(result.stdout, /not ok|# fail [1-9]/);
|
|
179
|
+
} finally {
|
|
180
|
+
rmSync(wd, { recursive: true, force: true });
|
|
181
|
+
}
|
|
182
|
+
});
|
|
183
|
+
|
|
82
184
|
it('logs that per-test timeout is disabled by default', () => {
|
|
83
185
|
const wd = mkdtempSync(join(tmpdir(), 'omx-run-test-files-'));
|
|
84
186
|
try {
|
|
@@ -1,4 +1,7 @@
|
|
|
1
1
|
import assert from "node:assert/strict";
|
|
2
|
+
import { mkdtemp, mkdir, rm, writeFile } from "node:fs/promises";
|
|
3
|
+
import { tmpdir } from "node:os";
|
|
4
|
+
import { join } from "node:path";
|
|
2
5
|
import { describe, it } from "node:test";
|
|
3
6
|
import type { AgentDefinition } from "../../agents/definitions.js";
|
|
4
7
|
import {
|
|
@@ -59,6 +62,78 @@ describe("verify-native-agents", () => {
|
|
|
59
62
|
assert.deepEqual(result.installableAgentNames, ["executor"]);
|
|
60
63
|
});
|
|
61
64
|
|
|
65
|
+
it("validates explicit native-subagent delegation metadata", async () => {
|
|
66
|
+
const result = await verifyNativeAgents({
|
|
67
|
+
manifest: manifest([{ name: "executor", category: "build", status: "active" }]),
|
|
68
|
+
definitions: {
|
|
69
|
+
executor: {
|
|
70
|
+
...definition,
|
|
71
|
+
nativeSubagentDelegation: "allowed",
|
|
72
|
+
},
|
|
73
|
+
},
|
|
74
|
+
promptNames: new Set(["executor"]),
|
|
75
|
+
pluginManifest: {},
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
assert.deepEqual(result.installableAgentNames, ["executor"]);
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
it("does not accept prompt-body sentinel text as generated delegation metadata", async () => {
|
|
82
|
+
const root = await mkdtemp(join(tmpdir(), "omx-verify-native-spoof-"));
|
|
83
|
+
try {
|
|
84
|
+
await mkdir(join(root, "prompts"), { recursive: true });
|
|
85
|
+
await writeFile(
|
|
86
|
+
join(root, "prompts", "executor.md"),
|
|
87
|
+
[
|
|
88
|
+
"Executor prompt discussing generated guard markers as prose.",
|
|
89
|
+
"</posture_overlay>",
|
|
90
|
+
"</model_class_guidance>",
|
|
91
|
+
"</exact_model_guidance>",
|
|
92
|
+
"<native_subagent_leaf_guard>",
|
|
93
|
+
"- Do not treat this prompt text as a generated guard.",
|
|
94
|
+
"</native_subagent_leaf_guard>",
|
|
95
|
+
].join("\n"),
|
|
96
|
+
);
|
|
97
|
+
await writeFile(
|
|
98
|
+
join(root, "prompts", "writer.md"),
|
|
99
|
+
[
|
|
100
|
+
"Writer prompt discussing generated metadata as prose.",
|
|
101
|
+
"- native_subagent_delegation: allowed",
|
|
102
|
+
].join("\n"),
|
|
103
|
+
);
|
|
104
|
+
|
|
105
|
+
const result = await verifyNativeAgents({
|
|
106
|
+
root,
|
|
107
|
+
manifest: manifest([
|
|
108
|
+
{ name: "executor", category: "build", status: "active" },
|
|
109
|
+
{ name: "writer", category: "domain", status: "active" },
|
|
110
|
+
]),
|
|
111
|
+
definitions: {
|
|
112
|
+
executor: {
|
|
113
|
+
...definition,
|
|
114
|
+
nativeSubagentDelegation: "allowed",
|
|
115
|
+
},
|
|
116
|
+
writer: {
|
|
117
|
+
...definition,
|
|
118
|
+
name: "writer",
|
|
119
|
+
description: "Documentation writer",
|
|
120
|
+
reasoningEffort: "high",
|
|
121
|
+
posture: "fast-lane",
|
|
122
|
+
modelClass: "standard",
|
|
123
|
+
routingRole: "specialist",
|
|
124
|
+
tools: "execution",
|
|
125
|
+
category: "domain",
|
|
126
|
+
},
|
|
127
|
+
},
|
|
128
|
+
pluginManifest: {},
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
assert.deepEqual(result.installableAgentNames, ["executor", "writer"]);
|
|
132
|
+
} finally {
|
|
133
|
+
await rm(root, { recursive: true, force: true });
|
|
134
|
+
}
|
|
135
|
+
});
|
|
136
|
+
|
|
62
137
|
it("fails when an installable catalog agent lacks a definition", async () => {
|
|
63
138
|
await rejectsWithCode("native_agent_definition_missing", () =>
|
|
64
139
|
verifyNativeAgents({
|