sneakoscope 2.0.14 → 2.0.16
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/README.md +6 -3
- package/crates/sks-core/Cargo.lock +1 -1
- package/crates/sks-core/Cargo.toml +1 -1
- package/crates/sks-core/src/main.rs +1 -1
- package/dist/.sks-build-stamp.json +4 -4
- package/dist/bin/sks.js +1 -1
- package/dist/cli/command-registry.js +2 -1
- package/dist/commands/mad-db.js +5 -0
- package/dist/commands/zellij-slot-pane.js +3 -1
- package/dist/core/agents/agent-orchestrator.js +66 -3
- package/dist/core/agents/agent-plan.js +3 -2
- package/dist/core/agents/agent-scheduler.js +204 -86
- package/dist/core/agents/agent-schema.js +1 -1
- package/dist/core/agents/native-cli-session-swarm.js +199 -15
- package/dist/core/agents/native-cli-worker.js +85 -0
- package/dist/core/agents/parallel-runtime-proof.js +217 -0
- package/dist/core/codex-control/codex-task-runner.js +32 -4
- package/dist/core/codex-control/model-call-concurrency.js +106 -0
- package/dist/core/commands/basic-cli.js +1 -1
- package/dist/core/commands/command-suggestions.js +1 -1
- package/dist/core/commands/mad-db-command.js +106 -0
- package/dist/core/commands/mad-sks-command.js +50 -13
- package/dist/core/commands/naruto-command.js +128 -5
- package/dist/core/commands/research-command.js +13 -1
- package/dist/core/commands/team-command.js +23 -175
- package/dist/core/db-safety.js +55 -1
- package/dist/core/fsx.js +1 -1
- package/dist/core/git/git-worktree-capability.js +18 -0
- package/dist/core/git/git-worktree-manager.js +80 -0
- package/dist/core/git/git-worktree-pool.js +4 -0
- package/dist/core/mad-db/mad-db-capability.js +116 -0
- package/dist/core/mad-db/mad-db-ledger.js +31 -0
- package/dist/core/mad-db/mad-db-policy-resolver.js +48 -0
- package/dist/core/naruto/naruto-concurrency-governor.js +14 -1
- package/dist/core/pipeline-internals/runtime-core.js +74 -8
- package/dist/core/pipeline-internals/runtime-gates.js +44 -0
- package/dist/core/proof/route-proof-gate.js +5 -3
- package/dist/core/proof/route-proof-policy.js +9 -1
- package/dist/core/release/release-gate-affected-selector.js +113 -0
- package/dist/core/release/release-gate-batch-runner.js +67 -0
- package/dist/core/release/release-gate-dag.js +22 -3
- package/dist/core/release/release-gate-resource-governor.js +23 -11
- package/dist/core/research/implementation-blueprint-densifier.js +1 -1
- package/dist/core/research/implementation-blueprint-markdown.js +1 -1
- package/dist/core/research/implementation-blueprint.js +68 -7
- package/dist/core/research/research-final-reviewer.js +27 -1
- package/dist/core/research/research-handoff.js +69 -5
- package/dist/core/research/research-realistic-report.js +162 -0
- package/dist/core/research/research-repetition-detector.js +75 -0
- package/dist/core/research/research-report-quality.js +27 -5
- package/dist/core/research/research-stage-runner.js +40 -13
- package/dist/core/research/research-synthesis-prompt.js +52 -0
- package/dist/core/research/research-synthesis-writer.js +208 -0
- package/dist/core/research.js +60 -48
- package/dist/core/routes.js +23 -19
- package/dist/core/update/update-notice.js +120 -0
- package/dist/core/version.js +1 -1
- package/dist/core/zellij/zellij-dashboard-renderer.js +2 -0
- package/dist/core/zellij/zellij-slot-column-anchor.js +35 -1
- package/dist/core/zellij/zellij-slot-pane-renderer.js +57 -0
- package/dist/core/zellij/zellij-slot-telemetry.js +237 -0
- package/dist/scripts/release-gate-dag-runner.js +5 -0
- package/dist/scripts/release-speed-summary.js +27 -0
- package/package.json +76 -5
- package/schemas/agents/parallel-runtime-proof.schema.json +48 -0
- package/schemas/mad-db/mad-db-capability.schema.json +31 -0
- package/schemas/mad-db/mad-db-ledger.schema.json +14 -0
- package/schemas/research/implementation-blueprint.schema.json +6 -1
- package/schemas/research/research-final-review.schema.json +10 -0
- package/schemas/research/research-synthesis-output.schema.json +62 -0
- package/schemas/update/update-notice.schema.json +19 -0
- package/schemas/zellij/zellij-slot-telemetry.schema.json +89 -0
- package/dist/scripts/agent-ast-aware-work-graph-check.js +0 -25
- package/dist/scripts/agent-backfill-replenishment-check.js +0 -13
- package/dist/scripts/agent-backfill-route-blackbox.js +0 -5
- package/dist/scripts/agent-background-terminals-check.js +0 -16
- package/dist/scripts/agent-cleanup-command-ux-check.js +0 -12
- package/dist/scripts/agent-cleanup-executor-check.js +0 -53
- package/dist/scripts/agent-cleanup-executor-v2-check.js +0 -39
- package/dist/scripts/agent-cli-options-to-task-graph-check.js +0 -5
- package/dist/scripts/agent-codex-app-cockpit-check.js +0 -91
- package/dist/scripts/agent-codex-child-overlap-check.js +0 -21
- package/dist/scripts/agent-dynamic-cockpit-check.js +0 -10
- package/dist/scripts/agent-dynamic-pool-check.js +0 -13
- package/dist/scripts/agent-dynamic-pool-route-blackbox.js +0 -5
- package/dist/scripts/agent-fast-mode-default-check.js +0 -62
- package/dist/scripts/agent-fast-mode-worker-propagation-check.js +0 -7
- package/dist/scripts/agent-follow-up-work-schema-check.js +0 -80
- package/dist/scripts/agent-goal-mode-propagation-check.js +0 -9
- package/dist/scripts/agent-intelligent-work-graph-check.js +0 -25
- package/dist/scripts/agent-janitor-check.js +0 -76
- package/dist/scripts/agent-main-no-scout-check.js +0 -11
- package/dist/scripts/agent-model-authored-patch-envelope-check.js +0 -15
- package/dist/scripts/agent-multi-project-isolation-check.js +0 -86
- package/dist/scripts/agent-native-cli-session-proof-check.js +0 -7
- package/dist/scripts/agent-native-cli-session-swarm-10-check.js +0 -7
- package/dist/scripts/agent-native-cli-session-swarm-20-check.js +0 -7
- package/dist/scripts/agent-native-cli-session-swarm-check.js +0 -7
- package/dist/scripts/agent-no-subagent-scaling-check.js +0 -7
- package/dist/scripts/agent-parallel-write-blackbox.js +0 -56
- package/dist/scripts/agent-parallel-write-kernel-check.js +0 -103
- package/dist/scripts/agent-patch-conflict-rebase-check.js +0 -198
- package/dist/scripts/agent-patch-envelope-extraction-check.js +0 -17
- package/dist/scripts/agent-patch-proof-check.js +0 -41
- package/dist/scripts/agent-patch-proof-runtime-check.js +0 -63
- package/dist/scripts/agent-patch-queue-runtime-check.js +0 -36
- package/dist/scripts/agent-patch-rollback-check.js +0 -38
- package/dist/scripts/agent-patch-rollback-dag-check.js +0 -14
- package/dist/scripts/agent-patch-swarm-route-blackbox.js +0 -10
- package/dist/scripts/agent-patch-swarm-runtime-check.js +0 -10
- package/dist/scripts/agent-patch-swarm-runtime-truth-check.js +0 -76
- package/dist/scripts/agent-patch-transaction-journal-check.js +0 -57
- package/dist/scripts/agent-patch-verification-dag-check.js +0 -14
- package/dist/scripts/agent-proof-contract-reconciled-check.js +0 -5
- package/dist/scripts/agent-real-codex-dynamic-smoke-check.js +0 -166
- package/dist/scripts/agent-real-codex-dynamic-smoke-v2-check.js +0 -14
- package/dist/scripts/agent-real-codex-in-zellij-worker-pane-check.js +0 -229
- package/dist/scripts/agent-real-codex-parallel-workers-10-check.js +0 -5
- package/dist/scripts/agent-real-codex-parallel-workers-20-check.js +0 -5
- package/dist/scripts/agent-real-codex-parallel-workers-5-check.js +0 -5
- package/dist/scripts/agent-real-codex-parallel-workers-check.js +0 -5
- package/dist/scripts/agent-role-config-repair-check.js +0 -33
- package/dist/scripts/agent-rollback-command-check.js +0 -86
- package/dist/scripts/agent-route-truth-backfill-check.js +0 -5
- package/dist/scripts/agent-scheduler-proof-check.js +0 -13
- package/dist/scripts/agent-scheduler-proof-hardening-check.js +0 -22
- package/dist/scripts/agent-session-generation-check.js +0 -21
- package/dist/scripts/agent-slot-pane-binding-proof-check.js +0 -64
- package/dist/scripts/agent-source-intelligence-propagation-check.js +0 -9
- package/dist/scripts/agent-strategy-to-lease-wiring-check.js +0 -32
- package/dist/scripts/agent-strategy-to-patch-strict-check.js +0 -54
- package/dist/scripts/agent-task-graph-expansion-check.js +0 -14
- package/dist/scripts/agent-terminal-generations-check.js +0 -23
- package/dist/scripts/agent-visual-consistency-check.js +0 -9
- package/dist/scripts/agent-wiki-context-proof-check.js +0 -62
- package/dist/scripts/agent-worker-backend-router-check.js +0 -63
- package/dist/scripts/agent-worker-scout-limited-check.js +0 -17
- package/dist/scripts/agent-zellij-dynamic-backfill-panes-check.js +0 -34
- package/dist/scripts/agent-zellij-runtime-check.js +0 -84
- package/dist/scripts/all-feature-deep-completion-check.js +0 -31
- package/dist/scripts/appshots-capability-check.js +0 -18
- package/dist/scripts/appshots-evidence-check.js +0 -48
- package/dist/scripts/appshots-operator-policy-check.js +0 -25
- package/dist/scripts/appshots-privacy-safety-check.js +0 -48
- package/dist/scripts/appshots-source-intelligence-check.js +0 -53
- package/dist/scripts/appshots-thread-attachment-discovery-check.js +0 -87
- package/dist/scripts/appshots-triwiki-voxel-check.js +0 -46
- package/dist/scripts/architecture-guard-check.js +0 -55
- package/dist/scripts/changelog-check.js +0 -47
- package/dist/scripts/codex-0-133-official-compat-report.js +0 -53
- package/dist/scripts/codex-0-134-official-compat-report.js +0 -110
- package/dist/scripts/codex-0-134-runner-truth-check.js +0 -66
- package/dist/scripts/codex-0-135-compat-check.js +0 -57
- package/dist/scripts/codex-0-136-compat-check.js +0 -30
- package/dist/scripts/codex-0-137-compat-check.js +0 -27
- package/dist/scripts/codex-app-fast-ui-preservation-check.js +0 -32
- package/dist/scripts/codex-app-provider-badge-check.js +0 -37
- package/dist/scripts/codex-app-ui-clobber-guard-check.js +0 -22
- package/dist/scripts/codex-app-ui-preservation-check.js +0 -96
- package/dist/scripts/codex-control-all-pipelines-check.js +0 -36
- package/dist/scripts/codex-control-capability-check.js +0 -10
- package/dist/scripts/codex-control-empty-result-retry-check.js +0 -43
- package/dist/scripts/codex-control-event-stream-ledger-check.js +0 -10
- package/dist/scripts/codex-control-keepalive-no-cot-leak-check.js +0 -14
- package/dist/scripts/codex-control-no-legacy-fallback-check.js +0 -31
- package/dist/scripts/codex-control-side-effect-scope-check.js +0 -26
- package/dist/scripts/codex-control-stream-idle-watchdog-check.js +0 -18
- package/dist/scripts/codex-control-structured-output-check.js +0 -11
- package/dist/scripts/codex-control-thread-registry-check.js +0 -11
- package/dist/scripts/codex-control-tool-call-sequence-repair-check.js +0 -14
- package/dist/scripts/codex-environment-scoped-approvals-check.js +0 -10
- package/dist/scripts/codex-exec-output-schema-actual-syntax-check.js +0 -33
- package/dist/scripts/codex-fast-mode-profile-propagation-check.js +0 -12
- package/dist/scripts/codex-history-search-check.js +0 -19
- package/dist/scripts/codex-hook-semantic-check.js +0 -15
- package/dist/scripts/codex-hook-strict-subset-check.js +0 -61
- package/dist/scripts/codex-lb-config-toml-safety-check.js +0 -85
- package/dist/scripts/codex-lb-persistence-truth-check.js +0 -96
- package/dist/scripts/codex-lb-setup-fixture-check.js +0 -91
- package/dist/scripts/codex-lb-setup-truthfulness-check.js +0 -84
- package/dist/scripts/codex-legacy-profile-consumers-removed-check.js +0 -24
- package/dist/scripts/codex-managed-proxy-env-check.js +0 -17
- package/dist/scripts/codex-output-schema-fixture-check.js +0 -25
- package/dist/scripts/codex-permission-profiles-check.js +0 -36
- package/dist/scripts/codex-plugin-list-json-check.js +0 -8
- package/dist/scripts/codex-profile-primary-check.js +0 -13
- package/dist/scripts/codex-project-config-policy-splitter-check.js +0 -51
- package/dist/scripts/codex-resume-cwd-truth-check.js +0 -17
- package/dist/scripts/codex-sdk-all-pipelines-check.js +0 -32
- package/dist/scripts/codex-sdk-backend-router-check.js +0 -65
- package/dist/scripts/codex-sdk-capability-check.js +0 -11
- package/dist/scripts/codex-sdk-core-skill-pipeline-check.js +0 -9
- package/dist/scripts/codex-sdk-dfix-pipeline-check.js +0 -9
- package/dist/scripts/codex-sdk-event-stream-ledger-check.js +0 -9
- package/dist/scripts/codex-sdk-no-legacy-fallback-check.js +0 -33
- package/dist/scripts/codex-sdk-qa-pipeline-check.js +0 -8
- package/dist/scripts/codex-sdk-real-smoke-check.js +0 -39
- package/dist/scripts/codex-sdk-release-review-pipeline-check.js +0 -13
- package/dist/scripts/codex-sdk-research-pipeline-check.js +0 -47
- package/dist/scripts/codex-sdk-sandbox-policy-check.js +0 -21
- package/dist/scripts/codex-sdk-structured-output-check.js +0 -10
- package/dist/scripts/codex-sdk-team-naruto-agent-pipeline-check.js +0 -12
- package/dist/scripts/codex-sdk-thread-registry-check.js +0 -11
- package/dist/scripts/codex-sdk-ux-ppt-review-pipeline-check.js +0 -9
- package/dist/scripts/codex-sdk-zellij-pane-binding-check.js +0 -13
- package/dist/scripts/codex-thread-runtime-choice-check.js +0 -10
- package/dist/scripts/codex-web-adapter-check.js +0 -12
- package/dist/scripts/computer-use-live-evidence-check.js +0 -55
- package/dist/scripts/computer-use-live-optional-check.js +0 -32
- package/dist/scripts/computer-use-policy-check.js +0 -69
- package/dist/scripts/computer-use-visual-route-fixture-check.js +0 -37
- package/dist/scripts/core-skill-card-schema-check.js +0 -61
- package/dist/scripts/core-skill-deployment-snapshot-check.js +0 -54
- package/dist/scripts/core-skill-heldout-validation-check.js +0 -49
- package/dist/scripts/core-skill-no-inference-optimizer-check.js +0 -75
- package/dist/scripts/core-skill-patch-check.js +0 -79
- package/dist/scripts/core-skill-promotion-side-effect-ledger-check.js +0 -64
- package/dist/scripts/core-skill-rollout-scoring-check.js +0 -72
- package/dist/scripts/core-skill-route-runtime-integration-check.js +0 -49
- package/dist/scripts/dfix-fast-blackbox-check.js +0 -37
- package/dist/scripts/dfix-fast-kernel-check.js +0 -26
- package/dist/scripts/dfix-fixture-check.js +0 -6
- package/dist/scripts/dfix-parallel-write-blackbox.js +0 -48
- package/dist/scripts/dfix-patch-handoff-check.js +0 -13
- package/dist/scripts/dfix-patch-swarm-route-blackbox.js +0 -10
- package/dist/scripts/dfix-performance-check.js +0 -15
- package/dist/scripts/dfix-verification-check.js +0 -9
- package/dist/scripts/dfix-verification-recommendation-check.js +0 -15
- package/dist/scripts/docs-truthfulness-check.js +0 -61
- package/dist/scripts/doctor-codex-doctor-parity-check.js +0 -17
- package/dist/scripts/doctor-fix-proves-codex-read-check.js +0 -64
- package/dist/scripts/doctor-fix-recovers-corrupted-config-check.js +0 -122
- package/dist/scripts/doctor-fixes-codex-app-fast-ui-check.js +0 -39
- package/dist/scripts/evidence-fixture-check.js +0 -26
- package/dist/scripts/evidence-flagship-coverage-check.js +0 -55
- package/dist/scripts/fake-real-proof-policy-v2-check.js +0 -27
- package/dist/scripts/fake-vs-real-proof-policy-check.js +0 -14
- package/dist/scripts/fast-codex-service-tier-proof-check.js +0 -42
- package/dist/scripts/flagship-proof-graph-v2-check.js +0 -48
- package/dist/scripts/flagship-proof-graph-v3-check.js +0 -67
- package/dist/scripts/flagship-proof-graph-v4-check.js +0 -61
- package/dist/scripts/git-precommit-fixture-check.js +0 -41
- package/dist/scripts/git-worktree-cache-performance-check.js +0 -25
- package/dist/scripts/git-worktree-capability-check.js +0 -27
- package/dist/scripts/git-worktree-checkpoint-check.js +0 -20
- package/dist/scripts/git-worktree-cleanup-check.js +0 -27
- package/dist/scripts/git-worktree-cross-rebase-check.js +0 -39
- package/dist/scripts/git-worktree-diff-envelope-check.js +0 -17
- package/dist/scripts/git-worktree-diff-export-check.js +0 -43
- package/dist/scripts/git-worktree-dirty-lock-check.js +0 -17
- package/dist/scripts/git-worktree-dirty-main-detection-check.js +0 -14
- package/dist/scripts/git-worktree-integration-primary-check.js +0 -24
- package/dist/scripts/git-worktree-integration-primary-runtime-check.js +0 -20
- package/dist/scripts/git-worktree-manager-check.js +0 -37
- package/dist/scripts/git-worktree-manifest-append-check.js +0 -18
- package/dist/scripts/git-worktree-merge-queue-check.js +0 -31
- package/dist/scripts/git-worktree-pool-performance-check.js +0 -20
- package/dist/scripts/git-worktree-untracked-diff-check.js +0 -18
- package/dist/scripts/goal-mode-official-default-check.js +0 -12
- package/dist/scripts/gpt-final-arbiter-check.js +0 -63
- package/dist/scripts/gpt-final-arbiter-performance-check.js +0 -36
- package/dist/scripts/gpt-image-2-request-validator-check.js +0 -35
- package/dist/scripts/hooks-0.134-context-parity-check.js +0 -20
- package/dist/scripts/hooks-actual-parity-check.js +0 -17
- package/dist/scripts/hooks-actual-parity-v2-check.js +0 -21
- package/dist/scripts/hooks-latest-schema-check.js +0 -20
- package/dist/scripts/hooks-managed-install-fixture-check.js +0 -21
- package/dist/scripts/hooks-official-hash-oracle-check.js +0 -35
- package/dist/scripts/hooks-official-hash-parity-check.js +0 -17
- package/dist/scripts/hooks-subagent-events-check.js +0 -17
- package/dist/scripts/hooks-trust-state-check.js +0 -14
- package/dist/scripts/image-fidelity-fixture-check.js +0 -24
- package/dist/scripts/imagegen-capability-check.js +0 -30
- package/dist/scripts/imagegen-real-smoke-check.js +0 -155
- package/dist/scripts/install-update-preserves-config-check.js +0 -87
- package/dist/scripts/json-schema-recursive-check.js +0 -78
- package/dist/scripts/legacy-multiagent-removal-check.js +0 -85
- package/dist/scripts/legacy-upgrade-matrix-check.js +0 -300
- package/dist/scripts/local-collab-all-pipelines-final-gpt-check.js +0 -21
- package/dist/scripts/local-collab-gpt-final-availability-check.js +0 -58
- package/dist/scripts/local-collab-no-local-only-final-check.js +0 -27
- package/dist/scripts/local-collab-policy-check.js +0 -17
- package/dist/scripts/local-collab-worktree-gpt-final-apply-policy-check.js +0 -63
- package/dist/scripts/local-llm-all-pipelines-check.js +0 -11
- package/dist/scripts/local-llm-cache-performance-check.js +0 -10
- package/dist/scripts/local-llm-capability-check.js +0 -14
- package/dist/scripts/local-llm-smoke-check.js +0 -23
- package/dist/scripts/local-llm-structured-output-check.js +0 -11
- package/dist/scripts/local-llm-throughput-check.js +0 -10
- package/dist/scripts/local-llm-tool-call-repair-check.js +0 -10
- package/dist/scripts/local-llm-warmup-check.js +0 -11
- package/dist/scripts/loop-blocker-check.js +0 -15
- package/dist/scripts/mad-preflight-blocks-unreadable-config-check.js +0 -35
- package/dist/scripts/mad-sks-actual-executor-blackbox.js +0 -5
- package/dist/scripts/mad-sks-app-ui-no-mutation-check.js +0 -92
- package/dist/scripts/mad-sks-audit-proof-check.js +0 -34
- package/dist/scripts/mad-sks-db-executor-check.js +0 -5
- package/dist/scripts/mad-sks-executor-proof-graph-check.js +0 -5
- package/dist/scripts/mad-sks-fast-mode-propagation-check.js +0 -24
- package/dist/scripts/mad-sks-file-write-executor-check.js +0 -5
- package/dist/scripts/mad-sks-immutable-harness-check.js +0 -36
- package/dist/scripts/mad-sks-no-harness-modification-check.js +0 -25
- package/dist/scripts/mad-sks-package-executor-check.js +0 -5
- package/dist/scripts/mad-sks-permission-model-check.js +0 -22
- package/dist/scripts/mad-sks-rollback-apply-check.js +0 -5
- package/dist/scripts/mad-sks-service-executor-check.js +0 -5
- package/dist/scripts/mad-sks-shell-executor-check.js +0 -5
- package/dist/scripts/mad-sks-write-guard-check.js +0 -28
- package/dist/scripts/mad-sks-zellij-default-pane-worker-check.js +0 -37
- package/dist/scripts/mad-sks-zellij-launch-check.js +0 -102
- package/dist/scripts/mcp-0-134-modernization-check.js +0 -55
- package/dist/scripts/mcp-readonly-concurrency-check.js +0 -17
- package/dist/scripts/mcp-readonly-runtime-scheduler-check.js +0 -20
- package/dist/scripts/mcp-tool-naming-parity-check.js +0 -16
- package/dist/scripts/memory-summary-rebuild-check.js +0 -22
- package/dist/scripts/mutation-callsite-coverage-check.js +0 -180
- package/dist/scripts/naruto-active-pool-check.js +0 -39
- package/dist/scripts/naruto-actual-worker-control-plane-check.js +0 -56
- package/dist/scripts/naruto-allocation-policy-check.js +0 -33
- package/dist/scripts/naruto-allocation-runtime-wiring-check.js +0 -92
- package/dist/scripts/naruto-concurrency-governor-check.js +0 -53
- package/dist/scripts/naruto-extreme-parallelism-check.js +0 -22
- package/dist/scripts/naruto-extreme-parallelism-real-check.js +0 -43
- package/dist/scripts/naruto-gpt-final-pack-check.js +0 -34
- package/dist/scripts/naruto-orchestrator-runtime-source-check.js +0 -70
- package/dist/scripts/naruto-parallel-patch-apply-check.js +0 -41
- package/dist/scripts/naruto-readonly-routing-check.js +0 -116
- package/dist/scripts/naruto-real-active-pool-check.js +0 -39
- package/dist/scripts/naruto-real-active-pool-runtime-check.js +0 -55
- package/dist/scripts/naruto-rebalance-policy-check.js +0 -41
- package/dist/scripts/naruto-role-distribution-check.js +0 -23
- package/dist/scripts/naruto-shadow-clone-swarm-check.js +0 -153
- package/dist/scripts/naruto-verification-pool-check.js +0 -36
- package/dist/scripts/naruto-work-graph-check.js +0 -24
- package/dist/scripts/naruto-worktree-coding-blackbox.js +0 -29
- package/dist/scripts/naruto-worktree-coding-check.js +0 -44
- package/dist/scripts/naruto-worktree-gpt-final-check.js +0 -45
- package/dist/scripts/naruto-worktree-zellij-ui-check.js +0 -28
- package/dist/scripts/naruto-zellij-dynamic-right-column-check.js +0 -48
- package/dist/scripts/naruto-zellij-massive-ui-check.js +0 -23
- package/dist/scripts/non-recursive-pipeline-check.js +0 -68
- package/dist/scripts/npm-publish-performance-check.js +0 -65
- package/dist/scripts/official-docs-compat-report.js +0 -304
- package/dist/scripts/packlist-performance-check.js +0 -83
- package/dist/scripts/parallel-verification-engine-check.js +0 -85
- package/dist/scripts/postinstall-safe-side-effects-check.js +0 -65
- package/dist/scripts/ppt-full-e2e-artifact-graph-check.js +0 -40
- package/dist/scripts/ppt-full-e2e-blackbox-check.js +0 -109
- package/dist/scripts/ppt-image-voxel-relations-check.js +0 -9
- package/dist/scripts/ppt-imagegen-blackbox-check.js +0 -46
- package/dist/scripts/ppt-imagegen-review-fixture-check.js +0 -6
- package/dist/scripts/ppt-issue-extraction-fixture-check.js +0 -7
- package/dist/scripts/ppt-no-mock-as-real-check.js +0 -8
- package/dist/scripts/ppt-no-text-fallback-check.js +0 -7
- package/dist/scripts/ppt-proof-trust-fixture-check.js +0 -10
- package/dist/scripts/ppt-real-export-adapter-check.js +0 -13
- package/dist/scripts/ppt-real-imagegen-smoke-check.js +0 -42
- package/dist/scripts/ppt-real-imagegen-wiring-check.js +0 -16
- package/dist/scripts/ppt-reexport-rereview-check.js +0 -19
- package/dist/scripts/ppt-slide-export-fixture-check.js +0 -7
- package/dist/scripts/prepublish-fast-check.js +0 -128
- package/dist/scripts/priority-full-closure-check.js +0 -12
- package/dist/scripts/product-design-auto-install-check.js +0 -119
- package/dist/scripts/product-design-plugin-routing-check.js +0 -101
- package/dist/scripts/prompt-placeholder-guard-check.js +0 -33
- package/dist/scripts/provider-badge-context-check.js +0 -26
- package/dist/scripts/provider-context-config-toml-check.js +0 -63
- package/dist/scripts/python-codex-sdk-all-pipelines-check.js +0 -47
- package/dist/scripts/python-codex-sdk-capability-check.js +0 -75
- package/dist/scripts/python-codex-sdk-sandbox-policy-check.js +0 -10
- package/dist/scripts/python-codex-sdk-stream-bridge-check.js +0 -12
- package/dist/scripts/python-tools-smoke-check.js +0 -71
- package/dist/scripts/qa-actual-route-backfill-check.js +0 -5
- package/dist/scripts/qa-backfill-route-blackbox.js +0 -5
- package/dist/scripts/qa-patch-swarm-route-blackbox.js +0 -10
- package/dist/scripts/readme-architecture-imagegen-official-check.js +0 -448
- package/dist/scripts/release-cache-glob-hashing-check.js +0 -42
- package/dist/scripts/release-dag-full-coverage-check.js +0 -66
- package/dist/scripts/release-dist-freshness-check.js +0 -8
- package/dist/scripts/release-dynamic-performance-check.js +0 -103
- package/dist/scripts/release-gate-budget-check.js +0 -36
- package/dist/scripts/release-gate-dag-runner-check.js +0 -17
- package/dist/scripts/release-metadata-1-11-check.js +0 -37
- package/dist/scripts/release-metadata-1-12-check.js +0 -48
- package/dist/scripts/release-metadata-1-13-check.js +0 -53
- package/dist/scripts/release-metadata-1-14-check.js +0 -63
- package/dist/scripts/release-metadata-1-16-check.js +0 -81
- package/dist/scripts/release-metadata-1-17-check.js +0 -51
- package/dist/scripts/release-metadata-1-19-check.js +0 -371
- package/dist/scripts/release-metadata-check.js +0 -7
- package/dist/scripts/release-native-agent-fixture-check.js +0 -41
- package/dist/scripts/release-parallel-check.js +0 -374
- package/dist/scripts/release-parallel-full-coverage-check.js +0 -13
- package/dist/scripts/release-parallel-speed-budget-check.js +0 -84
- package/dist/scripts/release-provenance-check.js +0 -150
- package/dist/scripts/release-real-check.js +0 -330
- package/dist/scripts/release-registry-check.js +0 -344
- package/dist/scripts/release-runtime-truth-matrix-check.js +0 -47
- package/dist/scripts/release-stability-report-check.js +0 -99
- package/dist/scripts/release-version-truth-check.js +0 -134
- package/dist/scripts/research-actual-route-backfill-check.js +0 -5
- package/dist/scripts/research-backfill-route-blackbox.js +0 -5
- package/dist/scripts/research-blueprint-densifier-check.js +0 -21
- package/dist/scripts/research-claim-builder-check.js +0 -19
- package/dist/scripts/research-complete-package-fixture-check.js +0 -23
- package/dist/scripts/research-final-reviewer-blackbox.js +0 -22
- package/dist/scripts/research-parallel-source-shards-check.js +0 -22
- package/dist/scripts/research-quality-gate-check.js +0 -111
- package/dist/scripts/research-real-cycle-no-legacy-final-md-check.js +0 -14
- package/dist/scripts/research-short-report-rejection-check.js +0 -46
- package/dist/scripts/research-source-ledger-merge-check.js +0 -26
- package/dist/scripts/research-stage-cycle-runtime-blackbox.js +0 -24
- package/dist/scripts/responses-retry-policy-centralized-check.js +0 -19
- package/dist/scripts/retention-cleanup-safety-check.js +0 -155
- package/dist/scripts/route-blackbox-realism-check.js +0 -21
- package/dist/scripts/route-proof-artifact-structure-check.js +0 -145
- package/dist/scripts/runtime-dist-parity-check.js +0 -78
- package/dist/scripts/runtime-no-mjs-scripts-check.js +0 -45
- package/dist/scripts/runtime-no-src-mjs-check.js +0 -32
- package/dist/scripts/runtime-no-tmux-check.js +0 -113
- package/dist/scripts/runtime-ts-python-boundary-check.js +0 -59
- package/dist/scripts/runtime-ts-rust-boundary-check.js +0 -74
- package/dist/scripts/runtime-ts-source-of-truth-check.js +0 -55
- package/dist/scripts/safety-check.js +0 -23
- package/dist/scripts/shared-memory-fixture-check.js +0 -27
- package/dist/scripts/side-effect-runtime-report-check.js +0 -19
- package/dist/scripts/side-effect-zero-gate-check.js +0 -226
- package/dist/scripts/sks-1-11-fixture-check.js +0 -130
- package/dist/scripts/source-intelligence-all-modes-check.js +0 -32
- package/dist/scripts/source-intelligence-policy-check.js +0 -13
- package/dist/scripts/strategy-adhd-orchestrating-gate-check.js +0 -22
- package/dist/scripts/strategy-file-ownership-plan-check.js +0 -18
- package/dist/scripts/strategy-parallel-modification-plan-check.js +0 -19
- package/dist/scripts/strategy-verification-rollback-dag-check.js +0 -19
- package/dist/scripts/team-actual-route-backfill-check.js +0 -5
- package/dist/scripts/team-backfill-route-blackbox.js +0 -5
- package/dist/scripts/team-parallel-write-blackbox.js +0 -55
- package/dist/scripts/team-patch-swarm-route-blackbox.js +0 -10
- package/dist/scripts/terminal-keyboard-enhancement-safety-check.js +0 -12
- package/dist/scripts/terminal-tui-output-stability-check.js +0 -35
- package/dist/scripts/test-no-orphan-dist-imports-check.js +0 -73
- package/dist/scripts/trust-fixture-check.js +0 -33
- package/dist/scripts/typescript-migration-report.js +0 -78
- package/dist/scripts/ultra-router-auto-router-check.js +0 -33
- package/dist/scripts/ultra-router-classification-check.js +0 -28
- package/dist/scripts/ux-patch-swarm-route-blackbox.js +0 -10
- package/dist/scripts/ux-ppt-structured-extraction-check.js +0 -21
- package/dist/scripts/ux-review-extract-real-callouts-fixture-check.js +0 -8
- package/dist/scripts/ux-review-extract-wires-real-extractor-check.js +0 -15
- package/dist/scripts/ux-review-generate-callouts-fixture-check.js +0 -9
- package/dist/scripts/ux-review-image-voxel-relations-check.js +0 -31
- package/dist/scripts/ux-review-imagegen-blackbox-check.js +0 -67
- package/dist/scripts/ux-review-no-fake-callouts-check.js +0 -8
- package/dist/scripts/ux-review-no-text-fallback-check.js +0 -25
- package/dist/scripts/ux-review-patch-diff-recheck-check.js +0 -20
- package/dist/scripts/ux-review-patch-handoff-fixture-check.js +0 -8
- package/dist/scripts/ux-review-real-imagegen-smoke-check.js +0 -31
- package/dist/scripts/ux-review-real-loop-fixture-check.js +0 -24
- package/dist/scripts/ux-review-recapture-recheck-fixture-check.js +0 -8
- package/dist/scripts/ux-review-run-wires-imagegen-check.js +0 -11
- package/dist/scripts/worker-pane-communication-contract-check.js +0 -54
- package/dist/scripts/wrongness-fixture-check.js +0 -65
- package/dist/scripts/xai-mcp-capability-check.js +0 -14
- package/dist/scripts/zellij-capability-check.js +0 -15
- package/dist/scripts/zellij-dashboard-pane-check.js +0 -70
- package/dist/scripts/zellij-developer-controls-check.js +0 -20
- package/dist/scripts/zellij-doctor-readiness-check.js +0 -63
- package/dist/scripts/zellij-dynamic-pane-lifecycle-check.js +0 -21
- package/dist/scripts/zellij-first-slot-down-stack-check.js +0 -20
- package/dist/scripts/zellij-first-slot-down-stack-real-check.js +0 -356
- package/dist/scripts/zellij-initial-main-only-blackbox.js +0 -28
- package/dist/scripts/zellij-lane-renderer-check.js +0 -65
- package/dist/scripts/zellij-launch-command-truth-check.js +0 -75
- package/dist/scripts/zellij-layout-valid-check.js +0 -90
- package/dist/scripts/zellij-pane-proof-check.js +0 -59
- package/dist/scripts/zellij-real-session-cleanup-check.js +0 -21
- package/dist/scripts/zellij-real-session-heartbeat-check.js +0 -49
- package/dist/scripts/zellij-real-session-launch-check.js +0 -57
- package/dist/scripts/zellij-right-column-headless-overflow-check.js +0 -22
- package/dist/scripts/zellij-right-column-manager-check.js +0 -27
- package/dist/scripts/zellij-screen-proof-check.js +0 -45
- package/dist/scripts/zellij-slot-column-anchor-check.js +0 -66
- package/dist/scripts/zellij-slot-only-ui-check.js +0 -26
- package/dist/scripts/zellij-slot-pane-renderer-check.js +0 -106
- package/dist/scripts/zellij-slot-renderer-proof-semantics-check.js +0 -59
- package/dist/scripts/zellij-spawn-on-demand-layout-check.js +0 -40
- package/dist/scripts/zellij-ui-design-check.js +0 -105
- package/dist/scripts/zellij-worker-pane-manager-check.js +0 -109
- package/dist/scripts/zellij-worker-pane-manager-single-owner-check.js +0 -47
- package/dist/scripts/zellij-worker-pane-real-ui-blackbox.js +0 -202
- package/dist/scripts/zellij-worker-pane-spawn-order-check.js +0 -35
|
@@ -4,6 +4,7 @@ import { MAX_AGENT_COUNT } from './agent-schema.js';
|
|
|
4
4
|
import { appendAgentWorkQueueEvent, completeWorkItem, createAgentWorkQueue, enqueueFollowUpWorkItems, leaseNextWorkItem, pendingWorkItems, writeAgentWorkQueue } from './agent-work-queue.js';
|
|
5
5
|
import { closeWorkerSlotsAfterDrain, createAgentWorkerSlots, markWorkerSlotGenerationClosed, openWorkerSlotGeneration, writeAgentWorkerSlots } from './agent-worker-slot.js';
|
|
6
6
|
import { closeAgentSessionGeneration, createAgentSessionGeneration, writeAgentSessionGeneration } from './agent-session-generation.js';
|
|
7
|
+
import { appendParallelRuntimeEvent } from './parallel-runtime-proof.js';
|
|
7
8
|
export const AGENT_SCHEDULER_SCHEMA = 'sks.agent-scheduler.v1';
|
|
8
9
|
export const AGENT_SCHEDULER_EVENT_SCHEMA = 'sks.agent-scheduler-event.v1';
|
|
9
10
|
export async function runAgentScheduler(input) {
|
|
@@ -19,6 +20,10 @@ export async function runAgentScheduler(input) {
|
|
|
19
20
|
});
|
|
20
21
|
const active = new Map();
|
|
21
22
|
const results = [];
|
|
23
|
+
const schedulerStartedAt = Date.now();
|
|
24
|
+
let batchCounter = 0;
|
|
25
|
+
let batchLaunchSpanTotalMs = 0;
|
|
26
|
+
let batchDispatchInProgress = false;
|
|
22
27
|
let state = buildState(input.missionId, targetActiveSlots, queue, slots, active, {
|
|
23
28
|
status: 'initializing',
|
|
24
29
|
refillDelayMs: input.refillDelayMs || 0,
|
|
@@ -27,7 +32,7 @@ export async function runAgentScheduler(input) {
|
|
|
27
32
|
await writeAll(input.root, state, slots, queue, active, { event_type: 'scheduler_initialized' }, input.onSchedulerEvent);
|
|
28
33
|
await refillSlots(null);
|
|
29
34
|
while (active.size > 0 || pendingWorkItems(queue).length > 0) {
|
|
30
|
-
if (active.size === 0 && pendingWorkItems(queue).length > 0) {
|
|
35
|
+
if (!batchDispatchInProgress && active.size === 0 && pendingWorkItems(queue).length > 0) {
|
|
31
36
|
state.blockers.push('scheduler_pending_queue_without_active_sessions');
|
|
32
37
|
state.status = 'blocked';
|
|
33
38
|
await writeAll(input.root, state, slots, queue, active, { event_type: 'scheduler_blocked', pending_count: pendingWorkItems(queue).length }, input.onSchedulerEvent);
|
|
@@ -94,6 +99,7 @@ export async function runAgentScheduler(input) {
|
|
|
94
99
|
state.all_generations_closed = true;
|
|
95
100
|
if (!state.pending_queue_drained)
|
|
96
101
|
state.blockers.push('scheduler_pending_queue_not_drained');
|
|
102
|
+
updateUtilizationMetrics();
|
|
97
103
|
await writeAll(input.root, state, slots, queue, active, { event_type: 'scheduler_drained' }, input.onSchedulerEvent);
|
|
98
104
|
return {
|
|
99
105
|
schema: 'sks.agent-scheduler-result.v1',
|
|
@@ -105,9 +111,179 @@ export async function runAgentScheduler(input) {
|
|
|
105
111
|
};
|
|
106
112
|
async function refillSlots(backfill) {
|
|
107
113
|
state.status = 'running';
|
|
114
|
+
const launches = collectLaunchBatch();
|
|
115
|
+
if (!launches.length)
|
|
116
|
+
return;
|
|
117
|
+
batchDispatchInProgress = true;
|
|
118
|
+
const batchId = `batch-${Date.now().toString(36)}-${batchCounter++}`;
|
|
119
|
+
const batchStart = Date.now();
|
|
108
120
|
const launchEvents = [];
|
|
109
|
-
|
|
110
|
-
|
|
121
|
+
try {
|
|
122
|
+
for (const launch of launches)
|
|
123
|
+
slots[launch.slotIndex] = launch.openedSlot;
|
|
124
|
+
await Promise.all(launches.map((launch) => writeAgentSessionGeneration(input.root, launch.generation)));
|
|
125
|
+
await writeAll(input.root, state, slots, queue, active, {
|
|
126
|
+
event_type: 'batch_dispatch_started',
|
|
127
|
+
batch_id: batchId,
|
|
128
|
+
launch_count: launches.length,
|
|
129
|
+
session_ids: launches.map((launch) => launch.generation.session_id)
|
|
130
|
+
}, input.onSchedulerEvent);
|
|
131
|
+
await appendParallelRuntimeEvent(input.root, input.missionId, {
|
|
132
|
+
event_type: 'batch_dispatch_started',
|
|
133
|
+
slot_id: null,
|
|
134
|
+
generation_index: null,
|
|
135
|
+
session_id: null,
|
|
136
|
+
pid: null,
|
|
137
|
+
backend: 'scheduler',
|
|
138
|
+
placement: 'unknown',
|
|
139
|
+
batch_id: batchId,
|
|
140
|
+
meta: { launch_count: launches.length, active_count_before: active.size }
|
|
141
|
+
}).catch(() => undefined);
|
|
142
|
+
for (const launch of launches) {
|
|
143
|
+
const { slot, openedSlot, generation, agent, workItem } = launch;
|
|
144
|
+
await appendParallelRuntimeEvent(input.root, input.missionId, {
|
|
145
|
+
event_type: 'slot_reserved',
|
|
146
|
+
slot_id: slot.slot_id,
|
|
147
|
+
generation_index: generation.generation_index,
|
|
148
|
+
session_id: generation.session_id,
|
|
149
|
+
pid: null,
|
|
150
|
+
backend: 'scheduler',
|
|
151
|
+
placement: 'unknown',
|
|
152
|
+
batch_id: batchId,
|
|
153
|
+
meta: { work_item_id: workItem.id }
|
|
154
|
+
}).catch(() => undefined);
|
|
155
|
+
await appendParallelRuntimeEvent(input.root, input.missionId, {
|
|
156
|
+
event_type: 'worker_launch_invoked',
|
|
157
|
+
slot_id: slot.slot_id,
|
|
158
|
+
generation_index: generation.generation_index,
|
|
159
|
+
session_id: generation.session_id,
|
|
160
|
+
pid: null,
|
|
161
|
+
backend: 'scheduler',
|
|
162
|
+
placement: 'unknown',
|
|
163
|
+
batch_id: batchId,
|
|
164
|
+
meta: { work_item_id: workItem.id }
|
|
165
|
+
}).catch(() => undefined);
|
|
166
|
+
const promise = Promise.resolve()
|
|
167
|
+
.then(() => input.launchSession({ agent, workItem, generation, slot: openedSlot, queue, state }))
|
|
168
|
+
.then((result) => ({
|
|
169
|
+
result,
|
|
170
|
+
session_id: generation.session_id,
|
|
171
|
+
slot_id: slot.slot_id,
|
|
172
|
+
generation_index: generation.generation_index,
|
|
173
|
+
terminal_close_report_path: path.join(generation.artifact_dir, 'agent-terminal-close-report.json')
|
|
174
|
+
}))
|
|
175
|
+
.catch((err) => ({
|
|
176
|
+
result: {
|
|
177
|
+
schema: 'sks.agent-result.v1',
|
|
178
|
+
mission_id: input.missionId,
|
|
179
|
+
agent_id: agent.id,
|
|
180
|
+
session_id: generation.session_id,
|
|
181
|
+
persona_id: agent.persona_id,
|
|
182
|
+
task_slice_id: workItem.id,
|
|
183
|
+
status: 'failed',
|
|
184
|
+
backend: 'fake',
|
|
185
|
+
summary: err instanceof Error ? err.message : String(err),
|
|
186
|
+
findings: [],
|
|
187
|
+
proposed_changes: [],
|
|
188
|
+
changed_files: [],
|
|
189
|
+
lease_compliance: { ok: true, violations: [] },
|
|
190
|
+
artifacts: [],
|
|
191
|
+
blockers: ['scheduler_launch_failed'],
|
|
192
|
+
confidence: 'failed',
|
|
193
|
+
handoff_notes: '',
|
|
194
|
+
unverified: [],
|
|
195
|
+
writes: [],
|
|
196
|
+
recursion_guard: { ok: true, violations: [] },
|
|
197
|
+
verification: { status: 'failed', checks: [] },
|
|
198
|
+
source_intelligence_refs: input.sourceIntelligenceRefs || null,
|
|
199
|
+
goal_mode_ref: input.goalModeRef || null
|
|
200
|
+
},
|
|
201
|
+
session_id: generation.session_id,
|
|
202
|
+
slot_id: slot.slot_id,
|
|
203
|
+
generation_index: generation.generation_index,
|
|
204
|
+
error: err instanceof Error ? err.message : String(err),
|
|
205
|
+
terminal_close_report_path: path.join(generation.artifact_dir, 'agent-terminal-close-report.json')
|
|
206
|
+
}));
|
|
207
|
+
active.set(generation.session_id, { slot_id: slot.slot_id, work_item_id: workItem.id, session_id: generation.session_id, promise });
|
|
208
|
+
}
|
|
209
|
+
await appendAgentWorkQueueEvent(input.root, 'batch_work_items_dispatched', {
|
|
210
|
+
batch_id: batchId,
|
|
211
|
+
launch_count: launches.length,
|
|
212
|
+
session_ids: launches.map((launch) => launch.generation.session_id),
|
|
213
|
+
work_item_ids: launches.map((launch) => launch.workItem.id)
|
|
214
|
+
});
|
|
215
|
+
for (const launch of launches)
|
|
216
|
+
await appendAgentWorkQueueEvent(input.root, 'work_item_dispatched', { work_item_id: launch.workItem.id, session_id: launch.generation.session_id, slot_id: launch.slot.slot_id });
|
|
217
|
+
if (backfill) {
|
|
218
|
+
const firstLaunch = launches[0];
|
|
219
|
+
const refillLatencyMs = Math.max(0, Date.now() - backfill.closed_at_ms);
|
|
220
|
+
state.backfill_count += 1;
|
|
221
|
+
state.refill_latency_events_ms.push(refillLatencyMs);
|
|
222
|
+
state.refill_latency_p95_ms = percentile95(state.refill_latency_events_ms);
|
|
223
|
+
launchEvents.push({
|
|
224
|
+
event_type: 'backfill_event',
|
|
225
|
+
closed_session_id: backfill.closed_session_id,
|
|
226
|
+
new_session_id: firstLaunch?.generation.session_id || null,
|
|
227
|
+
slot_id: firstLaunch?.slot.slot_id || null,
|
|
228
|
+
batch_id: batchId,
|
|
229
|
+
launch_count: launches.length,
|
|
230
|
+
active_count_before: backfill.active_count_before,
|
|
231
|
+
active_count_after: active.size,
|
|
232
|
+
refill_latency_ms: refillLatencyMs
|
|
233
|
+
});
|
|
234
|
+
backfill = null;
|
|
235
|
+
}
|
|
236
|
+
else {
|
|
237
|
+
for (const launch of launches)
|
|
238
|
+
launchEvents.push({
|
|
239
|
+
event_type: 'session_launched',
|
|
240
|
+
session_id: launch.generation.session_id,
|
|
241
|
+
slot_id: launch.slot.slot_id,
|
|
242
|
+
work_item_id: launch.workItem.id,
|
|
243
|
+
active_count_after: active.size
|
|
244
|
+
});
|
|
245
|
+
}
|
|
246
|
+
if (input.refillDelayMs && input.refillDelayMs > 0)
|
|
247
|
+
await delay(input.refillDelayMs);
|
|
248
|
+
const launchSpanMs = Math.max(0, Date.now() - batchStart);
|
|
249
|
+
batchLaunchSpanTotalMs += launchSpanMs;
|
|
250
|
+
state.batch_dispatch_count += 1;
|
|
251
|
+
state.largest_batch_size = Math.max(state.largest_batch_size, launches.length);
|
|
252
|
+
if (state.first_batch_launch_span_ms === 0)
|
|
253
|
+
state.first_batch_launch_span_ms = launchSpanMs;
|
|
254
|
+
state.average_batch_launch_span_ms = Math.round(batchLaunchSpanTotalMs / Math.max(1, state.batch_dispatch_count));
|
|
255
|
+
updateUtilizationMetrics();
|
|
256
|
+
await appendParallelRuntimeEvent(input.root, input.missionId, {
|
|
257
|
+
event_type: 'batch_dispatch_completed',
|
|
258
|
+
slot_id: null,
|
|
259
|
+
generation_index: null,
|
|
260
|
+
session_id: null,
|
|
261
|
+
pid: null,
|
|
262
|
+
backend: 'scheduler',
|
|
263
|
+
placement: 'unknown',
|
|
264
|
+
batch_id: batchId,
|
|
265
|
+
meta: { launch_count: launches.length, launch_span_ms: launchSpanMs, active_count_after: active.size }
|
|
266
|
+
}).catch(() => undefined);
|
|
267
|
+
await writeAll(input.root, state, slots, queue, active, {
|
|
268
|
+
event_type: 'batch_dispatch_completed',
|
|
269
|
+
batch_id: batchId,
|
|
270
|
+
launch_count: launches.length,
|
|
271
|
+
launch_span_ms: launchSpanMs,
|
|
272
|
+
active_count_after: active.size,
|
|
273
|
+
session_ids: launches.map((launch) => launch.generation.session_id)
|
|
274
|
+
}, input.onSchedulerEvent);
|
|
275
|
+
}
|
|
276
|
+
finally {
|
|
277
|
+
batchDispatchInProgress = false;
|
|
278
|
+
}
|
|
279
|
+
for (const event of launchEvents)
|
|
280
|
+
await appendJsonl(path.join(input.root, 'agent-scheduler-events.jsonl'), { schema: AGENT_SCHEDULER_EVENT_SCHEMA, ts: nowIso(), ...event });
|
|
281
|
+
}
|
|
282
|
+
function collectLaunchBatch() {
|
|
283
|
+
const launches = [];
|
|
284
|
+
const reservedSlots = new Set();
|
|
285
|
+
while (active.size + launches.length < targetActiveSlots && pendingWorkItems(queue).length > 0) {
|
|
286
|
+
const slotIndex = slots.findIndex((slot, index) => slot.status === 'idle' && !reservedSlots.has(index));
|
|
111
287
|
if (slotIndex < 0)
|
|
112
288
|
break;
|
|
113
289
|
const slot = slots[slotIndex];
|
|
@@ -133,90 +309,18 @@ export async function runAgentScheduler(input) {
|
|
|
133
309
|
goalModeRef: workItem.goal_mode_ref
|
|
134
310
|
});
|
|
135
311
|
workItem.running_session_id = generation.session_id;
|
|
136
|
-
await writeAgentSessionGeneration(input.root, generation);
|
|
137
|
-
const agent = buildAgentForGeneration(slot, generation, workItem);
|
|
138
312
|
const openedSlot = openWorkerSlotGeneration(slot, generation);
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
session_id: generation.session_id,
|
|
143
|
-
slot_id: slot.slot_id,
|
|
144
|
-
generation_index: generation.generation_index,
|
|
145
|
-
work_item_id: workItem.id
|
|
146
|
-
}, input.onSchedulerEvent);
|
|
147
|
-
const promise = Promise.resolve()
|
|
148
|
-
.then(() => input.launchSession({ agent, workItem, generation, slot: openedSlot, queue, state }))
|
|
149
|
-
.then((result) => ({
|
|
150
|
-
result,
|
|
151
|
-
session_id: generation.session_id,
|
|
152
|
-
slot_id: slot.slot_id,
|
|
153
|
-
generation_index: generation.generation_index,
|
|
154
|
-
terminal_close_report_path: path.join(generation.artifact_dir, 'agent-terminal-close-report.json')
|
|
155
|
-
}))
|
|
156
|
-
.catch((err) => ({
|
|
157
|
-
result: {
|
|
158
|
-
schema: 'sks.agent-result.v1',
|
|
159
|
-
mission_id: input.missionId,
|
|
160
|
-
agent_id: agent.id,
|
|
161
|
-
session_id: generation.session_id,
|
|
162
|
-
persona_id: agent.persona_id,
|
|
163
|
-
task_slice_id: workItem.id,
|
|
164
|
-
status: 'failed',
|
|
165
|
-
backend: 'fake',
|
|
166
|
-
summary: err instanceof Error ? err.message : String(err),
|
|
167
|
-
findings: [],
|
|
168
|
-
proposed_changes: [],
|
|
169
|
-
changed_files: [],
|
|
170
|
-
lease_compliance: { ok: true, violations: [] },
|
|
171
|
-
artifacts: [],
|
|
172
|
-
blockers: ['scheduler_launch_failed'],
|
|
173
|
-
confidence: 'failed',
|
|
174
|
-
handoff_notes: '',
|
|
175
|
-
unverified: [],
|
|
176
|
-
writes: [],
|
|
177
|
-
recursion_guard: { ok: true, violations: [] },
|
|
178
|
-
verification: { status: 'failed', checks: [] },
|
|
179
|
-
source_intelligence_refs: input.sourceIntelligenceRefs || null,
|
|
180
|
-
goal_mode_ref: input.goalModeRef || null
|
|
181
|
-
},
|
|
182
|
-
session_id: generation.session_id,
|
|
183
|
-
slot_id: slot.slot_id,
|
|
184
|
-
generation_index: generation.generation_index,
|
|
185
|
-
error: err instanceof Error ? err.message : String(err),
|
|
186
|
-
terminal_close_report_path: path.join(generation.artifact_dir, 'agent-terminal-close-report.json')
|
|
187
|
-
}));
|
|
188
|
-
active.set(generation.session_id, { slot_id: slot.slot_id, work_item_id: workItem.id, session_id: generation.session_id, promise });
|
|
189
|
-
await appendAgentWorkQueueEvent(input.root, 'work_item_dispatched', { work_item_id: workItem.id, session_id: generation.session_id, slot_id: slot.slot_id });
|
|
190
|
-
if (backfill) {
|
|
191
|
-
const refillLatencyMs = Math.max(0, Date.now() - backfill.closed_at_ms);
|
|
192
|
-
state.backfill_count += 1;
|
|
193
|
-
state.refill_latency_events_ms.push(refillLatencyMs);
|
|
194
|
-
state.refill_latency_p95_ms = percentile95(state.refill_latency_events_ms);
|
|
195
|
-
launchEvents.push({
|
|
196
|
-
event_type: 'backfill_event',
|
|
197
|
-
closed_session_id: backfill.closed_session_id,
|
|
198
|
-
new_session_id: generation.session_id,
|
|
199
|
-
slot_id: slot.slot_id,
|
|
200
|
-
active_count_before: backfill.active_count_before,
|
|
201
|
-
active_count_after: active.size,
|
|
202
|
-
refill_latency_ms: refillLatencyMs
|
|
203
|
-
});
|
|
204
|
-
backfill = null;
|
|
205
|
-
}
|
|
206
|
-
else {
|
|
207
|
-
launchEvents.push({
|
|
208
|
-
event_type: 'session_launched',
|
|
209
|
-
session_id: generation.session_id,
|
|
210
|
-
slot_id: slot.slot_id,
|
|
211
|
-
work_item_id: workItem.id,
|
|
212
|
-
active_count_after: active.size
|
|
213
|
-
});
|
|
214
|
-
}
|
|
215
|
-
if (input.refillDelayMs && input.refillDelayMs > 0)
|
|
216
|
-
await delay(input.refillDelayMs);
|
|
313
|
+
const agent = buildAgentForGeneration(slot, generation, workItem);
|
|
314
|
+
launches.push({ slotIndex, slot, openedSlot, generation, agent, workItem, provisionalSessionId });
|
|
315
|
+
reservedSlots.add(slotIndex);
|
|
217
316
|
}
|
|
218
|
-
|
|
219
|
-
|
|
317
|
+
return launches;
|
|
318
|
+
}
|
|
319
|
+
function updateUtilizationMetrics() {
|
|
320
|
+
state.wall_time_ms = Math.max(0, Date.now() - schedulerStartedAt);
|
|
321
|
+
state.active_slot_time_ms = Math.max(state.active_slot_time_ms, state.completed_count * state.wall_time_ms);
|
|
322
|
+
const denominator = Math.max(1, state.wall_time_ms * targetActiveSlots);
|
|
323
|
+
state.scheduler_utilization = Number(Math.min(1, state.active_slot_time_ms / denominator).toFixed(3));
|
|
220
324
|
}
|
|
221
325
|
}
|
|
222
326
|
export function normalizeTargetActiveSlots(value, maxActiveSlots = MAX_AGENT_COUNT) {
|
|
@@ -261,7 +365,14 @@ function buildState(missionId, targetActiveSlots, queue, slots, active, opts) {
|
|
|
261
365
|
pending_queue_drained: pendingCount === 0,
|
|
262
366
|
all_slots_closed_after_drain: slots.length > 0 && slots.every((slot) => slot.status === 'closed'),
|
|
263
367
|
all_generations_closed: false,
|
|
264
|
-
blockers: [...(previous?.blockers || [])]
|
|
368
|
+
blockers: [...(previous?.blockers || [])],
|
|
369
|
+
batch_dispatch_count: previous?.batch_dispatch_count || 0,
|
|
370
|
+
largest_batch_size: previous?.largest_batch_size || 0,
|
|
371
|
+
first_batch_launch_span_ms: previous?.first_batch_launch_span_ms || 0,
|
|
372
|
+
average_batch_launch_span_ms: previous?.average_batch_launch_span_ms || 0,
|
|
373
|
+
scheduler_utilization: previous?.scheduler_utilization || 0,
|
|
374
|
+
active_slot_time_ms: previous?.active_slot_time_ms || 0,
|
|
375
|
+
wall_time_ms: previous?.wall_time_ms || 0
|
|
265
376
|
};
|
|
266
377
|
}
|
|
267
378
|
async function writeAll(root, currentState, slots, queue, active, event, onSchedulerEvent) {
|
|
@@ -289,6 +400,13 @@ async function writeAll(root, currentState, slots, queue, active, event, onSched
|
|
|
289
400
|
currentState.blocked = nextState.blocked;
|
|
290
401
|
currentState.pending_queue_drained = nextState.pending_queue_drained;
|
|
291
402
|
currentState.all_slots_closed_after_drain = nextState.all_slots_closed_after_drain;
|
|
403
|
+
currentState.batch_dispatch_count = nextState.batch_dispatch_count;
|
|
404
|
+
currentState.largest_batch_size = nextState.largest_batch_size;
|
|
405
|
+
currentState.first_batch_launch_span_ms = nextState.first_batch_launch_span_ms;
|
|
406
|
+
currentState.average_batch_launch_span_ms = nextState.average_batch_launch_span_ms;
|
|
407
|
+
currentState.scheduler_utilization = nextState.scheduler_utilization;
|
|
408
|
+
currentState.active_slot_time_ms = nextState.active_slot_time_ms;
|
|
409
|
+
currentState.wall_time_ms = nextState.wall_time_ms;
|
|
292
410
|
await writeAgentWorkQueue(root, queue);
|
|
293
411
|
await writeAgentWorkerSlots(root, slots);
|
|
294
412
|
await writeJsonAtomic(path.join(root, 'agent-scheduler-state.json'), currentState);
|
|
@@ -13,7 +13,7 @@ export const DEFAULT_AGENT_CONCURRENCY = 5;
|
|
|
13
13
|
// ceiling to up to 100 concurrent clone sessions. Only the naruto path opts into this
|
|
14
14
|
// cap; every other roster/scheduler caller keeps MAX_AGENT_COUNT as the default.
|
|
15
15
|
export const MAX_NARUTO_AGENT_COUNT = 100;
|
|
16
|
-
export const DEFAULT_NARUTO_CLONES =
|
|
16
|
+
export const DEFAULT_NARUTO_CLONES = 32;
|
|
17
17
|
export const AGENT_BACKENDS = ['fake', 'process', 'codex-sdk', 'zellij', 'ollama', 'local-llm'];
|
|
18
18
|
export function normalizeAgentBackend(input) {
|
|
19
19
|
const value = String(input || 'codex-sdk');
|