sneakoscope 2.0.13 → 2.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 +6 -3
- package/crates/sks-core/Cargo.lock +1 -1
- package/crates/sks-core/Cargo.toml +1 -1
- package/crates/sks-core/src/main.rs +1 -1
- package/dist/.sks-build-stamp.json +4 -4
- package/dist/bin/sks.js +1 -1
- package/dist/cli/command-registry.js +1 -0
- package/dist/commands/mad-db.js +5 -0
- package/dist/commands/zellij-slot-pane.js +3 -1
- package/dist/core/agents/agent-orchestrator.js +11 -4
- package/dist/core/agents/agent-output-validator.js +1 -1
- package/dist/core/agents/agent-plan.js +3 -2
- package/dist/core/agents/native-cli-session-swarm.js +118 -0
- package/dist/core/agents/native-cli-worker.js +85 -0
- package/dist/core/codex-control/codex-fake-sdk-adapter.js +3 -3
- package/dist/core/codex-control/gpt-final-review-schema.js +61 -14
- package/dist/core/commands/basic-cli.js +1 -1
- package/dist/core/commands/command-suggestions.js +1 -1
- package/dist/core/commands/mad-db-command.js +106 -0
- package/dist/core/commands/mad-sks-command.js +50 -13
- package/dist/core/commands/naruto-command.js +82 -1
- package/dist/core/commands/research-command.js +83 -17
- package/dist/core/commands/team-command.js +25 -1
- package/dist/core/db-safety.js +26 -0
- package/dist/core/fsx.js +1 -1
- package/dist/core/mad-db/mad-db-capability.js +84 -0
- package/dist/core/mad-db/mad-db-ledger.js +17 -0
- package/dist/core/mad-db/mad-db-policy-resolver.js +46 -0
- package/dist/core/naruto/naruto-real-worker-child.js +11 -3
- package/dist/core/naruto/naruto-real-worker-runtime.js +4 -0
- package/dist/core/pipeline/final-gpt-patch-stage.js +20 -3
- package/dist/core/pipeline-internals/runtime-core.js +74 -8
- package/dist/core/pipeline-internals/runtime-gates.js +44 -0
- package/dist/core/proof/route-proof-gate.js +5 -3
- package/dist/core/proof/route-proof-policy.js +9 -1
- package/dist/core/release/release-gate-affected-selector.js +113 -0
- package/dist/core/release/release-gate-batch-runner.js +67 -0
- package/dist/core/release/release-gate-dag.js +22 -3
- package/dist/core/release/release-gate-resource-governor.js +23 -11
- package/dist/core/research/implementation-blueprint-densifier.js +124 -0
- package/dist/core/research/implementation-blueprint-markdown.js +1 -1
- package/dist/core/research/implementation-blueprint.js +68 -7
- package/dist/core/research/research-claim-builder.js +114 -0
- package/dist/core/research/research-cycle-runner.js +115 -11
- package/dist/core/research/research-final-reviewer.js +181 -1
- package/dist/core/research/research-handoff.js +69 -5
- package/dist/core/research/research-realistic-report.js +162 -0
- package/dist/core/research/research-repetition-detector.js +75 -0
- package/dist/core/research/research-report-quality.js +27 -5
- package/dist/core/research/research-source-ledger-merge.js +186 -0
- package/dist/core/research/research-source-shards.js +176 -0
- package/dist/core/research/research-stage-runner.js +537 -11
- package/dist/core/research/research-synthesis-prompt.js +52 -0
- package/dist/core/research/research-synthesis-writer.js +208 -0
- package/dist/core/research/research-work-graph.js +114 -23
- package/dist/core/research.js +72 -48
- package/dist/core/routes.js +23 -19
- package/dist/core/update/update-notice.js +120 -0
- package/dist/core/version.js +1 -1
- package/dist/core/zellij/zellij-dashboard-renderer.js +2 -0
- package/dist/core/zellij/zellij-slot-column-anchor.js +35 -1
- package/dist/core/zellij/zellij-slot-pane-renderer.js +57 -0
- package/dist/core/zellij/zellij-slot-telemetry.js +182 -0
- package/dist/scripts/release-gate-dag-runner.js +5 -0
- package/dist/scripts/release-speed-summary.js +25 -0
- package/package.json +67 -5
- package/schemas/codex/agent-result.schema.json +1 -1
- package/schemas/mad-db/mad-db-capability.schema.json +31 -0
- package/schemas/mad-db/mad-db-ledger.schema.json +14 -0
- package/schemas/research/implementation-blueprint.schema.json +6 -1
- package/schemas/research/research-final-review.schema.json +10 -0
- package/schemas/research/research-source-shard.schema.json +46 -0
- package/schemas/research/research-synthesis-output.schema.json +62 -0
- package/schemas/update/update-notice.schema.json +19 -0
- package/schemas/zellij/zellij-slot-telemetry.schema.json +89 -0
- package/dist/build-manifest.json +0 -1184
- package/dist/scripts/agent-ast-aware-work-graph-check.js +0 -25
- package/dist/scripts/agent-backfill-replenishment-check.js +0 -13
- package/dist/scripts/agent-backfill-route-blackbox.js +0 -5
- package/dist/scripts/agent-background-terminals-check.js +0 -16
- package/dist/scripts/agent-cleanup-command-ux-check.js +0 -12
- package/dist/scripts/agent-cleanup-executor-check.js +0 -53
- package/dist/scripts/agent-cleanup-executor-v2-check.js +0 -39
- package/dist/scripts/agent-cli-options-to-task-graph-check.js +0 -5
- package/dist/scripts/agent-codex-app-cockpit-check.js +0 -91
- package/dist/scripts/agent-codex-child-overlap-check.js +0 -21
- package/dist/scripts/agent-dynamic-cockpit-check.js +0 -10
- package/dist/scripts/agent-dynamic-pool-check.js +0 -13
- package/dist/scripts/agent-dynamic-pool-route-blackbox.js +0 -5
- package/dist/scripts/agent-fast-mode-default-check.js +0 -62
- package/dist/scripts/agent-fast-mode-worker-propagation-check.js +0 -7
- package/dist/scripts/agent-follow-up-work-schema-check.js +0 -80
- package/dist/scripts/agent-goal-mode-propagation-check.js +0 -9
- package/dist/scripts/agent-intelligent-work-graph-check.js +0 -25
- package/dist/scripts/agent-janitor-check.js +0 -76
- package/dist/scripts/agent-main-no-scout-check.js +0 -11
- package/dist/scripts/agent-model-authored-patch-envelope-check.js +0 -15
- package/dist/scripts/agent-multi-project-isolation-check.js +0 -86
- package/dist/scripts/agent-native-cli-session-proof-check.js +0 -7
- package/dist/scripts/agent-native-cli-session-swarm-10-check.js +0 -7
- package/dist/scripts/agent-native-cli-session-swarm-20-check.js +0 -7
- package/dist/scripts/agent-native-cli-session-swarm-check.js +0 -7
- package/dist/scripts/agent-no-subagent-scaling-check.js +0 -7
- package/dist/scripts/agent-parallel-write-blackbox.js +0 -56
- package/dist/scripts/agent-parallel-write-kernel-check.js +0 -103
- package/dist/scripts/agent-patch-conflict-rebase-check.js +0 -198
- package/dist/scripts/agent-patch-envelope-extraction-check.js +0 -17
- package/dist/scripts/agent-patch-proof-check.js +0 -41
- package/dist/scripts/agent-patch-proof-runtime-check.js +0 -63
- package/dist/scripts/agent-patch-queue-runtime-check.js +0 -36
- package/dist/scripts/agent-patch-rollback-check.js +0 -38
- package/dist/scripts/agent-patch-rollback-dag-check.js +0 -14
- package/dist/scripts/agent-patch-swarm-route-blackbox.js +0 -10
- package/dist/scripts/agent-patch-swarm-runtime-check.js +0 -10
- package/dist/scripts/agent-patch-swarm-runtime-truth-check.js +0 -76
- package/dist/scripts/agent-patch-transaction-journal-check.js +0 -57
- package/dist/scripts/agent-patch-verification-dag-check.js +0 -14
- package/dist/scripts/agent-proof-contract-reconciled-check.js +0 -5
- package/dist/scripts/agent-real-codex-dynamic-smoke-check.js +0 -166
- package/dist/scripts/agent-real-codex-dynamic-smoke-v2-check.js +0 -14
- package/dist/scripts/agent-real-codex-in-zellij-worker-pane-check.js +0 -229
- package/dist/scripts/agent-real-codex-parallel-workers-10-check.js +0 -5
- package/dist/scripts/agent-real-codex-parallel-workers-20-check.js +0 -5
- package/dist/scripts/agent-real-codex-parallel-workers-5-check.js +0 -5
- package/dist/scripts/agent-real-codex-parallel-workers-check.js +0 -5
- package/dist/scripts/agent-role-config-repair-check.js +0 -33
- package/dist/scripts/agent-rollback-command-check.js +0 -86
- package/dist/scripts/agent-route-truth-backfill-check.js +0 -5
- package/dist/scripts/agent-scheduler-proof-check.js +0 -13
- package/dist/scripts/agent-scheduler-proof-hardening-check.js +0 -22
- package/dist/scripts/agent-session-generation-check.js +0 -21
- package/dist/scripts/agent-slot-pane-binding-proof-check.js +0 -64
- package/dist/scripts/agent-source-intelligence-propagation-check.js +0 -9
- package/dist/scripts/agent-strategy-to-lease-wiring-check.js +0 -32
- package/dist/scripts/agent-strategy-to-patch-strict-check.js +0 -54
- package/dist/scripts/agent-task-graph-expansion-check.js +0 -14
- package/dist/scripts/agent-terminal-generations-check.js +0 -23
- package/dist/scripts/agent-visual-consistency-check.js +0 -9
- package/dist/scripts/agent-wiki-context-proof-check.js +0 -62
- package/dist/scripts/agent-worker-backend-router-check.js +0 -63
- package/dist/scripts/agent-worker-scout-limited-check.js +0 -17
- package/dist/scripts/agent-zellij-dynamic-backfill-panes-check.js +0 -34
- package/dist/scripts/agent-zellij-runtime-check.js +0 -84
- package/dist/scripts/all-feature-deep-completion-check.js +0 -31
- package/dist/scripts/appshots-capability-check.js +0 -18
- package/dist/scripts/appshots-evidence-check.js +0 -48
- package/dist/scripts/appshots-operator-policy-check.js +0 -25
- package/dist/scripts/appshots-privacy-safety-check.js +0 -48
- package/dist/scripts/appshots-source-intelligence-check.js +0 -53
- package/dist/scripts/appshots-thread-attachment-discovery-check.js +0 -87
- package/dist/scripts/appshots-triwiki-voxel-check.js +0 -46
- package/dist/scripts/architecture-guard-check.js +0 -55
- package/dist/scripts/changelog-check.js +0 -47
- package/dist/scripts/codex-0-133-official-compat-report.js +0 -53
- package/dist/scripts/codex-0-134-official-compat-report.js +0 -110
- package/dist/scripts/codex-0-134-runner-truth-check.js +0 -66
- package/dist/scripts/codex-0-135-compat-check.js +0 -57
- package/dist/scripts/codex-0-136-compat-check.js +0 -30
- package/dist/scripts/codex-0-137-compat-check.js +0 -27
- package/dist/scripts/codex-app-fast-ui-preservation-check.js +0 -32
- package/dist/scripts/codex-app-provider-badge-check.js +0 -37
- package/dist/scripts/codex-app-ui-clobber-guard-check.js +0 -22
- package/dist/scripts/codex-app-ui-preservation-check.js +0 -96
- package/dist/scripts/codex-control-all-pipelines-check.js +0 -36
- package/dist/scripts/codex-control-capability-check.js +0 -10
- package/dist/scripts/codex-control-empty-result-retry-check.js +0 -43
- package/dist/scripts/codex-control-event-stream-ledger-check.js +0 -10
- package/dist/scripts/codex-control-keepalive-no-cot-leak-check.js +0 -14
- package/dist/scripts/codex-control-no-legacy-fallback-check.js +0 -31
- package/dist/scripts/codex-control-side-effect-scope-check.js +0 -26
- package/dist/scripts/codex-control-stream-idle-watchdog-check.js +0 -18
- package/dist/scripts/codex-control-structured-output-check.js +0 -11
- package/dist/scripts/codex-control-thread-registry-check.js +0 -11
- package/dist/scripts/codex-control-tool-call-sequence-repair-check.js +0 -14
- package/dist/scripts/codex-environment-scoped-approvals-check.js +0 -10
- package/dist/scripts/codex-exec-output-schema-actual-syntax-check.js +0 -33
- package/dist/scripts/codex-fast-mode-profile-propagation-check.js +0 -12
- package/dist/scripts/codex-history-search-check.js +0 -19
- package/dist/scripts/codex-hook-semantic-check.js +0 -15
- package/dist/scripts/codex-hook-strict-subset-check.js +0 -61
- package/dist/scripts/codex-lb-config-toml-safety-check.js +0 -85
- package/dist/scripts/codex-lb-persistence-truth-check.js +0 -96
- package/dist/scripts/codex-lb-setup-fixture-check.js +0 -91
- package/dist/scripts/codex-lb-setup-truthfulness-check.js +0 -84
- package/dist/scripts/codex-legacy-profile-consumers-removed-check.js +0 -24
- package/dist/scripts/codex-managed-proxy-env-check.js +0 -17
- package/dist/scripts/codex-output-schema-fixture-check.js +0 -25
- package/dist/scripts/codex-permission-profiles-check.js +0 -36
- package/dist/scripts/codex-plugin-list-json-check.js +0 -8
- package/dist/scripts/codex-profile-primary-check.js +0 -13
- package/dist/scripts/codex-project-config-policy-splitter-check.js +0 -51
- package/dist/scripts/codex-resume-cwd-truth-check.js +0 -17
- package/dist/scripts/codex-sdk-all-pipelines-check.js +0 -32
- package/dist/scripts/codex-sdk-backend-router-check.js +0 -65
- package/dist/scripts/codex-sdk-capability-check.js +0 -11
- package/dist/scripts/codex-sdk-core-skill-pipeline-check.js +0 -9
- package/dist/scripts/codex-sdk-dfix-pipeline-check.js +0 -9
- package/dist/scripts/codex-sdk-event-stream-ledger-check.js +0 -9
- package/dist/scripts/codex-sdk-no-legacy-fallback-check.js +0 -33
- package/dist/scripts/codex-sdk-qa-pipeline-check.js +0 -8
- package/dist/scripts/codex-sdk-real-smoke-check.js +0 -39
- package/dist/scripts/codex-sdk-release-review-pipeline-check.js +0 -13
- package/dist/scripts/codex-sdk-research-pipeline-check.js +0 -15
- package/dist/scripts/codex-sdk-sandbox-policy-check.js +0 -21
- package/dist/scripts/codex-sdk-structured-output-check.js +0 -10
- package/dist/scripts/codex-sdk-team-naruto-agent-pipeline-check.js +0 -12
- package/dist/scripts/codex-sdk-thread-registry-check.js +0 -11
- package/dist/scripts/codex-sdk-ux-ppt-review-pipeline-check.js +0 -9
- package/dist/scripts/codex-sdk-zellij-pane-binding-check.js +0 -13
- package/dist/scripts/codex-thread-runtime-choice-check.js +0 -10
- package/dist/scripts/codex-web-adapter-check.js +0 -12
- package/dist/scripts/computer-use-live-evidence-check.js +0 -55
- package/dist/scripts/computer-use-live-optional-check.js +0 -32
- package/dist/scripts/computer-use-policy-check.js +0 -69
- package/dist/scripts/computer-use-visual-route-fixture-check.js +0 -37
- package/dist/scripts/core-skill-card-schema-check.js +0 -61
- package/dist/scripts/core-skill-deployment-snapshot-check.js +0 -54
- package/dist/scripts/core-skill-heldout-validation-check.js +0 -49
- package/dist/scripts/core-skill-no-inference-optimizer-check.js +0 -75
- package/dist/scripts/core-skill-patch-check.js +0 -79
- package/dist/scripts/core-skill-promotion-side-effect-ledger-check.js +0 -64
- package/dist/scripts/core-skill-rollout-scoring-check.js +0 -72
- package/dist/scripts/core-skill-route-runtime-integration-check.js +0 -49
- package/dist/scripts/dfix-fast-blackbox-check.js +0 -37
- package/dist/scripts/dfix-fast-kernel-check.js +0 -26
- package/dist/scripts/dfix-fixture-check.js +0 -6
- package/dist/scripts/dfix-parallel-write-blackbox.js +0 -48
- package/dist/scripts/dfix-patch-handoff-check.js +0 -13
- package/dist/scripts/dfix-patch-swarm-route-blackbox.js +0 -10
- package/dist/scripts/dfix-performance-check.js +0 -15
- package/dist/scripts/dfix-verification-check.js +0 -9
- package/dist/scripts/dfix-verification-recommendation-check.js +0 -15
- package/dist/scripts/docs-truthfulness-check.js +0 -61
- package/dist/scripts/doctor-codex-doctor-parity-check.js +0 -17
- package/dist/scripts/doctor-fix-proves-codex-read-check.js +0 -64
- package/dist/scripts/doctor-fix-recovers-corrupted-config-check.js +0 -122
- package/dist/scripts/doctor-fixes-codex-app-fast-ui-check.js +0 -39
- package/dist/scripts/evidence-fixture-check.js +0 -26
- package/dist/scripts/evidence-flagship-coverage-check.js +0 -55
- package/dist/scripts/fake-real-proof-policy-v2-check.js +0 -27
- package/dist/scripts/fake-vs-real-proof-policy-check.js +0 -14
- package/dist/scripts/fast-codex-service-tier-proof-check.js +0 -42
- package/dist/scripts/flagship-proof-graph-v2-check.js +0 -48
- package/dist/scripts/flagship-proof-graph-v3-check.js +0 -67
- package/dist/scripts/flagship-proof-graph-v4-check.js +0 -61
- package/dist/scripts/git-precommit-fixture-check.js +0 -41
- package/dist/scripts/git-worktree-cache-performance-check.js +0 -25
- package/dist/scripts/git-worktree-capability-check.js +0 -27
- package/dist/scripts/git-worktree-checkpoint-check.js +0 -20
- package/dist/scripts/git-worktree-cleanup-check.js +0 -27
- package/dist/scripts/git-worktree-cross-rebase-check.js +0 -39
- package/dist/scripts/git-worktree-diff-envelope-check.js +0 -17
- package/dist/scripts/git-worktree-diff-export-check.js +0 -43
- package/dist/scripts/git-worktree-dirty-lock-check.js +0 -17
- package/dist/scripts/git-worktree-dirty-main-detection-check.js +0 -14
- package/dist/scripts/git-worktree-integration-primary-check.js +0 -24
- package/dist/scripts/git-worktree-integration-primary-runtime-check.js +0 -20
- package/dist/scripts/git-worktree-manager-check.js +0 -37
- package/dist/scripts/git-worktree-manifest-append-check.js +0 -18
- package/dist/scripts/git-worktree-merge-queue-check.js +0 -31
- package/dist/scripts/git-worktree-pool-performance-check.js +0 -20
- package/dist/scripts/git-worktree-untracked-diff-check.js +0 -18
- package/dist/scripts/goal-mode-official-default-check.js +0 -12
- package/dist/scripts/gpt-final-arbiter-check.js +0 -63
- package/dist/scripts/gpt-final-arbiter-performance-check.js +0 -36
- package/dist/scripts/gpt-image-2-request-validator-check.js +0 -35
- package/dist/scripts/hooks-0.134-context-parity-check.js +0 -20
- package/dist/scripts/hooks-actual-parity-check.js +0 -17
- package/dist/scripts/hooks-actual-parity-v2-check.js +0 -21
- package/dist/scripts/hooks-latest-schema-check.js +0 -20
- package/dist/scripts/hooks-managed-install-fixture-check.js +0 -21
- package/dist/scripts/hooks-official-hash-oracle-check.js +0 -35
- package/dist/scripts/hooks-official-hash-parity-check.js +0 -17
- package/dist/scripts/hooks-subagent-events-check.js +0 -17
- package/dist/scripts/hooks-trust-state-check.js +0 -14
- package/dist/scripts/image-fidelity-fixture-check.js +0 -24
- package/dist/scripts/imagegen-capability-check.js +0 -30
- package/dist/scripts/imagegen-real-smoke-check.js +0 -155
- package/dist/scripts/install-update-preserves-config-check.js +0 -87
- package/dist/scripts/json-schema-recursive-check.js +0 -78
- package/dist/scripts/legacy-multiagent-removal-check.js +0 -85
- package/dist/scripts/legacy-upgrade-matrix-check.js +0 -300
- package/dist/scripts/local-collab-all-pipelines-final-gpt-check.js +0 -21
- package/dist/scripts/local-collab-gpt-final-availability-check.js +0 -58
- package/dist/scripts/local-collab-no-local-only-final-check.js +0 -27
- package/dist/scripts/local-collab-policy-check.js +0 -17
- package/dist/scripts/local-collab-worktree-gpt-final-apply-policy-check.js +0 -63
- package/dist/scripts/local-llm-all-pipelines-check.js +0 -11
- package/dist/scripts/local-llm-cache-performance-check.js +0 -10
- package/dist/scripts/local-llm-capability-check.js +0 -14
- package/dist/scripts/local-llm-smoke-check.js +0 -23
- package/dist/scripts/local-llm-structured-output-check.js +0 -11
- package/dist/scripts/local-llm-throughput-check.js +0 -10
- package/dist/scripts/local-llm-tool-call-repair-check.js +0 -10
- package/dist/scripts/local-llm-warmup-check.js +0 -11
- package/dist/scripts/loop-blocker-check.js +0 -15
- package/dist/scripts/mad-preflight-blocks-unreadable-config-check.js +0 -35
- package/dist/scripts/mad-sks-actual-executor-blackbox.js +0 -5
- package/dist/scripts/mad-sks-app-ui-no-mutation-check.js +0 -92
- package/dist/scripts/mad-sks-audit-proof-check.js +0 -34
- package/dist/scripts/mad-sks-db-executor-check.js +0 -5
- package/dist/scripts/mad-sks-executor-proof-graph-check.js +0 -5
- package/dist/scripts/mad-sks-fast-mode-propagation-check.js +0 -24
- package/dist/scripts/mad-sks-file-write-executor-check.js +0 -5
- package/dist/scripts/mad-sks-immutable-harness-check.js +0 -36
- package/dist/scripts/mad-sks-no-harness-modification-check.js +0 -25
- package/dist/scripts/mad-sks-package-executor-check.js +0 -5
- package/dist/scripts/mad-sks-permission-model-check.js +0 -22
- package/dist/scripts/mad-sks-rollback-apply-check.js +0 -5
- package/dist/scripts/mad-sks-service-executor-check.js +0 -5
- package/dist/scripts/mad-sks-shell-executor-check.js +0 -5
- package/dist/scripts/mad-sks-write-guard-check.js +0 -28
- package/dist/scripts/mad-sks-zellij-default-pane-worker-check.js +0 -37
- package/dist/scripts/mad-sks-zellij-launch-check.js +0 -102
- package/dist/scripts/mcp-0-134-modernization-check.js +0 -55
- package/dist/scripts/mcp-readonly-concurrency-check.js +0 -17
- package/dist/scripts/mcp-readonly-runtime-scheduler-check.js +0 -20
- package/dist/scripts/mcp-tool-naming-parity-check.js +0 -16
- package/dist/scripts/memory-summary-rebuild-check.js +0 -22
- package/dist/scripts/mutation-callsite-coverage-check.js +0 -180
- package/dist/scripts/naruto-active-pool-check.js +0 -39
- package/dist/scripts/naruto-actual-worker-control-plane-check.js +0 -56
- package/dist/scripts/naruto-allocation-policy-check.js +0 -33
- package/dist/scripts/naruto-allocation-runtime-wiring-check.js +0 -92
- package/dist/scripts/naruto-concurrency-governor-check.js +0 -53
- package/dist/scripts/naruto-extreme-parallelism-check.js +0 -22
- package/dist/scripts/naruto-extreme-parallelism-real-check.js +0 -43
- package/dist/scripts/naruto-gpt-final-pack-check.js +0 -34
- package/dist/scripts/naruto-orchestrator-runtime-source-check.js +0 -70
- package/dist/scripts/naruto-parallel-patch-apply-check.js +0 -41
- package/dist/scripts/naruto-readonly-routing-check.js +0 -116
- package/dist/scripts/naruto-real-active-pool-check.js +0 -39
- package/dist/scripts/naruto-real-active-pool-runtime-check.js +0 -55
- package/dist/scripts/naruto-rebalance-policy-check.js +0 -41
- package/dist/scripts/naruto-role-distribution-check.js +0 -23
- package/dist/scripts/naruto-shadow-clone-swarm-check.js +0 -153
- package/dist/scripts/naruto-verification-pool-check.js +0 -36
- package/dist/scripts/naruto-work-graph-check.js +0 -24
- package/dist/scripts/naruto-worktree-coding-blackbox.js +0 -29
- package/dist/scripts/naruto-worktree-coding-check.js +0 -44
- package/dist/scripts/naruto-worktree-gpt-final-check.js +0 -45
- package/dist/scripts/naruto-worktree-zellij-ui-check.js +0 -28
- package/dist/scripts/naruto-zellij-dynamic-right-column-check.js +0 -48
- package/dist/scripts/naruto-zellij-massive-ui-check.js +0 -23
- package/dist/scripts/non-recursive-pipeline-check.js +0 -68
- package/dist/scripts/npm-publish-performance-check.js +0 -65
- package/dist/scripts/official-docs-compat-report.js +0 -304
- package/dist/scripts/packlist-performance-check.js +0 -83
- package/dist/scripts/parallel-verification-engine-check.js +0 -85
- package/dist/scripts/postinstall-safe-side-effects-check.js +0 -65
- package/dist/scripts/ppt-full-e2e-artifact-graph-check.js +0 -40
- package/dist/scripts/ppt-full-e2e-blackbox-check.js +0 -109
- package/dist/scripts/ppt-image-voxel-relations-check.js +0 -9
- package/dist/scripts/ppt-imagegen-blackbox-check.js +0 -46
- package/dist/scripts/ppt-imagegen-review-fixture-check.js +0 -6
- package/dist/scripts/ppt-issue-extraction-fixture-check.js +0 -7
- package/dist/scripts/ppt-no-mock-as-real-check.js +0 -8
- package/dist/scripts/ppt-no-text-fallback-check.js +0 -7
- package/dist/scripts/ppt-proof-trust-fixture-check.js +0 -10
- package/dist/scripts/ppt-real-export-adapter-check.js +0 -13
- package/dist/scripts/ppt-real-imagegen-smoke-check.js +0 -42
- package/dist/scripts/ppt-real-imagegen-wiring-check.js +0 -16
- package/dist/scripts/ppt-reexport-rereview-check.js +0 -19
- package/dist/scripts/ppt-slide-export-fixture-check.js +0 -7
- package/dist/scripts/prepublish-fast-check.js +0 -128
- package/dist/scripts/priority-full-closure-check.js +0 -12
- package/dist/scripts/product-design-auto-install-check.js +0 -119
- package/dist/scripts/product-design-plugin-routing-check.js +0 -101
- package/dist/scripts/prompt-placeholder-guard-check.js +0 -33
- package/dist/scripts/provider-badge-context-check.js +0 -26
- package/dist/scripts/provider-context-config-toml-check.js +0 -63
- package/dist/scripts/python-codex-sdk-all-pipelines-check.js +0 -47
- package/dist/scripts/python-codex-sdk-capability-check.js +0 -75
- package/dist/scripts/python-codex-sdk-sandbox-policy-check.js +0 -10
- package/dist/scripts/python-codex-sdk-stream-bridge-check.js +0 -12
- package/dist/scripts/python-tools-smoke-check.js +0 -71
- package/dist/scripts/qa-actual-route-backfill-check.js +0 -5
- package/dist/scripts/qa-backfill-route-blackbox.js +0 -5
- package/dist/scripts/qa-patch-swarm-route-blackbox.js +0 -10
- package/dist/scripts/readme-architecture-imagegen-official-check.js +0 -448
- package/dist/scripts/release-cache-glob-hashing-check.js +0 -42
- package/dist/scripts/release-dag-full-coverage-check.js +0 -53
- package/dist/scripts/release-dist-freshness-check.js +0 -8
- package/dist/scripts/release-dynamic-performance-check.js +0 -103
- package/dist/scripts/release-gate-budget-check.js +0 -36
- package/dist/scripts/release-gate-dag-runner-check.js +0 -17
- package/dist/scripts/release-metadata-1-11-check.js +0 -37
- package/dist/scripts/release-metadata-1-12-check.js +0 -48
- package/dist/scripts/release-metadata-1-13-check.js +0 -53
- package/dist/scripts/release-metadata-1-14-check.js +0 -63
- package/dist/scripts/release-metadata-1-16-check.js +0 -81
- package/dist/scripts/release-metadata-1-17-check.js +0 -51
- package/dist/scripts/release-metadata-1-19-check.js +0 -371
- package/dist/scripts/release-metadata-check.js +0 -7
- package/dist/scripts/release-native-agent-fixture-check.js +0 -41
- package/dist/scripts/release-parallel-check.js +0 -374
- package/dist/scripts/release-parallel-full-coverage-check.js +0 -13
- package/dist/scripts/release-parallel-speed-budget-check.js +0 -79
- package/dist/scripts/release-provenance-check.js +0 -150
- package/dist/scripts/release-readiness-report.js +0 -1146
- package/dist/scripts/release-real-check.js +0 -330
- package/dist/scripts/release-registry-check.js +0 -344
- package/dist/scripts/release-runtime-truth-matrix-check.js +0 -47
- package/dist/scripts/release-stability-report-check.js +0 -99
- package/dist/scripts/release-version-truth-check.js +0 -134
- package/dist/scripts/research-actual-route-backfill-check.js +0 -5
- package/dist/scripts/research-backfill-route-blackbox.js +0 -5
- package/dist/scripts/research-quality-gate-check.js +0 -86
- package/dist/scripts/responses-retry-policy-centralized-check.js +0 -19
- package/dist/scripts/retention-cleanup-safety-check.js +0 -155
- package/dist/scripts/route-blackbox-realism-check.js +0 -21
- package/dist/scripts/route-proof-artifact-structure-check.js +0 -145
- package/dist/scripts/runtime-dist-parity-check.js +0 -78
- package/dist/scripts/runtime-no-mjs-scripts-check.js +0 -45
- package/dist/scripts/runtime-no-src-mjs-check.js +0 -32
- package/dist/scripts/runtime-no-tmux-check.js +0 -113
- package/dist/scripts/runtime-ts-python-boundary-check.js +0 -59
- package/dist/scripts/runtime-ts-rust-boundary-check.js +0 -74
- package/dist/scripts/runtime-ts-source-of-truth-check.js +0 -55
- package/dist/scripts/safety-check.js +0 -23
- package/dist/scripts/shared-memory-fixture-check.js +0 -27
- package/dist/scripts/side-effect-runtime-report-check.js +0 -19
- package/dist/scripts/side-effect-zero-gate-check.js +0 -226
- package/dist/scripts/sks-1-11-fixture-check.js +0 -130
- package/dist/scripts/source-intelligence-all-modes-check.js +0 -32
- package/dist/scripts/source-intelligence-policy-check.js +0 -13
- package/dist/scripts/strategy-adhd-orchestrating-gate-check.js +0 -22
- package/dist/scripts/strategy-file-ownership-plan-check.js +0 -18
- package/dist/scripts/strategy-parallel-modification-plan-check.js +0 -19
- package/dist/scripts/strategy-verification-rollback-dag-check.js +0 -19
- package/dist/scripts/team-actual-route-backfill-check.js +0 -5
- package/dist/scripts/team-backfill-route-blackbox.js +0 -5
- package/dist/scripts/team-parallel-write-blackbox.js +0 -55
- package/dist/scripts/team-patch-swarm-route-blackbox.js +0 -10
- package/dist/scripts/terminal-keyboard-enhancement-safety-check.js +0 -12
- package/dist/scripts/terminal-tui-output-stability-check.js +0 -35
- package/dist/scripts/test-no-orphan-dist-imports-check.js +0 -73
- package/dist/scripts/trust-fixture-check.js +0 -33
- package/dist/scripts/typescript-migration-report.js +0 -78
- package/dist/scripts/ultra-router-auto-router-check.js +0 -33
- package/dist/scripts/ultra-router-classification-check.js +0 -28
- package/dist/scripts/ux-patch-swarm-route-blackbox.js +0 -10
- package/dist/scripts/ux-ppt-structured-extraction-check.js +0 -21
- package/dist/scripts/ux-review-extract-real-callouts-fixture-check.js +0 -8
- package/dist/scripts/ux-review-extract-wires-real-extractor-check.js +0 -15
- package/dist/scripts/ux-review-generate-callouts-fixture-check.js +0 -9
- package/dist/scripts/ux-review-image-voxel-relations-check.js +0 -31
- package/dist/scripts/ux-review-imagegen-blackbox-check.js +0 -67
- package/dist/scripts/ux-review-no-fake-callouts-check.js +0 -8
- package/dist/scripts/ux-review-no-text-fallback-check.js +0 -25
- package/dist/scripts/ux-review-patch-diff-recheck-check.js +0 -20
- package/dist/scripts/ux-review-patch-handoff-fixture-check.js +0 -8
- package/dist/scripts/ux-review-real-imagegen-smoke-check.js +0 -31
- package/dist/scripts/ux-review-real-loop-fixture-check.js +0 -24
- package/dist/scripts/ux-review-recapture-recheck-fixture-check.js +0 -8
- package/dist/scripts/ux-review-run-wires-imagegen-check.js +0 -11
- package/dist/scripts/worker-pane-communication-contract-check.js +0 -54
- package/dist/scripts/wrongness-fixture-check.js +0 -65
- package/dist/scripts/xai-mcp-capability-check.js +0 -14
- package/dist/scripts/zellij-capability-check.js +0 -15
- package/dist/scripts/zellij-dashboard-pane-check.js +0 -70
- package/dist/scripts/zellij-developer-controls-check.js +0 -20
- package/dist/scripts/zellij-doctor-readiness-check.js +0 -63
- package/dist/scripts/zellij-dynamic-pane-lifecycle-check.js +0 -21
- package/dist/scripts/zellij-first-slot-down-stack-check.js +0 -20
- package/dist/scripts/zellij-first-slot-down-stack-real-check.js +0 -356
- package/dist/scripts/zellij-initial-main-only-blackbox.js +0 -28
- package/dist/scripts/zellij-lane-renderer-check.js +0 -65
- package/dist/scripts/zellij-launch-command-truth-check.js +0 -75
- package/dist/scripts/zellij-layout-valid-check.js +0 -90
- package/dist/scripts/zellij-pane-proof-check.js +0 -59
- package/dist/scripts/zellij-real-session-cleanup-check.js +0 -21
- package/dist/scripts/zellij-real-session-heartbeat-check.js +0 -49
- package/dist/scripts/zellij-real-session-launch-check.js +0 -57
- package/dist/scripts/zellij-right-column-headless-overflow-check.js +0 -22
- package/dist/scripts/zellij-right-column-manager-check.js +0 -27
- package/dist/scripts/zellij-screen-proof-check.js +0 -45
- package/dist/scripts/zellij-slot-column-anchor-check.js +0 -66
- package/dist/scripts/zellij-slot-only-ui-check.js +0 -26
- package/dist/scripts/zellij-slot-pane-renderer-check.js +0 -106
- package/dist/scripts/zellij-slot-renderer-proof-semantics-check.js +0 -59
- package/dist/scripts/zellij-spawn-on-demand-layout-check.js +0 -40
- package/dist/scripts/zellij-ui-design-check.js +0 -105
- package/dist/scripts/zellij-worker-pane-manager-check.js +0 -109
- package/dist/scripts/zellij-worker-pane-manager-single-owner-check.js +0 -47
- package/dist/scripts/zellij-worker-pane-real-ui-blackbox.js +0 -202
- package/dist/scripts/zellij-worker-pane-spawn-order-check.js +0 -35
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/permission-request.command.input.schema.json +0 -61
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/permission-request.command.output.schema.json +0 -103
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/post-compact.command.input.schema.json +0 -52
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/post-compact.command.output.schema.json +0 -24
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/post-tool-use.command.input.schema.json +0 -67
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/post-tool-use.command.output.schema.json +0 -84
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/pre-compact.command.input.schema.json +0 -52
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/pre-compact.command.output.schema.json +0 -24
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/pre-tool-use.command.input.schema.json +0 -65
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/pre-tool-use.command.output.schema.json +0 -105
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/session-start.command.input.schema.json +0 -59
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/session-start.command.output.schema.json +0 -63
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/snapshot-metadata.json +0 -31
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/stop.command.input.schema.json +0 -63
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/stop.command.output.schema.json +0 -45
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/user-prompt-submit.command.input.schema.json +0 -59
- package/dist/vendor/openai-codex/rust-v0.131.0/hooks/user-prompt-submit.command.output.schema.json +0 -81
|
@@ -1,23 +0,0 @@
|
|
|
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 { assertGate, emitGate, importDist } from './sks-1-18-gate-lib.js';
|
|
7
|
-
const mod = await importDist('core/agents/agent-terminal-session.js');
|
|
8
|
-
const root = await fs.mkdtemp(path.join(os.tmpdir(), 'sks-terminal-generations-'));
|
|
9
|
-
await fs.mkdir(path.join(root, 'sessions'), { recursive: true });
|
|
10
|
-
await fs.writeFile(path.join(root, 'agent-events.jsonl'), '');
|
|
11
|
-
const sessions = {};
|
|
12
|
-
for (const generationIndex of [1, 2]) {
|
|
13
|
-
const agent = { id: 'slot-001', slot_id: 'slot-001', generation_index: generationIndex, session_id: `agent_slot-001-gen_${generationIndex}`, session_artifact_dir: path.join('sessions', 'slot-001', `gen-${generationIndex}`) };
|
|
14
|
-
sessions[agent.session_id] = { agent_id: agent.id, slot_id: agent.slot_id, generation_index: generationIndex, session_id: agent.session_id, status: 'closed', session_artifact_dir: agent.session_artifact_dir };
|
|
15
|
-
await mod.startAgentTerminalSession(root, agent, { backend: 'fake', real: false });
|
|
16
|
-
await mod.closeAgentTerminalSession(root, agent, { exitCode: 0, status: 'done' });
|
|
17
|
-
}
|
|
18
|
-
await fs.writeFile(path.join(root, 'agent-sessions.json'), JSON.stringify({ schema: 'sks.agent-sessions.v1', sessions }, null, 2));
|
|
19
|
-
const closed = await mod.assertAgentTerminalSessionsClosed(root);
|
|
20
|
-
assertGate(closed.ok === true, 'terminal close reports must exist for every generation', closed);
|
|
21
|
-
assertGate(closed.total_sessions === 2, 'terminal generation count must be 2', closed);
|
|
22
|
-
emitGate('agent:terminal-generations', { terminal_generation_count: closed.total_sessions });
|
|
23
|
-
//# sourceMappingURL=agent-terminal-generations-check.js.map
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
// @ts-nocheck
|
|
3
|
-
import { assertGate, emitGate, readText } from './sks-1-18-gate-lib.js';
|
|
4
|
-
const cockpit = readText('src/core/agents/agent-codex-cockpit.ts');
|
|
5
|
-
for (const token of ['source_intelligence_status', 'xai_status', 'codex_web_search_status', 'goal_mode_status', 'terminal_session_status', 'zellij_attach_command']) {
|
|
6
|
-
assertGate(cockpit.includes(token), `Codex App cockpit missing ${token}`);
|
|
7
|
-
}
|
|
8
|
-
emitGate('agent:visual-consistency', { dashboard_fields: 6 });
|
|
9
|
-
//# sourceMappingURL=agent-visual-consistency-check.js.map
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
// @ts-nocheck
|
|
3
|
-
// Gate: agent:wiki-context-proof
|
|
4
|
-
// Proves the native agent kernel consults the TriWiki context pack (read-only) and
|
|
5
|
-
// references it in proof: (1) the read-only pack loader behaves correctly with and
|
|
6
|
-
// without a pack, (2) the orchestrator wires loadTriWikiRuntimeContext + writes the
|
|
7
|
-
// artifact + passes it to proof, (3) agent-proof-evidence records the wiki proof fields.
|
|
8
|
-
import fs from 'node:fs';
|
|
9
|
-
import os from 'node:os';
|
|
10
|
-
import path from 'node:path';
|
|
11
|
-
import { assertGate, emitGate, importDist, readText, root } from './sks-1-18-gate-lib.js';
|
|
12
|
-
const triwiki = await importDist('core/triwiki-runtime.js');
|
|
13
|
-
const { loadTriWikiRuntimeContext, triWikiProofRecord, writeTriWikiContextArtifact } = triwiki;
|
|
14
|
-
// 1) Absent pack -> graceful fallback (present:false, warning, not consulted).
|
|
15
|
-
const emptyRoot = fs.mkdtempSync(path.join(os.tmpdir(), 'sks-triwiki-empty-'));
|
|
16
|
-
const emptyCtx = await loadTriWikiRuntimeContext(emptyRoot);
|
|
17
|
-
assertGate(emptyCtx.present === false, 'absent pack must yield present:false', { ctx: emptyCtx });
|
|
18
|
-
assertGate(typeof emptyCtx.warning === 'string' && emptyCtx.warning.length > 0, 'absent pack must carry a warning');
|
|
19
|
-
assertGate(emptyCtx.context_pack_hash === null && emptyCtx.use_first.length === 0, 'absent pack must have null hash + no use_first');
|
|
20
|
-
assertGate(triWikiProofRecord(emptyCtx).triwiki_context_consulted === false, 'absent pack proof must report not consulted');
|
|
21
|
-
// 2) Present pack -> consulted with hash + attention rows.
|
|
22
|
-
const packRoot = fs.mkdtempSync(path.join(os.tmpdir(), 'sks-triwiki-pack-'));
|
|
23
|
-
const packDir = path.join(packRoot, '.sneakoscope', 'wiki');
|
|
24
|
-
fs.mkdirSync(packDir, { recursive: true });
|
|
25
|
-
const pack = {
|
|
26
|
-
mission: 'project-wiki',
|
|
27
|
-
attention: { mode: 'aggressive_triwiki_active_recall', use_first: [['claim-a', [48, 132, 212, 240], 'h1']], hydrate_first: [['claim-b', 'risk:high']] },
|
|
28
|
-
wiki: { a: [['claim-a'], ['claim-b']] },
|
|
29
|
-
claims: [{ id: 'claim-a' }, { id: 'claim-b' }],
|
|
30
|
-
trust_summary: { avg: 0.71 }
|
|
31
|
-
};
|
|
32
|
-
fs.writeFileSync(path.join(packDir, 'context-pack.json'), `${JSON.stringify(pack, null, 2)}\n`);
|
|
33
|
-
const ctx = await loadTriWikiRuntimeContext(packRoot);
|
|
34
|
-
assertGate(ctx.present === true, 'present pack must yield present:true', { ctx });
|
|
35
|
-
assertGate(typeof ctx.context_pack_hash === 'string' && /^[0-9a-f]{64}$/.test(ctx.context_pack_hash), 'present pack must carry a sha256 hash', { hash: ctx.context_pack_hash });
|
|
36
|
-
assertGate(ctx.mission === 'project-wiki', 'pack mission must be read', { mission: ctx.mission });
|
|
37
|
-
assertGate(ctx.use_first.length === 1 && ctx.hydrate_first.length === 1, 'attention rows must be surfaced', { use: ctx.use_first.length, hyd: ctx.hydrate_first.length });
|
|
38
|
-
assertGate(ctx.claim_count === 2 && ctx.anchor_count === 2, 'claim/anchor counts must be read', { claims: ctx.claim_count, anchors: ctx.anchor_count });
|
|
39
|
-
const proof = triWikiProofRecord(ctx);
|
|
40
|
-
assertGate(proof.triwiki_context_consulted === true && proof.context_pack_hash === ctx.context_pack_hash, 'present pack proof must report consulted + hash');
|
|
41
|
-
// 3) Artifact write.
|
|
42
|
-
const ledger = fs.mkdtempSync(path.join(os.tmpdir(), 'sks-triwiki-ledger-'));
|
|
43
|
-
const artifactPath = await writeTriWikiContextArtifact(ledger, ctx);
|
|
44
|
-
assertGate(fs.existsSync(artifactPath), 'context artifact must be written');
|
|
45
|
-
const artifact = JSON.parse(fs.readFileSync(artifactPath, 'utf8'));
|
|
46
|
-
assertGate(artifact.proof?.triwiki_context_consulted === true, 'artifact must embed proof record');
|
|
47
|
-
// 4) Kernel + proof wiring (source-level so the consult cannot be silently removed).
|
|
48
|
-
const orchestrator = readText('src/core/agents/agent-orchestrator.ts');
|
|
49
|
-
assertGate(orchestrator.includes('loadTriWikiRuntimeContext') && orchestrator.includes('writeTriWikiContextArtifact') && orchestrator.includes('triwikiContext'), 'orchestrator must consult TriWiki + write artifact + pass to proof');
|
|
50
|
-
const proofSrc = readText('src/core/agents/agent-proof-evidence.ts');
|
|
51
|
-
assertGate(proofSrc.includes('triwiki_context_consulted') && proofSrc.includes('context_pack_hash') && proofSrc.includes("triwiki_context: 'agent-triwiki-context.json'"), 'agent-proof-evidence must record the TriWiki proof fields');
|
|
52
|
-
for (const dir of [emptyRoot, packRoot, ledger]) {
|
|
53
|
-
try {
|
|
54
|
-
fs.rmSync(dir, { recursive: true, force: true });
|
|
55
|
-
}
|
|
56
|
-
catch { /* best-effort */ }
|
|
57
|
-
}
|
|
58
|
-
const reportDir = path.join(root, '.sneakoscope', 'reports');
|
|
59
|
-
fs.mkdirSync(reportDir, { recursive: true });
|
|
60
|
-
fs.writeFileSync(path.join(reportDir, 'agent-wiki-context-proof.json'), `${JSON.stringify({ schema: 'sks.agent-wiki-context-proof.v1', ok: true, present_pack_hash: ctx.context_pack_hash, use_first: ctx.use_first.length, hydrate_first: ctx.hydrate_first.length }, null, 2)}\n`);
|
|
61
|
-
emitGate('agent:wiki-context-proof', { kernel_consults_triwiki: true, proof_records_hash: true });
|
|
62
|
-
//# sourceMappingURL=agent-wiki-context-proof-check.js.map
|
|
@@ -1,63 +0,0 @@
|
|
|
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 { assertGate, emitGate, importDist, root as repoRoot } from './sks-1-18-gate-lib.js';
|
|
7
|
-
const mod = await importDist('core/agents/native-cli-worker.js');
|
|
8
|
-
const root = await fs.mkdtemp(path.join(os.tmpdir(), 'sks-worker-router-'));
|
|
9
|
-
const old = snapshotEnv();
|
|
10
|
-
process.env.SKS_DISABLE_ROUTE_RECURSION = '1';
|
|
11
|
-
process.env.SKS_AGENT_WORKER = '1';
|
|
12
|
-
process.env.SKS_FAST_MODE = '1';
|
|
13
|
-
process.env.SKS_SERVICE_TIER = 'fast';
|
|
14
|
-
try {
|
|
15
|
-
const result = await mod.runNativeCliWorker({
|
|
16
|
-
intakeJson: {
|
|
17
|
-
mission_id: 'M-router-check',
|
|
18
|
-
parent_mission_id: 'M-router-check',
|
|
19
|
-
route: '$Agent',
|
|
20
|
-
backend: 'process',
|
|
21
|
-
agent_root: root,
|
|
22
|
-
agent: { id: 'router-agent', session_id: 'router-session', slot_id: 'slot-001', generation_index: 1, persona_id: 'executor' },
|
|
23
|
-
slice: { id: 'router-task', write_paths: ['router-output.txt'], description: 'exercise real process child backend' },
|
|
24
|
-
worker_artifact_dir: 'sessions/slot-001/gen-1/worker',
|
|
25
|
-
result_path: 'sessions/slot-001/gen-1/worker/worker-result.json',
|
|
26
|
-
heartbeat_path: 'sessions/slot-001/gen-1/worker/worker-heartbeat.jsonl',
|
|
27
|
-
patch_envelope_path: 'sessions/slot-001/gen-1/worker/worker-patch-envelope.json',
|
|
28
|
-
fast_mode: true,
|
|
29
|
-
service_tier: 'fast'
|
|
30
|
-
}
|
|
31
|
-
});
|
|
32
|
-
const workerDir = path.join(root, 'sessions', 'slot-001', 'gen-1', 'worker');
|
|
33
|
-
const router = JSON.parse(await fs.readFile(path.join(workerDir, 'worker-backend-router-report.json'), 'utf8'));
|
|
34
|
-
const patch = JSON.parse(await fs.readFile(path.join(workerDir, 'worker-patch-envelope.json'), 'utf8'));
|
|
35
|
-
assertGate(result.status === 'done', 'process backend worker result must be done', result);
|
|
36
|
-
assertGate(router.selected_backend === 'process', 'router selected backend mismatch', router);
|
|
37
|
-
assertGate(router.child_process_ids.length === 1, 'router must record child process id', router);
|
|
38
|
-
assertGate(patch.envelopes[0].source === 'process_generated', 'process backend patch envelope source missing', patch);
|
|
39
|
-
assertGate(result.backend_router_report?.proof_level === 'process_child_proven', 'router proof level must show process child', result.backend_router_report);
|
|
40
|
-
await fs.mkdir(path.join(repoRoot, '.sneakoscope', 'reports'), { recursive: true });
|
|
41
|
-
await fs.writeFile(path.join(repoRoot, '.sneakoscope', 'reports', 'agent-worker-backend-router.json'), `${JSON.stringify({ ok: true, router, patch_source: patch.envelopes[0].source }, null, 2)}\n`);
|
|
42
|
-
emitGate('agent:worker-backend-router', { backend: router.selected_backend, child_process_ids: router.child_process_ids.length, patch_source: patch.envelopes[0].source });
|
|
43
|
-
}
|
|
44
|
-
finally {
|
|
45
|
-
restoreEnv(old);
|
|
46
|
-
}
|
|
47
|
-
function snapshotEnv() {
|
|
48
|
-
return {
|
|
49
|
-
SKS_DISABLE_ROUTE_RECURSION: process.env.SKS_DISABLE_ROUTE_RECURSION,
|
|
50
|
-
SKS_AGENT_WORKER: process.env.SKS_AGENT_WORKER,
|
|
51
|
-
SKS_FAST_MODE: process.env.SKS_FAST_MODE,
|
|
52
|
-
SKS_SERVICE_TIER: process.env.SKS_SERVICE_TIER
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
function restoreEnv(old) {
|
|
56
|
-
for (const [key, value] of Object.entries(old)) {
|
|
57
|
-
if (value === undefined)
|
|
58
|
-
delete process.env[key];
|
|
59
|
-
else
|
|
60
|
-
process.env[key] = value;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
//# sourceMappingURL=agent-worker-backend-router-check.js.map
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
// @ts-nocheck
|
|
3
|
-
import path from 'node:path';
|
|
4
|
-
import { assertGate, emitGate, importDist, root } from './sks-1-18-gate-lib.js';
|
|
5
|
-
const mod = await importDist('core/agents/scout-policy.js');
|
|
6
|
-
const local = mod.validateWorkerScoutEvidence(path.join(root, '.sneakoscope/missions/fixture/agents'), {
|
|
7
|
-
agent_id: 'agent_1',
|
|
8
|
-
artifact_path: 'sessions/agent_1/worker-scout/evidence.json'
|
|
9
|
-
});
|
|
10
|
-
const global = mod.validateWorkerScoutEvidence(path.join(root, '.sneakoscope/missions/fixture/agents'), {
|
|
11
|
-
agent_id: 'agent_1',
|
|
12
|
-
artifact_path: '../scout-ledger.json'
|
|
13
|
-
});
|
|
14
|
-
assertGate(local.ok === true && local.central_proof_ssot === false, 'worker Scout local evidence must be accepted only as local evidence', local);
|
|
15
|
-
assertGate(global.ok === false, 'worker Scout global artifact must be blocked', global);
|
|
16
|
-
emitGate('agent:worker-scout-limited', { local_ok: local.ok, global_ok: global.ok });
|
|
17
|
-
//# sourceMappingURL=agent-worker-scout-limited-check.js.map
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
// @ts-nocheck
|
|
3
|
-
import path from 'node:path';
|
|
4
|
-
import { pathToFileURL } from 'node:url';
|
|
5
|
-
import { ensureDistFresh, root } from './lib/ensure-dist-fresh.js';
|
|
6
|
-
const freshness = ensureDistFresh({ rebuild: true });
|
|
7
|
-
if (!freshness.ok)
|
|
8
|
-
fail('dist_not_fresh', { freshness });
|
|
9
|
-
const proof = await import(pathToFileURL(path.join(root, 'dist', 'core', 'agents', 'agent-slot-pane-binding-proof.js')).href);
|
|
10
|
-
const targetActiveSlots = 5;
|
|
11
|
-
const workItems = 10;
|
|
12
|
-
const records = Array.from({ length: workItems }, (_, index) => {
|
|
13
|
-
const slotIndex = (index % targetActiveSlots) + 1;
|
|
14
|
-
const generationIndex = Math.floor(index / targetActiveSlots) + 1;
|
|
15
|
-
const slotId = `slot-${String(slotIndex).padStart(3, '0')}`;
|
|
16
|
-
return {
|
|
17
|
-
slot_id: slotId,
|
|
18
|
-
generation_index: generationIndex,
|
|
19
|
-
pane_name: `${slotId}/gen-${generationIndex}`,
|
|
20
|
-
active_at_once: targetActiveSlots
|
|
21
|
-
};
|
|
22
|
-
});
|
|
23
|
-
const report = proof.evaluateWorkerPaneBackfillProof(records, targetActiveSlots, workItems);
|
|
24
|
-
const bad = proof.evaluateWorkerPaneBackfillProof(records.slice(0, 5), targetActiveSlots, workItems);
|
|
25
|
-
const ok = report.ok
|
|
26
|
-
&& report.generation_record_count >= 10
|
|
27
|
-
&& report.distinct_pane_count >= 10
|
|
28
|
-
&& bad.ok === false
|
|
29
|
-
&& bad.blockers.includes('dynamic_backfill_generation_records_missing');
|
|
30
|
-
emit({ schema: 'sks.agent-zellij-dynamic-backfill-panes-check.v1', ok, report, bad, blockers: ok ? [] : ['agent_zellij_dynamic_backfill_panes_check_failed'] });
|
|
31
|
-
function emit(report) { console.log(JSON.stringify(report, null, 2)); if (!report.ok)
|
|
32
|
-
process.exitCode = 1; }
|
|
33
|
-
function fail(blocker, detail) { emit({ schema: 'sks.agent-zellij-dynamic-backfill-panes-check.v1', ok: false, blockers: [blocker], detail }); process.exit(1); }
|
|
34
|
-
//# sourceMappingURL=agent-zellij-dynamic-backfill-panes-check.js.map
|
|
@@ -1,84 +0,0 @@
|
|
|
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 } from './lib/ensure-dist-fresh.js';
|
|
8
|
-
const freshness = ensureDistFresh({ rebuild: true });
|
|
9
|
-
if (!freshness.ok)
|
|
10
|
-
fail('dist_not_fresh', { freshness });
|
|
11
|
-
const supervisor = await import(pathToFileURL(path.join(root, 'dist', 'core', 'agents', 'zellij-lane-supervisor.js')).href);
|
|
12
|
-
const runner = await import(pathToFileURL(path.join(root, 'dist', 'core', 'agents', 'agent-runner-zellij.js')).href);
|
|
13
|
-
const nativeSwarm = await import(pathToFileURL(path.join(root, 'dist', 'core', 'agents', 'native-cli-session-swarm.js')).href);
|
|
14
|
-
const manager = await import(pathToFileURL(path.join(root, 'dist', 'core', 'zellij', 'zellij-worker-pane-manager.js')).href);
|
|
15
|
-
const tmp = await fs.mkdtemp(path.join(os.tmpdir(), 'sks-agent-zellij-'));
|
|
16
|
-
await supervisor.initializeZellijLaneSupervisorEmpty(tmp, { missionId: 'M-agent-zellij', sessionName: 'sks-M-agent-zellij' });
|
|
17
|
-
const supervisorState = JSON.parse(await fs.readFile(path.join(tmp, 'agent-zellij-lane-supervisor.json'), 'utf8'));
|
|
18
|
-
const runtimeManifest = JSON.parse(await fs.readFile(path.join(tmp, 'zellij-lane-runtime.json'), 'utf8'));
|
|
19
|
-
const agent = { id: 'agent_1', session_id: 'session_1', persona_id: 'agent_1', slot_id: 'slot-001', generation_index: 1 };
|
|
20
|
-
const result = await runner.runZellijAgent(agent, { id: 'work-001' }, { agentRoot: tmp, missionId: 'M-agent-zellij' });
|
|
21
|
-
const supervisorOk = supervisorState.lane_count === 0
|
|
22
|
-
&& supervisorState.lanes.length === 0
|
|
23
|
-
&& supervisorState.all_lanes_closed_after_drain === true
|
|
24
|
-
&& runtimeManifest.lanes.length === 0;
|
|
25
|
-
const paneWorkerCommand = nativeSwarm.buildPaneWorkerCommand({
|
|
26
|
-
args: ['/tmp/sks.js', '--agent', 'worker', '--intake', '/tmp/worker-intake.json', '--json'],
|
|
27
|
-
stdoutPath: '/tmp/worker.stdout.log',
|
|
28
|
-
stderrPath: '/tmp/worker.stderr.log',
|
|
29
|
-
heartbeatPath: '/tmp/worker-heartbeat.jsonl',
|
|
30
|
-
env: {
|
|
31
|
-
SKS_AGENT_WORKER: '1',
|
|
32
|
-
SKS_PARENT_MISSION_ID: 'M-agent-zellij',
|
|
33
|
-
SKS_AGENT_SLOT_ID: 'slot-001',
|
|
34
|
-
SKS_ZELLIJ_WORKER_PANE: '1'
|
|
35
|
-
}
|
|
36
|
-
});
|
|
37
|
-
const paneArtifact = manager.buildWorkerPaneArtifact({
|
|
38
|
-
root: tmp,
|
|
39
|
-
missionId: 'M-agent-zellij',
|
|
40
|
-
sessionName: 'sks-M-agent-zellij',
|
|
41
|
-
slotId: 'slot-001',
|
|
42
|
-
generationIndex: 1,
|
|
43
|
-
sessionId: 'slot-001-gen-1',
|
|
44
|
-
workerArtifactDir: 'sessions/slot-001/gen-1/worker',
|
|
45
|
-
resultPath: 'sessions/slot-001/gen-1/worker/worker-result.json',
|
|
46
|
-
heartbeatPath: 'sessions/slot-001/gen-1/worker/worker-heartbeat.jsonl',
|
|
47
|
-
patchEnvelopePath: 'sessions/slot-001/gen-1/worker/worker-patch-envelope.json',
|
|
48
|
-
stdoutLog: 'sessions/slot-001/gen-1/worker/worker.stdout.log',
|
|
49
|
-
stderrLog: 'sessions/slot-001/gen-1/worker/worker.stderr.log',
|
|
50
|
-
paneId: '1',
|
|
51
|
-
paneIdSource: 'zellij_worker_new_pane_stdout',
|
|
52
|
-
status: 'running',
|
|
53
|
-
blockers: []
|
|
54
|
-
});
|
|
55
|
-
const expectedPanePrefix = 'slot-001/gen-1';
|
|
56
|
-
const paneTitle = String(paneArtifact.pane_title || paneArtifact.pane_name || '');
|
|
57
|
-
const providerContext = paneArtifact.provider_context || {};
|
|
58
|
-
const paneWorkerOk = paneWorkerCommand.includes('SKS_ZELLIJ_WORKER_PANE=')
|
|
59
|
-
&& paneWorkerCommand.includes('--agent')
|
|
60
|
-
&& paneWorkerCommand.includes('worker')
|
|
61
|
-
&& paneWorkerCommand.includes('worker.stdout.log')
|
|
62
|
-
&& paneWorkerCommand.includes('worker.stderr.log')
|
|
63
|
-
&& paneWorkerCommand.includes('worker-heartbeat.jsonl')
|
|
64
|
-
&& paneWorkerCommand.includes('code=$?')
|
|
65
|
-
&& paneArtifact.pane_name === paneTitle
|
|
66
|
-
&& paneTitle.startsWith(expectedPanePrefix)
|
|
67
|
-
&& paneTitle.includes('codex-sdk')
|
|
68
|
-
&& paneTitle.includes('tier-unknown')
|
|
69
|
-
&& paneTitle.includes('provider-unknown')
|
|
70
|
-
&& paneArtifact.provider === 'unknown'
|
|
71
|
-
&& paneArtifact.service_tier === 'unknown'
|
|
72
|
-
&& providerContext.schema === 'sks.provider-context.v1'
|
|
73
|
-
&& providerContext.provider === 'unknown'
|
|
74
|
-
&& providerContext.service_tier === 'unknown'
|
|
75
|
-
&& paneArtifact.scaling_primitive === 'native_cli_process_in_zellij_worker_pane';
|
|
76
|
-
const ok = result.status === 'done' && result.backend === 'zellij' && supervisorOk && paneWorkerOk;
|
|
77
|
-
const report = { schema: 'sks.agent-zellij-runtime-check.v1', ok, result, supervisor_ok: supervisorOk, pane_worker_ok: paneWorkerOk, pane_worker_command: paneWorkerCommand, pane_artifact: paneArtifact, supervisor: supervisorState, runtime_manifest: runtimeManifest, blockers: ok ? [] : ['agent_zellij_runtime_check_failed'] };
|
|
78
|
-
await fs.mkdir(path.join(root, '.sneakoscope', 'reports'), { recursive: true });
|
|
79
|
-
await fs.writeFile(path.join(root, '.sneakoscope', 'reports', 'agent-zellij-runtime.json'), `${JSON.stringify(report, null, 2)}\n`);
|
|
80
|
-
emit(report);
|
|
81
|
-
function emit(report) { console.log(JSON.stringify(report, null, 2)); if (!report.ok)
|
|
82
|
-
process.exitCode = 1; }
|
|
83
|
-
function fail(blocker, detail) { emit({ schema: 'sks.agent-zellij-runtime-check.v1', ok: false, blockers: [blocker], detail }); process.exit(1); }
|
|
84
|
-
//# sourceMappingURL=agent-zellij-runtime-check.js.map
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
// @ts-nocheck
|
|
3
|
-
import { assertGate, emitGate, requireContains, requirePackageScripts, runSksJson } from './sks-1-12-real-execution-check-lib.js';
|
|
4
|
-
const requiredScripts = [
|
|
5
|
-
'ux-review:run-wires-imagegen',
|
|
6
|
-
'ux-review:extract-wires-real-extractor',
|
|
7
|
-
'ux-review:patch-diff-recheck',
|
|
8
|
-
'ppt:real-export-adapter',
|
|
9
|
-
'ppt:real-imagegen-wiring',
|
|
10
|
-
'ppt:reexport-rereview',
|
|
11
|
-
'dfix:patch-handoff',
|
|
12
|
-
'dfix:verification-recommendation',
|
|
13
|
-
'all-features:deep-completion',
|
|
14
|
-
'evidence:flagship-coverage'
|
|
15
|
-
];
|
|
16
|
-
requirePackageScripts('all-features:deep-completion', requiredScripts);
|
|
17
|
-
requireContains('all-features:deep-completion', 'src/core/feature-registry.ts', [
|
|
18
|
-
'command_registry',
|
|
19
|
-
'evidence_router',
|
|
20
|
-
'completion_proof',
|
|
21
|
-
'trust_report',
|
|
22
|
-
'wrongness',
|
|
23
|
-
'blackbox',
|
|
24
|
-
'mock_not_real',
|
|
25
|
-
'unavailable_blocker'
|
|
26
|
-
]);
|
|
27
|
-
const report = runSksJson(['features', 'complete', '--json']);
|
|
28
|
-
assertGate(report.schema === 'sks.all-feature-completion.v1', 'all-feature completion schema mismatch', report);
|
|
29
|
-
assertGate(Array.isArray(report.features) && report.features.length > 0, 'all-feature completion rows missing', report);
|
|
30
|
-
emitGate('all-features:deep-completion', { version: report.version, features: report.features.length, status: report.status });
|
|
31
|
-
//# sourceMappingURL=all-feature-deep-completion-check.js.map
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
// @ts-nocheck
|
|
3
|
-
import fs from 'node:fs';
|
|
4
|
-
import path from 'node:path';
|
|
5
|
-
import { assertGate, emitGate, importDist, root } from './sks-1-18-gate-lib.js';
|
|
6
|
-
const mod = await importDist('core/codex/appshots-detector.js');
|
|
7
|
-
const notRequired = mod.detectAppshotsCapability({ prompt: 'nonvisual release metadata' });
|
|
8
|
-
const visualWithOperator = mod.detectAppshotsCapability({ prompt: 'verify UI with Appshots', operatorActionRecorded: true });
|
|
9
|
-
const visualMissing = mod.detectAppshotsCapability({ prompt: 'verify UI with Appshots' });
|
|
10
|
-
const report = { schema: 'sks.appshots-capability-check.v1', ok: notRequired.ok && visualWithOperator.ok && !visualMissing.ok, notRequired, visualWithOperator, visualMissing };
|
|
11
|
-
const out = path.join(root, '.sneakoscope', 'reports', 'appshots-capability.json');
|
|
12
|
-
fs.mkdirSync(path.dirname(out), { recursive: true });
|
|
13
|
-
fs.writeFileSync(out, `${JSON.stringify(report, null, 2)}\n`);
|
|
14
|
-
assertGate(notRequired.status === 'not_required', 'nonvisual prompts must not require Appshots', report);
|
|
15
|
-
assertGate(visualWithOperator.ok === true, 'operator-recorded visual Appshots must pass', report);
|
|
16
|
-
assertGate(visualMissing.ok === false, 'missing visual Appshots operator action must block', report);
|
|
17
|
-
emitGate('appshots:capability', { visual_required: visualWithOperator.visual_required });
|
|
18
|
-
//# sourceMappingURL=appshots-capability-check.js.map
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
// @ts-nocheck
|
|
3
|
-
import fs from 'node:fs';
|
|
4
|
-
import path from 'node:path';
|
|
5
|
-
import { assertGate, emitGate, importDist, root } from './sks-1-18-gate-lib.js';
|
|
6
|
-
const mod = await importDist('core/source-intelligence/appshots-evidence.js');
|
|
7
|
-
const fixture = writeAppshotFixture('evidence');
|
|
8
|
-
const evidence = mod.buildAppshotsEvidence({
|
|
9
|
-
root,
|
|
10
|
-
prompt: 'visual Appshots proof',
|
|
11
|
-
sourcePaths: [fixture.rel],
|
|
12
|
-
sourceMetadata: [fixture.metadata],
|
|
13
|
-
operatorActionRecorded: true
|
|
14
|
-
});
|
|
15
|
-
const report = { schema: 'sks.appshots-evidence-check.v1', ok: evidence.ok, evidence };
|
|
16
|
-
const out = path.join(root, '.sneakoscope', 'reports', 'appshots-evidence.json');
|
|
17
|
-
fs.mkdirSync(path.dirname(out), { recursive: true });
|
|
18
|
-
fs.writeFileSync(out, `${JSON.stringify(report, null, 2)}\n`);
|
|
19
|
-
assertGate(evidence.ok === true, 'Appshots evidence must pass with source path', report);
|
|
20
|
-
assertGate(evidence.status === 'recorded', 'Appshots evidence must mark recorded visual source', report);
|
|
21
|
-
assertGate(evidence.proof_level === 'fixture_instrumented_real', 'Appshots fixture evidence must not be promoted to proven', report);
|
|
22
|
-
assertGate(evidence.source_verification.every((row) => row.accepted === true), 'Appshots evidence must verify source metadata', report);
|
|
23
|
-
emitGate('appshots:evidence', { source_count: evidence.source_count });
|
|
24
|
-
function writeAppshotFixture(name) {
|
|
25
|
-
const dir = path.join(root, '.sneakoscope', 'reports', 'appshots-fixtures');
|
|
26
|
-
fs.mkdirSync(dir, { recursive: true });
|
|
27
|
-
const file = path.join(dir, `${name}.redacted-appshot.json`);
|
|
28
|
-
fs.writeFileSync(file, `${JSON.stringify({ fixture: true, redacted: true, text: '[redacted appshot fixture]' })}\n`);
|
|
29
|
-
const rel = path.relative(root, file).split(path.sep).join('/');
|
|
30
|
-
return {
|
|
31
|
-
rel,
|
|
32
|
-
metadata: {
|
|
33
|
-
path: rel,
|
|
34
|
-
source_type: 'codex_appshot',
|
|
35
|
-
origin: 'fixture',
|
|
36
|
-
operator_attached: true,
|
|
37
|
-
frontmost_window: true,
|
|
38
|
-
redacted: true,
|
|
39
|
-
local_only: true,
|
|
40
|
-
fixture: true,
|
|
41
|
-
thread_id: 'thread-fixture-evidence',
|
|
42
|
-
attachment_id: 'attachment-fixture-evidence',
|
|
43
|
-
source_app: 'Codex',
|
|
44
|
-
source_window: 'Fixture Appshot'
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
//# sourceMappingURL=appshots-evidence-check.js.map
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
// @ts-nocheck
|
|
3
|
-
import fs from 'node:fs';
|
|
4
|
-
import path from 'node:path';
|
|
5
|
-
import { assertGate, emitGate, importDist, root } from './sks-1-18-gate-lib.js';
|
|
6
|
-
const detector = await importDist('core/codex/appshots-detector.js');
|
|
7
|
-
const policyMod = await importDist('core/codex/appshots-operator-policy.js');
|
|
8
|
-
const fixture = writeAppshotFixture('operator-policy');
|
|
9
|
-
const capability = detector.detectAppshotsCapability({ prompt: 'visual Appshots check', operatorActionRecorded: true });
|
|
10
|
-
const policy = policyMod.buildAppshotsOperatorPolicy(capability, { operatorActionRecorded: true, sourcePaths: [fixture.rel] });
|
|
11
|
-
const report = { schema: 'sks.appshots-operator-policy-check.v1', ok: policy.ok, policy };
|
|
12
|
-
const out = path.join(root, '.sneakoscope', 'reports', 'appshots-operator-policy.json');
|
|
13
|
-
fs.mkdirSync(path.dirname(out), { recursive: true });
|
|
14
|
-
fs.writeFileSync(out, `${JSON.stringify(report, null, 2)}\n`);
|
|
15
|
-
assertGate(policy.ok === true, 'Appshots operator policy must pass when action is recorded', report);
|
|
16
|
-
assertGate(policy.privacy_safety.no_background_screen_capture === true, 'Appshots policy must prevent background capture', report);
|
|
17
|
-
emitGate('appshots:operator-policy', { mode: policy.mode });
|
|
18
|
-
function writeAppshotFixture(name) {
|
|
19
|
-
const dir = path.join(root, '.sneakoscope', 'reports', 'appshots-fixtures');
|
|
20
|
-
fs.mkdirSync(dir, { recursive: true });
|
|
21
|
-
const file = path.join(dir, `${name}.redacted-appshot.json`);
|
|
22
|
-
fs.writeFileSync(file, `${JSON.stringify({ fixture: true, redacted: true, text: '[redacted appshot fixture]' })}\n`);
|
|
23
|
-
return { rel: path.relative(root, file).split(path.sep).join('/') };
|
|
24
|
-
}
|
|
25
|
-
//# sourceMappingURL=appshots-operator-policy-check.js.map
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
// @ts-nocheck
|
|
3
|
-
import fs from 'node:fs';
|
|
4
|
-
import path from 'node:path';
|
|
5
|
-
import { assertGate, emitGate, importDist, root } from './sks-1-18-gate-lib.js';
|
|
6
|
-
const mod = await importDist('core/source-intelligence/appshots-evidence.js');
|
|
7
|
-
const fixture = writeAppshotFixture('privacy');
|
|
8
|
-
const evidence = mod.buildAppshotsEvidence({
|
|
9
|
-
root,
|
|
10
|
-
prompt: 'visual Appshots privacy',
|
|
11
|
-
sourcePaths: [fixture.rel],
|
|
12
|
-
sourceMetadata: [fixture.metadata],
|
|
13
|
-
operatorActionRecorded: true
|
|
14
|
-
});
|
|
15
|
-
const policy = evidence.operator_policy.privacy_safety;
|
|
16
|
-
const report = { schema: 'sks.appshots-privacy-safety-check.v1', ok: evidence.privacy_safety_ok, policy };
|
|
17
|
-
const out = path.join(root, '.sneakoscope', 'reports', 'appshots-privacy-safety.json');
|
|
18
|
-
fs.mkdirSync(path.dirname(out), { recursive: true });
|
|
19
|
-
fs.writeFileSync(out, `${JSON.stringify(report, null, 2)}\n`);
|
|
20
|
-
assertGate(evidence.privacy_safety_ok === true, 'Appshots privacy safety must pass', report);
|
|
21
|
-
assertGate(policy.avoid_secrets_and_credentials === true, 'Appshots privacy safety must avoid secrets', report);
|
|
22
|
-
assertGate(evidence.source_verification.every((row) => row.redacted && row.local_only), 'Appshots privacy safety must verify redacted local-only sources', report);
|
|
23
|
-
emitGate('appshots:privacy-safety', { privacy_safety_ok: evidence.privacy_safety_ok });
|
|
24
|
-
function writeAppshotFixture(name) {
|
|
25
|
-
const dir = path.join(root, '.sneakoscope', 'reports', 'appshots-fixtures');
|
|
26
|
-
fs.mkdirSync(dir, { recursive: true });
|
|
27
|
-
const file = path.join(dir, `${name}.redacted-appshot.json`);
|
|
28
|
-
fs.writeFileSync(file, `${JSON.stringify({ fixture: true, redacted: true, text: '[redacted appshot fixture]' })}\n`);
|
|
29
|
-
const rel = path.relative(root, file).split(path.sep).join('/');
|
|
30
|
-
return {
|
|
31
|
-
rel,
|
|
32
|
-
metadata: {
|
|
33
|
-
path: rel,
|
|
34
|
-
source_type: 'codex_appshot',
|
|
35
|
-
origin: 'fixture',
|
|
36
|
-
operator_attached: true,
|
|
37
|
-
frontmost_window: true,
|
|
38
|
-
redacted: true,
|
|
39
|
-
local_only: true,
|
|
40
|
-
fixture: true,
|
|
41
|
-
thread_id: 'thread-fixture-privacy',
|
|
42
|
-
attachment_id: 'attachment-fixture-privacy',
|
|
43
|
-
source_app: 'Codex',
|
|
44
|
-
source_window: 'Fixture Appshot'
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
//# sourceMappingURL=appshots-privacy-safety-check.js.map
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
// @ts-nocheck
|
|
3
|
-
import fs from 'node:fs';
|
|
4
|
-
import os from 'node:os';
|
|
5
|
-
import path from 'node:path';
|
|
6
|
-
import { assertGate, emitGate, importDist, root } from './sks-1-18-gate-lib.js';
|
|
7
|
-
const mod = await importDist('core/source-intelligence/source-intelligence-runner.js');
|
|
8
|
-
const missionDir = fs.mkdtempSync(path.join(os.tmpdir(), 'sks-appshots-source-intelligence-'));
|
|
9
|
-
const fixture = writeAppshotFixture(missionDir);
|
|
10
|
-
const evidence = await mod.runSourceIntelligence({
|
|
11
|
-
root,
|
|
12
|
-
missionDir,
|
|
13
|
-
route: '$UX-Review',
|
|
14
|
-
query: 'visual Appshots source intelligence',
|
|
15
|
-
offline: true,
|
|
16
|
-
context7Available: true,
|
|
17
|
-
appshots: {
|
|
18
|
-
sourcePaths: [fixture.rel],
|
|
19
|
-
sourceMetadata: [fixture.metadata],
|
|
20
|
-
operatorActionRecorded: true
|
|
21
|
-
}
|
|
22
|
-
});
|
|
23
|
-
const report = { schema: 'sks.appshots-source-intelligence-check.v1', ok: evidence.ok, evidence };
|
|
24
|
-
const out = path.join(root, '.sneakoscope', 'reports', 'appshots-source-intelligence.json');
|
|
25
|
-
fs.mkdirSync(path.dirname(out), { recursive: true });
|
|
26
|
-
fs.writeFileSync(out, `${JSON.stringify(report, null, 2)}\n`);
|
|
27
|
-
assertGate(evidence.appshots?.ok === true, 'Source Intelligence must carry Appshots evidence', report);
|
|
28
|
-
assertGate(evidence.proof.source_intelligence.appshots_ok === true, 'Source Intelligence proof must mark Appshots ok', report);
|
|
29
|
-
assertGate(evidence.appshots?.proof_level === 'fixture_instrumented_real', 'Source Intelligence must not promote fixture Appshots to proven', report);
|
|
30
|
-
emitGate('appshots:source-intelligence', { mode: evidence.mode });
|
|
31
|
-
function writeAppshotFixture(dir) {
|
|
32
|
-
const file = path.join(dir, 'redacted-appshot-fixture.json');
|
|
33
|
-
fs.writeFileSync(file, `${JSON.stringify({ fixture: true, redacted: true, text: '[redacted appshot fixture]' })}\n`);
|
|
34
|
-
const rel = path.relative(root, file).split(path.sep).join('/');
|
|
35
|
-
return {
|
|
36
|
-
rel,
|
|
37
|
-
metadata: {
|
|
38
|
-
path: rel,
|
|
39
|
-
source_type: 'codex_appshot',
|
|
40
|
-
origin: 'fixture',
|
|
41
|
-
operator_attached: true,
|
|
42
|
-
frontmost_window: true,
|
|
43
|
-
redacted: true,
|
|
44
|
-
local_only: true,
|
|
45
|
-
fixture: true,
|
|
46
|
-
thread_id: 'thread-fixture-source-intelligence',
|
|
47
|
-
attachment_id: 'attachment-fixture-source-intelligence',
|
|
48
|
-
source_app: 'Codex',
|
|
49
|
-
source_window: 'Fixture Appshot'
|
|
50
|
-
}
|
|
51
|
-
};
|
|
52
|
-
}
|
|
53
|
-
//# sourceMappingURL=appshots-source-intelligence-check.js.map
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
// @ts-nocheck
|
|
3
|
-
import fs from 'node:fs';
|
|
4
|
-
import path from 'node:path';
|
|
5
|
-
import { assertGate, emitGate, importDist, root } from './sks-1-18-gate-lib.js';
|
|
6
|
-
const detector = await importDist('core/codex/appshots-detector.js');
|
|
7
|
-
const evidenceMod = await importDist('core/source-intelligence/appshots-evidence.js');
|
|
8
|
-
const fixture = writeAppshotFixture();
|
|
9
|
-
const threadAttachments = [
|
|
10
|
-
{
|
|
11
|
-
thread_id: 'thread-appshot-001',
|
|
12
|
-
attachment_id: 'att-appshot-001',
|
|
13
|
-
kind: 'appshot',
|
|
14
|
-
mime_type: 'image/png',
|
|
15
|
-
source_app: 'Codex',
|
|
16
|
-
source_window: 'Release Fixture',
|
|
17
|
-
local_only: true,
|
|
18
|
-
codex_appshot: true
|
|
19
|
-
},
|
|
20
|
-
{
|
|
21
|
-
thread_id: 'thread-appshot-001',
|
|
22
|
-
attachment_id: 'att-text-001',
|
|
23
|
-
kind: 'text',
|
|
24
|
-
mime_type: 'text/plain',
|
|
25
|
-
local_only: true
|
|
26
|
-
}
|
|
27
|
-
];
|
|
28
|
-
const discovery = detector.discoverAppshotsThreadAttachments(threadAttachments, { visualRequired: true });
|
|
29
|
-
const evidence = evidenceMod.buildAppshotsEvidence({
|
|
30
|
-
root,
|
|
31
|
-
prompt: 'visual Appshots thread attachment discovery fixture',
|
|
32
|
-
sourcePaths: [fixture.rel],
|
|
33
|
-
sourceMetadata: [fixture.metadata],
|
|
34
|
-
threadAttachments,
|
|
35
|
-
operatorActionRecorded: true
|
|
36
|
-
});
|
|
37
|
-
const missing = detector.detectAppshotsCapability({
|
|
38
|
-
prompt: 'visual Appshots required',
|
|
39
|
-
visualRequired: true,
|
|
40
|
-
operatorActionRecorded: false,
|
|
41
|
-
appshotsToolAvailable: false,
|
|
42
|
-
threadAttachments: []
|
|
43
|
-
});
|
|
44
|
-
const report = {
|
|
45
|
-
schema: 'sks.appshots-thread-attachment-discovery-check.v1',
|
|
46
|
-
ok: discovery.ok === true && evidence.ok === true && missing.operator_action_required === true,
|
|
47
|
-
discovery,
|
|
48
|
-
evidence,
|
|
49
|
-
missing_required_status: missing.status,
|
|
50
|
-
missing_required_blockers: missing.blockers
|
|
51
|
-
};
|
|
52
|
-
const out = path.join(root, '.sneakoscope', 'reports', 'appshots-thread-attachment-discovery.json');
|
|
53
|
-
fs.mkdirSync(path.dirname(out), { recursive: true });
|
|
54
|
-
fs.writeFileSync(out, `${JSON.stringify(report, null, 2)}\n`);
|
|
55
|
-
assertGate(discovery.attachments.some((row) => row.kind === 'appshot' && row.thread_id && row.attachment_id), 'Appshots discovery must retain thread and attachment ids', report);
|
|
56
|
-
assertGate(discovery.attachments.some((row) => row.kind === 'appshot' && row.source_app && row.source_window && row.local_only === true), 'Appshots discovery must retain source app, source window, and local-only provenance', report);
|
|
57
|
-
assertGate(discovery.attachments.some((row) => row.kind === 'text'), 'Appshots discovery must classify text attachments when metadata exists', report);
|
|
58
|
-
assertGate(evidence.thread_attachment_discovery.appshot_attachment_count === 1, 'Appshots evidence must embed thread attachment discovery', report);
|
|
59
|
-
assertGate(evidence.source_verification.every((row) => row.source_type !== 'codex_appshot' || (row.thread_id && row.attachment_id && row.source_app && row.source_window && row.local_only === true)), 'Appshots codex_appshot evidence must preserve thread, attachment, source, and local-only fields', report);
|
|
60
|
-
assertGate(!JSON.stringify(report).includes('CLI-created'), 'Appshots evidence must not claim CLI-created Appshots', report);
|
|
61
|
-
assertGate(missing.operator_action_required === true, 'Missing required Appshot must request operator action', report);
|
|
62
|
-
emitGate('appshots:thread-attachment-discovery', { appshot_attachment_count: discovery.appshot_attachment_count });
|
|
63
|
-
function writeAppshotFixture() {
|
|
64
|
-
const dir = path.join(root, '.sneakoscope', 'reports', 'appshots-fixtures');
|
|
65
|
-
fs.mkdirSync(dir, { recursive: true });
|
|
66
|
-
const file = path.join(dir, 'thread-attachment.redacted-appshot.json');
|
|
67
|
-
fs.writeFileSync(file, `${JSON.stringify({ fixture: true, redacted: true, text: '[redacted appshot fixture]' })}\n`);
|
|
68
|
-
const rel = path.relative(root, file).split(path.sep).join('/');
|
|
69
|
-
return {
|
|
70
|
-
rel,
|
|
71
|
-
metadata: {
|
|
72
|
-
path: rel,
|
|
73
|
-
source_type: 'codex_appshot',
|
|
74
|
-
origin: 'fixture',
|
|
75
|
-
operator_attached: true,
|
|
76
|
-
frontmost_window: true,
|
|
77
|
-
redacted: true,
|
|
78
|
-
local_only: true,
|
|
79
|
-
fixture: true,
|
|
80
|
-
thread_id: 'thread-appshot-001',
|
|
81
|
-
attachment_id: 'att-appshot-001',
|
|
82
|
-
source_app: 'Codex',
|
|
83
|
-
source_window: 'Release Fixture'
|
|
84
|
-
}
|
|
85
|
-
};
|
|
86
|
-
}
|
|
87
|
-
//# sourceMappingURL=appshots-thread-attachment-discovery-check.js.map
|