sneakoscope 4.0.13 → 4.0.15
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 +19 -2
- package/config/codex-releases/rust-v0.142.0.json +39 -0
- 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/bin/sks.js +1 -1
- package/dist/cli/global-mode-router.js +2 -1
- package/dist/commands/codex.js +15 -1
- package/dist/core/codex-adapter.js +7 -12
- package/dist/core/codex-compat/codex-compat-report.js +11 -1
- package/dist/core/codex-compat/codex-release-manifest.js +66 -0
- package/dist/core/codex-compat/codex-version-policy.js +5 -4
- package/dist/core/codex-compat/codex-version.js +5 -2
- package/dist/core/codex-control/codex-0142-capability.js +243 -0
- package/dist/core/codex-control/codex-app-server-v2-client.js +211 -0
- package/dist/core/codex-control/codex-sdk-adapter.js +37 -7
- package/dist/core/codex-control/codex-sdk-capability.js +2 -1
- package/dist/core/codex-control/codex-sdk-config-policy.js +16 -0
- package/dist/core/codex-control/codex-sdk-env-policy.js +29 -5
- package/dist/core/codex-control/codex-thread-registry.js +110 -19
- package/dist/core/codex-runtime/resolve-codex-runtime.js +102 -0
- package/dist/core/commands/mad-sks-command.js +3 -0
- package/dist/core/fsx.js +1 -1
- package/dist/core/providers/glm/bench/glm-bench-model-lock-proof.js +32 -3
- package/dist/core/providers/glm/bench/glm-benchmark-runner.js +29 -5
- package/dist/core/providers/glm/bench/glm-benchmark-types.js +1 -1
- package/dist/core/providers/glm/naruto/glm-naruto-critical-path.js +51 -0
- package/dist/core/providers/glm/naruto/glm-naruto-final-seal.js +9 -2
- package/dist/core/providers/glm/naruto/glm-naruto-orchestrator.js +101 -15
- package/dist/core/providers/glm/naruto/glm-naruto-parallelism-summary.js +55 -0
- package/dist/core/providers/glm/naruto/glm-naruto-requirement-coverage.js +92 -0
- package/dist/core/providers/glm/naruto/glm-naruto-requirement-ledger.js +42 -0
- package/dist/core/providers/glm/naruto/glm-naruto-stage-scheduler.js +85 -0
- package/dist/core/providers/glm/naruto/glm-naruto-task-size-classifier.js +12 -0
- package/dist/core/providers/glm/naruto/glm-naruto-trace.js +4 -0
- package/dist/core/providers/glm/naruto/glm-naruto-verifier-output.js +5 -0
- package/dist/core/providers/glm/naruto/glm-naruto-worker-pool.js +130 -44
- package/dist/core/providers/glm/naruto/glm-naruto-worker-runtime.js +6 -2
- package/dist/core/release/gate-manifest.js +24 -1
- package/dist/core/release/gate-pack-manifest.js +6 -6
- package/dist/core/release/release-gate-affected-selector.js +24 -0
- package/dist/core/routes/model-mode-router.js +44 -0
- package/dist/core/routes.js +1 -1
- package/dist/core/version.js +1 -1
- package/dist/scripts/agent-ast-aware-work-graph-check.js +25 -0
- package/dist/scripts/agent-backfill-replenishment-check.js +13 -0
- package/dist/scripts/agent-backfill-route-blackbox.js +5 -0
- package/dist/scripts/agent-background-terminals-check.js +16 -0
- package/dist/scripts/agent-cleanup-command-ux-check.js +12 -0
- package/dist/scripts/agent-cleanup-executor-check.js +53 -0
- package/dist/scripts/agent-cleanup-executor-v2-check.js +39 -0
- package/dist/scripts/agent-cli-options-to-task-graph-check.js +5 -0
- package/dist/scripts/agent-codex-app-cockpit-check.js +91 -0
- package/dist/scripts/agent-codex-child-overlap-check.js +21 -0
- package/dist/scripts/agent-dynamic-cockpit-check.js +10 -0
- package/dist/scripts/agent-dynamic-pool-check.js +13 -0
- package/dist/scripts/agent-dynamic-pool-route-blackbox.js +5 -0
- package/dist/scripts/agent-fast-mode-default-check.js +79 -0
- package/dist/scripts/agent-fast-mode-worker-propagation-check.js +7 -0
- package/dist/scripts/agent-follow-up-work-schema-check.js +80 -0
- package/dist/scripts/agent-goal-mode-propagation-check.js +9 -0
- package/dist/scripts/agent-intelligent-work-graph-check.js +29 -0
- package/dist/scripts/agent-janitor-check.js +79 -0
- package/dist/scripts/agent-main-no-scout-check.js +11 -0
- package/dist/scripts/agent-message-bus-reader-check.js +19 -0
- package/dist/scripts/agent-model-authored-patch-envelope-check.js +15 -0
- package/dist/scripts/agent-multi-project-isolation-check.js +86 -0
- package/dist/scripts/agent-native-cli-session-proof-check.js +7 -0
- package/dist/scripts/agent-native-cli-session-swarm-10-check.js +7 -0
- package/dist/scripts/agent-native-cli-session-swarm-20-check.js +7 -0
- package/dist/scripts/agent-native-cli-session-swarm-check.js +7 -0
- package/dist/scripts/agent-no-subagent-scaling-check.js +7 -0
- package/dist/scripts/agent-official-subagent-helper-policy-check.js +71 -0
- package/dist/scripts/agent-parallel-write-blackbox.js +56 -0
- package/dist/scripts/agent-parallel-write-kernel-check.js +103 -0
- package/dist/scripts/agent-patch-conflict-rebase-check.js +198 -0
- package/dist/scripts/agent-patch-envelope-extraction-check.js +17 -0
- package/dist/scripts/agent-patch-proof-check.js +41 -0
- package/dist/scripts/agent-patch-proof-runtime-check.js +63 -0
- package/dist/scripts/agent-patch-queue-runtime-check.js +36 -0
- package/dist/scripts/agent-patch-rollback-check.js +38 -0
- package/dist/scripts/agent-patch-rollback-dag-check.js +14 -0
- package/dist/scripts/agent-patch-swarm-route-blackbox.js +10 -0
- package/dist/scripts/agent-patch-swarm-runtime-check.js +10 -0
- package/dist/scripts/agent-patch-swarm-runtime-truth-check.js +76 -0
- package/dist/scripts/agent-patch-transaction-journal-check.js +57 -0
- package/dist/scripts/agent-patch-verification-dag-check.js +14 -0
- package/dist/scripts/agent-proof-contract-reconciled-check.js +5 -0
- package/dist/scripts/agent-real-codex-dynamic-smoke-check.js +166 -0
- package/dist/scripts/agent-real-codex-dynamic-smoke-v2-check.js +14 -0
- package/dist/scripts/agent-real-codex-in-zellij-worker-pane-check.js +227 -0
- package/dist/scripts/agent-real-codex-parallel-workers-10-check.js +5 -0
- package/dist/scripts/agent-real-codex-parallel-workers-20-check.js +5 -0
- package/dist/scripts/agent-real-codex-parallel-workers-5-check.js +5 -0
- package/dist/scripts/agent-real-codex-parallel-workers-check.js +5 -0
- package/dist/scripts/agent-role-config-repair-check.js +33 -0
- package/dist/scripts/agent-rollback-command-check.js +86 -0
- package/dist/scripts/agent-route-truth-backfill-check.js +5 -0
- package/dist/scripts/agent-scheduler-proof-check.js +13 -0
- package/dist/scripts/agent-scheduler-proof-hardening-check.js +22 -0
- package/dist/scripts/agent-session-generation-check.js +21 -0
- package/dist/scripts/agent-slot-pane-binding-proof-check.js +64 -0
- package/dist/scripts/agent-slot-telemetry-wiring-check.js +11 -0
- package/dist/scripts/agent-source-intelligence-propagation-check.js +9 -0
- package/dist/scripts/agent-strategy-to-lease-wiring-check.js +32 -0
- package/dist/scripts/agent-strategy-to-patch-strict-check.js +54 -0
- package/dist/scripts/agent-task-graph-expansion-check.js +14 -0
- package/dist/scripts/agent-terminal-generations-check.js +23 -0
- package/dist/scripts/agent-visual-consistency-check.js +9 -0
- package/dist/scripts/agent-wiki-context-proof-check.js +62 -0
- package/dist/scripts/agent-worker-backend-router-check.js +63 -0
- package/dist/scripts/agent-worker-scout-limited-check.js +17 -0
- package/dist/scripts/agent-zellij-dynamic-backfill-panes-check.js +34 -0
- package/dist/scripts/agent-zellij-runtime-check.js +85 -0
- package/dist/scripts/all-feature-deep-completion-check.js +31 -0
- package/dist/scripts/appshots-capability-check.js +18 -0
- package/dist/scripts/appshots-evidence-check.js +48 -0
- package/dist/scripts/appshots-operator-policy-check.js +25 -0
- package/dist/scripts/appshots-privacy-safety-check.js +48 -0
- package/dist/scripts/appshots-source-intelligence-check.js +53 -0
- package/dist/scripts/appshots-thread-attachment-discovery-check.js +87 -0
- package/dist/scripts/appshots-triwiki-voxel-check.js +46 -0
- package/dist/scripts/architecture-guard-check.js +55 -0
- package/dist/scripts/brand-neutrality-generated-artifacts-check.js +161 -0
- package/dist/scripts/brand-neutrality-rename-map-check.js +4 -0
- package/dist/scripts/brand-neutrality-zero-leakage-blackbox.js +4 -0
- package/dist/scripts/brand-neutrality-zero-leakage-check.js +4 -0
- package/dist/scripts/build-once-runner-blackbox.js +34 -0
- package/dist/scripts/build-once-runner-check.js +8 -0
- package/dist/scripts/certificate-sla-check.js +9 -0
- package/dist/scripts/changelog-check.js +47 -0
- package/dist/scripts/changelog-loop-productionization-check.js +3 -0
- package/dist/scripts/cli-check-tiers-check.js +10 -0
- package/dist/scripts/cli-five-minute-task-check.js +6 -0
- package/dist/scripts/codex-0-133-official-compat-report.js +53 -0
- package/dist/scripts/codex-0-134-official-compat-report.js +110 -0
- package/dist/scripts/codex-0-134-runner-truth-check.js +66 -0
- package/dist/scripts/codex-0-135-compat-check.js +57 -0
- package/dist/scripts/codex-0-136-compat-check.js +30 -0
- package/dist/scripts/codex-0-137-compat-check.js +27 -0
- package/dist/scripts/codex-0138-capability-artifact-check.js +15 -0
- package/dist/scripts/codex-0138-capability-check.js +11 -0
- package/dist/scripts/codex-0138-doctor-check.js +15 -0
- package/dist/scripts/codex-0138-feature-probes-check.js +12 -0
- package/dist/scripts/codex-0139-capability-check.js +26 -0
- package/dist/scripts/codex-0139-code-mode-web-search-check.js +25 -0
- package/dist/scripts/codex-0139-code-mode-web-search-real-check.js +10 -0
- package/dist/scripts/codex-0139-doctor-env-real-check.js +10 -0
- package/dist/scripts/codex-0139-doctor-env-redaction-check.js +18 -0
- package/dist/scripts/codex-0139-feature-probes-check.js +30 -0
- package/dist/scripts/codex-0139-image-path-real-check.js +10 -0
- package/dist/scripts/codex-0139-interrupt-agent-check.js +14 -0
- package/dist/scripts/codex-0139-interrupt-agent-real-check.js +8 -0
- package/dist/scripts/codex-0139-marketplace-source-check.js +13 -0
- package/dist/scripts/codex-0139-plugin-cache-real-check.js +10 -0
- package/dist/scripts/codex-0139-plugin-marketplace-real-check.js +10 -0
- package/dist/scripts/codex-0139-real-probe-summary-check.js +14 -0
- package/dist/scripts/codex-0139-real-probes-check.js +37 -0
- package/dist/scripts/codex-0139-rich-tool-schema-check.js +12 -0
- package/dist/scripts/codex-0139-rich-tool-schema-real-check.js +10 -0
- package/dist/scripts/codex-0139-sandbox-profile-alias-check.js +13 -0
- package/dist/scripts/codex-0139-sandbox-profile-alias-real-check.js +10 -0
- package/dist/scripts/codex-0139-sandbox-proxy-real-check.js +10 -0
- package/dist/scripts/codex-0140-bedrock-managed-auth-check.js +4 -0
- package/dist/scripts/codex-0140-capability-check.js +15 -0
- package/dist/scripts/codex-0140-deep-probes-check.js +40 -0
- package/dist/scripts/codex-0140-feature-probes-check.js +24 -0
- package/dist/scripts/codex-0140-goal-attachment-preservation-check.js +8 -0
- package/dist/scripts/codex-0140-goal-attachment-roundtrip-check.js +9 -0
- package/dist/scripts/codex-0140-import-check.js +4 -0
- package/dist/scripts/codex-0140-integration-blackbox.js +13 -0
- package/dist/scripts/codex-0140-large-repo-performance-check.js +4 -0
- package/dist/scripts/codex-0140-mcp-reliability-check.js +4 -0
- package/dist/scripts/codex-0140-non-tty-interrupt-check.js +4 -0
- package/dist/scripts/codex-0140-real-probes-check.js +9 -0
- package/dist/scripts/codex-0140-session-delete-check.js +4 -0
- package/dist/scripts/codex-0140-sqlite-recovery-check.js +4 -0
- package/dist/scripts/codex-0140-unified-mentions-check.js +4 -0
- package/dist/scripts/codex-0140-usage-check.js +4 -0
- package/dist/scripts/codex-0140-usage-real-parser-check.js +17 -0
- package/dist/scripts/codex-0141-capability-check.js +17 -0
- package/dist/scripts/codex-0142-app-server-v2-check.js +46 -0
- package/dist/scripts/codex-0142-binary-identity-check.js +17 -0
- package/dist/scripts/codex-0142-capability-check.js +21 -0
- package/dist/scripts/codex-0142-manifest-check.js +21 -0
- package/dist/scripts/codex-0142-policy-check.js +32 -0
- package/dist/scripts/codex-0142-thread-store-check.js +54 -0
- package/dist/scripts/codex-account-usage-autodiscovery-check.js +22 -0
- package/dist/scripts/codex-account-usage-check.js +9 -0
- package/dist/scripts/codex-agent-role-rich-content-check.js +4 -0
- package/dist/scripts/codex-agent-role-sync-check.js +4 -0
- package/dist/scripts/codex-agent-type-blackbox.js +4 -0
- package/dist/scripts/codex-agent-type-probe-check.js +4 -0
- package/dist/scripts/codex-agent-type-routing-check.js +4 -0
- package/dist/scripts/codex-app-execution-profile-check.js +4 -0
- package/dist/scripts/codex-app-fast-ui-preservation-check.js +32 -0
- package/dist/scripts/codex-app-handoff-check.js +25 -0
- package/dist/scripts/codex-app-handoff-launch-check.js +25 -0
- package/dist/scripts/codex-app-harness-blackbox.js +4 -0
- package/dist/scripts/codex-app-harness-matrix-check.js +4 -0
- package/dist/scripts/codex-app-launcher-check.js +17 -0
- package/dist/scripts/codex-app-provider-badge-check.js +37 -0
- package/dist/scripts/codex-app-skill-agent-blackbox.js +4 -0
- package/dist/scripts/codex-app-type-safety-check.js +4 -0
- package/dist/scripts/codex-app-ui-clobber-guard-check.js +22 -0
- package/dist/scripts/codex-app-ui-preservation-check.js +96 -0
- package/dist/scripts/codex-control-all-pipelines-check.js +37 -0
- package/dist/scripts/codex-control-capability-check.js +10 -0
- package/dist/scripts/codex-control-empty-result-retry-check.js +43 -0
- package/dist/scripts/codex-control-event-stream-ledger-check.js +10 -0
- package/dist/scripts/codex-control-keepalive-no-cot-leak-check.js +14 -0
- package/dist/scripts/codex-control-no-legacy-fallback-check.js +31 -0
- package/dist/scripts/codex-control-side-effect-scope-check.js +26 -0
- package/dist/scripts/codex-control-stream-idle-watchdog-check.js +18 -0
- package/dist/scripts/codex-control-structured-output-check.js +11 -0
- package/dist/scripts/codex-control-thread-registry-check.js +11 -0
- package/dist/scripts/codex-control-tool-call-sequence-repair-check.js +14 -0
- package/dist/scripts/codex-effort-auto-discovery-check.js +17 -0
- package/dist/scripts/codex-effort-order-check.js +9 -0
- package/dist/scripts/codex-environment-scoped-approvals-check.js +10 -0
- package/dist/scripts/codex-exec-output-schema-actual-syntax-check.js +33 -0
- package/dist/scripts/codex-fast-mode-profile-propagation-check.js +14 -0
- package/dist/scripts/codex-history-search-check.js +19 -0
- package/dist/scripts/codex-hook-approval-blackbox.js +4 -0
- package/dist/scripts/codex-hook-approval-matrix-check.js +4 -0
- package/dist/scripts/codex-hook-approval-probe-check.js +4 -0
- package/dist/scripts/codex-hook-lifecycle-check.js +4 -0
- package/dist/scripts/codex-hook-semantic-check.js +15 -0
- package/dist/scripts/codex-hook-strict-subset-check.js +61 -0
- package/dist/scripts/codex-init-deep-check.js +4 -0
- package/dist/scripts/codex-init-deep-directory-local-blackbox.js +4 -0
- package/dist/scripts/codex-init-deep-managed-agents-check.js +4 -0
- package/dist/scripts/codex-lb-config-toml-safety-check.js +85 -0
- package/dist/scripts/codex-lb-persistence-truth-check.js +96 -0
- package/dist/scripts/codex-lb-setup-fixture-check.js +91 -0
- package/dist/scripts/codex-lb-setup-truthfulness-check.js +84 -0
- package/dist/scripts/codex-legacy-profile-consumers-removed-check.js +24 -0
- package/dist/scripts/codex-managed-proxy-env-check.js +17 -0
- package/dist/scripts/codex-model-metadata-check.js +10 -0
- package/dist/scripts/codex-native-agent-role-content-check.js +27 -0
- package/dist/scripts/codex-native-broker-read-only-check.js +44 -0
- package/dist/scripts/codex-native-feature-broker-blackbox.js +4 -0
- package/dist/scripts/codex-native-feature-broker-check.js +4 -0
- package/dist/scripts/codex-native-harness-compat-check.js +4 -0
- package/dist/scripts/codex-native-hook-lifecycle-proof-check.js +4 -0
- package/dist/scripts/codex-native-interop-policy-check.js +4 -0
- package/dist/scripts/codex-native-invocation-defaults-check.js +4 -0
- package/dist/scripts/codex-native-invocation-router-check.js +4 -0
- package/dist/scripts/codex-native-pattern-analysis-blackbox.js +4 -0
- package/dist/scripts/codex-native-pattern-analysis-check.js +4 -0
- package/dist/scripts/codex-native-read-repair-split-blackbox.js +55 -0
- package/dist/scripts/codex-native-reference-cache-blackbox.js +41 -0
- package/dist/scripts/codex-native-reference-cache-check.js +23 -0
- package/dist/scripts/codex-native-reference-evidence-check.js +4 -0
- package/dist/scripts/codex-native-repair-transaction-check.js +45 -0
- package/dist/scripts/codex-native-route-map-check.js +4 -0
- package/dist/scripts/codex-native-skill-content-check.js +24 -0
- package/dist/scripts/codex-output-schema-fixture-check.js +25 -0
- package/dist/scripts/codex-permission-profiles-check.js +36 -0
- package/dist/scripts/codex-plugin-app-template-policy-check.js +11 -0
- package/dist/scripts/codex-plugin-cache-check.js +15 -0
- package/dist/scripts/codex-plugin-diff-check.js +16 -0
- package/dist/scripts/codex-plugin-inventory-check.js +15 -0
- package/dist/scripts/codex-plugin-json-check.js +10 -0
- package/dist/scripts/codex-plugin-list-json-check.js +8 -0
- package/dist/scripts/codex-plugin-parallel-detail-fetch-check.js +12 -0
- package/dist/scripts/codex-profile-primary-check.js +13 -0
- package/dist/scripts/codex-project-config-policy-splitter-check.js +51 -0
- package/dist/scripts/codex-resume-cwd-truth-check.js +17 -0
- package/dist/scripts/codex-sdk-all-pipelines-check.js +33 -0
- package/dist/scripts/codex-sdk-backend-router-check.js +65 -0
- package/dist/scripts/codex-sdk-capability-check.js +11 -0
- package/dist/scripts/codex-sdk-core-skill-pipeline-check.js +9 -0
- package/dist/scripts/codex-sdk-dfix-pipeline-check.js +9 -0
- package/dist/scripts/codex-sdk-event-stream-ledger-check.js +9 -0
- package/dist/scripts/codex-sdk-no-legacy-fallback-check.js +33 -0
- package/dist/scripts/codex-sdk-qa-pipeline-check.js +8 -0
- package/dist/scripts/codex-sdk-real-smoke-check.js +39 -0
- package/dist/scripts/codex-sdk-release-review-pipeline-check.js +13 -0
- package/dist/scripts/codex-sdk-research-pipeline-check.js +47 -0
- package/dist/scripts/codex-sdk-sandbox-policy-check.js +21 -0
- package/dist/scripts/codex-sdk-structured-output-check.js +10 -0
- package/dist/scripts/codex-sdk-team-naruto-agent-pipeline-check.js +12 -0
- package/dist/scripts/codex-sdk-thread-registry-check.js +11 -0
- package/dist/scripts/codex-sdk-ux-ppt-review-pipeline-check.js +9 -0
- package/dist/scripts/codex-sdk-version-compat-check.js +10 -0
- package/dist/scripts/codex-sdk-zellij-pane-binding-check.js +13 -0
- package/dist/scripts/codex-skill-rich-content-check.js +4 -0
- package/dist/scripts/codex-skill-sync-check.js +4 -0
- package/dist/scripts/codex-thread-runtime-choice-check.js +10 -0
- package/dist/scripts/codex-web-adapter-check.js +12 -0
- package/dist/scripts/computer-use-live-evidence-check.js +55 -0
- package/dist/scripts/computer-use-live-optional-check.js +32 -0
- package/dist/scripts/computer-use-policy-check.js +69 -0
- package/dist/scripts/computer-use-visual-route-fixture-check.js +37 -0
- package/dist/scripts/config-managed-merge-callsite-coverage-check.js +200 -0
- package/dist/scripts/context7-evidence-dedupe-check.js +54 -0
- package/dist/scripts/core-skill-card-schema-check.js +61 -0
- package/dist/scripts/core-skill-deployment-snapshot-check.js +54 -0
- package/dist/scripts/core-skill-heldout-validation-check.js +49 -0
- package/dist/scripts/core-skill-immutable-sync-check.js +18 -0
- package/dist/scripts/core-skill-integrity-blackbox.js +32 -0
- package/dist/scripts/core-skill-manifest-check.js +15 -0
- package/dist/scripts/core-skill-no-drift-check.js +24 -0
- package/dist/scripts/core-skill-no-inference-optimizer-check.js +75 -0
- package/dist/scripts/core-skill-patch-check.js +79 -0
- package/dist/scripts/core-skill-promotion-side-effect-ledger-check.js +64 -0
- package/dist/scripts/core-skill-rollout-scoring-check.js +72 -0
- package/dist/scripts/core-skill-route-runtime-integration-check.js +49 -0
- package/dist/scripts/core-skill-trainer-check.js +116 -0
- package/dist/scripts/dfix-fast-blackbox-check.js +37 -0
- package/dist/scripts/dfix-fast-kernel-check.js +26 -0
- package/dist/scripts/dfix-fixture-check.js +6 -0
- package/dist/scripts/dfix-parallel-write-blackbox.js +48 -0
- package/dist/scripts/dfix-patch-handoff-check.js +13 -0
- package/dist/scripts/dfix-patch-swarm-route-blackbox.js +10 -0
- package/dist/scripts/dfix-performance-check.js +15 -0
- package/dist/scripts/dfix-verification-check.js +9 -0
- package/dist/scripts/dfix-verification-recommendation-check.js +15 -0
- package/dist/scripts/docs-brand-neutrality-check.js +4 -0
- package/dist/scripts/docs-codex-0139-wording-check.js +21 -0
- package/dist/scripts/docs-loop-productionization-check.js +3 -0
- package/dist/scripts/docs-loop-runtime-check.js +3 -0
- package/dist/scripts/docs-truthfulness-check.js +61 -0
- package/dist/scripts/doctor-codex-0138-fix-check.js +10 -0
- package/dist/scripts/doctor-codex-0139-real-probes-check.js +25 -0
- package/dist/scripts/doctor-codex-app-harness-check.js +4 -0
- package/dist/scripts/doctor-codex-doctor-parity-check.js +17 -0
- package/dist/scripts/doctor-codex-native-readiness-ux-check.js +29 -0
- package/dist/scripts/doctor-codex-native-repair-actions-check.js +24 -0
- package/dist/scripts/doctor-codex-startup-repair-check.js +103 -0
- package/dist/scripts/doctor-context7-mcp-repair-blackbox.js +16 -0
- package/dist/scripts/doctor-context7-mcp-repair-check.js +11 -0
- package/dist/scripts/doctor-context7-repair-check.js +47 -0
- package/dist/scripts/doctor-dirty-plan-check.js +9 -0
- package/dist/scripts/doctor-dirty-repair-blackbox.js +22 -0
- package/dist/scripts/doctor-dirty-repair-check.js +8 -0
- package/dist/scripts/doctor-dirty-semantic-blackbox.js +8 -0
- package/dist/scripts/doctor-dirty-semantic-check.js +7 -0
- package/dist/scripts/doctor-fix-production-blackbox.js +26 -0
- package/dist/scripts/doctor-fix-proves-codex-read-check.js +102 -0
- package/dist/scripts/doctor-fix-recovers-corrupted-config-check.js +122 -0
- package/dist/scripts/doctor-fixes-codex-app-fast-ui-check.js +44 -0
- package/dist/scripts/doctor-native-capability-repair-blackbox.js +39 -0
- package/dist/scripts/doctor-native-capability-repair-check.js +10 -0
- package/dist/scripts/doctor-native-repair-output-check.js +18 -0
- package/dist/scripts/doctor-startup-config-repair-blackbox.js +13 -0
- package/dist/scripts/doctor-startup-config-repair-check.js +10 -0
- package/dist/scripts/doctor-supabase-mcp-repair-blackbox.js +14 -0
- package/dist/scripts/doctor-supabase-mcp-repair-check.js +12 -0
- package/dist/scripts/doctor-transaction-engine-blackbox.js +28 -0
- package/dist/scripts/doctor-transaction-engine-check.js +31 -0
- package/dist/scripts/doctor-zellij-fix-blackbox.js +4 -0
- package/dist/scripts/doctor-zellij-fix-output-check.js +4 -0
- package/dist/scripts/doctor-zellij-no-homebrew-blackbox.js +4 -0
- package/dist/scripts/doctor-zellij-repair-check.js +4 -0
- package/dist/scripts/doctor-zellij-upgrade-blackbox.js +4 -0
- package/dist/scripts/evidence-fixture-check.js +26 -0
- package/dist/scripts/evidence-flagship-coverage-check.js +55 -0
- package/dist/scripts/fake-real-proof-policy-v2-check.js +27 -0
- package/dist/scripts/fake-vs-real-proof-policy-check.js +14 -0
- package/dist/scripts/fast-codex-service-tier-proof-check.js +42 -0
- package/dist/scripts/flagship-proof-graph-v2-check.js +48 -0
- package/dist/scripts/flagship-proof-graph-v3-check.js +67 -0
- package/dist/scripts/flagship-proof-graph-v4-check.js +61 -0
- package/dist/scripts/gate-pack-fixture-cache-check.js +9 -0
- package/dist/scripts/gate-pack-manifest-check.js +9 -0
- package/dist/scripts/gate-pack-runner-blackbox.js +27 -0
- package/dist/scripts/gate-pack-runner-check.js +6 -0
- package/dist/scripts/gate-pack-v2-blackbox.js +18 -0
- package/dist/scripts/git-precommit-fixture-check.js +41 -0
- package/dist/scripts/git-worktree-batch-allocation-check.js +10 -0
- package/dist/scripts/git-worktree-cache-performance-check.js +25 -0
- package/dist/scripts/git-worktree-capability-check.js +27 -0
- package/dist/scripts/git-worktree-checkpoint-check.js +20 -0
- package/dist/scripts/git-worktree-cleanup-check.js +27 -0
- package/dist/scripts/git-worktree-cross-rebase-check.js +41 -0
- package/dist/scripts/git-worktree-diff-envelope-check.js +17 -0
- package/dist/scripts/git-worktree-diff-export-check.js +43 -0
- package/dist/scripts/git-worktree-dirty-lock-check.js +17 -0
- package/dist/scripts/git-worktree-dirty-main-detection-check.js +14 -0
- package/dist/scripts/git-worktree-integration-primary-check.js +24 -0
- package/dist/scripts/git-worktree-integration-primary-runtime-check.js +20 -0
- package/dist/scripts/git-worktree-manager-check.js +37 -0
- package/dist/scripts/git-worktree-manifest-append-check.js +18 -0
- package/dist/scripts/git-worktree-merge-queue-check.js +31 -0
- package/dist/scripts/git-worktree-pool-performance-check.js +20 -0
- package/dist/scripts/git-worktree-prewarm-runtime-check.js +7 -0
- package/dist/scripts/git-worktree-untracked-diff-check.js +18 -0
- package/dist/scripts/goal-artifact-compat-check.js +3 -0
- package/dist/scripts/goal-legacy-runtime-escape-check.js +3 -0
- package/dist/scripts/goal-loop-compat-check.js +3 -0
- package/dist/scripts/goal-loop-runtime-default-check.js +3 -0
- package/dist/scripts/goal-mode-official-default-check.js +12 -0
- package/dist/scripts/gpt-final-arbiter-check.js +63 -0
- package/dist/scripts/gpt-final-arbiter-performance-check.js +36 -0
- package/dist/scripts/gpt-image-2-request-validator-check.js +35 -0
- package/dist/scripts/hooks-0.134-context-parity-check.js +20 -0
- package/dist/scripts/hooks-actual-parity-check.js +17 -0
- package/dist/scripts/hooks-actual-parity-v2-check.js +21 -0
- package/dist/scripts/hooks-latest-schema-check.js +20 -0
- package/dist/scripts/hooks-managed-install-fixture-check.js +21 -0
- package/dist/scripts/hooks-official-hash-oracle-check.js +35 -0
- package/dist/scripts/hooks-official-hash-parity-check.js +17 -0
- package/dist/scripts/hooks-subagent-events-check.js +17 -0
- package/dist/scripts/hooks-trust-state-check.js +14 -0
- package/dist/scripts/image-artifact-path-contract-check.js +14 -0
- package/dist/scripts/image-artifact-registry-check.js +14 -0
- package/dist/scripts/image-fidelity-fixture-check.js +24 -0
- package/dist/scripts/image-followup-edit-path-check.js +14 -0
- package/dist/scripts/image-generation-path-handoff-check.js +8 -0
- package/dist/scripts/image-global-path-contract-check.js +38 -0
- package/dist/scripts/imagegen-capability-check.js +30 -0
- package/dist/scripts/imagegen-real-smoke-check.js +155 -0
- package/dist/scripts/init-deep-backup-retention-check.js +37 -0
- package/dist/scripts/init-deep-memory-scope-safety-check.js +23 -0
- package/dist/scripts/install-update-preserves-config-check.js +172 -0
- package/dist/scripts/json-schema-recursive-check.js +78 -0
- package/dist/scripts/legacy-gate-inventory-check.js +49 -0
- package/dist/scripts/legacy-gate-purge-check.js +7 -0
- package/dist/scripts/legacy-multiagent-removal-check.js +85 -0
- package/dist/scripts/legacy-purge-final-check.js +5 -0
- package/dist/scripts/legacy-strong-inventory-check.js +43 -0
- package/dist/scripts/legacy-upgrade-matrix-check.js +300 -0
- package/dist/scripts/local-collab-all-pipelines-final-gpt-check.js +21 -0
- package/dist/scripts/local-collab-gpt-final-availability-check.js +58 -0
- package/dist/scripts/local-collab-no-local-only-final-check.js +27 -0
- package/dist/scripts/local-collab-policy-check.js +17 -0
- package/dist/scripts/local-collab-worktree-gpt-final-apply-policy-check.js +63 -0
- package/dist/scripts/local-llm-all-pipelines-check.js +11 -0
- package/dist/scripts/local-llm-cache-performance-check.js +10 -0
- package/dist/scripts/local-llm-capability-check.js +14 -0
- package/dist/scripts/local-llm-smoke-check.js +32 -0
- package/dist/scripts/local-llm-structured-output-check.js +11 -0
- package/dist/scripts/local-llm-throughput-check.js +10 -0
- package/dist/scripts/local-llm-tool-call-repair-check.js +10 -0
- package/dist/scripts/local-llm-warmup-check.js +11 -0
- package/dist/scripts/loop-artifact-paths-check.js +3 -0
- package/dist/scripts/loop-blocker-check.js +15 -0
- package/dist/scripts/loop-cli-check.js +3 -0
- package/dist/scripts/loop-cli-registry-check.js +3 -0
- package/dist/scripts/loop-collision-blackbox.js +3 -0
- package/dist/scripts/loop-concurrency-budget-check.js +3 -0
- package/dist/scripts/loop-concurrency-budget-runtime-check.js +3 -0
- package/dist/scripts/loop-concurrency-oversubscription-blackbox.js +3 -0
- package/dist/scripts/loop-continuation-enforcer-check.js +4 -0
- package/dist/scripts/loop-decomposer-check.js +3 -0
- package/dist/scripts/loop-directive-check-lib.js +388 -0
- package/dist/scripts/loop-execution-profile-routing-check.js +4 -0
- package/dist/scripts/loop-final-arbiter-contract-check.js +3 -0
- package/dist/scripts/loop-fixture-policy-check.js +3 -0
- package/dist/scripts/loop-fixture-production-misuse-blackbox.js +3 -0
- package/dist/scripts/loop-fixture-safety-check.js +3 -0
- package/dist/scripts/loop-gate-fixture-guard-check.js +3 -0
- package/dist/scripts/loop-gate-ladder-check.js +3 -0
- package/dist/scripts/loop-gate-runner-check.js +3 -0
- package/dist/scripts/loop-gate-selector-check.js +3 -0
- package/dist/scripts/loop-gpt-final-contract-crossref-check.js +3 -0
- package/dist/scripts/loop-gpt-final-fixture-guard-check.js +3 -0
- package/dist/scripts/loop-gpt-final-gate-contract-check.js +3 -0
- package/dist/scripts/loop-hardening-check-lib.js +289 -0
- package/dist/scripts/loop-integration-finalizer-check.js +3 -0
- package/dist/scripts/loop-integration-merge-strategy-check.js +3 -0
- package/dist/scripts/loop-interrupt-registry-check.js +3 -0
- package/dist/scripts/loop-kill-interrupt-real-blackbox.js +3 -0
- package/dist/scripts/loop-lease-check.js +3 -0
- package/dist/scripts/loop-merge-strategy-blackbox.js +3 -0
- package/dist/scripts/loop-merge-strategy-check.js +3 -0
- package/dist/scripts/loop-mesh-production-e2e-blackbox.js +3 -0
- package/dist/scripts/loop-mutation-ledger-check.js +3 -0
- package/dist/scripts/loop-observability-check.js +3 -0
- package/dist/scripts/loop-owner-inference-check.js +3 -0
- package/dist/scripts/loop-planner-check.js +3 -0
- package/dist/scripts/loop-planner-project-memory-check.js +4 -0
- package/dist/scripts/loop-planner-project-memory-deep-check.js +4 -0
- package/dist/scripts/loop-proof-check.js +3 -0
- package/dist/scripts/loop-proof-summary-cli-check.js +3 -0
- package/dist/scripts/loop-risk-classifier-check.js +3 -0
- package/dist/scripts/loop-runtime-check.js +3 -0
- package/dist/scripts/loop-scheduler-check.js +3 -0
- package/dist/scripts/loop-schema-check.js +3 -0
- package/dist/scripts/loop-side-effect-blackbox.js +3 -0
- package/dist/scripts/loop-side-effect-final-arbiter-check.js +3 -0
- package/dist/scripts/loop-side-effect-scanner-check.js +3 -0
- package/dist/scripts/loop-state-check.js +3 -0
- package/dist/scripts/loop-status-proof-ux-check.js +3 -0
- package/dist/scripts/loop-worker-fixture-guard-check.js +3 -0
- package/dist/scripts/loop-worker-handle-registration-check.js +3 -0
- package/dist/scripts/loop-worker-interrupt-check.js +3 -0
- package/dist/scripts/loop-worktree-policy-check.js +3 -0
- package/dist/scripts/loop-zellij-ui-check.js +3 -0
- package/dist/scripts/mad-db-capability-check.js +15 -0
- package/dist/scripts/mad-db-command-check.js +13 -0
- package/dist/scripts/mad-db-ledger-check.js +7 -0
- package/dist/scripts/mad-db-lifecycle-hook-decision-check.js +17 -0
- package/dist/scripts/mad-db-mad-command-check.js +100 -0
- package/dist/scripts/mad-db-mcp-result-lifecycle-check.js +30 -0
- package/dist/scripts/mad-db-one-cycle-bounded-check.js +27 -0
- package/dist/scripts/mad-db-one-cycle-consumption-check.js +16 -0
- package/dist/scripts/mad-db-operation-lifecycle-blackbox.js +29 -0
- package/dist/scripts/mad-db-operation-lifecycle-ledger-check.js +17 -0
- package/dist/scripts/mad-db-priority-resolver-check.js +20 -0
- package/dist/scripts/mad-db-safety-conflict-matrix-check.js +22 -0
- package/dist/scripts/mad-preflight-blocks-unreadable-config-check.js +66 -0
- package/dist/scripts/mad-sks-actual-executor-blackbox.js +5 -0
- package/dist/scripts/mad-sks-app-ui-no-mutation-check.js +92 -0
- package/dist/scripts/mad-sks-audit-proof-check.js +34 -0
- package/dist/scripts/mad-sks-db-executor-check.js +5 -0
- package/dist/scripts/mad-sks-executor-proof-graph-check.js +5 -0
- package/dist/scripts/mad-sks-fast-mode-propagation-check.js +24 -0
- package/dist/scripts/mad-sks-file-write-executor-check.js +5 -0
- package/dist/scripts/mad-sks-immutable-harness-check.js +36 -0
- package/dist/scripts/mad-sks-no-harness-modification-check.js +25 -0
- package/dist/scripts/mad-sks-package-executor-check.js +5 -0
- package/dist/scripts/mad-sks-permission-model-check.js +22 -0
- package/dist/scripts/mad-sks-rollback-apply-check.js +5 -0
- package/dist/scripts/mad-sks-service-executor-check.js +5 -0
- package/dist/scripts/mad-sks-shell-executor-check.js +5 -0
- package/dist/scripts/mad-sks-write-guard-check.js +28 -0
- package/dist/scripts/mad-sks-zellij-default-pane-worker-check.js +37 -0
- package/dist/scripts/mad-sks-zellij-launch-check.js +102 -0
- package/dist/scripts/mad-zellij-headless-fallback-blackbox.js +4 -0
- package/dist/scripts/mad-zellij-no-contradictory-output-check.js +4 -0
- package/dist/scripts/mad-zellij-self-heal-blackbox.js +4 -0
- package/dist/scripts/mad-zellij-self-heal-check.js +4 -0
- package/dist/scripts/managed-config-merge-check.js +24 -0
- package/dist/scripts/mcp-0-134-modernization-check.js +55 -0
- package/dist/scripts/mcp-plugin-inventory-check.js +12 -0
- package/dist/scripts/mcp-readonly-concurrency-check.js +17 -0
- package/dist/scripts/mcp-readonly-runtime-scheduler-check.js +20 -0
- package/dist/scripts/mcp-tool-naming-parity-check.js +16 -0
- package/dist/scripts/memory-summary-rebuild-check.js +22 -0
- package/dist/scripts/model-call-concurrency-check.js +15 -0
- package/dist/scripts/mutation-callsite-coverage-check.js +180 -0
- package/dist/scripts/naruto-active-pool-check.js +39 -0
- package/dist/scripts/naruto-actual-worker-control-plane-check.js +56 -0
- package/dist/scripts/naruto-allocation-policy-check.js +33 -0
- package/dist/scripts/naruto-allocation-runtime-wiring-check.js +92 -0
- package/dist/scripts/naruto-concurrency-governor-check.js +53 -0
- package/dist/scripts/naruto-extreme-parallelism-check.js +22 -0
- package/dist/scripts/naruto-extreme-parallelism-real-check.js +43 -0
- package/dist/scripts/naruto-gpt-final-pack-check.js +34 -0
- package/dist/scripts/naruto-loop-maker-checker-check.js +3 -0
- package/dist/scripts/naruto-loop-mesh-blackbox.js +3 -0
- package/dist/scripts/naruto-loop-mesh-check.js +3 -0
- package/dist/scripts/naruto-loop-worker-router-check.js +3 -0
- package/dist/scripts/naruto-orchestrator-runtime-source-check.js +70 -0
- package/dist/scripts/naruto-parallel-gate-consistency-check.js +8 -0
- package/dist/scripts/naruto-parallel-patch-apply-check.js +41 -0
- package/dist/scripts/naruto-parallel-runtime-proof-check.js +9 -0
- package/dist/scripts/naruto-parallelism-mode-check.js +12 -0
- package/dist/scripts/naruto-parallelism-ux-check.js +8 -0
- package/dist/scripts/naruto-proof-message-summary-check.js +9 -0
- package/dist/scripts/naruto-proof-zellij-stacked-summary-check.js +47 -0
- package/dist/scripts/naruto-readonly-routing-check.js +119 -0
- package/dist/scripts/naruto-real-active-pool-check.js +39 -0
- package/dist/scripts/naruto-real-active-pool-runtime-check.js +55 -0
- package/dist/scripts/naruto-real-parallelism-blackbox.js +294 -0
- package/dist/scripts/naruto-rebalance-policy-check.js +41 -0
- package/dist/scripts/naruto-role-distribution-check.js +23 -0
- package/dist/scripts/naruto-shadow-clone-swarm-check.js +164 -0
- package/dist/scripts/naruto-ssot-default-check.js +9 -0
- package/dist/scripts/naruto-ssot-gate-aliases-check.js +10 -0
- package/dist/scripts/naruto-ssot-pipeline-default-check.js +11 -0
- package/dist/scripts/naruto-ssot-route-normalization-check.js +9 -0
- package/dist/scripts/naruto-ssot-routing-check.js +13 -0
- package/dist/scripts/naruto-verification-pool-check.js +36 -0
- package/dist/scripts/naruto-visible-vs-active-workers-check.js +10 -0
- package/dist/scripts/naruto-work-graph-check.js +24 -0
- package/dist/scripts/naruto-worktree-coding-blackbox.js +29 -0
- package/dist/scripts/naruto-worktree-coding-check.js +44 -0
- package/dist/scripts/naruto-worktree-gpt-final-check.js +45 -0
- package/dist/scripts/naruto-worktree-zellij-ui-check.js +28 -0
- package/dist/scripts/naruto-zellij-dynamic-right-column-check.js +48 -0
- package/dist/scripts/naruto-zellij-massive-ui-check.js +23 -0
- package/dist/scripts/native-app-screenshot-repair-check.js +11 -0
- package/dist/scripts/native-capability-postcheck-check.js +16 -0
- package/dist/scripts/native-capability-repair-check.js +15 -0
- package/dist/scripts/native-capability-repair-matrix-check.js +10 -0
- package/dist/scripts/native-chrome-web-review-repair-check.js +10 -0
- package/dist/scripts/native-computer-use-repair-check.js +10 -0
- package/dist/scripts/native-image-generation-repair-check.js +9 -0
- package/dist/scripts/native-swarm-heartbeat-does-not-serialize-launch-check.js +8 -0
- package/dist/scripts/native-swarm-process-spawn-proof-check.js +7 -0
- package/dist/scripts/native-swarm-zellij-does-not-block-workers-check.js +11 -0
- package/dist/scripts/no-ts-nocheck-core-check.js +4 -0
- package/dist/scripts/no-ts-nocheck-release-scripts-check.js +4 -0
- package/dist/scripts/non-recursive-pipeline-check.js +68 -0
- package/dist/scripts/npm-publish-performance-check.js +65 -0
- package/dist/scripts/official-docs-compat-report.js +304 -0
- package/dist/scripts/orphan-gate-detection-check.js +53 -0
- package/dist/scripts/orphan-purge-final-check.js +5 -0
- package/dist/scripts/orphan-strong-detection-check.js +12 -0
- package/dist/scripts/package-published-contract-check.js +46 -0
- package/dist/scripts/packlist-performance-check.js +83 -0
- package/dist/scripts/parallel-claim-enforcement-check.js +21 -0
- package/dist/scripts/parallel-missing-pid-rejection-check.js +55 -0
- package/dist/scripts/parallel-runtime-proof-check.js +23 -0
- package/dist/scripts/parallel-runtime-proof-events-check.js +13 -0
- package/dist/scripts/parallel-runtime-real-blackbox.js +44 -0
- package/dist/scripts/parallel-strict-pid-proof-check.js +54 -0
- package/dist/scripts/parallel-verification-engine-check.js +85 -0
- package/dist/scripts/pipeline-codex-0140-integration-check.js +30 -0
- package/dist/scripts/pipeline-codex-native-doctor-mad-routing-check.js +4 -0
- package/dist/scripts/pipeline-codex-native-doctor-mad-routing-real-blackbox.js +77 -0
- package/dist/scripts/pipeline-codex-native-e2e-blackbox.js +13 -0
- package/dist/scripts/pipeline-codex-native-image-routing-check.js +4 -0
- package/dist/scripts/pipeline-codex-native-image-routing-real-blackbox.js +50 -0
- package/dist/scripts/pipeline-codex-native-loop-routing-check.js +4 -0
- package/dist/scripts/pipeline-codex-native-loop-routing-real-blackbox.js +74 -0
- package/dist/scripts/pipeline-codex-native-qa-routing-check.js +4 -0
- package/dist/scripts/pipeline-codex-native-qa-routing-real-blackbox.js +51 -0
- package/dist/scripts/pipeline-codex-native-research-routing-check.js +4 -0
- package/dist/scripts/pipeline-codex-native-research-routing-real-blackbox.js +45 -0
- package/dist/scripts/pipeline-execution-profile-routing-blackbox.js +4 -0
- package/dist/scripts/pipeline-five-minute-sla-check.js +7 -0
- package/dist/scripts/postinstall-safe-side-effects-check.js +65 -0
- package/dist/scripts/ppt-full-e2e-artifact-graph-check.js +40 -0
- package/dist/scripts/ppt-full-e2e-blackbox-check.js +109 -0
- package/dist/scripts/ppt-image-voxel-relations-check.js +9 -0
- package/dist/scripts/ppt-imagegen-blackbox-check.js +46 -0
- package/dist/scripts/ppt-imagegen-review-fixture-check.js +6 -0
- package/dist/scripts/ppt-issue-extraction-fixture-check.js +7 -0
- package/dist/scripts/ppt-no-mock-as-real-check.js +8 -0
- package/dist/scripts/ppt-no-text-fallback-check.js +7 -0
- package/dist/scripts/ppt-proof-trust-fixture-check.js +10 -0
- package/dist/scripts/ppt-real-export-adapter-check.js +13 -0
- package/dist/scripts/ppt-real-imagegen-smoke-check.js +42 -0
- package/dist/scripts/ppt-real-imagegen-wiring-check.js +16 -0
- package/dist/scripts/ppt-reexport-rereview-check.js +19 -0
- package/dist/scripts/ppt-slide-export-fixture-check.js +7 -0
- package/dist/scripts/prepublish-fast-check.js +128 -0
- package/dist/scripts/priority-full-closure-check.js +12 -0
- package/dist/scripts/probe-memoization-check.js +11 -0
- package/dist/scripts/product-design-auto-install-check.js +119 -0
- package/dist/scripts/product-design-plugin-routing-check.js +101 -0
- package/dist/scripts/project-skill-dedupe-blackbox.js +36 -0
- package/dist/scripts/project-skill-dedupe-check.js +16 -0
- package/dist/scripts/prompt-placeholder-guard-check.js +33 -0
- package/dist/scripts/proof-root-cause-policy-check.js +70 -0
- package/dist/scripts/provider-badge-context-check.js +26 -0
- package/dist/scripts/provider-context-config-toml-check.js +63 -0
- package/dist/scripts/python-codex-sdk-all-pipelines-check.js +47 -0
- package/dist/scripts/python-codex-sdk-capability-check.js +75 -0
- package/dist/scripts/python-codex-sdk-sandbox-policy-check.js +10 -0
- package/dist/scripts/python-codex-sdk-stream-bridge-check.js +12 -0
- package/dist/scripts/python-tools-smoke-check.js +71 -0
- package/dist/scripts/qa-actual-route-backfill-check.js +5 -0
- package/dist/scripts/qa-backfill-route-blackbox.js +5 -0
- package/dist/scripts/qa-loop-app-handoff-capability-check.js +9 -0
- package/dist/scripts/qa-loop-app-handoff-check.js +9 -0
- package/dist/scripts/qa-loop-app-handoff-cli-check.js +8 -0
- package/dist/scripts/qa-loop-app-handoff-confirmation-check.js +24 -0
- package/dist/scripts/qa-loop-app-handoff-gate-lifecycle-check.js +44 -0
- package/dist/scripts/qa-loop-app-handoff-launch-check.js +7 -0
- package/dist/scripts/qa-loop-app-handoff-status-lifecycle-check.js +7 -0
- package/dist/scripts/qa-loop-budget-policy-check.js +8 -0
- package/dist/scripts/qa-loop-effort-escalation-check.js +9 -0
- package/dist/scripts/qa-loop-execution-profile-routing-check.js +4 -0
- package/dist/scripts/qa-loop-image-path-exposure-check.js +9 -0
- package/dist/scripts/qa-loop-image-path-prompt-injection-check.js +8 -0
- package/dist/scripts/qa-patch-swarm-route-blackbox.js +10 -0
- package/dist/scripts/readme-architecture-imagegen-official-check.js +448 -0
- package/dist/scripts/release-affected-selector-check.js +41 -0
- package/dist/scripts/release-aggressive-resource-governor-check.js +25 -0
- package/dist/scripts/release-batch-runner-check.js +6 -0
- package/dist/scripts/release-cache-bridge-check.js +23 -0
- package/dist/scripts/release-cache-glob-hashing-check.js +42 -0
- package/dist/scripts/release-cache-input-classifier-check.js +13 -0
- package/dist/scripts/release-cache-neutralization-report-check.js +13 -0
- package/dist/scripts/release-cache-version-neutral-fixture-check.js +65 -0
- package/dist/scripts/release-check-stamp.js +2 -1
- package/dist/scripts/release-dag-full-coverage-check.js +428 -0
- package/dist/scripts/release-dist-freshness-check.js +8 -0
- package/dist/scripts/release-dynamic-performance-check.js +110 -0
- package/dist/scripts/release-dynamic-presets-check.js +20 -0
- package/dist/scripts/release-full-parallelism-blackbox.js +41 -0
- package/dist/scripts/release-gate-batch-runner-check.js +43 -0
- package/dist/scripts/release-gate-budget-check.js +36 -0
- package/dist/scripts/release-gate-dag-runner-check.js +107 -0
- package/dist/scripts/release-gate-script-parity-check.js +117 -0
- package/dist/scripts/release-metadata-1-11-check.js +37 -0
- package/dist/scripts/release-metadata-1-12-check.js +48 -0
- package/dist/scripts/release-metadata-1-13-check.js +53 -0
- package/dist/scripts/release-metadata-1-14-check.js +63 -0
- package/dist/scripts/release-metadata-1-16-check.js +81 -0
- package/dist/scripts/release-metadata-1-17-check.js +51 -0
- package/dist/scripts/release-metadata-1-19-check.js +376 -0
- package/dist/scripts/release-metadata-check.js +7 -0
- package/dist/scripts/release-native-agent-fixture-check.js +41 -0
- package/dist/scripts/release-parallel-check.js +375 -0
- package/dist/scripts/release-parallel-full-coverage-check.js +13 -0
- package/dist/scripts/release-parallel-speed-budget-check.js +91 -0
- package/dist/scripts/release-proof-truth-check.js +14 -0
- package/dist/scripts/release-provenance-check.js +143 -0
- package/dist/scripts/release-readiness-report.js +1231 -0
- package/dist/scripts/release-real-check.js +338 -0
- package/dist/scripts/release-registry-check.js +353 -0
- package/dist/scripts/release-runtime-truth-matrix-check.js +47 -0
- package/dist/scripts/release-script-type-safety-check.js +4 -0
- package/dist/scripts/release-speed-summary-check.js +20 -0
- package/dist/scripts/release-stability-report-check.js +99 -0
- package/dist/scripts/release-triwiki-first-runner-blackbox.js +44 -0
- package/dist/scripts/release-triwiki-first-runner-check.js +9 -0
- package/dist/scripts/release-version-truth-check.js +134 -0
- package/dist/scripts/release-wiring-3110-blackbox.js +27 -0
- package/dist/scripts/release-wiring-3112-blackbox.js +17 -0
- package/dist/scripts/release-wiring-3113-blackbox.js +17 -0
- package/dist/scripts/research-actual-route-backfill-check.js +5 -0
- package/dist/scripts/research-backfill-route-blackbox.js +5 -0
- package/dist/scripts/research-blueprint-densifier-check.js +21 -0
- package/dist/scripts/research-claim-builder-check.js +19 -0
- package/dist/scripts/research-complete-package-fixture-check.js +29 -0
- package/dist/scripts/research-execution-profile-routing-check.js +4 -0
- package/dist/scripts/research-final-reviewer-blackbox.js +70 -0
- package/dist/scripts/research-handoff-consumability-check.js +23 -0
- package/dist/scripts/research-parallel-source-shards-check.js +22 -0
- package/dist/scripts/research-quality-gate-check.js +112 -0
- package/dist/scripts/research-real-cycle-no-legacy-final-md-check.js +14 -0
- package/dist/scripts/research-real-synthesis-no-deterministic-renderer-check.js +14 -0
- package/dist/scripts/research-repetition-detector-check.js +19 -0
- package/dist/scripts/research-short-report-rejection-check.js +46 -0
- package/dist/scripts/research-source-ledger-merge-check.js +26 -0
- package/dist/scripts/research-stage-cycle-runtime-blackbox.js +40 -0
- package/dist/scripts/research-synthesis-prompt-contract-check.js +36 -0
- package/dist/scripts/research-synthesis-writer-blackbox.js +24 -0
- package/dist/scripts/research-synthesis-writer-check.js +26 -0
- package/dist/scripts/research-template-report-rejection-check.js +56 -0
- package/dist/scripts/research-ultra-stability-report.js +45 -0
- package/dist/scripts/responses-retry-policy-centralized-check.js +19 -0
- package/dist/scripts/retention-cleanup-safety-check.js +155 -0
- package/dist/scripts/route-blackbox-realism-check.js +21 -0
- package/dist/scripts/route-proof-artifact-structure-check.js +145 -0
- package/dist/scripts/runtime-dist-parity-check.js +78 -0
- package/dist/scripts/runtime-no-mjs-scripts-check.js +45 -0
- package/dist/scripts/runtime-no-src-mjs-check.js +32 -0
- package/dist/scripts/runtime-no-tmux-check.js +114 -0
- package/dist/scripts/runtime-proof-summary-check.js +58 -0
- package/dist/scripts/runtime-proof-summary-cli-check.js +51 -0
- package/dist/scripts/runtime-proof-summary-messages-check.js +37 -0
- package/dist/scripts/runtime-proof-zellij-stacked-summary-check.js +58 -0
- package/dist/scripts/runtime-ts-python-boundary-check.js +59 -0
- package/dist/scripts/runtime-ts-rust-boundary-check.js +74 -0
- package/dist/scripts/runtime-ts-source-of-truth-check.js +55 -0
- package/dist/scripts/safety-check.js +23 -0
- package/dist/scripts/scheduler-batch-dispatch-check.js +17 -0
- package/dist/scripts/scheduler-critical-path-check.js +9 -0
- package/dist/scripts/scheduler-extreme-parallel-check.js +7 -0
- package/dist/scripts/scheduler-no-false-pending-block-check.js +7 -0
- package/dist/scripts/scheduler-parallel-proof-consistency-check.js +65 -0
- package/dist/scripts/scheduler-resource-budget-check.js +7 -0
- package/dist/scripts/scheduler-resource-claim-blackbox.js +24 -0
- package/dist/scripts/scheduler-utilization-integral-check.js +105 -0
- package/dist/scripts/scheduler-utilization-proof-check.js +8 -0
- package/dist/scripts/secret-line-rollback-check.js +35 -0
- package/dist/scripts/secret-preservation-check.js +11 -0
- package/dist/scripts/secret-preservation-guard-check.js +37 -0
- package/dist/scripts/shared-memory-fixture-check.js +27 -0
- package/dist/scripts/side-effect-runtime-report-check.js +19 -0
- package/dist/scripts/side-effect-zero-gate-check.js +226 -0
- package/dist/scripts/skill-name-canonicalizer-check.js +9 -0
- package/dist/scripts/skill-registry-ledger-check.js +14 -0
- package/dist/scripts/skill-sync-atomic-check.js +35 -0
- package/dist/scripts/sks-1-11-fixture-check.js +130 -0
- package/dist/scripts/sks-1-12-real-execution-check-lib.js +27 -0
- package/dist/scripts/sks-3-1-4-directive-check-lib.js +212 -0
- package/dist/scripts/sks-3-1-5-directive-check-lib.js +318 -0
- package/dist/scripts/sks-3-1-6-directive-check-lib.js +522 -0
- package/dist/scripts/sks-3-1-7-directive-check-lib.js +58 -0
- package/dist/scripts/sks-3-1-8-check-lib.js +30 -0
- package/dist/scripts/sks-3110-all-feature-regression-blackbox.js +116 -0
- package/dist/scripts/sks-3112-all-feature-regression-blackbox.js +29 -0
- package/dist/scripts/sks-3113-all-feature-regression-blackbox.js +17 -0
- package/dist/scripts/sks-400-all-feature-regression-blackbox.js +21 -0
- package/dist/scripts/sks-400-extreme-parallel-blackbox.js +8 -0
- package/dist/scripts/sks-400-five-minute-blackbox.js +9 -0
- package/dist/scripts/sks-400-legacy-purge-blackbox.js +8 -0
- package/dist/scripts/sks-401-all-feature-regression-blackbox.js +46 -0
- package/dist/scripts/sks-401-five-minute-actual-blackbox.js +23 -0
- package/dist/scripts/sks-402-all-feature-regression-blackbox.js +9 -0
- package/dist/scripts/sks-402-five-minute-real-blackbox.js +22 -0
- package/dist/scripts/sksd-daemon-check.js +9 -0
- package/dist/scripts/sksd-warm-cache-blackbox.js +12 -0
- package/dist/scripts/source-intelligence-all-modes-check.js +32 -0
- package/dist/scripts/source-intelligence-policy-check.js +13 -0
- package/dist/scripts/strategy-adhd-orchestrating-gate-check.js +22 -0
- package/dist/scripts/strategy-file-ownership-plan-check.js +18 -0
- package/dist/scripts/strategy-parallel-modification-plan-check.js +19 -0
- package/dist/scripts/strategy-verification-rollback-dag-check.js +19 -0
- package/dist/scripts/supabase-secret-preservation-blackbox.js +29 -0
- package/dist/scripts/team-actual-route-backfill-check.js +5 -0
- package/dist/scripts/team-alias-to-naruto-check.js +7 -0
- package/dist/scripts/team-backfill-route-blackbox.js +5 -0
- package/dist/scripts/team-legacy-create-removed-check.js +12 -0
- package/dist/scripts/team-parallel-write-blackbox.js +55 -0
- package/dist/scripts/team-patch-swarm-route-blackbox.js +10 -0
- package/dist/scripts/terminal-keyboard-enhancement-safety-check.js +12 -0
- package/dist/scripts/terminal-tui-output-stability-check.js +35 -0
- package/dist/scripts/test-no-orphan-dist-imports-check.js +73 -0
- package/dist/scripts/triwiki-affected-graph-blackbox.js +28 -0
- package/dist/scripts/triwiki-affected-graph-check.js +10 -0
- package/dist/scripts/triwiki-cache-key-check.js +9 -0
- package/dist/scripts/triwiki-gate-impact-map-check.js +8 -0
- package/dist/scripts/triwiki-module-card-check.js +7 -0
- package/dist/scripts/triwiki-proof-bank-blackbox.js +30 -0
- package/dist/scripts/triwiki-proof-bank-check.js +7 -0
- package/dist/scripts/triwiki-proof-bank-lock-blackbox.js +7 -0
- package/dist/scripts/triwiki-proof-card-check.js +23 -0
- package/dist/scripts/triwiki-stale-proof-rejection-check.js +25 -0
- package/dist/scripts/trust-fixture-check.js +33 -0
- package/dist/scripts/type-surface-codex-app-check.js +4 -0
- package/dist/scripts/typescript-migration-report.js +78 -0
- package/dist/scripts/ultra-router-auto-router-check.js +33 -0
- package/dist/scripts/ultra-router-classification-check.js +28 -0
- package/dist/scripts/update-gate-removed-check.js +9 -0
- package/dist/scripts/update-mad-zellij-notice-check.js +9 -0
- package/dist/scripts/update-notice-check.js +10 -0
- package/dist/scripts/update-preserves-supabase-keys-blackbox.js +27 -0
- package/dist/scripts/update-secret-migration-journal-check.js +8 -0
- package/dist/scripts/update-secret-preservation-guard-check.js +10 -0
- package/dist/scripts/ux-patch-swarm-route-blackbox.js +10 -0
- package/dist/scripts/ux-ppt-structured-extraction-check.js +21 -0
- package/dist/scripts/ux-review-extract-real-callouts-fixture-check.js +8 -0
- package/dist/scripts/ux-review-extract-wires-real-extractor-check.js +15 -0
- package/dist/scripts/ux-review-generate-callouts-fixture-check.js +9 -0
- package/dist/scripts/ux-review-image-voxel-relations-check.js +31 -0
- package/dist/scripts/ux-review-imagegen-blackbox-check.js +67 -0
- package/dist/scripts/ux-review-no-fake-callouts-check.js +8 -0
- package/dist/scripts/ux-review-no-text-fallback-check.js +25 -0
- package/dist/scripts/ux-review-patch-diff-recheck-check.js +20 -0
- package/dist/scripts/ux-review-patch-handoff-fixture-check.js +8 -0
- package/dist/scripts/ux-review-real-imagegen-smoke-check.js +31 -0
- package/dist/scripts/ux-review-real-loop-fixture-check.js +24 -0
- package/dist/scripts/ux-review-recapture-recheck-fixture-check.js +8 -0
- package/dist/scripts/ux-review-run-wires-imagegen-check.js +11 -0
- package/dist/scripts/worker-pane-communication-contract-check.js +54 -0
- package/dist/scripts/wrongness-fixture-check.js +65 -0
- package/dist/scripts/xai-mcp-capability-check.js +14 -0
- package/dist/scripts/zellij-capability-check.js +15 -0
- package/dist/scripts/zellij-dashboard-pane-check.js +70 -0
- package/dist/scripts/zellij-developer-controls-check.js +20 -0
- package/dist/scripts/zellij-doctor-readiness-check.js +63 -0
- package/dist/scripts/zellij-dynamic-pane-lifecycle-check.js +21 -0
- package/dist/scripts/zellij-fake-adapter-check.js +33 -0
- package/dist/scripts/zellij-first-slot-down-stack-check.js +21 -0
- package/dist/scripts/zellij-first-slot-down-stack-real-check.js +349 -0
- package/dist/scripts/zellij-homebrew-policy-check.js +4 -0
- package/dist/scripts/zellij-initial-main-only-blackbox.js +28 -0
- package/dist/scripts/zellij-lane-renderer-check.js +80 -0
- package/dist/scripts/zellij-launch-command-truth-check.js +75 -0
- package/dist/scripts/zellij-layout-valid-check.js +90 -0
- package/dist/scripts/zellij-pane-creation-lock-metrics-check.js +12 -0
- package/dist/scripts/zellij-pane-lock-concurrency-blackbox.js +80 -0
- package/dist/scripts/zellij-pane-lock-does-not-block-worker-check.js +14 -0
- package/dist/scripts/zellij-pane-lock-open-worker-integration-blackbox.js +137 -0
- package/dist/scripts/zellij-pane-proof-check.js +59 -0
- package/dist/scripts/zellij-qa-app-handoff-status-check.js +9 -0
- package/dist/scripts/zellij-real-session-cleanup-check.js +21 -0
- package/dist/scripts/zellij-real-session-heartbeat-check.js +49 -0
- package/dist/scripts/zellij-real-session-launch-check.js +57 -0
- package/dist/scripts/zellij-right-column-headless-overflow-check.js +22 -0
- package/dist/scripts/zellij-right-column-manager-check.js +27 -0
- package/dist/scripts/zellij-screen-proof-check.js +45 -0
- package/dist/scripts/zellij-self-heal-check.js +4 -0
- package/dist/scripts/zellij-self-heal-dry-run-check.js +4 -0
- package/dist/scripts/zellij-self-heal-status-contract-check.js +4 -0
- package/dist/scripts/zellij-self-heal-typed-blackbox.js +4 -0
- package/dist/scripts/zellij-slot-column-anchor-check.js +66 -0
- package/dist/scripts/zellij-slot-column-anchor-telemetry-check.js +9 -0
- package/dist/scripts/zellij-slot-only-ui-check.js +31 -0
- package/dist/scripts/zellij-slot-pane-renderer-check.js +150 -0
- package/dist/scripts/zellij-slot-pane-stale-detection-check.js +74 -0
- package/dist/scripts/zellij-slot-pane-telemetry-renderer-check.js +11 -0
- package/dist/scripts/zellij-slot-renderer-proof-semantics-check.js +59 -0
- package/dist/scripts/zellij-slot-telemetry-check.js +39 -0
- package/dist/scripts/zellij-slot-telemetry-incremental-check.js +48 -0
- package/dist/scripts/zellij-slot-telemetry-live-flush-check.js +57 -0
- package/dist/scripts/zellij-slot-telemetry-performance-check.js +34 -0
- package/dist/scripts/zellij-slot-telemetry-real-blackbox.js +20 -0
- package/dist/scripts/zellij-slot-telemetry-renderer-check.js +10 -0
- package/dist/scripts/zellij-slot-telemetry-runtime-check.js +23 -0
- package/dist/scripts/zellij-spawn-on-demand-layout-check.js +40 -0
- package/dist/scripts/zellij-stacked-capability-routing-check.js +11 -0
- package/dist/scripts/zellij-stacked-fallback-integration-blackbox.js +81 -0
- package/dist/scripts/zellij-stacked-version-matrix-check.js +31 -0
- package/dist/scripts/zellij-stacked-version-parser-check.js +21 -0
- package/dist/scripts/zellij-ui-design-check.js +105 -0
- package/dist/scripts/zellij-update-missing-self-heal-check.js +4 -0
- package/dist/scripts/zellij-update-prompt-matrix-check.js +18 -0
- package/dist/scripts/zellij-update-prompt-mode-check.js +20 -0
- package/dist/scripts/zellij-update-prompt-safety-check.js +10 -0
- package/dist/scripts/zellij-worker-pane-manager-check.js +109 -0
- package/dist/scripts/zellij-worker-pane-manager-single-owner-check.js +47 -0
- package/dist/scripts/zellij-worker-pane-real-ui-blackbox.js +202 -0
- package/dist/scripts/zellij-worker-pane-spawn-order-check.js +35 -0
- package/package.json +17 -7
- package/schemas/codex/app-server-0.142/codex_app_server_protocol.v2.schemas.json +18447 -0
- package/schemas/codex-release-manifest.schema.json +44 -0
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import fs from 'node:fs/promises';
|
|
3
|
+
import path from 'node:path';
|
|
4
|
+
import { assertGate, emitGate, makeTempRoot, writeText } from './sks-3-1-8-check-lib.js';
|
|
5
|
+
import { repairContext7Mcp } from '../core/doctor/context7-mcp-repair.js';
|
|
6
|
+
const root = await makeTempRoot('sks-context7-blackbox-');
|
|
7
|
+
const configPath = path.join(root, '.codex', 'config.toml');
|
|
8
|
+
await writeText(configPath, '[mcp_servers.context7]\ncommand = "npx"\n');
|
|
9
|
+
const repaired = await repairContext7Mcp({ root, apply: true });
|
|
10
|
+
const text = await fs.readFile(configPath, 'utf8');
|
|
11
|
+
assertGate(repaired.ok === true && text.includes('https://mcp.context7.com/mcp'), 'Context7 blackbox must write remote URL', { repaired, text });
|
|
12
|
+
await writeText(configPath, '[mcp_servers.context7]\ndisabled = true\ncommand = "npx"\n');
|
|
13
|
+
const disabled = await repairContext7Mcp({ root, apply: true });
|
|
14
|
+
assertGate(disabled.after_transport === 'disabled' && disabled.repaired === false && disabled.disabled_preserved === true, 'Context7 blackbox must preserve explicitly disabled server', disabled);
|
|
15
|
+
emitGate('doctor:context7-mcp-repair-blackbox');
|
|
16
|
+
//# sourceMappingURL=doctor-context7-mcp-repair-blackbox.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { assertGate, emitGate, makeTempRoot, writeText } from './sks-3-1-8-check-lib.js';
|
|
3
|
+
import { repairContext7Mcp } from '../core/doctor/context7-mcp-repair.js';
|
|
4
|
+
import path from 'node:path';
|
|
5
|
+
const root = await makeTempRoot('sks-context7-');
|
|
6
|
+
await writeText(path.join(root, '.codex', 'config.toml'), '[mcp_servers.context7]\ncommand = "npx"\nargs = ["-y", "@upstash/context7-mcp"]\n');
|
|
7
|
+
const report = await repairContext7Mcp({ root, apply: true });
|
|
8
|
+
assertGate(report.ok === true && report.after_transport === 'remote', 'Context7 MCP repair must migrate stdio config to remote when safe', report);
|
|
9
|
+
assertGate(report.remote_probe_status === 'skipped' && report.disabled_preserved === false, 'Context7 MCP repair must record remote probe/disabled preservation status', report);
|
|
10
|
+
emitGate('doctor:context7-mcp-repair');
|
|
11
|
+
//# sourceMappingURL=doctor-context7-mcp-repair-check.js.map
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
// @ts-nocheck
|
|
3
|
+
import fs from 'node:fs/promises';
|
|
4
|
+
import os from 'node:os';
|
|
5
|
+
import path from 'node:path';
|
|
6
|
+
import { pathToFileURL } from 'node:url';
|
|
7
|
+
import { ensureDistFresh, root as repoRoot } from './lib/ensure-dist-fresh.js';
|
|
8
|
+
import { assertGate, emitGate } from './sks-1-18-gate-lib.js';
|
|
9
|
+
import { writeTextAtomic } from '../core/fsx.js';
|
|
10
|
+
const freshness = ensureDistFresh({ rebuild: true });
|
|
11
|
+
assertGate(freshness.ok, 'dist must be fresh for doctor context7 repair check', freshness);
|
|
12
|
+
const mod = await import(pathToFileURL(path.join(repoRoot, 'dist', 'core', 'doctor', 'doctor-context7-repair.js')).href);
|
|
13
|
+
const tmp = await fs.mkdtemp(path.join(os.tmpdir(), 'sks-context7-doctor-'));
|
|
14
|
+
const codexHome = path.join(tmp, 'codex-home');
|
|
15
|
+
await fs.mkdir(path.join(tmp, '.codex'), { recursive: true });
|
|
16
|
+
await fs.mkdir(codexHome, { recursive: true });
|
|
17
|
+
const localBlock = [
|
|
18
|
+
'model = "gpt-5.5"',
|
|
19
|
+
'',
|
|
20
|
+
'[mcp_servers.context7]',
|
|
21
|
+
'command = "npx"',
|
|
22
|
+
'args = ["-y", "@upstash/context7-mcp@latest"]',
|
|
23
|
+
'',
|
|
24
|
+
'[features]',
|
|
25
|
+
'hooks = true',
|
|
26
|
+
'',
|
|
27
|
+
'[mcp_servers.context7.env]',
|
|
28
|
+
'CONTEXT7_API_KEY = "fixture"',
|
|
29
|
+
''
|
|
30
|
+
].join('\n');
|
|
31
|
+
await writeTextAtomic(path.join(tmp, '.codex', 'config.toml'), localBlock);
|
|
32
|
+
await writeTextAtomic(path.join(codexHome, 'config.toml'), localBlock);
|
|
33
|
+
const planned = await mod.runDoctorContext7Repair({ root: tmp, codexHome, fix: false });
|
|
34
|
+
assertGate(planned.configs.every((entry) => entry.status === 'local_stdio_detected'), 'dry inspect must detect local stdio context7', planned);
|
|
35
|
+
const repaired = await mod.runDoctorContext7Repair({ root: tmp, codexHome, fix: true });
|
|
36
|
+
const projectText = await fs.readFile(path.join(tmp, '.codex', 'config.toml'), 'utf8');
|
|
37
|
+
const globalText = await fs.readFile(path.join(codexHome, 'config.toml'), 'utf8');
|
|
38
|
+
for (const text of [projectText, globalText]) {
|
|
39
|
+
assertGate(text.includes('url = "https://mcp.context7.com/mcp"'), 'context7 must migrate to remote MCP URL', text);
|
|
40
|
+
assertGate(!text.includes('@upstash/context7-mcp'), 'local stdio context7 package must be removed', text);
|
|
41
|
+
assertGate(!text.includes('[mcp_servers.context7.env]'), 'nested local context7 env table must be removed with the stdio block', text);
|
|
42
|
+
assertGate(text.includes('[features]') && text.includes('hooks = true'), 'unrelated config tables must be preserved', text);
|
|
43
|
+
}
|
|
44
|
+
assertGate(repaired.ok === true, 'context7 doctor repair must pass', repaired);
|
|
45
|
+
assertGate(repaired.configs.every((entry) => entry.changed === true && entry.backup_path), 'context7 repair must back up changed configs', repaired);
|
|
46
|
+
emitGate('doctor:context7-repair', { configs: repaired.configs.length, actions: repaired.actions });
|
|
47
|
+
//# sourceMappingURL=doctor-context7-repair-check.js.map
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import { assertGate, emitGate, makeTempRoot } from './sks-3-1-8-check-lib.js';
|
|
3
|
+
import { importDist } from './sks-1-18-gate-lib.js';
|
|
4
|
+
const tmp = await makeTempRoot('doctor-dirty-plan-');
|
|
5
|
+
const mod = await importDist('core/doctor/doctor-dirty-planner.js');
|
|
6
|
+
const plan = mod.planDoctorDirtyRepair(tmp, ['setup', 'context7_repair']);
|
|
7
|
+
assertGate(plan.schema === 'sks.doctor-dirty-plan.v1' && plan.dirty_count === 2, 'dirty planner must mark missing markers dirty', plan);
|
|
8
|
+
emitGate('doctor:dirty-plan', { dirty: plan.dirty_count });
|
|
9
|
+
//# sourceMappingURL=doctor-dirty-plan-check.js.map
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import { assertGate, emitGate, makeTempRoot } from './sks-3-1-8-check-lib.js';
|
|
3
|
+
import { importDist } from './sks-1-18-gate-lib.js';
|
|
4
|
+
const tmp = await makeTempRoot('doctor-dirty-repair-');
|
|
5
|
+
const planner = await importDist('core/doctor/doctor-dirty-planner.js');
|
|
6
|
+
const tx = await importDist('core/doctor/doctor-transaction.js');
|
|
7
|
+
const proofId = planner.markDoctorPhaseClean(tmp, 'setup');
|
|
8
|
+
await tx.writeDoctorFixTransaction({
|
|
9
|
+
root: tmp,
|
|
10
|
+
phases: [],
|
|
11
|
+
proofIdsUsed: [proofId]
|
|
12
|
+
});
|
|
13
|
+
let ran = false;
|
|
14
|
+
const report = await tx.runDoctorFixTransaction({
|
|
15
|
+
root: tmp,
|
|
16
|
+
reportPath: null,
|
|
17
|
+
dirtyPlan: planner.planDoctorDirtyRepair(tmp, ['setup']),
|
|
18
|
+
phases: [{ id: 'setup', run: async () => { ran = true; return { id: 'setup', ok: true }; } }]
|
|
19
|
+
});
|
|
20
|
+
assertGate(ran === false && report.ok === true && report.phases[0].warnings.some((warning) => warning.startsWith('dirty_plan_skipped_clean_phase')), 'dirty repair must skip clean phase', { ran, report });
|
|
21
|
+
emitGate('doctor:dirty-repair-blackbox', { skipped: true });
|
|
22
|
+
//# sourceMappingURL=doctor-dirty-repair-blackbox.js.map
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import { assertGate, emitGate, readText } from './sks-1-18-gate-lib.js';
|
|
3
|
+
const tx = readText('src/core/doctor/doctor-transaction.ts');
|
|
4
|
+
const cmd = readText('src/commands/doctor.ts');
|
|
5
|
+
assertGate(tx.includes('isDoctorPhaseClean') && tx.includes('markDoctorPhaseClean'), 'doctor transaction must skip clean phases and mark successful phases clean');
|
|
6
|
+
assertGate(cmd.includes('doctorDirtyPlan') && cmd.includes('planDoctorDirtyRepair'), 'doctor command must wire dirty planner');
|
|
7
|
+
emitGate('doctor:dirty-repair');
|
|
8
|
+
//# sourceMappingURL=doctor-dirty-repair-check.js.map
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { assertGate, emitGate, readText } from './sks-1-18-gate-lib.js';
|
|
2
|
+
const source = readText('src/core/doctor/doctor-dirty-planner.ts');
|
|
3
|
+
assertGate(!source.includes('stat.isDirectory() ? `dir:${stat.mtimeMs}`'), 'doctor dirty planner must not hash directory mtimes');
|
|
4
|
+
assertGate(!source.includes('mtimeMs, text'), 'doctor dirty planner must not mix file mtime into semantic hashes');
|
|
5
|
+
assertGate(source.includes('phaseSemanticState'), 'doctor dirty planner must include phase-specific semantic state');
|
|
6
|
+
assertGate(source.includes('clean_proof_missing'), 'doctor dirty planner must reject markers with missing proof evidence');
|
|
7
|
+
emitGate('doctor:dirty-semantic-blackbox');
|
|
8
|
+
//# sourceMappingURL=doctor-dirty-semantic-blackbox.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { assertGate, emitGate, importDist, root } from './sks-1-18-gate-lib.js';
|
|
2
|
+
const mod = await importDist('core/doctor/doctor-dirty-planner.js');
|
|
3
|
+
const plan = mod.planDoctorDirtyRepair(root, ['context7-mcp']);
|
|
4
|
+
const phase = plan.phases[0];
|
|
5
|
+
assertGate(Boolean(phase.input_hash) && phase.postcheck_required === true, 'dirty planner must use semantic hash and postcheck requirement', phase);
|
|
6
|
+
emitGate('doctor:dirty-semantic', { status: phase.status, reason: phase.reason, input_hash: phase.input_hash });
|
|
7
|
+
//# sourceMappingURL=doctor-dirty-semantic-check.js.map
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import path from 'node:path';
|
|
3
|
+
import { assertGate, emitGate, makeTempRoot, writeText } from './sks-3-1-8-check-lib.js';
|
|
4
|
+
import { repairCodexStartupConfig } from '../core/doctor/codex-startup-config-repair.js';
|
|
5
|
+
import { repairContext7Mcp } from '../core/doctor/context7-mcp-repair.js';
|
|
6
|
+
import { repairSupabaseMcp } from '../core/doctor/supabase-mcp-repair.js';
|
|
7
|
+
import { runDoctorFixTransaction } from '../core/doctor/doctor-transaction.js';
|
|
8
|
+
import { doctorRepairPostcheck } from '../core/doctor/doctor-repair-postcheck.js';
|
|
9
|
+
const root = await makeTempRoot('sks-doctor-production-');
|
|
10
|
+
await writeText(path.join(root, '.codex', 'config.toml'), '[mcp_servers.context7]\ncommand = "npx"\n\n[mcp_servers.supabase]\nurl = "https://supabase.example/mcp"\nread_only = true\n\n[agents.analysis_scout]\nconfig_file = ".codex/agents/stale.toml"\nmessage_role_prefix = "legacy"\n');
|
|
11
|
+
const startup = await repairCodexStartupConfig({ root, apply: true });
|
|
12
|
+
const context7 = await repairContext7Mcp({ root, apply: true });
|
|
13
|
+
const supabase = await repairSupabaseMcp({ root, apply: true });
|
|
14
|
+
const tx = await runDoctorFixTransaction({ root, phases: [
|
|
15
|
+
{ id: 'preflight', run: async () => ({ id: 'preflight', ok: true }) },
|
|
16
|
+
{ id: 'codex_startup_config_repair', run: async () => ({ id: 'codex_startup_config_repair', ok: startup.ok, repaired: true, blockers: startup.blockers }) },
|
|
17
|
+
{ id: 'context7_mcp_repair', run: async () => ({ id: 'context7_mcp_repair', ok: context7.ok, repaired: context7.repaired, blockers: context7.blockers }) },
|
|
18
|
+
{ id: 'supabase_mcp_repair', required_for_ready: false, run: async () => ({ id: 'supabase_mcp_repair', ok: supabase.ok, manual_required: supabase.manual_required, required_for_ready: false, blockers: supabase.blockers, warnings: supabase.warnings }) },
|
|
19
|
+
{ id: 'postcheck', run: async () => ({ id: 'postcheck', ok: true }) }
|
|
20
|
+
] });
|
|
21
|
+
const postcheck = doctorRepairPostcheck(tx);
|
|
22
|
+
assertGate(tx.schema === 'sks.doctor-fix-transaction.v1' && tx.raw_secret_values_recorded === false, 'doctor transaction must write production schema without raw secrets', tx);
|
|
23
|
+
assertGate(tx.phases.every((phase) => typeof phase.duration_ms === 'number' && phase.started_at && phase.completed_at), 'doctor transaction phases must include runtime evidence', tx);
|
|
24
|
+
assertGate(postcheck.ok === true, 'doctor repair postcheck must pass when only manual-required optional phases remain', postcheck);
|
|
25
|
+
emitGate('doctor:fix-production-blackbox', { phases: tx.phases.length });
|
|
26
|
+
//# sourceMappingURL=doctor-fix-production-blackbox.js.map
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
// @ts-nocheck
|
|
3
|
+
import { spawnSync } from 'node:child_process';
|
|
4
|
+
import fs from 'node:fs/promises';
|
|
5
|
+
import os from 'node:os';
|
|
6
|
+
import path from 'node:path';
|
|
7
|
+
const repo = process.cwd();
|
|
8
|
+
const fakeCodex = path.join(repo, 'dist', 'scripts', 'fixtures', 'fake-codex-config-loader.js');
|
|
9
|
+
function runDoctorFix(fixture, home, extraEnv) {
|
|
10
|
+
return spawnSync(process.execPath, [
|
|
11
|
+
path.join(repo, 'dist', 'bin', 'sks.js'),
|
|
12
|
+
'doctor',
|
|
13
|
+
'--fix',
|
|
14
|
+
'--json',
|
|
15
|
+
'--codex-bin',
|
|
16
|
+
fakeCodex
|
|
17
|
+
], {
|
|
18
|
+
cwd: fixture,
|
|
19
|
+
env: {
|
|
20
|
+
...process.env,
|
|
21
|
+
HOME: home,
|
|
22
|
+
CODEX_HOME: path.join(home, '.codex'),
|
|
23
|
+
SKS_DISABLE_UPDATE_CHECK: '1',
|
|
24
|
+
...extraEnv
|
|
25
|
+
},
|
|
26
|
+
encoding: 'utf8',
|
|
27
|
+
timeout: 180000
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
// Scenario 1: an EPERM config-load failure the repairs cannot fix MUST stay a blocker
|
|
31
|
+
// (the re-probe of a genuinely-unreadable config still reports failure — Fix B does not
|
|
32
|
+
// paper over real problems).
|
|
33
|
+
const epermFixture = await fs.mkdtemp(path.join(os.tmpdir(), 'sks-doctor-fix-eperm-'));
|
|
34
|
+
const epermHome = path.join(epermFixture, 'home');
|
|
35
|
+
await fs.mkdir(epermHome, { recursive: true });
|
|
36
|
+
const epermRun = runDoctorFix(epermFixture, epermHome, { SKS_FAKE_CODEX_CONFIG_EPERM: '1' });
|
|
37
|
+
const epermParsed = parseLastJson(epermRun.stdout || '{}');
|
|
38
|
+
const epermOk = epermRun.status !== 0
|
|
39
|
+
&& epermParsed.ready?.ready === false
|
|
40
|
+
&& epermParsed.ready?.blockers?.includes('codex_cli_config_eperm')
|
|
41
|
+
&& epermParsed.ready?.next_actions?.length > 0;
|
|
42
|
+
// Scenario 2 (regression for the endless `sks doctor --fix` loop): the project config
|
|
43
|
+
// seeds Context7 as a LOCAL STDIO server, which the fake loader treats as the Codex 0.140
|
|
44
|
+
// stdio/url merge conflict (`url is not supported for stdio`). `sks doctor --fix` migrates
|
|
45
|
+
// Context7 to the remote `url` transport; the post-repair re-probe must then observe a
|
|
46
|
+
// loadable config and clear `codex_cli_config_toml_parse_error` — instead of reporting the
|
|
47
|
+
// stale pre-migration failure that previously trapped users in a rerun loop.
|
|
48
|
+
const c7Fixture = await fs.mkdtemp(path.join(os.tmpdir(), 'sks-doctor-fix-c7-'));
|
|
49
|
+
const c7Home = path.join(c7Fixture, 'home');
|
|
50
|
+
await fs.mkdir(path.join(c7Fixture, '.codex'), { recursive: true });
|
|
51
|
+
await fs.mkdir(c7Home, { recursive: true });
|
|
52
|
+
await fs.writeFile(path.join(c7Fixture, '.codex', 'config.toml'), '[mcp_servers.context7]\ncommand = "npx"\nargs = ["-y", "@upstash/context7-mcp@latest"]\n');
|
|
53
|
+
const c7Run = runDoctorFix(c7Fixture, c7Home, { SKS_FAKE_CODEX_CONFIG_CONTEXT7_STDIO_CONFLICT: '1' });
|
|
54
|
+
const c7Parsed = parseLastJson(c7Run.stdout || '{}');
|
|
55
|
+
const c7ConfigText = await fs.readFile(path.join(c7Fixture, '.codex', 'config.toml'), 'utf8').catch(() => '');
|
|
56
|
+
const c7MigratedToRemote = /\[mcp_servers\.context7\][^[]*url\s*=\s*"https:\/\/mcp\.context7\.com\/mcp"/.test(c7ConfigText)
|
|
57
|
+
&& !/^\s*command\s*=/m.test(c7ConfigText.match(/\[mcp_servers\.context7\][^[]*/)?.[0] || '');
|
|
58
|
+
const c7BlockerCleared = !((c7Parsed.ready?.blockers || []).includes('codex_cli_config_toml_parse_error'));
|
|
59
|
+
const c7ConfigReadable = c7Parsed.ready?.codex_config_readable_by_codex_cli === true;
|
|
60
|
+
const context7Ok = c7MigratedToRemote && c7BlockerCleared && c7ConfigReadable;
|
|
61
|
+
const ok = epermOk && context7Ok;
|
|
62
|
+
console.log(JSON.stringify({
|
|
63
|
+
schema: 'sks.doctor-fix-proves-codex-read-check.v2',
|
|
64
|
+
ok,
|
|
65
|
+
eperm_case: {
|
|
66
|
+
ok: epermOk,
|
|
67
|
+
status: epermRun.status,
|
|
68
|
+
blockers: epermParsed.ready?.blockers || null
|
|
69
|
+
},
|
|
70
|
+
context7_reprobe_case: {
|
|
71
|
+
ok: context7Ok,
|
|
72
|
+
status: c7Run.status,
|
|
73
|
+
migrated_to_remote: c7MigratedToRemote,
|
|
74
|
+
parse_error_cleared: c7BlockerCleared,
|
|
75
|
+
config_readable_by_codex_cli: c7ConfigReadable,
|
|
76
|
+
blockers: c7Parsed.ready?.blockers || null,
|
|
77
|
+
config_tail: c7ConfigText.slice(-400)
|
|
78
|
+
},
|
|
79
|
+
parsed: epermParsed,
|
|
80
|
+
stdout_tail: String(epermRun.stdout || '').slice(-1000),
|
|
81
|
+
stderr_tail: String(epermRun.stderr || '').slice(-1000)
|
|
82
|
+
}, null, 2));
|
|
83
|
+
if (!ok)
|
|
84
|
+
process.exitCode = 1;
|
|
85
|
+
function parseLastJson(text) {
|
|
86
|
+
const source = String(text || '').trim();
|
|
87
|
+
if (!source)
|
|
88
|
+
return {};
|
|
89
|
+
const starts = [];
|
|
90
|
+
for (let index = source.indexOf('{'); index >= 0; index = source.indexOf('{', index + 1))
|
|
91
|
+
starts.push(index);
|
|
92
|
+
for (let i = starts.length - 1; i >= 0; i -= 1) {
|
|
93
|
+
try {
|
|
94
|
+
return JSON.parse(source.slice(starts[i]));
|
|
95
|
+
}
|
|
96
|
+
catch {
|
|
97
|
+
// Continue searching for the outer JSON object; pretty JSON may contain nested objects.
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
return {};
|
|
101
|
+
}
|
|
102
|
+
//# sourceMappingURL=doctor-fix-proves-codex-read-check.js.map
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
// @ts-nocheck
|
|
3
|
+
// Proves `sks doctor --fix` (via repairCodexConfigEperm) RECOVERS an already-corrupted
|
|
4
|
+
// Codex config — both the project config and the global CODEX_HOME config — by hoisting
|
|
5
|
+
// machine-local keys that a prior buggy move absorbed into a trailing table back to the
|
|
6
|
+
// top of the file, restoring a loadable config.toml. Also proves the structural repair
|
|
7
|
+
// is a no-op on a healthy config.
|
|
8
|
+
import fs from 'node:fs/promises';
|
|
9
|
+
import os from 'node:os';
|
|
10
|
+
import path from 'node:path';
|
|
11
|
+
import { pathToFileURL } from 'node:url';
|
|
12
|
+
import { ensureDistFresh, root as repoRoot } from './lib/ensure-dist-fresh.js';
|
|
13
|
+
const freshness = ensureDistFresh({ rebuild: true });
|
|
14
|
+
if (!freshness.ok)
|
|
15
|
+
fail('dist_not_fresh', { freshness });
|
|
16
|
+
const distUrl = (rel) => pathToFileURL(path.join(repoRoot, 'dist', rel)).href;
|
|
17
|
+
const policy = await import(distUrl('core/codex/codex-project-config-policy.js'));
|
|
18
|
+
const eperm = await import(distUrl('core/codex/codex-config-eperm-repair.js'));
|
|
19
|
+
const results = [];
|
|
20
|
+
// Corruption signature: machine-local keys absorbed into the trailing env table.
|
|
21
|
+
const corrupted = [
|
|
22
|
+
'[mcp_servers.xai-grok]',
|
|
23
|
+
'command = "npx"',
|
|
24
|
+
'',
|
|
25
|
+
'[mcp_servers.xai-grok.env]',
|
|
26
|
+
'XAI_API_KEY = "xai-123"',
|
|
27
|
+
'# SKS moved machine-local Codex config from .codex/config.toml at 2026-05-29T00:00:00Z',
|
|
28
|
+
'model_provider = "codex-lb"',
|
|
29
|
+
'notify = ["notify-send", "SKS"]',
|
|
30
|
+
''
|
|
31
|
+
].join('\n');
|
|
32
|
+
// helper: top-level key index vs first table index
|
|
33
|
+
function keyBeforeFirstTable(text, key) {
|
|
34
|
+
const lines = text.split('\n');
|
|
35
|
+
const firstTable = lines.findIndex((l) => /^\s*\[/.test(l));
|
|
36
|
+
const keyIdx = lines.findIndex((l) => new RegExp(`^\\s*${key}\\s*=`).test(l));
|
|
37
|
+
return keyIdx >= 0 && firstTable >= 0 && keyIdx < firstTable;
|
|
38
|
+
}
|
|
39
|
+
function envTableHasMachineKey(text) {
|
|
40
|
+
// model_provider/notify must NOT appear after the env header
|
|
41
|
+
return /\[mcp_servers\.xai-grok\.env\][\s\S]*\b(model_provider|notify)\s*=/.test(text);
|
|
42
|
+
}
|
|
43
|
+
// --- Case 1: standalone structural repair hoists keys back to root ---
|
|
44
|
+
{
|
|
45
|
+
const dir = await fs.mkdtemp(path.join(os.tmpdir(), 'sks-struct-'));
|
|
46
|
+
const cfg = path.join(dir, 'config.toml');
|
|
47
|
+
await fs.writeFile(cfg, corrupted);
|
|
48
|
+
const rep = await policy.repairCodexConfigStructure(cfg, { apply: true });
|
|
49
|
+
const after = await fs.readFile(cfg, 'utf8');
|
|
50
|
+
const ok = rep.changed === true &&
|
|
51
|
+
rep.applied === true &&
|
|
52
|
+
rep.hoisted_keys.includes('model_provider') &&
|
|
53
|
+
rep.hoisted_keys.includes('notify') &&
|
|
54
|
+
keyBeforeFirstTable(after, 'model_provider') &&
|
|
55
|
+
keyBeforeFirstTable(after, 'notify') &&
|
|
56
|
+
!envTableHasMachineKey(after) &&
|
|
57
|
+
/XAI_API_KEY = "xai-123"/.test(after) &&
|
|
58
|
+
rep.backup_path &&
|
|
59
|
+
rep.parse_smoke.ok === true;
|
|
60
|
+
results.push({ case: 'structure_repair_hoists_keys', ok, hoisted: rep.hoisted_keys, status: rep.status, after });
|
|
61
|
+
}
|
|
62
|
+
// --- Case 2: structural repair is a no-op on a healthy config ---
|
|
63
|
+
{
|
|
64
|
+
const dir = await fs.mkdtemp(path.join(os.tmpdir(), 'sks-struct-ok-'));
|
|
65
|
+
const cfg = path.join(dir, 'config.toml');
|
|
66
|
+
const healthy = [
|
|
67
|
+
'model_provider = "codex-lb"',
|
|
68
|
+
'notify = ["notify-send", "SKS"]',
|
|
69
|
+
'',
|
|
70
|
+
'[mcp_servers.xai-grok.env]',
|
|
71
|
+
'XAI_API_KEY = "xai-123"',
|
|
72
|
+
'',
|
|
73
|
+
'[profiles.sks-mad-high]',
|
|
74
|
+
'model_provider = "codex-lb"',
|
|
75
|
+
'model_reasoning_effort = "high"',
|
|
76
|
+
''
|
|
77
|
+
].join('\n');
|
|
78
|
+
await fs.writeFile(cfg, healthy);
|
|
79
|
+
const rep = await policy.repairCodexConfigStructure(cfg, { apply: true });
|
|
80
|
+
const after = await fs.readFile(cfg, 'utf8');
|
|
81
|
+
// profiles.* model_provider must be preserved inside the profile (NOT hoisted).
|
|
82
|
+
const profileIntact = /\[profiles\.sks-mad-high\][\s\S]*model_provider = "codex-lb"/.test(after);
|
|
83
|
+
const ok = rep.changed === false && rep.status === 'structure_ok' && profileIntact;
|
|
84
|
+
results.push({ case: 'structure_repair_noop_on_healthy', ok, status: rep.status, profile_intact: profileIntact });
|
|
85
|
+
}
|
|
86
|
+
// --- Case 3: doctor --fix recovers the GLOBAL CODEX_HOME config end-to-end ---
|
|
87
|
+
{
|
|
88
|
+
const fixture = await fs.mkdtemp(path.join(os.tmpdir(), 'sks-doctor-fix-'));
|
|
89
|
+
const codexHome = path.join(fixture, 'home', '.codex');
|
|
90
|
+
await fs.mkdir(codexHome, { recursive: true });
|
|
91
|
+
await fs.writeFile(path.join(codexHome, 'config.toml'), corrupted);
|
|
92
|
+
// Project has only a benign config so the project path is healthy.
|
|
93
|
+
await fs.mkdir(path.join(fixture, '.codex'), { recursive: true });
|
|
94
|
+
await fs.writeFile(path.join(fixture, '.codex', 'config.toml'), 'sandbox_mode = "workspace-write"\n');
|
|
95
|
+
const report = await eperm.repairCodexConfigEperm(fixture, {
|
|
96
|
+
fix: true,
|
|
97
|
+
codexHome,
|
|
98
|
+
// no real codex needed; structural repair runs regardless
|
|
99
|
+
actualCodex: false,
|
|
100
|
+
codexProbe: false,
|
|
101
|
+
writeReport: false
|
|
102
|
+
});
|
|
103
|
+
const homeAfter = await fs.readFile(path.join(codexHome, 'config.toml'), 'utf8');
|
|
104
|
+
const homeRepair = (report.structure_repairs || []).find((r) => r.scope === 'codex_home');
|
|
105
|
+
const ok = Boolean(homeRepair) &&
|
|
106
|
+
homeRepair.applied === true &&
|
|
107
|
+
homeRepair.hoisted_keys.includes('model_provider') &&
|
|
108
|
+
homeRepair.hoisted_keys.includes('notify') &&
|
|
109
|
+
keyBeforeFirstTable(homeAfter, 'model_provider') &&
|
|
110
|
+
keyBeforeFirstTable(homeAfter, 'notify') &&
|
|
111
|
+
!envTableHasMachineKey(homeAfter);
|
|
112
|
+
results.push({ case: 'doctor_fix_recovers_codex_home', ok, home_repair: homeRepair, home_after: homeAfter });
|
|
113
|
+
}
|
|
114
|
+
const ok = results.every((r) => r.ok);
|
|
115
|
+
console.log(JSON.stringify({ schema: 'sks.doctor-fix-recovers-corrupted-config-check.v1', ok, results }, null, 2));
|
|
116
|
+
if (!ok)
|
|
117
|
+
process.exitCode = 1;
|
|
118
|
+
function fail(blocker, detail) {
|
|
119
|
+
console.log(JSON.stringify({ schema: 'sks.doctor-fix-recovers-corrupted-config-check.v1', ok: false, blocker, detail }, null, 2));
|
|
120
|
+
process.exit(1);
|
|
121
|
+
}
|
|
122
|
+
//# sourceMappingURL=doctor-fix-recovers-corrupted-config-check.js.map
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import fs from 'node:fs/promises';
|
|
3
|
+
import os from 'node:os';
|
|
4
|
+
import path from 'node:path';
|
|
5
|
+
import { repairCodexAppFastUi } from '../core/codex-app/codex-app-fast-ui-repair.js';
|
|
6
|
+
const root = await fs.mkdtemp(path.join(os.tmpdir(), 'sks-doctor-fast-ui-'));
|
|
7
|
+
const codexHome = path.join(root, 'home', '.codex');
|
|
8
|
+
await fs.mkdir(path.join(root, '.codex'), { recursive: true });
|
|
9
|
+
await fs.mkdir(codexHome, { recursive: true });
|
|
10
|
+
await fs.writeFile(path.join(root, '.codex', 'config.toml'), 'model_provider = "codex-lb"\n');
|
|
11
|
+
await fs.writeFile(path.join(codexHome, 'config.toml'), '# SKS forced fast UI during legacy install\nmodel_provider = "codex-lb"\nservice_tier = "fast"\n[features]\nfast_mode = false # user disabled, must remain untouched\n\n[profiles.sks-fast-high]\nmodel = "gpt-5.5"\nservice_tier = "fast"\n\n[model_providers.codex-lb]\nname = "OpenAI"\nbase_url = "https://lb.example.test/backend-api/codex"\nwire_api = "responses"\nenv_key = "CODEX_LB_API_KEY"\nsupports_websockets = true\nrequires_openai_auth = false\n');
|
|
12
|
+
const plan = await repairCodexAppFastUi(root, { codexHome, apply: false });
|
|
13
|
+
const repaired = await repairCodexAppFastUi(root, { codexHome, apply: true });
|
|
14
|
+
const projectAfter = await fs.readFile(path.join(root, '.codex', 'config.toml'), 'utf8');
|
|
15
|
+
const homeAfter = await fs.readFile(path.join(codexHome, 'config.toml'), 'utf8');
|
|
16
|
+
const homeTopLevel = homeAfter.split(/\n\s*\[/)[0] || '';
|
|
17
|
+
const backups = repaired.actions.filter((action) => action.changed).map((action) => action.backup_path).filter(Boolean);
|
|
18
|
+
const unsafeRoot = await fs.mkdtemp(path.join(os.tmpdir(), 'sks-doctor-fast-ui-unsafe-'));
|
|
19
|
+
const unsafeCodexHome = path.join(unsafeRoot, 'home', '.codex');
|
|
20
|
+
await fs.mkdir(path.join(unsafeRoot, '.codex'), { recursive: true });
|
|
21
|
+
await fs.mkdir(unsafeCodexHome, { recursive: true });
|
|
22
|
+
await fs.writeFile(path.join(unsafeCodexHome, 'config.toml'), 'service_tier = "standard"\n');
|
|
23
|
+
const unsafePlan = await repairCodexAppFastUi(unsafeRoot, { codexHome: unsafeCodexHome, apply: false });
|
|
24
|
+
const ok = plan.fast_selector === 'manual_action_required'
|
|
25
|
+
&& plan.safe_auto_apply === true
|
|
26
|
+
&& repaired.fast_selector === 'repaired'
|
|
27
|
+
&& repaired.safe_auto_apply === true
|
|
28
|
+
&& backups.length >= 2
|
|
29
|
+
&& !/model_provider\s*=/.test(projectAfter)
|
|
30
|
+
&& !/service_tier\s*=/.test(homeTopLevel)
|
|
31
|
+
&& /fast_mode = false/.test(homeAfter)
|
|
32
|
+
&& /model_provider = "codex-lb"/.test(homeAfter)
|
|
33
|
+
&& /\[profiles\.sks-fast-high\]/.test(homeAfter)
|
|
34
|
+
&& /\[profiles\.sks-fast-high\][\s\S]*service_tier = "fast"/.test(homeAfter)
|
|
35
|
+
&& /\[model_providers\.codex-lb\]/.test(homeAfter)
|
|
36
|
+
&& unsafePlan.requires_confirmation === true
|
|
37
|
+
&& unsafePlan.safe_auto_apply === false;
|
|
38
|
+
emit({ schema: 'sks.doctor-fixes-codex-app-fast-ui-check.v1', ok, plan, repaired, unsafe_plan: unsafePlan, project_after: projectAfter, home_after: homeAfter, blockers: ok ? [] : ['doctor_fixes_codex_app_fast_ui_check_failed'] });
|
|
39
|
+
function emit(report) {
|
|
40
|
+
console.log(JSON.stringify(report, null, 2));
|
|
41
|
+
if (!report.ok)
|
|
42
|
+
process.exitCode = 1;
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=doctor-fixes-codex-app-fast-ui-check.js.map
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { assertGate, emitGate, makeTempRoot, writeText } from './sks-3-1-8-check-lib.js';
|
|
3
|
+
import { repairNativeCapabilities } from '../core/codex-native/native-capability-repair.js';
|
|
4
|
+
import path from 'node:path';
|
|
5
|
+
const repairableRoot = await makeTempRoot('sks-doctor-native-repairable-');
|
|
6
|
+
process.env.SKS_CHROME_EXTENSION_READY = '1';
|
|
7
|
+
process.env.SKS_COMPUTER_USE_CAPABILITY = 'verified';
|
|
8
|
+
const repairable = await repairNativeCapabilities({ root: repairableRoot, fix: true, yes: true, fixture: 'all-repairable' });
|
|
9
|
+
delete process.env.SKS_CHROME_EXTENSION_READY;
|
|
10
|
+
delete process.env.SKS_COMPUTER_USE_CAPABILITY;
|
|
11
|
+
const manualRoot = await makeTempRoot('sks-doctor-native-manual-');
|
|
12
|
+
const manual = await repairNativeCapabilities({ root: manualRoot, fix: true, yes: true, fixture: 'manual-required' });
|
|
13
|
+
const screenshotBlockedRoot = await makeTempRoot('sks-doctor-native-screenshot-blocked-');
|
|
14
|
+
await writeText(path.join(screenshotBlockedRoot, '.sneakoscope', 'app-screenshots'), 'not-a-directory');
|
|
15
|
+
const screenshotBlocked = await repairNativeCapabilities({
|
|
16
|
+
root: screenshotBlockedRoot,
|
|
17
|
+
fix: false,
|
|
18
|
+
yes: true,
|
|
19
|
+
fixture: 'all-repairable',
|
|
20
|
+
capabilities: ['codex_app_screenshot']
|
|
21
|
+
});
|
|
22
|
+
const corruptContractRoot = await makeTempRoot('sks-doctor-native-contract-repair-');
|
|
23
|
+
await writeText(path.join(corruptContractRoot, '.sneakoscope', 'reports', 'saved-artifact-path-contract.json'), '{"schema":"broken"}\n');
|
|
24
|
+
const corruptContract = await repairNativeCapabilities({
|
|
25
|
+
root: corruptContractRoot,
|
|
26
|
+
fix: true,
|
|
27
|
+
yes: true,
|
|
28
|
+
fixture: 'manual-required',
|
|
29
|
+
capabilities: ['saved_artifact_path_contract']
|
|
30
|
+
});
|
|
31
|
+
assertGate(repairable.ok === true, 'repairable fixture must verify after doctor native repair', repairable);
|
|
32
|
+
assertGate(manual.capabilities.some((state) => state.repairability === 'manual-required' && state.after !== 'verified'), 'manual-only fixture must not fake verified success', manual);
|
|
33
|
+
assertGate(manual.capabilities.find((state) => state.id === 'image_generation')?.after !== 'verified', 'image generation auth missing must not verify', manual);
|
|
34
|
+
assertGate(manual.capabilities.find((state) => state.id === 'chrome_web_review')?.after !== 'verified', 'Chrome/web review missing extension must not verify', manual);
|
|
35
|
+
assertGate(manual.capabilities.find((state) => state.id === 'image_path_exposure')?.after === 'degraded', 'saved artifact path fallback must be degraded rather than verified', manual);
|
|
36
|
+
assertGate(screenshotBlocked.capabilities.find((state) => state.id === 'codex_app_screenshot')?.after === 'blocked', 'unwritable screenshot artifact root must block postcheck', screenshotBlocked);
|
|
37
|
+
assertGate(corruptContract.capabilities.find((state) => state.id === 'saved_artifact_path_contract')?.after === 'verified', 'doctor fix must repair corrupt saved artifact path contract', corruptContract);
|
|
38
|
+
emitGate('doctor:native-capability-repair-blackbox');
|
|
39
|
+
//# sourceMappingURL=doctor-native-capability-repair-blackbox.js.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { assertGate, emitGate, makeTempRoot } from './sks-3-1-8-check-lib.js';
|
|
3
|
+
import { runDoctorNativeCapabilityRepair } from '../core/doctor/doctor-native-capability-repair.js';
|
|
4
|
+
const root = await makeTempRoot('sks-doctor-native-');
|
|
5
|
+
process.env.CODEX_HOME = `${root}/codex-home`;
|
|
6
|
+
const report = await runDoctorNativeCapabilityRepair({ root, fix: false, yes: true, flags: [] });
|
|
7
|
+
assertGate(report.schema === 'sks.doctor-native-capability-repair.v1', 'doctor native repair report schema mismatch', report);
|
|
8
|
+
assertGate(Boolean(report.core_skills) && Boolean(report.skill_dedupe) && Boolean(report.native_capabilities), 'doctor native repair must call core skills, dedupe, and native capability matrix', report);
|
|
9
|
+
emitGate('doctor:native-capability-repair');
|
|
10
|
+
//# sourceMappingURL=doctor-native-capability-repair-check.js.map
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { assertGate, emitGate, readText } from './sks-1-18-gate-lib.js';
|
|
3
|
+
const source = readText('src/commands/doctor.ts');
|
|
4
|
+
const matrixSource = readText('src/core/codex-native/native-capability-repair-matrix.ts');
|
|
5
|
+
for (const token of ['SKS Native Capabilities:', 'SKS Skills:', 'Secret preservation:', 'raw secret values: never recorded', 'Chrome/web review', 'manual next actions:', 'uniqueNativeManualActions']) {
|
|
6
|
+
assertGate(source.includes(token), `doctor output missing token: ${token}`);
|
|
7
|
+
}
|
|
8
|
+
for (const token of [
|
|
9
|
+
"id === 'image_path_exposure'",
|
|
10
|
+
"return 'fallback'",
|
|
11
|
+
"id === 'app_handoff'",
|
|
12
|
+
"return 'unavailable'"
|
|
13
|
+
]) {
|
|
14
|
+
assertGate(source.includes(token), `doctor native status mapping missing token: ${token}`);
|
|
15
|
+
}
|
|
16
|
+
assertGate(matrixSource.includes('Install/enable the official Codex Chrome Extension') && matrixSource.includes('Enable Codex Computer Use and macOS Screen Recording/Accessibility permissions'), 'doctor output must retain exact manual actions for native capabilities');
|
|
17
|
+
emitGate('doctor:native-repair-output');
|
|
18
|
+
//# sourceMappingURL=doctor-native-repair-output-check.js.map
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import fs from 'node:fs/promises';
|
|
3
|
+
import path from 'node:path';
|
|
4
|
+
import { assertGate, emitGate, makeTempRoot, writeText } from './sks-3-1-8-check-lib.js';
|
|
5
|
+
import { repairCodexStartupConfig } from '../core/doctor/codex-startup-config-repair.js';
|
|
6
|
+
const root = await makeTempRoot('sks-startup-config-blackbox-');
|
|
7
|
+
await writeText(path.join(root, '.codex', 'config.toml'), '[agents.analysis_scout]\nconfig_file = ".codex/agents/stale.toml"\nmessage_role_prefix = "legacy"\n');
|
|
8
|
+
const report = await repairCodexStartupConfig({ root, apply: true });
|
|
9
|
+
const text = await fs.readFile(path.join(root, '.codex', 'config.toml'), 'utf8');
|
|
10
|
+
assertGate(report.ok === true, 'startup config blackbox must pass postcheck', report);
|
|
11
|
+
assertGate(!text.includes('message_role_prefix') && /config_file = "\//.test(text), 'startup config blackbox must rewrite to absolute config paths and remove unsupported fields', { text });
|
|
12
|
+
emitGate('doctor:startup-config-repair-blackbox');
|
|
13
|
+
//# sourceMappingURL=doctor-startup-config-repair-blackbox.js.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { assertGate, emitGate, makeTempRoot, writeText } from './sks-3-1-8-check-lib.js';
|
|
3
|
+
import { repairCodexStartupConfig } from '../core/doctor/codex-startup-config-repair.js';
|
|
4
|
+
import path from 'node:path';
|
|
5
|
+
const root = await makeTempRoot('sks-startup-config-');
|
|
6
|
+
await writeText(path.join(root, '.codex', 'config.toml'), '[agents.analysis_scout]\nconfig_file = ".codex/agents/missing.toml"\nmessage_role_prefix = "legacy"\n');
|
|
7
|
+
const report = await repairCodexStartupConfig({ root, apply: true });
|
|
8
|
+
assertGate(report.ok === true, 'startup config repair must repair stale config_file paths and unsupported fields', report);
|
|
9
|
+
emitGate('doctor:startup-config-repair');
|
|
10
|
+
//# sourceMappingURL=doctor-startup-config-repair-check.js.map
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import path from 'node:path';
|
|
3
|
+
import { assertGate, emitGate, makeTempRoot, writeText } from './sks-3-1-8-check-lib.js';
|
|
4
|
+
import { repairSupabaseMcp } from '../core/doctor/supabase-mcp-repair.js';
|
|
5
|
+
const root = await makeTempRoot('sks-supabase-mcp-blackbox-');
|
|
6
|
+
delete process.env.SUPABASE_ACCESS_TOKEN;
|
|
7
|
+
await writeText(path.join(root, '.codex', 'config.toml'), '[mcp_servers.supabase]\nurl = "https://supabase.example/mcp"\nSUPABASE_ACCESS_TOKEN = "env:SUPABASE_ACCESS_TOKEN"\n');
|
|
8
|
+
const unsafe = await repairSupabaseMcp({ root, apply: true });
|
|
9
|
+
assertGate(unsafe.ok === true && unsafe.manual_required === true && unsafe.read_only_migrated === true && unsafe.ready_blocking === false, 'Supabase unsafe write access must be migrated to read-only without passing silently as write-ready', unsafe);
|
|
10
|
+
await writeText(path.join(root, '.codex', 'config.toml'), '[mcp_servers.supabase_sauron]\ndisabled = true\n');
|
|
11
|
+
const optional = await repairSupabaseMcp({ root, apply: true });
|
|
12
|
+
assertGate(optional.ok === true && optional.disabled === true && optional.disabled_preserved === true, 'optional disabled Supabase config must be preserved', optional);
|
|
13
|
+
emitGate('doctor:supabase-mcp-repair-blackbox');
|
|
14
|
+
//# sourceMappingURL=doctor-supabase-mcp-repair-blackbox.js.map
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { assertGate, emitGate, makeTempRoot, writeText } from './sks-3-1-8-check-lib.js';
|
|
3
|
+
import { repairSupabaseMcp } from '../core/doctor/supabase-mcp-repair.js';
|
|
4
|
+
import path from 'node:path';
|
|
5
|
+
const root = await makeTempRoot('sks-supabase-mcp-');
|
|
6
|
+
delete process.env.SUPABASE_ACCESS_TOKEN;
|
|
7
|
+
await writeText(path.join(root, '.codex', 'config.toml'), '[mcp_servers.supabase]\nurl = "https://supabase.example/mcp"\nread_only = true\n');
|
|
8
|
+
const report = await repairSupabaseMcp({ root, apply: true });
|
|
9
|
+
assertGate(report.ok === true && report.manual_required === true && report.ready_blocking === false && report.raw_secret_values_recorded === false, 'Supabase MCP repair must mark unset token as manual for write features without blocking read-only readiness', report);
|
|
10
|
+
assertGate(report.disabled_preserved === false && report.write_scope_requires_confirmation === false, 'Supabase MCP read-only config must not require write confirmation', report);
|
|
11
|
+
emitGate('doctor:supabase-mcp-repair');
|
|
12
|
+
//# sourceMappingURL=doctor-supabase-mcp-repair-check.js.map
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { assertGate, emitGate, makeTempRoot } from './sks-3-1-8-check-lib.js';
|
|
3
|
+
import { runDoctorFixTransaction } from '../core/doctor/doctor-transaction.js';
|
|
4
|
+
import { doctorRepairPostcheck } from '../core/doctor/doctor-repair-postcheck.js';
|
|
5
|
+
const root = await makeTempRoot('sks-doctor-tx-blackbox-');
|
|
6
|
+
const tx = await runDoctorFixTransaction({
|
|
7
|
+
root,
|
|
8
|
+
phases: [
|
|
9
|
+
{ id: 'preflight', run: async () => ({ id: 'preflight', ok: true, artifact_path: `${root}/preflight.json` }) },
|
|
10
|
+
{
|
|
11
|
+
id: 'postchecked',
|
|
12
|
+
run: async () => ({ id: 'postchecked', ok: true }),
|
|
13
|
+
postcheck: async () => ({ ok: true, warnings: ['postcheck_executed'] })
|
|
14
|
+
},
|
|
15
|
+
{
|
|
16
|
+
id: 'optional_operator',
|
|
17
|
+
required_for_ready: false,
|
|
18
|
+
run: async () => ({ id: 'optional_operator', ok: false, manual_required: true, required_for_ready: false, blockers: ['operator_action_required'] })
|
|
19
|
+
}
|
|
20
|
+
],
|
|
21
|
+
reportPath: null
|
|
22
|
+
});
|
|
23
|
+
const postcheck = doctorRepairPostcheck(tx);
|
|
24
|
+
assertGate(tx.ok === true && postcheck.ok === true, 'doctor transaction blackbox must allow optional manual follow-up without blocking readiness', { tx, postcheck });
|
|
25
|
+
assertGate(tx.phases.some((phase) => phase.warnings.includes('postcheck_executed')), 'doctor transaction blackbox must run phase postchecks', tx);
|
|
26
|
+
assertGate(tx.raw_secret_values_recorded === false, 'doctor transaction blackbox must not record raw secrets', tx);
|
|
27
|
+
emitGate('doctor:transaction-engine-blackbox', { phases: tx.phases.length });
|
|
28
|
+
//# sourceMappingURL=doctor-transaction-engine-blackbox.js.map
|