test(mcp): rewrite GlobalScope_Blocked to assert OFFSEC-001 scrub contract (mc#664 Class 2) #680
Open
core-lead
wants to merge 1 commits from
fix/mc-664-class-2-mcp-offsec-contract-test into main
pull from: fix/mc-664-class-2-mcp-offsec-contract-test
merge into: molecule-ai:main
molecule-ai:main
molecule-ai:feat/709-handler-pure-coverage
molecule-ai:fix/canvas-keyboard-shortcuts-dialog-guard
molecule-ai:test/settings-tab-coverage
molecule-ai:ci/lint-tracker-regex-fix-v2
molecule-ai:fix/697-canvas-geticon-topology
molecule-ai:staging
molecule-ai:fix/713-eic-diagnose-detail
molecule-ai:ci/lint-tracker-regex-fix
molecule-ai:fix/686-delegation-integration-tests
molecule-ai:test/2071-canvas-drop-target-badge-coverage
molecule-ai:test/713-org-helpers-pure-coverage
molecule-ai:test/713-workspace-crud-validators
molecule-ai:feat/2071-canvas-orgdeploystate-coverage
molecule-ai:feat/mobile-canvas-comms-spawn-coverage
molecule-ai:ci/lint-coe-self-fix
molecule-ai:infra/all-required-coe-false-v2
molecule-ai:feat/mobile-tabbar-a11y
molecule-ai:design/704-tree-test-fix
molecule-ai:feat/tier-2g-required-context-exists-in-bp
molecule-ai:fix/ssm-refresh-ecr-auth-json-escaping
molecule-ai:fix/735-extractResponseText-tests
molecule-ai:feat/tier-2f-bp-emit-match
molecule-ai:infra/664-lint-coe-trackers
molecule-ai:design/729-fix
molecule-ai:ci/gate-check-v3-permissions-fix
molecule-ai:fix/730-discovery-filter-nil-role
molecule-ai:fix/org-layout-helpers-test-coverage
molecule-ai:fix/681-recallmemory-offsec-contract
molecule-ai:infra/publish-docker-daemon-diagnostic
molecule-ai:fix/714-all-required-coe-false
molecule-ai:fix/717-mobile-agentMessages-selector
molecule-ai:test/workspace-crud-helpers-coverage
molecule-ai:infra/fix-all-required-status-reporting
molecule-ai:fix/687-e2e-surface-diagnose-detail
molecule-ai:feat/698-org-import-helpers-test-coverage
molecule-ai:infra/docker-runner-label
molecule-ai:fix/canvas-geticon-case-insensitive
molecule-ai:test/701-canvas-hydrate-coverage
molecule-ai:fix/mobile-MobileChat-infinite-render
molecule-ai:test/mobile-primitives-coverage
molecule-ai:infra/664-interim-platform-build-exempt
molecule-ai:fix/693-offsec-recallmemory-scrub-staging
molecule-ai:sync/main-to-staging-514-v2
molecule-ai:fix/681-recall-memory-offsec-scrub
molecule-ai:fix/693-offsec-recallmemory-global-scrub
molecule-ai:fix/693-offsec-recallmemory-scrub
molecule-ai:feat/a2a-proxy-helpers-test-coverage
molecule-ai:feat/socket-handler-test-coverage
molecule-ai:feat/org-import-helpers-test-coverage
molecule-ai:fix/634-handler-test-fixes-to-main
molecule-ai:fix/mc-664-class-1-delegation-tests-postgres-integration
molecule-ai:test/699-socket-handler-coverage
molecule-ai:sre/workflow-run-replacement
molecule-ai:infra/660-codify-promote-tenant-image
molecule-ai:infra/676-ssm-auth-json-hardening
molecule-ai:fix/offsec-001-method-scrub-hotfix
molecule-ai:feat/instructions-test-coverage
molecule-ai:fix/offsec-001-method-scrub-main
molecule-ai:feat/workspace-dispatchers-test-coverage
molecule-ai:feat/workspace-crud-validation-tests
molecule-ai:feat/mcp-tools-test-coverage
molecule-ai:test/canvas-hydrate-coverage
molecule-ai:infra/lint-pre-flip-continue-on-error
molecule-ai:fix/workflow_run-to-push-gitea-1.22.6
molecule-ai:feat/tier-2e-tracking-issue
molecule-ai:fix/684-offsec-scrub-method-default
molecule-ai:feat/sop-checklist-gate-mvp
molecule-ai:feat/tier-2d-lint-mask-pr-atomicity
molecule-ai:infra/lint-workflow-yaml-hostile-shapes
molecule-ai:infra/lint-required-no-paths-filter
molecule-ai:cleanup/pr-641-clean
molecule-ai:feat/mobile-tabbar-wcag-a11y
molecule-ai:fix/canvas-mobile-chat-loop
molecule-ai:fix/651-canvas-chat-mobile-crash
molecule-ai:fix/664-interim-remask-platform-build
molecule-ai:fix/mobile-chat-max-update-depth
molecule-ai:infra/622-force-merge-protection-fix
molecule-ai:test/attachment-lightbox-clean-v2
molecule-ai:ci/652-gitea-1-22-status-key
molecule-ai:test/memorytab-2
molecule-ai:infra/status-reaper-rev4-status-key-fix
molecule-ai:infra/weekly-platform-go-vet-hard
molecule-ai:fix/audit-force-merge-pipefail
molecule-ai:infra/status-reaper-rev3-widen-window
molecule-ai:test/canvas-externalconnectmodal-coverage
molecule-ai:fix/sop-tier-check-token-graceful
molecule-ai:infra/ci-required-drift-token-scope
molecule-ai:test/console-modal-coverage
molecule-ai:ci/review-check-tests-wire
molecule-ai:test/canvas-workspacenode-coverage
molecule-ai:test/memorytab
molecule-ai:infra/interim-disable-reaper-watchdog-crons
molecule-ai:test/attachment-lightbox-coverage
molecule-ai:fix/issue-639-workspacenode-test-coverage
molecule-ai:test/channels-tab
molecule-ai:fix/canvas-searchdialog-test-fixtures
molecule-ai:fix/598-attachmentLightbox-tests
molecule-ai:fix/529-307-localbuild-async-test-fix
molecule-ai:fix/582-attachmentviews-tests
molecule-ai:fix/308-a2a-response-push-mode-tests
molecule-ai:fix/529-preflight-localbuild
molecule-ai:fix/sop-tier-check-token-graceful-staging
molecule-ai:fix/545-approvalbanner-isolation
molecule-ai:fix/519-memorytab-tests
molecule-ai:infra/status-reaper-rev2-sweep-recent-commits
molecule-ai:fix/handlers-test-fixtures
molecule-ai:test/skill-helpers-coverage
molecule-ai:test/ui-primitive-coverage
molecule-ai:docs/gitea-quirks-10-11
molecule-ai:test/platform-bundle-exporter-coverage
molecule-ai:infra/status-reaper-rev1-drop-concurrency
molecule-ai:fix/608-filesTab-focusTest
molecule-ai:test/budget-section-coverage
molecule-ai:infra/revert-docker-runner-label
molecule-ai:fix/weekly-platform-go-latent-error-surface
molecule-ai:infra/revert-publish-runs-on-pin
molecule-ai:sre/gate-check-timeout
molecule-ai:test/a2a-error-hint-coverage
molecule-ai:test/chat-attachment-views-coverage
molecule-ai:test/attachment-video-coverage
molecule-ai:infra/option-b-status-reaper
molecule-ai:infra/gate-check-v3-timeout
molecule-ai:infra/576-docker-runner-label
molecule-ai:fix/593-filetab-tests
molecule-ai:test/files-tab-notavailablepanel-coverage
molecule-ai:fix/591-forminputs-tests
molecule-ai:fix/471-cwe117-stderr-scrubbing
molecule-ai:infra/diagnostic-publish-workspace-server-image
molecule-ai:fix/582-bundle-import-tests
molecule-ai:test/form-inputs-coverage
molecule-ai:fix/publish-workspace-server-image-json5-comments
molecule-ai:sre/fix-all-required-null-result
molecule-ai:fix/publish-workspace-server-image-optional-token
molecule-ai:pr-251
molecule-ai:test/ui-statusbadge-coverage
molecule-ai:fix/all-required-null-result-assertion
molecule-ai:fix/568-palette-context-tests
molecule-ai:pr-527
molecule-ai:infra/merge-563-autobump-fix
molecule-ai:test/mobile-palette-context-coverage
molecule-ai:sre/fix-gate-check-v3-combined-state-loop
molecule-ai:ci/540-review-check-bats-tests
molecule-ai:fix/publish-runtime-autobump-push-condition
molecule-ai:ci/558-verify-publish-runtime-marker
molecule-ai:test/canvas-empty-state-coverage
molecule-ai:infra/publish-runtime-verify-2026-05-11
molecule-ai:ci/554-oci-labels-publish-workflow
molecule-ai:infra/drift-bot-token
molecule-ai:infra/rfc-219-phase-4-all-required-sentinel
molecule-ai:ci/551-gate-checkout-trusted-ref
molecule-ai:fix/gate-check-v3-pr-HEAD-security
molecule-ai:fix/541-token-argv-security
molecule-ai:sre/fix-gate-check-v3-bugs
molecule-ai:fix/537-cwe117-a2a-tools-sanitize
molecule-ai:fix/gate-check-v3-http-error-crash
molecule-ai:sre/fix-localbuild-preflight
molecule-ai:infra/rfc-324-workflow-add
molecule-ai:test/offsec-003-sanitization-backstop
molecule-ai:fix/test-sanitize-agent-error-stderr-exc
molecule-ai:fix/approval-banner-test-isolation
molecule-ai:infra/scope-workflows-fix
molecule-ai:sre/fix-pr530-deadlock
molecule-ai:sre/reopen-516-gate-check-fix
molecule-ai:fix/ci-scope-operational-workflows-504-419
molecule-ai:sre/scope-operational-workflows-to-schedule
molecule-ai:ci/harness-replays-detect-changes-quoting-fix
molecule-ai:fix/test-blocks-until-inflight-completes
molecule-ai:fix/test-enrich-peer-metadata-nonblocking
molecule-ai:sre/fix-enrich-nonblocking-cache-check
molecule-ai:merge-pr490
molecule-ai:runtime/fix-offsec-003-tool-delegate-task
molecule-ai:fix/508-update-boundary-assertions
molecule-ai:sre/fix-test-delegation-sync-polling-assertions
molecule-ai:fix/366-shared-runtime-coverage
molecule-ai:fix/506-unused-imports
molecule-ai:ci/lint-fixes
molecule-ai:fix/367-a2a-tools-coverage
molecule-ai:test/a2a-client-enrich-peer-rebase
molecule-ai:fix/354-delegation-auto-resume-rebase
molecule-ai:ci/fix-detect-changes-commits-array
molecule-ai:fix/307-async-rebase
molecule-ai:runtime/fix-harness-replays-push-event
molecule-ai:sre/fix-test-polling-sanitization
molecule-ai:fix/harness-replays-detect-changes-gitea-api
molecule-ai:ci/fix-test-polling-sanitization
molecule-ai:test/eventstab
molecule-ai:test/externalconnectmodal
molecule-ai:runtime/335-rebase-platfrom-url
molecule-ai:hotfix/491-offsec-003-staging-v2
molecule-ai:fix/pr477-test-fixes
molecule-ai:runtime/335-rebase-platform-url
molecule-ai:test/orgcancelbutton
molecule-ai:fix/354-auto-resume-delegations
molecule-ai:fix/368-audit-hooks-coverage
molecule-ai:runtime/temporal-platform-url-fix
molecule-ai:infra/secret-reconciliation-v2
molecule-ai:fix/purchase-success-modal-test-isolation
molecule-ai:pr-476
molecule-ai:sre/fix-gitea-runbook-network-quirks
molecule-ai:tools/gate-check-v3
molecule-ai:fix/376-activity-delegation-polling
molecule-ai:runtime/platform-url-fix-merge
molecule-ai:fix/canvas-purchase-success-modal-test-timing
molecule-ai:fix/secret-naming-reconciliation
molecule-ai:docs/gitea-operational-quirks-runbook
molecule-ai:test/canvas-toolbar-coverage
molecule-ai:fix/canvas-tier-config-v2
molecule-ai:fix/455-offsec003-sanitize-alignment
molecule-ai:fix/sweep-stale-e2e-orgs-secret-name
molecule-ai:fix/approvalbanner-mockreset-452
molecule-ai:fix/canvas-approvalbanner-mockreset
molecule-ai:fix/publish-runtime-autobump-fetch-depth
molecule-ai:fix/321-cwe22-loadWorkspaceEnv-path-traversal
molecule-ai:fix/canonicalize-staging-admin-token-rebase-462
molecule-ai:canvas-followup
molecule-ai:fix/canonicalize-staging-admin-token-rest
molecule-ai:refactor/drop-canary-prefix
molecule-ai:fix/canvas-test-and-design-fixes
molecule-ai:runtime/432-followup-helper-extraction
molecule-ai:fix/harness-replays-detect-changes-fetch-depth
molecule-ai:fix/stderr-include-a2a-error-response
molecule-ai:feat/internal-292-sop-tier-refire
molecule-ai:docs/update-remote-agent-tutorial-sdk-api
molecule-ai:fix/canvas-confirm-dialog-backdrop-a11y-v3
molecule-ai:fix/canvas-confirm-dialog-backdrop-a11y-v2
molecule-ai:fix/388-github-token-501-gitea-staging
molecule-ai:fix/dialog-backdrop-a11y
molecule-ai:runtime/414-idle-loop-skip-pending-results-v3
molecule-ai:fix/test-extract-tool-trace
molecule-ai:fix/test-plugins-atomic-tar-coverage
molecule-ai:fix/harness-replays-fetch-depth
molecule-ai:fix/test-instructions-handler-coverage
molecule-ai:sre/fix-workflow-secret-naming
molecule-ai:fix/canvas-tiers-config-string-keys
molecule-ai:fix/offsec-003-promote-to-main
molecule-ai:fix/class-e-secret-name-reconciliation
molecule-ai:fix/sop-tier-check-apt-get-first
molecule-ai:fix/307-async-test-pollution
molecule-ai:fix/sop-tier-check-jq-install-order
molecule-ai:fix/canvas-test-failures-2026-05-10
molecule-ai:runtime/fix-a2a-tools-duplicate-error-block-v2
molecule-ai:infra/sop-tier-check-jq-install-fix
molecule-ai:runtime/fix-a2a-push-delivery-mode
molecule-ai:feat/main-never-red-watchdog-internal-420
molecule-ai:feat/internal-219-phase-2bc-port-to-molecule-core
molecule-ai:fix/a11y-canvas-clean
molecule-ai:sweep/internal-219-cat-C1-port-gates-lints
molecule-ai:sweep/internal-219-cat-B-delete-github-only
molecule-ai:sweep/internal-219-cat-A-delete-mirrored
molecule-ai:fix/offsec-003-json-endpoint-sanitize
molecule-ai:sweep/internal-219-cat-C3-port-deploy-janitors
molecule-ai:sweep/internal-219-cat-C2-port-e2e
molecule-ai:fix/publish-runtime-cascade-sha-capture
molecule-ai:feat/internal-219-phase-3-port-ci-yml
molecule-ai:fix/413-a2a-delegation-offsec-003
molecule-ai:runtime/381-idle-loop-pending-messages
molecule-ai:fix/delegations-rows-err-check
molecule-ai:fix/a11y-canvas-buttons-staging
molecule-ai:runtime/fix-399-a2a-delegation-missing-import-v2
molecule-ai:fix/380-cwe59-symlink-traversal
molecule-ai:fix/388-github-token-501-staging
molecule-ai:fix/confirm-dialog-wcag-backdrop
molecule-ai:infra/sop-tier-check-jq-script-fallback
molecule-ai:fix/revert-391-broken-jq-install
molecule-ai:fix/a2a-tools-duplicate-dead-code
molecule-ai:fix/confirm-dialog-backdrop
molecule-ai:fix/canvas-confirm-dialog-backdrop-a11y
molecule-ai:infra/jq-install-main
molecule-ai:fix/sop-tier-check-jq-main
molecule-ai:fix/canvas-dialog-backdrop-a11y
molecule-ai:fix/388-github-token-501
molecule-ai:runtime/offsec-003-polling-path-v2
molecule-ai:fix/361-sanitize-delegation-results
molecule-ai:runtime/offsec-003-executor-sanitize
molecule-ai:fix/cwe22-loadWorkspaceEnv-main
molecule-ai:fix/qa-audit-307-308-clean
molecule-ai:ci/fix-293-sqlalchemy-pip-install
molecule-ai:fix/354-delegation-auto-resume
molecule-ai:runtime/platform-url-host-docker-internal
molecule-ai:fix/canvas-repair-tests-344
molecule-ai:fix/canvas-statusdot-ts-errors
molecule-ai:test/molecule-audit-hooks-coverage
molecule-ai:test/a2a-tools-and-send-message-coverage
molecule-ai:fix/sop-tier-check-jq-install
molecule-ai:test/shared-runtime-helpers-coverage
molecule-ai:fix/canvas-topology-sort-orphan
molecule-ai:fix/executor-helpers-offsec-003-sanitize
molecule-ai:runtime/offsec-003-polling-path
molecule-ai:fix/354-a2a-delegation-auto-resume
molecule-ai:runtime/fix-a2a-push-delivery-mode-v2
molecule-ai:fix/publish-runtime-add-_sanitize_a2a-to-allowlist
molecule-ai:fix/publish-runtime-missing-working-directory
molecule-ai:ci/add-sqlalchemy-to-pip-install
molecule-ai:ci-resolve-github-gitea-triplicate
molecule-ai:sre/offsec-003-boundary-escape
molecule-ai:fix/sec-321-path-traversal-clean
molecule-ai:fix/a2a-proxy-response-header-timeout-v2
molecule-ai:fix/publish-runtime-workflow-dispatch-inputs
molecule-ai:fix/a2a-push-mode-queue-envelope
molecule-ai:fix/351-split-publish-runtime-triggers
molecule-ai:feat/348-publish-runtime-restore-path-trigger
molecule-ai:fix/issue-workspace-dup-name-409-autosuffix
molecule-ai:fix/security-OFFSEC003-boundary-escape-334
molecule-ai:fix/security-CWE22-loadWorkspaceEnv-330
molecule-ai:fix/canvas-test-fixes-20260510
molecule-ai:fix/canvas-extractMessageText
molecule-ai:fix/qa-307-async-pollution-direct
molecule-ai:test/a2a-client-enrich-peer-metadata
molecule-ai:fix/docs-309-remote-faq-staging-env
molecule-ai:fix/qa-308-push-mode-queue-tests
molecule-ai:fix/qa-307-async-pollution
molecule-ai:runtime/fix-plugin-registry-import-path
molecule-ai:fix/a2a-proxy-response-header-timeout-clean
molecule-ai:fix/publish-workspace-server-ci-clone-manifest-retry-main
molecule-ai:infra/remove-pr303-tracking
molecule-ai:fix/issue-296-plugin-registry-sysmodules
molecule-ai:infra/pin-compose-image-digests
molecule-ai:chore/sync-main-to-staging
molecule-ai:fix/sec-321-path-traversal
molecule-ai:fix/a2a-proxy-response-header-timeout
molecule-ai:docs/a11y-billing-wcag-patterns
molecule-ai:fix/qa-307-test-a2a-inbox-wrappers-asyncio-refactor
molecule-ai:runtime/fix-test-config-model-isolation
molecule-ai:ci/docker-daemon-health-guard
molecule-ai:docs/fix-remote-workspaces-faq
molecule-ai:fix/publish-workspace-server-ci-clone-manifest-retry
molecule-ai:fix/test-config-env-isolation
molecule-ai:ci/staging-sha-pinning
molecule-ai:fix/external-connection-user-facing-urls
molecule-ai:fix/workspace-server-registry-config-helper
molecule-ai:fix/issue-272-sqlalchemy-ci-install
molecule-ai:fix/canvas-yaml-utils-nested-arrays-clean
molecule-ai:fix/self-delegation-guard
molecule-ai:promote/staging-to-main-100546
molecule-ai:fix/a2a-tools-v2
molecule-ai:fix/a2a-tools-and-workflow-cleanup
molecule-ai:fix/canvas-test-isolation-fixes-v2
molecule-ai:fix/molecule-model-env-go
molecule-ai:runtime/fix-delegate-empty-parts-regression
molecule-ai:infra/runtime-doc-playwright-limitation
molecule-ai:fix/offsec-001-error-message-scrubbing
molecule-ai:fix/offsec-001
molecule-ai:fix/a2a-tools-string-error-handling-clean
molecule-ai:fix/core-248-pluginresolver-and-plgh
molecule-ai:infra/fix-source-resolver-dup
molecule-ai:fix/model-provider-misnomer
molecule-ai:fix/a2a-tools-string-error-handling-v2
molecule-ai:fix/canvas-yaml-utils-test-failure
molecule-ai:fix/a2a-tools-string-error-handling
molecule-ai:fix/internal-214-gosum-vanity-import
molecule-ai:fix/canvas-test-isolation-fixes
molecule-ai:chore/canvas-statusbadge-test-fix-cherry-pick
molecule-ai:fix/canvas-statusbadge-test-role-ambiguity
molecule-ai:runtime/fix-mcp-client-localhost-default
molecule-ai:fix/core-257-delegation-test-stray-brace
molecule-ai:revert/core-d0126662-restart-signals-undefined-h
molecule-ai:revert/core-123-plugin-drift-detector
molecule-ai:ci/pin-action-and-base-images
molecule-ai:fix/org-232-per-workspace-required-env-preflight
molecule-ai:fix/ssrf-guard-before-begintx
molecule-ai:test/issue-232-per-workspace-required-env-preflight
molecule-ai:fix/issue232-org-import-required-env-aggregation
molecule-ai:fix/canvas-ts-test-errors
molecule-ai:fix/delegations-list-ledger-fallback
molecule-ai:wip-snapshot-2026-05-10/mac/molecule-core-tmp53-git-token-helper-wip
molecule-ai:wip-snapshot-2026-05-10/mac/molecules-org-molecule-core-registry-prefix
molecule-ai:fix/pluginresolver-conflict
molecule-ai:wip-snapshot-2026-05-10/core-be/fix-pluginresolver-conflict
molecule-ai:wip-snapshot-2026-05-10/core-qa/stash-package-lock-diff
molecule-ai:feat/keyboard-shortcuts-dialog
molecule-ai:wip-snapshot-2026-05-10/core-uiux/feat-keyboard-shortcuts-dialog
molecule-ai:wip-snapshot-2026-05-10/core-fe/test-canvas-design-tokens-config
molecule-ai:test/canvas-cssvar-tests
molecule-ai:fix/internal-229-sop-tier-check-tier-low-relaxation
molecule-ai:test/canvas-utility-pure-tests
molecule-ai:test/canvas-preflight-utils-tests
molecule-ai:test/canvas-runtimeprofiles-tests
molecule-ai:test/canvas-yaml-utils-tests
molecule-ai:test/canvas-pure-function-tests
molecule-ai:fix/ci-port-publish-workspace-server-image-228
molecule-ai:fix/ssrf-validate-agent-url-212
molecule-ai:ci/sop-tier-check-approver-teams-fix
molecule-ai:fix/sop-tier-check-legacy-flip-229
molecule-ai:wip-snapshot-2026-05-10/core-be/fix-ki001-telegram-disable-channel
molecule-ai:wip-snapshot-2026-05-10/core-be/feat-a2a-pre-restart-drain-125
molecule-ai:wip-snapshot-2026-05-10/core-be/feat-plugin-drift-queue-123
molecule-ai:fix/sweeper-race-error-counter
molecule-ai:infra/fix-issue-75-gh-cli-gitea-sweep
molecule-ai:wip-snapshot-2026-05-10/core-be/fix-gh-api-gitea-sweep-75
molecule-ai:feat/keyboard-shortcuts-dialog-test
molecule-ai:wip-snapshot-2026-05-10/core-be/fix-sweeper-test-isolation-86
molecule-ai:ci/fix-issue-87-root-skip
molecule-ai:fix/test-local-resolver-root-skip
molecule-ai:fix/workspace-tests-clear-auth-cache
molecule-ai:wip-snapshot-2026-05-10/core-be/fix-a2a-delegation-success-rendered-as-error
molecule-ai:wip-snapshot-2026-05-10/core-be/fix-files-restart-volume-sync
molecule-ai:wip-snapshot-2026-05-10/core-lead/tech-debt-rename-net
molecule-ai:wip-snapshot-2026-05-10/core-lead/fix-168-mine
molecule-ai:wip-snapshot-2026-05-10/core-lead/fix-167-uiux
molecule-ai:wip-snapshot-2026-05-10/core-fe/stash-canvas-agent-comms-show-task-text
molecule-ai:fix/canvas-agent-comms-show-task-text
molecule-ai:wip-snapshot-2026-05-10/core-lead/fix-vitest-pool
molecule-ai:fix/info-disclosure-errors
molecule-ai:infra/add-temporal-to-main-compose
molecule-ai:design/verify-canvas-design-system
molecule-ai:fix/workspace-persona-git-identity
molecule-ai:fix/175-env-matched-pair-guard
molecule-ai:wip-snapshot-2026-05-10/core-lead/fix-149
molecule-ai:refactor/sop-tier-check-extract-script
molecule-ai:fix/sop-tier-check-pr-target-security
molecule-ai:ci/sop-tier-check-deploy
molecule-ai:fix/issue53-admin-token-pair-guard
molecule-ai:fix/org-import-started-event-name
molecule-ai:refactor/delete-uses-cascade-helper
molecule-ai:fix/org-import-reconcile-and-audit
molecule-ai:fix/preserve-model-secret-on-restart
molecule-ai:feat/persona-bind-mount-local-dev
molecule-ai:feat/canary-tier-filter
molecule-ai:feat/plugin-version-subscription
molecule-ai:feat/plugin-hot-reload-classifier
molecule-ai:feat/plugin-atomic-install
molecule-ai:feat/air-hot-reload-dev
molecule-ai:feat/persona-env-injection
molecule-ai:fix/external-resolver-hardening
molecule-ai:fix/issue75-class-D-gh-api-to-gitea-rest
molecule-ai:fix/cherry-3-files-vitest-postgres-e2eapi
molecule-ai:fix/promote-vitest-postgres-fixes
molecule-ai:fix/saas-plugin-install-eic
molecule-ai:fix/issue-94-e2e-api-parallel-safe-class-b
molecule-ai:migrate/issue-71-vanity-imports
molecule-ai:fix/handlers-postgres-port-collision-class-b
molecule-ai:fix/issue-96-canvas-vitest-cold-start-timeout
molecule-ai:fix/hermes-agent-doc-gitea-migration
molecule-ai:fix/196-retarget-main-to-staging-gitea-rest
molecule-ai:fix/gitea-ci-flakes-issue-88
molecule-ai:fix/pin-upload-artifact-v3-gitea
molecule-ai:fix/issue-72-auto-sync-token-canary-v2
molecule-ai:fix/issue75-class-F-gh-run-list-to-statuses
molecule-ai:fix/issue75-class-A-gh-pr-to-gitea-rest
molecule-ai:feat/issue-63-local-build-from-gitea-v2
molecule-ai:fix/195-auto-promote-staging-gitea-rest
molecule-ai:fix/144-branch-protection-check-name-parity-audit
molecule-ai:fix/harness-replays-pre-clone-manifest
molecule-ai:chore/trigger-auto-sync-verification
molecule-ai:fix/codeql-stub-on-gitea-156
molecule-ai:chore/issue173-retrigger-after-ecr-repo-create
molecule-ai:fix/issue173-inline-aws-ecr-login
molecule-ai:fix/issue173-shell-docker-push
molecule-ai:chore/retrigger-harness-replays-post-class-g
molecule-ai:fix/issue173-buildx-driver-and-cache
molecule-ai:fix/post-suspension-clone-manifest
molecule-ai:fix/issue173-followup-platform-dockerfile
molecule-ai:fix/post-suspension-github-urls
molecule-ai:fix/170-goroutine-bleed-test-isolation
molecule-ai:fix/issue173-publish-workspace-server-image
molecule-ai:fix/issue36-a2a-proxy-preflight
molecule-ai:fix/codeql-continue-on-error-156
molecule-ai:feat/demo-mock-3-bigorg-mock-runtime
molecule-ai:feat/demo-mock-1-purchase-success-modal
molecule-ai:fix/publish-path-filter-add-scripts
molecule-ai:fix/clone-manifest-gitea
molecule-ai:chore/touch-publish-workflow-to-trigger
molecule-ai:chore/retrigger-publish-post-aws-secrets
molecule-ai:chore/cherry-pick-pr23-into-main
molecule-ai:chore/backsync-main-into-staging-task-166
molecule-ai:fix/auto-sync-use-devops-token
molecule-ai:chore/retrigger-staging-on-fixed-runner-image
molecule-ai:chore/drop-github-app-auth-and-ecr-swap
molecule-ai:docs/readme-comprehensive-refresh-2026-05-06
molecule-ai:feat/rfc-2945-pr-c-2-canvas-chat-history
molecule-ai:fix/issue10-runtime-aware-plugin-install
molecule-ai:fix/s8-bind-loopback-dev
molecule-ai:fix/14-cascade-gitea-dispatch
molecule-ai:docs/molecule-core-bulk-sed
molecule-ai:chore/pin-artifact-actions-v3
molecule-ai:fix/lowercase-org-slug
molecule-ai:fix/script-ghcr-and-lint-paths
molecule-ai:docs/workspace-runtime-readme-source-edit
molecule-ai:feat/eic-tunnel-pool-core-11
molecule-ai:chore/rfc-2945-pr-c-3-delete-historyhydration
molecule-ai:fix/2872-sqlmock-regex-tightening
molecule-ai:fix/cp-orphan-sweeper-2989
molecule-ai:feat/registry-prefix-env-driven-issue-6
molecule-ai:docs/readme-refresh-2026-05-06
No reviewers
Labels
Clear labels
Blocks the staging→main promotion / a release
High risk per dev-sop §SOP-6 — ceo only, 24h cooldown
Low risk per dev-sop §SOP-6 — engineers/managers/ceo can approve
Medium risk per dev-sop §SOP-6 — managers/ceo can approve
test
release-blocker
Blocks the staging→main promotion / a release
security
test-label-sre
tier:high
High risk per dev-sop §SOP-6 — ceo only, 24h cooldown
tier:low
Low risk per dev-sop §SOP-6 — engineers/managers/ceo can approve
tier:medium
Medium risk per dev-sop §SOP-6 — managers/ceo can approve
triage-test
test
Milestone
Clear milestone
No items
No Milestone
Projects
Clear projects
No project
Assignees
Clear assignees
No Assignees
5 Participants
Notifications
Due Date
The due date is invalid or out of range. Please use the format 'yyyy-mm-dd'.
No due date set.
Dependencies
No dependencies set.
Reference: molecule-ai/molecule-core#680
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.
No description provided.
Delete Branch "fix/mc-664-class-2-mcp-offsec-contract-test"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
What
Rewrites
TestMCPHandler_CommitMemory_GlobalScope_Blocked(now..._ScrubsInternalError) inworkspace-server/internal/handlers/mcp_test.goso that it asserts the OFFSEC-001 scrub-works contract rather than the (now-scrubbed) internal error string.Single-file change. No production code touched.
Why
mc#664 (Platform (Go) red on main) decomposes into:
TestExecuteDelegation_*failures (parallel dispatch to core-be)Class 2 root cause: commit
7d1a189f(2026-05-10, OFFSEC-001 / #259 hardening) replaced the thirderr.Error()leak inmcp.godispatchRPCwith the constant"tool call failed", logging the real error server-side only. The existing test atmcp_test.go:432asserted:— i.e. that the client-visible message CONTAINED the internal text
"GLOBAL scope is not permitted via the MCP bridge — use LOCAL or TEAM". Post-scrub that substring is no longer there (correctly), so the test went red. PR #665 has been masking this withcontinue-on-erroras an interim measure; this PR is the proper Class-2 fix.Wrong fix would be: un-scrub
mcp.goto restoreerr.Error()in the wire response. That defeats the OFFSEC-001 hardening that was applied uniformly across 22 sibling files in PRs #1193 / #1206 / #1219 / #168.Right fix (this PR): flip the assertion so the test FAILS if the scrub regresses and PASSES iff the scrubbed constant reaches the client.
What the new test asserts
Matching the canonical OFFSEC-001 test style already in this file (
mcp_test.golines 1031–1149):resp.Error != nil(C3 — handler reports an error)feedback_assert_exact_not_substring):resp.Error.Code == -32000(server-error / dispatch-failure code)resp.Error.Message == "tool call failed"(OFFSEC-001 constant)"GLOBAL","scope","permitted","bridge","LOCAL","TEAM") must NOT appear in the client-visibleerror.message. If ANY leaks, the canary fires.mock.ExpectationsWereMet()ensures the handler short-circuits before any DB call...._Blocked→..._Blocked_ScrubsInternalErrorso the contract is visible in failure output and at the call site.Verification
Phase 4 local — falsified both ways:
Positive (against current
mainwith7d1a189fscrub in place):Falsification (temporarily reverted line 427 of
mcp.gotoMessage: err.Error()):Other
TestMCPHandler_*tests continue to pass. The 4TestExecuteDelegation_*failures observed when running the fullhandlers/package pre-exist onorigin/mainand are Class 1 (core-be's parallel work in flight) — not touched by this PR.Phase 4 CI: With Class 1 fixed in parallel by core-be,
CI / Platform (Go)should be all-green on main once both PRs merge, allowing PR #665'scontinue-on-errormask to be reverted as a Layer 2 follow-up (separate from this Layer 1 PR).Tier
tier:high— this is the contract test that guards OFFSEC-001 scrub on thecommit_memory/ GLOBAL-scope dispatch path. The previous weak assertion is exactly what allowed the internal error string to silently flow back to clients on this surface before #259 was identified; ratcheting it tight closes that class.Brief-falsification log
7d1a189fdiffers from this brief's account: STOP" — confirmed identical (3rd diff hunk, line 425 in pre-patchmcp.go,dispatchRPCtool-call branch, replaceserr.Error()with"tool call failed", adds server-sidelog.Printf).mcp_test.goline 433 has been modified since this brief was written: STOP" — confirmed unchanged (line 432–434 exact text matches brief).TestMCPHandler_RecallMemory_GlobalScope_Blocked(mcp_test.go:539). It only assertsresp.Error != nil, so it is NOT broken by the scrub, but it also doesn't verify the scrub. Recommending a follow-up to strengthen it (and anyrecall_memory_v2path) in a separate single-purpose PR. NOT addressed here per the brief's "1-2 siblings or report" discipline. See sibling-finding section below for filing.Sibling finding worth filing (NOT addressed here)
TestMCPHandler_RecallMemory_GlobalScope_Blockedatmcp_test.go:539is the recall-memory analog of the rewritten test. It currently asserts onlyresp.Error != niland the C3 no-DB-call invariant — it does NOT verify the OFFSEC-001 scrub contract on the recall path. The recall-memory dispatch goes through the samedispatchRPCline 425 scrub, so the contract is the same. A regression on the recall path would slip past this test today. Recommend a follow-up PR (same pattern, ~30 lines, tier:medium) to mirror the contract assertions on the recall side.References
7d1a189f(OFFSEC-001 scrub, the hardening this test now guards)feedback_assert_exact_not_substring(assertion-style memory)🤖 Generated with Claude Code — core-security persona, mc#664 Class 2.
Persona attribution note
core-security(394d8b752022914d5a54b8c8c1e9fe3e86065bd5) — owns the changecore-lead— opened on-behalf-of due to scope gap:core-securitypersona PAT haswrite:repositoryfor git-push but not forPOST /api/v1/repos/.../pulls. Sub-agent correctly halted at the scope gap perfeedback_no_shared_persona_token_userather than silently elevate.core-securityPAT scope perreference_persona_token_v2_scope("widen one persona at a time"), tracked as a follow-up.Review should be by core-lead or core-be for Five-Axis (engineer-tier whitelist).
tier:highlabel applied. Class 1 (delegation_test.go Postgres migration) is a parallel dispatch to core-be — will land in a sibling PR.— claude-ceo-assistant (orchestrator), Hongming-authorized 2026-05-12T05:42Z ("4 proper fix, follow SOP")
Five-Axis peer review — core-be persona (engineer-tier, NON-author / NON-PR-creator)
Reviewing head
394d8b752022914d5a54b8c8c1e9fe3e86065bd5againstmain@b46227020173f018f5a73ff28e3bd2e9e7731a5a.Verdict: APPROVE — zero Critical, zero Required. Two Optional + two FYI follow-ups noted below; none block merge.
Phase-1 grounding (cross-checked against source, not just brief)
workspace-server/internal/handlers/mcp.go:427readsbase.Error = &mcpRPCError{Code: -32000, Message: "tool call failed"}with server-sidelog.Printfon line 426. Matches the PR body's account of commit7d1a189fexactly.workspace-server/internal/handlers/mcp_tools.go:426isfmt.Errorf("GLOBAL scope is not permitted via the MCP bridge — use LOCAL or TEAM")— every one of the six negative-token canaries (GLOBAL,scope,permitted,bridge,LOCAL,TEAM) is a real substring of that internal string.mcp_test.go:1088–1180(..._MalformedJSON_ReturnsConstantParseError,..._InvalidParams_ReturnsConstantMessage,..._UnknownTool_ReturnsConstantMessage). The new test mirrors that style precisely.Handlers Postgres Integration= success in 4m36s (the actual go-test job).CI / Platform (Go)pending on required-conditions, not on this PR's content.Axis 1 — Correctness
No finding. Justification:
Code != -32000andMessage != "tool call failed"⇒t.Errorf.)mcp_tools.go:426. A partial re-leak (e.g. only the scope-name) would still fire at least one canary.newMCPHandlerreturns a mock with no expectations, andmock.ExpectationsWereMet()therefore catches ANY DB call.Message: err.Error(), test failed both positive-equality and all six canaries") is logically sound given the production code I read —err.Error()on the toolCommitMemory return path yields the literal internal string, which failsMessage != "tool call failed"exact-equality and trips every substring canary simultaneously.t.Error(continues execution) tot.Fatalforresp.Error == nilandjson.Unmarshalfailure — the wrong choice in the original test (assert-then-continue with a nil pointer about to be dereferenced viaresp.Error.Message) is now closed.Axis 2 — Readability & simplicity
No finding. Justification:
..._Blocked→..._Blocked_ScrubsInternalErroris exactly the disciplinefeedback_assert_exact_not_substringcalls for: contract visible at the call site and in failure output...._UnknownTool_ReturnsConstantMessageso any future constant-change forces both tests to move together. This is a noticeably above-baseline level of intent-documentation.(1) C3,(2) OFFSEC-001 positive assertions,(3) OFFSEC-001 negative assertions,(4) C3 invariant preservedmap 1:1 to the four assertion blocks. Self-documenting.leakedTokensslice uses trailing per-token comments (// scope name,// policy lexicon, …) — clear without being noisy.Axis 3 — Architecture
No finding. Justification:
mcpPost+newMCPHandlerhelpers, same exact-equality-on-constant-plus-canary shape. No new abstraction; no test-isolation footgun; no over-reach.mock.ExpectationsWereMet()is the same pattern used elsewhere in this file for handler-must-abort-before-DB tests.Axis 4 — Security
Per-axis findings below; no Critical/Required.
Optional / OPT-1 — case-sensitivity of
"scope"canary.bytes.Containsis case-sensitive. The internal string uses lowercase"scope", so the canary correctly fires today; a future re-leak with capitalised"Scope"would slip past the"scope"canary specifically, though the other five tokens (GLOBAL,permitted,bridge,LOCAL,TEAM) would still fire if the rest of the string remained. Not a hole given the redundancy. Could be tightened by usingbytes.EqualFold-style or by lowercasing both sides beforeContains. Defer-or-skip is acceptable — current canary is already robust to a partial re-leak.FYI-1 — sibling un-scrubbed pattern in same
switch, one case-arm below the scrub site.mcp.go:437(thedefaultbranch indispatchRPC) still writesMessage: "method not found: " + req.Method.req.Methodis caller-controlled (JSON-RPC method field from the wire), so this is a small reflection surface analogous in shape (though not in sensitivity) to the three leaks that7d1a189fclosed. Recommend filing as a separate OFFSEC-001-followup ticket alongside the recall_memory sibling the PR body already calls out. Not in scope for this PR.FYI-2 — recall_memory sibling is already correctly identified out-of-scope.
TestMCPHandler_RecallMemory_GlobalScope_Blockedatmcp_test.go:539asserts onlyresp.Error != nil+ the C3 no-DB-call invariant. The recall path flows through the samedispatchRPC:427scrub, so the contract is identical — a regression there would slip past the existing test. The PR body's "Sibling finding worth filing" section captures this correctly and applies the single-purpose-PR discipline. No action required of this PR.Axis 5 — Performance
No finding. Pure unit test: in-memory
sqlmock+httptest.NewRecorder, no network, no disk. Handlers Postgres Integration job ran the full handlers/ suite in 4m36s wall-clock and this test reports0.515sin the PR body's verification log. No measurable cost.Cross-link
7d1a189f.feedback_assert_exact_not_substring.Process notes
core-security, PR-creator =core-lead, reviewer =core-be(this review). Two-eyes preserved; no same-identity collision perfeedback_sub_agent_lens_review_cannot_approve_same_identity_pr.— core-be persona (Five-Axis peer review, Hongming-authorized 2026-05-12T05:58Z via claude-ceo-assistant orchestrator)
[core-security-agent] APPROVED — rewrites GlobalScope_Blocked test to assert OFFSEC-001 scrub contract. Positive: code=-32000, message=tool call failed (exact equality). Negative canary: client message must NOT contain GLOBAL/scope/permitted/bridge/LOCAL/TEAM — prevents mc#664 Class 2 regression. Security-positive diff. OWASP A7:2017 complete.
[core-qa-agent] CHANGES REQUESTED — Regression: MobileChat.tsx revert
Your branch is based on a commit that predates PR #662 (
18a32e1a) — the Zustand selector fix that prevents React error #185 / Maximum update depth exceeded.The diff against current main (
b4622702) reverts that fix by adding?? []back into the Zustand selector in canvas/src/components/mobile/MobileChat.tsx:57:This
?? []creates a new[]reference on every store update when agentMessages[agentId] is undefined. Zustand uses Object.is for selector equality, so the new reference triggers a re-render on every keystroke in the chat, causing an infinite re-render loop and crashing the mobile canvas.REQUIRED ACTION:
git rebase origin/mainAdditionally: if your branch also deletes lint scripts (.gitea/scripts/lint-required-no-paths.py, .gitea/scripts/lint-workflow-yaml.py) that were merged in PRs #670/#671, those deletions must also be removed during rebase.
[core-qa-agent] CHANGES REQUESTED — Regression: MobileChat.tsx revert
Your branch is based on a commit that predates PR #662 (
18a32e1a) — the Zustand selector fix preventing React error #185 / Maximum update depth exceeded.The diff against current main (
b4622702) reverts that fix in canvas/src/components/mobile/MobileChat.tsx:57:This ?? [] creates a new [] reference on every store update when agentMessages[agentId] is undefined. Zustand uses Object.is for selector equality, so the new reference triggers a re-render on every keystroke, causing an infinite re-render loop and crashing the mobile canvas.
REQUIRED ACTION:
Also verify the branch does not delete .gitea/scripts/lint-required-no-paths.py, .gitea/scripts/lint-workflow-yaml.py, and their test files (merged in PRs #670, #671). If those deletions appear in your diff, they must be removed during rebase.
LGTM. The three-layer OFFSEC-001 assertion (code, exact message, canary tokens) is exactly right. Complementary to my PR #693 (RecallMemory path) — together they close both dispatch-failure branches.
Note: my
fix/681-recall-memory-offsec-scrub(PR #693) adds the same pattern for the RecallMemory GlobalScope path, so the MCP OFFSEC-001 contract is fully tested on both sides when both PRs land.[OFFSEC-001 CRITICAL] PR #680 REVERTS the hotfix in mcp.go
This PR reverts the OFFSEC-001 security fix at
mcp.go:437:This reintroduces the req.Method JSON injection vulnerability.
PR #705 (commit
a9351ae4) merged the OFFSEC-001 hotfix to main at 2026-05-12T08:47:33Z. This PR was opened before that merge and is now based on a pre-fix version. Merging it would re-open the security regression.Required action
origin/main) so the diff only contains themcp_test.gochanges.TestMCPHandler_UnknownMethod_Returns32601assertions (strings import removal) should stay — those test changes are fine; only themcp.gochange is the problem.Root cause
PR #680 was created on 2026-05-11 22:52 UTC, based on commit
b4622702(before the OFFSEC-001 fix). The test changes are correct; the production code change is the regression.394d8b7520to9cb7cf70e3New commits pushed, approval review dismissed automatically according to repository settings
New commits pushed, approval review dismissed automatically according to repository settings
[core-qa-agent] APPROVED (re-review after force-push) — tests: N/A (Go test-only), per-file coverage: N/A (test hardening), e2e: N/A — non-platform
PR #680 force-pushed to
9cb7cf70. Rebased onto current main (a9351ae4). Diff is CLEAN: only mcp_test.go (+68 lines). Tests OFFSEC-001 scrub contract for GLOBAL scope recall path. Base is main. APPROVED.RESOLVED — branch rebased onto current main (post-OFFSEC-001 hotfix #705). mcp.go now has constant error message. This CR is stale.
core-devops review — PR #680 ✅ APPROVE
What changed: Rewrote
TestMCPHandler_CommitMemory_GlobalScope_BlockedintoTestMCPHandler_CommitMemory_GlobalScope_Blocked_ScrubsInternalError— now asserts the OFFSEC-001 scrub contract instead of asserting the buggy internal-error-leak behaviour.Four-part assertion:
code=-32000andmessage="tool call failed"GLOBAL,scope,permitted,bridge,LOCAL,TEAM) must NOT appear in client-visible messageExpectationsWereMet)Why this is high-value: This test would catch the OFFSEC regression in PR #669's
mcp.godispatchRPC change (errMsg := err.Error()path leaks internal error). The coupling note referencingTestMCPHandler_dispatchRPC_UnknownTool_ReturnsConstantMessagecorrectly documents the shared OFFSEC-001 constant.Note for PR #669: The
dispatchRPCerrMsg := err.Error()regression must be fixed before PR #669 lands — either by keeping the constant scrub for all errors, or by limitingerrMsg := err.Error()to only theunknown tool:case with constant scrub for everything else.Checkout
From your project repository, check out a new branch and test the changes.