gsd-pi 2.76.0-dev.fe143342a → 2.77.0-dev.1d17f366c
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +17 -35
- package/dist/claude-cli-check.js +32 -3
- package/dist/cli-web-branch.d.ts +1 -0
- package/dist/cli-web-branch.js +3 -0
- package/dist/cli.js +38 -2
- package/dist/extension-discovery.d.ts +6 -0
- package/dist/extension-discovery.js +37 -0
- package/dist/extension-registry.d.ts +3 -0
- package/dist/extension-sort.d.ts +18 -0
- package/dist/extension-sort.js +114 -0
- package/dist/extension-validator.d.ts +47 -0
- package/dist/extension-validator.js +127 -0
- package/dist/loader.js +35 -7
- package/dist/onboarding.js +45 -0
- package/dist/provider-migrations.d.ts +18 -0
- package/dist/provider-migrations.js +14 -0
- package/dist/resources/extensions/claude-code-cli/readiness.js +4 -3
- package/dist/resources/extensions/claude-code-cli/stream-adapter.js +78 -59
- package/dist/resources/extensions/cmux/index.js +20 -0
- package/dist/resources/extensions/github-sync/templates.js +103 -0
- package/dist/resources/extensions/google-search/extension-manifest.json +5 -4
- package/dist/resources/extensions/google-search/index.js +3 -375
- package/dist/resources/extensions/gsd/abandon-detect.js +44 -0
- package/dist/resources/extensions/gsd/auto/loop.js +90 -2
- package/dist/resources/extensions/gsd/auto/phases.js +95 -21
- package/dist/resources/extensions/gsd/auto/resolve.js +24 -0
- package/dist/resources/extensions/gsd/auto/run-unit.js +48 -4
- package/dist/resources/extensions/gsd/auto/session.js +18 -1
- package/dist/resources/extensions/gsd/auto/turn-epoch.js +95 -0
- package/dist/resources/extensions/gsd/auto-dispatch.js +115 -17
- package/dist/resources/extensions/gsd/auto-loop.js +1 -1
- package/dist/resources/extensions/gsd/auto-model-selection.js +1 -1
- package/dist/resources/extensions/gsd/auto-post-unit.js +90 -2
- package/dist/resources/extensions/gsd/auto-prompts.js +14 -0
- package/dist/resources/extensions/gsd/auto-recovery.js +46 -1
- package/dist/resources/extensions/gsd/auto-start.js +45 -39
- package/dist/resources/extensions/gsd/auto-timeout-recovery.js +11 -5
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +11 -2
- package/dist/resources/extensions/gsd/auto-worktree.js +109 -61
- package/dist/resources/extensions/gsd/auto.js +97 -31
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +27 -1
- package/dist/resources/extensions/gsd/bootstrap/provider-error-resume.js +4 -2
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +11 -0
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +17 -6
- package/dist/resources/extensions/gsd/bootstrap/system-context.js +11 -6
- package/dist/resources/extensions/gsd/bootstrap/write-gate.js +34 -2
- package/dist/resources/extensions/gsd/clean-root-preflight.js +93 -0
- package/dist/resources/extensions/gsd/commands/handlers/workflow.js +31 -4
- package/dist/resources/extensions/gsd/commands-cmux.js +9 -6
- package/dist/resources/extensions/gsd/commands-extensions.js +634 -43
- package/dist/resources/extensions/gsd/commands-prefs-wizard.js +968 -23
- package/dist/resources/extensions/gsd/dispatch-guard.js +29 -3
- package/dist/resources/extensions/gsd/file-lock.js +49 -9
- package/dist/resources/extensions/gsd/git-service.js +1 -0
- package/dist/resources/extensions/gsd/gitignore.js +2 -0
- package/dist/resources/extensions/gsd/gsd-db.js +90 -30
- package/dist/resources/extensions/gsd/guided-flow-queue.js +4 -1
- package/dist/resources/extensions/gsd/guided-flow.js +212 -9
- package/dist/resources/extensions/gsd/health-widget.js +4 -1
- package/dist/resources/extensions/gsd/journal.js +17 -2
- package/dist/resources/extensions/gsd/key-manager.js +22 -0
- package/dist/resources/extensions/gsd/milestone-actions.js +15 -0
- package/dist/resources/extensions/gsd/milestone-summary-classifier.js +37 -0
- package/dist/resources/extensions/gsd/model-router.js +36 -3
- package/dist/resources/extensions/gsd/notifications.js +30 -16
- package/dist/resources/extensions/gsd/pre-execution-checks.js +31 -6
- package/dist/resources/extensions/gsd/prompts/discuss-headless.md +29 -2
- package/dist/resources/extensions/gsd/prompts/discuss.md +29 -2
- package/dist/resources/extensions/gsd/prompts/doctor-heal.md +5 -4
- package/dist/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
- package/dist/resources/extensions/gsd/prompts/system.md +1 -0
- package/dist/resources/extensions/gsd/reports.js +5 -4
- package/dist/resources/extensions/gsd/safety/evidence-collector.js +96 -0
- package/dist/resources/extensions/gsd/safety/file-change-validator.js +12 -4
- package/dist/resources/extensions/gsd/safety/safety-harness.js +5 -1
- package/dist/resources/extensions/gsd/state-transition-matrix.js +118 -0
- package/dist/resources/extensions/gsd/state.js +25 -25
- package/dist/resources/extensions/gsd/token-counter.js +22 -5
- package/dist/resources/extensions/gsd/tools/complete-milestone.js +16 -10
- package/dist/resources/extensions/gsd/tools/complete-slice.js +21 -0
- package/dist/resources/extensions/gsd/tools/complete-task.js +31 -0
- package/dist/resources/extensions/gsd/uok/audit.js +18 -2
- package/dist/resources/extensions/gsd/uok/dispatch-envelope.js +33 -0
- package/dist/resources/extensions/gsd/uok/execution-graph.js +10 -0
- package/dist/resources/extensions/gsd/uok/gitops.js +2 -1
- package/dist/resources/extensions/gsd/uok/loop-adapter.js +37 -10
- package/dist/resources/extensions/gsd/uok/parity-report.js +58 -0
- package/dist/resources/extensions/gsd/uok/plan-v2.js +30 -7
- package/dist/resources/extensions/gsd/uok/writer.js +82 -0
- package/dist/resources/extensions/gsd/workflow-logger.js +10 -2
- package/dist/resources/extensions/gsd/worktree-manager.js +1 -0
- package/dist/resources/extensions/gsd/worktree-resolver.js +50 -10
- package/dist/resources/extensions/mcp-client/auth.js +10 -1
- package/dist/resources/extensions/mcp-client/index.js +118 -9
- package/dist/resources/extensions/shared/cmux-events.js +12 -0
- package/dist/resources/extensions/shared/rtk-session-stats.js +1 -2
- package/dist/resources/skills/create-skill/SKILL.md +2 -2
- package/dist/resources/skills/create-skill/references/gsd-skill-ecosystem.md +4 -4
- package/dist/resources/skills/create-skill/workflows/audit-skill.md +4 -4
- package/dist/resources/skills/create-skill/workflows/create-new-skill.md +5 -5
- package/dist/resources/skills/verify-before-complete/SKILL.md +2 -1
- package/dist/resources/skills/write-docs/SKILL.md +2 -1
- package/dist/tsconfig.extensions.tsbuildinfo +1 -1
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +9 -9
- 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/boot/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/boot/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/captures/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/cleanup/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/doctor/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/export-data/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/files/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/forensics/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/git/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/history/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/hooks/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/inspect/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/knowledge/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/live-state/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/notifications/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/notifications/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/projects/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/recovery/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/browser/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/command/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/session/events/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/events/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/session/manage/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/settings-data/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/skill-health/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/steer/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/undo/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/visualizer/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 +9 -9
- package/dist/web/standalone/.next/server/chunks/1926.js +1 -0
- package/dist/web/standalone/.next/server/chunks/6897.js +2 -2
- package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware-manifest.json +5 -5
- 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/2826.e9f5195e91f9cad2.js +11 -0
- package/dist/web/standalone/.next/static/chunks/{webpack-5fc74f13a25fa1bb.js → webpack-2e68521d7c82f7c2.js} +1 -1
- package/dist/welcome-screen.js +6 -1
- package/dist/wizard.js +2 -0
- package/package.json +16 -14
- package/packages/daemon/package.json +2 -2
- package/packages/mcp-server/README.md +3 -3
- package/packages/mcp-server/dist/env-writer.d.ts +1 -0
- package/packages/mcp-server/dist/env-writer.d.ts.map +1 -1
- package/packages/mcp-server/dist/env-writer.js +74 -6
- package/packages/mcp-server/dist/env-writer.js.map +1 -1
- package/packages/mcp-server/dist/remote-questions.d.ts +45 -0
- package/packages/mcp-server/dist/remote-questions.d.ts.map +1 -0
- package/packages/mcp-server/dist/remote-questions.js +732 -0
- package/packages/mcp-server/dist/remote-questions.js.map +1 -0
- package/packages/mcp-server/dist/server.d.ts +7 -0
- package/packages/mcp-server/dist/server.d.ts.map +1 -1
- package/packages/mcp-server/dist/server.js +95 -10
- package/packages/mcp-server/dist/server.js.map +1 -1
- package/packages/mcp-server/dist/session-manager.d.ts +14 -0
- package/packages/mcp-server/dist/session-manager.d.ts.map +1 -1
- package/packages/mcp-server/dist/session-manager.js +49 -1
- package/packages/mcp-server/dist/session-manager.js.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +15 -6
- package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
- package/packages/mcp-server/package.json +9 -3
- package/packages/mcp-server/src/env-writer.test.ts +79 -1
- package/packages/mcp-server/src/env-writer.ts +76 -6
- package/packages/mcp-server/src/mcp-server.test.ts +67 -0
- package/packages/mcp-server/src/readers/readers.test.ts +5 -1
- package/packages/mcp-server/src/remote-questions.test.ts +294 -0
- package/packages/mcp-server/src/remote-questions.ts +916 -0
- package/packages/mcp-server/src/server.ts +118 -16
- package/packages/mcp-server/src/session-manager.ts +43 -1
- package/packages/mcp-server/src/workflow-tools.test.ts +44 -0
- package/packages/mcp-server/src/workflow-tools.ts +19 -6
- package/packages/mcp-server/tsconfig.test.json +19 -0
- package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
- package/packages/native/package.json +6 -1
- package/packages/native/src/__tests__/clipboard.test.mjs +69 -23
- package/packages/native/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-agent-core/package.json +6 -1
- package/packages/pi-agent-core/src/agent-loop.test.ts +220 -15
- package/packages/pi-ai/dist/models/custom.d.ts +38 -0
- package/packages/pi-ai/dist/models/custom.d.ts.map +1 -1
- package/packages/pi-ai/dist/models/custom.js +41 -0
- package/packages/pi-ai/dist/models/custom.js.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic-auth.test.js +1 -1
- package/packages/pi-ai/dist/providers/anthropic-auth.test.js.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic-shared.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic-shared.js +27 -4
- package/packages/pi-ai/dist/providers/anthropic-shared.js.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.js +8 -3
- package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
- package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts +2 -0
- package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts.map +1 -0
- package/packages/pi-ai/dist/providers/minimax-tool-name.test.js +80 -0
- package/packages/pi-ai/dist/providers/minimax-tool-name.test.js.map +1 -0
- package/packages/pi-ai/dist/providers/simple-options.d.ts +10 -0
- package/packages/pi-ai/dist/providers/simple-options.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/simple-options.js +16 -1
- package/packages/pi-ai/dist/providers/simple-options.js.map +1 -1
- package/packages/pi-ai/package.json +6 -1
- package/packages/pi-ai/src/models/custom.ts +42 -0
- package/packages/pi-ai/src/providers/anthropic-auth.test.ts +1 -1
- package/packages/pi-ai/src/providers/anthropic-shared.ts +26 -5
- package/packages/pi-ai/src/providers/anthropic.ts +9 -3
- package/packages/pi-ai/src/providers/minimax-tool-name.test.ts +98 -0
- package/packages/pi-ai/src/providers/simple-options.ts +17 -1
- package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js +3 -2
- package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.js +7 -0
- package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts +25 -0
- package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction/compaction.js +105 -6
- package/packages/pi-coding-agent/dist/core/compaction/compaction.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction/compaction.test.js +230 -28
- package/packages/pi-coding-agent/dist/core/compaction/compaction.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction/utils.d.ts +30 -2
- package/packages/pi-coding-agent/dist/core/compaction/utils.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction/utils.js +113 -12
- package/packages/pi-coding-agent/dist/core/compaction/utils.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.d.ts +1 -0
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js +29 -18
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.js +130 -0
- package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/compaction-utils.test.js +56 -1
- package/packages/pi-coding-agent/dist/core/compaction-utils.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/discovery-cache.test.js +8 -15
- package/packages/pi-coding-agent/dist/core/discovery-cache.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.d.ts +25 -0
- package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.js +109 -0
- package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/extensions/extension-registry.d.ts +67 -0
- package/packages/pi-coding-agent/dist/core/extensions/extension-registry.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/extensions/extension-registry.js +167 -0
- package/packages/pi-coding-agent/dist/core/extensions/extension-registry.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts +3 -2
- package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/loader.js +24 -8
- package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/types.d.ts +14 -0
- package/packages/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/lsp/lsp-integration.test.js +11 -0
- package/packages/pi-coding-agent/dist/core/lsp/lsp-integration.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js +2 -2
- package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js +203 -0
- package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-registry.js +14 -0
- package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/resource-loader.js +1 -1
- package/packages/pi-coding-agent/dist/core/resource-loader.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/sdk.d.ts +1 -0
- package/packages/pi-coding-agent/dist/core/sdk.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/sdk.js +4 -1
- package/packages/pi-coding-agent/dist/core/sdk.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/sdk.test.js +19 -1
- package/packages/pi-coding-agent/dist/core/sdk.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/session-manager.js +1 -1
- package/packages/pi-coding-agent/dist/core/session-manager.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/session-manager.test.js +21 -1
- package/packages/pi-coding-agent/dist/core/session-manager.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/system-prompt.js +3 -3
- package/packages/pi-coding-agent/dist/core/system-prompt.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/path-utils.test.js +2 -1
- package/packages/pi-coding-agent/dist/core/tools/path-utils.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/provider-display-name.test.js +15 -6
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/provider-display-name.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js +14 -5
- package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.d.ts +7 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.js +31 -9
- package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js +14 -0
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +13 -1
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
- package/packages/pi-coding-agent/package.json +6 -1
- package/packages/pi-coding-agent/src/core/agent-session-abort-order.test.ts +3 -2
- package/packages/pi-coding-agent/src/core/agent-session.ts +11 -0
- package/packages/pi-coding-agent/src/core/compaction/compaction.test.ts +368 -28
- package/packages/pi-coding-agent/src/core/compaction/compaction.ts +122 -6
- package/packages/pi-coding-agent/src/core/compaction/utils.ts +111 -13
- package/packages/pi-coding-agent/src/core/compaction-orchestrator.test.ts +154 -0
- package/packages/pi-coding-agent/src/core/compaction-orchestrator.ts +32 -18
- package/packages/pi-coding-agent/src/core/compaction-utils.test.ts +68 -1
- package/packages/pi-coding-agent/src/core/discovery-cache.test.ts +9 -18
- package/packages/pi-coding-agent/src/core/extensions/extension-discovery.ts +119 -0
- package/packages/pi-coding-agent/src/core/extensions/extension-registry.ts +222 -0
- package/packages/pi-coding-agent/src/core/extensions/loader.ts +24 -11
- package/packages/pi-coding-agent/src/core/extensions/runner.ts +2 -0
- package/packages/pi-coding-agent/src/core/extensions/types.ts +15 -0
- package/packages/pi-coding-agent/src/core/lsp/lsp-integration.test.ts +13 -0
- package/packages/pi-coding-agent/src/core/model-registry-auth-mode.test.ts +2 -2
- package/packages/pi-coding-agent/src/core/model-registry-custom-caps.test.ts +245 -0
- package/packages/pi-coding-agent/src/core/model-registry.ts +16 -0
- package/packages/pi-coding-agent/src/core/resource-loader.ts +1 -1
- package/packages/pi-coding-agent/src/core/sdk.test.ts +25 -1
- package/packages/pi-coding-agent/src/core/sdk.ts +10 -3
- package/packages/pi-coding-agent/src/core/session-manager.test.ts +30 -1
- package/packages/pi-coding-agent/src/core/session-manager.ts +1 -1
- package/packages/pi-coding-agent/src/core/system-prompt.ts +3 -3
- package/packages/pi-coding-agent/src/core/tools/path-utils.test.ts +2 -1
- package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/provider-display-name.test.ts +17 -7
- package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +14 -5
- package/packages/pi-coding-agent/src/modes/interactive/components/model-selector.ts +45 -11
- package/packages/pi-coding-agent/src/modes/interactive/controllers/input-controller.test.ts +14 -0
- package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +13 -1
- package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-tui/dist/__tests__/autocomplete.test.js +12 -5
- package/packages/pi-tui/dist/__tests__/autocomplete.test.js.map +1 -1
- package/packages/pi-tui/dist/__tests__/stdin-buffer.test.js +21 -0
- package/packages/pi-tui/dist/__tests__/stdin-buffer.test.js.map +1 -1
- package/packages/pi-tui/dist/stdin-buffer.d.ts +7 -0
- package/packages/pi-tui/dist/stdin-buffer.d.ts.map +1 -1
- package/packages/pi-tui/dist/stdin-buffer.js +20 -0
- package/packages/pi-tui/dist/stdin-buffer.js.map +1 -1
- package/packages/pi-tui/package.json +6 -1
- package/packages/pi-tui/src/__tests__/autocomplete.test.ts +20 -5
- package/packages/pi-tui/src/__tests__/stdin-buffer.test.ts +27 -0
- package/packages/pi-tui/src/stdin-buffer.ts +26 -0
- package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
- package/packages/rpc-client/package.json +6 -1
- package/pkg/package.json +1 -1
- package/scripts/install.js +512 -0
- package/scripts/lib/workspace-manifest.cjs +86 -0
- package/scripts/link-workspace-packages.cjs +5 -17
- package/scripts/postinstall.js +9 -178
- package/src/resources/extensions/claude-code-cli/readiness.ts +4 -3
- package/src/resources/extensions/claude-code-cli/stream-adapter.ts +91 -63
- package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +114 -12
- package/src/resources/extensions/cmux/index.ts +35 -10
- package/src/resources/extensions/github-sync/templates.ts +151 -0
- package/src/resources/extensions/github-sync/tests/templates.test.ts +59 -0
- package/src/resources/extensions/google-search/extension-manifest.json +5 -4
- package/src/resources/extensions/google-search/index.ts +9 -470
- package/src/resources/extensions/gsd/abandon-detect.ts +62 -0
- package/src/resources/extensions/gsd/auto/loop-deps.ts +14 -1
- package/src/resources/extensions/gsd/auto/loop.ts +104 -2
- package/src/resources/extensions/gsd/auto/phases.ts +123 -21
- package/src/resources/extensions/gsd/auto/resolve.ts +29 -0
- package/src/resources/extensions/gsd/auto/run-unit.ts +56 -4
- package/src/resources/extensions/gsd/auto/session.ts +28 -1
- package/src/resources/extensions/gsd/auto/turn-epoch.ts +108 -0
- package/src/resources/extensions/gsd/auto/types.ts +1 -1
- package/src/resources/extensions/gsd/auto-dispatch.ts +117 -16
- package/src/resources/extensions/gsd/auto-loop.ts +1 -1
- package/src/resources/extensions/gsd/auto-model-selection.ts +1 -1
- package/src/resources/extensions/gsd/auto-post-unit.ts +92 -3
- package/src/resources/extensions/gsd/auto-prompts.ts +28 -1
- package/src/resources/extensions/gsd/auto-recovery.ts +40 -1
- package/src/resources/extensions/gsd/auto-start.ts +48 -52
- package/src/resources/extensions/gsd/auto-timeout-recovery.ts +12 -5
- package/src/resources/extensions/gsd/auto-unit-closeout.ts +14 -3
- package/src/resources/extensions/gsd/auto-worktree.ts +122 -68
- package/src/resources/extensions/gsd/auto.ts +105 -35
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +34 -1
- package/src/resources/extensions/gsd/bootstrap/provider-error-resume.ts +6 -2
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +11 -0
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +18 -6
- package/src/resources/extensions/gsd/bootstrap/system-context.ts +13 -9
- package/src/resources/extensions/gsd/bootstrap/write-gate.ts +35 -2
- package/src/resources/extensions/gsd/clean-root-preflight.ts +111 -0
- package/src/resources/extensions/gsd/commands/handlers/workflow.ts +27 -8
- package/src/resources/extensions/gsd/commands-cmux.ts +10 -6
- package/src/resources/extensions/gsd/commands-extensions.ts +747 -41
- package/src/resources/extensions/gsd/commands-prefs-wizard.ts +898 -32
- package/src/resources/extensions/gsd/dispatch-guard.ts +26 -2
- package/src/resources/extensions/gsd/file-lock.ts +84 -11
- package/src/resources/extensions/gsd/git-service.ts +1 -0
- package/src/resources/extensions/gsd/gitignore.ts +2 -1
- package/src/resources/extensions/gsd/gsd-db.ts +92 -32
- package/src/resources/extensions/gsd/guided-flow-queue.ts +4 -1
- package/src/resources/extensions/gsd/guided-flow.ts +259 -10
- package/src/resources/extensions/gsd/health-widget.ts +3 -1
- package/src/resources/extensions/gsd/journal.ts +29 -3
- package/src/resources/extensions/gsd/key-manager.ts +22 -0
- package/src/resources/extensions/gsd/milestone-actions.ts +18 -0
- package/src/resources/extensions/gsd/milestone-summary-classifier.ts +42 -0
- package/src/resources/extensions/gsd/model-router.ts +42 -1
- package/src/resources/extensions/gsd/notifications.ts +27 -15
- package/src/resources/extensions/gsd/pre-execution-checks.ts +33 -7
- package/src/resources/extensions/gsd/preferences-types.ts +8 -0
- package/src/resources/extensions/gsd/prompts/discuss-headless.md +29 -2
- package/src/resources/extensions/gsd/prompts/discuss.md +29 -2
- package/src/resources/extensions/gsd/prompts/doctor-heal.md +5 -4
- package/src/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
- package/src/resources/extensions/gsd/prompts/system.md +1 -0
- package/src/resources/extensions/gsd/reports.ts +5 -4
- package/src/resources/extensions/gsd/safety/evidence-collector.ts +119 -0
- package/src/resources/extensions/gsd/safety/file-change-validator.ts +16 -3
- package/src/resources/extensions/gsd/safety/safety-harness.ts +9 -0
- package/src/resources/extensions/gsd/state-transition-matrix.ts +152 -0
- package/src/resources/extensions/gsd/state.ts +35 -30
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +238 -4
- package/src/resources/extensions/gsd/tests/auto-mode-guards.test.ts +79 -0
- package/src/resources/extensions/gsd/tests/auto-paused-session-validation.test.ts +12 -0
- package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +122 -0
- package/src/resources/extensions/gsd/tests/auto-start-bootstrap-await-3420.test.ts +141 -0
- package/src/resources/extensions/gsd/tests/auto-start-clean-runtime-db-gated.test.ts +63 -0
- package/src/resources/extensions/gsd/tests/auto-wrapup-inflight-guard.test.ts +23 -0
- package/src/resources/extensions/gsd/tests/clean-root-preflight.test.ts +186 -0
- package/src/resources/extensions/gsd/tests/cmux.test.ts +5 -9
- package/src/resources/extensions/gsd/tests/complete-milestone-false-merge.test.ts +15 -0
- package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +61 -1
- package/src/resources/extensions/gsd/tests/complete-slice.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/complete-task.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +161 -0
- package/src/resources/extensions/gsd/tests/db-access-guardrails.test.ts +1 -0
- package/src/resources/extensions/gsd/tests/derive-state.test.ts +1 -2
- package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +14 -9
- package/src/resources/extensions/gsd/tests/dispatch-guard-summary-db-mismatch.test.ts +77 -0
- package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +25 -0
- package/src/resources/extensions/gsd/tests/dispatch-missing-task-plans.test.ts +14 -0
- package/src/resources/extensions/gsd/tests/doctor-providers.test.ts +31 -0
- package/src/resources/extensions/gsd/tests/double-merge-guard.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/escalation.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/exec-history.test.ts +113 -0
- package/src/resources/extensions/gsd/tests/execution-entry-missing-context-4671.test.ts +173 -0
- package/src/resources/extensions/gsd/tests/file-change-validator.test.ts +38 -0
- package/src/resources/extensions/gsd/tests/file-lock.test.ts +86 -12
- package/src/resources/extensions/gsd/tests/google-search-stub.test.ts +131 -0
- package/src/resources/extensions/gsd/tests/gsd-db.test.ts +296 -1
- package/src/resources/extensions/gsd/tests/headless-milestone-parity.test.ts +117 -0
- package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +30 -0
- package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +4 -2
- package/src/resources/extensions/gsd/tests/integration/gitignore-tracked-gsd.test.ts +1 -0
- package/src/resources/extensions/gsd/tests/integration/idle-recovery.test.ts +30 -0
- package/src/resources/extensions/gsd/tests/integration/worktree-e2e.test.ts +11 -0
- package/src/resources/extensions/gsd/tests/issue-4540-regressions.test.ts +288 -0
- package/src/resources/extensions/gsd/tests/journal-integration.test.ts +66 -0
- package/src/resources/extensions/gsd/tests/key-manager.test.ts +2 -0
- package/src/resources/extensions/gsd/tests/mcp-client-security.test.ts +76 -0
- package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/memory-pressure-stuck-state.test.ts +12 -0
- package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/milestone-status-authoritative.test.ts +3 -3
- package/src/resources/extensions/gsd/tests/milestone-summary-classifier.test.ts +30 -0
- package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +4 -2
- package/src/resources/extensions/gsd/tests/parallel-commit-scope.test.ts +5 -0
- package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +19 -0
- package/src/resources/extensions/gsd/tests/parallel-skill-prompt-integration.test.ts +150 -0
- package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +37 -0
- package/src/resources/extensions/gsd/tests/pre-exec-gate-loop.test.ts +272 -0
- package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +337 -0
- package/src/resources/extensions/gsd/tests/prefs-wizard-coverage.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/provider-errors.test.ts +39 -25
- package/src/resources/extensions/gsd/tests/queue-auto-guard.test.ts +181 -0
- package/src/resources/extensions/gsd/tests/quick-auto-guard.test.ts +13 -7
- package/src/resources/extensions/gsd/tests/ready-phrase-no-files-4573.test.ts +388 -0
- package/src/resources/extensions/gsd/tests/require-slice-discussion-dispatch.test.ts +170 -0
- package/src/resources/extensions/gsd/tests/restore-tools-after-discuss.test.ts +9 -3
- package/src/resources/extensions/gsd/tests/resume-dispatch-worktree.test.ts +230 -0
- package/src/resources/extensions/gsd/tests/rewrite-docs-abandon-detect.test.ts +195 -0
- package/src/resources/extensions/gsd/tests/safety-harness-false-positives.test.ts +205 -0
- package/src/resources/extensions/gsd/tests/schema-v21-sequence.test.ts +413 -0
- package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +32 -40
- package/src/resources/extensions/gsd/tests/stale-dirlistcache-4648.test.ts +112 -0
- package/src/resources/extensions/gsd/tests/stash-queued-context-files.test.ts +56 -0
- package/src/resources/extensions/gsd/tests/state-machine-full-walkthrough.test.ts +24 -0
- package/src/resources/extensions/gsd/tests/state-transition-matrix.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/stuck-detection-coverage.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/token-counter.test.ts +105 -1
- package/src/resources/extensions/gsd/tests/tool-compatibility.test.ts +107 -0
- package/src/resources/extensions/gsd/tests/triage-resolution.test.ts +50 -2
- package/src/resources/extensions/gsd/tests/turn-epoch.test.ts +162 -0
- package/src/resources/extensions/gsd/tests/uok-contracts.test.ts +51 -0
- package/src/resources/extensions/gsd/tests/uok-execution-graph.test.ts +16 -0
- package/src/resources/extensions/gsd/tests/uok-loop-adapter-writer.test.ts +65 -0
- package/src/resources/extensions/gsd/tests/uok-parity-report.test.ts +42 -0
- package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +42 -2
- package/src/resources/extensions/gsd/tests/uok-writer.test.ts +75 -0
- package/src/resources/extensions/gsd/tests/validate-extension-package.test.ts +168 -0
- package/src/resources/extensions/gsd/tests/validate-milestone.test.ts +138 -5
- package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +25 -2
- package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +65 -2
- package/src/resources/extensions/gsd/tests/worktree-db.test.ts +35 -0
- package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +6 -1
- package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +78 -5
- package/src/resources/extensions/gsd/tests/write-gate.test.ts +64 -0
- package/src/resources/extensions/gsd/token-counter.ts +22 -5
- package/src/resources/extensions/gsd/tools/complete-milestone.ts +15 -9
- package/src/resources/extensions/gsd/tools/complete-slice.ts +38 -0
- package/src/resources/extensions/gsd/tools/complete-task.ts +49 -0
- package/src/resources/extensions/gsd/uok/audit.ts +20 -2
- package/src/resources/extensions/gsd/uok/contracts.ts +65 -0
- package/src/resources/extensions/gsd/uok/dispatch-envelope.ts +56 -0
- package/src/resources/extensions/gsd/uok/execution-graph.ts +22 -0
- package/src/resources/extensions/gsd/uok/gitops.ts +6 -1
- package/src/resources/extensions/gsd/uok/loop-adapter.ts +45 -10
- package/src/resources/extensions/gsd/uok/parity-report.ts +84 -0
- package/src/resources/extensions/gsd/uok/plan-v2.ts +39 -8
- package/src/resources/extensions/gsd/uok/writer.ts +113 -0
- package/src/resources/extensions/gsd/workflow-logger.ts +23 -3
- package/src/resources/extensions/gsd/worktree-manager.ts +1 -0
- package/src/resources/extensions/gsd/worktree-resolver.ts +54 -9
- package/src/resources/extensions/mcp-client/auth.ts +12 -1
- package/src/resources/extensions/mcp-client/index.ts +129 -10
- package/src/resources/extensions/shared/cmux-events.ts +59 -0
- package/src/resources/extensions/shared/rtk-session-stats.ts +1 -2
- package/src/resources/skills/create-skill/SKILL.md +2 -2
- package/src/resources/skills/create-skill/references/gsd-skill-ecosystem.md +4 -4
- package/src/resources/skills/create-skill/workflows/audit-skill.md +4 -4
- package/src/resources/skills/create-skill/workflows/create-new-skill.md +5 -5
- package/src/resources/skills/verify-before-complete/SKILL.md +2 -1
- package/src/resources/skills/write-docs/SKILL.md +2 -1
- package/dist/web/standalone/.next/server/chunks/7461.js +0 -1
- package/dist/web/standalone/.next/static/chunks/2826.e59e8578e2e28639.js +0 -9
- /package/dist/web/standalone/.next/static/{n21VtX2hZlkpdEUO_nU4z → vidAVJkURvTJ0_V2-64ro}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{n21VtX2hZlkpdEUO_nU4z → vidAVJkURvTJ0_V2-64ro}/_ssgManifest.js +0 -0
|
@@ -1599,6 +1599,221 @@ describe("checkTaskOrdering directory inputs (#4446)", () => {
|
|
|
1599
1599
|
});
|
|
1600
1600
|
});
|
|
1601
1601
|
|
|
1602
|
+
// ─── Regression Tests: checkTaskOrdering false positive for pre-execution refs (#4071) ──
|
|
1603
|
+
|
|
1604
|
+
describe("checkTaskOrdering false positive for pre-execution refs (#4071)", () => {
|
|
1605
|
+
test("completed task at higher index does not trigger ordering violation for its outputs", () => {
|
|
1606
|
+
// Scenario: after a replan, a completed task at higher array index has already
|
|
1607
|
+
// created a file. A new earlier-sequence task reads that file. Since the
|
|
1608
|
+
// completed task already ran, its output is available regardless of disk state.
|
|
1609
|
+
// checkTaskOrdering must not flag this as a sequence violation.
|
|
1610
|
+
const tasks = [
|
|
1611
|
+
createTask({
|
|
1612
|
+
id: "T_NEW",
|
|
1613
|
+
sequence: 1,
|
|
1614
|
+
status: "pending",
|
|
1615
|
+
inputs: ["artifacts/setup.json"],
|
|
1616
|
+
expected_output: [],
|
|
1617
|
+
}),
|
|
1618
|
+
createTask({
|
|
1619
|
+
id: "T_SETUP",
|
|
1620
|
+
sequence: 5,
|
|
1621
|
+
status: "completed",
|
|
1622
|
+
inputs: [],
|
|
1623
|
+
expected_output: ["artifacts/setup.json"],
|
|
1624
|
+
}),
|
|
1625
|
+
];
|
|
1626
|
+
|
|
1627
|
+
const results = checkTaskOrdering(tasks, "/tmp");
|
|
1628
|
+
assert.equal(
|
|
1629
|
+
results.length,
|
|
1630
|
+
0,
|
|
1631
|
+
"completed task outputs must not trigger ordering violations for earlier-sequence tasks that read them",
|
|
1632
|
+
);
|
|
1633
|
+
});
|
|
1634
|
+
|
|
1635
|
+
test("pending task at higher index still triggers ordering violation", () => {
|
|
1636
|
+
// A PENDING task at higher index creating a file is a real violation.
|
|
1637
|
+
// Only completed tasks get the exemption.
|
|
1638
|
+
const tasks = [
|
|
1639
|
+
createTask({
|
|
1640
|
+
id: "T01",
|
|
1641
|
+
sequence: 1,
|
|
1642
|
+
status: "pending",
|
|
1643
|
+
inputs: ["artifacts/output.json"],
|
|
1644
|
+
expected_output: [],
|
|
1645
|
+
}),
|
|
1646
|
+
createTask({
|
|
1647
|
+
id: "T02",
|
|
1648
|
+
sequence: 5,
|
|
1649
|
+
status: "pending",
|
|
1650
|
+
inputs: [],
|
|
1651
|
+
expected_output: ["artifacts/output.json"],
|
|
1652
|
+
}),
|
|
1653
|
+
];
|
|
1654
|
+
|
|
1655
|
+
const results = checkTaskOrdering(tasks, "/tmp");
|
|
1656
|
+
assert.equal(
|
|
1657
|
+
results.length,
|
|
1658
|
+
1,
|
|
1659
|
+
"pending task at higher index must still be flagged as ordering violation",
|
|
1660
|
+
);
|
|
1661
|
+
assert.equal(results[0].blocking, true);
|
|
1662
|
+
assert.ok(results[0].message.includes("T01"));
|
|
1663
|
+
assert.ok(results[0].message.includes("T02"));
|
|
1664
|
+
assert.ok(results[0].message.includes("sequence violation"));
|
|
1665
|
+
});
|
|
1666
|
+
|
|
1667
|
+
test("pending-first then completed-later: completed replaces pending in fileCreators (#4572)", () => {
|
|
1668
|
+
// Regression for CodeRabbit Major finding on PR #4572:
|
|
1669
|
+
// fileCreators only stored the FIRST task for a given path. If a PENDING task at
|
|
1670
|
+
// array index 1 was registered first, and a COMPLETED task at array index 2 also
|
|
1671
|
+
// declared the same output path, the completed entry was discarded. Line ~529 then
|
|
1672
|
+
// saw a pending creator with index > i and incorrectly fired a sequence violation
|
|
1673
|
+
// for the reader at array index 0.
|
|
1674
|
+
//
|
|
1675
|
+
// Scenario: path first declared by pending task (index 1), then by completed task
|
|
1676
|
+
// (index 2). Reader is at index 0. Without the fix a violation fires; with the fix
|
|
1677
|
+
// the completed entry replaces the pending entry and grants the exemption.
|
|
1678
|
+
const tasks = [
|
|
1679
|
+
// array index 0 — reads the shared path
|
|
1680
|
+
createTask({
|
|
1681
|
+
id: "T_READER",
|
|
1682
|
+
sequence: 1,
|
|
1683
|
+
status: "pending",
|
|
1684
|
+
inputs: ["shared/artifact.json"],
|
|
1685
|
+
expected_output: [],
|
|
1686
|
+
}),
|
|
1687
|
+
// array index 1 — pending producer (visited first during map build)
|
|
1688
|
+
createTask({
|
|
1689
|
+
id: "T_PENDING_PRODUCER",
|
|
1690
|
+
sequence: 5,
|
|
1691
|
+
status: "pending",
|
|
1692
|
+
inputs: [],
|
|
1693
|
+
expected_output: ["shared/artifact.json"],
|
|
1694
|
+
}),
|
|
1695
|
+
// array index 2 — completed producer (visited second; must replace pending entry)
|
|
1696
|
+
createTask({
|
|
1697
|
+
id: "T_COMPLETED_PRODUCER",
|
|
1698
|
+
sequence: 2,
|
|
1699
|
+
status: "completed",
|
|
1700
|
+
inputs: [],
|
|
1701
|
+
expected_output: ["shared/artifact.json"],
|
|
1702
|
+
}),
|
|
1703
|
+
];
|
|
1704
|
+
|
|
1705
|
+
// Without the fix: creator = T_PENDING_PRODUCER (index 1), !creator.completed && 1 > 0 → violation.
|
|
1706
|
+
// With the fix: creator = T_COMPLETED_PRODUCER (index 2), creator.completed → no violation.
|
|
1707
|
+
const results = checkTaskOrdering(tasks, "/tmp");
|
|
1708
|
+
assert.equal(
|
|
1709
|
+
results.length,
|
|
1710
|
+
0,
|
|
1711
|
+
"completed producer must replace pending producer in fileCreators and suppress false violation",
|
|
1712
|
+
);
|
|
1713
|
+
});
|
|
1714
|
+
|
|
1715
|
+
test("completed task output exemption applies regardless of whether file exists on disk", (t) => {
|
|
1716
|
+
// The completed-task exemption must work even when the file is not on disk
|
|
1717
|
+
// (e.g., the file was a temporary artifact that was cleaned up after the task ran).
|
|
1718
|
+
const tempDir = join(tmpdir(), `pre-exec-completed-task-${Date.now()}`);
|
|
1719
|
+
mkdirSync(tempDir, { recursive: true });
|
|
1720
|
+
t.after(() => rmSync(tempDir, { recursive: true, force: true }));
|
|
1721
|
+
|
|
1722
|
+
// File deliberately NOT created on disk — completed task ran in a prior session
|
|
1723
|
+
const tasks = [
|
|
1724
|
+
createTask({
|
|
1725
|
+
id: "T_MAIN",
|
|
1726
|
+
sequence: 0,
|
|
1727
|
+
status: "pending",
|
|
1728
|
+
inputs: ["generated/config.json"],
|
|
1729
|
+
expected_output: [],
|
|
1730
|
+
}),
|
|
1731
|
+
createTask({
|
|
1732
|
+
id: "T_INIT",
|
|
1733
|
+
sequence: 10,
|
|
1734
|
+
status: "completed",
|
|
1735
|
+
inputs: [],
|
|
1736
|
+
expected_output: ["generated/config.json"],
|
|
1737
|
+
}),
|
|
1738
|
+
];
|
|
1739
|
+
|
|
1740
|
+
const results = checkTaskOrdering(tasks, tempDir);
|
|
1741
|
+
assert.equal(
|
|
1742
|
+
results.length,
|
|
1743
|
+
0,
|
|
1744
|
+
"completed task exemption must apply even when file is absent from disk",
|
|
1745
|
+
);
|
|
1746
|
+
});
|
|
1747
|
+
});
|
|
1748
|
+
|
|
1749
|
+
describe("checkFilePathConsistency completed-task output exemption (#4071)", () => {
|
|
1750
|
+
test("completed task at higher index does not cause false positive for file it produced", (t) => {
|
|
1751
|
+
// Parallel to the checkTaskOrdering fix: checkFilePathConsistency also uses
|
|
1752
|
+
// getExpectedOutputsUpTo which historically only looked at prior-index tasks.
|
|
1753
|
+
// A completed task at a higher index has already run and its outputs are available.
|
|
1754
|
+
const tempDir = join(tmpdir(), `pre-exec-fc-completed-${Date.now()}`);
|
|
1755
|
+
mkdirSync(tempDir, { recursive: true });
|
|
1756
|
+
t.after(() => rmSync(tempDir, { recursive: true, force: true }));
|
|
1757
|
+
|
|
1758
|
+
// File is NOT on disk — completed task ran in a prior session and file was cleaned
|
|
1759
|
+
const tasks = [
|
|
1760
|
+
createTask({
|
|
1761
|
+
id: "T_MAIN",
|
|
1762
|
+
sequence: 1,
|
|
1763
|
+
status: "pending",
|
|
1764
|
+
inputs: ["artifacts/config.json"],
|
|
1765
|
+
expected_output: [],
|
|
1766
|
+
}),
|
|
1767
|
+
createTask({
|
|
1768
|
+
id: "T_SETUP",
|
|
1769
|
+
sequence: 10,
|
|
1770
|
+
status: "completed",
|
|
1771
|
+
inputs: [],
|
|
1772
|
+
expected_output: ["artifacts/config.json"],
|
|
1773
|
+
}),
|
|
1774
|
+
];
|
|
1775
|
+
|
|
1776
|
+
const results = checkFilePathConsistency(tasks, tempDir);
|
|
1777
|
+
assert.equal(
|
|
1778
|
+
results.length,
|
|
1779
|
+
0,
|
|
1780
|
+
"completed task at higher index should satisfy inputs of pending tasks that read its outputs",
|
|
1781
|
+
);
|
|
1782
|
+
});
|
|
1783
|
+
|
|
1784
|
+
test("pending task at higher index still causes a missing-file error", (t) => {
|
|
1785
|
+
const tempDir = join(tmpdir(), `pre-exec-fc-pending-${Date.now()}`);
|
|
1786
|
+
mkdirSync(tempDir, { recursive: true });
|
|
1787
|
+
t.after(() => rmSync(tempDir, { recursive: true, force: true }));
|
|
1788
|
+
|
|
1789
|
+
const tasks = [
|
|
1790
|
+
createTask({
|
|
1791
|
+
id: "T01",
|
|
1792
|
+
sequence: 1,
|
|
1793
|
+
status: "pending",
|
|
1794
|
+
inputs: ["artifacts/output.json"],
|
|
1795
|
+
expected_output: [],
|
|
1796
|
+
}),
|
|
1797
|
+
createTask({
|
|
1798
|
+
id: "T02",
|
|
1799
|
+
sequence: 10,
|
|
1800
|
+
status: "pending",
|
|
1801
|
+
inputs: [],
|
|
1802
|
+
expected_output: ["artifacts/output.json"],
|
|
1803
|
+
}),
|
|
1804
|
+
];
|
|
1805
|
+
|
|
1806
|
+
const results = checkFilePathConsistency(tasks, tempDir);
|
|
1807
|
+
assert.equal(
|
|
1808
|
+
results.length,
|
|
1809
|
+
1,
|
|
1810
|
+
"pending task at higher index must still be flagged — the file is not available yet",
|
|
1811
|
+
);
|
|
1812
|
+
assert.equal(results[0].blocking, true);
|
|
1813
|
+
assert.equal(results[0].target, "artifacts/output.json");
|
|
1814
|
+
});
|
|
1815
|
+
});
|
|
1816
|
+
|
|
1602
1817
|
describe("checkFilePathConsistency self-referential inputs (#4459)", () => {
|
|
1603
1818
|
test("input that is also in the same task's expected_output is not blocking when missing on disk", (t) => {
|
|
1604
1819
|
const tempDir = join(tmpdir(), `pre-exec-self-output-${Date.now()}`);
|
|
@@ -1664,3 +1879,125 @@ describe("checkFilePathConsistency self-referential inputs (#4459)", () => {
|
|
|
1664
1879
|
);
|
|
1665
1880
|
});
|
|
1666
1881
|
});
|
|
1882
|
+
|
|
1883
|
+
// ─── Regression Tests: quote-wrapped inputs treated as literal paths (#3747) ──
|
|
1884
|
+
|
|
1885
|
+
describe("checkFilePathConsistency quote-wrapped annotation (#3747)", () => {
|
|
1886
|
+
test("double-quoted path annotation is stripped before path check", (t) => {
|
|
1887
|
+
// Plan documents sometimes emit `"src/foo.ts"` (double-quote wrapped) as an
|
|
1888
|
+
// input value. The checker must strip the quotes before checking existence so
|
|
1889
|
+
// it doesn't produce a false-positive "file not found" error.
|
|
1890
|
+
const tempDir = join(tmpdir(), `pre-exec-quote-${Date.now()}`);
|
|
1891
|
+
mkdirSync(join(tempDir, "src"), { recursive: true });
|
|
1892
|
+
writeFileSync(join(tempDir, "src/foo.ts"), "// content");
|
|
1893
|
+
t.after(() => rmSync(tempDir, { recursive: true, force: true }));
|
|
1894
|
+
|
|
1895
|
+
const tasks = [
|
|
1896
|
+
createTask({
|
|
1897
|
+
id: "T01",
|
|
1898
|
+
inputs: ['"src/foo.ts"'],
|
|
1899
|
+
expected_output: [],
|
|
1900
|
+
}),
|
|
1901
|
+
];
|
|
1902
|
+
|
|
1903
|
+
const results = checkFilePathConsistency(tasks, tempDir);
|
|
1904
|
+
assert.equal(
|
|
1905
|
+
results.length,
|
|
1906
|
+
0,
|
|
1907
|
+
"Double-quoted path should be stripped and resolved to the real file",
|
|
1908
|
+
);
|
|
1909
|
+
});
|
|
1910
|
+
|
|
1911
|
+
test("single-quoted path annotation is stripped before path check", (t) => {
|
|
1912
|
+
const tempDir = join(tmpdir(), `pre-exec-squote-${Date.now()}`);
|
|
1913
|
+
mkdirSync(join(tempDir, "src"), { recursive: true });
|
|
1914
|
+
writeFileSync(join(tempDir, "src/bar.ts"), "// content");
|
|
1915
|
+
t.after(() => rmSync(tempDir, { recursive: true, force: true }));
|
|
1916
|
+
|
|
1917
|
+
const tasks = [
|
|
1918
|
+
createTask({
|
|
1919
|
+
id: "T01",
|
|
1920
|
+
inputs: ["'src/bar.ts'"],
|
|
1921
|
+
expected_output: [],
|
|
1922
|
+
}),
|
|
1923
|
+
];
|
|
1924
|
+
|
|
1925
|
+
const results = checkFilePathConsistency(tasks, tempDir);
|
|
1926
|
+
assert.equal(
|
|
1927
|
+
results.length,
|
|
1928
|
+
0,
|
|
1929
|
+
"Single-quoted path should be stripped and resolved to the real file",
|
|
1930
|
+
);
|
|
1931
|
+
});
|
|
1932
|
+
|
|
1933
|
+
test("backtick-only wrapped path without annotation resolves correctly", (t) => {
|
|
1934
|
+
// The bare form `src/foo.ts` (no dash annotation) must also work
|
|
1935
|
+
const tempDir = join(tmpdir(), `pre-exec-backtick-bare-${Date.now()}`);
|
|
1936
|
+
mkdirSync(join(tempDir, "src"), { recursive: true });
|
|
1937
|
+
writeFileSync(join(tempDir, "src/baz.ts"), "// content");
|
|
1938
|
+
t.after(() => rmSync(tempDir, { recursive: true, force: true }));
|
|
1939
|
+
|
|
1940
|
+
const tasks = [
|
|
1941
|
+
createTask({
|
|
1942
|
+
id: "T01",
|
|
1943
|
+
inputs: ["`src/baz.ts`"],
|
|
1944
|
+
expected_output: [],
|
|
1945
|
+
}),
|
|
1946
|
+
];
|
|
1947
|
+
|
|
1948
|
+
const results = checkFilePathConsistency(tasks, tempDir);
|
|
1949
|
+
assert.equal(
|
|
1950
|
+
results.length,
|
|
1951
|
+
0,
|
|
1952
|
+
"Bare backtick-wrapped path should resolve to the real file",
|
|
1953
|
+
);
|
|
1954
|
+
});
|
|
1955
|
+
|
|
1956
|
+
test("prose value with spaces inside quotes is skipped (not a path)", () => {
|
|
1957
|
+
// "some description text" contains spaces — should not be checked as a path
|
|
1958
|
+
const tasks = [
|
|
1959
|
+
createTask({
|
|
1960
|
+
id: "T01",
|
|
1961
|
+
inputs: ['"some description text"'],
|
|
1962
|
+
expected_output: [],
|
|
1963
|
+
}),
|
|
1964
|
+
];
|
|
1965
|
+
|
|
1966
|
+
const results = checkFilePathConsistency(tasks, "/tmp");
|
|
1967
|
+
assert.equal(
|
|
1968
|
+
results.length,
|
|
1969
|
+
0,
|
|
1970
|
+
"Quoted prose with spaces should not be treated as a file path",
|
|
1971
|
+
);
|
|
1972
|
+
});
|
|
1973
|
+
|
|
1974
|
+
test("17-error scenario: mixed annotated inputs produce 0 blocking errors", (t) => {
|
|
1975
|
+
// Reproduces the M004-ej6j88/S07 scenario from issue #3747 where a plan with
|
|
1976
|
+
// multiple backtick- and quote-wrapped input strings causes 17 false blocking errors.
|
|
1977
|
+
const tempDir = join(tmpdir(), `pre-exec-3747-scenario-${Date.now()}`);
|
|
1978
|
+
mkdirSync(join(tempDir, "src"), { recursive: true });
|
|
1979
|
+
writeFileSync(join(tempDir, "src/foo.ts"), "// content");
|
|
1980
|
+
writeFileSync(join(tempDir, "src/bar.ts"), "// content");
|
|
1981
|
+
t.after(() => rmSync(tempDir, { recursive: true, force: true }));
|
|
1982
|
+
|
|
1983
|
+
const tasks = [
|
|
1984
|
+
createTask({
|
|
1985
|
+
id: "T01",
|
|
1986
|
+
inputs: [
|
|
1987
|
+
"`src/foo.ts`",
|
|
1988
|
+
'"src/bar.ts"',
|
|
1989
|
+
"some description text",
|
|
1990
|
+
"Existing enum definition",
|
|
1991
|
+
],
|
|
1992
|
+
expected_output: [],
|
|
1993
|
+
}),
|
|
1994
|
+
];
|
|
1995
|
+
|
|
1996
|
+
const results = checkFilePathConsistency(tasks, tempDir);
|
|
1997
|
+
assert.equal(
|
|
1998
|
+
results.length,
|
|
1999
|
+
0,
|
|
2000
|
+
"Annotated file paths and prose inputs should produce zero blocking errors",
|
|
2001
|
+
);
|
|
2002
|
+
});
|
|
2003
|
+
});
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
// Guard test — every key in KNOWN_PREFERENCE_KEYS must be reachable from the
|
|
2
|
+
// /gsd prefs wizard. Without this guard, a new preference can be added to the
|
|
3
|
+
// schema without anyone wiring it into the TUI, silently re-creating the gap
|
|
4
|
+
// this test exists to prevent.
|
|
5
|
+
|
|
6
|
+
import test from "node:test";
|
|
7
|
+
import assert from "node:assert/strict";
|
|
8
|
+
import { readFileSync } from "node:fs";
|
|
9
|
+
|
|
10
|
+
import { KNOWN_PREFERENCE_KEYS } from "../preferences-types.ts";
|
|
11
|
+
|
|
12
|
+
// Keys exposed via a dedicated command rather than the wizard. They're still
|
|
13
|
+
// reachable by the user, just not inside the category menu flow. If you add a
|
|
14
|
+
// new key here, add a comment explaining where it lives.
|
|
15
|
+
const EXPOSED_OUTSIDE_WIZARD = new Set<string>([
|
|
16
|
+
"version", // auto-managed by writePreferencesFile
|
|
17
|
+
"modelOverrides", // advanced routing — edit PREFERENCES.md directly (not in KNOWN_PREFERENCE_KEYS)
|
|
18
|
+
"context_mode", // advanced sandbox config (gsd_exec + compaction) — enabled by default; edit PREFERENCES.md directly to tune timeouts/caps. Wizard coverage tracked separately.
|
|
19
|
+
]);
|
|
20
|
+
|
|
21
|
+
test("every KNOWN_PREFERENCE_KEYS entry is reachable from the wizard source", () => {
|
|
22
|
+
const src = readFileSync(
|
|
23
|
+
new URL("../commands-prefs-wizard.ts", import.meta.url),
|
|
24
|
+
"utf-8",
|
|
25
|
+
);
|
|
26
|
+
|
|
27
|
+
const missing: string[] = [];
|
|
28
|
+
for (const key of KNOWN_PREFERENCE_KEYS) {
|
|
29
|
+
if (EXPOSED_OUTSIDE_WIZARD.has(key)) continue;
|
|
30
|
+
// The key must appear somewhere in the wizard — either as a direct
|
|
31
|
+
// prefs[...] / pref reference, or in the orderedKeys serialization list.
|
|
32
|
+
// A plain substring match is enough because all prefs-wizard references
|
|
33
|
+
// use the exact key name.
|
|
34
|
+
if (!src.includes(`"${key}"`) && !src.includes(`.${key}`)) {
|
|
35
|
+
missing.push(key);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
assert.deepEqual(
|
|
40
|
+
missing,
|
|
41
|
+
[],
|
|
42
|
+
`These preference keys are in KNOWN_PREFERENCE_KEYS but are not referenced anywhere in the /gsd prefs wizard — they cannot be configured through the UI. Either add wizard coverage or add them to EXPOSED_OUTSIDE_WIZARD with an explanatory comment:\n${missing.join("\n")}`,
|
|
43
|
+
);
|
|
44
|
+
});
|
|
@@ -404,6 +404,8 @@ test("resumeAutoAfterProviderDelay restarts paused auto-mode from the recorded b
|
|
|
404
404
|
stepMode: true,
|
|
405
405
|
basePath: "/tmp/project",
|
|
406
406
|
}),
|
|
407
|
+
resetTransientRetryState: () => {},
|
|
408
|
+
resetSessionTimeoutState: () => {},
|
|
407
409
|
startAuto: async (_ctx, _pi, base, verboseMode, options) => {
|
|
408
410
|
startCalls.push({ base, verboseMode, step: options?.step });
|
|
409
411
|
},
|
|
@@ -428,6 +430,8 @@ test("resumeAutoAfterProviderDelay does not double-start when auto-mode is alrea
|
|
|
428
430
|
stepMode: false,
|
|
429
431
|
basePath: "/tmp/project",
|
|
430
432
|
}),
|
|
433
|
+
resetTransientRetryState: () => {},
|
|
434
|
+
resetSessionTimeoutState: () => {},
|
|
431
435
|
startAuto: async () => {
|
|
432
436
|
startCalls += 1;
|
|
433
437
|
},
|
|
@@ -458,6 +462,8 @@ test("resumeAutoAfterProviderDelay leaves auto paused when no base path is avail
|
|
|
458
462
|
stepMode: false,
|
|
459
463
|
basePath: "",
|
|
460
464
|
}),
|
|
465
|
+
resetTransientRetryState: () => {},
|
|
466
|
+
resetSessionTimeoutState: () => {},
|
|
461
467
|
startAuto: async () => {
|
|
462
468
|
startCalls += 1;
|
|
463
469
|
},
|
|
@@ -474,6 +480,39 @@ test("resumeAutoAfterProviderDelay leaves auto paused when no base path is avail
|
|
|
474
480
|
]);
|
|
475
481
|
});
|
|
476
482
|
|
|
483
|
+
test("resumeAutoAfterProviderDelay resets provider retry state before restarting auto-mode", async () => {
|
|
484
|
+
const calls: string[] = [];
|
|
485
|
+
|
|
486
|
+
const result = await resumeAutoAfterProviderDelay(
|
|
487
|
+
{} as any,
|
|
488
|
+
{ ui: { notify() {} } } as any,
|
|
489
|
+
{
|
|
490
|
+
getSnapshot: () => ({
|
|
491
|
+
active: false,
|
|
492
|
+
paused: true,
|
|
493
|
+
stepMode: false,
|
|
494
|
+
basePath: "/tmp/project",
|
|
495
|
+
}),
|
|
496
|
+
resetTransientRetryState: () => {
|
|
497
|
+
calls.push("reset-transient");
|
|
498
|
+
},
|
|
499
|
+
resetSessionTimeoutState: () => {
|
|
500
|
+
calls.push("reset-session-timeout");
|
|
501
|
+
},
|
|
502
|
+
startAuto: async () => {
|
|
503
|
+
calls.push("start-auto");
|
|
504
|
+
},
|
|
505
|
+
},
|
|
506
|
+
);
|
|
507
|
+
|
|
508
|
+
assert.equal(result, "resumed");
|
|
509
|
+
assert.deepEqual(calls, [
|
|
510
|
+
"reset-transient",
|
|
511
|
+
"reset-session-timeout",
|
|
512
|
+
"start-auto",
|
|
513
|
+
]);
|
|
514
|
+
});
|
|
515
|
+
|
|
477
516
|
// ── Escalating backoff for transient errors (#1166) ─────────────────────────
|
|
478
517
|
|
|
479
518
|
test("agent-end-recovery.ts tracks consecutive transient errors for escalating backoff", () => {
|
|
@@ -567,31 +606,6 @@ test("resetTransientRetryState is exported from agent-end-recovery.ts", () => {
|
|
|
567
606
|
);
|
|
568
607
|
});
|
|
569
608
|
|
|
570
|
-
test("provider-error-resume.ts calls resetTransientRetryState before startAuto", () => {
|
|
571
|
-
const src = readFileSync(join(__dirname, "..", "bootstrap", "provider-error-resume.ts"), "utf-8");
|
|
572
|
-
assert.ok(
|
|
573
|
-
src.includes("resetTransientRetryState"),
|
|
574
|
-
"provider-error-resume.ts must import and call resetTransientRetryState",
|
|
575
|
-
);
|
|
576
|
-
// Ensure reset is called BEFORE startAuto — order matters
|
|
577
|
-
const resetIdx = src.indexOf("resetTransientRetryState()");
|
|
578
|
-
const startIdx = src.indexOf("await deps.startAuto(");
|
|
579
|
-
assert.ok(
|
|
580
|
-
resetIdx !== -1 && startIdx !== -1 && resetIdx < startIdx,
|
|
581
|
-
"resetTransientRetryState() must be called before deps.startAuto()",
|
|
582
|
-
);
|
|
583
|
-
// Session timeout counter must also be reset before startAuto
|
|
584
|
-
assert.ok(
|
|
585
|
-
src.includes("resetSessionTimeoutState"),
|
|
586
|
-
"provider-error-resume.ts must import and call resetSessionTimeoutState",
|
|
587
|
-
);
|
|
588
|
-
const sessionResetIdx = src.indexOf("resetSessionTimeoutState()");
|
|
589
|
-
assert.ok(
|
|
590
|
-
sessionResetIdx !== -1 && startIdx !== -1 && sessionResetIdx < startIdx,
|
|
591
|
-
"resetSessionTimeoutState() must be called before deps.startAuto()",
|
|
592
|
-
);
|
|
593
|
-
});
|
|
594
|
-
|
|
595
609
|
// ── Fix 2: Session creation timeout treated as transient in phases.ts ───────
|
|
596
610
|
|
|
597
611
|
test("phases.ts handles timeout session-creation failures with pause instead of stopAuto", () => {
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests that /gsd queue is blocked when auto-mode is active.
|
|
3
|
+
*
|
|
4
|
+
* Relates to #4704: /gsd queue writes .gsd/PROJECT.md + QUEUE-ORDER.json
|
|
5
|
+
* directly into the project-root worktree, racing with auto-mode's
|
|
6
|
+
* pre-merge dirty-tree check and causing __dirty_working_tree__ failures.
|
|
7
|
+
*
|
|
8
|
+
* The fix adds an isAutoActive() guard in handleWorkflowCommand before
|
|
9
|
+
* delegating to showQueue, mirroring the existing /gsd quick guard (#2417).
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
import { describe, it } from "node:test";
|
|
13
|
+
import assert from "node:assert/strict";
|
|
14
|
+
import { readFileSync } from "node:fs";
|
|
15
|
+
import { join } from "node:path";
|
|
16
|
+
|
|
17
|
+
// ─── Structural test: verify the guard exists in source ──────────────────────
|
|
18
|
+
|
|
19
|
+
describe("/gsd queue auto-mode guard (#4704)", () => {
|
|
20
|
+
it("handleWorkflowCommand checks isAutoActive() before calling showQueue", () => {
|
|
21
|
+
const src = readFileSync(
|
|
22
|
+
join(
|
|
23
|
+
import.meta.dirname,
|
|
24
|
+
"..",
|
|
25
|
+
"commands",
|
|
26
|
+
"handlers",
|
|
27
|
+
"workflow.ts",
|
|
28
|
+
),
|
|
29
|
+
"utf-8",
|
|
30
|
+
);
|
|
31
|
+
|
|
32
|
+
// Find the queue command block
|
|
33
|
+
const queueBlockMatch = src.match(
|
|
34
|
+
/if\s*\(\s*trimmed\s*===\s*"queue"\s*\)\s*\{([\s\S]*?)\n \}/,
|
|
35
|
+
);
|
|
36
|
+
assert.ok(queueBlockMatch, "queue command block exists in handleWorkflowCommand");
|
|
37
|
+
|
|
38
|
+
const queueBlock = queueBlockMatch[1];
|
|
39
|
+
|
|
40
|
+
// Verify auto-mode guard comes BEFORE showQueue call. Accepts either the
|
|
41
|
+
// inline isAutoActive() check (Tier 1) or the shared requireNotAutoActive()
|
|
42
|
+
// helper (Tier 2 / #4712).
|
|
43
|
+
const guardIndex = Math.max(
|
|
44
|
+
queueBlock.indexOf("isAutoActive()"),
|
|
45
|
+
queueBlock.indexOf("requireNotAutoActive("),
|
|
46
|
+
);
|
|
47
|
+
const showQueueIndex = queueBlock.indexOf("showQueue(");
|
|
48
|
+
|
|
49
|
+
assert.ok(guardIndex !== -1, "auto-mode guard exists in queue command block");
|
|
50
|
+
assert.ok(showQueueIndex !== -1, "showQueue() call exists in queue command block");
|
|
51
|
+
assert.ok(
|
|
52
|
+
guardIndex < showQueueIndex,
|
|
53
|
+
"auto-mode guard appears before showQueue() call",
|
|
54
|
+
);
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
it("guard shows error message mentioning /gsd stop", () => {
|
|
58
|
+
const src = readFileSync(
|
|
59
|
+
join(
|
|
60
|
+
import.meta.dirname,
|
|
61
|
+
"..",
|
|
62
|
+
"commands",
|
|
63
|
+
"handlers",
|
|
64
|
+
"workflow.ts",
|
|
65
|
+
),
|
|
66
|
+
"utf-8",
|
|
67
|
+
);
|
|
68
|
+
|
|
69
|
+
assert.ok(
|
|
70
|
+
src.includes("cannot run while auto-mode is active"),
|
|
71
|
+
"error message explains that the command cannot run during auto-mode",
|
|
72
|
+
);
|
|
73
|
+
assert.ok(
|
|
74
|
+
src.includes("/gsd stop"),
|
|
75
|
+
"error message mentions /gsd stop as the resolution",
|
|
76
|
+
);
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
it("guard returns true (handled) to prevent falling through", () => {
|
|
80
|
+
const src = readFileSync(
|
|
81
|
+
join(
|
|
82
|
+
import.meta.dirname,
|
|
83
|
+
"..",
|
|
84
|
+
"commands",
|
|
85
|
+
"handlers",
|
|
86
|
+
"workflow.ts",
|
|
87
|
+
),
|
|
88
|
+
"utf-8",
|
|
89
|
+
);
|
|
90
|
+
|
|
91
|
+
const queueBlockMatch = src.match(
|
|
92
|
+
/if\s*\(\s*trimmed\s*===\s*"queue"\s*\)\s*\{([\s\S]*?)\n \}/,
|
|
93
|
+
);
|
|
94
|
+
assert.ok(queueBlockMatch);
|
|
95
|
+
const queueBlock = queueBlockMatch[1];
|
|
96
|
+
|
|
97
|
+
// The guard block should have its own return true before showQueue
|
|
98
|
+
const guardBlock = queueBlock.slice(0, queueBlock.indexOf("showQueue("));
|
|
99
|
+
assert.ok(
|
|
100
|
+
guardBlock.includes("return true"),
|
|
101
|
+
"guard block returns true before showQueue is reached",
|
|
102
|
+
);
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
// ─── .gsd/audit/ runtime classification regression ──────────────────────────
|
|
107
|
+
|
|
108
|
+
describe(".gsd/audit/ runtime classification (#4704)", () => {
|
|
109
|
+
it("GSD_RUNTIME_PATTERNS in gitignore.ts includes .gsd/audit/", () => {
|
|
110
|
+
const src = readFileSync(
|
|
111
|
+
join(import.meta.dirname, "..", "gitignore.ts"),
|
|
112
|
+
"utf-8",
|
|
113
|
+
);
|
|
114
|
+
assert.ok(
|
|
115
|
+
src.includes('".gsd/audit/"'),
|
|
116
|
+
".gsd/audit/ listed in GSD_RUNTIME_PATTERNS",
|
|
117
|
+
);
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
it("RUNTIME_EXCLUSION_PATHS in git-service.ts includes .gsd/audit/", () => {
|
|
121
|
+
const src = readFileSync(
|
|
122
|
+
join(import.meta.dirname, "..", "git-service.ts"),
|
|
123
|
+
"utf-8",
|
|
124
|
+
);
|
|
125
|
+
assert.ok(
|
|
126
|
+
src.includes('".gsd/audit/"'),
|
|
127
|
+
".gsd/audit/ listed in RUNTIME_EXCLUSION_PATHS",
|
|
128
|
+
);
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
it("SKIP_PATHS in worktree-manager.ts includes .gsd/audit/", () => {
|
|
132
|
+
const src = readFileSync(
|
|
133
|
+
join(import.meta.dirname, "..", "worktree-manager.ts"),
|
|
134
|
+
"utf-8",
|
|
135
|
+
);
|
|
136
|
+
assert.ok(
|
|
137
|
+
src.includes('".gsd/audit/"'),
|
|
138
|
+
".gsd/audit/ listed in SKIP_PATHS",
|
|
139
|
+
);
|
|
140
|
+
});
|
|
141
|
+
});
|
|
142
|
+
|
|
143
|
+
// ─── Windows gsd.db close+reopen around pre-merge stash ─────────────────────
|
|
144
|
+
|
|
145
|
+
describe("Windows pre-merge DB release (#4704)", () => {
|
|
146
|
+
it("mergeMilestoneToMain closes gsd.db on win32 before git stash", () => {
|
|
147
|
+
const src = readFileSync(
|
|
148
|
+
join(import.meta.dirname, "..", "auto-worktree.ts"),
|
|
149
|
+
"utf-8",
|
|
150
|
+
);
|
|
151
|
+
|
|
152
|
+
// Locate the stash push line and ensure a win32-gated closeDatabase()
|
|
153
|
+
// call precedes it in the same function scope.
|
|
154
|
+
const stashIndex = src.indexOf('"stash", "push", "--include-untracked"');
|
|
155
|
+
assert.ok(stashIndex !== -1, "pre-merge stash push exists");
|
|
156
|
+
|
|
157
|
+
const beforeStash = src.slice(0, stashIndex);
|
|
158
|
+
const win32Index = beforeStash.lastIndexOf('process.platform === "win32"');
|
|
159
|
+
const closeIndex = beforeStash.lastIndexOf("closeDatabase()");
|
|
160
|
+
|
|
161
|
+
assert.ok(win32Index !== -1, "win32 platform guard appears before stash");
|
|
162
|
+
assert.ok(closeIndex !== -1, "closeDatabase() invoked before stash");
|
|
163
|
+
assert.ok(
|
|
164
|
+
win32Index < closeIndex && closeIndex < stashIndex,
|
|
165
|
+
"platform guard wraps the closeDatabase() call before the stash",
|
|
166
|
+
);
|
|
167
|
+
});
|
|
168
|
+
|
|
169
|
+
it("openDatabase is called after the stash to reopen the connection", () => {
|
|
170
|
+
const src = readFileSync(
|
|
171
|
+
join(import.meta.dirname, "..", "auto-worktree.ts"),
|
|
172
|
+
"utf-8",
|
|
173
|
+
);
|
|
174
|
+
const stashIndex = src.indexOf('"stash", "push", "--include-untracked"');
|
|
175
|
+
const afterStash = src.slice(stashIndex);
|
|
176
|
+
assert.ok(
|
|
177
|
+
afterStash.includes("openDatabase("),
|
|
178
|
+
"openDatabase() called after the pre-merge stash",
|
|
179
|
+
);
|
|
180
|
+
});
|
|
181
|
+
});
|