@opengsd/gsd-pi 1.2.0-dev.955e4da0 → 1.2.0-dev.9ad8ae33
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-style.d.ts +17 -0
- package/dist/cli-style.js +28 -0
- package/dist/cli.js +1 -1
- package/dist/headless-events.d.ts +4 -2
- package/dist/headless-events.js +14 -34
- package/dist/mcp-server.js +2 -1
- package/dist/models-resolver.d.ts +3 -13
- package/dist/models-resolver.js +3 -22
- package/dist/resource-loader.d.ts +10 -5
- package/dist/resource-loader.js +123 -20
- package/dist/resources/.managed-resources-content-hash +1 -1
- package/dist/resources/GSD-WORKFLOW.md +5 -4
- 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/bg-shell/utilities.js +3 -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 +30 -4
- 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 +105 -0
- package/dist/resources/extensions/gsd/auto/dispatch-key.js +37 -0
- package/dist/resources/extensions/gsd/auto/loop.js +4 -1
- package/dist/resources/extensions/gsd/auto/orchestrator.js +89 -54
- package/dist/resources/extensions/gsd/auto/phases.js +49 -6
- package/dist/resources/extensions/gsd/auto/session.js +3 -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 +35 -8
- package/dist/resources/extensions/gsd/auto-prompts.js +81 -19
- package/dist/resources/extensions/gsd/auto-start.js +41 -18
- package/dist/resources/extensions/gsd/auto-tool-tracking.js +18 -0
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +45 -21
- package/dist/resources/extensions/gsd/auto-unit-tool-scope.js +12 -20
- package/dist/resources/extensions/gsd/auto-verification.js +23 -30
- package/dist/resources/extensions/gsd/auto-worktree.js +44 -91
- package/dist/resources/extensions/gsd/auto.js +41 -14
- package/dist/resources/extensions/gsd/blocked-models.js +28 -0
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +29 -8
- package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +23 -6
- 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 +212 -48
- package/dist/resources/extensions/gsd/bootstrap/write-gate.js +303 -77
- package/dist/resources/extensions/gsd/branch-patterns.js +2 -0
- 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/captures.js +4 -6
- 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/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 +12 -15
- package/dist/resources/extensions/gsd/db/queries.js +26 -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 +2 -6
- package/dist/resources/extensions/gsd/doctor-format.js +9 -6
- package/dist/resources/extensions/gsd/doctor-git-checks.js +2 -18
- package/dist/resources/extensions/gsd/doctor-runtime-checks.js +13 -15
- package/dist/resources/extensions/gsd/engine-hook-contract.js +70 -0
- package/dist/resources/extensions/gsd/error-classifier.js +9 -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 +158 -0
- package/dist/resources/extensions/gsd/guided-flow.js +23 -5
- package/dist/resources/extensions/gsd/markdown-renderer.js +10 -0
- package/dist/resources/extensions/gsd/mcp-filter.js +2 -19
- package/dist/resources/extensions/gsd/mcp-tool-name.js +5 -13
- package/dist/resources/extensions/gsd/memory-consolidation-scanner.js +1 -1
- package/dist/resources/extensions/gsd/migrate/safety.js +4 -1
- 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/notification-store.js +11 -4
- package/dist/resources/extensions/gsd/parallel-monitor-overlay.js +6 -4
- package/dist/resources/extensions/gsd/parsers-legacy.js +16 -4
- package/dist/resources/extensions/gsd/paths.js +27 -0
- package/dist/resources/extensions/gsd/pre-execution-checks.js +91 -3
- package/dist/resources/extensions/gsd/preferences-models.js +14 -48
- package/dist/resources/extensions/gsd/projection-flush.js +7 -0
- package/dist/resources/extensions/gsd/prompts/complete-slice.md +3 -3
- package/dist/resources/extensions/gsd/prompts/execute-task.md +1 -1
- package/dist/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
- package/dist/resources/extensions/gsd/prompts/plan-slice.md +2 -2
- 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 +2 -2
- package/dist/resources/extensions/gsd/prompts/replan-slice.md +2 -2
- 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 +7 -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/provider-error-guidance.js +1 -5
- package/dist/resources/extensions/gsd/provider-switch-observer.js +1 -1
- package/dist/resources/extensions/gsd/publication.js +87 -0
- package/dist/resources/extensions/gsd/reactive-graph.js +8 -1
- package/dist/resources/extensions/gsd/recovery-classification.js +37 -94
- 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/state.js +6 -20
- package/dist/resources/extensions/gsd/stop-notice.js +57 -0
- 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 +56 -0
- 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 +3 -2
- package/dist/resources/extensions/gsd/tools/exec-tool.js +9 -7
- package/dist/resources/extensions/gsd/tools/plan-slice.js +14 -8
- 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-closeout.js +138 -0
- package/dist/resources/extensions/gsd/unit-context-composer.js +74 -1
- package/dist/resources/extensions/gsd/unit-context-manifest.js +4 -27
- package/dist/resources/extensions/gsd/unit-registry.js +337 -0
- package/dist/resources/extensions/gsd/unit-tool-contracts.js +9 -182
- 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-reconcile.js +21 -56
- package/dist/resources/extensions/gsd/workflow-tool-surface.js +1 -1
- package/dist/resources/extensions/gsd/worktree-git-recovery.js +15 -9
- 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-root.js +11 -0
- package/dist/resources/extensions/gsd/worktree-session-state.js +4 -5
- package/dist/resources/extensions/gsd/worktree.js +8 -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/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 +13 -13
- 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 +13 -13
- package/dist/web/standalone/.next/server/chunks/5124.js +1 -1
- 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/dist/worktree-cli.js +3 -6
- package/dist/worktree-status-banner.js +7 -15
- package/package.json +2 -2
- 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/dist/workflow.d.ts +4 -0
- package/packages/contracts/dist/workflow.d.ts.map +1 -1
- package/packages/contracts/dist/workflow.js.map +1 -1
- package/packages/contracts/package.json +1 -1
- package/packages/daemon/package.json +4 -4
- package/packages/gsd-agent-core/package.json +5 -5
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts +5 -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 +5 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.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-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/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/dist/cli.js +9 -1
- 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/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/workflow-tools.d.ts +26 -18
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +116 -39
- 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/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 +35 -125
- package/packages/pi-ai/dist/models.generated.d.ts.map +1 -1
- package/packages/pi-ai/dist/models.generated.js +46 -120
- 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/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/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/tui.d.ts.map +1 -1
- package/packages/pi-tui/dist/tui.js +9 -0
- package/packages/pi-tui/dist/tui.js.map +1 -1
- package/packages/pi-tui/package.json +2 -2
- package/packages/rpc-client/package.json +2 -2
- package/pkg/package.json +1 -1
- package/src/resources/GSD-WORKFLOW.md +5 -4
- 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/bg-shell/utilities.ts +3 -0
- 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 +34 -4
- 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 +152 -0
- package/src/resources/extensions/gsd/auto/dispatch-key.ts +39 -0
- package/src/resources/extensions/gsd/auto/loop.ts +4 -1
- package/src/resources/extensions/gsd/auto/orchestrator.ts +98 -56
- package/src/resources/extensions/gsd/auto/phases.ts +65 -26
- package/src/resources/extensions/gsd/auto/session.ts +3 -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 +40 -8
- package/src/resources/extensions/gsd/auto-prompts.ts +118 -35
- package/src/resources/extensions/gsd/auto-start.ts +42 -21
- package/src/resources/extensions/gsd/auto-tool-tracking.ts +19 -0
- package/src/resources/extensions/gsd/auto-unit-closeout.ts +83 -28
- package/src/resources/extensions/gsd/auto-unit-tool-scope.ts +14 -21
- package/src/resources/extensions/gsd/auto-verification.ts +26 -28
- package/src/resources/extensions/gsd/auto-worktree.ts +44 -94
- package/src/resources/extensions/gsd/auto.ts +52 -16
- package/src/resources/extensions/gsd/blocked-models.ts +49 -0
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +37 -10
- package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +23 -6
- 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 +251 -47
- package/src/resources/extensions/gsd/bootstrap/write-gate.ts +352 -84
- package/src/resources/extensions/gsd/branch-patterns.ts +3 -0
- 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/captures.ts +4 -6
- 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/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 +13 -11
- package/src/resources/extensions/gsd/db/queries.ts +37 -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 +2 -7
- package/src/resources/extensions/gsd/doctor-format.ts +12 -7
- package/src/resources/extensions/gsd/doctor-git-checks.ts +2 -19
- package/src/resources/extensions/gsd/doctor-runtime-checks.ts +13 -15
- package/src/resources/extensions/gsd/engine-hook-contract.ts +79 -0
- package/src/resources/extensions/gsd/error-classifier.ts +11 -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 +217 -0
- package/src/resources/extensions/gsd/guided-flow.ts +37 -28
- package/src/resources/extensions/gsd/markdown-renderer.ts +11 -0
- package/src/resources/extensions/gsd/mcp-filter.ts +2 -23
- package/src/resources/extensions/gsd/mcp-tool-name.ts +6 -11
- package/src/resources/extensions/gsd/memory-consolidation-scanner.ts +1 -1
- package/src/resources/extensions/gsd/migrate/safety.ts +4 -1
- 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/notification-store.ts +26 -3
- package/src/resources/extensions/gsd/parallel-monitor-overlay.ts +6 -4
- package/src/resources/extensions/gsd/parsers-legacy.ts +16 -4
- package/src/resources/extensions/gsd/paths.ts +33 -0
- package/src/resources/extensions/gsd/pre-execution-checks.ts +109 -3
- package/src/resources/extensions/gsd/preferences-models.ts +12 -47
- package/src/resources/extensions/gsd/projection-flush.ts +20 -0
- package/src/resources/extensions/gsd/prompts/complete-slice.md +3 -3
- package/src/resources/extensions/gsd/prompts/execute-task.md +1 -1
- package/src/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
- package/src/resources/extensions/gsd/prompts/plan-slice.md +2 -2
- 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 +2 -2
- package/src/resources/extensions/gsd/prompts/replan-slice.md +2 -2
- 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 +7 -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/provider-error-guidance.ts +4 -9
- package/src/resources/extensions/gsd/provider-switch-observer.ts +1 -1
- package/src/resources/extensions/gsd/publication.ts +122 -0
- package/src/resources/extensions/gsd/reactive-graph.ts +11 -1
- package/src/resources/extensions/gsd/recovery-classification.ts +42 -96
- 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/state.ts +9 -21
- package/src/resources/extensions/gsd/stop-notice.ts +75 -0
- package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +97 -1
- package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +198 -26
- 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/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/checkout-branch-stash-guard.test.ts +66 -1
- package/src/resources/extensions/gsd/tests/clear-stale-autostart.test.ts +22 -0
- package/src/resources/extensions/gsd/tests/commands-verdict.test.ts +8 -7
- package/src/resources/extensions/gsd/tests/complete-slice-verification-gate.test.ts +42 -0
- 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 +10 -10
- 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 +273 -0
- package/src/resources/extensions/gsd/tests/dispatch-run-uat-browser-tools.test.ts +2 -1
- 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/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 +148 -0
- package/src/resources/extensions/gsd/tests/guided-dispatch-root.test.ts +2 -6
- package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +53 -11
- package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +73 -58
- package/src/resources/extensions/gsd/tests/integration/gsd-integration-fixture.ts +80 -0
- package/src/resources/extensions/gsd/tests/integration/run-uat.test.ts +199 -0
- package/src/resources/extensions/gsd/tests/mcp-project-config.test.ts +3 -1
- package/src/resources/extensions/gsd/tests/milestone-closeout.test.ts +95 -4
- package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +32 -1
- package/src/resources/extensions/gsd/tests/notification-store.test.ts +32 -0
- 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/parsers-legacy-importers.test.ts +138 -0
- package/src/resources/extensions/gsd/tests/phases-terminal-complete-idempotent.test.ts +242 -0
- package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +63 -2
- package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +193 -1
- package/src/resources/extensions/gsd/tests/prompt-db.test.ts +124 -6
- package/src/resources/extensions/gsd/tests/provider-error-guidance.test.ts +3 -3
- package/src/resources/extensions/gsd/tests/publication.test.ts +120 -0
- package/src/resources/extensions/gsd/tests/register-hooks-depth-verification.test.ts +157 -0
- package/src/resources/extensions/gsd/tests/roadmap-slices.test.ts +68 -0
- package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +20 -1
- package/src/resources/extensions/gsd/tests/stop-notice.test.ts +70 -0
- 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 +76 -0
- package/src/resources/extensions/gsd/tests/tool-invocation-error-loop-break.test.ts +8 -0
- package/src/resources/extensions/gsd/tests/tool-surface-readiness.test.ts +155 -0
- 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-closeout.test.ts +209 -0
- package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +67 -2
- package/src/resources/extensions/gsd/tests/unit-registry.test.ts +163 -0
- package/src/resources/extensions/gsd/tests/uok-audit-unified.test.ts +8 -0
- 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.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/workflow-reconcile.test.ts +20 -0
- package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +275 -40
- 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 +76 -0
- 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 +3 -2
- package/src/resources/extensions/gsd/tools/exec-tool.ts +8 -7
- package/src/resources/extensions/gsd/tools/plan-slice.ts +14 -8
- 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-closeout.ts +201 -0
- package/src/resources/extensions/gsd/unit-context-composer.ts +111 -1
- package/src/resources/extensions/gsd/unit-context-manifest.ts +4 -28
- package/src/resources/extensions/gsd/unit-registry.ts +412 -0
- package/src/resources/extensions/gsd/unit-tool-contracts.ts +27 -192
- 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-reconcile.ts +29 -62
- package/src/resources/extensions/gsd/workflow-tool-surface.ts +4 -1
- package/src/resources/extensions/gsd/worktree-git-recovery.ts +15 -9
- 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-root.ts +12 -0
- package/src/resources/extensions/gsd/worktree-session-state.ts +3 -5
- package/src/resources/extensions/gsd/worktree.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/{C24pqUd-aru-l0Dp0gLZP → FBNo5cT_chy7YNoAQsU3o}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{C24pqUd-aru-l0Dp0gLZP → FBNo5cT_chy7YNoAQsU3o}/_ssgManifest.js +0 -0
|
@@ -200,6 +200,74 @@ test("parseRoadmapSlices: checkbox slices with pipe characters do not switch to
|
|
|
200
200
|
assert.deepEqual(slices[2]?.depends, ["S01", "S02"]);
|
|
201
201
|
});
|
|
202
202
|
|
|
203
|
+
test("parseRoadmapSlices: demo markdown table does not switch checkbox roadmap to table mode (#721)", () => {
|
|
204
|
+
const checkboxWithDemoTable = [
|
|
205
|
+
"# M004: Demo Table Repro",
|
|
206
|
+
"",
|
|
207
|
+
"## Slices",
|
|
208
|
+
"",
|
|
209
|
+
"- [x] **S01: First** `risk:low` `depends:[]`",
|
|
210
|
+
" > After this: cli can render examples:",
|
|
211
|
+
"| Example | Meaning |",
|
|
212
|
+
"| --- | --- |",
|
|
213
|
+
"| S01 | Not a roadmap row |",
|
|
214
|
+
"- [ ] **S02: Second** `risk:medium` `depends:[S01]`",
|
|
215
|
+
" > After this: cat file | sort returns stable output.",
|
|
216
|
+
"",
|
|
217
|
+
].join("\n");
|
|
218
|
+
|
|
219
|
+
const slices = parseRoadmapSlices(checkboxWithDemoTable);
|
|
220
|
+
assert.equal(slices.length, 2);
|
|
221
|
+
assert.equal(slices[0]?.id, "S01");
|
|
222
|
+
assert.equal(slices[0]?.title, "First");
|
|
223
|
+
assert.equal(slices[0]?.done, true);
|
|
224
|
+
assert.equal(slices[1]?.id, "S02");
|
|
225
|
+
assert.deepEqual(slices[1]?.depends, ["S01"]);
|
|
226
|
+
});
|
|
227
|
+
|
|
228
|
+
test("parseRoadmapSlices: table preceded by intro prose still parsed as table (#722)", () => {
|
|
229
|
+
const tableWithIntro = [
|
|
230
|
+
"# M005: Intro Before Table",
|
|
231
|
+
"",
|
|
232
|
+
"## Slices",
|
|
233
|
+
"",
|
|
234
|
+
"This milestone is broken into the following slices:",
|
|
235
|
+
"",
|
|
236
|
+
"| Slice | Title | Risk | Status |",
|
|
237
|
+
"| --- | --- | --- | --- |",
|
|
238
|
+
"| S01 | Foundation | Low | [x] Done |",
|
|
239
|
+
"| S02 | Core | High | [ ] Pending |",
|
|
240
|
+
"",
|
|
241
|
+
].join("\n");
|
|
242
|
+
|
|
243
|
+
const slices = parseRoadmapSlices(tableWithIntro);
|
|
244
|
+
assert.equal(slices.length, 2);
|
|
245
|
+
assert.equal(slices[0]?.id, "S01");
|
|
246
|
+
assert.equal(slices[0]?.done, true);
|
|
247
|
+
assert.equal(slices[1]?.id, "S02");
|
|
248
|
+
assert.equal(slices[1]?.done, false);
|
|
249
|
+
});
|
|
250
|
+
|
|
251
|
+
test("parseRoadmapSlices: table without markdown separator row still parsed as table (#722)", () => {
|
|
252
|
+
const tableWithoutSeparator = [
|
|
253
|
+
"# M006: No Separator",
|
|
254
|
+
"",
|
|
255
|
+
"## Slices",
|
|
256
|
+
"",
|
|
257
|
+
"| Slice | Title | Risk | Status |",
|
|
258
|
+
"| S01 | Foundation | Low | [x] Done |",
|
|
259
|
+
"| S02 | Core | High | [ ] Pending |",
|
|
260
|
+
"",
|
|
261
|
+
].join("\n");
|
|
262
|
+
|
|
263
|
+
const slices = parseRoadmapSlices(tableWithoutSeparator);
|
|
264
|
+
assert.equal(slices.length, 2);
|
|
265
|
+
assert.equal(slices[0]?.id, "S01");
|
|
266
|
+
assert.equal(slices[0]?.done, true);
|
|
267
|
+
assert.equal(slices[1]?.id, "S02");
|
|
268
|
+
assert.equal(slices[1]?.done, false);
|
|
269
|
+
});
|
|
270
|
+
|
|
203
271
|
// --- Prose slice header completion marker tests (#1803) ---
|
|
204
272
|
|
|
205
273
|
test("parseRoadmapSlices: prose headers with ✓ marker detected as done", () => {
|
|
@@ -6,7 +6,11 @@ import assert from "node:assert/strict";
|
|
|
6
6
|
|
|
7
7
|
import { classifyFailure } from "../recovery-classification.js";
|
|
8
8
|
import { reconcileBeforeDispatch } from "../state-reconciliation.js";
|
|
9
|
-
import {
|
|
9
|
+
import {
|
|
10
|
+
compileUnitContextContract,
|
|
11
|
+
compileUnitToolContract,
|
|
12
|
+
getUnitWorkflowDispatchReadinessError,
|
|
13
|
+
} from "../tool-contract.js";
|
|
10
14
|
import { shouldBlockAutoUnitToolCall } from "../auto-unit-tool-scope.js";
|
|
11
15
|
import type { GSDState } from "../types.js";
|
|
12
16
|
|
|
@@ -87,6 +91,20 @@ test("Tool Contract compiles known Unit prompt and tool policy", () => {
|
|
|
87
91
|
});
|
|
88
92
|
});
|
|
89
93
|
|
|
94
|
+
test("Tool Contract derives dispatch readiness from Unit workflow tools", () => {
|
|
95
|
+
const error = getUnitWorkflowDispatchReadinessError({
|
|
96
|
+
provider: "claude-code",
|
|
97
|
+
unitType: "plan-slice",
|
|
98
|
+
projectRoot: "/tmp/project",
|
|
99
|
+
env: { GSD_WORKFLOW_MCP_COMMAND: "node" },
|
|
100
|
+
surface: "auto-mode",
|
|
101
|
+
authMode: "externalCli",
|
|
102
|
+
baseUrl: "local://claude-code",
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
assert.equal(error, null);
|
|
106
|
+
});
|
|
107
|
+
|
|
90
108
|
test("Unit Context Contract exposes prompt context without workflow tool surface", () => {
|
|
91
109
|
const result = compileUnitContextContract("execute-task");
|
|
92
110
|
|
|
@@ -164,6 +182,7 @@ test("Recovery Classification covers ADR-015 failure families", () => {
|
|
|
164
182
|
const cases = [
|
|
165
183
|
["invalid tool schema enum", "tool-schema", "stop"],
|
|
166
184
|
["Tool Contract failure: complete-slice cannot use gsd_uat_result_save", "tool-contract", "stop"],
|
|
185
|
+
["No such tool available: mcp__gsd-workflow__gsd_uat_exec", "tool-unavailable", "retry"],
|
|
167
186
|
["deterministic policy rejection", "deterministic-policy", "stop"],
|
|
168
187
|
["cannot legally advance because required UAT Assessment artifact is missing", "lifecycle-progression", "stop"],
|
|
169
188
|
["stale worker lease", "stale-worker", "stop"],
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
// GSD Extension — Stop Notice module tests
|
|
2
|
+
// Locks the emitter↔detector round-trip: every notice the formatters produce
|
|
3
|
+
// must be recognized by the classifiers the headless host uses for exit codes.
|
|
4
|
+
|
|
5
|
+
import { describe, test } from "node:test";
|
|
6
|
+
import assert from "node:assert/strict";
|
|
7
|
+
|
|
8
|
+
import {
|
|
9
|
+
formatStopNoticePrefix,
|
|
10
|
+
isBlockedStopReason,
|
|
11
|
+
stopNoticeDisplayReason,
|
|
12
|
+
stopNoticeKind,
|
|
13
|
+
isTerminalNotice,
|
|
14
|
+
isPauseNotice,
|
|
15
|
+
isBlockedNoticeMessage,
|
|
16
|
+
isManualResolutionNotice,
|
|
17
|
+
PAUSED_NOTICE_PREFIXES,
|
|
18
|
+
TERMINAL_NOTICE_PREFIXES,
|
|
19
|
+
} from "../stop-notice.js";
|
|
20
|
+
|
|
21
|
+
describe("stop notice formatting", () => {
|
|
22
|
+
test("plain stop has no reason suffix", () => {
|
|
23
|
+
assert.equal(formatStopNoticePrefix(), "Auto-mode stopped");
|
|
24
|
+
assert.equal(formatStopNoticePrefix(null), "Auto-mode stopped");
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
test("reason is appended after an em-dash", () => {
|
|
28
|
+
assert.equal(formatStopNoticePrefix("user request"), "Auto-mode stopped — user request");
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
test("Blocked: marker switches the prefix and is stripped from display", () => {
|
|
32
|
+
assert.equal(formatStopNoticePrefix("Blocked: validation gate"), "Auto-mode blocked — validation gate");
|
|
33
|
+
assert.equal(stopNoticeKind("Blocked: x"), "blocked");
|
|
34
|
+
assert.equal(stopNoticeKind("stop"), "stopped");
|
|
35
|
+
assert.ok(isBlockedStopReason("blocked: lowercase too"));
|
|
36
|
+
assert.equal(stopNoticeDisplayReason("Blocked: spaced "), "spaced");
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
describe("emitter↔detector round-trip", () => {
|
|
41
|
+
test("formatted stop notices classify as terminal", () => {
|
|
42
|
+
for (const reason of [undefined, "user request"]) {
|
|
43
|
+
const message = formatStopNoticePrefix(reason).toLowerCase();
|
|
44
|
+
assert.ok(isTerminalNotice(message), `not terminal: ${message}`);
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
test("pause prefixes classify as pause and as blocked (operator intervention)", () => {
|
|
49
|
+
for (const prefix of PAUSED_NOTICE_PREFIXES) {
|
|
50
|
+
assert.ok(isPauseNotice(`${prefix}: provider error`));
|
|
51
|
+
assert.ok(isBlockedNoticeMessage(`${prefix}: provider error`));
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
test("idempotent-advance pauses are non-blocking", () => {
|
|
56
|
+
assert.equal(isBlockedNoticeMessage("auto-mode paused (idempotent advance: unit already active)"), false);
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
test("manual-resolution notices classify as blocked", () => {
|
|
60
|
+
const message = "merge conflict — resolve manually and re-run /gsd auto";
|
|
61
|
+
assert.ok(isManualResolutionNotice(message));
|
|
62
|
+
assert.ok(isBlockedNoticeMessage(message));
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
test("terminal prefixes cover the known stop vocabulary", () => {
|
|
66
|
+
for (const message of ["auto-mode stopped.", "auto-mode complete", "auto-mode idle", "no active milestone"]) {
|
|
67
|
+
assert.ok(TERMINAL_NOTICE_PREFIXES.some((prefix) => message.startsWith(prefix)), message);
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
});
|
|
@@ -159,4 +159,21 @@ describe("teardown chdir failure clears registry", () => {
|
|
|
159
159
|
assert.strictEqual(getAutoWorktreeOriginalBase(), null, "registry null after successful teardown");
|
|
160
160
|
assert.strictEqual(getActiveAutoWorktreeContext(), null, "context null after successful teardown");
|
|
161
161
|
});
|
|
162
|
+
|
|
163
|
+
test("teardown survives when current working directory was deleted", () => {
|
|
164
|
+
repoDir = createTempRepo();
|
|
165
|
+
seedMilestone(repoDir, "M003");
|
|
166
|
+
|
|
167
|
+
const worktreePath = createAutoWorktree(repoDir, "M003");
|
|
168
|
+
process.chdir(worktreePath);
|
|
169
|
+
rmSync(worktreePath, { recursive: true, force: true });
|
|
170
|
+
|
|
171
|
+
assert.doesNotThrow(
|
|
172
|
+
() => teardownAutoWorktree(repoDir, "M003"),
|
|
173
|
+
"teardownAutoWorktree should not call process.cwd() unguarded from a deleted cwd",
|
|
174
|
+
);
|
|
175
|
+
|
|
176
|
+
assert.strictEqual(getAutoWorktreeOriginalBase(), null, "registry null after deleted-cwd teardown");
|
|
177
|
+
assert.strictEqual(getActiveAutoWorktreeContext(), null, "context null after deleted-cwd teardown");
|
|
178
|
+
});
|
|
162
179
|
});
|
|
@@ -10,6 +10,7 @@ import { DISCUSS_TOOLS_ALLOWLIST } from "../constants.ts";
|
|
|
10
10
|
import { buildMinimalAutoGsdToolSet, buildMinimalGsdToolSet, buildMinimalGsdWorkflowToolSet, buildRequestScopedGsdToolSet, MINIMAL_AUTO_BASE_TOOL_NAMES, MINIMAL_GSD_TOOL_NAMES, requestHasGsdCustomType, restoreGsdWorkflowTools, scopeGsdWorkflowToolsForDispatch } from "../bootstrap/register-hooks.ts";
|
|
11
11
|
import { filterToolsForProvider } from "../model-router.ts";
|
|
12
12
|
import { applyUnitSkillVisibility } from "../skill-scope.ts";
|
|
13
|
+
import { drainLogs } from "../workflow-logger.ts";
|
|
13
14
|
|
|
14
15
|
test("buildMinimalGsdToolSet preserves non-GSD tools and replaces broad GSD surface", () => {
|
|
15
16
|
const result = buildMinimalGsdToolSet([
|
|
@@ -17,6 +18,7 @@ test("buildMinimalGsdToolSet preserves non-GSD tools and replaces broad GSD surf
|
|
|
17
18
|
"read",
|
|
18
19
|
"browser_open",
|
|
19
20
|
"gsd_plan_milestone",
|
|
21
|
+
"gsd_plan_slice",
|
|
20
22
|
"gsd_task_complete",
|
|
21
23
|
"gsd_exec",
|
|
22
24
|
"gsd_exec_search",
|
|
@@ -103,6 +105,40 @@ test("buildMinimalAutoGsdToolSet keeps unit-specific completion tools without al
|
|
|
103
105
|
assert.ok(!result.includes("gsd_complete_slice"));
|
|
104
106
|
});
|
|
105
107
|
|
|
108
|
+
test("buildMinimalAutoGsdToolSet warns when plan-milestone required tools are unresolved", () => {
|
|
109
|
+
drainLogs();
|
|
110
|
+
const result = buildMinimalAutoGsdToolSet(
|
|
111
|
+
[
|
|
112
|
+
"ask_user_questions",
|
|
113
|
+
"bash",
|
|
114
|
+
"read",
|
|
115
|
+
"gsd_milestone_status",
|
|
116
|
+
"gsd_plan_milestone",
|
|
117
|
+
],
|
|
118
|
+
"plan-milestone",
|
|
119
|
+
[
|
|
120
|
+
"ask_user_questions",
|
|
121
|
+
"bash",
|
|
122
|
+
"read",
|
|
123
|
+
"gsd_milestone_status",
|
|
124
|
+
"gsd_plan_milestone",
|
|
125
|
+
],
|
|
126
|
+
);
|
|
127
|
+
|
|
128
|
+
assert.ok(result.includes("gsd_plan_milestone"));
|
|
129
|
+
assert.ok(!result.includes("gsd_plan_slice"));
|
|
130
|
+
|
|
131
|
+
const logs = drainLogs();
|
|
132
|
+
assert.ok(
|
|
133
|
+
logs.some((entry) =>
|
|
134
|
+
entry.component === "bootstrap" &&
|
|
135
|
+
entry.message.includes("buildMinimalAutoGsdToolSet(plan-milestone)") &&
|
|
136
|
+
entry.message.includes("gsd_plan_slice")
|
|
137
|
+
),
|
|
138
|
+
`expected missing gsd_plan_slice bootstrap warning, got ${JSON.stringify(logs)}`,
|
|
139
|
+
);
|
|
140
|
+
});
|
|
141
|
+
|
|
106
142
|
test("buildMinimalAutoGsdToolSet scopes run-uat to UAT-specific and read-only tools", () => {
|
|
107
143
|
const active = ["ask_user_questions", "bash", "read", "edit", "write", "gsd_summary_save"];
|
|
108
144
|
const registered = [
|
|
@@ -613,6 +649,46 @@ test("buildMinimalAutoGsdToolSet resolves MCP-scoped gsd_memory_query and gsd_ca
|
|
|
613
649
|
);
|
|
614
650
|
});
|
|
615
651
|
|
|
652
|
+
// ── Regression #627: auto-mode cannot run plan-milestone because gsd_plan_slice is missing ──
|
|
653
|
+
// gsd_plan_slice is in AUTO_UNIT_SCOPED_TOOLS["plan-milestone"] (via unit-tool-contracts).
|
|
654
|
+
// buildMinimalAutoGsdToolSet must expose it when unitType is "plan-milestone".
|
|
655
|
+
|
|
656
|
+
test("buildMinimalAutoGsdToolSet includes gsd_plan_slice for plan-milestone (regression #627)", () => {
|
|
657
|
+
const result = buildMinimalAutoGsdToolSet([
|
|
658
|
+
"bash",
|
|
659
|
+
"read",
|
|
660
|
+
"gsd_plan_milestone",
|
|
661
|
+
"gsd_plan_slice",
|
|
662
|
+
"gsd_milestone_status",
|
|
663
|
+
"gsd_checkpoint_db",
|
|
664
|
+
"memory_query",
|
|
665
|
+
"capture_thought",
|
|
666
|
+
], "plan-milestone");
|
|
667
|
+
|
|
668
|
+
assert.ok(
|
|
669
|
+
result.includes("gsd_plan_slice"),
|
|
670
|
+
"gsd_plan_slice must be included in plan-milestone auto-mode tool set",
|
|
671
|
+
);
|
|
672
|
+
});
|
|
673
|
+
|
|
674
|
+
test("buildMinimalAutoGsdToolSet resolves MCP-scoped gsd_plan_slice for plan-milestone when subprocess only registers prefixed variant (regression #627)", () => {
|
|
675
|
+
const result = buildMinimalAutoGsdToolSet([
|
|
676
|
+
"bash",
|
|
677
|
+
"read",
|
|
678
|
+
"mcp__gsd-workflow__gsd_plan_milestone",
|
|
679
|
+
"mcp__gsd-workflow__gsd_plan_slice",
|
|
680
|
+
"mcp__gsd-workflow__gsd_milestone_status",
|
|
681
|
+
"mcp__gsd-workflow__gsd_checkpoint_db",
|
|
682
|
+
"mcp__gsd-workflow__memory_query",
|
|
683
|
+
"mcp__gsd-workflow__capture_thought",
|
|
684
|
+
], "plan-milestone");
|
|
685
|
+
|
|
686
|
+
assert.ok(
|
|
687
|
+
result.includes("mcp__gsd-workflow__gsd_plan_slice"),
|
|
688
|
+
"mcp__gsd-workflow__gsd_plan_slice must be included when only the MCP-scoped variant is available",
|
|
689
|
+
);
|
|
690
|
+
});
|
|
691
|
+
|
|
616
692
|
test("applyUnitSkillVisibility sets manifest or clears for wildcard", () => {
|
|
617
693
|
const calls: Array<string[] | undefined> = [];
|
|
618
694
|
applyUnitSkillVisibility({
|
|
@@ -48,6 +48,7 @@ import {
|
|
|
48
48
|
isDeterministicPolicyError,
|
|
49
49
|
isPendingUserApprovalGateError,
|
|
50
50
|
isToolInvocationError,
|
|
51
|
+
isToolUnavailableError,
|
|
51
52
|
isQueuedUserMessageSkip,
|
|
52
53
|
} from "../auto-tool-tracking.ts";
|
|
53
54
|
import {
|
|
@@ -121,6 +122,13 @@ describe("#2883: isToolInvocationError classification", () => {
|
|
|
121
122
|
assert.equal(isToolInvocationError("No such tool available: mcp__gsd-workflow__memory_query"), true);
|
|
122
123
|
});
|
|
123
124
|
|
|
125
|
+
test("isToolUnavailableError singles out the startup-race error as transient", () => {
|
|
126
|
+
assert.equal(isToolUnavailableError("No such tool available: mcp__gsd-workflow__gsd_uat_exec"), true);
|
|
127
|
+
assert.equal(isToolUnavailableError("Validation failed for tool gsd_complete_slice"), false);
|
|
128
|
+
assert.equal(isToolUnavailableError("Unexpected end of JSON input"), false);
|
|
129
|
+
assert.equal(isToolUnavailableError(""), false);
|
|
130
|
+
});
|
|
131
|
+
|
|
124
132
|
test("detects ESM export-link errors", () => {
|
|
125
133
|
assert.equal(
|
|
126
134
|
isToolInvocationError("The requested module '../paths.js' does not provide an export named 'gsdProjectionRoot'"),
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
// Project/App: gsd-pi
|
|
2
|
+
// File Purpose: Contract coverage for the Tool Surface Readiness gate and its recovery classification.
|
|
3
|
+
|
|
4
|
+
import { describe, test } from "node:test";
|
|
5
|
+
import assert from "node:assert/strict";
|
|
6
|
+
|
|
7
|
+
import { getToolSurfaceReadinessError } from "../tool-surface-readiness.ts";
|
|
8
|
+
import { isToolUnavailableError } from "../auto-tool-tracking.ts";
|
|
9
|
+
import { classifyError, isTransient } from "../error-classifier.ts";
|
|
10
|
+
import { toMcpToolName } from "../mcp-tool-name.ts";
|
|
11
|
+
import { classifyFailure } from "../recovery-classification.ts";
|
|
12
|
+
|
|
13
|
+
const SERVER = "gsd-workflow";
|
|
14
|
+
|
|
15
|
+
function prefixed(tool: string): string {
|
|
16
|
+
return toMcpToolName(SERVER, tool);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
const RUN_UAT_TOOLS = [
|
|
20
|
+
"gsd_uat_exec",
|
|
21
|
+
"gsd_uat_result_save",
|
|
22
|
+
"gsd_resume",
|
|
23
|
+
"gsd_milestone_status",
|
|
24
|
+
"gsd_journal_query",
|
|
25
|
+
];
|
|
26
|
+
|
|
27
|
+
describe("getToolSurfaceReadinessError", () => {
|
|
28
|
+
test("returns null when no unit type or no workflow server is in play", () => {
|
|
29
|
+
const observation = { tools: [], mcpServers: [] };
|
|
30
|
+
assert.equal(
|
|
31
|
+
getToolSurfaceReadinessError({ unitType: undefined, workflowServerName: SERVER, observation }),
|
|
32
|
+
null,
|
|
33
|
+
);
|
|
34
|
+
assert.equal(
|
|
35
|
+
getToolSurfaceReadinessError({ unitType: "run-uat", workflowServerName: undefined, observation }),
|
|
36
|
+
null,
|
|
37
|
+
);
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
test("returns null for units with no required workflow tools", () => {
|
|
41
|
+
const error = getToolSurfaceReadinessError({
|
|
42
|
+
unitType: "rewrite-docs",
|
|
43
|
+
workflowServerName: SERVER,
|
|
44
|
+
observation: { tools: [], mcpServers: [{ name: SERVER, status: "failed" }] },
|
|
45
|
+
});
|
|
46
|
+
assert.equal(error, null);
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
test("returns an error when the expected workflow server is absent from the init surface", () => {
|
|
50
|
+
const error = getToolSurfaceReadinessError({
|
|
51
|
+
unitType: "run-uat",
|
|
52
|
+
workflowServerName: SERVER,
|
|
53
|
+
observation: { tools: ["read", "bash"], mcpServers: [{ name: "other-server", status: "connected" }] },
|
|
54
|
+
});
|
|
55
|
+
assert.ok(error, "expected a readiness error when the workflow server is absent");
|
|
56
|
+
assert.match(error, /workflow tool surface not ready for run-uat/);
|
|
57
|
+
assert.match(error, /absent from the init surface/);
|
|
58
|
+
assert.match(error, /gsd_uat_exec/);
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
test("passes a still-connecting (pending) server through instead of aborting", () => {
|
|
62
|
+
// The SDK reports still-connecting servers as "pending" at init — the
|
|
63
|
+
// common healthy session. A genuine miss after pass-through is caught
|
|
64
|
+
// in-session ("No such tool available" → tool-unavailable → retry).
|
|
65
|
+
const error = getToolSurfaceReadinessError({
|
|
66
|
+
unitType: "plan-slice",
|
|
67
|
+
workflowServerName: SERVER,
|
|
68
|
+
observation: { tools: ["read", "bash"], mcpServers: [{ name: SERVER, status: "pending" }] },
|
|
69
|
+
});
|
|
70
|
+
assert.equal(error, null);
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
test("returns null when all required tools are registered under the MCP prefix", () => {
|
|
74
|
+
const error = getToolSurfaceReadinessError({
|
|
75
|
+
unitType: "run-uat",
|
|
76
|
+
workflowServerName: SERVER,
|
|
77
|
+
observation: {
|
|
78
|
+
tools: ["read", ...RUN_UAT_TOOLS.map(prefixed)],
|
|
79
|
+
mcpServers: [{ name: SERVER, status: "connected" }],
|
|
80
|
+
},
|
|
81
|
+
});
|
|
82
|
+
assert.equal(error, null);
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
test("reports the failed server and the missing tools when the surface never registered", () => {
|
|
86
|
+
const error = getToolSurfaceReadinessError({
|
|
87
|
+
unitType: "run-uat",
|
|
88
|
+
workflowServerName: SERVER,
|
|
89
|
+
observation: { tools: ["read", "bash"], mcpServers: [{ name: SERVER, status: "failed" }] },
|
|
90
|
+
});
|
|
91
|
+
assert.ok(error, "expected a readiness error");
|
|
92
|
+
assert.match(error, /workflow tool surface not ready for run-uat/);
|
|
93
|
+
assert.match(error, /status is "failed"/);
|
|
94
|
+
assert.match(error, /gsd_uat_exec/);
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
test("aborts on needs-auth (terminal — cannot self-heal)", () => {
|
|
98
|
+
const error = getToolSurfaceReadinessError({
|
|
99
|
+
unitType: "run-uat",
|
|
100
|
+
workflowServerName: SERVER,
|
|
101
|
+
observation: { tools: ["read", "bash"], mcpServers: [{ name: SERVER, status: "needs-auth" }] },
|
|
102
|
+
});
|
|
103
|
+
assert.ok(error, "expected a readiness error for needs-auth");
|
|
104
|
+
assert.match(error, /status is "needs-auth"/);
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
test("aborts on disabled (terminal — cannot self-heal)", () => {
|
|
108
|
+
const error = getToolSurfaceReadinessError({
|
|
109
|
+
unitType: "run-uat",
|
|
110
|
+
workflowServerName: SERVER,
|
|
111
|
+
observation: { tools: ["read", "bash"], mcpServers: [{ name: SERVER, status: "disabled" }] },
|
|
112
|
+
});
|
|
113
|
+
assert.ok(error, "expected a readiness error for disabled");
|
|
114
|
+
assert.match(error, /status is "disabled"/);
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
test("reports partially-registered surfaces even when the server says connected", () => {
|
|
118
|
+
const error = getToolSurfaceReadinessError({
|
|
119
|
+
unitType: "run-uat",
|
|
120
|
+
workflowServerName: SERVER,
|
|
121
|
+
observation: {
|
|
122
|
+
tools: [prefixed("gsd_uat_exec")],
|
|
123
|
+
mcpServers: [{ name: SERVER, status: "connected" }],
|
|
124
|
+
},
|
|
125
|
+
});
|
|
126
|
+
assert.ok(error, "expected a readiness error");
|
|
127
|
+
assert.match(error, /connected but has not registered/);
|
|
128
|
+
assert.match(error, /gsd_uat_result_save/);
|
|
129
|
+
assert.doesNotMatch(error, /gsd_uat_exec,/);
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
describe("readiness error classification contract", () => {
|
|
134
|
+
const readinessError = getToolSurfaceReadinessError({
|
|
135
|
+
unitType: "run-uat",
|
|
136
|
+
workflowServerName: SERVER,
|
|
137
|
+
observation: { tools: [], mcpServers: [{ name: SERVER, status: "failed" }] },
|
|
138
|
+
})!;
|
|
139
|
+
|
|
140
|
+
test("auto-tool-tracking treats the readiness error as tool-unavailable", () => {
|
|
141
|
+
assert.equal(isToolUnavailableError(readinessError), true);
|
|
142
|
+
});
|
|
143
|
+
|
|
144
|
+
test("error-classifier treats the readiness error as transient", () => {
|
|
145
|
+
const cls = classifyError(`Claude Code error: ${readinessError}`);
|
|
146
|
+
assert.equal(isTransient(cls), true);
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
test("Recovery Classification maps the readiness error to tool-unavailable → retry", () => {
|
|
150
|
+
const recovery = classifyFailure({ error: new Error(readinessError), unitType: "run-uat", unitId: "M001" });
|
|
151
|
+
assert.equal(recovery.failureKind, "tool-unavailable");
|
|
152
|
+
assert.equal(recovery.action, "retry");
|
|
153
|
+
assert.equal(recovery.exitReason, "tool-unavailable");
|
|
154
|
+
});
|
|
155
|
+
});
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Regression test for MCP tool-availability race.
|
|
3
|
+
*
|
|
4
|
+
* When the MCP workflow server is still connecting, tool calls fail with
|
|
5
|
+
* "No such tool available". The bounded retry counter on AutoSession
|
|
6
|
+
* (toolUnavailableRetries) prevents infinite re-dispatch loops by capping
|
|
7
|
+
* retries at 3 with escalating delay, then pausing auto-mode.
|
|
8
|
+
*/
|
|
9
|
+
import { describe, test } from "node:test";
|
|
10
|
+
import assert from "node:assert/strict";
|
|
11
|
+
import { AutoSession } from "../auto/session.ts";
|
|
12
|
+
|
|
13
|
+
describe("toolUnavailableRetries on AutoSession", () => {
|
|
14
|
+
test("defaults to 0", () => {
|
|
15
|
+
const s = new AutoSession();
|
|
16
|
+
assert.equal(s.toolUnavailableRetries, 0);
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
test("is cleared on reset()", () => {
|
|
20
|
+
const s = new AutoSession();
|
|
21
|
+
s.toolUnavailableRetries = 2;
|
|
22
|
+
s.reset();
|
|
23
|
+
assert.equal(s.toolUnavailableRetries, 0);
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
test("accumulates across assignments (simulates retry increments)", () => {
|
|
27
|
+
const s = new AutoSession();
|
|
28
|
+
s.toolUnavailableRetries = 1;
|
|
29
|
+
s.toolUnavailableRetries = 2;
|
|
30
|
+
s.toolUnavailableRetries = 3;
|
|
31
|
+
assert.equal(s.toolUnavailableRetries, 3);
|
|
32
|
+
});
|
|
33
|
+
});
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
// gsd-pi — Regression tests for the centralized transport gate and
|
|
2
|
+
// milestone double-complete guard (auto-dispatch.ts + phases.ts).
|
|
3
|
+
|
|
4
|
+
import test from "node:test";
|
|
5
|
+
import assert from "node:assert/strict";
|
|
6
|
+
import { mkdirSync, mkdtempSync, rmSync } from "node:fs";
|
|
7
|
+
import { join } from "node:path";
|
|
8
|
+
import { tmpdir } from "node:os";
|
|
9
|
+
|
|
10
|
+
import { resolveDispatch } from "../auto-dispatch.ts";
|
|
11
|
+
import { openDatabase, closeDatabase, insertMilestone, getMilestone } from "../gsd-db.ts";
|
|
12
|
+
import { isClosedStatus } from "../status-guards.ts";
|
|
13
|
+
import { getWorkflowTransportSupportError } from "../workflow-mcp.ts";
|
|
14
|
+
|
|
15
|
+
// ── transport gate: getWorkflowTransportSupportError blocks missing tools ────
|
|
16
|
+
|
|
17
|
+
test("getWorkflowTransportSupportError blocks when required non-surface tools are missing", () => {
|
|
18
|
+
const err = getWorkflowTransportSupportError(
|
|
19
|
+
"claude-code",
|
|
20
|
+
["custom_non_surface_tool"],
|
|
21
|
+
{
|
|
22
|
+
projectRoot: process.cwd(),
|
|
23
|
+
surface: "auto-mode",
|
|
24
|
+
unitType: "execute-task",
|
|
25
|
+
authMode: "externalCli",
|
|
26
|
+
baseUrl: "local://claude-code",
|
|
27
|
+
activeTools: ["some_other_tool"],
|
|
28
|
+
},
|
|
29
|
+
);
|
|
30
|
+
assert.ok(err, "should return an error when required non-surface tools are missing from activeTools");
|
|
31
|
+
assert.match(err, /cannot run/i);
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
test("getWorkflowTransportSupportError passes for non-MCP transport", () => {
|
|
35
|
+
const err = getWorkflowTransportSupportError(
|
|
36
|
+
"claude-code",
|
|
37
|
+
["custom_non_surface_tool"],
|
|
38
|
+
{
|
|
39
|
+
projectRoot: process.cwd(),
|
|
40
|
+
surface: "auto-mode",
|
|
41
|
+
unitType: "execute-task",
|
|
42
|
+
authMode: "apiKey",
|
|
43
|
+
baseUrl: "https://api.anthropic.com",
|
|
44
|
+
activeTools: [],
|
|
45
|
+
},
|
|
46
|
+
);
|
|
47
|
+
assert.equal(err, null, "non-MCP transport should not be blocked");
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
test("resolveDispatch allows dispatch when MCP tools are available", async (t) => {
|
|
51
|
+
const base = mkdtempSync(join(tmpdir(), "gsd-transport-pass-"));
|
|
52
|
+
mkdirSync(join(base, ".gsd"), { recursive: true });
|
|
53
|
+
openDatabase(join(base, ".gsd", "gsd.db"));
|
|
54
|
+
t.after(() => {
|
|
55
|
+
closeDatabase();
|
|
56
|
+
rmSync(base, { recursive: true, force: true });
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
insertMilestone({ id: "M001", title: "Test", status: "active" });
|
|
60
|
+
|
|
61
|
+
const action = await resolveDispatch({
|
|
62
|
+
basePath: base,
|
|
63
|
+
mid: "M001",
|
|
64
|
+
midTitle: "Test",
|
|
65
|
+
state: {
|
|
66
|
+
phase: "executing",
|
|
67
|
+
activeMilestone: { id: "M001", title: "Test", status: "active" },
|
|
68
|
+
activeSlice: { id: "S01", title: "Slice" },
|
|
69
|
+
activeTask: { id: "M001/S01/T01", title: "Task", status: "pending" },
|
|
70
|
+
registry: [],
|
|
71
|
+
blockers: [],
|
|
72
|
+
} as any,
|
|
73
|
+
prefs: undefined,
|
|
74
|
+
// No transport gate deps → no MCP check → dispatch should go through
|
|
75
|
+
});
|
|
76
|
+
|
|
77
|
+
assert.equal(action.action, "dispatch");
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
// ── double-complete guard: isClosedStatus prevents duplicate closeout ────────
|
|
81
|
+
|
|
82
|
+
test("isClosedStatus detects complete milestone status", () => {
|
|
83
|
+
assert.equal(isClosedStatus("complete"), true);
|
|
84
|
+
assert.equal(isClosedStatus("done"), true);
|
|
85
|
+
assert.equal(isClosedStatus("skipped"), true);
|
|
86
|
+
assert.equal(isClosedStatus("closed"), true);
|
|
87
|
+
assert.equal(isClosedStatus("active"), false);
|
|
88
|
+
assert.equal(isClosedStatus("pending"), false);
|
|
89
|
+
assert.equal(isClosedStatus(""), false);
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
test("getMilestone + isClosedStatus guards against double-complete dispatch", (t) => {
|
|
93
|
+
const base = mkdtempSync(join(tmpdir(), "gsd-double-complete-"));
|
|
94
|
+
mkdirSync(join(base, ".gsd"), { recursive: true });
|
|
95
|
+
openDatabase(join(base, ".gsd", "gsd.db"));
|
|
96
|
+
t.after(() => {
|
|
97
|
+
closeDatabase();
|
|
98
|
+
rmSync(base, { recursive: true, force: true });
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
insertMilestone({ id: "M001", title: "Test", status: "complete" });
|
|
102
|
+
|
|
103
|
+
// resolveDispatch itself checks for closed milestones at the top
|
|
104
|
+
// (before any dispatch rule fires), which is the same guard used
|
|
105
|
+
// by the phases.ts double-complete check.
|
|
106
|
+
const milestone = getMilestone("M001");
|
|
107
|
+
assert.ok(milestone, "milestone should exist in DB");
|
|
108
|
+
assert.equal(isClosedStatus(milestone.status), true, "closed milestone must be detected");
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
test("resolveDispatch stops on closed milestone before dispatching", async (t) => {
|
|
112
|
+
const base = mkdtempSync(join(tmpdir(), "gsd-closed-milestone-"));
|
|
113
|
+
mkdirSync(join(base, ".gsd"), { recursive: true });
|
|
114
|
+
openDatabase(join(base, ".gsd", "gsd.db"));
|
|
115
|
+
t.after(() => {
|
|
116
|
+
closeDatabase();
|
|
117
|
+
rmSync(base, { recursive: true, force: true });
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
insertMilestone({ id: "M001", title: "Test", status: "complete" });
|
|
121
|
+
|
|
122
|
+
const action = await resolveDispatch({
|
|
123
|
+
basePath: base,
|
|
124
|
+
mid: "M001",
|
|
125
|
+
midTitle: "Test",
|
|
126
|
+
state: {
|
|
127
|
+
phase: "complete",
|
|
128
|
+
activeMilestone: { id: "M001", title: "Test", status: "complete" },
|
|
129
|
+
activeSlice: null,
|
|
130
|
+
activeTask: null,
|
|
131
|
+
registry: [],
|
|
132
|
+
blockers: [],
|
|
133
|
+
} as any,
|
|
134
|
+
prefs: undefined,
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
assert.equal(action.action, "stop");
|
|
138
|
+
assert.match(action.reason ?? "", /closed/i);
|
|
139
|
+
});
|