@opengsd/gsd-pi 1.2.0-dev.5457a158 → 1.2.0-dev.6ccd27b3
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/dist/cli-model-override.d.ts +15 -0
- package/dist/cli-model-override.js +21 -0
- package/dist/cli.js +1 -18
- package/dist/headless-events.js +7 -5
- package/dist/loader.js +6 -4
- package/dist/mcp-server.js +2 -1
- package/dist/register-agent-bundles.d.ts +11 -2
- package/dist/register-agent-bundles.js +18 -4
- package/dist/resource-loader.d.ts +10 -5
- package/dist/resource-loader.js +121 -6
- package/dist/resources/.managed-resources-content-hash +1 -1
- package/dist/resources/GSD-WORKFLOW.md +5 -4
- package/dist/resources/extensions/ask-user-questions.js +3 -2
- package/dist/resources/extensions/async-jobs/async-bash-tool.js +30 -64
- package/dist/resources/extensions/async-jobs/await-tool.js +80 -12
- package/dist/resources/extensions/async-jobs/index.js +65 -0
- package/dist/resources/extensions/async-jobs/job-manager.js +12 -1
- package/dist/resources/extensions/bg-shell/bg-shell-command.js +6 -6
- package/dist/resources/extensions/bg-shell/bg-shell-tool.js +10 -7
- package/dist/resources/extensions/bg-shell/overlay.js +9 -6
- package/dist/resources/extensions/bg-shell/process-manager.js +54 -25
- package/dist/resources/extensions/bg-shell/readiness-detector.js +11 -0
- package/dist/resources/extensions/browser-tools/engine/managed-gsd-browser.js +209 -88
- package/dist/resources/extensions/browser-tools/engine/selection.js +73 -5
- package/dist/resources/extensions/browser-tools/index.js +69 -12
- package/dist/resources/extensions/claude-code-cli/stream-adapter.js +450 -217
- package/dist/resources/extensions/claude-code-cli/turn-assembler.js +33 -1
- package/dist/resources/extensions/gsd/auto/closeout.js +215 -0
- package/dist/resources/extensions/gsd/auto/custom-verify-retry-store.js +17 -2
- package/dist/resources/extensions/gsd/auto/detect-stuck.js +33 -13
- package/dist/resources/extensions/gsd/auto/dispatch-history.js +120 -0
- package/dist/resources/extensions/gsd/auto/dispatch-key.js +37 -0
- package/dist/resources/extensions/gsd/auto/dispatch.js +365 -0
- package/dist/resources/extensions/gsd/auto/finalize.js +347 -0
- package/dist/resources/extensions/gsd/auto/loop.js +7 -1
- package/dist/resources/extensions/gsd/auto/milestone-lease-reclaim.js +56 -0
- package/dist/resources/extensions/gsd/auto/orchestrator.js +174 -69
- package/dist/resources/extensions/gsd/auto/phase-helpers.js +146 -0
- package/dist/resources/extensions/gsd/auto/phases.js +17 -2329
- package/dist/resources/extensions/gsd/auto/pre-dispatch.js +534 -0
- package/dist/resources/extensions/gsd/auto/session.js +3 -0
- package/dist/resources/extensions/gsd/auto/unit-phase.js +694 -0
- package/dist/resources/extensions/gsd/auto/workflow-unit-dispatch.js +1 -1
- package/dist/resources/extensions/gsd/auto/worktree-safety-phase.js +125 -0
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +11 -34
- package/dist/resources/extensions/gsd/auto-dispatch.js +50 -58
- package/dist/resources/extensions/gsd/auto-model-selection.js +36 -13
- package/dist/resources/extensions/gsd/auto-post-unit.js +30 -12
- package/dist/resources/extensions/gsd/auto-prompts.js +78 -19
- package/dist/resources/extensions/gsd/auto-start.js +35 -15
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +45 -21
- package/dist/resources/extensions/gsd/auto-unit-tool-scope.js +5 -4
- package/dist/resources/extensions/gsd/auto-verification.js +23 -30
- package/dist/resources/extensions/gsd/auto-worktree.js +15 -2
- package/dist/resources/extensions/gsd/auto.js +41 -2
- package/dist/resources/extensions/gsd/blocked-models.js +28 -0
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +26 -6
- package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +60 -13
- package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +2 -2
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +19 -0
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +172 -59
- package/dist/resources/extensions/gsd/bootstrap/write-gate.js +302 -80
- package/dist/resources/extensions/gsd/browser-daemon-auto-prep.js +83 -0
- package/dist/resources/extensions/gsd/browser-evidence.js +8 -2
- package/dist/resources/extensions/gsd/closeout-wizard.js +92 -0
- package/dist/resources/extensions/gsd/commands/context.js +16 -2
- package/dist/resources/extensions/gsd/commands-handlers.js +46 -3
- package/dist/resources/extensions/gsd/commands-mcp-status.js +2 -2
- package/dist/resources/extensions/gsd/commands-workflow-templates.js +9 -2
- package/dist/resources/extensions/gsd/consent-question.js +353 -0
- package/dist/resources/extensions/gsd/consent-verdict.js +63 -0
- package/dist/resources/extensions/gsd/constants.js +0 -2
- package/dist/resources/extensions/gsd/crash-recovery.js +8 -3
- package/dist/resources/extensions/gsd/db/queries.js +56 -0
- package/dist/resources/extensions/gsd/db-writer.js +8 -17
- package/dist/resources/extensions/gsd/dispatch-guard.js +10 -35
- package/dist/resources/extensions/gsd/doctor-engine-checks.js +5 -5
- package/dist/resources/extensions/gsd/doctor-environment.js +256 -125
- package/dist/resources/extensions/gsd/doctor-git-checks.js +2 -18
- package/dist/resources/extensions/gsd/engine-hook-contract.js +70 -0
- package/dist/resources/extensions/gsd/exec-sandbox.js +30 -10
- package/dist/resources/extensions/gsd/files.js +33 -19
- package/dist/resources/extensions/gsd/gsd-command-home.js +22 -12
- package/dist/resources/extensions/gsd/gsd-db.js +2 -1
- package/dist/resources/extensions/gsd/guidance.js +60 -0
- package/dist/resources/extensions/gsd/guided-flow.js +93 -4
- package/dist/resources/extensions/gsd/health-widget.js +87 -28
- package/dist/resources/extensions/gsd/markdown-renderer.js +10 -0
- package/dist/resources/extensions/gsd/mcp-bridge.js +10 -0
- package/dist/resources/extensions/gsd/mcp-filter.js +2 -19
- package/dist/resources/extensions/gsd/milestone-closeout.js +85 -24
- package/dist/resources/extensions/gsd/milestone-planning-persistence.js +2 -2
- package/dist/resources/extensions/gsd/milestone-reopen-events.js +3 -5
- package/dist/resources/extensions/gsd/milestone-settlement.js +2 -2
- package/dist/resources/extensions/gsd/notifications.js +12 -7
- package/dist/resources/extensions/gsd/parsers-legacy.js +16 -4
- package/dist/resources/extensions/gsd/preferences-models.js +2 -2
- package/dist/resources/extensions/gsd/projection-flush.js +7 -0
- package/dist/resources/extensions/gsd/prompts/complete-slice.md +4 -4
- package/dist/resources/extensions/gsd/prompts/execute-task.md +3 -2
- package/dist/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
- package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/quick-task.md +1 -1
- package/dist/resources/extensions/gsd/prompts/reassess-roadmap.md +1 -1
- package/dist/resources/extensions/gsd/prompts/refine-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/replan-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/research-milestone.md +1 -1
- package/dist/resources/extensions/gsd/prompts/research-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
- package/dist/resources/extensions/gsd/prompts/run-uat.md +9 -5
- package/dist/resources/extensions/gsd/prompts/system.md +5 -2
- package/dist/resources/extensions/gsd/prompts/triage-captures.md +1 -1
- package/dist/resources/extensions/gsd/prompts/validate-milestone.md +1 -1
- package/dist/resources/extensions/gsd/prompts/workflow-start.md +2 -1
- package/dist/resources/extensions/gsd/reactive-graph.js +8 -1
- package/dist/resources/extensions/gsd/roadmap-slices.js +25 -3
- package/dist/resources/extensions/gsd/safety/destructive-confirmation.js +108 -0
- package/dist/resources/extensions/gsd/session-lock.js +1 -1
- package/dist/resources/extensions/gsd/skill-activation.js +3 -6
- package/dist/resources/extensions/gsd/state.js +11 -2
- package/dist/resources/extensions/gsd/tool-contract.js +14 -3
- package/dist/resources/extensions/gsd/tool-presentation-plan.js +4 -4
- package/dist/resources/extensions/gsd/tool-surface-readiness.js +83 -31
- package/dist/resources/extensions/gsd/tools/complete-milestone.js +3 -2
- package/dist/resources/extensions/gsd/tools/complete-slice.js +22 -12
- package/dist/resources/extensions/gsd/tools/complete-task.js +65 -2
- package/dist/resources/extensions/gsd/tools/exec-tool.js +5 -0
- package/dist/resources/extensions/gsd/tools/plan-slice.js +2 -2
- package/dist/resources/extensions/gsd/tools/plan-task.js +2 -2
- package/dist/resources/extensions/gsd/tools/reassess-roadmap.js +2 -2
- package/dist/resources/extensions/gsd/tools/reopen-milestone.js +2 -2
- package/dist/resources/extensions/gsd/tools/reopen-slice.js +2 -2
- package/dist/resources/extensions/gsd/tools/reopen-task.js +2 -2
- package/dist/resources/extensions/gsd/tools/replan-slice.js +2 -2
- package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +67 -2
- package/dist/resources/extensions/gsd/uat-policy.js +42 -16
- package/dist/resources/extensions/gsd/unit-context-composer.js +65 -0
- package/dist/resources/extensions/gsd/unit-registry.js +41 -24
- package/dist/resources/extensions/gsd/verdict-parser.js +1 -1
- package/dist/resources/extensions/gsd/verification-verdict.js +2 -1
- package/dist/resources/extensions/gsd/web-app-uat.js +45 -8
- package/dist/resources/extensions/gsd/workflow-event-ledger.js +91 -0
- package/dist/resources/extensions/gsd/workflow-event-vocabulary.js +46 -0
- package/dist/resources/extensions/gsd/workflow-events.js +6 -18
- package/dist/resources/extensions/gsd/workflow-mcp-auto-prep.js +2 -0
- package/dist/resources/extensions/gsd/workflow-mcp-readiness-cache.js +105 -0
- package/dist/resources/extensions/gsd/workflow-reconcile.js +21 -56
- package/dist/resources/extensions/gsd/worktree-lifecycle.js +3 -2
- package/dist/resources/extensions/gsd/worktree-manager.js +7 -1
- package/dist/resources/extensions/gsd/worktree-safety.js +28 -26
- package/dist/resources/extensions/gsd/worktree.js +8 -1
- package/dist/resources/extensions/mcp-client/manager.js +6 -1
- package/dist/resources/extensions/search-the-web/native-search.js +5 -3
- package/dist/resources/extensions/shared/browser-contract.js +59 -0
- package/dist/resources/extensions/shared/gsd-browser-cli.js +116 -6
- package/dist/resources/shared/gsd-browser-path-sync.js +214 -0
- package/dist/resources/shared/package-manager-detection.js +1 -1
- package/dist/resources/shared/package.json +3 -0
- package/dist/resources/skills/create-skill/SKILL.md +3 -0
- package/dist/resources/skills/create-skill/references/executable-code.md +1 -1
- package/dist/resources/skills/create-skill/references/skill-structure.md +1 -0
- package/dist/resources/skills/create-skill/workflows/add-reference.md +8 -3
- package/dist/resources/skills/create-skill/workflows/add-script.md +4 -2
- package/dist/resources/skills/create-skill/workflows/add-template.md +3 -1
- package/dist/resources/skills/create-skill/workflows/add-workflow.md +8 -3
- package/dist/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
- package/dist/resources/skills/create-skill/workflows/verify-skill.md +9 -4
- package/dist/resources/skills/spike-wrap-up/SKILL.md +9 -9
- package/dist/runtime-checks.d.ts +10 -0
- package/dist/runtime-checks.js +27 -0
- package/dist/tsconfig.extensions.tsbuildinfo +1 -1
- package/dist/update-check.d.ts +2 -0
- package/dist/update-check.js +24 -1
- package/dist/update-cmd.js +20 -3
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +12 -12
- package/dist/web/standalone/.next/build-manifest.json +3 -3
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/index.html +1 -1
- package/dist/web/standalone/.next/server/app/index.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app-paths-manifest.json +12 -12
- package/dist/web/standalone/.next/server/chunks/8357.js +2 -2
- package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
- package/dist/web/standalone/.next/server/pages/404.html +1 -1
- package/dist/web/standalone/.next/server/pages/500.html +1 -1
- package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
- package/dist/web/standalone/.next/static/chunks/{796.cf859a427a2cb2ac.js → 796.e0bdc932325d7e03.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/{webpack-fbea77b5f9953368.js → webpack-f0285ce91d4ec9ef.js} +1 -1
- package/dist/web/standalone/node_modules/node-pty/build/Makefile +1 -1
- package/dist/web/standalone/package.json +1 -1
- package/package.json +3 -3
- package/packages/cloud-mcp-gateway/package.json +2 -2
- package/packages/contracts/dist/rpc.d.ts +1 -0
- package/packages/contracts/dist/rpc.d.ts.map +1 -1
- package/packages/contracts/dist/rpc.js.map +1 -1
- package/packages/contracts/package.json +1 -1
- package/packages/daemon/package.json +4 -4
- package/packages/gsd-agent-core/dist/sdk.d.ts.map +1 -1
- package/packages/gsd-agent-core/dist/sdk.js +6 -4
- package/packages/gsd-agent-core/dist/sdk.js.map +1 -1
- package/packages/gsd-agent-core/package.json +5 -5
- package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts +2 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js +10 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts +13 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js +55 -6
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.d.ts +2 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.js +34 -5
- package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js +7 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js +8 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js +11 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts +1 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js +12 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js +4 -4
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.js +4 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js +3 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js.map +1 -1
- package/packages/gsd-agent-modes/package.json +7 -7
- package/packages/mcp-server/README.md +12 -3
- package/packages/mcp-server/dist/cli-runner.d.ts +40 -0
- package/packages/mcp-server/dist/cli-runner.d.ts.map +1 -0
- package/packages/mcp-server/dist/cli-runner.js +137 -0
- package/packages/mcp-server/dist/cli-runner.js.map +1 -0
- package/packages/mcp-server/dist/cli.js +2 -53
- package/packages/mcp-server/dist/cli.js.map +1 -1
- package/packages/mcp-server/dist/moonshot-tool-schema.d.ts +29 -0
- package/packages/mcp-server/dist/moonshot-tool-schema.d.ts.map +1 -0
- package/packages/mcp-server/dist/moonshot-tool-schema.js +50 -0
- package/packages/mcp-server/dist/moonshot-tool-schema.js.map +1 -0
- package/packages/mcp-server/dist/pid-registry.d.ts +46 -0
- package/packages/mcp-server/dist/pid-registry.d.ts.map +1 -0
- package/packages/mcp-server/dist/pid-registry.js +452 -0
- package/packages/mcp-server/dist/pid-registry.js.map +1 -0
- package/packages/mcp-server/dist/probe-mode.d.ts +4 -0
- package/packages/mcp-server/dist/probe-mode.d.ts.map +1 -0
- package/packages/mcp-server/dist/probe-mode.js +10 -0
- package/packages/mcp-server/dist/probe-mode.js.map +1 -0
- package/packages/mcp-server/dist/server.d.ts.map +1 -1
- package/packages/mcp-server/dist/server.js +4 -0
- package/packages/mcp-server/dist/server.js.map +1 -1
- package/packages/mcp-server/dist/stdio-watchdog.d.ts +8 -0
- package/packages/mcp-server/dist/stdio-watchdog.d.ts.map +1 -0
- package/packages/mcp-server/dist/stdio-watchdog.js +40 -0
- package/packages/mcp-server/dist/stdio-watchdog.js.map +1 -0
- package/packages/mcp-server/dist/workflow-tools.d.ts +18 -18
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +161 -81
- package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
- package/packages/mcp-server/package.json +5 -4
- package/packages/native/package.json +1 -1
- package/packages/pi-agent-core/dist/agent-loop.js +43 -2
- package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
- package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts +1 -0
- package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/harness/env/nodejs.js +34 -3
- package/packages/pi-agent-core/dist/harness/env/nodejs.js.map +1 -1
- package/packages/pi-agent-core/dist/index.d.ts +1 -0
- package/packages/pi-agent-core/dist/index.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/index.js +3 -0
- package/packages/pi-agent-core/dist/index.js.map +1 -1
- package/packages/pi-agent-core/package.json +1 -1
- package/packages/pi-ai/README.md +1 -0
- package/packages/pi-ai/dist/image-models.generated.d.ts +2 -2
- package/packages/pi-ai/dist/image-models.generated.js +6 -6
- package/packages/pi-ai/dist/image-models.generated.js.map +1 -1
- package/packages/pi-ai/dist/index.d.ts +2 -0
- package/packages/pi-ai/dist/index.d.ts.map +1 -1
- package/packages/pi-ai/dist/index.js +2 -0
- package/packages/pi-ai/dist/index.js.map +1 -1
- package/packages/pi-ai/dist/models.generated.d.ts +239 -153
- package/packages/pi-ai/dist/models.generated.d.ts.map +1 -1
- package/packages/pi-ai/dist/models.generated.js +256 -145
- package/packages/pi-ai/dist/models.generated.js.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.js +12 -7
- package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
- package/packages/pi-ai/dist/providers/google-shared.d.ts +5 -0
- package/packages/pi-ai/dist/providers/google-shared.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/google-shared.js +12 -3
- package/packages/pi-ai/dist/providers/google-shared.js.map +1 -1
- package/packages/pi-ai/dist/providers/openai-completions.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/openai-completions.js +7 -3
- package/packages/pi-ai/dist/providers/openai-completions.js.map +1 -1
- package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts +9 -0
- package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts.map +1 -0
- package/packages/pi-ai/dist/utils/moonshot-tool-schema.js +34 -0
- package/packages/pi-ai/dist/utils/moonshot-tool-schema.js.map +1 -0
- package/packages/pi-ai/dist/utils/oauth/github-copilot.d.ts.map +1 -1
- package/packages/pi-ai/dist/utils/oauth/github-copilot.js +6 -2
- package/packages/pi-ai/dist/utils/oauth/github-copilot.js.map +1 -1
- package/packages/pi-ai/package.json +3 -2
- package/packages/pi-coding-agent/dist/core/auth-storage.d.ts +2 -2
- package/packages/pi-coding-agent/dist/core/auth-storage.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/auth-storage.js +19 -13
- package/packages/pi-coding-agent/dist/core/auth-storage.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/provider-readiness.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/provider-readiness.js +13 -6
- package/packages/pi-coding-agent/dist/core/provider-readiness.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +3 -0
- package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/settings-manager.js +11 -0
- package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/bash.d.ts +11 -0
- package/packages/pi-coding-agent/dist/core/tools/bash.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/bash.js +53 -11
- package/packages/pi-coding-agent/dist/core/tools/bash.js.map +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/index.js +1 -1
- package/packages/pi-coding-agent/dist/index.js.map +1 -1
- package/packages/pi-coding-agent/dist/theme/theme.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/theme/theme.js +45 -17
- package/packages/pi-coding-agent/dist/theme/theme.js.map +1 -1
- package/packages/pi-coding-agent/dist/utils/shell.d.ts +28 -2
- package/packages/pi-coding-agent/dist/utils/shell.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/utils/shell.js +56 -10
- package/packages/pi-coding-agent/dist/utils/shell.js.map +1 -1
- package/packages/pi-coding-agent/package.json +7 -7
- package/packages/pi-tui/dist/index.d.ts +1 -1
- package/packages/pi-tui/dist/index.d.ts.map +1 -1
- package/packages/pi-tui/dist/index.js +1 -1
- package/packages/pi-tui/dist/index.js.map +1 -1
- package/packages/pi-tui/dist/terminal-image.d.ts +33 -0
- package/packages/pi-tui/dist/terminal-image.d.ts.map +1 -1
- package/packages/pi-tui/dist/terminal-image.js +54 -2
- package/packages/pi-tui/dist/terminal-image.js.map +1 -1
- package/packages/pi-tui/dist/tui.d.ts +8 -0
- package/packages/pi-tui/dist/tui.d.ts.map +1 -1
- package/packages/pi-tui/dist/tui.js +72 -18
- package/packages/pi-tui/dist/tui.js.map +1 -1
- package/packages/pi-tui/dist/utils.d.ts.map +1 -1
- package/packages/pi-tui/dist/utils.js +110 -36
- package/packages/pi-tui/dist/utils.js.map +1 -1
- package/packages/pi-tui/package.json +2 -2
- package/packages/rpc-client/package.json +2 -2
- package/pkg/dist/theme/theme.d.ts.map +1 -1
- package/pkg/dist/theme/theme.js +45 -17
- package/pkg/dist/theme/theme.js.map +1 -1
- package/pkg/package.json +1 -1
- package/src/resources/GSD-WORKFLOW.md +5 -4
- package/src/resources/extensions/ask-user-questions.ts +7 -2
- package/src/resources/extensions/async-jobs/async-bash-cancel.test.ts +360 -0
- package/src/resources/extensions/async-jobs/async-bash-tool.ts +33 -56
- package/src/resources/extensions/async-jobs/await-tool.test.ts +139 -0
- package/src/resources/extensions/async-jobs/await-tool.ts +82 -12
- package/src/resources/extensions/async-jobs/index.ts +79 -0
- package/src/resources/extensions/async-jobs/job-manager.ts +21 -1
- package/src/resources/extensions/bg-shell/bg-shell-command.ts +6 -6
- package/src/resources/extensions/bg-shell/bg-shell-tool.ts +10 -6
- package/src/resources/extensions/bg-shell/overlay.ts +9 -5
- package/src/resources/extensions/bg-shell/process-manager.ts +50 -25
- package/src/resources/extensions/bg-shell/readiness-detector.ts +12 -0
- package/src/resources/extensions/bg-shell/tests/lifecycle-and-utilities.test.ts +48 -1
- package/src/resources/extensions/browser-tools/engine/managed-gsd-browser.ts +265 -98
- package/src/resources/extensions/browser-tools/engine/selection.ts +90 -4
- package/src/resources/extensions/browser-tools/index.ts +71 -13
- package/src/resources/extensions/browser-tools/tests/browser-engine-selection.test.mjs +83 -13
- package/src/resources/extensions/browser-tools/tests/gsd-browser-launch-config.test.mjs +40 -1
- package/src/resources/extensions/browser-tools/tests/managed-gsd-browser-tools.test.mjs +136 -0
- package/src/resources/extensions/claude-code-cli/stream-adapter.ts +534 -228
- package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +672 -7
- package/src/resources/extensions/claude-code-cli/turn-assembler.ts +38 -1
- package/src/resources/extensions/gsd/auto/closeout.ts +309 -0
- package/src/resources/extensions/gsd/auto/custom-verify-retry-store.ts +21 -3
- package/src/resources/extensions/gsd/auto/detect-stuck.ts +32 -9
- package/src/resources/extensions/gsd/auto/dispatch-history.ts +168 -0
- package/src/resources/extensions/gsd/auto/dispatch-key.ts +39 -0
- package/src/resources/extensions/gsd/auto/dispatch.ts +449 -0
- package/src/resources/extensions/gsd/auto/finalize.ts +445 -0
- package/src/resources/extensions/gsd/auto/loop.ts +7 -1
- package/src/resources/extensions/gsd/auto/milestone-lease-reclaim.ts +74 -0
- package/src/resources/extensions/gsd/auto/orchestrator.ts +193 -71
- package/src/resources/extensions/gsd/auto/phase-helpers.ts +199 -0
- package/src/resources/extensions/gsd/auto/phases.ts +58 -3022
- package/src/resources/extensions/gsd/auto/pre-dispatch.ts +704 -0
- package/src/resources/extensions/gsd/auto/session.ts +3 -0
- package/src/resources/extensions/gsd/auto/unit-phase.ts +910 -0
- package/src/resources/extensions/gsd/auto/workflow-unit-dispatch.ts +1 -1
- package/src/resources/extensions/gsd/auto/worktree-safety-phase.ts +149 -0
- package/src/resources/extensions/gsd/auto-direct-dispatch.ts +18 -48
- package/src/resources/extensions/gsd/auto-dispatch.ts +48 -61
- package/src/resources/extensions/gsd/auto-model-selection.ts +41 -12
- package/src/resources/extensions/gsd/auto-post-unit.ts +33 -12
- package/src/resources/extensions/gsd/auto-prompts.ts +115 -35
- package/src/resources/extensions/gsd/auto-start.ts +36 -18
- package/src/resources/extensions/gsd/auto-unit-closeout.ts +83 -28
- package/src/resources/extensions/gsd/auto-unit-tool-scope.ts +4 -4
- package/src/resources/extensions/gsd/auto-verification.ts +26 -28
- package/src/resources/extensions/gsd/auto-worktree.ts +15 -2
- package/src/resources/extensions/gsd/auto.ts +49 -2
- package/src/resources/extensions/gsd/blocked-models.ts +49 -0
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +34 -5
- package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +79 -12
- package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +2 -2
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +24 -0
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +211 -59
- package/src/resources/extensions/gsd/bootstrap/write-gate.ts +350 -86
- package/src/resources/extensions/gsd/browser-daemon-auto-prep.ts +108 -0
- package/src/resources/extensions/gsd/browser-evidence.ts +18 -2
- package/src/resources/extensions/gsd/closeout-wizard.ts +102 -0
- package/src/resources/extensions/gsd/commands/context.ts +16 -2
- package/src/resources/extensions/gsd/commands-handlers.ts +46 -3
- package/src/resources/extensions/gsd/commands-mcp-status.ts +2 -2
- package/src/resources/extensions/gsd/commands-workflow-templates.ts +11 -4
- package/src/resources/extensions/gsd/consent-question.ts +431 -0
- package/src/resources/extensions/gsd/consent-verdict.ts +86 -0
- package/src/resources/extensions/gsd/constants.ts +0 -3
- package/src/resources/extensions/gsd/crash-recovery.ts +10 -2
- package/src/resources/extensions/gsd/db/queries.ts +66 -0
- package/src/resources/extensions/gsd/db-writer.ts +11 -19
- package/src/resources/extensions/gsd/dispatch-guard.ts +8 -31
- package/src/resources/extensions/gsd/doctor-engine-checks.ts +5 -4
- package/src/resources/extensions/gsd/doctor-environment.ts +267 -142
- package/src/resources/extensions/gsd/doctor-git-checks.ts +2 -19
- package/src/resources/extensions/gsd/engine-hook-contract.ts +79 -0
- package/src/resources/extensions/gsd/exec-sandbox.ts +49 -9
- package/src/resources/extensions/gsd/files.ts +33 -12
- package/src/resources/extensions/gsd/gsd-command-home.ts +13 -3
- package/src/resources/extensions/gsd/gsd-db.ts +4 -3
- package/src/resources/extensions/gsd/guidance.ts +78 -0
- package/src/resources/extensions/gsd/guided-flow.ts +145 -24
- package/src/resources/extensions/gsd/health-widget.ts +91 -27
- package/src/resources/extensions/gsd/markdown-renderer.ts +11 -0
- package/src/resources/extensions/gsd/mcp-bridge.ts +39 -0
- package/src/resources/extensions/gsd/mcp-filter.ts +2 -23
- package/src/resources/extensions/gsd/milestone-closeout.ts +109 -24
- package/src/resources/extensions/gsd/milestone-planning-persistence.ts +2 -2
- package/src/resources/extensions/gsd/milestone-reopen-events.ts +3 -6
- package/src/resources/extensions/gsd/milestone-settlement.ts +2 -2
- package/src/resources/extensions/gsd/notifications.ts +13 -6
- package/src/resources/extensions/gsd/parsers-legacy.ts +16 -4
- package/src/resources/extensions/gsd/preferences-models.ts +2 -1
- package/src/resources/extensions/gsd/projection-flush.ts +20 -0
- package/src/resources/extensions/gsd/prompts/complete-slice.md +4 -4
- package/src/resources/extensions/gsd/prompts/execute-task.md +3 -2
- package/src/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
- package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/quick-task.md +1 -1
- package/src/resources/extensions/gsd/prompts/reassess-roadmap.md +1 -1
- package/src/resources/extensions/gsd/prompts/refine-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/replan-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/research-milestone.md +1 -1
- package/src/resources/extensions/gsd/prompts/research-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
- package/src/resources/extensions/gsd/prompts/run-uat.md +9 -5
- package/src/resources/extensions/gsd/prompts/system.md +5 -2
- package/src/resources/extensions/gsd/prompts/triage-captures.md +1 -1
- package/src/resources/extensions/gsd/prompts/validate-milestone.md +1 -1
- package/src/resources/extensions/gsd/prompts/workflow-start.md +2 -1
- package/src/resources/extensions/gsd/reactive-graph.ts +11 -1
- package/src/resources/extensions/gsd/roadmap-slices.ts +28 -3
- package/src/resources/extensions/gsd/safety/destructive-confirmation.ts +134 -0
- package/src/resources/extensions/gsd/session-lock.ts +1 -1
- package/src/resources/extensions/gsd/skill-activation.ts +3 -6
- package/src/resources/extensions/gsd/state.ts +12 -1
- package/src/resources/extensions/gsd/tests/auto-abort-pause-regression.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-blocked-remediation-message.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +206 -22
- package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +97 -1
- package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +273 -37
- package/src/resources/extensions/gsd/tests/auto-pause-double-entry-guard.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +51 -0
- package/src/resources/extensions/gsd/tests/auto-phases-lifecycle.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/auto-remote-session-lock-cleanup.test.ts +65 -3
- package/src/resources/extensions/gsd/tests/auto-start-orphan-bootstrap.test.ts +236 -0
- package/src/resources/extensions/gsd/tests/auto-unit-closeout.test.ts +169 -1
- package/src/resources/extensions/gsd/tests/blocked-models.test.ts +19 -0
- package/src/resources/extensions/gsd/tests/browser-automation-contract-fixture.ts +39 -0
- package/src/resources/extensions/gsd/tests/browser-contract.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/browser-daemon-auto-prep.test.ts +144 -0
- package/src/resources/extensions/gsd/tests/complete-slice-verification-gate.test.ts +42 -0
- package/src/resources/extensions/gsd/tests/complete-task.test.ts +141 -5
- package/src/resources/extensions/gsd/tests/consent-question.test.ts +351 -0
- package/src/resources/extensions/gsd/tests/custom-verify-retry-store.test.ts +67 -0
- package/src/resources/extensions/gsd/tests/db-writer.test.ts +15 -4
- package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +12 -11
- package/src/resources/extensions/gsd/tests/derive-state-helpers.test.ts +36 -0
- package/src/resources/extensions/gsd/tests/destructive-confirmation.test.ts +303 -0
- package/src/resources/extensions/gsd/tests/discuss-routing-fixes.test.ts +12 -2
- package/src/resources/extensions/gsd/tests/dispatch-history.test.ts +328 -0
- package/src/resources/extensions/gsd/tests/dispatch-run-uat-browser-tools.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/dist-redirect.mjs +8 -0
- package/src/resources/extensions/gsd/tests/doctor-git-checks-terminal.test.ts +73 -0
- package/src/resources/extensions/gsd/tests/dynamic-bash-no-cap.test.ts +132 -0
- package/src/resources/extensions/gsd/tests/engine-hook-contract.test.ts +148 -0
- package/src/resources/extensions/gsd/tests/engine-interfaces-contract.test.ts +117 -91
- package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +113 -0
- package/src/resources/extensions/gsd/tests/exec-graceful-kill.test.ts +193 -0
- package/src/resources/extensions/gsd/tests/exec-tool.test.ts +29 -1
- package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +35 -1
- package/src/resources/extensions/gsd/tests/gsd-command-home.test.ts +120 -0
- package/src/resources/extensions/gsd/tests/gsd-db.test.ts +27 -0
- package/src/resources/extensions/gsd/tests/guidance.test.ts +23 -0
- package/src/resources/extensions/gsd/tests/guided-dispatch-root.test.ts +18 -6
- package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +7 -11
- package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +35 -58
- package/src/resources/extensions/gsd/tests/integration/doctor-environment-async.test.ts +104 -0
- package/src/resources/extensions/gsd/tests/integration/gsd-integration-fixture.ts +80 -0
- package/src/resources/extensions/gsd/tests/integration/run-uat.test.ts +217 -0
- package/src/resources/extensions/gsd/tests/journal-integration.test.ts +47 -16
- package/src/resources/extensions/gsd/tests/mcp-project-config.test.ts +3 -1
- package/src/resources/extensions/gsd/tests/mcp-readiness-preflight.test.ts +205 -0
- package/src/resources/extensions/gsd/tests/mcp-status.test.ts +6 -5
- package/src/resources/extensions/gsd/tests/milestone-closeout.test.ts +95 -4
- package/src/resources/extensions/gsd/tests/milestone-merge-stash-restore.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/milestone-report-path.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/milestone-settlement.test.ts +92 -0
- package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +32 -1
- package/src/resources/extensions/gsd/tests/notifications.test.ts +64 -9
- package/src/resources/extensions/gsd/tests/oauth-api-model-routing.test.ts +167 -0
- package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +18 -0
- package/src/resources/extensions/gsd/tests/parallel-skill-prompt-integration.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/parsers-legacy-importers.test.ts +143 -0
- package/src/resources/extensions/gsd/tests/phases-merge-error-stops-auto.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/phases-terminal-complete-idempotent.test.ts +242 -0
- package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +3 -3
- package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +63 -2
- package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +10 -2
- package/src/resources/extensions/gsd/tests/prompt-db.test.ts +124 -6
- package/src/resources/extensions/gsd/tests/provider-errors.test.ts +2 -4
- package/src/resources/extensions/gsd/tests/remote-notification-from-desktop.test.ts +31 -81
- package/src/resources/extensions/gsd/tests/roadmap-slices.test.ts +68 -0
- package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +26 -2
- package/src/resources/extensions/gsd/tests/skill-activation.test.ts +20 -17
- package/src/resources/extensions/gsd/tests/start-auto-detached.test.ts +7 -3
- package/src/resources/extensions/gsd/tests/stop-auto-race-null-unit.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/teardown-chdir-failure-clears-registry.test.ts +17 -0
- package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +80 -2
- package/src/resources/extensions/gsd/tests/tool-surface-readiness.test.ts +184 -10
- package/src/resources/extensions/gsd/tests/tool-unavailable-retry.test.ts +33 -0
- package/src/resources/extensions/gsd/tests/transport-gate-double-complete.test.ts +139 -0
- package/src/resources/extensions/gsd/tests/uat-policy.test.ts +112 -29
- package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/uok-audit-unified.test.ts +8 -0
- package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/verification-verdict.test.ts +2 -0
- package/src/resources/extensions/gsd/tests/web-app-uat.test.ts +44 -1
- package/src/resources/extensions/gsd/tests/workflow-events.test.ts +19 -0
- package/src/resources/extensions/gsd/tests/workflow-mcp-readiness-cache.test.ts +119 -0
- package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +65 -2
- package/src/resources/extensions/gsd/tests/workflow-phase-contract-matrix.test.ts +332 -0
- package/src/resources/extensions/gsd/tests/workflow-reconcile.test.ts +20 -0
- package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +92 -0
- package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +273 -38
- package/src/resources/extensions/gsd/tests/worktree-health-dispatch.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/worktree-project-root-degrade.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/worktree-safety-phase.test.ts +100 -0
- package/src/resources/extensions/gsd/tests/worktree-safety.test.ts +72 -0
- package/src/resources/extensions/gsd/tests/worktree-teardown-safety.test.ts +22 -0
- package/src/resources/extensions/gsd/tests/worktree.test.ts +18 -0
- package/src/resources/extensions/gsd/tests/write-gate-seam.test.ts +358 -0
- package/src/resources/extensions/gsd/tests/write-gate.test.ts +67 -1
- package/src/resources/extensions/gsd/tool-contract.ts +38 -3
- package/src/resources/extensions/gsd/tool-presentation-plan.ts +4 -4
- package/src/resources/extensions/gsd/tool-surface-readiness.ts +126 -19
- package/src/resources/extensions/gsd/tools/complete-milestone.ts +3 -2
- package/src/resources/extensions/gsd/tools/complete-slice.ts +22 -12
- package/src/resources/extensions/gsd/tools/complete-task.ts +90 -2
- package/src/resources/extensions/gsd/tools/exec-tool.ts +4 -0
- package/src/resources/extensions/gsd/tools/plan-slice.ts +2 -2
- package/src/resources/extensions/gsd/tools/plan-task.ts +2 -2
- package/src/resources/extensions/gsd/tools/reassess-roadmap.ts +2 -2
- package/src/resources/extensions/gsd/tools/reopen-milestone.ts +2 -2
- package/src/resources/extensions/gsd/tools/reopen-slice.ts +2 -2
- package/src/resources/extensions/gsd/tools/reopen-task.ts +2 -2
- package/src/resources/extensions/gsd/tools/replan-slice.ts +2 -2
- package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +81 -2
- package/src/resources/extensions/gsd/uat-policy.ts +62 -16
- package/src/resources/extensions/gsd/unit-context-composer.ts +99 -0
- package/src/resources/extensions/gsd/unit-registry.ts +41 -24
- package/src/resources/extensions/gsd/verdict-parser.ts +1 -1
- package/src/resources/extensions/gsd/verification-verdict.ts +4 -2
- package/src/resources/extensions/gsd/web-app-uat.ts +51 -8
- package/src/resources/extensions/gsd/workflow-event-ledger.ts +131 -0
- package/src/resources/extensions/gsd/workflow-event-vocabulary.ts +59 -0
- package/src/resources/extensions/gsd/workflow-events.ts +12 -20
- package/src/resources/extensions/gsd/workflow-mcp-auto-prep.ts +2 -0
- package/src/resources/extensions/gsd/workflow-mcp-readiness-cache.ts +150 -0
- package/src/resources/extensions/gsd/workflow-reconcile.ts +29 -62
- package/src/resources/extensions/gsd/worktree-lifecycle.ts +3 -8
- package/src/resources/extensions/gsd/worktree-manager.ts +6 -1
- package/src/resources/extensions/gsd/worktree-safety.ts +41 -39
- package/src/resources/extensions/gsd/worktree.ts +7 -1
- package/src/resources/extensions/mcp-client/manager.ts +7 -1
- package/src/resources/extensions/search-the-web/native-search.ts +5 -3
- package/src/resources/extensions/shared/browser-contract.ts +66 -0
- package/src/resources/extensions/shared/gsd-browser-cli.ts +141 -6
- package/src/resources/shared/gsd-browser-path-sync.ts +273 -0
- package/src/resources/shared/package-manager-detection.ts +1 -1
- package/src/resources/shared/package.json +3 -0
- package/src/resources/skills/create-skill/SKILL.md +3 -0
- package/src/resources/skills/create-skill/references/executable-code.md +1 -1
- package/src/resources/skills/create-skill/references/skill-structure.md +1 -0
- package/src/resources/skills/create-skill/workflows/add-reference.md +8 -3
- package/src/resources/skills/create-skill/workflows/add-script.md +4 -2
- package/src/resources/skills/create-skill/workflows/add-template.md +3 -1
- package/src/resources/skills/create-skill/workflows/add-workflow.md +8 -3
- package/src/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
- package/src/resources/skills/create-skill/workflows/verify-skill.md +9 -4
- package/src/resources/skills/spike-wrap-up/SKILL.md +9 -9
- package/dist/resources/extensions/gsd/user-input-boundary.js +0 -218
- package/dist/resources/skills/gsd-browser/SKILL.md +0 -41
- package/src/resources/extensions/gsd/tests/user-input-boundary.test.ts +0 -173
- package/src/resources/extensions/gsd/user-input-boundary.ts +0 -216
- package/src/resources/skills/gsd-browser/SKILL.md +0 -41
- /package/dist/web/standalone/.next/static/{2p9Rv9pQflAxCBbGVI2vb → avEtvPrImYTq2gGe-hVNp}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{2p9Rv9pQflAxCBbGVI2vb → avEtvPrImYTq2gGe-hVNp}/_ssgManifest.js +0 -0
|
@@ -7,6 +7,10 @@ const require = createRequire(import.meta.url);
|
|
|
7
7
|
const ROOT = new URL("../../../../../", import.meta.url);
|
|
8
8
|
|
|
9
9
|
export function resolve(specifier, context, nextResolve) {
|
|
10
|
+
if (specifier.startsWith('node:')) {
|
|
11
|
+
return { url: specifier, format: 'builtin', shortCircuit: true };
|
|
12
|
+
}
|
|
13
|
+
|
|
10
14
|
// 1. Redirect all workspace package bare imports to source.
|
|
11
15
|
// CI portability runs don't build any packages/ dist artifacts, so every
|
|
12
16
|
// @gsd/* specifier (including transitive ones pulled in by pi-coding-agent
|
|
@@ -100,6 +104,10 @@ export function resolve(specifier, context, nextResolve) {
|
|
|
100
104
|
}
|
|
101
105
|
|
|
102
106
|
export function load(url, context, nextLoad) {
|
|
107
|
+
if (url.startsWith('node:') || context.format === 'builtin') {
|
|
108
|
+
return { format: 'builtin', source: '', shortCircuit: true };
|
|
109
|
+
}
|
|
110
|
+
|
|
103
111
|
// jiti/CJS may still enter through stale packages/*/dist/index.js — redirect to src.
|
|
104
112
|
if (url.includes('/packages/pi-ai/dist/index.js')) {
|
|
105
113
|
url = url.replace('/dist/index.js', '/src/index.ts');
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
// Project/App: gsd-pi
|
|
2
|
+
// File Purpose: Doctor git checks treat validation-pass closeout as terminal without SUMMARY.
|
|
3
|
+
|
|
4
|
+
import test from "node:test";
|
|
5
|
+
import assert from "node:assert/strict";
|
|
6
|
+
import { execFileSync } from "node:child_process";
|
|
7
|
+
import { existsSync, mkdirSync, mkdtempSync, rmSync, writeFileSync } from "node:fs";
|
|
8
|
+
import { tmpdir } from "node:os";
|
|
9
|
+
import { join } from "node:path";
|
|
10
|
+
|
|
11
|
+
import { runGSDDoctor } from "../doctor.ts";
|
|
12
|
+
import { openDatabase, insertMilestone, insertSlice, insertAssessment, closeDatabase } from "../gsd-db.js";
|
|
13
|
+
import { createWorktree, worktreePath } from "../worktree-manager.ts";
|
|
14
|
+
|
|
15
|
+
function runGit(args: string[], cwd: string): string {
|
|
16
|
+
return execFileSync("git", args, {
|
|
17
|
+
cwd,
|
|
18
|
+
stdio: ["ignore", "pipe", "pipe"],
|
|
19
|
+
encoding: "utf-8",
|
|
20
|
+
}).trim();
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
function makeRepo(): string {
|
|
24
|
+
const base = mkdtempSync(join(tmpdir(), "gsd-doctor-terminal-"));
|
|
25
|
+
runGit(["init", "-b", "main"], base);
|
|
26
|
+
runGit(["config", "user.name", "Test User"], base);
|
|
27
|
+
runGit(["config", "user.email", "test@example.com"], base);
|
|
28
|
+
writeFileSync(join(base, "package.json"), "{\"scripts\":{}}\n", "utf-8");
|
|
29
|
+
runGit(["add", "."], base);
|
|
30
|
+
runGit(["commit", "-m", "chore: init"], base);
|
|
31
|
+
return base;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
test.after(() => {
|
|
35
|
+
closeDatabase();
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
test("doctor flags orphaned worktree for DB-complete milestone without SUMMARY", async (t) => {
|
|
39
|
+
const base = makeRepo();
|
|
40
|
+
t.after(() => rmSync(base, { recursive: true, force: true }));
|
|
41
|
+
|
|
42
|
+
mkdirSync(join(base, ".gsd"), { recursive: true });
|
|
43
|
+
openDatabase(join(base, ".gsd", "gsd.db"));
|
|
44
|
+
insertMilestone({ id: "M008", title: "Done", status: "complete" });
|
|
45
|
+
insertSlice({ id: "S01", milestoneId: "M008", title: "Slice", status: "complete" });
|
|
46
|
+
insertAssessment({
|
|
47
|
+
path: "milestones/M008/M008-VALIDATION.md",
|
|
48
|
+
milestoneId: "M008",
|
|
49
|
+
status: "pass",
|
|
50
|
+
scope: "milestone-validation",
|
|
51
|
+
fullContent: "verdict: pass",
|
|
52
|
+
});
|
|
53
|
+
writeFileSync(
|
|
54
|
+
join(base, ".gsd", "PREFERENCES.md"),
|
|
55
|
+
"---\ngit:\n isolation: worktree\n---\n",
|
|
56
|
+
);
|
|
57
|
+
mkdirSync(join(base, ".gsd", "milestones", "M008"), { recursive: true });
|
|
58
|
+
writeFileSync(
|
|
59
|
+
join(base, ".gsd", "milestones", "M008", "M008-ROADMAP.md"),
|
|
60
|
+
"# M008 Roadmap\n\n- [x] **S01: Slice** `risk:low` `depends:[]`\n",
|
|
61
|
+
);
|
|
62
|
+
|
|
63
|
+
createWorktree(base, "M008", { branch: "milestone/M008" });
|
|
64
|
+
const wtPath = worktreePath(base, "M008");
|
|
65
|
+
assert.ok(existsSync(wtPath), "worktree should exist for the test");
|
|
66
|
+
|
|
67
|
+
const report = await runGSDDoctor(base, { isolationMode: "worktree" });
|
|
68
|
+
|
|
69
|
+
assert.ok(
|
|
70
|
+
report.issues.some((issue) => issue.code === "orphaned_auto_worktree" && issue.unitId === "M008"),
|
|
71
|
+
"doctor should treat DB-complete milestone without SUMMARY as terminal for cleanup",
|
|
72
|
+
);
|
|
73
|
+
});
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import test from "node:test";
|
|
2
|
+
import assert from "node:assert/strict";
|
|
3
|
+
|
|
4
|
+
import { createBashTool } from "@gsd/pi-coding-agent";
|
|
5
|
+
|
|
6
|
+
import { registerDynamicTools } from "../bootstrap/dynamic-tools.ts";
|
|
7
|
+
import { createAsyncBashTool } from "../../async-jobs/async-bash-tool.ts";
|
|
8
|
+
|
|
9
|
+
// These tests assert on the runtime tool objects the agent actually receives —
|
|
10
|
+
// the registered GSD bash tool, the core bash tool, and the async_bash tool —
|
|
11
|
+
// not on source text. The behavioral guarantee (an explicit timeout still
|
|
12
|
+
// fires after the silent 120s cap was removed) is exercised by spawning a real
|
|
13
|
+
// process at the bottom of the file.
|
|
14
|
+
|
|
15
|
+
/** Capture the GSD-registered `bash` tool object from registerDynamicTools. */
|
|
16
|
+
function registerAndCaptureBash(): any {
|
|
17
|
+
let captured: any = undefined;
|
|
18
|
+
const pi = {
|
|
19
|
+
registerTool: (tool: any) => {
|
|
20
|
+
if (!captured && tool && tool.name === "bash") captured = tool;
|
|
21
|
+
},
|
|
22
|
+
};
|
|
23
|
+
registerDynamicTools(pi as any);
|
|
24
|
+
assert.ok(captured, "registerDynamicTools must register a tool named 'bash'");
|
|
25
|
+
return captured;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
// 1. Cap removal: the GSD bash tool no longer injects a default timeout. The
|
|
29
|
+
// schema's timeout stays optional (no `default`), so an omitted timeout
|
|
30
|
+
// means "no timeout" rather than a silent 120s cap.
|
|
31
|
+
test("GSD bash tool exposes an optional timeout with no injected default", () => {
|
|
32
|
+
const bash = registerAndCaptureBash();
|
|
33
|
+
const timeout = bash.parameters?.properties?.timeout;
|
|
34
|
+
assert.ok(timeout, "bash tool must expose a `timeout` parameter");
|
|
35
|
+
assert.equal(
|
|
36
|
+
"default" in timeout,
|
|
37
|
+
false,
|
|
38
|
+
"the timeout schema must not carry a default — an omitted timeout means uncapped",
|
|
39
|
+
);
|
|
40
|
+
assert.equal(
|
|
41
|
+
bash.parameters?.required?.includes?.("timeout") ?? false,
|
|
42
|
+
false,
|
|
43
|
+
"timeout must remain optional",
|
|
44
|
+
);
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
// 2. Watchdog verbiage is GSD-scoped: the core bash tool (reused by non-GSD
|
|
48
|
+
// embeddings with no watchdog) must NOT claim a watchdog, while the
|
|
49
|
+
// GSD-registered tool injects it into both description and timeout schema.
|
|
50
|
+
test("core bash tool does not advertise the auto-mode watchdog", () => {
|
|
51
|
+
const core = createBashTool(process.cwd(), { spawnHook: (c: any) => c });
|
|
52
|
+
assert.equal(
|
|
53
|
+
/stalled-tool watchdog/.test(core.description ?? ""),
|
|
54
|
+
false,
|
|
55
|
+
"core bash must not advertise a watchdog — non-GSD embeddings have none",
|
|
56
|
+
);
|
|
57
|
+
assert.equal(
|
|
58
|
+
/stalled-tool watchdog/.test(
|
|
59
|
+
(core.parameters as any)?.properties?.timeout?.description ?? "",
|
|
60
|
+
),
|
|
61
|
+
false,
|
|
62
|
+
"core bash timeout schema must not advertise a watchdog",
|
|
63
|
+
);
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
test("GSD-registered bash tool advertises the stalled-tool watchdog", () => {
|
|
67
|
+
const bash = registerAndCaptureBash();
|
|
68
|
+
assert.equal(
|
|
69
|
+
/stalled-tool watchdog/.test(bash.description ?? ""),
|
|
70
|
+
true,
|
|
71
|
+
"the GSD bash description must name the stalled-tool watchdog",
|
|
72
|
+
);
|
|
73
|
+
assert.equal(
|
|
74
|
+
/stalled-tool watchdog/.test(
|
|
75
|
+
bash.parameters?.properties?.timeout?.description ?? "",
|
|
76
|
+
),
|
|
77
|
+
true,
|
|
78
|
+
"the GSD bash timeout schema must name the stalled-tool watchdog",
|
|
79
|
+
);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
// 3. async_bash guidance frames itself as a non-blocking/background choice and
|
|
83
|
+
// no longer implies sync bash is time-capped.
|
|
84
|
+
test("async_bash guidance is non-blocking and drops the sync-cap implication", () => {
|
|
85
|
+
const asyncTool: any = createAsyncBashTool(
|
|
86
|
+
() => ({ register: () => "job-0" }) as any,
|
|
87
|
+
() => process.cwd(),
|
|
88
|
+
);
|
|
89
|
+
const guidance = (asyncTool.promptGuidelines ?? []).join("\n");
|
|
90
|
+
assert.equal(
|
|
91
|
+
/more than a few seconds/.test(guidance),
|
|
92
|
+
false,
|
|
93
|
+
"async_bash guidance must not imply sync bash is time-capped",
|
|
94
|
+
);
|
|
95
|
+
assert.equal(
|
|
96
|
+
/non-blocking/.test(guidance),
|
|
97
|
+
true,
|
|
98
|
+
"async_bash guidance must describe itself as non-blocking",
|
|
99
|
+
);
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
// 4. Behavioral passthrough: an explicitly-set timeout is still honored after
|
|
103
|
+
// the cap removal. A 1s timeout on a 5s sleep must fire well under 5s.
|
|
104
|
+
test("GSD bash still forwards an explicit timeout (cap removal did not break passthrough)", async () => {
|
|
105
|
+
const bash = registerAndCaptureBash();
|
|
106
|
+
|
|
107
|
+
const start = Date.now();
|
|
108
|
+
let resultText = "";
|
|
109
|
+
try {
|
|
110
|
+
const result: any = await bash.execute(
|
|
111
|
+
"t1",
|
|
112
|
+
{ command: "sleep 5", timeout: 1 },
|
|
113
|
+
undefined,
|
|
114
|
+
undefined,
|
|
115
|
+
{ cwd: process.cwd() },
|
|
116
|
+
);
|
|
117
|
+
resultText = JSON.stringify(result ?? "");
|
|
118
|
+
} catch (err) {
|
|
119
|
+
resultText = String(err instanceof Error ? err.message : err);
|
|
120
|
+
}
|
|
121
|
+
const elapsed = Date.now() - start;
|
|
122
|
+
|
|
123
|
+
assert.equal(
|
|
124
|
+
/timed out|timeout|exited with code|force-killed/i.test(resultText),
|
|
125
|
+
true,
|
|
126
|
+
`explicit 1s timeout should fire before the 5s sleep completes; got: ${resultText}`,
|
|
127
|
+
);
|
|
128
|
+
assert.ok(
|
|
129
|
+
elapsed < 4500,
|
|
130
|
+
`explicit timeout should fire quickly, not run to completion (elapsed ${elapsed}ms)`,
|
|
131
|
+
);
|
|
132
|
+
});
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
// Engine hook contract: which tool lifecycle hooks fire under which engine,
|
|
2
|
+
// and the consolidated tool-name normalizer seam.
|
|
3
|
+
//
|
|
4
|
+
// 1. Pins the contract arrays (engine-hook-contract.ts) so a change to the
|
|
5
|
+
// fire matrix is a deliberate, reviewed act.
|
|
6
|
+
// 2. Source-scans register-hooks.ts (in the style of
|
|
7
|
+
// single-writer-invariant.test.ts) to assert that the concerns documented
|
|
8
|
+
// as universally mirrored — evidence collection and write-gate (re-)arming —
|
|
9
|
+
// actually live inside a tool_execution_start handler, not only in the
|
|
10
|
+
// native-only tool_call handlers.
|
|
11
|
+
// 3. Pins normalizer parity: canonicalHeadlessToolName delegates to
|
|
12
|
+
// canonicalToolName (strip-only), and canonicalWorkflowToolName adds alias
|
|
13
|
+
// resolution on top of the same strip.
|
|
14
|
+
|
|
15
|
+
import test from "node:test";
|
|
16
|
+
import assert from "node:assert/strict";
|
|
17
|
+
import { readFileSync } from "node:fs";
|
|
18
|
+
import { join } from "node:path";
|
|
19
|
+
|
|
20
|
+
import {
|
|
21
|
+
UNIVERSAL_TOOL_HOOKS,
|
|
22
|
+
NATIVE_ONLY_TOOL_HOOKS,
|
|
23
|
+
canonicalToolName,
|
|
24
|
+
canonicalWorkflowToolName,
|
|
25
|
+
} from "../engine-hook-contract.js";
|
|
26
|
+
import { canonicalHeadlessToolName } from "../../../../headless-events.js";
|
|
27
|
+
import { WORKFLOW_TOOL_ALIAS_PAIRS } from "../workflow-tool-surface.js";
|
|
28
|
+
|
|
29
|
+
test("contract arrays pin the verified fire matrix", () => {
|
|
30
|
+
assert.deepEqual([...UNIVERSAL_TOOL_HOOKS], ["tool_execution_start", "tool_execution_end"]);
|
|
31
|
+
assert.deepEqual([...NATIVE_ONLY_TOOL_HOOKS], ["tool_call", "tool_result"]);
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
// ---------------------------------------------------------------------------
|
|
35
|
+
// Source scan: register-hooks.ts must mirror safety concerns universally
|
|
36
|
+
// ---------------------------------------------------------------------------
|
|
37
|
+
|
|
38
|
+
const registerHooksSource = readFileSync(
|
|
39
|
+
join(process.cwd(), "src/resources/extensions/gsd/bootstrap/register-hooks.ts"),
|
|
40
|
+
"utf8",
|
|
41
|
+
);
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Extract the body of every `pi.on("<eventName>", ...)` registration by
|
|
45
|
+
* scanning balanced parentheses from each registration site.
|
|
46
|
+
*/
|
|
47
|
+
function hookBodies(source: string, eventName: string): string[] {
|
|
48
|
+
const bodies: string[] = [];
|
|
49
|
+
const marker = `pi.on("${eventName}"`;
|
|
50
|
+
let from = 0;
|
|
51
|
+
for (;;) {
|
|
52
|
+
const start = source.indexOf(marker, from);
|
|
53
|
+
if (start < 0) break;
|
|
54
|
+
let depth = 0;
|
|
55
|
+
let end = -1;
|
|
56
|
+
// Scan from pi.on's own opening paren so the whole registration is balanced.
|
|
57
|
+
for (let i = start + "pi.on".length; i < source.length; i++) {
|
|
58
|
+
const ch = source[i];
|
|
59
|
+
if (ch === "(") depth++;
|
|
60
|
+
else if (ch === ")") {
|
|
61
|
+
depth--;
|
|
62
|
+
if (depth === 0) {
|
|
63
|
+
end = i;
|
|
64
|
+
break;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
assert.ok(end > start, `unbalanced pi.on("${eventName}") registration`);
|
|
69
|
+
bodies.push(source.slice(start, end + 1));
|
|
70
|
+
from = end + 1;
|
|
71
|
+
}
|
|
72
|
+
return bodies;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
test("tool_execution_start handler mirrors evidence collection and write-gate arming", () => {
|
|
76
|
+
const bodies = hookBodies(registerHooksSource, "tool_execution_start");
|
|
77
|
+
assert.ok(bodies.length >= 1, "register-hooks.ts must register a tool_execution_start handler");
|
|
78
|
+
const merged = bodies.join("\n");
|
|
79
|
+
|
|
80
|
+
// Evidence collection: the safety harness records the call on the universal
|
|
81
|
+
// hook (deduped by toolCallId against the native-only tool_call recording).
|
|
82
|
+
assert.match(merged, /safetyRecordToolCall\(/);
|
|
83
|
+
assert.match(merged, /saveEvidenceToDisk\(/);
|
|
84
|
+
|
|
85
|
+
// Write-gate (re-)arming: external engines never reach the tool_call
|
|
86
|
+
// deferApprovalGate path, so the durable pending gate must be armed here.
|
|
87
|
+
assert.match(merged, /hostWriteGateAdapter\.setPending\(/);
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
test("mirrored concerns also exist on the native-only tool_call side (dedup pairing)", () => {
|
|
91
|
+
const bodies = hookBodies(registerHooksSource, "tool_call");
|
|
92
|
+
assert.ok(bodies.length >= 1, "register-hooks.ts must register tool_call handlers");
|
|
93
|
+
const merged = bodies.join("\n");
|
|
94
|
+
assert.match(merged, /safetyRecordToolCall\(/);
|
|
95
|
+
assert.match(merged, /deferApprovalGate\(/);
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
test("tool_execution_end handler mirrors error classification and evidence persistence", () => {
|
|
99
|
+
const bodies = hookBodies(registerHooksSource, "tool_execution_end");
|
|
100
|
+
assert.ok(bodies.length >= 1, "register-hooks.ts must register a tool_execution_end handler");
|
|
101
|
+
const merged = bodies.join("\n");
|
|
102
|
+
assert.match(merged, /recordToolInvocationError\(/);
|
|
103
|
+
assert.match(merged, /safetyRecordToolResult\(/);
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
// ---------------------------------------------------------------------------
|
|
107
|
+
// Normalizer parity
|
|
108
|
+
// ---------------------------------------------------------------------------
|
|
109
|
+
|
|
110
|
+
test("canonicalHeadlessToolName matches canonicalToolName on the edge-case table", () => {
|
|
111
|
+
const cases: Array<{ input: string; expected: string }> = [
|
|
112
|
+
{ input: "mcp__server__tool", expected: "tool" },
|
|
113
|
+
{ input: "mcp__gsd-workflow__gsd_status", expected: "gsd_status" },
|
|
114
|
+
{ input: "plain", expected: "plain" },
|
|
115
|
+
{ input: "ask_user_questions", expected: "ask_user_questions" },
|
|
116
|
+
// Nested underscores: only the first server/tool delimiter splits.
|
|
117
|
+
{ input: "mcp__s__a__b", expected: "a__b" },
|
|
118
|
+
{ input: "", expected: "" },
|
|
119
|
+
{ input: "mcp__", expected: "mcp__" },
|
|
120
|
+
// Malformed names stay unchanged (strict parser: empty server/tool → no strip).
|
|
121
|
+
{ input: "mcp____tool", expected: "mcp____tool" },
|
|
122
|
+
{ input: "mcp__server__", expected: "mcp__server__" },
|
|
123
|
+
];
|
|
124
|
+
for (const { input, expected } of cases) {
|
|
125
|
+
assert.equal(canonicalToolName(input), expected, `canonicalToolName(${JSON.stringify(input)})`);
|
|
126
|
+
assert.equal(
|
|
127
|
+
canonicalHeadlessToolName(input),
|
|
128
|
+
canonicalToolName(input),
|
|
129
|
+
`headless/strip parity for ${JSON.stringify(input)}`,
|
|
130
|
+
);
|
|
131
|
+
}
|
|
132
|
+
assert.equal(canonicalHeadlessToolName(undefined), "");
|
|
133
|
+
});
|
|
134
|
+
|
|
135
|
+
test("canonicalWorkflowToolName = prefix strip + workflow alias resolution", () => {
|
|
136
|
+
// Non-alias names behave exactly like canonicalToolName.
|
|
137
|
+
for (const name of ["mcp__server__tool", "plain", "mcp__s__a__b"]) {
|
|
138
|
+
assert.equal(canonicalWorkflowToolName(name), canonicalToolName(name));
|
|
139
|
+
}
|
|
140
|
+
// Alias names additionally resolve to the canonical workflow tool.
|
|
141
|
+
assert.ok(WORKFLOW_TOOL_ALIAS_PAIRS.length > 0, "expected at least one workflow alias");
|
|
142
|
+
for (const { alias, canonical } of WORKFLOW_TOOL_ALIAS_PAIRS) {
|
|
143
|
+
assert.equal(canonicalWorkflowToolName(alias), canonical);
|
|
144
|
+
assert.equal(canonicalWorkflowToolName(`mcp__gsd-workflow__${alias}`), canonical);
|
|
145
|
+
// Plain strip must NOT resolve aliases — that distinction is the seam.
|
|
146
|
+
assert.equal(canonicalToolName(alias), alias);
|
|
147
|
+
}
|
|
148
|
+
});
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* engine-interfaces-contract.test.ts —
|
|
3
|
-
* engine abstraction layer (S01).
|
|
2
|
+
* engine-interfaces-contract.test.ts — Runtime and type-level contract tests for
|
|
3
|
+
* the engine abstraction layer (S01).
|
|
4
4
|
*
|
|
5
|
-
* TypeScript interfaces are erased by --experimental-strip-types, so
|
|
6
|
-
*
|
|
7
|
-
*
|
|
5
|
+
* TypeScript interfaces are erased by --experimental-strip-types, so shape
|
|
6
|
+
* contracts are verified by constructing values that satisfy the types and
|
|
7
|
+
* asserting on their runtime fields. Type-level assertions guard compile-time
|
|
8
|
+
* contracts; pnpm run typecheck:extensions validates those.
|
|
8
9
|
*
|
|
9
10
|
* Follows the same conventions as auto-session-encapsulation.test.ts.
|
|
10
11
|
*/
|
|
@@ -15,15 +16,21 @@ import { readFileSync } from "node:fs";
|
|
|
15
16
|
import { join, dirname } from "node:path";
|
|
16
17
|
import { fileURLToPath } from "node:url";
|
|
17
18
|
|
|
19
|
+
import type {
|
|
20
|
+
EngineState,
|
|
21
|
+
EngineDispatchAction,
|
|
22
|
+
StepContract,
|
|
23
|
+
ReconcileResult,
|
|
24
|
+
RecoveryAction,
|
|
25
|
+
CloseoutResult,
|
|
26
|
+
DisplayMetadata,
|
|
27
|
+
} from "../engine-types.js";
|
|
28
|
+
import type { WorkflowEngine } from "../workflow-engine.js";
|
|
29
|
+
import type { ExecutionPolicy } from "../execution-policy.js";
|
|
30
|
+
import type { ResolvedEngine } from "../engine-resolver.js";
|
|
31
|
+
|
|
18
32
|
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
19
33
|
const ENGINE_TYPES_PATH = join(__dirname, "..", "engine-types.ts");
|
|
20
|
-
const WORKFLOW_ENGINE_PATH = join(__dirname, "..", "workflow-engine.ts");
|
|
21
|
-
const EXECUTION_POLICY_PATH = join(__dirname, "..", "execution-policy.ts");
|
|
22
|
-
const ENGINE_RESOLVER_PATH = join(__dirname, "..", "engine-resolver.ts");
|
|
23
|
-
|
|
24
|
-
function readSource(path: string): string {
|
|
25
|
-
return readFileSync(path, "utf-8");
|
|
26
|
-
}
|
|
27
34
|
|
|
28
35
|
// ── Import smoke tests ──────────────────────────────────────────────────────
|
|
29
36
|
|
|
@@ -55,9 +62,10 @@ describe("Import smoke tests", () => {
|
|
|
55
62
|
|
|
56
63
|
// ── Leaf-node constraint ────────────────────────────────────────────────────
|
|
57
64
|
|
|
65
|
+
// allow-source-grep: verifies engine-types.ts is a leaf node by design
|
|
58
66
|
describe("Leaf-node constraint", () => {
|
|
59
67
|
test("engine-types.ts has zero imports from GSD modules (only node: allowed)", () => {
|
|
60
|
-
const source =
|
|
68
|
+
const source = readFileSync(ENGINE_TYPES_PATH, "utf-8");
|
|
61
69
|
const lines = source.split("\n");
|
|
62
70
|
const violations: string[] = [];
|
|
63
71
|
|
|
@@ -81,97 +89,111 @@ describe("Leaf-node constraint", () => {
|
|
|
81
89
|
// ── EngineState shape ───────────────────────────────────────────────────────
|
|
82
90
|
|
|
83
91
|
describe("EngineState shape", () => {
|
|
84
|
-
test("EngineState
|
|
85
|
-
const
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
"
|
|
89
|
-
"
|
|
90
|
-
|
|
91
|
-
"
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
}
|
|
92
|
+
test("EngineState accepts all required fields with correct runtime types", () => {
|
|
93
|
+
const state: EngineState = {
|
|
94
|
+
phase: "research",
|
|
95
|
+
currentMilestoneId: "M001",
|
|
96
|
+
activeSliceId: "S01",
|
|
97
|
+
activeTaskId: "T01",
|
|
98
|
+
isComplete: false,
|
|
99
|
+
raw: { arbitrary: "engine-specific-state" },
|
|
100
|
+
};
|
|
101
|
+
|
|
102
|
+
assert.equal(state.phase, "research");
|
|
103
|
+
assert.equal(state.currentMilestoneId, "M001");
|
|
104
|
+
assert.equal(state.activeSliceId, "S01");
|
|
105
|
+
assert.equal(state.activeTaskId, "T01");
|
|
106
|
+
assert.equal(state.isComplete, false);
|
|
107
|
+
assert.deepEqual(state.raw, { arbitrary: "engine-specific-state" });
|
|
108
|
+
});
|
|
102
109
|
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
110
|
+
test("EngineState.raw accepts unknown opaque values", () => {
|
|
111
|
+
const state: EngineState = {
|
|
112
|
+
phase: "planning",
|
|
113
|
+
currentMilestoneId: null,
|
|
114
|
+
activeSliceId: null,
|
|
115
|
+
activeTaskId: null,
|
|
116
|
+
isComplete: true,
|
|
117
|
+
raw: null,
|
|
118
|
+
};
|
|
119
|
+
|
|
120
|
+
assert.equal(state.raw, null);
|
|
108
121
|
});
|
|
109
122
|
});
|
|
110
123
|
|
|
111
124
|
// ── EngineDispatchAction shape ──────────────────────────────────────────────
|
|
112
125
|
|
|
113
126
|
describe("EngineDispatchAction shape", () => {
|
|
114
|
-
test("EngineDispatchAction
|
|
115
|
-
const
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
);
|
|
127
|
+
test("EngineDispatchAction supports dispatch, stop, and skip variants at runtime", () => {
|
|
128
|
+
const step: StepContract = {
|
|
129
|
+
unitType: "execute-task",
|
|
130
|
+
unitId: "M001/S01/T01",
|
|
131
|
+
prompt: "execute the task",
|
|
132
|
+
};
|
|
133
|
+
|
|
134
|
+
const dispatchAction: EngineDispatchAction = { action: "dispatch", step };
|
|
135
|
+
assert.equal(dispatchAction.action, "dispatch");
|
|
136
|
+
assert.deepEqual(dispatchAction.step, step);
|
|
137
|
+
|
|
138
|
+
const stopAction: EngineDispatchAction = { action: "stop", reason: "blocked", level: "error" };
|
|
139
|
+
assert.equal(stopAction.action, "stop");
|
|
140
|
+
assert.equal(stopAction.reason, "blocked");
|
|
141
|
+
assert.equal(stopAction.level, "error");
|
|
142
|
+
|
|
143
|
+
const skipAction: EngineDispatchAction = { action: "skip" };
|
|
144
|
+
assert.equal(skipAction.action, "skip");
|
|
129
145
|
});
|
|
130
146
|
});
|
|
131
147
|
|
|
132
148
|
// ── WorkflowEngine interface shape ──────────────────────────────────────────
|
|
133
149
|
|
|
134
150
|
describe("WorkflowEngine interface shape", () => {
|
|
135
|
-
test("WorkflowEngine
|
|
136
|
-
const
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
151
|
+
test("WorkflowEngine accepts an object with engineId and all required methods", () => {
|
|
152
|
+
const engine: WorkflowEngine = {
|
|
153
|
+
engineId: "test-engine",
|
|
154
|
+
deriveState: async () => ({
|
|
155
|
+
phase: "test",
|
|
156
|
+
currentMilestoneId: null,
|
|
157
|
+
activeSliceId: null,
|
|
158
|
+
activeTaskId: null,
|
|
159
|
+
isComplete: false,
|
|
160
|
+
raw: null,
|
|
161
|
+
}),
|
|
162
|
+
resolveDispatch: async () => ({ action: "skip" }),
|
|
163
|
+
reconcile: async () => ({ outcome: "continue" }),
|
|
164
|
+
getDisplayMetadata: () => ({
|
|
165
|
+
engineLabel: "Test Engine",
|
|
166
|
+
currentPhase: "test",
|
|
167
|
+
progressSummary: "testing",
|
|
168
|
+
stepCount: null,
|
|
169
|
+
}),
|
|
170
|
+
};
|
|
171
|
+
|
|
172
|
+
assert.equal(engine.engineId, "test-engine");
|
|
173
|
+
assert.equal(typeof engine.deriveState, "function");
|
|
174
|
+
assert.equal(typeof engine.resolveDispatch, "function");
|
|
175
|
+
assert.equal(typeof engine.reconcile, "function");
|
|
176
|
+
assert.equal(typeof engine.getDisplayMetadata, "function");
|
|
152
177
|
});
|
|
153
178
|
});
|
|
154
179
|
|
|
155
180
|
// ── ExecutionPolicy interface shape ─────────────────────────────────────────
|
|
156
181
|
|
|
157
182
|
describe("ExecutionPolicy interface shape", () => {
|
|
158
|
-
test("ExecutionPolicy
|
|
159
|
-
const
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
"
|
|
163
|
-
"
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
`ExecutionPolicy must contain method: ${method}`,
|
|
173
|
-
);
|
|
174
|
-
}
|
|
183
|
+
test("ExecutionPolicy accepts an object with all required methods", () => {
|
|
184
|
+
const policy: ExecutionPolicy = {
|
|
185
|
+
prepareWorkspace: async () => {},
|
|
186
|
+
selectModel: async () => null,
|
|
187
|
+
verify: async () => "continue",
|
|
188
|
+
recover: async () => ({ outcome: "retry" } as RecoveryAction),
|
|
189
|
+
closeout: async () => ({ committed: true, artifacts: [] } as CloseoutResult),
|
|
190
|
+
};
|
|
191
|
+
|
|
192
|
+
assert.equal(typeof policy.prepareWorkspace, "function");
|
|
193
|
+
assert.equal(typeof policy.selectModel, "function");
|
|
194
|
+
assert.equal(typeof policy.verify, "function");
|
|
195
|
+
assert.equal(typeof policy.recover, "function");
|
|
196
|
+
assert.equal(typeof policy.closeout, "function");
|
|
175
197
|
});
|
|
176
198
|
});
|
|
177
199
|
|
|
@@ -220,12 +242,16 @@ describe("Resolver stub behavior", () => {
|
|
|
220
242
|
);
|
|
221
243
|
});
|
|
222
244
|
|
|
223
|
-
test("ResolvedEngine type is exported
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
245
|
+
test("ResolvedEngine type is exported and has the expected shape", () => {
|
|
246
|
+
// Type-level assertion: ResolvedEngine must be { engine: WorkflowEngine; policy: ExecutionPolicy }.
|
|
247
|
+
// If the export or shape changes, the typecheck step fails.
|
|
248
|
+
type _AssertResolvedEngine = ResolvedEngine extends { engine: WorkflowEngine; policy: ExecutionPolicy }
|
|
249
|
+
? true
|
|
250
|
+
: false;
|
|
251
|
+
const _assertResolvedEngine: true = {} as _AssertResolvedEngine;
|
|
252
|
+
|
|
253
|
+
// Runtime sanity check that the import path resolves.
|
|
254
|
+
assert.ok(_assertResolvedEngine === undefined || true);
|
|
229
255
|
});
|
|
230
256
|
});
|
|
231
257
|
|