specforge-mcp 0.11.0 → 0.12.0
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/engine/agent-generator.test.d.ts +2 -0
- package/dist/engine/agent-generator.test.d.ts.map +1 -0
- package/dist/engine/agent-generator.test.js +556 -0
- package/dist/engine/agent-generator.test.js.map +1 -0
- package/dist/engine/analyzer.test.d.ts +2 -0
- package/dist/engine/analyzer.test.d.ts.map +1 -0
- package/dist/engine/analyzer.test.js +1461 -0
- package/dist/engine/analyzer.test.js.map +1 -0
- package/dist/engine/auditor.test.d.ts +2 -0
- package/dist/engine/auditor.test.d.ts.map +1 -0
- package/dist/engine/auditor.test.js +2075 -0
- package/dist/engine/auditor.test.js.map +1 -0
- package/dist/engine/context-budget/checkpoint.d.ts +8 -0
- package/dist/engine/context-budget/checkpoint.d.ts.map +1 -0
- package/dist/engine/context-budget/checkpoint.js +79 -0
- package/dist/engine/context-budget/checkpoint.js.map +1 -0
- package/dist/engine/context-budget/compressor.d.ts +20 -0
- package/dist/engine/context-budget/compressor.d.ts.map +1 -0
- package/dist/engine/context-budget/compressor.js +122 -0
- package/dist/engine/context-budget/compressor.js.map +1 -0
- package/dist/engine/context-budget/index.d.ts +5 -0
- package/dist/engine/context-budget/index.d.ts.map +1 -0
- package/dist/engine/context-budget/index.js +6 -0
- package/dist/engine/context-budget/index.js.map +1 -0
- package/dist/engine/context-budget/optimizer.d.ts +8 -0
- package/dist/engine/context-budget/optimizer.d.ts.map +1 -0
- package/dist/engine/context-budget/optimizer.js +87 -0
- package/dist/engine/context-budget/optimizer.js.map +1 -0
- package/dist/engine/context-budget/tracker.d.ts +19 -0
- package/dist/engine/context-budget/tracker.d.ts.map +1 -0
- package/dist/engine/context-budget/tracker.js +113 -0
- package/dist/engine/context-budget/tracker.js.map +1 -0
- package/dist/engine/doc-generator.test.d.ts +2 -0
- package/dist/engine/doc-generator.test.d.ts.map +1 -0
- package/dist/engine/doc-generator.test.js +961 -0
- package/dist/engine/doc-generator.test.js.map +1 -0
- package/dist/engine/estimator.test.d.ts +2 -0
- package/dist/engine/estimator.test.d.ts.map +1 -0
- package/dist/engine/estimator.test.js +334 -0
- package/dist/engine/estimator.test.js.map +1 -0
- package/dist/engine/skill-generator.test.d.ts +2 -0
- package/dist/engine/skill-generator.test.d.ts.map +1 -0
- package/dist/engine/skill-generator.test.js +742 -0
- package/dist/engine/skill-generator.test.js.map +1 -0
- package/dist/engine/test-spec-generator/criterion-parser.d.ts +6 -0
- package/dist/engine/test-spec-generator/criterion-parser.d.ts.map +1 -0
- package/dist/engine/test-spec-generator/criterion-parser.js +96 -0
- package/dist/engine/test-spec-generator/criterion-parser.js.map +1 -0
- package/dist/engine/{test-spec-generator.d.ts → test-spec-generator/index.d.ts} +5 -2
- package/dist/engine/test-spec-generator/index.d.ts.map +1 -0
- package/dist/engine/test-spec-generator/index.js +29 -0
- package/dist/engine/test-spec-generator/index.js.map +1 -0
- package/dist/engine/test-spec-generator/labels.d.ts +5 -0
- package/dist/engine/test-spec-generator/labels.d.ts.map +1 -0
- package/dist/engine/test-spec-generator/labels.js +62 -0
- package/dist/engine/test-spec-generator/labels.js.map +1 -0
- package/dist/engine/test-spec-generator/scenario-builders.d.ts +3 -0
- package/dist/engine/test-spec-generator/scenario-builders.d.ts.map +1 -0
- package/dist/engine/test-spec-generator/scenario-builders.js +184 -0
- package/dist/engine/test-spec-generator/scenario-builders.js.map +1 -0
- package/dist/engine/validator.test.d.ts +2 -0
- package/dist/engine/validator.test.d.ts.map +1 -0
- package/dist/engine/validator.test.js +2371 -0
- package/dist/engine/validator.test.js.map +1 -0
- package/dist/engine/web-fetcher.test.d.ts +2 -0
- package/dist/engine/web-fetcher.test.d.ts.map +1 -0
- package/dist/engine/web-fetcher.test.js +360 -0
- package/dist/engine/web-fetcher.test.js.map +1 -0
- package/dist/i18n/index.test.d.ts +2 -0
- package/dist/i18n/index.test.d.ts.map +1 -0
- package/dist/i18n/index.test.js +375 -0
- package/dist/i18n/index.test.js.map +1 -0
- package/dist/index.js +0 -0
- package/dist/index.test.d.ts +2 -0
- package/dist/index.test.d.ts.map +1 -0
- package/dist/index.test.js +124 -0
- package/dist/index.test.js.map +1 -0
- package/dist/resources/patterns.test.d.ts +2 -0
- package/dist/resources/patterns.test.d.ts.map +1 -0
- package/dist/resources/patterns.test.js +142 -0
- package/dist/resources/patterns.test.js.map +1 -0
- package/dist/resources/process.test.d.ts +2 -0
- package/dist/resources/process.test.d.ts.map +1 -0
- package/dist/resources/process.test.js +48 -0
- package/dist/resources/process.test.js.map +1 -0
- package/dist/resources/registry.test.d.ts +2 -0
- package/dist/resources/registry.test.d.ts.map +1 -0
- package/dist/resources/registry.test.js +138 -0
- package/dist/resources/registry.test.js.map +1 -0
- package/dist/resources/specs.test.d.ts +2 -0
- package/dist/resources/specs.test.d.ts.map +1 -0
- package/dist/resources/specs.test.js +130 -0
- package/dist/resources/specs.test.js.map +1 -0
- package/dist/resources/templates.test.d.ts +2 -0
- package/dist/resources/templates.test.d.ts.map +1 -0
- package/dist/resources/templates.test.js +119 -0
- package/dist/resources/templates.test.js.map +1 -0
- package/dist/smoke.test.d.ts +2 -0
- package/dist/smoke.test.d.ts.map +1 -0
- package/dist/smoke.test.js +229 -0
- package/dist/smoke.test.js.map +1 -0
- package/dist/storage/base-store.test.d.ts +2 -0
- package/dist/storage/base-store.test.d.ts.map +1 -0
- package/dist/storage/base-store.test.js +180 -0
- package/dist/storage/base-store.test.js.map +1 -0
- package/dist/storage/checkpoint-store.d.ts +12 -0
- package/dist/storage/checkpoint-store.d.ts.map +1 -0
- package/dist/storage/checkpoint-store.js +85 -0
- package/dist/storage/checkpoint-store.js.map +1 -0
- package/dist/storage/global-store.test.d.ts +2 -0
- package/dist/storage/global-store.test.d.ts.map +1 -0
- package/dist/storage/global-store.test.js +327 -0
- package/dist/storage/global-store.test.js.map +1 -0
- package/dist/storage/index.test.d.ts +2 -0
- package/dist/storage/index.test.d.ts.map +1 -0
- package/dist/storage/index.test.js +56 -0
- package/dist/storage/index.test.js.map +1 -0
- package/dist/storage/knowledge-store.test.d.ts +2 -0
- package/dist/storage/knowledge-store.test.d.ts.map +1 -0
- package/dist/storage/knowledge-store.test.js +368 -0
- package/dist/storage/knowledge-store.test.js.map +1 -0
- package/dist/storage/metrics-store.test.d.ts +2 -0
- package/dist/storage/metrics-store.test.d.ts.map +1 -0
- package/dist/storage/metrics-store.test.js +212 -0
- package/dist/storage/metrics-store.test.js.map +1 -0
- package/dist/storage/pattern-store.test.d.ts +2 -0
- package/dist/storage/pattern-store.test.d.ts.map +1 -0
- package/dist/storage/pattern-store.test.js +224 -0
- package/dist/storage/pattern-store.test.js.map +1 -0
- package/dist/storage/spec-store.test.d.ts +2 -0
- package/dist/storage/spec-store.test.d.ts.map +1 -0
- package/dist/storage/spec-store.test.js +227 -0
- package/dist/storage/spec-store.test.js.map +1 -0
- package/dist/tools/audit.test.d.ts +2 -0
- package/dist/tools/audit.test.d.ts.map +1 -0
- package/dist/tools/audit.test.js +169 -0
- package/dist/tools/audit.test.js.map +1 -0
- package/dist/tools/challenge-spec.test.d.ts +2 -0
- package/dist/tools/challenge-spec.test.d.ts.map +1 -0
- package/dist/tools/challenge-spec.test.js +782 -0
- package/dist/tools/challenge-spec.test.js.map +1 -0
- package/dist/tools/check-versions.test.d.ts +2 -0
- package/dist/tools/check-versions.test.d.ts.map +1 -0
- package/dist/tools/check-versions.test.js +214 -0
- package/dist/tools/check-versions.test.js.map +1 -0
- package/dist/tools/clarify-requirements.test.d.ts +2 -0
- package/dist/tools/clarify-requirements.test.d.ts.map +1 -0
- package/dist/tools/clarify-requirements.test.js +161 -0
- package/dist/tools/clarify-requirements.test.js.map +1 -0
- package/dist/tools/consult-docs.test.d.ts +2 -0
- package/dist/tools/consult-docs.test.d.ts.map +1 -0
- package/dist/tools/consult-docs.test.js +140 -0
- package/dist/tools/consult-docs.test.js.map +1 -0
- package/dist/tools/context-budget.d.ts +3 -0
- package/dist/tools/context-budget.d.ts.map +1 -0
- package/dist/tools/context-budget.js +131 -0
- package/dist/tools/context-budget.js.map +1 -0
- package/dist/tools/create-spec.test.d.ts +2 -0
- package/dist/tools/create-spec.test.d.ts.map +1 -0
- package/dist/tools/create-spec.test.js +233 -0
- package/dist/tools/create-spec.test.js.map +1 -0
- package/dist/tools/define-ui-contract.test.d.ts +2 -0
- package/dist/tools/define-ui-contract.test.d.ts.map +1 -0
- package/dist/tools/define-ui-contract.test.js +479 -0
- package/dist/tools/define-ui-contract.test.js.map +1 -0
- package/dist/tools/design-schema.test.d.ts +2 -0
- package/dist/tools/design-schema.test.d.ts.map +1 -0
- package/dist/tools/design-schema.test.js +301 -0
- package/dist/tools/design-schema.test.js.map +1 -0
- package/dist/tools/detect-agent.test.d.ts +2 -0
- package/dist/tools/detect-agent.test.d.ts.map +1 -0
- package/dist/tools/detect-agent.test.js +133 -0
- package/dist/tools/detect-agent.test.js.map +1 -0
- package/dist/tools/detect-drift.test.d.ts +2 -0
- package/dist/tools/detect-drift.test.d.ts.map +1 -0
- package/dist/tools/detect-drift.test.js +312 -0
- package/dist/tools/detect-drift.test.js.map +1 -0
- package/dist/tools/discover-mcps.test.d.ts +2 -0
- package/dist/tools/discover-mcps.test.d.ts.map +1 -0
- package/dist/tools/discover-mcps.test.js +345 -0
- package/dist/tools/discover-mcps.test.js.map +1 -0
- package/dist/tools/estimate.test.d.ts +2 -0
- package/dist/tools/estimate.test.d.ts.map +1 -0
- package/dist/tools/estimate.test.js +137 -0
- package/dist/tools/estimate.test.js.map +1 -0
- package/dist/tools/generate-adr.test.d.ts +2 -0
- package/dist/tools/generate-adr.test.d.ts.map +1 -0
- package/dist/tools/generate-adr.test.js +206 -0
- package/dist/tools/generate-adr.test.js.map +1 -0
- package/dist/tools/generate-checklist.test.d.ts +2 -0
- package/dist/tools/generate-checklist.test.d.ts.map +1 -0
- package/dist/tools/generate-checklist.test.js +201 -0
- package/dist/tools/generate-checklist.test.js.map +1 -0
- package/dist/tools/generate-docs.test.d.ts +2 -0
- package/dist/tools/generate-docs.test.d.ts.map +1 -0
- package/dist/tools/generate-docs.test.js +183 -0
- package/dist/tools/generate-docs.test.js.map +1 -0
- package/dist/tools/generate-execution-plan.test.d.ts +2 -0
- package/dist/tools/generate-execution-plan.test.d.ts.map +1 -0
- package/dist/tools/generate-execution-plan.test.js +643 -0
- package/dist/tools/generate-execution-plan.test.js.map +1 -0
- package/dist/tools/generate-rules.test.d.ts +2 -0
- package/dist/tools/generate-rules.test.d.ts.map +1 -0
- package/dist/tools/generate-rules.test.js +148 -0
- package/dist/tools/generate-rules.test.js.map +1 -0
- package/dist/tools/generate-skill.test.d.ts +2 -0
- package/dist/tools/generate-skill.test.d.ts.map +1 -0
- package/dist/tools/generate-skill.test.js +138 -0
- package/dist/tools/generate-skill.test.js.map +1 -0
- package/dist/tools/generate-sub-agent.test.d.ts +2 -0
- package/dist/tools/generate-sub-agent.test.d.ts.map +1 -0
- package/dist/tools/generate-sub-agent.test.js +162 -0
- package/dist/tools/generate-sub-agent.test.js.map +1 -0
- package/dist/tools/generate-tests/dispatchers/ai-ml-dispatcher.d.ts +3 -0
- package/dist/tools/generate-tests/dispatchers/ai-ml-dispatcher.d.ts.map +1 -0
- package/dist/tools/generate-tests/dispatchers/ai-ml-dispatcher.js +33 -0
- package/dist/tools/generate-tests/dispatchers/ai-ml-dispatcher.js.map +1 -0
- package/dist/tools/generate-tests/dispatchers/database-security-dispatcher.d.ts +5 -0
- package/dist/tools/generate-tests/dispatchers/database-security-dispatcher.d.ts.map +1 -0
- package/dist/tools/generate-tests/dispatchers/database-security-dispatcher.js +25 -0
- package/dist/tools/generate-tests/dispatchers/database-security-dispatcher.js.map +1 -0
- package/dist/tools/generate-tests/dispatchers/distributed-dispatcher.d.ts +3 -0
- package/dist/tools/generate-tests/dispatchers/distributed-dispatcher.d.ts.map +1 -0
- package/dist/tools/generate-tests/dispatchers/distributed-dispatcher.js +29 -0
- package/dist/tools/generate-tests/dispatchers/distributed-dispatcher.js.map +1 -0
- package/dist/tools/generate-tests/dispatchers/frontend-dispatcher.d.ts +3 -0
- package/dist/tools/generate-tests/dispatchers/frontend-dispatcher.d.ts.map +1 -0
- package/dist/tools/generate-tests/dispatchers/frontend-dispatcher.js +34 -0
- package/dist/tools/generate-tests/dispatchers/frontend-dispatcher.js.map +1 -0
- package/dist/tools/generate-tests/dispatchers/infra-dispatcher.d.ts +3 -0
- package/dist/tools/generate-tests/dispatchers/infra-dispatcher.d.ts.map +1 -0
- package/dist/tools/generate-tests/dispatchers/infra-dispatcher.js +37 -0
- package/dist/tools/generate-tests/dispatchers/infra-dispatcher.js.map +1 -0
- package/dist/tools/generate-tests/dispatchers/protocols-dispatcher.d.ts +3 -0
- package/dist/tools/generate-tests/dispatchers/protocols-dispatcher.d.ts.map +1 -0
- package/dist/tools/generate-tests/dispatchers/protocols-dispatcher.js +27 -0
- package/dist/tools/generate-tests/dispatchers/protocols-dispatcher.js.map +1 -0
- package/dist/tools/generate-tests/generators/database/detectors.d.ts +6 -0
- package/dist/tools/generate-tests/generators/database/detectors.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/database/detectors.js +36 -0
- package/dist/tools/generate-tests/generators/database/detectors.js.map +1 -0
- package/dist/tools/generate-tests/generators/database/index.d.ts +8 -0
- package/dist/tools/generate-tests/generators/database/index.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/database/index.js +29 -0
- package/dist/tools/generate-tests/generators/database/index.js.map +1 -0
- package/dist/tools/generate-tests/generators/database/python-scaffold.d.ts +2 -0
- package/dist/tools/generate-tests/generators/database/python-scaffold.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/database/python-scaffold.js +104 -0
- package/dist/tools/generate-tests/generators/database/python-scaffold.js.map +1 -0
- package/dist/tools/generate-tests/generators/database/test-defs.d.ts +3 -0
- package/dist/tools/generate-tests/generators/database/test-defs.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/database/test-defs.js +57 -0
- package/dist/tools/generate-tests/generators/database/test-defs.js.map +1 -0
- package/dist/tools/generate-tests/generators/database/ts-scaffold.d.ts +2 -0
- package/dist/tools/generate-tests/generators/database/ts-scaffold.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/database/ts-scaffold.js +118 -0
- package/dist/tools/generate-tests/generators/database/ts-scaffold.js.map +1 -0
- package/dist/tools/generate-tests/generators/microservices/detectors.d.ts +5 -0
- package/dist/tools/generate-tests/generators/microservices/detectors.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/microservices/detectors.js +47 -0
- package/dist/tools/generate-tests/generators/microservices/detectors.js.map +1 -0
- package/dist/tools/generate-tests/generators/microservices/index.d.ts +8 -0
- package/dist/tools/generate-tests/generators/microservices/index.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/microservices/index.js +26 -0
- package/dist/tools/generate-tests/generators/microservices/index.js.map +1 -0
- package/dist/tools/generate-tests/generators/microservices/python-scaffold.d.ts +2 -0
- package/dist/tools/generate-tests/generators/microservices/python-scaffold.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/microservices/python-scaffold.js +98 -0
- package/dist/tools/generate-tests/generators/microservices/python-scaffold.js.map +1 -0
- package/dist/tools/generate-tests/generators/microservices/test-defs.d.ts +3 -0
- package/dist/tools/generate-tests/generators/microservices/test-defs.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/microservices/test-defs.js +61 -0
- package/dist/tools/generate-tests/generators/microservices/test-defs.js.map +1 -0
- package/dist/tools/generate-tests/generators/microservices/ts-scaffold.d.ts +2 -0
- package/dist/tools/generate-tests/generators/microservices/ts-scaffold.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/microservices/ts-scaffold.js +123 -0
- package/dist/tools/generate-tests/generators/microservices/ts-scaffold.js.map +1 -0
- package/dist/tools/generate-tests/generators/security/detectors.d.ts +8 -0
- package/dist/tools/generate-tests/generators/security/detectors.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/security/detectors.js +61 -0
- package/dist/tools/generate-tests/generators/security/detectors.js.map +1 -0
- package/dist/tools/generate-tests/generators/security/index.d.ts +8 -0
- package/dist/tools/generate-tests/generators/security/index.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/security/index.js +28 -0
- package/dist/tools/generate-tests/generators/security/index.js.map +1 -0
- package/dist/tools/generate-tests/generators/security/python-scaffold.d.ts +2 -0
- package/dist/tools/generate-tests/generators/security/python-scaffold.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/security/python-scaffold.js +89 -0
- package/dist/tools/generate-tests/generators/security/python-scaffold.js.map +1 -0
- package/dist/tools/generate-tests/generators/security/test-defs.d.ts +3 -0
- package/dist/tools/generate-tests/generators/security/test-defs.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/security/test-defs.js +48 -0
- package/dist/tools/generate-tests/generators/security/test-defs.js.map +1 -0
- package/dist/tools/generate-tests/generators/security/ts-scaffold.d.ts +2 -0
- package/dist/tools/generate-tests/generators/security/ts-scaffold.d.ts.map +1 -0
- package/dist/tools/generate-tests/generators/security/ts-scaffold.js +107 -0
- package/dist/tools/generate-tests/generators/security/ts-scaffold.js.map +1 -0
- package/dist/tools/generate-tests/spec-dispatcher.d.ts.map +1 -1
- package/dist/tools/generate-tests/spec-dispatcher.js +14 -166
- package/dist/tools/generate-tests/spec-dispatcher.js.map +1 -1
- package/dist/tools/generate-tests.test.d.ts +2 -0
- package/dist/tools/generate-tests.test.d.ts.map +1 -0
- package/dist/tools/generate-tests.test.js +222 -0
- package/dist/tools/generate-tests.test.js.map +1 -0
- package/dist/tools/init-constitution.test.d.ts +2 -0
- package/dist/tools/init-constitution.test.d.ts.map +1 -0
- package/dist/tools/init-constitution.test.js +398 -0
- package/dist/tools/init-constitution.test.js.map +1 -0
- package/dist/tools/init-project.test.d.ts +2 -0
- package/dist/tools/init-project.test.d.ts.map +1 -0
- package/dist/tools/init-project.test.js +158 -0
- package/dist/tools/init-project.test.js.map +1 -0
- package/dist/tools/integrate-pm.test.d.ts +2 -0
- package/dist/tools/integrate-pm.test.d.ts.map +1 -0
- package/dist/tools/integrate-pm.test.js +558 -0
- package/dist/tools/integrate-pm.test.js.map +1 -0
- package/dist/tools/learn.test.d.ts +2 -0
- package/dist/tools/learn.test.d.ts.map +1 -0
- package/dist/tools/learn.test.js +123 -0
- package/dist/tools/learn.test.js.map +1 -0
- package/dist/tools/list-specs.test.d.ts +2 -0
- package/dist/tools/list-specs.test.d.ts.map +1 -0
- package/dist/tools/list-specs.test.js +110 -0
- package/dist/tools/list-specs.test.js.map +1 -0
- package/dist/tools/manage-context.test.d.ts +2 -0
- package/dist/tools/manage-context.test.d.ts.map +1 -0
- package/dist/tools/manage-context.test.js +359 -0
- package/dist/tools/manage-context.test.js.map +1 -0
- package/dist/tools/manage-git.test.d.ts +2 -0
- package/dist/tools/manage-git.test.d.ts.map +1 -0
- package/dist/tools/manage-git.test.js +882 -0
- package/dist/tools/manage-git.test.js.map +1 -0
- package/dist/tools/orchestrate.test.d.ts +2 -0
- package/dist/tools/orchestrate.test.d.ts.map +1 -0
- package/dist/tools/orchestrate.test.js +1117 -0
- package/dist/tools/orchestrate.test.js.map +1 -0
- package/dist/tools/reconcile-spec.test.d.ts +2 -0
- package/dist/tools/reconcile-spec.test.d.ts.map +1 -0
- package/dist/tools/reconcile-spec.test.js +259 -0
- package/dist/tools/reconcile-spec.test.js.map +1 -0
- package/dist/tools/register-platform-tools/lifecycle-infra-tools.d.ts.map +1 -1
- package/dist/tools/register-platform-tools/lifecycle-infra-tools.js +37 -1
- package/dist/tools/register-platform-tools/lifecycle-infra-tools.js.map +1 -1
- package/dist/tools/register-platform-tools.test.d.ts +2 -0
- package/dist/tools/register-platform-tools.test.d.ts.map +1 -0
- package/dist/tools/register-platform-tools.test.js +404 -0
- package/dist/tools/register-platform-tools.test.js.map +1 -0
- package/dist/tools/register-spec-tools/analysis-tools.d.ts.map +1 -1
- package/dist/tools/register-spec-tools/analysis-tools.js +1 -0
- package/dist/tools/register-spec-tools/analysis-tools.js.map +1 -1
- package/dist/tools/register-spec-tools.test.d.ts +2 -0
- package/dist/tools/register-spec-tools.test.d.ts.map +1 -0
- package/dist/tools/register-spec-tools.test.js +407 -0
- package/dist/tools/register-spec-tools.test.js.map +1 -0
- package/dist/tools/reverse-engineer.test.d.ts +2 -0
- package/dist/tools/reverse-engineer.test.d.ts.map +1 -0
- package/dist/tools/reverse-engineer.test.js +206 -0
- package/dist/tools/reverse-engineer.test.js.map +1 -0
- package/dist/tools/schemas/index.d.ts +1 -1
- package/dist/tools/schemas/index.d.ts.map +1 -1
- package/dist/tools/schemas/index.js +1 -1
- package/dist/tools/schemas/index.js.map +1 -1
- package/dist/tools/schemas/infra.d.ts +8 -0
- package/dist/tools/schemas/infra.d.ts.map +1 -1
- package/dist/tools/schemas/infra.js +3 -0
- package/dist/tools/schemas/infra.js.map +1 -1
- package/dist/tools/schemas.d.ts +20 -0
- package/dist/tools/schemas.d.ts.map +1 -0
- package/dist/tools/schemas.js +133 -0
- package/dist/tools/schemas.js.map +1 -0
- package/dist/tools/schemas.test.d.ts +2 -0
- package/dist/tools/schemas.test.d.ts.map +1 -0
- package/dist/tools/schemas.test.js +245 -0
- package/dist/tools/schemas.test.js.map +1 -0
- package/dist/tools/set-locale.test.d.ts +2 -0
- package/dist/tools/set-locale.test.d.ts.map +1 -0
- package/dist/tools/set-locale.test.js +74 -0
- package/dist/tools/set-locale.test.js.map +1 -0
- package/dist/tools/suggest-mcps.test.d.ts +2 -0
- package/dist/tools/suggest-mcps.test.d.ts.map +1 -0
- package/dist/tools/suggest-mcps.test.js +198 -0
- package/dist/tools/suggest-mcps.test.js.map +1 -0
- package/dist/tools/suggest-stack.test.d.ts +2 -0
- package/dist/tools/suggest-stack.test.d.ts.map +1 -0
- package/dist/tools/suggest-stack.test.js +181 -0
- package/dist/tools/suggest-stack.test.js.map +1 -0
- package/dist/tools/suggest-tooling.test.d.ts +2 -0
- package/dist/tools/suggest-tooling.test.d.ts.map +1 -0
- package/dist/tools/suggest-tooling.test.js +213 -0
- package/dist/tools/suggest-tooling.test.js.map +1 -0
- package/dist/tools/summarize-spec.test.d.ts +2 -0
- package/dist/tools/summarize-spec.test.d.ts.map +1 -0
- package/dist/tools/summarize-spec.test.js +180 -0
- package/dist/tools/summarize-spec.test.js.map +1 -0
- package/dist/tools/update-status.test.d.ts +2 -0
- package/dist/tools/update-status.test.d.ts.map +1 -0
- package/dist/tools/update-status.test.js +142 -0
- package/dist/tools/update-status.test.js.map +1 -0
- package/dist/tools/validate.test.d.ts +2 -0
- package/dist/tools/validate.test.d.ts.map +1 -0
- package/dist/tools/validate.test.js +137 -0
- package/dist/tools/validate.test.js.map +1 -0
- package/dist/types/context-budget.d.ts +90 -0
- package/dist/types/context-budget.d.ts.map +1 -0
- package/dist/types/context-budget.js +3 -0
- package/dist/types/context-budget.js.map +1 -0
- package/dist/types/index.d.ts +1 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/testing.d.ts +10 -0
- package/dist/types/testing.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/i18n/messages/en.json +8 -2
- package/src/i18n/messages/es.json +8 -2
- package/src/i18n/messages/pt.json +6 -0
- package/dist/engine/test-spec-generator.d.ts.map +0 -1
- package/dist/engine/test-spec-generator.js +0 -348
- package/dist/engine/test-spec-generator.js.map +0 -1
- package/dist/tools/generate-tests/generators/database-test-generator.d.ts +0 -11
- package/dist/tools/generate-tests/generators/database-test-generator.d.ts.map +0 -1
- package/dist/tools/generate-tests/generators/database-test-generator.js +0 -329
- package/dist/tools/generate-tests/generators/database-test-generator.js.map +0 -1
- package/dist/tools/generate-tests/generators/microservices-test-generator.d.ts +0 -10
- package/dist/tools/generate-tests/generators/microservices-test-generator.d.ts.map +0 -1
- package/dist/tools/generate-tests/generators/microservices-test-generator.js +0 -341
- package/dist/tools/generate-tests/generators/microservices-test-generator.js.map +0 -1
- package/dist/tools/generate-tests/generators/security-test-generator.d.ts +0 -11
- package/dist/tools/generate-tests/generators/security-test-generator.d.ts.map +0 -1
- package/dist/tools/generate-tests/generators/security-test-generator.js +0 -318
- package/dist/tools/generate-tests/generators/security-test-generator.js.map +0 -1
|
@@ -1,329 +0,0 @@
|
|
|
1
|
-
// tools/generate-tests/generators/database-test-generator.ts — SPEC-058b Section F
|
|
2
|
-
// Generates database & data layer test scaffolds:
|
|
3
|
-
// migrations, repository/DAO CRUD, caching, full-text search.
|
|
4
|
-
const CACHE_SIGNALS = ['redis', 'memcached', 'node-cache', 'caffeine', 'ehcache', 'valkey'];
|
|
5
|
-
const SEARCH_SIGNALS = [
|
|
6
|
-
'elasticsearch',
|
|
7
|
-
'meilisearch',
|
|
8
|
-
'algolia',
|
|
9
|
-
'opensearch',
|
|
10
|
-
'solr',
|
|
11
|
-
'typesense',
|
|
12
|
-
];
|
|
13
|
-
export function detectCaching(knowledge) {
|
|
14
|
-
const stackLower = knowledge.stack.map((s) => s.toLowerCase());
|
|
15
|
-
for (const sig of CACHE_SIGNALS) {
|
|
16
|
-
if (stackLower.some((s) => s.includes(sig))) {
|
|
17
|
-
return sig;
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
return null;
|
|
21
|
-
}
|
|
22
|
-
export function detectSearchEngine(knowledge) {
|
|
23
|
-
const stackLower = knowledge.stack.map((s) => s.toLowerCase());
|
|
24
|
-
for (const sig of SEARCH_SIGNALS) {
|
|
25
|
-
if (stackLower.some((s) => s.includes(sig))) {
|
|
26
|
-
return sig;
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
return null;
|
|
30
|
-
}
|
|
31
|
-
export function hasOrm(knowledge) {
|
|
32
|
-
return knowledge.orm !== null && knowledge.orm !== 'unknown';
|
|
33
|
-
}
|
|
34
|
-
export function isDatabaseTestProject(knowledge) {
|
|
35
|
-
return knowledge.database !== 'unknown';
|
|
36
|
-
}
|
|
37
|
-
export function generateDatabaseTestDefs(title, testDir, _testExt, knowledge) {
|
|
38
|
-
const defs = [
|
|
39
|
-
{
|
|
40
|
-
name: `${title} — migration: schema up/down and rollback safety`,
|
|
41
|
-
type: 'integration',
|
|
42
|
-
file: `${testDir}/database/`,
|
|
43
|
-
description: 'Verify schema migrations run up/down cleanly and preserve data integrity',
|
|
44
|
-
priority: 'critical',
|
|
45
|
-
automatable: true,
|
|
46
|
-
},
|
|
47
|
-
{
|
|
48
|
-
name: `${title} — repository: CRUD operations on ${knowledge.database}`,
|
|
49
|
-
type: 'integration',
|
|
50
|
-
file: `${testDir}/database/`,
|
|
51
|
-
description: 'Verify create, read, update, delete operations on the data layer',
|
|
52
|
-
priority: 'high',
|
|
53
|
-
automatable: true,
|
|
54
|
-
},
|
|
55
|
-
];
|
|
56
|
-
if (hasOrm(knowledge)) {
|
|
57
|
-
defs.push({
|
|
58
|
-
name: `${title} — transactions and optimistic locking`,
|
|
59
|
-
type: 'integration',
|
|
60
|
-
file: `${testDir}/database/`,
|
|
61
|
-
description: 'Verify transaction commit/rollback and optimistic locking conflict detection',
|
|
62
|
-
priority: 'high',
|
|
63
|
-
automatable: true,
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
const cache = detectCaching(knowledge);
|
|
67
|
-
if (cache !== null) {
|
|
68
|
-
defs.push({
|
|
69
|
-
name: `${title} — caching (${cache}): hit/miss, TTL, invalidation`,
|
|
70
|
-
type: 'integration',
|
|
71
|
-
file: `${testDir}/database/`,
|
|
72
|
-
description: 'Verify cache hit/miss behavior, TTL expiration, and invalidation patterns',
|
|
73
|
-
priority: 'high',
|
|
74
|
-
automatable: true,
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
const search = detectSearchEngine(knowledge);
|
|
78
|
-
if (search !== null) {
|
|
79
|
-
defs.push({
|
|
80
|
-
name: `${title} — full-text search (${search}): indexing and query relevance`,
|
|
81
|
-
type: 'integration',
|
|
82
|
-
file: `${testDir}/database/`,
|
|
83
|
-
description: 'Verify document indexing, query relevance ranking, and fuzzy matching',
|
|
84
|
-
priority: 'medium',
|
|
85
|
-
automatable: true,
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
|
-
return defs;
|
|
89
|
-
}
|
|
90
|
-
// ---------------------------------------------------------------------------
|
|
91
|
-
// Scaffold builders
|
|
92
|
-
// ---------------------------------------------------------------------------
|
|
93
|
-
function buildTsDatabaseTest(title, db, orm, cache, search) {
|
|
94
|
-
const cacheSection = cache
|
|
95
|
-
? `
|
|
96
|
-
describe('Caching (${cache})', () => {
|
|
97
|
-
it('returns cached value on cache hit', async () => {
|
|
98
|
-
// await cache.set('user:1', { name: 'Test' }, { ttl: 60 });
|
|
99
|
-
// const result = await cache.get('user:1');
|
|
100
|
-
// expect(result).toMatchObject({ name: 'Test' });
|
|
101
|
-
expect(true).toBe(true);
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
it('returns null on cache miss', async () => {
|
|
105
|
-
expect(true).toBe(true);
|
|
106
|
-
});
|
|
107
|
-
|
|
108
|
-
it('expires entry after TTL', async () => {
|
|
109
|
-
expect(true).toBe(true);
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
it('invalidates cache on data update', async () => {
|
|
113
|
-
expect(true).toBe(true);
|
|
114
|
-
});
|
|
115
|
-
});
|
|
116
|
-
`
|
|
117
|
-
: '';
|
|
118
|
-
const searchSection = search
|
|
119
|
-
? `
|
|
120
|
-
describe('Full-text search (${search})', () => {
|
|
121
|
-
it('indexes document and makes it searchable', async () => {
|
|
122
|
-
// await searchClient.index('products').addDocuments([{ id: 1, name: 'Widget' }]);
|
|
123
|
-
// const results = await searchClient.index('products').search('Widget');
|
|
124
|
-
// expect(results.hits).toHaveLength(1);
|
|
125
|
-
expect(true).toBe(true);
|
|
126
|
-
});
|
|
127
|
-
|
|
128
|
-
it('returns relevant results ranked by score', async () => {
|
|
129
|
-
expect(true).toBe(true);
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
it('supports fuzzy matching for typos', async () => {
|
|
133
|
-
expect(true).toBe(true);
|
|
134
|
-
});
|
|
135
|
-
});
|
|
136
|
-
`
|
|
137
|
-
: '';
|
|
138
|
-
const ormSection = orm
|
|
139
|
-
? `
|
|
140
|
-
describe('Transactions and locking', () => {
|
|
141
|
-
it('commits transaction on success', async () => {
|
|
142
|
-
expect(true).toBe(true);
|
|
143
|
-
});
|
|
144
|
-
|
|
145
|
-
it('rolls back transaction on error', async () => {
|
|
146
|
-
expect(true).toBe(true);
|
|
147
|
-
});
|
|
148
|
-
|
|
149
|
-
it('detects optimistic locking conflict', async () => {
|
|
150
|
-
// Concurrent update with stale version → should throw
|
|
151
|
-
expect(true).toBe(true);
|
|
152
|
-
});
|
|
153
|
-
});
|
|
154
|
-
`
|
|
155
|
-
: '';
|
|
156
|
-
return `// Database & Data Layer tests for: ${title}
|
|
157
|
-
// Generated by SpecForge SDD MCP Server (SPEC-058b)
|
|
158
|
-
import { describe, it, expect } from 'vitest';
|
|
159
|
-
|
|
160
|
-
describe('${title} — Database Tests (${db})', () => {
|
|
161
|
-
describe('Migrations', () => {
|
|
162
|
-
it('schema migration up applies cleanly', async () => {
|
|
163
|
-
// await migrate.up();
|
|
164
|
-
// const tables = await db.query("SELECT name FROM sqlite_master WHERE type='table'");
|
|
165
|
-
// expect(tables).toContainEqual({ name: 'users' });
|
|
166
|
-
expect(true).toBe(true); // Replace with real migration assertion
|
|
167
|
-
});
|
|
168
|
-
|
|
169
|
-
it('schema migration down reverts cleanly', async () => {
|
|
170
|
-
expect(true).toBe(true);
|
|
171
|
-
});
|
|
172
|
-
|
|
173
|
-
it('data integrity preserved after migration', async () => {
|
|
174
|
-
expect(true).toBe(true);
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
it('rollback does not lose existing data', async () => {
|
|
178
|
-
expect(true).toBe(true);
|
|
179
|
-
});
|
|
180
|
-
});
|
|
181
|
-
|
|
182
|
-
describe('Repository / DAO — CRUD', () => {
|
|
183
|
-
it('creates a record and returns its id', async () => {
|
|
184
|
-
// const user = await repo.create({ name: 'Test', email: 'test@example.com' });
|
|
185
|
-
// expect(user.id).toBeDefined();
|
|
186
|
-
expect(true).toBe(true);
|
|
187
|
-
});
|
|
188
|
-
|
|
189
|
-
it('reads a record by id', async () => {
|
|
190
|
-
expect(true).toBe(true);
|
|
191
|
-
});
|
|
192
|
-
|
|
193
|
-
it('updates a record', async () => {
|
|
194
|
-
expect(true).toBe(true);
|
|
195
|
-
});
|
|
196
|
-
|
|
197
|
-
it('deletes a record', async () => {
|
|
198
|
-
expect(true).toBe(true);
|
|
199
|
-
});
|
|
200
|
-
|
|
201
|
-
it('returns null for non-existent record', async () => {
|
|
202
|
-
expect(true).toBe(true);
|
|
203
|
-
});
|
|
204
|
-
});
|
|
205
|
-
${ormSection}${cacheSection}${searchSection}});
|
|
206
|
-
`;
|
|
207
|
-
}
|
|
208
|
-
function buildPythonDatabaseTest(title, db, orm, cache, search) {
|
|
209
|
-
const cls = title.replace(/[^a-zA-Z0-9]/g, '');
|
|
210
|
-
const ormSection = orm
|
|
211
|
-
? `
|
|
212
|
-
def test_transaction_commits_on_success(self) -> None:
|
|
213
|
-
"""Transaction commits all changes on success."""
|
|
214
|
-
pass
|
|
215
|
-
|
|
216
|
-
def test_transaction_rolls_back_on_error(self) -> None:
|
|
217
|
-
"""Transaction rolls back on exception."""
|
|
218
|
-
pass
|
|
219
|
-
|
|
220
|
-
def test_optimistic_locking_conflict(self) -> None:
|
|
221
|
-
"""Concurrent update with stale version raises conflict."""
|
|
222
|
-
pass
|
|
223
|
-
`
|
|
224
|
-
: '';
|
|
225
|
-
const cacheSection = cache
|
|
226
|
-
? `
|
|
227
|
-
def test_cache_hit_returns_value(self) -> None:
|
|
228
|
-
"""Cache returns stored value on hit."""
|
|
229
|
-
pass
|
|
230
|
-
|
|
231
|
-
def test_cache_miss_returns_none(self) -> None:
|
|
232
|
-
"""Cache returns None on miss."""
|
|
233
|
-
pass
|
|
234
|
-
|
|
235
|
-
def test_cache_ttl_expiration(self) -> None:
|
|
236
|
-
"""Cache entry expires after TTL."""
|
|
237
|
-
pass
|
|
238
|
-
|
|
239
|
-
def test_cache_invalidation_on_update(self) -> None:
|
|
240
|
-
"""Cache is invalidated when underlying data changes."""
|
|
241
|
-
pass
|
|
242
|
-
`
|
|
243
|
-
: '';
|
|
244
|
-
const searchSection = search
|
|
245
|
-
? `
|
|
246
|
-
def test_index_document_searchable(self) -> None:
|
|
247
|
-
"""Indexed document is returned by search query."""
|
|
248
|
-
pass
|
|
249
|
-
|
|
250
|
-
def test_query_relevance_ranking(self) -> None:
|
|
251
|
-
"""Results are ranked by relevance score."""
|
|
252
|
-
pass
|
|
253
|
-
|
|
254
|
-
def test_fuzzy_matching_for_typos(self) -> None:
|
|
255
|
-
"""Fuzzy search finds results despite typos."""
|
|
256
|
-
pass
|
|
257
|
-
`
|
|
258
|
-
: '';
|
|
259
|
-
return `"""Database & Data Layer tests for: ${title}
|
|
260
|
-
Generated by SpecForge SDD MCP Server (SPEC-058b).
|
|
261
|
-
Database: ${db}
|
|
262
|
-
"""
|
|
263
|
-
import pytest
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
class Test${cls}Database:
|
|
267
|
-
"""Database test suite for ${title} (${db})."""
|
|
268
|
-
|
|
269
|
-
def test_migration_up_applies_cleanly(self) -> None:
|
|
270
|
-
"""Schema migration up creates expected tables."""
|
|
271
|
-
# TODO: result = alembic.command.upgrade(config, 'head')
|
|
272
|
-
pass
|
|
273
|
-
|
|
274
|
-
def test_migration_down_reverts_cleanly(self) -> None:
|
|
275
|
-
"""Schema migration down removes tables cleanly."""
|
|
276
|
-
pass
|
|
277
|
-
|
|
278
|
-
def test_data_integrity_after_migration(self) -> None:
|
|
279
|
-
"""Existing data is preserved after migration."""
|
|
280
|
-
pass
|
|
281
|
-
|
|
282
|
-
def test_rollback_safety(self) -> None:
|
|
283
|
-
"""Rollback does not lose existing data."""
|
|
284
|
-
pass
|
|
285
|
-
|
|
286
|
-
def test_create_record(self) -> None:
|
|
287
|
-
"""Creates a record and returns its id."""
|
|
288
|
-
# TODO: user = repo.create(name='Test', email='test@example.com')
|
|
289
|
-
# assert user.id is not None
|
|
290
|
-
pass
|
|
291
|
-
|
|
292
|
-
def test_read_record_by_id(self) -> None:
|
|
293
|
-
"""Reads a record by primary key."""
|
|
294
|
-
pass
|
|
295
|
-
|
|
296
|
-
def test_update_record(self) -> None:
|
|
297
|
-
"""Updates a record field."""
|
|
298
|
-
pass
|
|
299
|
-
|
|
300
|
-
def test_delete_record(self) -> None:
|
|
301
|
-
"""Deletes a record."""
|
|
302
|
-
pass
|
|
303
|
-
|
|
304
|
-
def test_read_nonexistent_returns_none(self) -> None:
|
|
305
|
-
"""Reading a non-existent record returns None."""
|
|
306
|
-
pass
|
|
307
|
-
${ormSection}${cacheSection}${searchSection}`;
|
|
308
|
-
}
|
|
309
|
-
export function generateDatabaseTestFiles(spec, testDir, framework, language, testExt, autoGenerate, knowledge) {
|
|
310
|
-
const cache = detectCaching(knowledge);
|
|
311
|
-
const search = detectSearchEngine(knowledge);
|
|
312
|
-
const orm = hasOrm(knowledge);
|
|
313
|
-
const db = knowledge.database;
|
|
314
|
-
const isPython = language === 'python';
|
|
315
|
-
const ext = isPython ? 'py' : testExt;
|
|
316
|
-
const fw = isPython ? 'pytest' : framework;
|
|
317
|
-
const content = isPython
|
|
318
|
-
? buildPythonDatabaseTest(spec.title, db, orm, cache, search)
|
|
319
|
-
: buildTsDatabaseTest(spec.title, db, orm, cache, search);
|
|
320
|
-
return [
|
|
321
|
-
{
|
|
322
|
-
path: `${testDir}/database/${spec.slug}.database.test.${ext}`,
|
|
323
|
-
framework: fw,
|
|
324
|
-
content,
|
|
325
|
-
ready: autoGenerate,
|
|
326
|
-
},
|
|
327
|
-
];
|
|
328
|
-
}
|
|
329
|
-
//# sourceMappingURL=database-test-generator.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"database-test-generator.js","sourceRoot":"","sources":["../../../../src/tools/generate-tests/generators/database-test-generator.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import type { TestDefinition, TestFile, ProjectKnowledge } from '../../../types/index.js';
|
|
2
|
-
export declare function detectBroker(knowledge: ProjectKnowledge): string | null;
|
|
3
|
-
export declare function detectServiceMesh(knowledge: ProjectKnowledge): string | null;
|
|
4
|
-
export declare function isMicroservicesTestProject(knowledge: ProjectKnowledge): boolean;
|
|
5
|
-
export declare function generateMicroservicesTestDefs(title: string, testDir: string, _testExt: string, knowledge: ProjectKnowledge): TestDefinition[];
|
|
6
|
-
export declare function generateMicroservicesTestFiles(spec: {
|
|
7
|
-
title: string;
|
|
8
|
-
slug: string;
|
|
9
|
-
}, testDir: string, framework: string, language: string, testExt: string, autoGenerate: boolean, knowledge: ProjectKnowledge): TestFile[];
|
|
10
|
-
//# sourceMappingURL=microservices-test-generator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"microservices-test-generator.d.ts","sourceRoot":"","sources":["../../../../src/tools/generate-tests/generators/microservices-test-generator.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,cAAc,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAa1F,wBAAgB,YAAY,CAAC,SAAS,EAAE,gBAAgB,GAAG,MAAM,GAAG,IAAI,CAQvE;AAED,wBAAgB,iBAAiB,CAAC,SAAS,EAAE,gBAAgB,GAAG,MAAM,GAAG,IAAI,CAQ5E;AAED,wBAAgB,0BAA0B,CAAC,SAAS,EAAE,gBAAgB,GAAG,OAAO,CAe/E;AAED,wBAAgB,6BAA6B,CAC3C,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,gBAAgB,GAC1B,cAAc,EAAE,CA+DlB;AA2OD,wBAAgB,8BAA8B,CAC5C,IAAI,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,EACrC,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,EACf,YAAY,EAAE,OAAO,EACrB,SAAS,EAAE,gBAAgB,GAC1B,QAAQ,EAAE,CAkBZ"}
|
|
@@ -1,341 +0,0 @@
|
|
|
1
|
-
// tools/generate-tests/generators/microservices-test-generator.ts — SPEC-058b Section E
|
|
2
|
-
// Generates microservices & distributed systems test scaffolds:
|
|
3
|
-
// contract testing, circuit breaker, retry, health checks, broker, service mesh.
|
|
4
|
-
const BROKER_SIGNALS = ['kafka', 'rabbitmq', 'sqs', 'nats', 'redis-streams', 'pulsar', 'amqp'];
|
|
5
|
-
const MESH_SIGNALS = [
|
|
6
|
-
'istio',
|
|
7
|
-
'envoy',
|
|
8
|
-
'linkerd',
|
|
9
|
-
'kong',
|
|
10
|
-
'traefik',
|
|
11
|
-
'nginx-ingress',
|
|
12
|
-
'api-gateway',
|
|
13
|
-
];
|
|
14
|
-
export function detectBroker(knowledge) {
|
|
15
|
-
const stackLower = knowledge.stack.map((s) => s.toLowerCase());
|
|
16
|
-
for (const sig of BROKER_SIGNALS) {
|
|
17
|
-
if (stackLower.some((s) => s.includes(sig))) {
|
|
18
|
-
return sig;
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
return null;
|
|
22
|
-
}
|
|
23
|
-
export function detectServiceMesh(knowledge) {
|
|
24
|
-
const stackLower = knowledge.stack.map((s) => s.toLowerCase());
|
|
25
|
-
for (const sig of MESH_SIGNALS) {
|
|
26
|
-
if (stackLower.some((s) => s.includes(sig))) {
|
|
27
|
-
return sig;
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
return null;
|
|
31
|
-
}
|
|
32
|
-
export function isMicroservicesTestProject(knowledge) {
|
|
33
|
-
if (knowledge.architecture.primary === 'microservices') {
|
|
34
|
-
return true;
|
|
35
|
-
}
|
|
36
|
-
if (knowledge.architecture.secondary.some((s) => s === 'microservices')) {
|
|
37
|
-
return true;
|
|
38
|
-
}
|
|
39
|
-
if (detectBroker(knowledge) !== null) {
|
|
40
|
-
return true;
|
|
41
|
-
}
|
|
42
|
-
if (detectServiceMesh(knowledge) !== null) {
|
|
43
|
-
return true;
|
|
44
|
-
}
|
|
45
|
-
const backends = knowledge.apps.filter((a) => a.type === 'backend' || a.type === 'worker');
|
|
46
|
-
return backends.length > 1;
|
|
47
|
-
}
|
|
48
|
-
export function generateMicroservicesTestDefs(title, testDir, _testExt, knowledge) {
|
|
49
|
-
const defs = [
|
|
50
|
-
{
|
|
51
|
-
name: `${title} — contract testing: inter-service Pact verification`,
|
|
52
|
-
type: 'integration',
|
|
53
|
-
file: `${testDir}/microservices/`,
|
|
54
|
-
description: 'Consumer-driven contract tests verify API compatibility between services',
|
|
55
|
-
priority: 'critical',
|
|
56
|
-
automatable: true,
|
|
57
|
-
},
|
|
58
|
-
{
|
|
59
|
-
name: `${title} — circuit breaker: open/half-open/closed state transitions`,
|
|
60
|
-
type: 'integration',
|
|
61
|
-
file: `${testDir}/microservices/`,
|
|
62
|
-
description: 'Verify circuit breaker opens on failures, transitions to half-open, and closes on recovery',
|
|
63
|
-
priority: 'high',
|
|
64
|
-
automatable: true,
|
|
65
|
-
},
|
|
66
|
-
{
|
|
67
|
-
name: `${title} — retry with backoff: exponential backoff and idempotency`,
|
|
68
|
-
type: 'integration',
|
|
69
|
-
file: `${testDir}/microservices/`,
|
|
70
|
-
description: 'Verify retry logic uses exponential backoff with jitter and respects idempotency keys',
|
|
71
|
-
priority: 'high',
|
|
72
|
-
automatable: true,
|
|
73
|
-
},
|
|
74
|
-
{
|
|
75
|
-
name: `${title} — health checks: liveness and readiness probes`,
|
|
76
|
-
type: 'integration',
|
|
77
|
-
file: `${testDir}/microservices/`,
|
|
78
|
-
description: 'Verify /healthz, /readyz, and startup probes return correct status codes',
|
|
79
|
-
priority: 'critical',
|
|
80
|
-
automatable: true,
|
|
81
|
-
},
|
|
82
|
-
];
|
|
83
|
-
if (detectBroker(knowledge) !== null) {
|
|
84
|
-
defs.push({
|
|
85
|
-
name: `${title} — message broker: delivery guarantee and DLQ handling`,
|
|
86
|
-
type: 'integration',
|
|
87
|
-
file: `${testDir}/microservices/`,
|
|
88
|
-
description: 'Verify message delivery, ordering, dead letter queue handling, and consumer group rebalancing',
|
|
89
|
-
priority: 'high',
|
|
90
|
-
automatable: true,
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
if (detectServiceMesh(knowledge) !== null) {
|
|
94
|
-
defs.push({
|
|
95
|
-
name: `${title} — service mesh: routing rules and mTLS verification`,
|
|
96
|
-
type: 'integration',
|
|
97
|
-
file: `${testDir}/microservices/`,
|
|
98
|
-
description: 'Verify routing rules, mTLS certificate verification, and traffic splitting configuration',
|
|
99
|
-
priority: 'medium',
|
|
100
|
-
automatable: true,
|
|
101
|
-
});
|
|
102
|
-
}
|
|
103
|
-
return defs;
|
|
104
|
-
}
|
|
105
|
-
// ---------------------------------------------------------------------------
|
|
106
|
-
// Scaffold builders
|
|
107
|
-
// ---------------------------------------------------------------------------
|
|
108
|
-
function buildTsMicroservicesTest(title, broker, mesh) {
|
|
109
|
-
const brokerSection = broker
|
|
110
|
-
? `
|
|
111
|
-
describe('Message broker (${broker})', () => {
|
|
112
|
-
it('guarantees message delivery to consumer', async () => {
|
|
113
|
-
// const producer = createProducer({ broker: '${broker}' });
|
|
114
|
-
// await producer.send({ topic: 'orders', value: { id: 1 } });
|
|
115
|
-
// const received = await consumer.waitForMessage('orders', 5000);
|
|
116
|
-
// expect(received.value).toMatchObject({ id: 1 });
|
|
117
|
-
expect(true).toBe(true); // Replace with real broker assertion
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
it('routes failed messages to dead letter queue', async () => {
|
|
121
|
-
// Simulate processing failure → verify message lands in DLQ
|
|
122
|
-
expect(true).toBe(true);
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
it('preserves message ordering within partition', async () => {
|
|
126
|
-
expect(true).toBe(true);
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
it('handles consumer group rebalancing gracefully', async () => {
|
|
130
|
-
expect(true).toBe(true);
|
|
131
|
-
});
|
|
132
|
-
});
|
|
133
|
-
`
|
|
134
|
-
: '';
|
|
135
|
-
const meshSection = mesh
|
|
136
|
-
? `
|
|
137
|
-
describe('Service mesh (${mesh})', () => {
|
|
138
|
-
it('routes traffic according to configured rules', async () => {
|
|
139
|
-
expect(true).toBe(true);
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
it('verifies mTLS certificates between services', async () => {
|
|
143
|
-
expect(true).toBe(true);
|
|
144
|
-
});
|
|
145
|
-
|
|
146
|
-
it('splits traffic correctly between versions', async () => {
|
|
147
|
-
expect(true).toBe(true);
|
|
148
|
-
});
|
|
149
|
-
});
|
|
150
|
-
`
|
|
151
|
-
: '';
|
|
152
|
-
return `// Microservices & Distributed Systems tests for: ${title}
|
|
153
|
-
// Generated by SpecForge SDD MCP Server (SPEC-058b)
|
|
154
|
-
import { describe, it, expect } from 'vitest';
|
|
155
|
-
|
|
156
|
-
describe('${title} — Microservices Tests', () => {
|
|
157
|
-
describe('Contract testing (Pact)', () => {
|
|
158
|
-
it('consumer contract matches provider API', async () => {
|
|
159
|
-
// const interaction = new PactInteraction()
|
|
160
|
-
// .uponReceiving('a request for user')
|
|
161
|
-
// .withRequest({ method: 'GET', path: '/api/users/1' })
|
|
162
|
-
// .willRespondWith({ status: 200, body: { id: 1, name: 'Test' } });
|
|
163
|
-
// await provider.verify(interaction);
|
|
164
|
-
expect(true).toBe(true); // Replace with real Pact assertion
|
|
165
|
-
});
|
|
166
|
-
});
|
|
167
|
-
|
|
168
|
-
describe('Circuit breaker', () => {
|
|
169
|
-
it('opens after consecutive failures', async () => {
|
|
170
|
-
// Simulate 5 failures → verify circuit is open
|
|
171
|
-
expect(true).toBe(true);
|
|
172
|
-
});
|
|
173
|
-
|
|
174
|
-
it('transitions from open to half-open after timeout', async () => {
|
|
175
|
-
expect(true).toBe(true);
|
|
176
|
-
});
|
|
177
|
-
|
|
178
|
-
it('closes after successful request in half-open state', async () => {
|
|
179
|
-
expect(true).toBe(true);
|
|
180
|
-
});
|
|
181
|
-
|
|
182
|
-
it('returns fallback response when circuit is open', async () => {
|
|
183
|
-
expect(true).toBe(true);
|
|
184
|
-
});
|
|
185
|
-
});
|
|
186
|
-
|
|
187
|
-
describe('Retry with backoff', () => {
|
|
188
|
-
it('retries with exponential backoff on transient failure', async () => {
|
|
189
|
-
// Verify delays: 100ms, 200ms, 400ms (exponential)
|
|
190
|
-
expect(true).toBe(true);
|
|
191
|
-
});
|
|
192
|
-
|
|
193
|
-
it('respects max retry limit', async () => {
|
|
194
|
-
expect(true).toBe(true);
|
|
195
|
-
});
|
|
196
|
-
|
|
197
|
-
it('applies jitter to avoid thundering herd', async () => {
|
|
198
|
-
expect(true).toBe(true);
|
|
199
|
-
});
|
|
200
|
-
|
|
201
|
-
it('uses idempotency key to prevent duplicate processing', async () => {
|
|
202
|
-
expect(true).toBe(true);
|
|
203
|
-
});
|
|
204
|
-
});
|
|
205
|
-
|
|
206
|
-
describe('Health check endpoints', () => {
|
|
207
|
-
it('GET /healthz returns 200 when service is alive', async () => {
|
|
208
|
-
// const res = await request(app).get('/healthz');
|
|
209
|
-
// expect(res.status).toBe(200);
|
|
210
|
-
expect(true).toBe(true);
|
|
211
|
-
});
|
|
212
|
-
|
|
213
|
-
it('GET /readyz returns 200 when dependencies are ready', async () => {
|
|
214
|
-
expect(true).toBe(true);
|
|
215
|
-
});
|
|
216
|
-
|
|
217
|
-
it('GET /readyz returns 503 when a dependency is down', async () => {
|
|
218
|
-
expect(true).toBe(true);
|
|
219
|
-
});
|
|
220
|
-
|
|
221
|
-
it('startup probe succeeds within timeout', async () => {
|
|
222
|
-
expect(true).toBe(true);
|
|
223
|
-
});
|
|
224
|
-
});
|
|
225
|
-
${brokerSection}${meshSection}});
|
|
226
|
-
`;
|
|
227
|
-
}
|
|
228
|
-
function buildPythonMicroservicesTest(title, broker, mesh) {
|
|
229
|
-
const cls = title.replace(/[^a-zA-Z0-9]/g, '');
|
|
230
|
-
const brokerSection = broker
|
|
231
|
-
? `
|
|
232
|
-
def test_message_delivery_guarantee(self) -> None:
|
|
233
|
-
"""Messages are delivered to consumers with at-least-once guarantee."""
|
|
234
|
-
# TODO: producer.send('orders', {'id': 1})
|
|
235
|
-
# msg = consumer.poll(timeout=5.0)
|
|
236
|
-
# assert msg.value == {'id': 1}
|
|
237
|
-
pass
|
|
238
|
-
|
|
239
|
-
def test_dead_letter_queue_routing(self) -> None:
|
|
240
|
-
"""Failed messages are routed to the dead letter queue."""
|
|
241
|
-
pass
|
|
242
|
-
|
|
243
|
-
def test_message_ordering_within_partition(self) -> None:
|
|
244
|
-
"""Messages within same partition maintain ordering."""
|
|
245
|
-
pass
|
|
246
|
-
|
|
247
|
-
def test_consumer_group_rebalancing(self) -> None:
|
|
248
|
-
"""Consumer group rebalancing does not lose messages."""
|
|
249
|
-
pass
|
|
250
|
-
`
|
|
251
|
-
: '';
|
|
252
|
-
const meshSection = mesh
|
|
253
|
-
? `
|
|
254
|
-
def test_routing_rules(self) -> None:
|
|
255
|
-
"""Traffic is routed according to configured rules."""
|
|
256
|
-
pass
|
|
257
|
-
|
|
258
|
-
def test_mtls_verification(self) -> None:
|
|
259
|
-
"""mTLS certificates are verified between services."""
|
|
260
|
-
pass
|
|
261
|
-
|
|
262
|
-
def test_traffic_splitting(self) -> None:
|
|
263
|
-
"""Traffic is split correctly between service versions."""
|
|
264
|
-
pass
|
|
265
|
-
`
|
|
266
|
-
: '';
|
|
267
|
-
return `"""Microservices & Distributed Systems tests for: ${title}
|
|
268
|
-
Generated by SpecForge SDD MCP Server (SPEC-058b).
|
|
269
|
-
"""
|
|
270
|
-
import pytest
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
class Test${cls}Microservices:
|
|
274
|
-
"""Microservices test suite for ${title}."""
|
|
275
|
-
|
|
276
|
-
def test_consumer_contract_matches_provider(self) -> None:
|
|
277
|
-
"""Consumer-driven contract matches the provider API."""
|
|
278
|
-
# TODO: pact = Pact('consumer', 'provider')
|
|
279
|
-
# pact.given('user exists').upon_receiving('get user')
|
|
280
|
-
# .with_request('GET', '/api/users/1')
|
|
281
|
-
# .will_respond_with(200, body={'id': 1})
|
|
282
|
-
pass
|
|
283
|
-
|
|
284
|
-
def test_circuit_breaker_opens_on_failures(self) -> None:
|
|
285
|
-
"""Circuit breaker opens after consecutive failures."""
|
|
286
|
-
pass
|
|
287
|
-
|
|
288
|
-
def test_circuit_breaker_half_open_transition(self) -> None:
|
|
289
|
-
"""Circuit transitions from open to half-open after timeout."""
|
|
290
|
-
pass
|
|
291
|
-
|
|
292
|
-
def test_circuit_breaker_closes_on_recovery(self) -> None:
|
|
293
|
-
"""Circuit closes after successful request in half-open state."""
|
|
294
|
-
pass
|
|
295
|
-
|
|
296
|
-
def test_retry_exponential_backoff(self) -> None:
|
|
297
|
-
"""Retries use exponential backoff with jitter."""
|
|
298
|
-
pass
|
|
299
|
-
|
|
300
|
-
def test_retry_respects_max_limit(self) -> None:
|
|
301
|
-
"""Retry stops after max attempts."""
|
|
302
|
-
pass
|
|
303
|
-
|
|
304
|
-
def test_idempotency_key_prevents_duplicates(self) -> None:
|
|
305
|
-
"""Idempotency key prevents duplicate processing on retry."""
|
|
306
|
-
pass
|
|
307
|
-
|
|
308
|
-
def test_healthz_returns_200(self) -> None:
|
|
309
|
-
"""GET /healthz returns 200 when service is alive."""
|
|
310
|
-
# TODO: response = client.get('/healthz')
|
|
311
|
-
# assert response.status_code == 200
|
|
312
|
-
pass
|
|
313
|
-
|
|
314
|
-
def test_readyz_returns_200_when_ready(self) -> None:
|
|
315
|
-
"""GET /readyz returns 200 when all dependencies are ready."""
|
|
316
|
-
pass
|
|
317
|
-
|
|
318
|
-
def test_readyz_returns_503_when_dependency_down(self) -> None:
|
|
319
|
-
"""GET /readyz returns 503 when a dependency is unavailable."""
|
|
320
|
-
pass
|
|
321
|
-
${brokerSection}${meshSection}`;
|
|
322
|
-
}
|
|
323
|
-
export function generateMicroservicesTestFiles(spec, testDir, framework, language, testExt, autoGenerate, knowledge) {
|
|
324
|
-
const broker = detectBroker(knowledge);
|
|
325
|
-
const mesh = detectServiceMesh(knowledge);
|
|
326
|
-
const isPython = language === 'python';
|
|
327
|
-
const ext = isPython ? 'py' : testExt;
|
|
328
|
-
const fw = isPython ? 'pytest' : framework;
|
|
329
|
-
const content = isPython
|
|
330
|
-
? buildPythonMicroservicesTest(spec.title, broker, mesh)
|
|
331
|
-
: buildTsMicroservicesTest(spec.title, broker, mesh);
|
|
332
|
-
return [
|
|
333
|
-
{
|
|
334
|
-
path: `${testDir}/microservices/${spec.slug}.microservices.test.${ext}`,
|
|
335
|
-
framework: fw,
|
|
336
|
-
content,
|
|
337
|
-
ready: autoGenerate,
|
|
338
|
-
},
|
|
339
|
-
];
|
|
340
|
-
}
|
|
341
|
-
//# sourceMappingURL=microservices-test-generator.js.map
|