gsd-pi 2.79.0-dev.ece5fd8ba → 2.80.0-dev.c5f2443b3
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/resources/.managed-resources-content-hash +1 -1
- package/dist/resources/extensions/github-sync/templates.js +55 -70
- package/dist/resources/extensions/gsd/auto/contracts.js +1 -0
- package/dist/resources/extensions/gsd/auto/custom-verify-retry-store.js +53 -0
- package/dist/resources/extensions/gsd/auto/loop.js +359 -523
- package/dist/resources/extensions/gsd/auto/orchestrator.js +146 -0
- package/dist/resources/extensions/gsd/auto/phases.js +55 -6
- package/dist/resources/extensions/gsd/auto/session.js +8 -0
- package/dist/resources/extensions/gsd/auto/workflow-custom-engine-dispatch-outcome.js +12 -0
- package/dist/resources/extensions/gsd/auto/workflow-custom-engine-iteration.js +24 -0
- package/dist/resources/extensions/gsd/auto/workflow-custom-engine-reconcile-outcome.js +33 -0
- package/dist/resources/extensions/gsd/auto/workflow-custom-engine-reconcile.js +26 -0
- package/dist/resources/extensions/gsd/auto/workflow-custom-engine-retry.js +49 -0
- package/dist/resources/extensions/gsd/auto/workflow-custom-engine-verify-outcome.js +25 -0
- package/dist/resources/extensions/gsd/auto/workflow-dispatch-claim.js +48 -0
- package/dist/resources/extensions/gsd/auto/workflow-dispatch-ledger.js +26 -0
- package/dist/resources/extensions/gsd/auto/workflow-iteration-completion.js +10 -0
- package/dist/resources/extensions/gsd/auto/workflow-journal-reporter.js +16 -0
- package/dist/resources/extensions/gsd/auto/workflow-kernel.js +263 -0
- package/dist/resources/extensions/gsd/auto/workflow-memory-pressure.js +36 -0
- package/dist/resources/extensions/gsd/auto/workflow-phase-reporter.js +9 -0
- package/dist/resources/extensions/gsd/auto/workflow-session-lock.js +35 -0
- package/dist/resources/extensions/gsd/auto/workflow-sidecar-iteration.js +24 -0
- package/dist/resources/extensions/gsd/auto/workflow-sidecar-queue.js +26 -0
- package/dist/resources/extensions/gsd/auto/workflow-turn-reporter.js +36 -0
- package/dist/resources/extensions/gsd/auto/workflow-unit-dispatch.js +44 -0
- package/dist/resources/extensions/gsd/auto/workflow-worker-heartbeat.js +15 -0
- package/dist/resources/extensions/gsd/auto-dashboard.js +3 -0
- package/dist/resources/extensions/gsd/auto-prompts.js +168 -3
- package/dist/resources/extensions/gsd/auto-recovery.js +45 -52
- package/dist/resources/extensions/gsd/auto-runtime-state.js +4 -0
- package/dist/resources/extensions/gsd/auto-verification.js +2 -11
- package/dist/resources/extensions/gsd/auto-worktree.js +87 -38
- package/dist/resources/extensions/gsd/auto.js +159 -2
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +9 -1
- package/dist/resources/extensions/gsd/bootstrap/db-tools.js +10 -0
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +11 -5
- package/dist/resources/extensions/gsd/commands-ship.js +23 -46
- package/dist/resources/extensions/gsd/commands-workflow-templates.js +12 -7
- package/dist/resources/extensions/gsd/component-loader.js +5 -11
- package/dist/resources/extensions/gsd/custom-workflow-engine.js +4 -0
- package/dist/resources/extensions/gsd/db-adapter.js +47 -0
- package/dist/resources/extensions/gsd/db-base-schema.js +337 -0
- package/dist/resources/extensions/gsd/db-connection-cache.js +31 -0
- package/dist/resources/extensions/gsd/db-coordination-schema.js +104 -0
- package/dist/resources/extensions/gsd/db-decision-requirement-rows.js +71 -0
- package/dist/resources/extensions/gsd/db-gate-rows.js +16 -0
- package/dist/resources/extensions/gsd/db-lightweight-query-rows.js +29 -0
- package/dist/resources/extensions/gsd/db-memory-fts-schema.js +56 -0
- package/dist/resources/extensions/gsd/db-migration-backup.js +22 -0
- package/dist/resources/extensions/gsd/db-migration-steps.js +394 -0
- package/dist/resources/extensions/gsd/db-milestone-artifact-rows.js +35 -0
- package/dist/resources/extensions/gsd/db-open-state.js +32 -0
- package/dist/resources/extensions/gsd/db-provider.js +108 -0
- package/dist/resources/extensions/gsd/db-runtime-kv-schema.js +27 -0
- package/dist/resources/extensions/gsd/db-schema-metadata.js +23 -0
- package/dist/resources/extensions/gsd/db-task-slice-rows.js +86 -0
- package/dist/resources/extensions/gsd/db-transaction.js +63 -0
- package/dist/resources/extensions/gsd/db-verification-evidence-rows.js +3 -0
- package/dist/resources/extensions/gsd/db-verification-evidence-schema.js +19 -0
- package/dist/resources/extensions/gsd/escalation.js +2 -0
- package/dist/resources/extensions/gsd/gsd-db.js +215 -1519
- package/dist/resources/extensions/gsd/legacy-telemetry.js +70 -0
- package/dist/resources/extensions/gsd/markdown-renderer.js +2 -0
- package/dist/resources/extensions/gsd/model-router.js +9 -6
- package/dist/resources/extensions/gsd/notification-widget.js +21 -3
- package/dist/resources/extensions/gsd/post-execution-checks.js +27 -6
- package/dist/resources/extensions/gsd/pr-evidence.js +76 -0
- package/dist/resources/extensions/gsd/pre-execution-checks.js +2 -0
- package/dist/resources/extensions/gsd/process-task-path.js +61 -0
- package/dist/resources/extensions/gsd/prompt-loader.js +9 -5
- package/dist/resources/extensions/gsd/prompts/complete-milestone.md +32 -30
- package/dist/resources/extensions/gsd/prompts/complete-slice.md +23 -34
- package/dist/resources/extensions/gsd/prompts/discuss-headless.md +50 -96
- package/dist/resources/extensions/gsd/prompts/discuss.md +81 -181
- package/dist/resources/extensions/gsd/prompts/execute-task.md +40 -67
- package/dist/resources/extensions/gsd/prompts/forensics.md +41 -84
- package/dist/resources/extensions/gsd/prompts/guided-discuss-milestone.md +29 -39
- package/dist/resources/extensions/gsd/prompts/guided-discuss-project.md +30 -65
- package/dist/resources/extensions/gsd/prompts/guided-discuss-requirements.md +25 -52
- package/dist/resources/extensions/gsd/prompts/guided-discuss-slice.md +36 -36
- package/dist/resources/extensions/gsd/prompts/guided-research-project.md +20 -38
- package/dist/resources/extensions/gsd/prompts/plan-milestone.md +45 -59
- package/dist/resources/extensions/gsd/prompts/plan-slice.md +25 -87
- package/dist/resources/extensions/gsd/prompts/queue.md +46 -53
- package/dist/resources/extensions/gsd/prompts/refine-slice.md +23 -23
- package/dist/resources/extensions/gsd/prompts/research-slice.md +23 -23
- package/dist/resources/extensions/gsd/prompts/rethink.md +10 -10
- package/dist/resources/extensions/gsd/prompts/system.md +65 -107
- package/dist/resources/extensions/gsd/prompts/triage-captures.md +15 -15
- package/dist/resources/extensions/gsd/prompts/validate-milestone.md +24 -24
- package/dist/resources/extensions/gsd/prompts/worktree-merge.md +35 -35
- package/dist/resources/extensions/gsd/state.js +4 -0
- package/dist/resources/extensions/gsd/tools/complete-milestone.js +14 -9
- package/dist/resources/extensions/gsd/tools/complete-task.js +2 -0
- package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +6 -1
- package/dist/resources/extensions/gsd/unit-context-composer.js +1 -1
- package/dist/resources/extensions/gsd/uok/kernel.js +8 -3
- package/dist/resources/extensions/gsd/uok/plan-v2.js +2 -0
- package/dist/resources/extensions/gsd/workflow-logger.js +13 -13
- package/dist/resources/extensions/gsd/workflow-manifest.js +2 -0
- package/dist/resources/extensions/gsd/workflow-projections.js +2 -0
- package/dist/resources/extensions/gsd/workflow-templates.js +9 -0
- package/dist/resources/extensions/shared/interview-ui.js +15 -4
- 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 +13 -13
- package/dist/web/standalone/.next/build-manifest.json +2 -2
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- package/dist/web/standalone/.next/required-server-files.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 +13 -13
- package/dist/web/standalone/.next/server/chunks/167.js +2 -0
- package/dist/web/standalone/.next/server/chunks/6897.js +1 -1
- package/dist/web/standalone/.next/server/middleware-build-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/package.json +1 -0
- package/dist/web/standalone/server.js +1 -1
- package/package.json +9 -2
- package/packages/contracts/dist/index.d.ts +3 -0
- package/packages/contracts/dist/index.d.ts.map +1 -0
- package/packages/contracts/dist/index.js +5 -0
- package/packages/contracts/dist/index.js.map +1 -0
- package/packages/contracts/dist/rpc.d.ts +549 -0
- package/packages/contracts/dist/rpc.d.ts.map +1 -0
- package/packages/contracts/dist/rpc.js +53 -0
- package/packages/contracts/dist/rpc.js.map +1 -0
- package/packages/contracts/dist/rpc.test.d.ts +2 -0
- package/packages/contracts/dist/rpc.test.d.ts.map +1 -0
- package/packages/contracts/dist/rpc.test.js +47 -0
- package/packages/contracts/dist/rpc.test.js.map +1 -0
- package/packages/contracts/dist/workflow.d.ts +180 -0
- package/packages/contracts/dist/workflow.d.ts.map +1 -0
- package/packages/contracts/dist/workflow.js +201 -0
- package/packages/contracts/dist/workflow.js.map +1 -0
- package/packages/contracts/package.json +39 -0
- package/packages/contracts/src/index.ts +5 -0
- package/packages/contracts/src/rpc.test.ts +72 -0
- package/packages/contracts/src/rpc.ts +286 -0
- package/packages/contracts/src/workflow.ts +213 -0
- package/packages/contracts/tsconfig.json +25 -0
- package/packages/contracts/tsconfig.tsbuildinfo +1 -0
- package/packages/daemon/package.json +3 -2
- package/packages/daemon/src/event-bridge.test.ts +2 -1
- package/packages/daemon/src/event-bridge.ts +1 -1
- package/packages/daemon/src/event-formatter.test.ts +1 -2
- package/packages/daemon/src/event-formatter.ts +1 -2
- package/packages/daemon/src/session-manager.ts +2 -2
- package/packages/daemon/src/types.ts +3 -18
- package/packages/mcp-server/dist/server.d.ts +13 -0
- package/packages/mcp-server/dist/server.d.ts.map +1 -1
- package/packages/mcp-server/dist/server.js +77 -0
- package/packages/mcp-server/dist/server.js.map +1 -1
- package/packages/mcp-server/dist/session-manager.js +1 -1
- package/packages/mcp-server/dist/session-manager.js.map +1 -1
- package/packages/mcp-server/dist/types.d.ts +3 -11
- package/packages/mcp-server/dist/types.d.ts.map +1 -1
- package/packages/mcp-server/dist/types.js.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.d.ts +1 -1
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +2 -40
- package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
- package/packages/mcp-server/package.json +3 -2
- package/packages/mcp-server/src/mcp-server.test.ts +138 -0
- package/packages/mcp-server/src/server.ts +99 -1
- package/packages/mcp-server/src/session-manager.ts +2 -2
- package/packages/mcp-server/src/types.ts +7 -18
- package/packages/mcp-server/src/workflow-tools.ts +2 -40
- package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
- package/packages/native/package.json +1 -1
- package/packages/pi-agent-core/package.json +1 -1
- package/packages/pi-ai/package.json +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js +14 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.js +20 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +6 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +9 -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 +31 -10
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/rpc/rpc-types.d.ts +1 -512
- package/packages/pi-coding-agent/dist/modes/rpc/rpc-types.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/rpc/rpc-types.js +3 -7
- package/packages/pi-coding-agent/dist/modes/rpc/rpc-types.js.map +1 -1
- package/packages/pi-coding-agent/package.json +2 -1
- package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/tool-execution.test.ts +23 -2
- package/packages/pi-coding-agent/src/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.ts +31 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +6 -1
- package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +50 -9
- package/packages/pi-coding-agent/src/modes/rpc/rpc-types.ts +3 -336
- package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
- package/packages/pi-tui/dist/tui.d.ts +1 -0
- package/packages/pi-tui/dist/tui.d.ts.map +1 -1
- package/packages/pi-tui/dist/tui.js +8 -2
- package/packages/pi-tui/dist/tui.js.map +1 -1
- package/packages/pi-tui/package.json +1 -1
- package/packages/pi-tui/src/tui.ts +8 -2
- package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
- package/packages/rpc-client/README.md +3 -3
- package/packages/rpc-client/dist/index.d.ts +1 -1
- package/packages/rpc-client/dist/index.d.ts.map +1 -1
- package/packages/rpc-client/dist/index.js.map +1 -1
- package/packages/rpc-client/dist/rpc-client.d.ts +2 -6
- package/packages/rpc-client/dist/rpc-client.d.ts.map +1 -1
- package/packages/rpc-client/dist/rpc-client.js.map +1 -1
- package/packages/rpc-client/dist/rpc-types.d.ts +1 -565
- package/packages/rpc-client/dist/rpc-types.d.ts.map +1 -1
- package/packages/rpc-client/dist/rpc-types.js +3 -11
- package/packages/rpc-client/dist/rpc-types.js.map +1 -1
- package/packages/rpc-client/package.json +4 -1
- package/packages/rpc-client/src/index.ts +1 -1
- package/packages/rpc-client/src/rpc-client.ts +3 -6
- package/packages/rpc-client/src/rpc-types.ts +3 -398
- package/packages/rpc-client/tsconfig.tsbuildinfo +1 -1
- package/pkg/package.json +1 -1
- package/src/resources/extensions/github-sync/templates.ts +59 -84
- package/src/resources/extensions/github-sync/tests/templates.test.ts +10 -2
- package/src/resources/extensions/gsd/auto/contracts.ts +87 -0
- package/src/resources/extensions/gsd/auto/custom-verify-retry-store.ts +72 -0
- package/src/resources/extensions/gsd/auto/loop-deps.ts +10 -3
- package/src/resources/extensions/gsd/auto/loop.ts +411 -598
- package/src/resources/extensions/gsd/auto/orchestrator.ts +161 -0
- package/src/resources/extensions/gsd/auto/phases.ts +82 -8
- package/src/resources/extensions/gsd/auto/session.ts +11 -0
- package/src/resources/extensions/gsd/auto/workflow-custom-engine-dispatch-outcome.ts +28 -0
- package/src/resources/extensions/gsd/auto/workflow-custom-engine-iteration.ts +52 -0
- package/src/resources/extensions/gsd/auto/workflow-custom-engine-reconcile-outcome.ts +58 -0
- package/src/resources/extensions/gsd/auto/workflow-custom-engine-reconcile.ts +71 -0
- package/src/resources/extensions/gsd/auto/workflow-custom-engine-retry.ts +90 -0
- package/src/resources/extensions/gsd/auto/workflow-custom-engine-verify-outcome.ts +50 -0
- package/src/resources/extensions/gsd/auto/workflow-dispatch-claim.ts +97 -0
- package/src/resources/extensions/gsd/auto/workflow-dispatch-ledger.ts +45 -0
- package/src/resources/extensions/gsd/auto/workflow-iteration-completion.ts +26 -0
- package/src/resources/extensions/gsd/auto/workflow-journal-reporter.ts +33 -0
- package/src/resources/extensions/gsd/auto/workflow-kernel.ts +520 -0
- package/src/resources/extensions/gsd/auto/workflow-memory-pressure.ts +58 -0
- package/src/resources/extensions/gsd/auto/workflow-phase-reporter.ts +22 -0
- package/src/resources/extensions/gsd/auto/workflow-session-lock.ts +68 -0
- package/src/resources/extensions/gsd/auto/workflow-sidecar-iteration.ts +46 -0
- package/src/resources/extensions/gsd/auto/workflow-sidecar-queue.ts +46 -0
- package/src/resources/extensions/gsd/auto/workflow-turn-reporter.ts +68 -0
- package/src/resources/extensions/gsd/auto/workflow-unit-dispatch.ts +89 -0
- package/src/resources/extensions/gsd/auto/workflow-worker-heartbeat.ts +38 -0
- package/src/resources/extensions/gsd/auto-dashboard.ts +4 -0
- package/src/resources/extensions/gsd/auto-prompts.ts +170 -3
- package/src/resources/extensions/gsd/auto-recovery.ts +42 -50
- package/src/resources/extensions/gsd/auto-runtime-state.ts +7 -0
- package/src/resources/extensions/gsd/auto-verification.ts +5 -1
- package/src/resources/extensions/gsd/auto-worktree.ts +85 -36
- package/src/resources/extensions/gsd/auto.ts +167 -1
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +14 -1
- package/src/resources/extensions/gsd/bootstrap/db-tools.ts +11 -0
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +13 -5
- package/src/resources/extensions/gsd/commands-ship.ts +24 -51
- package/src/resources/extensions/gsd/commands-workflow-templates.ts +13 -0
- package/src/resources/extensions/gsd/component-loader.ts +5 -11
- package/src/resources/extensions/gsd/custom-workflow-engine.ts +6 -0
- package/src/resources/extensions/gsd/db-adapter.ts +75 -0
- package/src/resources/extensions/gsd/db-base-schema.ts +368 -0
- package/src/resources/extensions/gsd/db-connection-cache.ts +45 -0
- package/src/resources/extensions/gsd/db-coordination-schema.ts +109 -0
- package/src/resources/extensions/gsd/db-decision-requirement-rows.ts +77 -0
- package/src/resources/extensions/gsd/db-gate-rows.ts +19 -0
- package/src/resources/extensions/gsd/db-lightweight-query-rows.ts +50 -0
- package/src/resources/extensions/gsd/db-memory-fts-schema.ts +66 -0
- package/src/resources/extensions/gsd/db-migration-backup.ts +34 -0
- package/src/resources/extensions/gsd/db-migration-steps.ts +434 -0
- package/src/resources/extensions/gsd/db-milestone-artifact-rows.ts +70 -0
- package/src/resources/extensions/gsd/db-open-state.ts +47 -0
- package/src/resources/extensions/gsd/db-provider.ts +148 -0
- package/src/resources/extensions/gsd/db-runtime-kv-schema.ts +30 -0
- package/src/resources/extensions/gsd/db-schema-metadata.ts +33 -0
- package/src/resources/extensions/gsd/db-task-slice-rows.ts +146 -0
- package/src/resources/extensions/gsd/db-transaction.ts +76 -0
- package/src/resources/extensions/gsd/db-verification-evidence-rows.ts +14 -0
- package/src/resources/extensions/gsd/db-verification-evidence-schema.ts +22 -0
- package/src/resources/extensions/gsd/escalation.ts +3 -1
- package/src/resources/extensions/gsd/gsd-db.ts +260 -1659
- package/src/resources/extensions/gsd/interrupted-session.ts +1 -0
- package/src/resources/extensions/gsd/legacy-telemetry.ts +99 -0
- package/src/resources/extensions/gsd/markdown-renderer.ts +4 -1
- package/src/resources/extensions/gsd/model-router.ts +10 -6
- package/src/resources/extensions/gsd/notification-widget.ts +25 -4
- package/src/resources/extensions/gsd/post-execution-checks.ts +35 -7
- package/src/resources/extensions/gsd/pr-evidence.ts +124 -0
- package/src/resources/extensions/gsd/pre-execution-checks.ts +4 -1
- package/src/resources/extensions/gsd/process-task-path.ts +81 -0
- package/src/resources/extensions/gsd/prompt-loader.ts +9 -5
- package/src/resources/extensions/gsd/prompts/complete-milestone.md +32 -30
- package/src/resources/extensions/gsd/prompts/complete-slice.md +23 -34
- package/src/resources/extensions/gsd/prompts/discuss-headless.md +50 -96
- package/src/resources/extensions/gsd/prompts/discuss.md +81 -181
- package/src/resources/extensions/gsd/prompts/execute-task.md +40 -67
- package/src/resources/extensions/gsd/prompts/forensics.md +41 -84
- package/src/resources/extensions/gsd/prompts/guided-discuss-milestone.md +29 -39
- package/src/resources/extensions/gsd/prompts/guided-discuss-project.md +30 -65
- package/src/resources/extensions/gsd/prompts/guided-discuss-requirements.md +25 -52
- package/src/resources/extensions/gsd/prompts/guided-discuss-slice.md +36 -36
- package/src/resources/extensions/gsd/prompts/guided-research-project.md +20 -38
- package/src/resources/extensions/gsd/prompts/plan-milestone.md +45 -59
- package/src/resources/extensions/gsd/prompts/plan-slice.md +25 -87
- package/src/resources/extensions/gsd/prompts/queue.md +46 -53
- package/src/resources/extensions/gsd/prompts/refine-slice.md +23 -23
- package/src/resources/extensions/gsd/prompts/research-slice.md +23 -23
- package/src/resources/extensions/gsd/prompts/rethink.md +10 -10
- package/src/resources/extensions/gsd/prompts/system.md +65 -107
- package/src/resources/extensions/gsd/prompts/triage-captures.md +15 -15
- package/src/resources/extensions/gsd/prompts/validate-milestone.md +24 -24
- package/src/resources/extensions/gsd/prompts/worktree-merge.md +35 -35
- package/src/resources/extensions/gsd/state.ts +6 -3
- package/src/resources/extensions/gsd/tests/auto-abort-pause-regression.test.ts +32 -0
- package/src/resources/extensions/gsd/tests/auto-dashboard.test.ts +65 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +38 -0
- package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +353 -0
- package/src/resources/extensions/gsd/tests/auto-pr-bugs.test.ts +19 -0
- package/src/resources/extensions/gsd/tests/auto-runtime-state.test.ts +39 -0
- package/src/resources/extensions/gsd/tests/auto-session-encapsulation.test.ts +3 -0
- package/src/resources/extensions/gsd/tests/commands-eval-review.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/commands-ship-eval-warn.test.ts +3 -2
- package/src/resources/extensions/gsd/tests/complete-milestone-prompt-rendering.test.ts +47 -0
- package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +19 -5
- package/src/resources/extensions/gsd/tests/component-loader.test.ts +2 -9
- package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +38 -0
- package/src/resources/extensions/gsd/tests/custom-verify-retry-store.test.ts +139 -0
- package/src/resources/extensions/gsd/tests/custom-workflow-engine.test.ts +12 -0
- package/src/resources/extensions/gsd/tests/dashboard-custom-engine.test.ts +3 -3
- package/src/resources/extensions/gsd/tests/db-adapter.test.ts +82 -0
- package/src/resources/extensions/gsd/tests/db-base-schema.test.ts +62 -0
- package/src/resources/extensions/gsd/tests/db-connection-cache.test.ts +60 -0
- package/src/resources/extensions/gsd/tests/db-coordination-schema.test.ts +39 -0
- package/src/resources/extensions/gsd/tests/db-decision-requirement-rows.test.ts +135 -0
- package/src/resources/extensions/gsd/tests/db-gate-rows.test.ts +53 -0
- package/src/resources/extensions/gsd/tests/db-lightweight-query-rows.test.ts +45 -0
- package/src/resources/extensions/gsd/tests/db-memory-fts-schema.test.ts +86 -0
- package/src/resources/extensions/gsd/tests/db-migration-backup.test.ts +105 -0
- package/src/resources/extensions/gsd/tests/db-migration-steps.test.ts +159 -0
- package/src/resources/extensions/gsd/tests/db-milestone-artifact-rows.test.ts +53 -0
- package/src/resources/extensions/gsd/tests/db-open-state.test.ts +56 -0
- package/src/resources/extensions/gsd/tests/db-provider.test.ts +105 -0
- package/src/resources/extensions/gsd/tests/db-runtime-kv-schema.test.ts +37 -0
- package/src/resources/extensions/gsd/tests/db-schema-metadata.test.ts +115 -0
- package/src/resources/extensions/gsd/tests/db-task-slice-rows.test.ts +128 -0
- package/src/resources/extensions/gsd/tests/db-transaction.test.ts +110 -0
- package/src/resources/extensions/gsd/tests/db-verification-evidence-schema.test.ts +76 -0
- package/src/resources/extensions/gsd/tests/discuss-headless-rendering.test.ts +37 -0
- package/src/resources/extensions/gsd/tests/execute-task-rendering.test.ts +59 -0
- package/src/resources/extensions/gsd/tests/forensics-prompt-rendering.test.ts +36 -0
- package/src/resources/extensions/gsd/tests/gsd-db.test.ts +95 -0
- package/src/resources/extensions/gsd/tests/guided-discuss-milestone-prompt-rendering.test.ts +43 -0
- package/src/resources/extensions/gsd/tests/guided-discuss-project-prompt-rendering.test.ts +41 -0
- package/src/resources/extensions/gsd/tests/guided-discuss-requirements-prompt-rendering.test.ts +45 -0
- package/src/resources/extensions/gsd/tests/integration/auto-recovery.test.ts +79 -0
- package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +37 -0
- package/src/resources/extensions/gsd/tests/integration/state-machine-live-validation.test.ts +5 -3
- package/src/resources/extensions/gsd/tests/journal-integration.test.ts +134 -0
- package/src/resources/extensions/gsd/tests/legacy-component-format-telemetry.test.ts +62 -0
- package/src/resources/extensions/gsd/tests/legacy-telemetry.test.ts +144 -0
- package/src/resources/extensions/gsd/tests/memory-pressure-stuck-state.test.ts +40 -16
- package/src/resources/extensions/gsd/tests/model-router.test.ts +33 -12
- package/src/resources/extensions/gsd/tests/notification-store.test.ts +8 -0
- package/src/resources/extensions/gsd/tests/notification-widget.test.ts +40 -1
- package/src/resources/extensions/gsd/tests/paused-session-via-db.test.ts +2 -0
- package/src/resources/extensions/gsd/tests/plan-milestone-rendering.test.ts +45 -0
- package/src/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +65 -16
- package/src/resources/extensions/gsd/tests/plan-slice.test.ts +27 -0
- package/src/resources/extensions/gsd/tests/post-execution-checks.test.ts +46 -0
- package/src/resources/extensions/gsd/tests/pr-evidence.test.ts +79 -0
- package/src/resources/extensions/gsd/tests/process-task-path.test.ts +51 -0
- package/src/resources/extensions/gsd/tests/prompt-step-ordering.test.ts +16 -1
- package/src/resources/extensions/gsd/tests/queue-prompt-rendering.test.ts +37 -0
- package/src/resources/extensions/gsd/tests/tool-naming.test.ts +32 -9
- package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +6 -6
- package/src/resources/extensions/gsd/tests/uok-kernel-path.test.ts +12 -0
- package/src/resources/extensions/gsd/tests/workflow-custom-engine-dispatch-outcome.test.ts +55 -0
- package/src/resources/extensions/gsd/tests/workflow-custom-engine-iteration.test.ts +93 -0
- package/src/resources/extensions/gsd/tests/workflow-custom-engine-reconcile-outcome.test.ts +108 -0
- package/src/resources/extensions/gsd/tests/workflow-custom-engine-reconcile.test.ts +146 -0
- package/src/resources/extensions/gsd/tests/workflow-custom-engine-retry.test.ts +136 -0
- package/src/resources/extensions/gsd/tests/workflow-custom-engine-verify-outcome.test.ts +95 -0
- package/src/resources/extensions/gsd/tests/workflow-dispatch-claim.test.ts +158 -0
- package/src/resources/extensions/gsd/tests/workflow-dispatch-ledger.test.ts +82 -0
- package/src/resources/extensions/gsd/tests/workflow-iteration-completion.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/workflow-journal-reporter.test.ts +49 -0
- package/src/resources/extensions/gsd/tests/workflow-kernel.test.ts +607 -0
- package/src/resources/extensions/gsd/tests/workflow-logger.test.ts +20 -4
- package/src/resources/extensions/gsd/tests/workflow-memory-pressure.test.ts +71 -0
- package/src/resources/extensions/gsd/tests/workflow-phase-reporter.test.ts +40 -0
- package/src/resources/extensions/gsd/tests/workflow-session-lock.test.ts +135 -0
- package/src/resources/extensions/gsd/tests/workflow-sidecar-iteration.test.ts +110 -0
- package/src/resources/extensions/gsd/tests/workflow-sidecar-queue.test.ts +116 -0
- package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +21 -0
- package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +32 -0
- package/src/resources/extensions/gsd/tests/workflow-turn-reporter.test.ts +87 -0
- package/src/resources/extensions/gsd/tests/workflow-unit-dispatch.test.ts +160 -0
- package/src/resources/extensions/gsd/tests/workflow-worker-heartbeat.test.ts +123 -0
- package/src/resources/extensions/gsd/tests/worktree-submodule-safety.test.ts +17 -33
- package/src/resources/extensions/gsd/tools/complete-milestone.ts +15 -9
- package/src/resources/extensions/gsd/tools/complete-task.ts +4 -1
- package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +6 -1
- package/src/resources/extensions/gsd/unit-context-composer.ts +1 -1
- package/src/resources/extensions/gsd/uok/kernel.ts +10 -3
- package/src/resources/extensions/gsd/uok/plan-v2.ts +5 -1
- package/src/resources/extensions/gsd/workflow-logger.ts +13 -13
- package/src/resources/extensions/gsd/workflow-manifest.ts +6 -15
- package/src/resources/extensions/gsd/workflow-projections.ts +5 -1
- package/src/resources/extensions/gsd/workflow-templates.ts +11 -0
- package/src/resources/extensions/shared/interview-ui.ts +18 -5
- package/src/resources/extensions/shared/tests/interview-notes-loop.test.ts +41 -0
- package/dist/web/standalone/.next/server/chunks/6336.js +0 -1
- /package/dist/web/standalone/.next/static/{TzEVJ1Lh8vbez4n4Q9TqQ → bQDK5_LtkGVS64AirQgQG}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{TzEVJ1Lh8vbez4n4Q9TqQ → bQDK5_LtkGVS64AirQgQG}/_ssgManifest.js +0 -0
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: Unit tests for custom workflow verification retry persistence.
|
|
3
|
+
|
|
4
|
+
import assert from "node:assert/strict";
|
|
5
|
+
import { mkdirSync, mkdtempSync, readFileSync, rmSync, writeFileSync } from "node:fs";
|
|
6
|
+
import { tmpdir } from "node:os";
|
|
7
|
+
import { join } from "node:path";
|
|
8
|
+
import test from "node:test";
|
|
9
|
+
|
|
10
|
+
import {
|
|
11
|
+
customVerifyRetryStatePath,
|
|
12
|
+
hydrateCustomVerifyRetryCounts,
|
|
13
|
+
saveCustomVerifyRetryCounts,
|
|
14
|
+
} from "../auto/custom-verify-retry-store.ts";
|
|
15
|
+
|
|
16
|
+
function makeSession(activeRunDir: string): {
|
|
17
|
+
activeRunDir: string;
|
|
18
|
+
basePath: string;
|
|
19
|
+
verificationRetryCount: Map<string, number>;
|
|
20
|
+
} {
|
|
21
|
+
return {
|
|
22
|
+
activeRunDir,
|
|
23
|
+
basePath: activeRunDir,
|
|
24
|
+
verificationRetryCount: new Map<string, number>(),
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
test("hydrateCustomVerifyRetryCounts loads positive finite counts from disk", () => {
|
|
29
|
+
const dir = mkdtempSync(join(tmpdir(), "gsd-verify-retries-"));
|
|
30
|
+
try {
|
|
31
|
+
const session = makeSession(dir);
|
|
32
|
+
mkdirSync(join(dir, "runtime"));
|
|
33
|
+
writeFileSync(customVerifyRetryStatePath(session), JSON.stringify({
|
|
34
|
+
counts: {
|
|
35
|
+
"execute-task/M001/S001/T001": 2.8,
|
|
36
|
+
"execute-task/M001/S001/T002": 1,
|
|
37
|
+
zero: 0,
|
|
38
|
+
negative: -1,
|
|
39
|
+
infinite: Number.POSITIVE_INFINITY,
|
|
40
|
+
string: "3",
|
|
41
|
+
},
|
|
42
|
+
}));
|
|
43
|
+
|
|
44
|
+
const logged: unknown[] = [];
|
|
45
|
+
const counts = hydrateCustomVerifyRetryCounts(session, {
|
|
46
|
+
logFailure: err => logged.push(err),
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
assert.equal(counts, session.verificationRetryCount);
|
|
50
|
+
assert.deepEqual([...counts.entries()], [
|
|
51
|
+
["execute-task/M001/S001/T001", 2],
|
|
52
|
+
["execute-task/M001/S001/T002", 1],
|
|
53
|
+
]);
|
|
54
|
+
assert.deepEqual(logged, []);
|
|
55
|
+
} finally {
|
|
56
|
+
rmSync(dir, { recursive: true, force: true });
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
test("hydrateCustomVerifyRetryCounts keeps existing in-memory counts", () => {
|
|
61
|
+
const dir = mkdtempSync(join(tmpdir(), "gsd-verify-retries-"));
|
|
62
|
+
try {
|
|
63
|
+
const session = makeSession(dir);
|
|
64
|
+
session.verificationRetryCount.set("existing", 4);
|
|
65
|
+
|
|
66
|
+
const counts = hydrateCustomVerifyRetryCounts(session, {
|
|
67
|
+
logFailure: () => assert.fail("logFailure should not be called"),
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
assert.deepEqual([...counts.entries()], [["existing", 4]]);
|
|
71
|
+
} finally {
|
|
72
|
+
rmSync(dir, { recursive: true, force: true });
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
test("hydrateCustomVerifyRetryCounts logs read failures and returns the existing map", () => {
|
|
77
|
+
const dir = mkdtempSync(join(tmpdir(), "gsd-verify-retries-"));
|
|
78
|
+
try {
|
|
79
|
+
const session = makeSession(dir);
|
|
80
|
+
const logged: unknown[] = [];
|
|
81
|
+
|
|
82
|
+
const counts = hydrateCustomVerifyRetryCounts(session, {
|
|
83
|
+
logFailure: err => logged.push(err),
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
assert.equal(counts, session.verificationRetryCount);
|
|
87
|
+
assert.equal(counts.size, 0);
|
|
88
|
+
assert.equal(logged.length, 1);
|
|
89
|
+
} finally {
|
|
90
|
+
rmSync(dir, { recursive: true, force: true });
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
test("saveCustomVerifyRetryCounts writes counts with an updated timestamp", () => {
|
|
95
|
+
const dir = mkdtempSync(join(tmpdir(), "gsd-verify-retries-"));
|
|
96
|
+
try {
|
|
97
|
+
const session = makeSession(dir);
|
|
98
|
+
session.verificationRetryCount.set("execute-task/M001/S001/T001", 3);
|
|
99
|
+
|
|
100
|
+
saveCustomVerifyRetryCounts(session, {
|
|
101
|
+
logFailure: () => assert.fail("logFailure should not be called"),
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
const saved = JSON.parse(readFileSync(customVerifyRetryStatePath(session), "utf-8"));
|
|
105
|
+
assert.deepEqual(saved.counts, {
|
|
106
|
+
"execute-task/M001/S001/T001": 3,
|
|
107
|
+
});
|
|
108
|
+
assert.equal(typeof saved.updatedAt, "string");
|
|
109
|
+
} finally {
|
|
110
|
+
rmSync(dir, { recursive: true, force: true });
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
test("saveCustomVerifyRetryCounts deletes empty retry files and ignores missing files", () => {
|
|
115
|
+
const dir = mkdtempSync(join(tmpdir(), "gsd-verify-retries-"));
|
|
116
|
+
try {
|
|
117
|
+
const session = makeSession(dir);
|
|
118
|
+
session.verificationRetryCount.set("execute-task/M001/S001/T001", 1);
|
|
119
|
+
saveCustomVerifyRetryCounts(session, {
|
|
120
|
+
logFailure: () => assert.fail("logFailure should not be called"),
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
session.verificationRetryCount.clear();
|
|
124
|
+
saveCustomVerifyRetryCounts(session, {
|
|
125
|
+
logFailure: () => assert.fail("logFailure should not be called"),
|
|
126
|
+
});
|
|
127
|
+
saveCustomVerifyRetryCounts(session, {
|
|
128
|
+
logFailure: () => assert.fail("logFailure should not be called"),
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
const logged: unknown[] = [];
|
|
132
|
+
hydrateCustomVerifyRetryCounts(session, {
|
|
133
|
+
logFailure: err => logged.push(err),
|
|
134
|
+
});
|
|
135
|
+
assert.equal(logged.length, 1);
|
|
136
|
+
} finally {
|
|
137
|
+
rmSync(dir, { recursive: true, force: true });
|
|
138
|
+
}
|
|
139
|
+
});
|
|
@@ -193,6 +193,18 @@ describe("CustomWorkflowEngine.resolveDispatch", () => {
|
|
|
193
193
|
}
|
|
194
194
|
});
|
|
195
195
|
|
|
196
|
+
it("returns skip when pending steps are blocked by incomplete dependencies", async () => {
|
|
197
|
+
const { engine } = setupEngine([
|
|
198
|
+
makeStep({ id: "a", dependsOn: ["b"] }),
|
|
199
|
+
makeStep({ id: "b", dependsOn: ["a"] }),
|
|
200
|
+
]);
|
|
201
|
+
|
|
202
|
+
const state = await engine.deriveState("/unused");
|
|
203
|
+
const dispatch = await engine.resolveDispatch(state, { basePath: "/unused" });
|
|
204
|
+
|
|
205
|
+
assert.deepEqual(dispatch, { action: "skip" });
|
|
206
|
+
});
|
|
207
|
+
|
|
196
208
|
it("respects dependency ordering", async () => {
|
|
197
209
|
const { engine } = setupEngine([
|
|
198
210
|
makeStep({ id: "a" }),
|
|
@@ -44,7 +44,7 @@ describe("Dashboard custom-engine: updateProgressWidget in custom engine path",
|
|
|
44
44
|
const source = readFileSync(loopPath, "utf-8");
|
|
45
45
|
|
|
46
46
|
// Find the custom engine block
|
|
47
|
-
const customEngineStart = source.indexOf(
|
|
47
|
+
const customEngineStart = source.indexOf("shouldUseCustomEnginePath({");
|
|
48
48
|
assert.ok(customEngineStart > -1, "Should find custom engine path in loop.ts");
|
|
49
49
|
|
|
50
50
|
// The updateProgressWidget call should appear after the custom engine block start
|
|
@@ -66,11 +66,11 @@ describe("Dashboard custom-engine: updateProgressWidget in custom engine path",
|
|
|
66
66
|
const loopPath = resolve(__filename, "../../auto/loop.ts");
|
|
67
67
|
const source = readFileSync(loopPath, "utf-8");
|
|
68
68
|
|
|
69
|
-
const customEngineStart = source.indexOf(
|
|
69
|
+
const customEngineStart = source.indexOf("shouldUseCustomEnginePath({");
|
|
70
70
|
const afterCustomEngine = source.slice(customEngineStart);
|
|
71
71
|
|
|
72
72
|
// Verify custom engine path has iterData built before the widget call
|
|
73
|
-
const iterDataIndex = afterCustomEngine.indexOf("
|
|
73
|
+
const iterDataIndex = afterCustomEngine.indexOf("buildCustomEngineIterationData({");
|
|
74
74
|
const widgetIndex = afterCustomEngine.indexOf("deps.updateProgressWidget");
|
|
75
75
|
assert.ok(iterDataIndex > -1 && widgetIndex > -1, "Both iterData and widget call should exist");
|
|
76
76
|
assert.ok(
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: Unit tests for the normalized SQLite adapter wrapper.
|
|
3
|
+
|
|
4
|
+
import assert from "node:assert/strict";
|
|
5
|
+
import test from "node:test";
|
|
6
|
+
|
|
7
|
+
import {
|
|
8
|
+
createDbAdapter,
|
|
9
|
+
normalizeDbRow,
|
|
10
|
+
normalizeDbRows,
|
|
11
|
+
} from "../db-adapter.ts";
|
|
12
|
+
|
|
13
|
+
test("normalizeDbRow returns undefined for missing rows", () => {
|
|
14
|
+
assert.equal(normalizeDbRow(null), undefined);
|
|
15
|
+
assert.equal(normalizeDbRow(undefined), undefined);
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
test("normalizeDbRow converts null-prototype rows to plain objects", () => {
|
|
19
|
+
const raw = Object.create(null) as Record<string, unknown>;
|
|
20
|
+
raw.id = "M001";
|
|
21
|
+
|
|
22
|
+
const normalized = normalizeDbRow(raw);
|
|
23
|
+
|
|
24
|
+
assert.deepEqual(normalized, { id: "M001" });
|
|
25
|
+
assert.equal(Object.getPrototypeOf(normalized), Object.prototype);
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
test("normalizeDbRows normalizes every row", () => {
|
|
29
|
+
const first = Object.create(null) as Record<string, unknown>;
|
|
30
|
+
first.id = "S01";
|
|
31
|
+
const second = { id: "S02" };
|
|
32
|
+
|
|
33
|
+
assert.deepEqual(normalizeDbRows([first, second]), [{ id: "S01" }, { id: "S02" }]);
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
test("createDbAdapter caches prepared statements and clears cache on close", () => {
|
|
37
|
+
const calls: unknown[] = [];
|
|
38
|
+
const rawStatement = {
|
|
39
|
+
run: (...params: unknown[]) => {
|
|
40
|
+
calls.push(["run", params]);
|
|
41
|
+
return { changes: 1 };
|
|
42
|
+
},
|
|
43
|
+
get: (...params: unknown[]) => {
|
|
44
|
+
calls.push(["get", params]);
|
|
45
|
+
const row = Object.create(null) as Record<string, unknown>;
|
|
46
|
+
row.id = "T01";
|
|
47
|
+
return row;
|
|
48
|
+
},
|
|
49
|
+
all: (...params: unknown[]) => {
|
|
50
|
+
calls.push(["all", params]);
|
|
51
|
+
const row = Object.create(null) as Record<string, unknown>;
|
|
52
|
+
row.id = "T02";
|
|
53
|
+
return [row];
|
|
54
|
+
},
|
|
55
|
+
};
|
|
56
|
+
let prepareCount = 0;
|
|
57
|
+
const rawDb = {
|
|
58
|
+
exec: (sql: string) => calls.push(["exec", sql]),
|
|
59
|
+
prepare: (sql: string) => {
|
|
60
|
+
prepareCount += 1;
|
|
61
|
+
calls.push(["prepare", sql]);
|
|
62
|
+
return rawStatement;
|
|
63
|
+
},
|
|
64
|
+
close: () => calls.push(["close"]),
|
|
65
|
+
};
|
|
66
|
+
const adapter = createDbAdapter(rawDb);
|
|
67
|
+
|
|
68
|
+
const first = adapter.prepare("SELECT * FROM tasks WHERE id = ?");
|
|
69
|
+
const second = adapter.prepare("SELECT * FROM tasks WHERE id = ?");
|
|
70
|
+
|
|
71
|
+
assert.equal(first, second);
|
|
72
|
+
assert.equal(prepareCount, 1);
|
|
73
|
+
assert.deepEqual(first.get("T01"), { id: "T01" });
|
|
74
|
+
assert.deepEqual(first.all("T02"), [{ id: "T02" }]);
|
|
75
|
+
assert.deepEqual(first.run("T01"), { changes: 1 });
|
|
76
|
+
|
|
77
|
+
adapter.close();
|
|
78
|
+
const third = adapter.prepare("SELECT * FROM tasks WHERE id = ?");
|
|
79
|
+
|
|
80
|
+
assert.notEqual(third, first);
|
|
81
|
+
assert.equal(prepareCount, 2);
|
|
82
|
+
});
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: Tests for base GSD database schema DDL helper.
|
|
3
|
+
|
|
4
|
+
import { describe, test } from "node:test";
|
|
5
|
+
import assert from "node:assert/strict";
|
|
6
|
+
import { createBaseSchemaObjects } from "../db-base-schema.ts";
|
|
7
|
+
import type { DbAdapter, DbStatement } from "../db-adapter.ts";
|
|
8
|
+
|
|
9
|
+
class FakeStatement implements DbStatement {
|
|
10
|
+
run(): unknown {
|
|
11
|
+
return undefined;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
get(): Record<string, unknown> | undefined {
|
|
15
|
+
return undefined;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
all(): Record<string, unknown>[] {
|
|
19
|
+
return [];
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
class FakeAdapter implements DbAdapter {
|
|
24
|
+
readonly execCalls: string[] = [];
|
|
25
|
+
|
|
26
|
+
exec(sql: string): void {
|
|
27
|
+
this.execCalls.push(sql);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
prepare(): DbStatement {
|
|
31
|
+
return new FakeStatement();
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
close(): void {}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
describe("db-base-schema", () => {
|
|
38
|
+
test("creates current base schema tables, indexes, and active views", () => {
|
|
39
|
+
const db = new FakeAdapter();
|
|
40
|
+
let ftsCalls = 0;
|
|
41
|
+
let dedupCalls = 0;
|
|
42
|
+
|
|
43
|
+
createBaseSchemaObjects(db, {
|
|
44
|
+
tryCreateMemoriesFts: () => {
|
|
45
|
+
ftsCalls += 1;
|
|
46
|
+
return true;
|
|
47
|
+
},
|
|
48
|
+
ensureVerificationEvidenceDedupIndex: () => {
|
|
49
|
+
dedupCalls += 1;
|
|
50
|
+
},
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
assert.equal(ftsCalls, 1);
|
|
54
|
+
assert.equal(dedupCalls, 1);
|
|
55
|
+
assert.ok(db.execCalls.some((sql) => sql.includes("CREATE TABLE IF NOT EXISTS schema_version")));
|
|
56
|
+
assert.ok(db.execCalls.some((sql) => sql.includes("CREATE TABLE IF NOT EXISTS tasks")));
|
|
57
|
+
assert.ok(db.execCalls.some((sql) => sql.includes("CREATE TABLE IF NOT EXISTS quality_gates")));
|
|
58
|
+
assert.ok(db.execCalls.some((sql) => sql.includes("CREATE INDEX IF NOT EXISTS idx_tasks_active")));
|
|
59
|
+
assert.ok(db.execCalls.some((sql) => sql.includes("CREATE VIEW IF NOT EXISTS active_decisions")));
|
|
60
|
+
assert.ok(db.execCalls.some((sql) => sql.includes("CREATE VIEW IF NOT EXISTS active_memories")));
|
|
61
|
+
});
|
|
62
|
+
});
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: Tests for workspace database connection cache lifecycle helpers.
|
|
3
|
+
|
|
4
|
+
import { describe, test } from "node:test";
|
|
5
|
+
import assert from "node:assert/strict";
|
|
6
|
+
import { createDbConnectionCache, type DbConnectionCacheEntry } from "../db-connection-cache.ts";
|
|
7
|
+
import type { DbAdapter, DbStatement } from "../db-adapter.ts";
|
|
8
|
+
|
|
9
|
+
class FakeAdapter implements DbAdapter {
|
|
10
|
+
readonly calls: string[] = [];
|
|
11
|
+
|
|
12
|
+
exec(sql: string): void {
|
|
13
|
+
this.calls.push(`exec:${sql}`);
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
prepare(): DbStatement {
|
|
17
|
+
throw new Error("prepare is not used by DbConnectionCache tests");
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
close(): void {
|
|
21
|
+
this.calls.push("close");
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
function entry(path: string, db = new FakeAdapter()): DbConnectionCacheEntry {
|
|
26
|
+
return { dbPath: path, db };
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
describe("db-connection-cache", () => {
|
|
30
|
+
test("stores entries and exposes a readonly cache view", () => {
|
|
31
|
+
const cache = createDbConnectionCache();
|
|
32
|
+
const cached = entry("/tmp/a.db");
|
|
33
|
+
|
|
34
|
+
cache.set("workspace-a", cached);
|
|
35
|
+
|
|
36
|
+
assert.equal(cache.get("workspace-a"), cached);
|
|
37
|
+
assert.equal(cache.has("workspace-a"), true);
|
|
38
|
+
assert.equal(cache.asReadonlyMap().size, 1);
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
test("closeNonActive closes and removes only inactive entries", () => {
|
|
42
|
+
const cache = createDbConnectionCache();
|
|
43
|
+
const activeDb = new FakeAdapter();
|
|
44
|
+
const inactiveDb = new FakeAdapter();
|
|
45
|
+
cache.set("active", entry("/tmp/active.db", activeDb));
|
|
46
|
+
cache.set("inactive", entry("/tmp/inactive.db", inactiveDb));
|
|
47
|
+
const closed: string[] = [];
|
|
48
|
+
|
|
49
|
+
cache.closeNonActive(activeDb, (cached) => {
|
|
50
|
+
closed.push(cached.dbPath);
|
|
51
|
+
cached.db.close();
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
assert.deepEqual(closed, ["/tmp/inactive.db"]);
|
|
55
|
+
assert.equal(cache.has("active"), true);
|
|
56
|
+
assert.equal(cache.has("inactive"), false);
|
|
57
|
+
assert.deepEqual(activeDb.calls, []);
|
|
58
|
+
assert.deepEqual(inactiveDb.calls, ["close"]);
|
|
59
|
+
});
|
|
60
|
+
});
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: Tests for auto-mode coordination schema helper.
|
|
3
|
+
|
|
4
|
+
import { describe, test } from "node:test";
|
|
5
|
+
import assert from "node:assert/strict";
|
|
6
|
+
import { createCoordinationTablesV24 } from "../db-coordination-schema.ts";
|
|
7
|
+
import type { DbAdapter, DbStatement } from "../db-adapter.ts";
|
|
8
|
+
|
|
9
|
+
class FakeAdapter implements DbAdapter {
|
|
10
|
+
readonly execCalls: string[] = [];
|
|
11
|
+
|
|
12
|
+
exec(sql: string): void {
|
|
13
|
+
this.execCalls.push(sql);
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
prepare(): DbStatement {
|
|
17
|
+
throw new Error("prepare is not used by coordination schema tests");
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
close(): void {}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
describe("db-coordination-schema", () => {
|
|
24
|
+
test("creates coordination tables and claim indexes", () => {
|
|
25
|
+
const db = new FakeAdapter();
|
|
26
|
+
|
|
27
|
+
createCoordinationTablesV24(db);
|
|
28
|
+
|
|
29
|
+
assert.equal(db.execCalls.length, 9);
|
|
30
|
+
assert.match(db.execCalls[0], /CREATE TABLE IF NOT EXISTS workers/);
|
|
31
|
+
assert.match(db.execCalls[1], /CREATE TABLE IF NOT EXISTS milestone_leases/);
|
|
32
|
+
assert.match(db.execCalls[2], /CREATE TABLE IF NOT EXISTS unit_dispatches/);
|
|
33
|
+
assert.match(db.execCalls[3], /CREATE TABLE IF NOT EXISTS cancellation_requests/);
|
|
34
|
+
assert.match(db.execCalls[4], /CREATE TABLE IF NOT EXISTS command_queue/);
|
|
35
|
+
assert.ok(db.execCalls.some((sql) => sql.includes("idx_unit_dispatches_active_per_unit")));
|
|
36
|
+
assert.ok(db.execCalls.some((sql) => sql.includes("WHERE status IN ('claimed','running')")));
|
|
37
|
+
assert.ok(db.execCalls.some((sql) => sql.includes("idx_command_queue_pending")));
|
|
38
|
+
});
|
|
39
|
+
});
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: Tests for decision and requirement database row mappers.
|
|
3
|
+
|
|
4
|
+
import { describe, test } from "node:test";
|
|
5
|
+
import assert from "node:assert/strict";
|
|
6
|
+
import {
|
|
7
|
+
rowToActiveDecision,
|
|
8
|
+
rowToActiveRequirement,
|
|
9
|
+
rowToDecision,
|
|
10
|
+
rowToRequirement,
|
|
11
|
+
rowsToRequirementCounts,
|
|
12
|
+
} from "../db-decision-requirement-rows.ts";
|
|
13
|
+
|
|
14
|
+
describe("db-decision-requirement-rows", () => {
|
|
15
|
+
test("maps persisted decision rows with defaults", () => {
|
|
16
|
+
const decision = rowToDecision({
|
|
17
|
+
seq: 7,
|
|
18
|
+
id: "D007",
|
|
19
|
+
when_context: "during planning",
|
|
20
|
+
scope: "M001/S01",
|
|
21
|
+
decision: "keep SQL writes in gsd-db",
|
|
22
|
+
choice: "facade wrappers",
|
|
23
|
+
rationale: "preserve the single-writer invariant",
|
|
24
|
+
revisable: "after repository split",
|
|
25
|
+
superseded_by: "D008",
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
assert.deepEqual(decision, {
|
|
29
|
+
seq: 7,
|
|
30
|
+
id: "D007",
|
|
31
|
+
when_context: "during planning",
|
|
32
|
+
scope: "M001/S01",
|
|
33
|
+
decision: "keep SQL writes in gsd-db",
|
|
34
|
+
choice: "facade wrappers",
|
|
35
|
+
rationale: "preserve the single-writer invariant",
|
|
36
|
+
revisable: "after repository split",
|
|
37
|
+
made_by: "agent",
|
|
38
|
+
source: "discussion",
|
|
39
|
+
superseded_by: "D008",
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
test("maps active decision rows as non-superseded", () => {
|
|
44
|
+
const decision = rowToActiveDecision({
|
|
45
|
+
seq: 1,
|
|
46
|
+
id: "D001",
|
|
47
|
+
when_context: "now",
|
|
48
|
+
scope: "global",
|
|
49
|
+
decision: "active only",
|
|
50
|
+
choice: "view row",
|
|
51
|
+
rationale: "view filters superseded rows",
|
|
52
|
+
revisable: "yes",
|
|
53
|
+
made_by: "human",
|
|
54
|
+
source: "planning",
|
|
55
|
+
superseded_by: "ignored",
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
assert.equal(decision.made_by, "human");
|
|
59
|
+
assert.equal(decision.source, "planning");
|
|
60
|
+
assert.equal(decision.superseded_by, null);
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
test("maps persisted requirement rows", () => {
|
|
64
|
+
const requirement = rowToRequirement({
|
|
65
|
+
id: "R001",
|
|
66
|
+
class: "functional",
|
|
67
|
+
status: "active",
|
|
68
|
+
description: "Persist requirements",
|
|
69
|
+
why: "planning needs durable context",
|
|
70
|
+
source: "roadmap",
|
|
71
|
+
primary_owner: "S01",
|
|
72
|
+
supporting_slices: "S02",
|
|
73
|
+
validation: "roundtrip",
|
|
74
|
+
notes: "important",
|
|
75
|
+
full_content: "Full requirement text",
|
|
76
|
+
superseded_by: "R002",
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
assert.deepEqual(requirement, {
|
|
80
|
+
id: "R001",
|
|
81
|
+
class: "functional",
|
|
82
|
+
status: "active",
|
|
83
|
+
description: "Persist requirements",
|
|
84
|
+
why: "planning needs durable context",
|
|
85
|
+
source: "roadmap",
|
|
86
|
+
primary_owner: "S01",
|
|
87
|
+
supporting_slices: "S02",
|
|
88
|
+
validation: "roundtrip",
|
|
89
|
+
notes: "important",
|
|
90
|
+
full_content: "Full requirement text",
|
|
91
|
+
superseded_by: "R002",
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
test("maps active requirement rows as non-superseded", () => {
|
|
96
|
+
const requirement = rowToActiveRequirement({
|
|
97
|
+
id: "R001",
|
|
98
|
+
class: "functional",
|
|
99
|
+
status: "validated",
|
|
100
|
+
description: "Validated requirement",
|
|
101
|
+
why: "done",
|
|
102
|
+
source: "roadmap",
|
|
103
|
+
primary_owner: "S01",
|
|
104
|
+
supporting_slices: "",
|
|
105
|
+
validation: "tests",
|
|
106
|
+
notes: "",
|
|
107
|
+
full_content: "Full requirement text",
|
|
108
|
+
superseded_by: "ignored",
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
assert.equal(requirement.status, "validated");
|
|
112
|
+
assert.equal(requirement.superseded_by, null);
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
test("reduces requirement status rows into stable counts", () => {
|
|
116
|
+
const counts = rowsToRequirementCounts([
|
|
117
|
+
{ status: "active", count: 2 },
|
|
118
|
+
{ status: "validated", count: 3 },
|
|
119
|
+
{ status: "deferred", count: 5 },
|
|
120
|
+
{ status: "out-of-scope", count: 7 },
|
|
121
|
+
{ status: "out_of_scope", count: 11 },
|
|
122
|
+
{ status: "blocked", count: 13 },
|
|
123
|
+
{ status: "unknown", count: 17 },
|
|
124
|
+
]);
|
|
125
|
+
|
|
126
|
+
assert.deepEqual(counts, {
|
|
127
|
+
active: 2,
|
|
128
|
+
validated: 3,
|
|
129
|
+
deferred: 5,
|
|
130
|
+
outOfScope: 18,
|
|
131
|
+
blocked: 13,
|
|
132
|
+
total: 58,
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
});
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: Tests for quality gate database row mapper.
|
|
3
|
+
|
|
4
|
+
import { describe, test } from "node:test";
|
|
5
|
+
import assert from "node:assert/strict";
|
|
6
|
+
import { rowToGate } from "../db-gate-rows.ts";
|
|
7
|
+
|
|
8
|
+
describe("db-gate-rows", () => {
|
|
9
|
+
test("rowToGate clears verdict for pending gates", () => {
|
|
10
|
+
const gate = rowToGate({
|
|
11
|
+
milestone_id: "M001",
|
|
12
|
+
slice_id: "S01",
|
|
13
|
+
gate_id: "Q3",
|
|
14
|
+
scope: "slice",
|
|
15
|
+
status: "pending",
|
|
16
|
+
verdict: "pass",
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
assert.equal(gate.task_id, "");
|
|
20
|
+
assert.equal(gate.verdict, null);
|
|
21
|
+
assert.equal(gate.rationale, "");
|
|
22
|
+
assert.equal(gate.findings, "");
|
|
23
|
+
assert.equal(gate.evaluated_at, null);
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
test("rowToGate preserves completed gate verdict and details", () => {
|
|
27
|
+
const gate = rowToGate({
|
|
28
|
+
milestone_id: "M001",
|
|
29
|
+
slice_id: "S01",
|
|
30
|
+
gate_id: "Q4",
|
|
31
|
+
scope: "task",
|
|
32
|
+
task_id: "T01",
|
|
33
|
+
status: "complete",
|
|
34
|
+
verdict: "flag",
|
|
35
|
+
rationale: "needs review",
|
|
36
|
+
findings: "minor risk",
|
|
37
|
+
evaluated_at: "2026-05-04T00:00:00.000Z",
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
assert.deepEqual(gate, {
|
|
41
|
+
milestone_id: "M001",
|
|
42
|
+
slice_id: "S01",
|
|
43
|
+
gate_id: "Q4",
|
|
44
|
+
scope: "task",
|
|
45
|
+
task_id: "T01",
|
|
46
|
+
status: "complete",
|
|
47
|
+
verdict: "flag",
|
|
48
|
+
rationale: "needs review",
|
|
49
|
+
findings: "minor risk",
|
|
50
|
+
evaluated_at: "2026-05-04T00:00:00.000Z",
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
});
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
// Project/App: GSD-2
|
|
2
|
+
// File Purpose: Tests for lightweight DB query row mappers.
|
|
3
|
+
|
|
4
|
+
import { describe, test } from "node:test";
|
|
5
|
+
import assert from "node:assert/strict";
|
|
6
|
+
import {
|
|
7
|
+
emptyTaskStatusCounts,
|
|
8
|
+
rowToActiveTaskSummary,
|
|
9
|
+
rowToIdStatusSummary,
|
|
10
|
+
rowToTaskStatusCounts,
|
|
11
|
+
rowsToStringColumn,
|
|
12
|
+
} from "../db-lightweight-query-rows.ts";
|
|
13
|
+
|
|
14
|
+
describe("db-lightweight-query-rows", () => {
|
|
15
|
+
test("maps id and status summaries", () => {
|
|
16
|
+
assert.deepEqual(rowToIdStatusSummary({ id: "M001", status: "active" }), {
|
|
17
|
+
id: "M001",
|
|
18
|
+
status: "active",
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
test("maps active task summaries", () => {
|
|
23
|
+
assert.deepEqual(rowToActiveTaskSummary({ id: "T01", status: "pending", title: "Plan task" }), {
|
|
24
|
+
id: "T01",
|
|
25
|
+
status: "pending",
|
|
26
|
+
title: "Plan task",
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
test("maps task status counts with stable empty defaults", () => {
|
|
31
|
+
assert.deepEqual(rowToTaskStatusCounts({ total: 3, done: 1, pending: 2 }), {
|
|
32
|
+
total: 3,
|
|
33
|
+
done: 1,
|
|
34
|
+
pending: 2,
|
|
35
|
+
});
|
|
36
|
+
assert.deepEqual(rowToTaskStatusCounts(undefined), emptyTaskStatusCounts());
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
test("extracts string columns from rows", () => {
|
|
40
|
+
assert.deepEqual(rowsToStringColumn([{ slice_id: "S01" }, { slice_id: "S02" }], "slice_id"), [
|
|
41
|
+
"S01",
|
|
42
|
+
"S02",
|
|
43
|
+
]);
|
|
44
|
+
});
|
|
45
|
+
});
|