gsd-pi 2.33.0-dev.bafba33 → 2.33.1-dev.235d83a
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 +13 -18
- package/dist/cli.js +16 -0
- package/dist/resource-loader.d.ts +2 -0
- package/dist/resource-loader.js +36 -3
- package/dist/resources/extensions/ask-user-questions.js +217 -0
- package/dist/resources/extensions/async-jobs/async-bash-tool.js +180 -0
- package/dist/resources/extensions/async-jobs/await-tool.js +90 -0
- package/dist/resources/extensions/async-jobs/cancel-job-tool.js +28 -0
- package/dist/resources/extensions/async-jobs/index.js +119 -0
- package/dist/resources/extensions/async-jobs/job-manager.js +159 -0
- package/dist/resources/extensions/aws-auth/index.js +138 -0
- package/dist/resources/extensions/bg-shell/bg-shell-command.js +182 -0
- package/dist/resources/extensions/bg-shell/bg-shell-lifecycle.js +343 -0
- package/dist/resources/extensions/bg-shell/bg-shell-tool.js +831 -0
- package/dist/resources/extensions/bg-shell/index.js +41 -0
- package/dist/resources/extensions/bg-shell/interaction.js +160 -0
- package/dist/resources/extensions/bg-shell/output-formatter.js +245 -0
- package/dist/resources/extensions/bg-shell/overlay.js +378 -0
- package/dist/resources/extensions/bg-shell/process-manager.js +413 -0
- package/dist/resources/extensions/bg-shell/readiness-detector.js +109 -0
- package/dist/resources/extensions/bg-shell/types.js +96 -0
- package/dist/resources/extensions/bg-shell/utilities.js +50 -0
- package/dist/resources/extensions/browser-tools/capture.js +179 -0
- package/dist/resources/extensions/browser-tools/core.js +899 -0
- package/dist/resources/extensions/browser-tools/{evaluate-helpers.ts → evaluate-helpers.js} +0 -1
- package/dist/resources/extensions/browser-tools/index.js +123 -0
- package/dist/resources/extensions/browser-tools/lifecycle.js +222 -0
- package/dist/resources/extensions/browser-tools/refs.js +254 -0
- package/dist/resources/extensions/browser-tools/settle.js +173 -0
- package/dist/resources/extensions/browser-tools/state.js +126 -0
- package/dist/resources/extensions/browser-tools/tools/action-cache.js +179 -0
- package/dist/resources/extensions/browser-tools/tools/assertions.js +320 -0
- package/dist/resources/extensions/browser-tools/tools/codegen.js +242 -0
- package/dist/resources/extensions/browser-tools/tools/device.js +162 -0
- package/dist/resources/extensions/browser-tools/tools/extract.js +191 -0
- package/dist/resources/extensions/browser-tools/tools/forms.js +710 -0
- package/dist/resources/extensions/browser-tools/tools/injection-detect.js +178 -0
- package/dist/resources/extensions/browser-tools/tools/inspection.js +426 -0
- package/dist/resources/extensions/browser-tools/tools/intent.js +556 -0
- package/dist/resources/extensions/browser-tools/tools/interaction.js +776 -0
- package/dist/resources/extensions/browser-tools/tools/navigation.js +208 -0
- package/dist/resources/extensions/browser-tools/tools/network-mock.js +194 -0
- package/dist/resources/extensions/browser-tools/tools/pages.js +280 -0
- package/dist/resources/extensions/browser-tools/tools/pdf.js +74 -0
- package/dist/resources/extensions/browser-tools/tools/refs.js +485 -0
- package/dist/resources/extensions/browser-tools/tools/screenshot.js +87 -0
- package/dist/resources/extensions/browser-tools/tools/session.js +375 -0
- package/dist/resources/extensions/browser-tools/tools/state-persistence.js +180 -0
- package/dist/resources/extensions/browser-tools/tools/visual-diff.js +174 -0
- package/dist/resources/extensions/browser-tools/tools/wait.js +201 -0
- package/dist/resources/extensions/browser-tools/tools/zoom.js +90 -0
- package/dist/resources/extensions/browser-tools/utils.js +490 -0
- package/dist/resources/extensions/context7/index.js +337 -0
- package/dist/resources/extensions/get-secrets-from-user.js +492 -0
- package/dist/resources/extensions/google-search/index.js +373 -0
- package/dist/resources/extensions/gsd/activity-log.js +146 -0
- package/dist/resources/extensions/gsd/atomic-write.js +38 -0
- package/dist/resources/extensions/gsd/auto/session.js +187 -0
- package/dist/resources/extensions/gsd/auto-budget.js +30 -0
- package/dist/resources/extensions/gsd/{auto-constants.ts → auto-constants.js} +0 -1
- package/dist/resources/extensions/gsd/auto-dashboard.js +509 -0
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +180 -0
- package/dist/resources/extensions/gsd/auto-dispatch.js +382 -0
- package/dist/resources/extensions/gsd/auto-idempotency.js +106 -0
- package/dist/resources/extensions/gsd/auto-model-selection.js +133 -0
- package/dist/resources/extensions/gsd/auto-observability.js +54 -0
- package/dist/resources/extensions/gsd/auto-post-unit.js +495 -0
- package/dist/resources/extensions/gsd/auto-prompts.js +1121 -0
- package/dist/resources/extensions/gsd/auto-recovery.js +550 -0
- package/dist/resources/extensions/gsd/auto-start.js +393 -0
- package/dist/resources/extensions/gsd/auto-stuck-detection.js +165 -0
- package/dist/resources/extensions/gsd/{auto-supervisor.ts → auto-supervisor.js} +29 -32
- package/dist/resources/extensions/gsd/auto-timeout-recovery.js +183 -0
- package/dist/resources/extensions/gsd/auto-timers.js +181 -0
- package/dist/resources/extensions/gsd/auto-tool-tracking.js +50 -0
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +30 -0
- package/dist/resources/extensions/gsd/auto-verification.js +209 -0
- package/dist/resources/extensions/gsd/auto-worktree.js +594 -0
- package/dist/resources/extensions/gsd/auto.js +1485 -0
- package/dist/resources/extensions/gsd/{cache.ts → cache.js} +5 -7
- package/dist/resources/extensions/gsd/captures.js +348 -0
- package/dist/resources/extensions/gsd/claude-import.js +540 -0
- package/dist/resources/extensions/gsd/collision-diagnostics.js +226 -0
- package/dist/resources/extensions/gsd/commands-bootstrap.js +223 -0
- package/dist/resources/extensions/gsd/commands-config.js +89 -0
- package/dist/resources/extensions/gsd/commands-extensions.js +259 -0
- package/dist/resources/extensions/gsd/commands-handlers.js +310 -0
- package/dist/resources/extensions/gsd/commands-inspect.js +70 -0
- package/dist/resources/extensions/gsd/commands-logs.js +468 -0
- package/dist/resources/extensions/gsd/commands-maintenance.js +185 -0
- package/dist/resources/extensions/gsd/commands-prefs-wizard.js +660 -0
- package/dist/resources/extensions/gsd/commands-workflow-templates.js +408 -0
- package/dist/resources/extensions/gsd/commands.js +1024 -0
- package/dist/resources/extensions/gsd/complexity-classifier.js +257 -0
- package/dist/resources/extensions/gsd/{constants.ts → constants.js} +0 -6
- package/dist/resources/extensions/gsd/context-budget.js +187 -0
- package/dist/resources/extensions/gsd/context-store.js +165 -0
- package/dist/resources/extensions/gsd/crash-recovery.js +110 -0
- package/dist/resources/extensions/gsd/dashboard-overlay.js +562 -0
- package/dist/resources/extensions/gsd/db-writer.js +298 -0
- package/dist/resources/extensions/gsd/debug-logger.js +161 -0
- package/dist/resources/extensions/gsd/detection.js +373 -0
- package/dist/resources/extensions/gsd/diff-context.js +168 -0
- package/dist/resources/extensions/gsd/dispatch-guard.js +76 -0
- package/dist/resources/extensions/gsd/doctor-checks.js +563 -0
- package/dist/resources/extensions/gsd/doctor-environment.js +429 -0
- package/dist/resources/extensions/gsd/doctor-format.js +71 -0
- package/dist/resources/extensions/gsd/doctor-proactive.js +239 -0
- package/dist/resources/extensions/gsd/doctor-providers.js +292 -0
- package/dist/resources/extensions/gsd/doctor-types.js +12 -0
- package/dist/resources/extensions/gsd/doctor.js +672 -0
- package/dist/resources/extensions/gsd/error-utils.js +6 -0
- package/dist/resources/extensions/gsd/{errors.ts → errors.js} +6 -11
- package/dist/resources/extensions/gsd/exit-command.js +11 -0
- package/dist/resources/extensions/gsd/{export-html.ts → export-html.js} +482 -614
- package/dist/resources/extensions/gsd/export.js +268 -0
- package/dist/resources/extensions/gsd/file-watcher.js +76 -0
- package/dist/resources/extensions/gsd/files.js +937 -0
- package/dist/resources/extensions/gsd/forensics.js +511 -0
- package/dist/resources/extensions/gsd/{git-constants.ts → git-constants.js} +4 -5
- package/dist/resources/extensions/gsd/git-self-heal.js +113 -0
- package/dist/resources/extensions/gsd/git-service.js +460 -0
- package/dist/resources/extensions/gsd/{gitignore.ts → gitignore.js} +98 -125
- package/dist/resources/extensions/gsd/gsd-db.js +590 -0
- package/dist/resources/extensions/gsd/guided-flow-queue.js +366 -0
- package/dist/resources/extensions/gsd/guided-flow.js +1149 -0
- package/dist/resources/extensions/gsd/health-widget.js +141 -0
- package/dist/resources/extensions/gsd/history.js +118 -0
- package/dist/resources/extensions/gsd/index.js +1250 -0
- package/dist/resources/extensions/gsd/init-wizard.js +479 -0
- package/dist/resources/extensions/gsd/json-persistence.js +62 -0
- package/dist/resources/extensions/gsd/{jsonl-utils.ts → jsonl-utils.js} +10 -7
- package/dist/resources/extensions/gsd/key-manager.js +829 -0
- package/dist/resources/extensions/gsd/marketplace-discovery.js +356 -0
- package/dist/resources/extensions/gsd/md-importer.js +440 -0
- package/dist/resources/extensions/gsd/mechanical-completion.js +351 -0
- package/dist/resources/extensions/gsd/memory-extractor.js +295 -0
- package/dist/resources/extensions/gsd/memory-store.js +351 -0
- package/dist/resources/extensions/gsd/metrics.js +377 -0
- package/dist/resources/extensions/gsd/migrate/command.js +157 -0
- package/dist/resources/extensions/gsd/migrate/index.js +7 -0
- package/dist/resources/extensions/gsd/migrate/parser.js +268 -0
- package/dist/resources/extensions/gsd/migrate/parsers.js +477 -0
- package/dist/resources/extensions/gsd/migrate/preview.js +47 -0
- package/dist/resources/extensions/gsd/migrate/transformer.js +278 -0
- package/dist/resources/extensions/gsd/migrate/types.js +4 -0
- package/dist/resources/extensions/gsd/migrate/validator.js +41 -0
- package/dist/resources/extensions/gsd/migrate/writer.js +477 -0
- package/dist/resources/extensions/gsd/migrate-external.js +130 -0
- package/dist/resources/extensions/gsd/milestone-actions.js +111 -0
- package/dist/resources/extensions/gsd/{milestone-ids.ts → milestone-ids.js} +50 -63
- package/dist/resources/extensions/gsd/model-cost-table.js +48 -0
- package/dist/resources/extensions/gsd/model-router.js +187 -0
- package/dist/resources/extensions/gsd/namespaced-registry.js +322 -0
- package/dist/resources/extensions/gsd/namespaced-resolver.js +176 -0
- package/dist/resources/extensions/gsd/native-git-bridge.js +842 -0
- package/dist/resources/extensions/gsd/native-parser-bridge.js +156 -0
- package/dist/resources/extensions/gsd/notifications.js +58 -0
- package/dist/resources/extensions/gsd/observability-validator.js +398 -0
- package/dist/resources/extensions/gsd/parallel-eligibility.js +182 -0
- package/dist/resources/extensions/gsd/parallel-merge.js +121 -0
- package/dist/resources/extensions/gsd/parallel-orchestrator.js +687 -0
- package/dist/resources/extensions/gsd/paths.js +414 -0
- package/dist/resources/extensions/gsd/plugin-importer.js +254 -0
- package/dist/resources/extensions/gsd/post-unit-hooks.js +433 -0
- package/dist/resources/extensions/gsd/preferences-models.js +294 -0
- package/dist/resources/extensions/gsd/preferences-skills.js +154 -0
- package/dist/resources/extensions/gsd/preferences-types.js +73 -0
- package/dist/resources/extensions/gsd/preferences-validation.js +607 -0
- package/dist/resources/extensions/gsd/preferences.js +325 -0
- package/dist/resources/extensions/gsd/progress-score.js +197 -0
- package/dist/resources/extensions/gsd/prompt-cache-optimizer.js +150 -0
- package/dist/resources/extensions/gsd/prompt-compressor.js +393 -0
- package/dist/resources/extensions/gsd/prompt-loader.js +119 -0
- package/dist/resources/extensions/gsd/prompt-ordering.js +170 -0
- package/dist/resources/extensions/gsd/provider-error-pause.js +60 -0
- package/dist/resources/extensions/gsd/queue-order.js +178 -0
- package/dist/resources/extensions/gsd/queue-reorder-ui.js +234 -0
- package/dist/resources/extensions/gsd/quick.js +230 -0
- package/dist/resources/extensions/gsd/repo-identity.js +187 -0
- package/dist/resources/extensions/gsd/{reports.ts → reports.js} +146 -241
- package/dist/resources/extensions/gsd/{resource-version.ts → resource-version.js} +50 -53
- package/dist/resources/extensions/gsd/roadmap-slices.js +130 -0
- package/dist/resources/extensions/gsd/routing-history.js +210 -0
- package/dist/resources/extensions/gsd/safe-fs.js +52 -0
- package/dist/resources/extensions/gsd/semantic-chunker.js +254 -0
- package/dist/resources/extensions/gsd/session-forensics.js +427 -0
- package/dist/resources/extensions/gsd/session-lock.js +376 -0
- package/dist/resources/extensions/gsd/session-status-io.js +134 -0
- package/dist/resources/extensions/gsd/skill-discovery.js +121 -0
- package/dist/resources/extensions/gsd/skill-health.js +324 -0
- package/dist/resources/extensions/gsd/{skill-telemetry.ts → skill-telemetry.js} +58 -74
- package/dist/resources/extensions/gsd/state.js +653 -0
- package/dist/resources/extensions/gsd/structured-data-formatter.js +97 -0
- package/dist/resources/extensions/gsd/summary-distiller.js +212 -0
- package/dist/resources/extensions/gsd/token-counter.js +54 -0
- package/dist/resources/extensions/gsd/triage-resolution.js +217 -0
- package/dist/resources/extensions/gsd/triage-ui.js +125 -0
- package/dist/resources/extensions/gsd/types.js +4 -0
- package/dist/resources/extensions/gsd/undo.js +210 -0
- package/dist/resources/extensions/gsd/unit-id.js +7 -0
- package/dist/resources/extensions/gsd/unit-runtime.js +130 -0
- package/dist/resources/extensions/gsd/validate-directory.js +143 -0
- package/dist/resources/extensions/gsd/verification-evidence.js +123 -0
- package/dist/resources/extensions/gsd/verification-gate.js +543 -0
- package/dist/resources/extensions/gsd/visualizer-data.js +612 -0
- package/dist/resources/extensions/gsd/visualizer-overlay.js +501 -0
- package/dist/resources/extensions/gsd/visualizer-views.js +893 -0
- package/dist/resources/extensions/gsd/workflow-templates.js +188 -0
- package/dist/resources/extensions/gsd/workspace-index.js +139 -0
- package/dist/resources/extensions/gsd/worktree-command-bootstrap.js +40 -0
- package/dist/resources/extensions/gsd/worktree-command.js +676 -0
- package/dist/resources/extensions/gsd/worktree-manager.js +359 -0
- package/dist/resources/extensions/gsd/worktree.js +236 -0
- package/dist/resources/extensions/mac-tools/index.js +768 -0
- package/dist/resources/extensions/mcp-client/index.js +363 -0
- package/dist/resources/extensions/package.json +3 -0
- package/dist/resources/extensions/remote-questions/config.js +70 -0
- package/dist/resources/extensions/remote-questions/discord-adapter.js +134 -0
- package/dist/resources/extensions/remote-questions/format.js +234 -0
- package/dist/resources/extensions/remote-questions/http-client.js +43 -0
- package/dist/resources/extensions/remote-questions/manager.js +156 -0
- package/dist/resources/extensions/remote-questions/{mod.ts → mod.js} +1 -10
- package/dist/resources/extensions/remote-questions/notify.js +89 -0
- package/dist/resources/extensions/remote-questions/remote-command.js +453 -0
- package/dist/resources/extensions/remote-questions/slack-adapter.js +123 -0
- package/dist/resources/extensions/remote-questions/status.js +25 -0
- package/dist/resources/extensions/remote-questions/store.js +70 -0
- package/dist/resources/extensions/remote-questions/telegram-adapter.js +123 -0
- package/dist/resources/extensions/remote-questions/types.js +5 -0
- package/dist/resources/extensions/search-the-web/cache.js +74 -0
- package/dist/resources/extensions/search-the-web/command-search-provider.js +79 -0
- package/dist/resources/extensions/search-the-web/format.js +161 -0
- package/dist/resources/extensions/search-the-web/http.js +178 -0
- package/dist/resources/extensions/search-the-web/index.js +41 -0
- package/dist/resources/extensions/search-the-web/native-search.js +166 -0
- package/dist/resources/extensions/search-the-web/provider.js +143 -0
- package/dist/resources/extensions/search-the-web/tavily.js +82 -0
- package/dist/resources/extensions/search-the-web/tool-fetch-page.js +452 -0
- package/dist/resources/extensions/search-the-web/tool-llm-context.js +455 -0
- package/dist/resources/extensions/search-the-web/tool-search.js +482 -0
- package/dist/resources/extensions/search-the-web/url-utils.js +121 -0
- package/dist/resources/extensions/shared/confirm-ui.js +96 -0
- package/dist/resources/extensions/shared/{format-utils.ts → format-utils.js} +85 -91
- package/dist/resources/extensions/shared/frontmatter.js +109 -0
- package/dist/resources/extensions/shared/interview-ui.js +569 -0
- package/dist/resources/extensions/shared/{mod.ts → mod.js} +2 -24
- package/dist/resources/extensions/shared/next-action-ui.js +168 -0
- package/dist/resources/extensions/shared/{path-display.ts → path-display.js} +2 -3
- package/dist/resources/extensions/shared/sanitize.js +17 -0
- package/dist/resources/extensions/shared/terminal.js +21 -0
- package/dist/resources/extensions/shared/ui.js +245 -0
- package/dist/resources/extensions/shared/wizard-ui.js +478 -0
- package/dist/resources/extensions/slash-commands/audit.js +72 -0
- package/dist/resources/extensions/slash-commands/clear.js +8 -0
- package/dist/resources/extensions/slash-commands/create-extension.js +264 -0
- package/dist/resources/extensions/slash-commands/create-slash-command.js +208 -0
- package/dist/resources/extensions/slash-commands/index.js +10 -0
- package/dist/resources/extensions/subagent/agents.js +103 -0
- package/dist/resources/extensions/subagent/index.js +905 -0
- package/dist/resources/extensions/subagent/isolation.js +384 -0
- package/dist/resources/extensions/subagent/worker-registry.js +73 -0
- package/dist/resources/extensions/ttsr/index.js +144 -0
- package/dist/resources/extensions/ttsr/rule-loader.js +70 -0
- package/dist/resources/extensions/ttsr/ttsr-manager.js +380 -0
- package/dist/resources/extensions/universal-config/discovery.js +94 -0
- package/dist/resources/extensions/universal-config/format.js +178 -0
- package/dist/resources/extensions/universal-config/index.js +99 -0
- package/dist/resources/extensions/universal-config/scanners.js +574 -0
- package/dist/resources/extensions/universal-config/tools.js +57 -0
- package/dist/resources/extensions/universal-config/types.js +8 -0
- package/dist/resources/extensions/voice/index.js +247 -0
- package/dist/startup-timings.d.ts +2 -0
- package/dist/startup-timings.js +22 -0
- package/package.json +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/index.d.ts +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/index.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/index.js +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/index.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts +1 -0
- package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/extensions/loader.js +31 -4
- package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/index.js +1 -1
- package/packages/pi-coding-agent/dist/index.js.map +1 -1
- package/packages/pi-coding-agent/package.json +1 -1
- package/packages/pi-coding-agent/src/core/extensions/index.ts +1 -0
- package/packages/pi-coding-agent/src/core/extensions/loader.ts +35 -4
- package/packages/pi-coding-agent/src/index.ts +1 -0
- package/pkg/package.json +1 -1
- package/src/resources/extensions/bg-shell/index.ts +41 -46
- package/src/resources/extensions/browser-tools/index.ts +156 -67
- package/src/resources/extensions/gsd/auto-supervisor.ts +10 -5
- package/src/resources/extensions/gsd/auto-verification.ts +20 -2
- package/src/resources/extensions/gsd/auto-worktree.ts +136 -1
- package/src/resources/extensions/gsd/commands-bootstrap.ts +252 -0
- package/src/resources/extensions/gsd/commands.ts +53 -33
- package/src/resources/extensions/gsd/git-service.ts +24 -11
- package/src/resources/extensions/gsd/index.ts +106 -34
- package/src/resources/extensions/gsd/quick.ts +52 -3
- package/src/resources/extensions/gsd/repo-identity.ts +56 -22
- package/src/resources/extensions/gsd/session-lock.ts +80 -16
- package/src/resources/extensions/gsd/tests/auto-dispatch-loop.test.ts +691 -0
- package/src/resources/extensions/gsd/tests/cache-staleness-regression.test.ts +317 -0
- package/src/resources/extensions/gsd/tests/git-service.test.ts +16 -7
- package/src/resources/extensions/gsd/tests/loop-regression.test.ts +40 -5
- package/src/resources/extensions/gsd/tests/quick-branch-lifecycle.test.ts +281 -0
- package/src/resources/extensions/gsd/tests/repo-identity-worktree.test.ts +71 -0
- package/src/resources/extensions/gsd/tests/roadmap-parse-regression.test.ts +358 -0
- package/src/resources/extensions/gsd/tests/session-lock-regression.test.ts +216 -0
- package/src/resources/extensions/gsd/tests/session-lock.test.ts +119 -0
- package/src/resources/extensions/gsd/tests/verification-gate.test.ts +65 -0
- package/src/resources/extensions/gsd/tests/worktree-sync-milestones.test.ts +206 -0
- package/src/resources/extensions/gsd/types.ts +4 -0
- package/src/resources/extensions/gsd/verification-evidence.ts +1 -1
- package/src/resources/extensions/gsd/verification-gate.ts +23 -2
- package/src/resources/extensions/gsd/worktree-command-bootstrap.ts +46 -0
- package/src/resources/extensions/gsd/worktree-command.ts +17 -11
- package/src/resources/extensions/package.json +3 -0
- package/src/resources/extensions/search-the-web/command-search-provider.ts +1 -1
- package/src/resources/extensions/search-the-web/index.ts +35 -52
- package/src/resources/extensions/search-the-web/tavily.ts +1 -1
- package/dist/resources/extensions/ask-user-questions.ts +0 -290
- package/dist/resources/extensions/async-jobs/async-bash-tool.ts +0 -212
- package/dist/resources/extensions/async-jobs/await-tool.ts +0 -103
- package/dist/resources/extensions/async-jobs/cancel-job-tool.ts +0 -35
- package/dist/resources/extensions/async-jobs/index.ts +0 -141
- package/dist/resources/extensions/async-jobs/job-manager.ts +0 -211
- package/dist/resources/extensions/aws-auth/index.ts +0 -144
- package/dist/resources/extensions/bg-shell/bg-shell-command.ts +0 -219
- package/dist/resources/extensions/bg-shell/bg-shell-lifecycle.ts +0 -400
- package/dist/resources/extensions/bg-shell/bg-shell-tool.ts +0 -985
- package/dist/resources/extensions/bg-shell/index.ts +0 -59
- package/dist/resources/extensions/bg-shell/interaction.ts +0 -198
- package/dist/resources/extensions/bg-shell/output-formatter.ts +0 -279
- package/dist/resources/extensions/bg-shell/overlay.ts +0 -437
- package/dist/resources/extensions/bg-shell/process-manager.ts +0 -464
- package/dist/resources/extensions/bg-shell/readiness-detector.ts +0 -126
- package/dist/resources/extensions/bg-shell/types.ts +0 -303
- package/dist/resources/extensions/bg-shell/utilities.ts +0 -57
- package/dist/resources/extensions/browser-tools/capture.ts +0 -199
- package/dist/resources/extensions/browser-tools/core.ts +0 -1196
- package/dist/resources/extensions/browser-tools/index.ts +0 -71
- package/dist/resources/extensions/browser-tools/lifecycle.ts +0 -270
- package/dist/resources/extensions/browser-tools/refs.ts +0 -264
- package/dist/resources/extensions/browser-tools/settle.ts +0 -197
- package/dist/resources/extensions/browser-tools/state.ts +0 -408
- package/dist/resources/extensions/browser-tools/tools/action-cache.ts +0 -216
- package/dist/resources/extensions/browser-tools/tools/assertions.ts +0 -342
- package/dist/resources/extensions/browser-tools/tools/codegen.ts +0 -274
- package/dist/resources/extensions/browser-tools/tools/device.ts +0 -183
- package/dist/resources/extensions/browser-tools/tools/extract.ts +0 -229
- package/dist/resources/extensions/browser-tools/tools/forms.ts +0 -801
- package/dist/resources/extensions/browser-tools/tools/injection-detect.ts +0 -221
- package/dist/resources/extensions/browser-tools/tools/inspection.ts +0 -492
- package/dist/resources/extensions/browser-tools/tools/intent.ts +0 -614
- package/dist/resources/extensions/browser-tools/tools/interaction.ts +0 -865
- package/dist/resources/extensions/browser-tools/tools/navigation.ts +0 -232
- package/dist/resources/extensions/browser-tools/tools/network-mock.ts +0 -244
- package/dist/resources/extensions/browser-tools/tools/pages.ts +0 -303
- package/dist/resources/extensions/browser-tools/tools/pdf.ts +0 -92
- package/dist/resources/extensions/browser-tools/tools/refs.ts +0 -541
- package/dist/resources/extensions/browser-tools/tools/screenshot.ts +0 -101
- package/dist/resources/extensions/browser-tools/tools/session.ts +0 -400
- package/dist/resources/extensions/browser-tools/tools/state-persistence.ts +0 -202
- package/dist/resources/extensions/browser-tools/tools/visual-diff.ts +0 -209
- package/dist/resources/extensions/browser-tools/tools/wait.ts +0 -247
- package/dist/resources/extensions/browser-tools/tools/zoom.ts +0 -104
- package/dist/resources/extensions/browser-tools/utils.ts +0 -660
- package/dist/resources/extensions/context7/index.ts +0 -428
- package/dist/resources/extensions/get-secrets-from-user.ts +0 -607
- package/dist/resources/extensions/google-search/index.ts +0 -466
- package/dist/resources/extensions/gsd/activity-log.ts +0 -162
- package/dist/resources/extensions/gsd/atomic-write.ts +0 -35
- package/dist/resources/extensions/gsd/auto/session.ts +0 -236
- package/dist/resources/extensions/gsd/auto-budget.ts +0 -32
- package/dist/resources/extensions/gsd/auto-dashboard.ts +0 -626
- package/dist/resources/extensions/gsd/auto-direct-dispatch.ts +0 -224
- package/dist/resources/extensions/gsd/auto-dispatch.ts +0 -409
- package/dist/resources/extensions/gsd/auto-idempotency.ts +0 -151
- package/dist/resources/extensions/gsd/auto-model-selection.ts +0 -179
- package/dist/resources/extensions/gsd/auto-observability.ts +0 -72
- package/dist/resources/extensions/gsd/auto-post-unit.ts +0 -618
- package/dist/resources/extensions/gsd/auto-prompts.ts +0 -1273
- package/dist/resources/extensions/gsd/auto-recovery.ts +0 -578
- package/dist/resources/extensions/gsd/auto-start.ts +0 -483
- package/dist/resources/extensions/gsd/auto-stuck-detection.ts +0 -221
- package/dist/resources/extensions/gsd/auto-timeout-recovery.ts +0 -263
- package/dist/resources/extensions/gsd/auto-timers.ts +0 -224
- package/dist/resources/extensions/gsd/auto-tool-tracking.ts +0 -54
- package/dist/resources/extensions/gsd/auto-unit-closeout.ts +0 -48
- package/dist/resources/extensions/gsd/auto-verification.ts +0 -229
- package/dist/resources/extensions/gsd/auto-worktree.ts +0 -524
- package/dist/resources/extensions/gsd/auto.ts +0 -1834
- package/dist/resources/extensions/gsd/captures.ts +0 -427
- package/dist/resources/extensions/gsd/claude-import.ts +0 -656
- package/dist/resources/extensions/gsd/collision-diagnostics.ts +0 -332
- package/dist/resources/extensions/gsd/commands-config.ts +0 -102
- package/dist/resources/extensions/gsd/commands-extensions.ts +0 -328
- package/dist/resources/extensions/gsd/commands-handlers.ts +0 -395
- package/dist/resources/extensions/gsd/commands-inspect.ts +0 -91
- package/dist/resources/extensions/gsd/commands-logs.ts +0 -536
- package/dist/resources/extensions/gsd/commands-maintenance.ts +0 -206
- package/dist/resources/extensions/gsd/commands-prefs-wizard.ts +0 -780
- package/dist/resources/extensions/gsd/commands-workflow-templates.ts +0 -543
- package/dist/resources/extensions/gsd/commands.ts +0 -1137
- package/dist/resources/extensions/gsd/complexity-classifier.ts +0 -320
- package/dist/resources/extensions/gsd/context-budget.ts +0 -266
- package/dist/resources/extensions/gsd/context-store.ts +0 -195
- package/dist/resources/extensions/gsd/crash-recovery.ts +0 -121
- package/dist/resources/extensions/gsd/dashboard-overlay.ts +0 -681
- package/dist/resources/extensions/gsd/db-writer.ts +0 -360
- package/dist/resources/extensions/gsd/debug-logger.ts +0 -178
- package/dist/resources/extensions/gsd/detection.ts +0 -470
- package/dist/resources/extensions/gsd/diff-context.ts +0 -214
- package/dist/resources/extensions/gsd/dispatch-guard.ts +0 -81
- package/dist/resources/extensions/gsd/doctor-checks.ts +0 -612
- package/dist/resources/extensions/gsd/doctor-environment.ts +0 -497
- package/dist/resources/extensions/gsd/doctor-format.ts +0 -78
- package/dist/resources/extensions/gsd/doctor-proactive.ts +0 -292
- package/dist/resources/extensions/gsd/doctor-providers.ts +0 -343
- package/dist/resources/extensions/gsd/doctor-types.ts +0 -87
- package/dist/resources/extensions/gsd/doctor.ts +0 -722
- package/dist/resources/extensions/gsd/error-utils.ts +0 -6
- package/dist/resources/extensions/gsd/exit-command.ts +0 -18
- package/dist/resources/extensions/gsd/export.ts +0 -317
- package/dist/resources/extensions/gsd/file-watcher.ts +0 -97
- package/dist/resources/extensions/gsd/files.ts +0 -1058
- package/dist/resources/extensions/gsd/forensics.ts +0 -629
- package/dist/resources/extensions/gsd/git-self-heal.ts +0 -127
- package/dist/resources/extensions/gsd/git-service.ts +0 -580
- package/dist/resources/extensions/gsd/gsd-db.ts +0 -685
- package/dist/resources/extensions/gsd/guided-flow-queue.ts +0 -440
- package/dist/resources/extensions/gsd/guided-flow.ts +0 -1303
- package/dist/resources/extensions/gsd/health-widget.ts +0 -167
- package/dist/resources/extensions/gsd/history.ts +0 -143
- package/dist/resources/extensions/gsd/index.ts +0 -1390
- package/dist/resources/extensions/gsd/init-wizard.ts +0 -587
- package/dist/resources/extensions/gsd/json-persistence.ts +0 -67
- package/dist/resources/extensions/gsd/key-manager.ts +0 -996
- package/dist/resources/extensions/gsd/marketplace-discovery.ts +0 -508
- package/dist/resources/extensions/gsd/md-importer.ts +0 -527
- package/dist/resources/extensions/gsd/mechanical-completion.ts +0 -430
- package/dist/resources/extensions/gsd/memory-extractor.ts +0 -352
- package/dist/resources/extensions/gsd/memory-store.ts +0 -441
- package/dist/resources/extensions/gsd/metrics.ts +0 -532
- package/dist/resources/extensions/gsd/migrate/command.ts +0 -219
- package/dist/resources/extensions/gsd/migrate/index.ts +0 -42
- package/dist/resources/extensions/gsd/migrate/parser.ts +0 -323
- package/dist/resources/extensions/gsd/migrate/parsers.ts +0 -539
- package/dist/resources/extensions/gsd/migrate/preview.ts +0 -48
- package/dist/resources/extensions/gsd/migrate/transformer.ts +0 -346
- package/dist/resources/extensions/gsd/migrate/types.ts +0 -370
- package/dist/resources/extensions/gsd/migrate/validator.ts +0 -55
- package/dist/resources/extensions/gsd/migrate/writer.ts +0 -579
- package/dist/resources/extensions/gsd/migrate-external.ts +0 -140
- package/dist/resources/extensions/gsd/milestone-actions.ts +0 -126
- package/dist/resources/extensions/gsd/model-cost-table.ts +0 -65
- package/dist/resources/extensions/gsd/model-router.ts +0 -256
- package/dist/resources/extensions/gsd/namespaced-registry.ts +0 -467
- package/dist/resources/extensions/gsd/namespaced-resolver.ts +0 -307
- package/dist/resources/extensions/gsd/native-git-bridge.ts +0 -1041
- package/dist/resources/extensions/gsd/native-parser-bridge.ts +0 -267
- package/dist/resources/extensions/gsd/notifications.ts +0 -87
- package/dist/resources/extensions/gsd/observability-validator.ts +0 -429
- package/dist/resources/extensions/gsd/parallel-eligibility.ts +0 -233
- package/dist/resources/extensions/gsd/parallel-merge.ts +0 -157
- package/dist/resources/extensions/gsd/parallel-orchestrator.ts +0 -826
- package/dist/resources/extensions/gsd/paths.ts +0 -449
- package/dist/resources/extensions/gsd/plugin-importer.ts +0 -411
- package/dist/resources/extensions/gsd/post-unit-hooks.ts +0 -520
- package/dist/resources/extensions/gsd/preferences-models.ts +0 -329
- package/dist/resources/extensions/gsd/preferences-skills.ts +0 -169
- package/dist/resources/extensions/gsd/preferences-types.ts +0 -229
- package/dist/resources/extensions/gsd/preferences-validation.ts +0 -590
- package/dist/resources/extensions/gsd/preferences.ts +0 -416
- package/dist/resources/extensions/gsd/progress-score.ts +0 -273
- package/dist/resources/extensions/gsd/prompt-cache-optimizer.ts +0 -213
- package/dist/resources/extensions/gsd/prompt-compressor.ts +0 -508
- package/dist/resources/extensions/gsd/prompt-loader.ts +0 -130
- package/dist/resources/extensions/gsd/prompt-ordering.ts +0 -200
- package/dist/resources/extensions/gsd/provider-error-pause.ts +0 -88
- package/dist/resources/extensions/gsd/queue-order.ts +0 -230
- package/dist/resources/extensions/gsd/queue-reorder-ui.ts +0 -276
- package/dist/resources/extensions/gsd/quick.ts +0 -212
- package/dist/resources/extensions/gsd/repo-identity.ts +0 -169
- package/dist/resources/extensions/gsd/roadmap-slices.ts +0 -149
- package/dist/resources/extensions/gsd/routing-history.ts +0 -286
- package/dist/resources/extensions/gsd/safe-fs.ts +0 -47
- package/dist/resources/extensions/gsd/semantic-chunker.ts +0 -336
- package/dist/resources/extensions/gsd/session-forensics.ts +0 -537
- package/dist/resources/extensions/gsd/session-lock.ts +0 -362
- package/dist/resources/extensions/gsd/session-status-io.ts +0 -179
- package/dist/resources/extensions/gsd/skill-discovery.ts +0 -139
- package/dist/resources/extensions/gsd/skill-health.ts +0 -417
- package/dist/resources/extensions/gsd/state.ts +0 -727
- package/dist/resources/extensions/gsd/structured-data-formatter.ts +0 -144
- package/dist/resources/extensions/gsd/summary-distiller.ts +0 -258
- package/dist/resources/extensions/gsd/tests/activity-log.test.ts +0 -213
- package/dist/resources/extensions/gsd/tests/agent-end-retry.test.ts +0 -107
- package/dist/resources/extensions/gsd/tests/all-milestones-complete-merge.test.ts +0 -200
- package/dist/resources/extensions/gsd/tests/auto-budget-alerts.test.ts +0 -50
- package/dist/resources/extensions/gsd/tests/auto-dashboard.test.ts +0 -166
- package/dist/resources/extensions/gsd/tests/auto-lock-creation.test.ts +0 -186
- package/dist/resources/extensions/gsd/tests/auto-preflight.test.ts +0 -40
- package/dist/resources/extensions/gsd/tests/auto-recovery.test.ts +0 -640
- package/dist/resources/extensions/gsd/tests/auto-reentrancy-guard.test.ts +0 -127
- package/dist/resources/extensions/gsd/tests/auto-secrets-gate.test.ts +0 -302
- package/dist/resources/extensions/gsd/tests/auto-session-encapsulation.test.ts +0 -257
- package/dist/resources/extensions/gsd/tests/auto-skip-loop.test.ts +0 -123
- package/dist/resources/extensions/gsd/tests/auto-worktree-milestone-merge.test.ts +0 -340
- package/dist/resources/extensions/gsd/tests/auto-worktree.test.ts +0 -167
- package/dist/resources/extensions/gsd/tests/budget-prediction.test.ts +0 -220
- package/dist/resources/extensions/gsd/tests/captures.test.ts +0 -438
- package/dist/resources/extensions/gsd/tests/claude-import-tui.test.ts +0 -351
- package/dist/resources/extensions/gsd/tests/collect-from-manifest.test.ts +0 -469
- package/dist/resources/extensions/gsd/tests/collision-diagnostics.test.ts +0 -705
- package/dist/resources/extensions/gsd/tests/commands-logs.test.ts +0 -241
- package/dist/resources/extensions/gsd/tests/complete-milestone.test.ts +0 -209
- package/dist/resources/extensions/gsd/tests/complexity-classifier.test.ts +0 -181
- package/dist/resources/extensions/gsd/tests/context-budget.test.ts +0 -352
- package/dist/resources/extensions/gsd/tests/context-compression.test.ts +0 -193
- package/dist/resources/extensions/gsd/tests/context-store.test.ts +0 -462
- package/dist/resources/extensions/gsd/tests/continue-here.test.ts +0 -285
- package/dist/resources/extensions/gsd/tests/cost-projection.test.ts +0 -134
- package/dist/resources/extensions/gsd/tests/crash-recovery.test.ts +0 -134
- package/dist/resources/extensions/gsd/tests/dashboard-budget.test.ts +0 -346
- package/dist/resources/extensions/gsd/tests/db-writer.test.ts +0 -602
- package/dist/resources/extensions/gsd/tests/debug-logger.test.ts +0 -185
- package/dist/resources/extensions/gsd/tests/derive-state-db.test.ts +0 -405
- package/dist/resources/extensions/gsd/tests/derive-state-deps.test.ts +0 -421
- package/dist/resources/extensions/gsd/tests/derive-state-draft.test.ts +0 -308
- package/dist/resources/extensions/gsd/tests/derive-state.test.ts +0 -788
- package/dist/resources/extensions/gsd/tests/detection.test.ts +0 -398
- package/dist/resources/extensions/gsd/tests/diff-context.test.ts +0 -136
- package/dist/resources/extensions/gsd/tests/discuss-prompt.test.ts +0 -15
- package/dist/resources/extensions/gsd/tests/dispatch-guard.test.ts +0 -128
- package/dist/resources/extensions/gsd/tests/dispatch-missing-task-plans.test.ts +0 -132
- package/dist/resources/extensions/gsd/tests/dispatch-stall-guard.test.ts +0 -126
- package/dist/resources/extensions/gsd/tests/doctor-environment.test.ts +0 -314
- package/dist/resources/extensions/gsd/tests/doctor-fixlevel.test.ts +0 -245
- package/dist/resources/extensions/gsd/tests/doctor-git.test.ts +0 -344
- package/dist/resources/extensions/gsd/tests/doctor-proactive.test.ts +0 -278
- package/dist/resources/extensions/gsd/tests/doctor-providers.test.ts +0 -298
- package/dist/resources/extensions/gsd/tests/doctor-runtime.test.ts +0 -302
- package/dist/resources/extensions/gsd/tests/doctor.test.ts +0 -652
- package/dist/resources/extensions/gsd/tests/draft-promotion.test.ts +0 -169
- package/dist/resources/extensions/gsd/tests/exit-command.test.ts +0 -50
- package/dist/resources/extensions/gsd/tests/export-html-all.test.ts +0 -105
- package/dist/resources/extensions/gsd/tests/export-html-enhancements.test.ts +0 -378
- package/dist/resources/extensions/gsd/tests/extension-selector-separator.test.ts +0 -144
- package/dist/resources/extensions/gsd/tests/feature-branch-lifecycle-integration.test.ts +0 -424
- package/dist/resources/extensions/gsd/tests/git-self-heal.test.ts +0 -131
- package/dist/resources/extensions/gsd/tests/git-service.test.ts +0 -1172
- package/dist/resources/extensions/gsd/tests/gsd-db.test.ts +0 -353
- package/dist/resources/extensions/gsd/tests/gsd-inspect.test.ts +0 -125
- package/dist/resources/extensions/gsd/tests/gsd-tools.test.ts +0 -326
- package/dist/resources/extensions/gsd/tests/headless-answers.test.ts +0 -340
- package/dist/resources/extensions/gsd/tests/headless-query.test.ts +0 -162
- package/dist/resources/extensions/gsd/tests/idle-recovery.test.ts +0 -485
- package/dist/resources/extensions/gsd/tests/in-flight-tool-tracking.test.ts +0 -32
- package/dist/resources/extensions/gsd/tests/init-wizard.test.ts +0 -197
- package/dist/resources/extensions/gsd/tests/integration/headless-command.ts +0 -534
- package/dist/resources/extensions/gsd/tests/integration-edge.test.ts +0 -228
- package/dist/resources/extensions/gsd/tests/integration-lifecycle.test.ts +0 -277
- package/dist/resources/extensions/gsd/tests/integration-mixed-milestones.test.ts +0 -523
- package/dist/resources/extensions/gsd/tests/key-manager.test.ts +0 -414
- package/dist/resources/extensions/gsd/tests/knowledge.test.ts +0 -161
- package/dist/resources/extensions/gsd/tests/loop-regression.test.ts +0 -839
- package/dist/resources/extensions/gsd/tests/manifest-status.test.ts +0 -283
- package/dist/resources/extensions/gsd/tests/marketplace-test-fixtures.ts +0 -91
- package/dist/resources/extensions/gsd/tests/md-importer.test.ts +0 -410
- package/dist/resources/extensions/gsd/tests/mechanical-completion.test.ts +0 -356
- package/dist/resources/extensions/gsd/tests/memory-extractor.test.ts +0 -180
- package/dist/resources/extensions/gsd/tests/memory-leak-guards.test.ts +0 -91
- package/dist/resources/extensions/gsd/tests/memory-store.test.ts +0 -345
- package/dist/resources/extensions/gsd/tests/metrics.test.ts +0 -253
- package/dist/resources/extensions/gsd/tests/migrate-command.test.ts +0 -369
- package/dist/resources/extensions/gsd/tests/migrate-parser.test.ts +0 -757
- package/dist/resources/extensions/gsd/tests/migrate-transformer.test.ts +0 -635
- package/dist/resources/extensions/gsd/tests/migrate-validator-parsers.test.ts +0 -414
- package/dist/resources/extensions/gsd/tests/migrate-writer-integration.test.ts +0 -303
- package/dist/resources/extensions/gsd/tests/migrate-writer.test.ts +0 -398
- package/dist/resources/extensions/gsd/tests/milestone-transition-worktree.test.ts +0 -147
- package/dist/resources/extensions/gsd/tests/model-cost-table.test.ts +0 -69
- package/dist/resources/extensions/gsd/tests/model-isolation.test.ts +0 -157
- package/dist/resources/extensions/gsd/tests/model-router.test.ts +0 -167
- package/dist/resources/extensions/gsd/tests/must-have-parser.test.ts +0 -291
- package/dist/resources/extensions/gsd/tests/namespaced-registry.test.ts +0 -1027
- package/dist/resources/extensions/gsd/tests/namespaced-resolver.test.ts +0 -671
- package/dist/resources/extensions/gsd/tests/native-has-changes-cache.test.ts +0 -61
- package/dist/resources/extensions/gsd/tests/next-milestone-id.test.ts +0 -23
- package/dist/resources/extensions/gsd/tests/none-mode-gates.test.ts +0 -114
- package/dist/resources/extensions/gsd/tests/notifications.test.ts +0 -67
- package/dist/resources/extensions/gsd/tests/overrides.test.ts +0 -131
- package/dist/resources/extensions/gsd/tests/parallel-budget-atomicity.test.ts +0 -331
- package/dist/resources/extensions/gsd/tests/parallel-crash-recovery.test.ts +0 -298
- package/dist/resources/extensions/gsd/tests/parallel-merge.test.ts +0 -468
- package/dist/resources/extensions/gsd/tests/parallel-orchestration.test.ts +0 -685
- package/dist/resources/extensions/gsd/tests/parallel-worker-monitoring.test.ts +0 -171
- package/dist/resources/extensions/gsd/tests/parallel-workers-multi-milestone-e2e.test.ts +0 -354
- package/dist/resources/extensions/gsd/tests/park-edge-cases.test.ts +0 -276
- package/dist/resources/extensions/gsd/tests/park-milestone.test.ts +0 -401
- package/dist/resources/extensions/gsd/tests/parsers.test.ts +0 -1704
- package/dist/resources/extensions/gsd/tests/plan-milestone.test.ts +0 -133
- package/dist/resources/extensions/gsd/tests/plan-quality-validator.test.ts +0 -363
- package/dist/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +0 -42
- package/dist/resources/extensions/gsd/tests/plugin-importer-live.test.ts +0 -481
- package/dist/resources/extensions/gsd/tests/plugin-importer.test.ts +0 -1383
- package/dist/resources/extensions/gsd/tests/post-unit-hooks.test.ts +0 -337
- package/dist/resources/extensions/gsd/tests/preferences.test.ts +0 -276
- package/dist/resources/extensions/gsd/tests/progress-score.test.ts +0 -206
- package/dist/resources/extensions/gsd/tests/prompt-budget-enforcement.test.ts +0 -464
- package/dist/resources/extensions/gsd/tests/prompt-cache-optimizer.test.ts +0 -314
- package/dist/resources/extensions/gsd/tests/prompt-compressor.test.ts +0 -529
- package/dist/resources/extensions/gsd/tests/prompt-db.test.ts +0 -385
- package/dist/resources/extensions/gsd/tests/prompt-ordering.test.ts +0 -296
- package/dist/resources/extensions/gsd/tests/provider-errors.test.ts +0 -338
- package/dist/resources/extensions/gsd/tests/queue-draft-detection.test.ts +0 -126
- package/dist/resources/extensions/gsd/tests/queue-order.test.ts +0 -204
- package/dist/resources/extensions/gsd/tests/queue-reorder-e2e.test.ts +0 -282
- package/dist/resources/extensions/gsd/tests/reassess-detection.test.ts +0 -154
- package/dist/resources/extensions/gsd/tests/reassess-prompt.test.ts +0 -145
- package/dist/resources/extensions/gsd/tests/regex-hardening.test.ts +0 -281
- package/dist/resources/extensions/gsd/tests/remote-questions.test.ts +0 -642
- package/dist/resources/extensions/gsd/tests/remote-status.test.ts +0 -99
- package/dist/resources/extensions/gsd/tests/replan-slice.test.ts +0 -538
- package/dist/resources/extensions/gsd/tests/requirements.test.ts +0 -106
- package/dist/resources/extensions/gsd/tests/roadmap-slices.test.ts +0 -66
- package/dist/resources/extensions/gsd/tests/routing-history.test.ts +0 -240
- package/dist/resources/extensions/gsd/tests/run-uat.test.ts +0 -416
- package/dist/resources/extensions/gsd/tests/secure-env-collect.test.ts +0 -185
- package/dist/resources/extensions/gsd/tests/semantic-chunker.test.ts +0 -426
- package/dist/resources/extensions/gsd/tests/session-lock.test.ts +0 -315
- package/dist/resources/extensions/gsd/tests/skill-lifecycle.test.ts +0 -126
- package/dist/resources/extensions/gsd/tests/smart-entry-draft.test.ts +0 -123
- package/dist/resources/extensions/gsd/tests/stale-worktree-cwd.test.ts +0 -142
- package/dist/resources/extensions/gsd/tests/stop-auto-remote.test.ts +0 -156
- package/dist/resources/extensions/gsd/tests/structured-data-formatter.test.ts +0 -365
- package/dist/resources/extensions/gsd/tests/summary-distiller.test.ts +0 -323
- package/dist/resources/extensions/gsd/tests/test-helpers.ts +0 -61
- package/dist/resources/extensions/gsd/tests/token-counter.test.ts +0 -129
- package/dist/resources/extensions/gsd/tests/token-optimization-benchmark.test.ts +0 -1272
- package/dist/resources/extensions/gsd/tests/token-optimization-prefs.test.ts +0 -164
- package/dist/resources/extensions/gsd/tests/token-profile.test.ts +0 -268
- package/dist/resources/extensions/gsd/tests/token-savings.test.ts +0 -366
- package/dist/resources/extensions/gsd/tests/triage-dispatch.test.ts +0 -340
- package/dist/resources/extensions/gsd/tests/triage-resolution.test.ts +0 -416
- package/dist/resources/extensions/gsd/tests/undo.test.ts +0 -136
- package/dist/resources/extensions/gsd/tests/unique-milestone-ids.test.ts +0 -219
- package/dist/resources/extensions/gsd/tests/unit-runtime.test.ts +0 -258
- package/dist/resources/extensions/gsd/tests/update-command.test.ts +0 -67
- package/dist/resources/extensions/gsd/tests/validate-directory.test.ts +0 -222
- package/dist/resources/extensions/gsd/tests/validate-milestone.test.ts +0 -375
- package/dist/resources/extensions/gsd/tests/verification-evidence.test.ts +0 -745
- package/dist/resources/extensions/gsd/tests/verification-gate.test.ts +0 -1208
- package/dist/resources/extensions/gsd/tests/visualizer-critical-path.test.ts +0 -145
- package/dist/resources/extensions/gsd/tests/visualizer-data.test.ts +0 -446
- package/dist/resources/extensions/gsd/tests/visualizer-overlay.test.ts +0 -237
- package/dist/resources/extensions/gsd/tests/visualizer-views.test.ts +0 -718
- package/dist/resources/extensions/gsd/tests/worker-registry.test.ts +0 -148
- package/dist/resources/extensions/gsd/tests/workflow-templates.test.ts +0 -173
- package/dist/resources/extensions/gsd/tests/workspace-index.test.ts +0 -38
- package/dist/resources/extensions/gsd/tests/worktree-bugfix.test.ts +0 -120
- package/dist/resources/extensions/gsd/tests/worktree-e2e.test.ts +0 -244
- package/dist/resources/extensions/gsd/tests/worktree-integration.test.ts +0 -207
- package/dist/resources/extensions/gsd/tests/worktree-manager.test.ts +0 -141
- package/dist/resources/extensions/gsd/tests/worktree-post-create-hook.test.ts +0 -165
- package/dist/resources/extensions/gsd/tests/worktree.test.ts +0 -171
- package/dist/resources/extensions/gsd/tests/write-gate.test.ts +0 -211
- package/dist/resources/extensions/gsd/token-counter.ts +0 -65
- package/dist/resources/extensions/gsd/triage-resolution.ts +0 -284
- package/dist/resources/extensions/gsd/triage-ui.ts +0 -175
- package/dist/resources/extensions/gsd/types.ts +0 -425
- package/dist/resources/extensions/gsd/undo.ts +0 -223
- package/dist/resources/extensions/gsd/unit-id.ts +0 -14
- package/dist/resources/extensions/gsd/unit-runtime.ts +0 -192
- package/dist/resources/extensions/gsd/validate-directory.ts +0 -164
- package/dist/resources/extensions/gsd/verification-evidence.ts +0 -188
- package/dist/resources/extensions/gsd/verification-gate.ts +0 -643
- package/dist/resources/extensions/gsd/visualizer-data.ts +0 -866
- package/dist/resources/extensions/gsd/visualizer-overlay.ts +0 -566
- package/dist/resources/extensions/gsd/visualizer-views.ts +0 -1171
- package/dist/resources/extensions/gsd/workflow-templates.ts +0 -241
- package/dist/resources/extensions/gsd/workspace-index.ts +0 -217
- package/dist/resources/extensions/gsd/worktree-command.ts +0 -807
- package/dist/resources/extensions/gsd/worktree-manager.ts +0 -449
- package/dist/resources/extensions/gsd/worktree.ts +0 -257
- package/dist/resources/extensions/mac-tools/index.ts +0 -852
- package/dist/resources/extensions/mcp-client/index.ts +0 -459
- package/dist/resources/extensions/mcporter/extension-manifest.json +0 -12
- package/dist/resources/extensions/remote-questions/config.ts +0 -83
- package/dist/resources/extensions/remote-questions/discord-adapter.ts +0 -148
- package/dist/resources/extensions/remote-questions/format.ts +0 -315
- package/dist/resources/extensions/remote-questions/http-client.ts +0 -76
- package/dist/resources/extensions/remote-questions/manager.ts +0 -184
- package/dist/resources/extensions/remote-questions/notify.ts +0 -90
- package/dist/resources/extensions/remote-questions/remote-command.ts +0 -457
- package/dist/resources/extensions/remote-questions/slack-adapter.ts +0 -141
- package/dist/resources/extensions/remote-questions/status.ts +0 -31
- package/dist/resources/extensions/remote-questions/store.ts +0 -81
- package/dist/resources/extensions/remote-questions/telegram-adapter.ts +0 -149
- package/dist/resources/extensions/remote-questions/types.ts +0 -102
- package/dist/resources/extensions/search-the-web/cache.ts +0 -78
- package/dist/resources/extensions/search-the-web/command-search-provider.ts +0 -101
- package/dist/resources/extensions/search-the-web/format.ts +0 -258
- package/dist/resources/extensions/search-the-web/http.ts +0 -238
- package/dist/resources/extensions/search-the-web/index.ts +0 -65
- package/dist/resources/extensions/search-the-web/native-search.ts +0 -193
- package/dist/resources/extensions/search-the-web/provider.ts +0 -148
- package/dist/resources/extensions/search-the-web/tavily.ts +0 -116
- package/dist/resources/extensions/search-the-web/tool-fetch-page.ts +0 -589
- package/dist/resources/extensions/search-the-web/tool-llm-context.ts +0 -608
- package/dist/resources/extensions/search-the-web/tool-search.ts +0 -649
- package/dist/resources/extensions/search-the-web/url-utils.ts +0 -125
- package/dist/resources/extensions/shared/confirm-ui.ts +0 -126
- package/dist/resources/extensions/shared/frontmatter.ts +0 -117
- package/dist/resources/extensions/shared/interview-ui.ts +0 -613
- package/dist/resources/extensions/shared/next-action-ui.ts +0 -212
- package/dist/resources/extensions/shared/sanitize.ts +0 -19
- package/dist/resources/extensions/shared/terminal.ts +0 -23
- package/dist/resources/extensions/shared/tests/format-utils.test.ts +0 -153
- package/dist/resources/extensions/shared/ui.ts +0 -400
- package/dist/resources/extensions/shared/wizard-ui.ts +0 -551
- package/dist/resources/extensions/slash-commands/audit.ts +0 -88
- package/dist/resources/extensions/slash-commands/clear.ts +0 -10
- package/dist/resources/extensions/slash-commands/create-extension.ts +0 -297
- package/dist/resources/extensions/slash-commands/create-slash-command.ts +0 -234
- package/dist/resources/extensions/slash-commands/index.ts +0 -12
- package/dist/resources/extensions/subagent/agents.ts +0 -126
- package/dist/resources/extensions/subagent/index.ts +0 -1121
- package/dist/resources/extensions/subagent/isolation.ts +0 -501
- package/dist/resources/extensions/subagent/worker-registry.ts +0 -99
- package/dist/resources/extensions/ttsr/index.ts +0 -168
- package/dist/resources/extensions/ttsr/rule-loader.ts +0 -74
- package/dist/resources/extensions/ttsr/ttsr-manager.ts +0 -456
- package/dist/resources/extensions/universal-config/discovery.ts +0 -104
- package/dist/resources/extensions/universal-config/format.ts +0 -191
- package/dist/resources/extensions/universal-config/index.ts +0 -120
- package/dist/resources/extensions/universal-config/scanners.ts +0 -642
- package/dist/resources/extensions/universal-config/tests/discovery.test.ts +0 -119
- package/dist/resources/extensions/universal-config/tests/format.test.ts +0 -127
- package/dist/resources/extensions/universal-config/tests/scanners.test.ts +0 -456
- package/dist/resources/extensions/universal-config/tools.ts +0 -60
- package/dist/resources/extensions/universal-config/types.ts +0 -135
- package/dist/resources/extensions/voice/index.ts +0 -272
- package/dist/resources/skills/create-gsd-extension/templates/extension-skeleton.ts +0 -51
- package/dist/resources/skills/create-gsd-extension/templates/stateful-tool-skeleton.ts +0 -143
- package/src/resources/extensions/mcporter/extension-manifest.json +0 -12
|
@@ -1,338 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Provider error handling tests — consolidated from:
|
|
3
|
-
* - provider-error-classify.test.ts (classifyProviderError)
|
|
4
|
-
* - network-error-fallback.test.ts (isTransientNetworkError, getNextFallbackModel)
|
|
5
|
-
* - agent-end-provider-error.test.ts (pauseAutoForProviderError)
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import test from "node:test";
|
|
9
|
-
import assert from "node:assert/strict";
|
|
10
|
-
import { readFileSync } from "node:fs";
|
|
11
|
-
import { join, dirname } from "node:path";
|
|
12
|
-
import { fileURLToPath } from "node:url";
|
|
13
|
-
import { classifyProviderError, pauseAutoForProviderError } from "../provider-error-pause.ts";
|
|
14
|
-
import { getNextFallbackModel, isTransientNetworkError } from "../preferences.ts";
|
|
15
|
-
|
|
16
|
-
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
17
|
-
|
|
18
|
-
// ── classifyProviderError ────────────────────────────────────────────────────
|
|
19
|
-
|
|
20
|
-
test("classifyProviderError detects rate limit from 429", () => {
|
|
21
|
-
const result = classifyProviderError("HTTP 429 Too Many Requests");
|
|
22
|
-
assert.ok(result.isTransient);
|
|
23
|
-
assert.ok(result.isRateLimit);
|
|
24
|
-
assert.ok(result.suggestedDelayMs > 0);
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
test("classifyProviderError detects rate limit from message", () => {
|
|
28
|
-
const result = classifyProviderError("rate limit exceeded");
|
|
29
|
-
assert.ok(result.isTransient);
|
|
30
|
-
assert.ok(result.isRateLimit);
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
test("classifyProviderError extracts reset delay from message", () => {
|
|
34
|
-
const result = classifyProviderError("rate limit exceeded, reset in 45s");
|
|
35
|
-
assert.ok(result.isRateLimit);
|
|
36
|
-
assert.equal(result.suggestedDelayMs, 45000);
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
test("classifyProviderError defaults to 60s for rate limit without reset", () => {
|
|
40
|
-
const result = classifyProviderError("429 too many requests");
|
|
41
|
-
assert.ok(result.isRateLimit);
|
|
42
|
-
assert.equal(result.suggestedDelayMs, 60_000);
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
test("classifyProviderError detects Anthropic internal server error", () => {
|
|
46
|
-
const msg = '{"type":"error","error":{"details":null,"type":"api_error","message":"Internal server error"}}';
|
|
47
|
-
const result = classifyProviderError(msg);
|
|
48
|
-
assert.ok(result.isTransient);
|
|
49
|
-
assert.ok(!result.isRateLimit);
|
|
50
|
-
assert.equal(result.suggestedDelayMs, 30_000);
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
test("classifyProviderError detects Codex server_error from extracted message", () => {
|
|
54
|
-
// After fix, mapCodexEvents extracts the nested error type and produces
|
|
55
|
-
// "Codex server_error: <message>" instead of raw JSON.
|
|
56
|
-
const msg = "Codex server_error: An error occurred while processing your request.";
|
|
57
|
-
const result = classifyProviderError(msg);
|
|
58
|
-
assert.ok(result.isTransient);
|
|
59
|
-
assert.ok(!result.isRateLimit);
|
|
60
|
-
assert.equal(result.suggestedDelayMs, 30_000);
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
test("classifyProviderError detects overloaded error", () => {
|
|
64
|
-
const result = classifyProviderError("overloaded_error: Overloaded");
|
|
65
|
-
assert.ok(result.isTransient);
|
|
66
|
-
assert.equal(result.suggestedDelayMs, 30_000);
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
test("classifyProviderError detects 503 service unavailable", () => {
|
|
70
|
-
const result = classifyProviderError("HTTP 503 Service Unavailable");
|
|
71
|
-
assert.ok(result.isTransient);
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
test("classifyProviderError detects 502 bad gateway", () => {
|
|
75
|
-
const result = classifyProviderError("HTTP 502 Bad Gateway");
|
|
76
|
-
assert.ok(result.isTransient);
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
test("classifyProviderError detects auth error as permanent", () => {
|
|
80
|
-
const result = classifyProviderError("unauthorized: invalid API key");
|
|
81
|
-
assert.ok(!result.isTransient);
|
|
82
|
-
assert.ok(!result.isRateLimit);
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
test("classifyProviderError detects billing error as permanent", () => {
|
|
86
|
-
const result = classifyProviderError("billing issue: payment required");
|
|
87
|
-
assert.ok(!result.isTransient);
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
test("classifyProviderError detects quota exceeded as permanent", () => {
|
|
91
|
-
const result = classifyProviderError("quota exceeded for this month");
|
|
92
|
-
assert.ok(!result.isTransient);
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
test("classifyProviderError treats unknown error as permanent", () => {
|
|
96
|
-
const result = classifyProviderError("something went wrong");
|
|
97
|
-
assert.ok(!result.isTransient);
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
test("classifyProviderError treats empty string as permanent", () => {
|
|
101
|
-
const result = classifyProviderError("");
|
|
102
|
-
assert.ok(!result.isTransient);
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
test("classifyProviderError: rate limit takes precedence over auth keywords", () => {
|
|
106
|
-
const result = classifyProviderError("429 unauthorized rate limit");
|
|
107
|
-
assert.ok(result.isRateLimit);
|
|
108
|
-
assert.ok(result.isTransient);
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
// ── isTransientNetworkError ──────────────────────────────────────────────────
|
|
112
|
-
|
|
113
|
-
test("isTransientNetworkError detects ECONNRESET", () => {
|
|
114
|
-
assert.ok(isTransientNetworkError("fetch failed: ECONNRESET"));
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
test("isTransientNetworkError detects ETIMEDOUT", () => {
|
|
118
|
-
assert.ok(isTransientNetworkError("ETIMEDOUT: request timed out"));
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
test("isTransientNetworkError detects generic network error", () => {
|
|
122
|
-
assert.ok(isTransientNetworkError("network error"));
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
test("isTransientNetworkError detects socket hang up", () => {
|
|
126
|
-
assert.ok(isTransientNetworkError("socket hang up"));
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
test("isTransientNetworkError detects fetch failed", () => {
|
|
130
|
-
assert.ok(isTransientNetworkError("fetch failed"));
|
|
131
|
-
});
|
|
132
|
-
|
|
133
|
-
test("isTransientNetworkError detects connection reset", () => {
|
|
134
|
-
assert.ok(isTransientNetworkError("connection was reset by peer"));
|
|
135
|
-
});
|
|
136
|
-
|
|
137
|
-
test("isTransientNetworkError detects DNS errors", () => {
|
|
138
|
-
assert.ok(isTransientNetworkError("dns resolution failed"));
|
|
139
|
-
});
|
|
140
|
-
|
|
141
|
-
test("isTransientNetworkError rejects auth errors", () => {
|
|
142
|
-
assert.ok(!isTransientNetworkError("unauthorized: invalid API key"));
|
|
143
|
-
});
|
|
144
|
-
|
|
145
|
-
test("isTransientNetworkError rejects quota errors", () => {
|
|
146
|
-
assert.ok(!isTransientNetworkError("quota exceeded"));
|
|
147
|
-
});
|
|
148
|
-
|
|
149
|
-
test("isTransientNetworkError rejects billing errors", () => {
|
|
150
|
-
assert.ok(!isTransientNetworkError("billing issue: network payment required"));
|
|
151
|
-
});
|
|
152
|
-
|
|
153
|
-
test("isTransientNetworkError rejects empty string", () => {
|
|
154
|
-
assert.ok(!isTransientNetworkError(""));
|
|
155
|
-
});
|
|
156
|
-
|
|
157
|
-
test("isTransientNetworkError rejects non-network errors", () => {
|
|
158
|
-
assert.ok(!isTransientNetworkError("model not found"));
|
|
159
|
-
});
|
|
160
|
-
|
|
161
|
-
// ── getNextFallbackModel ─────────────────────────────────────────────────────
|
|
162
|
-
|
|
163
|
-
test("getNextFallbackModel selects next fallback if current is a fallback", () => {
|
|
164
|
-
const modelConfig = { primary: "model-a", fallbacks: ["model-b", "model-c"] };
|
|
165
|
-
assert.equal(getNextFallbackModel("model-b", modelConfig), "model-c");
|
|
166
|
-
});
|
|
167
|
-
|
|
168
|
-
test("getNextFallbackModel returns undefined if fallbacks exhausted", () => {
|
|
169
|
-
const modelConfig = { primary: "model-a", fallbacks: ["model-b", "model-c"] };
|
|
170
|
-
assert.equal(getNextFallbackModel("model-c", modelConfig), undefined);
|
|
171
|
-
});
|
|
172
|
-
|
|
173
|
-
test("getNextFallbackModel finds current model with provider prefix", () => {
|
|
174
|
-
const modelConfig = { primary: "p/model-a", fallbacks: ["p/model-b"] };
|
|
175
|
-
assert.equal(getNextFallbackModel("model-a", modelConfig), "p/model-b");
|
|
176
|
-
});
|
|
177
|
-
|
|
178
|
-
test("getNextFallbackModel returns primary if current is unknown", () => {
|
|
179
|
-
const modelConfig = { primary: "model-a", fallbacks: ["model-b", "model-c"] };
|
|
180
|
-
assert.equal(getNextFallbackModel("model-x", modelConfig), "model-a");
|
|
181
|
-
});
|
|
182
|
-
|
|
183
|
-
test("getNextFallbackModel returns primary if current is undefined", () => {
|
|
184
|
-
const modelConfig = { primary: "model-a", fallbacks: ["model-b", "model-c"] };
|
|
185
|
-
assert.equal(getNextFallbackModel(undefined, modelConfig), "model-a");
|
|
186
|
-
});
|
|
187
|
-
|
|
188
|
-
// ── pauseAutoForProviderError ────────────────────────────────────────────────
|
|
189
|
-
|
|
190
|
-
test("pauseAutoForProviderError warns and pauses without requiring ctx.log", async () => {
|
|
191
|
-
const notifications: Array<{ message: string; level: string }> = [];
|
|
192
|
-
let pauseCalls = 0;
|
|
193
|
-
|
|
194
|
-
await pauseAutoForProviderError(
|
|
195
|
-
{ notify(message, level?) { notifications.push({ message, level: level ?? "info" }); } },
|
|
196
|
-
": terminated",
|
|
197
|
-
async () => { pauseCalls += 1; },
|
|
198
|
-
);
|
|
199
|
-
|
|
200
|
-
assert.equal(pauseCalls, 1);
|
|
201
|
-
assert.deepEqual(notifications, [
|
|
202
|
-
{ message: "Auto-mode paused due to provider error: terminated", level: "warning" },
|
|
203
|
-
]);
|
|
204
|
-
});
|
|
205
|
-
|
|
206
|
-
test("pauseAutoForProviderError schedules auto-resume for rate limit errors", async () => {
|
|
207
|
-
const notifications: Array<{ message: string; level: string }> = [];
|
|
208
|
-
let pauseCalls = 0;
|
|
209
|
-
let resumeCalled = false;
|
|
210
|
-
|
|
211
|
-
const originalSetTimeout = globalThis.setTimeout;
|
|
212
|
-
const timers: Array<{ fn: () => void; delay: number }> = [];
|
|
213
|
-
globalThis.setTimeout = ((fn: () => void, delay: number) => {
|
|
214
|
-
timers.push({ fn, delay });
|
|
215
|
-
return 0 as unknown as ReturnType<typeof setTimeout>;
|
|
216
|
-
}) as typeof setTimeout;
|
|
217
|
-
|
|
218
|
-
try {
|
|
219
|
-
await pauseAutoForProviderError(
|
|
220
|
-
{ notify(message, level?) { notifications.push({ message, level: level ?? "info" }); } },
|
|
221
|
-
": rate limit exceeded",
|
|
222
|
-
async () => { pauseCalls += 1; },
|
|
223
|
-
{ isRateLimit: true, retryAfterMs: 90000, resume: () => { resumeCalled = true; } },
|
|
224
|
-
);
|
|
225
|
-
|
|
226
|
-
assert.equal(pauseCalls, 1);
|
|
227
|
-
assert.equal(timers.length, 1);
|
|
228
|
-
assert.equal(timers[0].delay, 90000);
|
|
229
|
-
assert.deepEqual(notifications[0], {
|
|
230
|
-
message: "Rate limited: rate limit exceeded. Auto-resuming in 90s...",
|
|
231
|
-
level: "warning",
|
|
232
|
-
});
|
|
233
|
-
|
|
234
|
-
timers[0].fn();
|
|
235
|
-
assert.equal(resumeCalled, true);
|
|
236
|
-
assert.deepEqual(notifications[1], {
|
|
237
|
-
message: "Rate limit window elapsed. Resuming auto-mode.",
|
|
238
|
-
level: "info",
|
|
239
|
-
});
|
|
240
|
-
} finally {
|
|
241
|
-
globalThis.setTimeout = originalSetTimeout;
|
|
242
|
-
}
|
|
243
|
-
});
|
|
244
|
-
|
|
245
|
-
test("pauseAutoForProviderError falls back to indefinite pause when not rate limit", async () => {
|
|
246
|
-
const notifications: Array<{ message: string; level: string }> = [];
|
|
247
|
-
let pauseCalls = 0;
|
|
248
|
-
|
|
249
|
-
await pauseAutoForProviderError(
|
|
250
|
-
{ notify(message, level?) { notifications.push({ message, level: level ?? "info" }); } },
|
|
251
|
-
": connection refused",
|
|
252
|
-
async () => { pauseCalls += 1; },
|
|
253
|
-
{ isRateLimit: false },
|
|
254
|
-
);
|
|
255
|
-
|
|
256
|
-
assert.equal(pauseCalls, 1);
|
|
257
|
-
assert.deepEqual(notifications, [
|
|
258
|
-
{ message: "Auto-mode paused due to provider error: connection refused", level: "warning" },
|
|
259
|
-
]);
|
|
260
|
-
});
|
|
261
|
-
|
|
262
|
-
// ── Escalating backoff for transient errors (#1166) ─────────────────────────
|
|
263
|
-
|
|
264
|
-
test("index.ts tracks consecutive transient errors for escalating backoff", () => {
|
|
265
|
-
const indexSource = readFileSync(join(__dirname, "..", "index.ts"), "utf-8");
|
|
266
|
-
|
|
267
|
-
assert.ok(
|
|
268
|
-
indexSource.includes("consecutiveTransientErrors"),
|
|
269
|
-
"index.ts must track consecutiveTransientErrors for escalating backoff (#1166)",
|
|
270
|
-
);
|
|
271
|
-
assert.ok(
|
|
272
|
-
indexSource.includes("MAX_TRANSIENT_AUTO_RESUMES"),
|
|
273
|
-
"index.ts must define MAX_TRANSIENT_AUTO_RESUMES to cap infinite retries (#1166)",
|
|
274
|
-
);
|
|
275
|
-
});
|
|
276
|
-
|
|
277
|
-
test("index.ts resets consecutive transient error counter on success", () => {
|
|
278
|
-
const indexSource = readFileSync(join(__dirname, "..", "index.ts"), "utf-8");
|
|
279
|
-
|
|
280
|
-
// After successful unit completion, the counter must be reset
|
|
281
|
-
const marker = "successful unit completion";
|
|
282
|
-
const successSection = indexSource.indexOf(marker);
|
|
283
|
-
assert.ok(successSection > -1, "must have success section that clears network retries");
|
|
284
|
-
const nearbyCode = indexSource.slice(Math.max(0, successSection - 100), successSection + 200);
|
|
285
|
-
assert.ok(
|
|
286
|
-
nearbyCode.includes("consecutiveTransientErrors = 0"),
|
|
287
|
-
"consecutive transient error counter must be reset on successful unit completion (#1166)",
|
|
288
|
-
);
|
|
289
|
-
});
|
|
290
|
-
|
|
291
|
-
test("index.ts applies escalating delay for repeated transient errors", () => {
|
|
292
|
-
const indexSource = readFileSync(join(__dirname, "..", "index.ts"), "utf-8");
|
|
293
|
-
|
|
294
|
-
// Must contain the exponential backoff formula
|
|
295
|
-
assert.ok(
|
|
296
|
-
/retryAfterMs\s*[=*].*2\s*\*\*/.test(indexSource),
|
|
297
|
-
"index.ts must escalate retryAfterMs exponentially for consecutive transient errors (#1166)",
|
|
298
|
-
);
|
|
299
|
-
});
|
|
300
|
-
|
|
301
|
-
// ── Codex error extraction (#1166) ──────────────────────────────────────────
|
|
302
|
-
|
|
303
|
-
test("openai-codex-responses.ts extracts nested error fields", () => {
|
|
304
|
-
const codexSource = readFileSync(
|
|
305
|
-
join(__dirname, "../../../../../packages/pi-ai/src/providers/openai-codex-responses.ts"),
|
|
306
|
-
"utf-8",
|
|
307
|
-
);
|
|
308
|
-
|
|
309
|
-
// Must access event.error.message (nested), not just event.message (top-level)
|
|
310
|
-
assert.ok(
|
|
311
|
-
codexSource.includes("errorObj?.message"),
|
|
312
|
-
"mapCodexEvents must extract message from nested event.error object (#1166)",
|
|
313
|
-
);
|
|
314
|
-
assert.ok(
|
|
315
|
-
codexSource.includes("errorObj?.type"),
|
|
316
|
-
"mapCodexEvents must extract type from nested event.error object (#1166)",
|
|
317
|
-
);
|
|
318
|
-
});
|
|
319
|
-
|
|
320
|
-
// ── agent-session retryable regex handles server_error (#1166) ──────────────
|
|
321
|
-
|
|
322
|
-
test("agent-session retryable error regex matches server_error (underscore)", () => {
|
|
323
|
-
// This regex is extracted from _isRetryableError in agent-session.ts.
|
|
324
|
-
// It must match both "server error" (space) and "server_error" (underscore)
|
|
325
|
-
// to properly classify Codex streaming errors as retryable.
|
|
326
|
-
const retryableRegex = /overloaded|rate.?limit|too many requests|429|500|502|503|504|service.?unavailable|server.?error|internal.?error|connection.?error|connection.?refused|other side closed|fetch failed|upstream.?connect|reset before headers|terminated|retry delay|network.?(?:is\s+)?unavailable|credentials.*expired|temporarily backed off/i;
|
|
327
|
-
|
|
328
|
-
// server_error (with underscore — Codex streaming error format)
|
|
329
|
-
assert.ok(retryableRegex.test("Codex server_error: An error occurred"));
|
|
330
|
-
// server error (with space — traditional HTTP error format)
|
|
331
|
-
assert.ok(retryableRegex.test("server error occurred"));
|
|
332
|
-
// internal_error (with underscore)
|
|
333
|
-
assert.ok(retryableRegex.test("internal_error: something went wrong"));
|
|
334
|
-
// internal error (with space)
|
|
335
|
-
assert.ok(retryableRegex.test("internal error"));
|
|
336
|
-
// non-retryable errors must not match
|
|
337
|
-
assert.ok(!retryableRegex.test("model not found"));
|
|
338
|
-
});
|
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
import { mkdtempSync, mkdirSync, rmSync, writeFileSync } from "node:fs";
|
|
2
|
-
import { join } from "node:path";
|
|
3
|
-
import { tmpdir } from "node:os";
|
|
4
|
-
|
|
5
|
-
import { deriveState } from "../state.js";
|
|
6
|
-
import { buildExistingMilestonesContext } from "../guided-flow.js";
|
|
7
|
-
|
|
8
|
-
let passed = 0;
|
|
9
|
-
let failed = 0;
|
|
10
|
-
|
|
11
|
-
function assert(condition: boolean, message: string): void {
|
|
12
|
-
if (condition) {
|
|
13
|
-
passed++;
|
|
14
|
-
} else {
|
|
15
|
-
failed++;
|
|
16
|
-
console.error(` FAIL: ${message}`);
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
// ─── Fixture setup ──────────────────────────────────────────────────────
|
|
21
|
-
|
|
22
|
-
const tmpBase = mkdtempSync(join(tmpdir(), "gsd-queue-draft-test-"));
|
|
23
|
-
const gsd = join(tmpBase, ".gsd");
|
|
24
|
-
|
|
25
|
-
// M001: has only CONTEXT-DRAFT.md (draft milestone)
|
|
26
|
-
mkdirSync(join(gsd, "milestones", "M001"), { recursive: true });
|
|
27
|
-
writeFileSync(
|
|
28
|
-
join(gsd, "milestones", "M001", "M001-CONTEXT-DRAFT.md"),
|
|
29
|
-
"# M001: Draft Milestone\n\nSeed material from prior discussion.\n",
|
|
30
|
-
);
|
|
31
|
-
|
|
32
|
-
// M002: has full CONTEXT.md (ready milestone)
|
|
33
|
-
mkdirSync(join(gsd, "milestones", "M002"), { recursive: true });
|
|
34
|
-
writeFileSync(
|
|
35
|
-
join(gsd, "milestones", "M002", "M002-CONTEXT.md"),
|
|
36
|
-
"# M002: Ready Milestone\n\nFull context from deep discussion.\n",
|
|
37
|
-
);
|
|
38
|
-
|
|
39
|
-
// M003: has both CONTEXT.md and CONTEXT-DRAFT.md (CONTEXT wins)
|
|
40
|
-
mkdirSync(join(gsd, "milestones", "M003"), { recursive: true });
|
|
41
|
-
writeFileSync(
|
|
42
|
-
join(gsd, "milestones", "M003", "M003-CONTEXT.md"),
|
|
43
|
-
"# M003: Full Context\n\nThis is the real context.\n",
|
|
44
|
-
);
|
|
45
|
-
writeFileSync(
|
|
46
|
-
join(gsd, "milestones", "M003", "M003-CONTEXT-DRAFT.md"),
|
|
47
|
-
"# M003: Draft\n\nThis should be ignored.\n",
|
|
48
|
-
);
|
|
49
|
-
|
|
50
|
-
// M004: has neither (empty milestone dir)
|
|
51
|
-
mkdirSync(join(gsd, "milestones", "M004"), { recursive: true });
|
|
52
|
-
|
|
53
|
-
// ─── Build context ──────────────────────────────────────────────────────
|
|
54
|
-
|
|
55
|
-
const state = await deriveState(tmpBase);
|
|
56
|
-
const milestoneIds = ["M001", "M002", "M003", "M004"];
|
|
57
|
-
const context = await buildExistingMilestonesContext(tmpBase, milestoneIds, state);
|
|
58
|
-
|
|
59
|
-
// ─── Test: draft-only milestone includes "Draft context available" ──────
|
|
60
|
-
|
|
61
|
-
assert(
|
|
62
|
-
context.includes("Draft context available"),
|
|
63
|
-
"M001 (draft-only) should include 'Draft context available' label",
|
|
64
|
-
);
|
|
65
|
-
|
|
66
|
-
assert(
|
|
67
|
-
context.includes("Seed material from prior discussion"),
|
|
68
|
-
"M001 draft content should be included in context output",
|
|
69
|
-
);
|
|
70
|
-
|
|
71
|
-
// ─── Test: full-context milestone uses "Context:" label ────────────────
|
|
72
|
-
|
|
73
|
-
assert(
|
|
74
|
-
context.includes("**Context:**"),
|
|
75
|
-
"M002 (full context) should use 'Context:' label",
|
|
76
|
-
);
|
|
77
|
-
|
|
78
|
-
assert(
|
|
79
|
-
context.includes("Full context from deep discussion"),
|
|
80
|
-
"M002 context content should be included",
|
|
81
|
-
);
|
|
82
|
-
|
|
83
|
-
// ─── Test: both files → CONTEXT.md wins, no draft label ────────────────
|
|
84
|
-
|
|
85
|
-
// Find M003's section and check it has Context: but not Draft
|
|
86
|
-
const m003Idx = context.indexOf("M003:");
|
|
87
|
-
const m003Section = context.slice(m003Idx, m003Idx + 500);
|
|
88
|
-
|
|
89
|
-
assert(
|
|
90
|
-
m003Section.includes("**Context:**"),
|
|
91
|
-
"M003 (both files) should use 'Context:' label (CONTEXT.md wins)",
|
|
92
|
-
);
|
|
93
|
-
|
|
94
|
-
assert(
|
|
95
|
-
!m003Section.includes("Draft context available"),
|
|
96
|
-
"M003 (both files) should NOT show draft label — CONTEXT.md takes precedence",
|
|
97
|
-
);
|
|
98
|
-
|
|
99
|
-
assert(
|
|
100
|
-
m003Section.includes("This is the real context"),
|
|
101
|
-
"M003 should show CONTEXT.md content, not draft content",
|
|
102
|
-
);
|
|
103
|
-
|
|
104
|
-
// ─── Test: neither file → no context section ───────────────────────────
|
|
105
|
-
|
|
106
|
-
const m004Idx = context.indexOf("M004:");
|
|
107
|
-
const m004Section = context.slice(m004Idx, m004Idx + 500);
|
|
108
|
-
|
|
109
|
-
assert(
|
|
110
|
-
!m004Section.includes("**Context:**"),
|
|
111
|
-
"M004 (neither file) should not have Context: label",
|
|
112
|
-
);
|
|
113
|
-
|
|
114
|
-
assert(
|
|
115
|
-
!m004Section.includes("Draft context available"),
|
|
116
|
-
"M004 (neither file) should not have Draft label",
|
|
117
|
-
);
|
|
118
|
-
|
|
119
|
-
// ─── Cleanup ──────────────────────────────────────────────────────────
|
|
120
|
-
|
|
121
|
-
rmSync(tmpBase, { recursive: true, force: true });
|
|
122
|
-
|
|
123
|
-
// ─── Results ──────────────────────────────────────────────────────────
|
|
124
|
-
|
|
125
|
-
console.log(`\nqueue-draft-detection: ${passed} passed, ${failed} failed`);
|
|
126
|
-
if (failed > 0) process.exit(1);
|
|
@@ -1,204 +0,0 @@
|
|
|
1
|
-
import { mkdtempSync, mkdirSync, rmSync, writeFileSync, existsSync, readFileSync } from 'node:fs';
|
|
2
|
-
import { join } from 'node:path';
|
|
3
|
-
import { tmpdir } from 'node:os';
|
|
4
|
-
|
|
5
|
-
import {
|
|
6
|
-
loadQueueOrder,
|
|
7
|
-
saveQueueOrder,
|
|
8
|
-
sortByQueueOrder,
|
|
9
|
-
pruneQueueOrder,
|
|
10
|
-
validateQueueOrder,
|
|
11
|
-
} from '../queue-order.ts';
|
|
12
|
-
import { createTestContext } from './test-helpers.ts';
|
|
13
|
-
|
|
14
|
-
const { assertEq, assertTrue, report } = createTestContext();
|
|
15
|
-
|
|
16
|
-
// ─── Fixture Helpers ───────────────────────────────────────────────────────
|
|
17
|
-
|
|
18
|
-
function createFixtureBase(): string {
|
|
19
|
-
const base = mkdtempSync(join(tmpdir(), 'gsd-queue-order-'));
|
|
20
|
-
mkdirSync(join(base, '.gsd'), { recursive: true });
|
|
21
|
-
return base;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
function cleanup(base: string): void {
|
|
25
|
-
rmSync(base, { recursive: true, force: true });
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
29
|
-
// sortByQueueOrder
|
|
30
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
31
|
-
|
|
32
|
-
console.log('\n=== sortByQueueOrder ===');
|
|
33
|
-
|
|
34
|
-
// Null order → default milestoneIdSort
|
|
35
|
-
{
|
|
36
|
-
const result = sortByQueueOrder(['M003', 'M001', 'M002'], null);
|
|
37
|
-
assertEq(result, ['M001', 'M002', 'M003'], 'null order falls back to numeric sort');
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
// Custom order → exact sequence
|
|
41
|
-
{
|
|
42
|
-
const result = sortByQueueOrder(['M001', 'M002', 'M003'], ['M003', 'M001', 'M002']);
|
|
43
|
-
assertEq(result, ['M003', 'M001', 'M002'], 'custom order produces exact sequence');
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
// Custom order with new IDs → appended at end in numeric order
|
|
47
|
-
{
|
|
48
|
-
const result = sortByQueueOrder(['M001', 'M002', 'M003', 'M004'], ['M003', 'M001']);
|
|
49
|
-
assertEq(result, ['M003', 'M001', 'M002', 'M004'], 'new IDs appended in numeric order');
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
// Custom order with deleted IDs → silently skipped
|
|
53
|
-
{
|
|
54
|
-
const result = sortByQueueOrder(['M001', 'M003'], ['M003', 'M002', 'M001']);
|
|
55
|
-
assertEq(result, ['M003', 'M001'], 'deleted IDs in order are skipped');
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
// Empty custom order → all IDs in numeric order
|
|
59
|
-
{
|
|
60
|
-
const result = sortByQueueOrder(['M002', 'M001'], []);
|
|
61
|
-
assertEq(result, ['M001', 'M002'], 'empty custom order falls back to numeric sort');
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
65
|
-
// loadQueueOrder / saveQueueOrder
|
|
66
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
67
|
-
|
|
68
|
-
console.log('\n=== loadQueueOrder / saveQueueOrder ===');
|
|
69
|
-
|
|
70
|
-
// Load returns null when file doesn't exist
|
|
71
|
-
{
|
|
72
|
-
const base = createFixtureBase();
|
|
73
|
-
assertEq(loadQueueOrder(base), null, 'returns null when file missing');
|
|
74
|
-
cleanup(base);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
// Save then load round-trip
|
|
78
|
-
{
|
|
79
|
-
const base = createFixtureBase();
|
|
80
|
-
saveQueueOrder(base, ['M003', 'M001', 'M002']);
|
|
81
|
-
const loaded = loadQueueOrder(base);
|
|
82
|
-
assertEq(loaded, ['M003', 'M001', 'M002'], 'round-trip preserves order');
|
|
83
|
-
|
|
84
|
-
// Verify file contains updatedAt
|
|
85
|
-
const raw = JSON.parse(readFileSync(join(base, '.gsd', 'QUEUE-ORDER.json'), 'utf-8'));
|
|
86
|
-
assertTrue(typeof raw.updatedAt === 'string' && raw.updatedAt.length > 0, 'file contains updatedAt');
|
|
87
|
-
|
|
88
|
-
cleanup(base);
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
// Load returns null on corrupt JSON
|
|
92
|
-
{
|
|
93
|
-
const base = createFixtureBase();
|
|
94
|
-
writeFileSync(join(base, '.gsd', 'QUEUE-ORDER.json'), 'not json');
|
|
95
|
-
assertEq(loadQueueOrder(base), null, 'returns null on corrupt JSON');
|
|
96
|
-
cleanup(base);
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
// Load returns null when order field is not an array
|
|
100
|
-
{
|
|
101
|
-
const base = createFixtureBase();
|
|
102
|
-
writeFileSync(join(base, '.gsd', 'QUEUE-ORDER.json'), '{"order": "invalid"}');
|
|
103
|
-
assertEq(loadQueueOrder(base), null, 'returns null when order is not array');
|
|
104
|
-
cleanup(base);
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
108
|
-
// pruneQueueOrder
|
|
109
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
110
|
-
|
|
111
|
-
console.log('\n=== pruneQueueOrder ===');
|
|
112
|
-
|
|
113
|
-
// Prune removes invalid IDs
|
|
114
|
-
{
|
|
115
|
-
const base = createFixtureBase();
|
|
116
|
-
saveQueueOrder(base, ['M001', 'M002', 'M003']);
|
|
117
|
-
pruneQueueOrder(base, ['M001', 'M003']);
|
|
118
|
-
assertEq(loadQueueOrder(base), ['M001', 'M003'], 'prune removes invalid IDs');
|
|
119
|
-
cleanup(base);
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
// Prune no-ops when file doesn't exist
|
|
123
|
-
{
|
|
124
|
-
const base = createFixtureBase();
|
|
125
|
-
pruneQueueOrder(base, ['M001']); // should not throw
|
|
126
|
-
assertTrue(!existsSync(join(base, '.gsd', 'QUEUE-ORDER.json')), 'prune does not create file');
|
|
127
|
-
cleanup(base);
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
// Prune no-ops when all IDs are valid
|
|
131
|
-
{
|
|
132
|
-
const base = createFixtureBase();
|
|
133
|
-
saveQueueOrder(base, ['M001', 'M002']);
|
|
134
|
-
pruneQueueOrder(base, ['M001', 'M002', 'M003']);
|
|
135
|
-
assertEq(loadQueueOrder(base), ['M001', 'M002'], 'prune is no-op when all valid');
|
|
136
|
-
cleanup(base);
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
140
|
-
// validateQueueOrder
|
|
141
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
142
|
-
|
|
143
|
-
console.log('\n=== validateQueueOrder ===');
|
|
144
|
-
|
|
145
|
-
// Valid order with no dependencies
|
|
146
|
-
{
|
|
147
|
-
const depsMap = new Map<string, string[]>();
|
|
148
|
-
const result = validateQueueOrder(['M001', 'M002'], depsMap, new Set());
|
|
149
|
-
assertTrue(result.valid, 'valid when no dependencies');
|
|
150
|
-
assertEq(result.violations.length, 0, 'no violations');
|
|
151
|
-
assertEq(result.redundant.length, 0, 'no redundancies');
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
// Dependency violation: M002 before M001, but M002 depends on M001
|
|
155
|
-
{
|
|
156
|
-
const depsMap = new Map<string, string[]>([['M002', ['M001']]]);
|
|
157
|
-
const result = validateQueueOrder(['M002', 'M001'], depsMap, new Set());
|
|
158
|
-
assertTrue(!result.valid, 'invalid when dep violated');
|
|
159
|
-
assertEq(result.violations.length, 1, 'one violation');
|
|
160
|
-
assertEq(result.violations[0].type, 'would_block', 'violation type is would_block');
|
|
161
|
-
assertEq(result.violations[0].milestone, 'M002', 'violation milestone is M002');
|
|
162
|
-
assertEq(result.violations[0].dependsOn, 'M001', 'violation dep is M001');
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
// Redundant dependency: M002 depends on M001, M001 comes first in order
|
|
166
|
-
{
|
|
167
|
-
const depsMap = new Map<string, string[]>([['M002', ['M001']]]);
|
|
168
|
-
const result = validateQueueOrder(['M001', 'M002'], depsMap, new Set());
|
|
169
|
-
assertTrue(result.valid, 'valid when dep satisfied by position');
|
|
170
|
-
assertEq(result.redundant.length, 1, 'one redundancy');
|
|
171
|
-
assertEq(result.redundant[0].milestone, 'M002', 'redundant milestone is M002');
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
// Completed dep is always satisfied
|
|
175
|
-
{
|
|
176
|
-
const depsMap = new Map<string, string[]>([['M002', ['M001']]]);
|
|
177
|
-
const result = validateQueueOrder(['M002'], depsMap, new Set(['M001']));
|
|
178
|
-
assertTrue(result.valid, 'valid when dep is already completed');
|
|
179
|
-
assertEq(result.violations.length, 0, 'no violations for completed dep');
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
// Missing dependency
|
|
183
|
-
{
|
|
184
|
-
const depsMap = new Map<string, string[]>([['M002', ['M099']]]);
|
|
185
|
-
const result = validateQueueOrder(['M001', 'M002'], depsMap, new Set());
|
|
186
|
-
assertTrue(!result.valid, 'invalid when dep does not exist');
|
|
187
|
-
assertEq(result.violations[0].type, 'missing_dep', 'violation type is missing_dep');
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
// Circular dependency
|
|
191
|
-
{
|
|
192
|
-
const depsMap = new Map<string, string[]>([
|
|
193
|
-
['M001', ['M002']],
|
|
194
|
-
['M002', ['M001']],
|
|
195
|
-
]);
|
|
196
|
-
const result = validateQueueOrder(['M001', 'M002'], depsMap, new Set());
|
|
197
|
-
assertTrue(!result.valid, 'invalid on circular dependency');
|
|
198
|
-
const circularViolation = result.violations.find(v => v.type === 'circular');
|
|
199
|
-
assertTrue(!!circularViolation, 'circular violation detected');
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
203
|
-
|
|
204
|
-
report();
|