qa360 2.2.1 → 2.2.13
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/CHANGELOG.md +28 -0
- package/README.md +79 -0
- package/cli/dist/cli-minimal.d.ts +6 -0
- package/cli/dist/cli-minimal.js +36 -0
- package/cli/dist/commands/ai.d.ts +43 -0
- package/cli/dist/commands/ai.js +616 -0
- package/cli/dist/commands/ask.d.ts +94 -0
- package/cli/dist/commands/ask.js +582 -0
- package/cli/dist/commands/coverage.d.ts +8 -0
- package/cli/dist/commands/coverage.js +252 -0
- package/cli/dist/commands/crawl.d.ts +24 -0
- package/cli/dist/commands/crawl.js +121 -0
- package/cli/dist/commands/doctor.d.ts +54 -0
- package/cli/dist/commands/doctor.js +513 -0
- package/cli/dist/commands/examples.d.ts +33 -0
- package/cli/dist/commands/examples.js +193 -0
- package/cli/dist/commands/explain.d.ts +27 -0
- package/cli/dist/commands/explain.js +630 -0
- package/cli/dist/commands/flakiness.d.ts +73 -0
- package/cli/dist/commands/flakiness.js +435 -0
- package/cli/dist/commands/generate.d.ts +66 -0
- package/cli/dist/commands/generate.js +438 -0
- package/cli/dist/commands/history.d.ts +76 -0
- package/cli/dist/commands/history.js +755 -0
- package/cli/dist/commands/init.d.ts +106 -0
- package/cli/dist/commands/init.js +616 -0
- package/cli/dist/commands/monitor.d.ts +27 -0
- package/cli/dist/commands/monitor.js +225 -0
- package/cli/dist/commands/ollama.d.ts +40 -0
- package/cli/dist/commands/ollama.js +346 -0
- package/cli/dist/commands/pack.d.ts +70 -0
- package/cli/dist/commands/pack.js +413 -0
- package/cli/dist/commands/regression.d.ts +8 -0
- package/cli/dist/commands/regression.js +340 -0
- package/cli/dist/commands/repair.d.ts +26 -0
- package/cli/dist/commands/repair.js +307 -0
- package/cli/dist/commands/report.d.ts +62 -0
- package/cli/dist/commands/report.js +378 -0
- package/cli/dist/commands/retry.d.ts +43 -0
- package/cli/dist/commands/retry.js +275 -0
- package/cli/dist/commands/run.d.ts +41 -0
- package/cli/dist/commands/run.js +171 -0
- package/cli/dist/commands/scan.d.ts +5 -0
- package/cli/dist/commands/scan.js +155 -0
- package/cli/dist/commands/secrets.d.ts +58 -0
- package/cli/dist/commands/secrets.js +289 -0
- package/cli/dist/commands/serve.d.ts +13 -0
- package/cli/dist/commands/serve.js +156 -0
- package/cli/dist/commands/slo.d.ts +8 -0
- package/cli/dist/commands/slo.js +327 -0
- package/cli/dist/commands/verify.d.ts +32 -0
- package/cli/dist/commands/verify.js +278 -0
- package/cli/dist/core/adapters/gitleaks-secrets.d.ts +114 -0
- package/cli/dist/core/adapters/gitleaks-secrets.js +410 -0
- package/cli/dist/core/adapters/jest-adapter.d.ts +44 -0
- package/cli/dist/core/adapters/jest-adapter.js +261 -0
- package/cli/dist/core/adapters/k6-perf.d.ts +85 -0
- package/cli/dist/core/adapters/k6-perf.js +398 -0
- package/cli/dist/core/adapters/osv-deps.d.ts +123 -0
- package/cli/dist/core/adapters/osv-deps.js +372 -0
- package/cli/dist/core/adapters/playwright-native-adapter.d.ts +121 -0
- package/cli/dist/core/adapters/playwright-native-adapter.js +339 -0
- package/cli/dist/core/adapters/playwright-native-api.d.ts +183 -0
- package/cli/dist/core/adapters/playwright-native-api.js +465 -0
- package/cli/dist/core/adapters/playwright-ui.d.ts +197 -0
- package/cli/dist/core/adapters/playwright-ui.js +864 -0
- package/cli/dist/core/adapters/pytest-adapter.d.ts +49 -0
- package/cli/dist/core/adapters/pytest-adapter.js +324 -0
- package/cli/dist/core/adapters/semgrep-sast.d.ts +99 -0
- package/cli/dist/core/adapters/semgrep-sast.js +322 -0
- package/cli/dist/core/adapters/unit-test-types.d.ts +119 -0
- package/cli/dist/core/adapters/unit-test-types.js +6 -0
- package/cli/dist/core/adapters/vitest-adapter.d.ts +46 -0
- package/cli/dist/core/adapters/vitest-adapter.js +272 -0
- package/cli/dist/core/adapters/zap-dast.d.ts +133 -0
- package/cli/dist/core/adapters/zap-dast.js +424 -0
- package/cli/dist/core/ai/anthropic-provider.d.ts +50 -0
- package/cli/dist/core/ai/anthropic-provider.js +223 -0
- package/cli/dist/core/ai/deepseek-provider.d.ts +81 -0
- package/cli/dist/core/ai/deepseek-provider.js +266 -0
- package/cli/dist/core/ai/index.d.ts +60 -0
- package/cli/dist/core/ai/index.js +18 -0
- package/cli/dist/core/ai/llm-client.d.ts +45 -0
- package/cli/dist/core/ai/llm-client.js +7 -0
- package/cli/dist/core/ai/mock-provider.d.ts +49 -0
- package/cli/dist/core/ai/mock-provider.js +121 -0
- package/cli/dist/core/ai/ollama-provider.d.ts +78 -0
- package/cli/dist/core/ai/ollama-provider.js +216 -0
- package/cli/dist/core/ai/openai-provider.d.ts +48 -0
- package/cli/dist/core/ai/openai-provider.js +200 -0
- package/cli/dist/core/ai/provider-factory.d.ts +160 -0
- package/cli/dist/core/ai/provider-factory.js +269 -0
- package/cli/dist/core/artifacts/index.d.ts +6 -0
- package/cli/dist/core/artifacts/index.js +6 -0
- package/cli/dist/core/artifacts/ui-artifacts.d.ts +133 -0
- package/cli/dist/core/artifacts/ui-artifacts.js +304 -0
- package/cli/dist/core/assertions/engine.d.ts +51 -0
- package/cli/dist/core/assertions/engine.js +530 -0
- package/cli/dist/core/assertions/index.d.ts +11 -0
- package/cli/dist/core/assertions/index.js +11 -0
- package/cli/dist/core/assertions/types.d.ts +121 -0
- package/cli/dist/core/assertions/types.js +37 -0
- package/cli/dist/core/auth/api-key-provider.d.ts +16 -0
- package/cli/dist/core/auth/api-key-provider.js +63 -0
- package/cli/dist/core/auth/aws-iam-provider.d.ts +35 -0
- package/cli/dist/core/auth/aws-iam-provider.js +177 -0
- package/cli/dist/core/auth/azure-ad-provider.d.ts +15 -0
- package/cli/dist/core/auth/azure-ad-provider.js +99 -0
- package/cli/dist/core/auth/basic-auth-provider.d.ts +26 -0
- package/cli/dist/core/auth/basic-auth-provider.js +111 -0
- package/cli/dist/core/auth/gcp-adc-provider.d.ts +27 -0
- package/cli/dist/core/auth/gcp-adc-provider.js +126 -0
- package/cli/dist/core/auth/index.d.ts +238 -0
- package/cli/dist/core/auth/index.js +82 -0
- package/cli/dist/core/auth/jwt-provider.d.ts +19 -0
- package/cli/dist/core/auth/jwt-provider.js +160 -0
- package/cli/dist/core/auth/manager.d.ts +84 -0
- package/cli/dist/core/auth/manager.js +230 -0
- package/cli/dist/core/auth/oauth2-provider.d.ts +17 -0
- package/cli/dist/core/auth/oauth2-provider.js +114 -0
- package/cli/dist/core/auth/totp-provider.d.ts +31 -0
- package/cli/dist/core/auth/totp-provider.js +134 -0
- package/cli/dist/core/auth/ui-login-provider.d.ts +26 -0
- package/cli/dist/core/auth/ui-login-provider.js +198 -0
- package/cli/dist/core/cache/index.d.ts +7 -0
- package/cli/dist/core/cache/index.js +6 -0
- package/cli/dist/core/cache/lru-cache.d.ts +203 -0
- package/cli/dist/core/cache/lru-cache.js +397 -0
- package/cli/dist/core/coverage/analyzer.d.ts +101 -0
- package/cli/dist/core/coverage/analyzer.js +415 -0
- package/cli/dist/core/coverage/collector.d.ts +74 -0
- package/cli/dist/core/coverage/collector.js +459 -0
- package/cli/dist/core/coverage/config.d.ts +37 -0
- package/cli/dist/core/coverage/config.js +156 -0
- package/cli/dist/core/coverage/index.d.ts +11 -0
- package/cli/dist/core/coverage/index.js +15 -0
- package/cli/dist/core/coverage/types.d.ts +267 -0
- package/cli/dist/core/coverage/types.js +6 -0
- package/cli/dist/core/coverage/vault.d.ts +95 -0
- package/cli/dist/core/coverage/vault.js +405 -0
- package/cli/dist/core/crawler/index.d.ts +57 -0
- package/cli/dist/core/crawler/index.js +281 -0
- package/cli/dist/core/crawler/journey-generator.d.ts +49 -0
- package/cli/dist/core/crawler/journey-generator.js +412 -0
- package/cli/dist/core/crawler/page-analyzer.d.ts +88 -0
- package/cli/dist/core/crawler/page-analyzer.js +709 -0
- package/cli/dist/core/crawler/selector-generator.d.ts +34 -0
- package/cli/dist/core/crawler/selector-generator.js +309 -0
- package/cli/dist/core/crawler/types.d.ts +353 -0
- package/cli/dist/core/crawler/types.js +6 -0
- package/cli/dist/core/dashboard/assets.d.ts +6 -0
- package/cli/dist/core/dashboard/assets.js +690 -0
- package/cli/dist/core/dashboard/index.d.ts +6 -0
- package/cli/dist/core/dashboard/index.js +5 -0
- package/cli/dist/core/dashboard/server.d.ts +72 -0
- package/cli/dist/core/dashboard/server.js +354 -0
- package/cli/dist/core/dashboard/types.d.ts +70 -0
- package/cli/dist/core/dashboard/types.js +5 -0
- package/cli/dist/core/discoverer/index.d.ts +115 -0
- package/cli/dist/core/discoverer/index.js +250 -0
- package/cli/dist/core/fixtures/index.d.ts +8 -0
- package/cli/dist/core/fixtures/index.js +8 -0
- package/cli/dist/core/fixtures/loader.d.ts +65 -0
- package/cli/dist/core/fixtures/loader.js +161 -0
- package/cli/dist/core/fixtures/resolver.d.ts +79 -0
- package/cli/dist/core/fixtures/resolver.js +181 -0
- package/cli/dist/core/fixtures/types.d.ts +75 -0
- package/cli/dist/core/fixtures/types.js +30 -0
- package/cli/dist/core/flakiness/index.d.ts +228 -0
- package/cli/dist/core/flakiness/index.js +384 -0
- package/cli/dist/core/generation/code-formatter.d.ts +111 -0
- package/cli/dist/core/generation/code-formatter.js +307 -0
- package/cli/dist/core/generation/code-generator.d.ts +144 -0
- package/cli/dist/core/generation/code-generator.js +293 -0
- package/cli/dist/core/generation/crawler-pack-generator.d.ts +44 -0
- package/cli/dist/core/generation/crawler-pack-generator.js +245 -0
- package/cli/dist/core/generation/generator.d.ts +40 -0
- package/cli/dist/core/generation/generator.js +76 -0
- package/cli/dist/core/generation/index.d.ts +32 -0
- package/cli/dist/core/generation/index.js +30 -0
- package/cli/dist/core/generation/pack-generator.d.ts +107 -0
- package/cli/dist/core/generation/pack-generator.js +416 -0
- package/cli/dist/core/generation/prompt-builder.d.ts +132 -0
- package/cli/dist/core/generation/prompt-builder.js +672 -0
- package/cli/dist/core/generation/source-analyzer.d.ts +213 -0
- package/cli/dist/core/generation/source-analyzer.js +657 -0
- package/cli/dist/core/generation/test-optimizer.d.ts +117 -0
- package/cli/dist/core/generation/test-optimizer.js +328 -0
- package/cli/dist/core/generation/types.d.ts +214 -0
- package/cli/dist/core/generation/types.js +4 -0
- package/cli/dist/core/hooks/compose.d.ts +61 -0
- package/cli/dist/core/hooks/compose.js +225 -0
- package/cli/dist/core/hooks/runner.d.ts +68 -0
- package/cli/dist/core/hooks/runner.js +303 -0
- package/cli/dist/core/index.d.ts +110 -0
- package/cli/dist/core/index.js +99 -0
- package/cli/dist/core/pack/migrator.d.ts +51 -0
- package/cli/dist/core/pack/migrator.js +304 -0
- package/cli/dist/core/pack/validator.d.ts +42 -0
- package/cli/dist/core/pack/validator.js +330 -0
- package/cli/dist/core/pack-v2/index.d.ts +9 -0
- package/cli/dist/core/pack-v2/index.js +8 -0
- package/cli/dist/core/pack-v2/loader.d.ts +63 -0
- package/cli/dist/core/pack-v2/loader.js +292 -0
- package/cli/dist/core/pack-v2/migrator.d.ts +62 -0
- package/cli/dist/core/pack-v2/migrator.js +505 -0
- package/cli/dist/core/pack-v2/validator.d.ts +65 -0
- package/cli/dist/core/pack-v2/validator.js +629 -0
- package/cli/dist/core/parallel/index.d.ts +6 -0
- package/cli/dist/core/parallel/index.js +6 -0
- package/cli/dist/core/parallel/parallel-runner.d.ts +107 -0
- package/cli/dist/core/parallel/parallel-runner.js +192 -0
- package/cli/dist/core/pom/base-page.d.ts +237 -0
- package/cli/dist/core/pom/base-page.js +354 -0
- package/cli/dist/core/pom/index.d.ts +22 -0
- package/cli/dist/core/pom/index.js +23 -0
- package/cli/dist/core/pom/loader.d.ts +118 -0
- package/cli/dist/core/pom/loader.js +382 -0
- package/cli/dist/core/pom/types.d.ts +112 -0
- package/cli/dist/core/pom/types.js +9 -0
- package/cli/dist/core/proof/bundle.d.ts +137 -0
- package/cli/dist/core/proof/bundle.js +160 -0
- package/cli/dist/core/proof/canonicalize.d.ts +47 -0
- package/cli/dist/core/proof/canonicalize.js +105 -0
- package/cli/dist/core/proof/index.d.ts +13 -0
- package/cli/dist/core/proof/index.js +18 -0
- package/cli/dist/core/proof/schema.d.ts +217 -0
- package/cli/dist/core/proof/schema.js +263 -0
- package/cli/dist/core/proof/signer.d.ts +111 -0
- package/cli/dist/core/proof/signer.js +226 -0
- package/cli/dist/core/proof/verifier.d.ts +97 -0
- package/cli/dist/core/proof/verifier.js +308 -0
- package/cli/dist/core/regression/detector.d.ts +107 -0
- package/cli/dist/core/regression/detector.js +497 -0
- package/cli/dist/core/regression/index.d.ts +9 -0
- package/cli/dist/core/regression/index.js +11 -0
- package/cli/dist/core/regression/trend-analyzer.d.ts +102 -0
- package/cli/dist/core/regression/trend-analyzer.js +345 -0
- package/cli/dist/core/regression/types.d.ts +222 -0
- package/cli/dist/core/regression/types.js +7 -0
- package/cli/dist/core/regression/vault.d.ts +87 -0
- package/cli/dist/core/regression/vault.js +289 -0
- package/cli/dist/core/repair/engine/fixer.d.ts +24 -0
- package/cli/dist/core/repair/engine/fixer.js +226 -0
- package/cli/dist/core/repair/engine/suggestion-engine.d.ts +18 -0
- package/cli/dist/core/repair/engine/suggestion-engine.js +187 -0
- package/cli/dist/core/repair/index.d.ts +10 -0
- package/cli/dist/core/repair/index.js +13 -0
- package/cli/dist/core/repair/repairer.d.ts +90 -0
- package/cli/dist/core/repair/repairer.js +284 -0
- package/cli/dist/core/repair/types.d.ts +91 -0
- package/cli/dist/core/repair/types.js +6 -0
- package/cli/dist/core/repair/utils/error-analyzer.d.ts +28 -0
- package/cli/dist/core/repair/utils/error-analyzer.js +264 -0
- package/cli/dist/core/reporting/html-reporter.d.ts +119 -0
- package/cli/dist/core/reporting/html-reporter.js +737 -0
- package/cli/dist/core/reporting/index.d.ts +6 -0
- package/cli/dist/core/reporting/index.js +6 -0
- package/cli/dist/core/retry/flakiness-integration.d.ts +60 -0
- package/cli/dist/core/retry/flakiness-integration.js +228 -0
- package/cli/dist/core/retry/index.d.ts +14 -0
- package/cli/dist/core/retry/index.js +16 -0
- package/cli/dist/core/retry/retry-engine.d.ts +80 -0
- package/cli/dist/core/retry/retry-engine.js +296 -0
- package/cli/dist/core/retry/types.d.ts +178 -0
- package/cli/dist/core/retry/types.js +52 -0
- package/cli/dist/core/retry/vault.d.ts +77 -0
- package/cli/dist/core/retry/vault.js +304 -0
- package/cli/dist/core/runner/e2e-helpers.d.ts +102 -0
- package/cli/dist/core/runner/e2e-helpers.js +153 -0
- package/cli/dist/core/runner/phase3-runner.d.ts +249 -0
- package/cli/dist/core/runner/phase3-runner.js +1323 -0
- package/cli/dist/core/schemas/pack.schema.json +236 -0
- package/cli/dist/core/secrets/crypto.d.ts +75 -0
- package/cli/dist/core/secrets/crypto.js +223 -0
- package/cli/dist/core/secrets/manager.d.ts +76 -0
- package/cli/dist/core/secrets/manager.js +219 -0
- package/cli/dist/core/security/redaction-patterns-extended.d.ts +27 -0
- package/cli/dist/core/security/redaction-patterns-extended.js +247 -0
- package/cli/dist/core/security/redactor.d.ts +71 -0
- package/cli/dist/core/security/redactor.js +279 -0
- package/cli/dist/core/self-healing/assertion-healer.d.ts +97 -0
- package/cli/dist/core/self-healing/assertion-healer.js +371 -0
- package/cli/dist/core/self-healing/engine.d.ts +122 -0
- package/cli/dist/core/self-healing/engine.js +538 -0
- package/cli/dist/core/self-healing/index.d.ts +10 -0
- package/cli/dist/core/self-healing/index.js +11 -0
- package/cli/dist/core/self-healing/selector-healer.d.ts +103 -0
- package/cli/dist/core/self-healing/selector-healer.js +372 -0
- package/cli/dist/core/self-healing/types.d.ts +152 -0
- package/cli/dist/core/self-healing/types.js +6 -0
- package/cli/dist/core/serve/diagnostics-collector.d.ts +32 -0
- package/cli/dist/core/serve/diagnostics-collector.js +149 -0
- package/cli/dist/core/serve/health-checker.d.ts +44 -0
- package/cli/dist/core/serve/health-checker.js +219 -0
- package/cli/dist/core/serve/index.d.ts +8 -0
- package/cli/dist/core/serve/index.js +8 -0
- package/cli/dist/core/serve/metrics-collector.d.ts +24 -0
- package/cli/dist/core/serve/metrics-collector.js +322 -0
- package/cli/dist/core/serve/process-manager.d.ts +36 -0
- package/cli/dist/core/serve/process-manager.js +213 -0
- package/cli/dist/core/serve/server.d.ts +36 -0
- package/cli/dist/core/serve/server.js +191 -0
- package/cli/dist/core/slo/config.d.ts +107 -0
- package/cli/dist/core/slo/config.js +360 -0
- package/cli/dist/core/slo/index.d.ts +11 -0
- package/cli/dist/core/slo/index.js +15 -0
- package/cli/dist/core/slo/sli-calculator.d.ts +92 -0
- package/cli/dist/core/slo/sli-calculator.js +364 -0
- package/cli/dist/core/slo/slo-tracker.d.ts +148 -0
- package/cli/dist/core/slo/slo-tracker.js +379 -0
- package/cli/dist/core/slo/types.d.ts +281 -0
- package/cli/dist/core/slo/types.js +7 -0
- package/cli/dist/core/slo/vault.d.ts +102 -0
- package/cli/dist/core/slo/vault.js +427 -0
- package/cli/dist/core/tui/index.d.ts +7 -0
- package/cli/dist/core/tui/index.js +6 -0
- package/cli/dist/core/tui/monitor.d.ts +92 -0
- package/cli/dist/core/tui/monitor.js +271 -0
- package/cli/dist/core/tui/renderer.d.ts +33 -0
- package/cli/dist/core/tui/renderer.js +218 -0
- package/cli/dist/core/tui/types.d.ts +63 -0
- package/cli/dist/core/tui/types.js +5 -0
- package/cli/dist/core/types/pack-v1.d.ts +251 -0
- package/cli/dist/core/types/pack-v1.js +5 -0
- package/cli/dist/core/types/pack-v2.d.ts +456 -0
- package/cli/dist/core/types/pack-v2.js +8 -0
- package/cli/dist/core/types/trust-score.d.ts +69 -0
- package/cli/dist/core/types/trust-score.js +191 -0
- package/cli/dist/core/vault/cas.d.ts +90 -0
- package/cli/dist/core/vault/cas.js +261 -0
- package/cli/dist/core/vault/index.d.ts +326 -0
- package/cli/dist/core/vault/index.js +1042 -0
- package/cli/dist/core/visual/index.d.ts +6 -0
- package/cli/dist/core/visual/index.js +6 -0
- package/cli/dist/core/visual/visual-regression.d.ts +113 -0
- package/cli/dist/core/visual/visual-regression.js +236 -0
- package/cli/dist/core/watch/index.d.ts +7 -0
- package/cli/dist/core/watch/index.js +6 -0
- package/cli/dist/core/watch/watch-mode.d.ts +213 -0
- package/cli/dist/core/watch/watch-mode.js +389 -0
- package/cli/dist/generators/index.d.ts +5 -0
- package/cli/dist/generators/index.js +5 -0
- package/cli/dist/generators/json-reporter.d.ts +10 -0
- package/cli/dist/generators/json-reporter.js +12 -0
- package/cli/dist/generators/test-generator.d.ts +18 -0
- package/cli/dist/generators/test-generator.js +78 -0
- package/cli/dist/index.d.ts +8 -0
- package/cli/dist/index.js +262 -0
- package/cli/dist/scanners/dom-scanner.d.ts +52 -0
- package/cli/dist/scanners/dom-scanner.js +296 -0
- package/cli/dist/scanners/index.d.ts +4 -0
- package/cli/dist/scanners/index.js +4 -0
- package/cli/dist/schemas/pack.schema.json +236 -0
- package/cli/dist/types/scan.d.ts +68 -0
- package/cli/dist/types/scan.js +4 -0
- package/cli/dist/utils/config.d.ts +35 -0
- package/cli/dist/utils/config.js +196 -0
- package/cli/package.json +1 -1
- package/package.json +26 -2
- package/.BETA_TESTING_FEEDBACK.md +0 -256
- package/.claude/settings.local.json +0 -154
- package/.editorconfig +0 -21
- package/.github/CODEOWNERS +0 -23
- package/.github/ISSUE_TEMPLATE/bug_report.yml +0 -108
- package/.github/ISSUE_TEMPLATE/feedback_dx.yml +0 -121
- package/.github/dependabot.yml +0 -35
- package/.github/workflows/mcp-dx.yml +0 -106
- package/.github/workflows/release.yml +0 -26
- package/.github/workflows/test.yml +0 -93
- package/.nvmrc +0 -1
- package/.qa360/vault.db +0 -0
- package/.qa360/vault.db-shm +0 -0
- package/.qa360/vault.db-wal +0 -0
- package/.qa360-artifacts/.gitkeep +0 -0
- package/.qa360-artifacts/baselines/.gitkeep +0 -0
- package/.qa360-artifacts/cache/.gitkeep +0 -0
- package/.qa360-artifacts/reports/.gitkeep +0 -0
- package/.qa360-artifacts/screenshots/.gitkeep +0 -0
- package/.qa360-baselines/www_xyqo_ai.baseline.json +0 -33
- package/CODEOWNERS +0 -43
- package/NOVICE_USER_GUIDE.md +0 -272
- package/adapters/README.md +0 -46
- package/check-branches.sh +0 -32
- package/cli/.qa360/keys/ed25519.key +0 -1
- package/cli/.qa360/keys/ed25519.pub +0 -1
- package/cli/examples/README.md +0 -160
- package/cli/examples/accessibility.yml +0 -48
- package/cli/examples/api-basic.yml +0 -27
- package/cli/examples/complete.yml +0 -146
- package/cli/examples/crawler.yml +0 -38
- package/cli/examples/fullstack.yml +0 -78
- package/cli/examples/security.yml +0 -58
- package/cli/examples/ui-advanced.yml +0 -49
- package/cli/examples/ui-basic.yml +0 -24
- package/cli/scripts/bundle-for-npm.sh +0 -51
- package/cli/scripts/validate-package.js +0 -116
- package/cli/src/__tests__/commands/doctor.test.ts +0 -108
- package/cli/src/__tests__/index.test.ts +0 -15
- package/cli/src/cli-minimal.ts +0 -44
- package/cli/src/commands/__tests__/crawl.test.ts +0 -412
- package/cli/src/commands/__tests__/doctor-qa360-home.test.ts +0 -156
- package/cli/src/commands/__tests__/e2e-ui-tests.test.ts +0 -494
- package/cli/src/commands/__tests__/e2e.test.ts +0 -187
- package/cli/src/commands/__tests__/flakiness.test.ts +0 -528
- package/cli/src/commands/__tests__/generate.test.ts +0 -507
- package/cli/src/commands/__tests__/history.integration.test.ts +0 -358
- package/cli/src/commands/__tests__/history.test.ts +0 -433
- package/cli/src/commands/__tests__/monitor-realworld.test.ts +0 -199
- package/cli/src/commands/__tests__/monitor.test.ts +0 -81
- package/cli/src/commands/__tests__/ollama.test.ts +0 -529
- package/cli/src/commands/__tests__/repair.test.ts +0 -225
- package/cli/src/commands/__tests__/report.integration.test.ts +0 -167
- package/cli/src/commands/__tests__/report.test.ts +0 -294
- package/cli/src/commands/__tests__/report.vitest.ts +0 -288
- package/cli/src/commands/__tests__/retry.test.ts +0 -78
- package/cli/src/commands/__tests__/run.integration.test.ts +0 -240
- package/cli/src/commands/__tests__/run.test.ts +0 -346
- package/cli/src/commands/__tests__/run.vitest.ts +0 -301
- package/cli/src/commands/__tests__/secrets.test.ts +0 -114
- package/cli/src/commands/__tests__/serve.test.ts +0 -80
- package/cli/src/commands/__tests__/verify.test.ts +0 -103
- package/cli/src/commands/ai.ts +0 -702
- package/cli/src/commands/ask.ts +0 -678
- package/cli/src/commands/coverage.ts +0 -305
- package/cli/src/commands/crawl.ts +0 -155
- package/cli/src/commands/doctor.ts +0 -610
- package/cli/src/commands/examples.ts +0 -248
- package/cli/src/commands/explain.ts +0 -710
- package/cli/src/commands/flakiness.ts +0 -560
- package/cli/src/commands/generate.ts +0 -566
- package/cli/src/commands/history.ts +0 -914
- package/cli/src/commands/init.ts +0 -777
- package/cli/src/commands/monitor.ts +0 -270
- package/cli/src/commands/ollama.ts +0 -337
- package/cli/src/commands/pack.ts +0 -497
- package/cli/src/commands/regression.ts +0 -400
- package/cli/src/commands/repair.ts +0 -356
- package/cli/src/commands/report.ts +0 -463
- package/cli/src/commands/retry.ts +0 -380
- package/cli/src/commands/run.ts +0 -220
- package/cli/src/commands/scan.ts +0 -177
- package/cli/src/commands/secrets.ts +0 -340
- package/cli/src/commands/serve.ts +0 -194
- package/cli/src/commands/slo.ts +0 -387
- package/cli/src/commands/verify-temp-note.md +0 -11
- package/cli/src/commands/verify.ts +0 -322
- package/cli/src/generators/index.ts +0 -6
- package/cli/src/generators/json-reporter.ts +0 -15
- package/cli/src/generators/test-generator.ts +0 -90
- package/cli/src/index.ts +0 -289
- package/cli/src/scanners/dom-scanner.ts +0 -360
- package/cli/src/scanners/index.ts +0 -5
- package/cli/src/types/scan.ts +0 -84
- package/cli/src/utils/config.ts +0 -145
- package/cli/tsconfig.bundle.json +0 -12
- package/cli/tsconfig.json +0 -23
- package/cli/vitest.config.ts +0 -59
- package/core/src/__tests__/adapters-contract/adapters-contract.test.md +0 -156
- package/core/src/__tests__/index.test.ts +0 -31
- package/core/src/__tests__/integration/phase3.test.ts +0 -405
- package/core/src/__tests__/pack/validator.test.ts +0 -312
- package/core/src/__tests__/secrets/crypto.test.ts +0 -190
- package/core/src/__tests__/secrets/manager.test.ts +0 -316
- package/core/src/__tests__/security/redactor-phase3.test.ts +0 -233
- package/core/src/__tests__/serve/health-checker.test.ts +0 -155
- package/core/src/__tests__/serve/process-manager.test.ts +0 -213
- package/core/src/__tests__/serve/server.test.ts +0 -103
- package/core/src/__tests__/vault/cas.test.ts +0 -178
- package/core/src/__tests__/vault/vault.test.ts +0 -296
- package/core/src/adapters/__tests__/fixtures/jest-coverage.json +0 -8
- package/core/src/adapters/__tests__/fixtures/jest-results.json +0 -41
- package/core/src/adapters/__tests__/fixtures/pytest-junit.xml +0 -16
- package/core/src/adapters/__tests__/fixtures/vitest-coverage.json +0 -8
- package/core/src/adapters/__tests__/fixtures/vitest-results.json +0 -50
- package/core/src/adapters/__tests__/gitleaks-secrets.test.ts +0 -452
- package/core/src/adapters/__tests__/jest-adapter.test.ts +0 -276
- package/core/src/adapters/__tests__/k6-perf.test.ts +0 -538
- package/core/src/adapters/__tests__/osv-deps.test.ts +0 -471
- package/core/src/adapters/__tests__/playwright-native-api.test.ts +0 -792
- package/core/src/adapters/__tests__/playwright-ui-e2e.test.ts +0 -431
- package/core/src/adapters/__tests__/playwright-ui.test.ts +0 -1073
- package/core/src/adapters/__tests__/pytest-adapter.test.ts +0 -207
- package/core/src/adapters/__tests__/semgrep-sast.test.ts +0 -436
- package/core/src/adapters/__tests__/vitest-adapter.test.ts +0 -208
- package/core/src/adapters/__tests__/zap-dast.test.ts +0 -453
- package/core/src/adapters/gitleaks-secrets.ts +0 -521
- package/core/src/adapters/jest-adapter.ts +0 -306
- package/core/src/adapters/k6-perf.ts +0 -479
- package/core/src/adapters/osv-deps.ts +0 -467
- package/core/src/adapters/playwright-native-adapter.ts +0 -472
- package/core/src/adapters/playwright-native-api.ts +0 -619
- package/core/src/adapters/playwright-ui.ts +0 -1088
- package/core/src/adapters/pytest-adapter.ts +0 -472
- package/core/src/adapters/semgrep-sast.ts +0 -410
- package/core/src/adapters/unit-test-types.ts +0 -106
- package/core/src/adapters/vitest-adapter.ts +0 -295
- package/core/src/adapters/zap-dast.ts +0 -551
- package/core/src/ai/__tests__/deepseek-provider.test.ts +0 -586
- package/core/src/ai/__tests__/ollama-provider.test.ts +0 -641
- package/core/src/ai/anthropic-provider.ts +0 -262
- package/core/src/ai/deepseek-provider.ts +0 -315
- package/core/src/ai/index.ts +0 -87
- package/core/src/ai/llm-client.ts +0 -52
- package/core/src/ai/mock-provider.ts +0 -146
- package/core/src/ai/ollama-provider.ts +0 -269
- package/core/src/ai/openai-provider.ts +0 -240
- package/core/src/ai/provider-factory.ts +0 -408
- package/core/src/artifacts/README.md +0 -78
- package/core/src/artifacts/index.ts +0 -16
- package/core/src/artifacts/ui-artifacts.ts +0 -412
- package/core/src/assertions/__tests__/engine.test.ts +0 -360
- package/core/src/assertions/engine.ts +0 -577
- package/core/src/assertions/index.ts +0 -13
- package/core/src/assertions/types.ts +0 -229
- package/core/src/auth/__tests__/api-key-provider.test.ts +0 -282
- package/core/src/auth/__tests__/auth-manager.test.ts +0 -430
- package/core/src/auth/__tests__/basic-auth-provider.test.ts +0 -364
- package/core/src/auth/__tests__/cloud-providers.test.ts +0 -751
- package/core/src/auth/__tests__/jwt-provider.test.ts +0 -400
- package/core/src/auth/__tests__/oauth2-provider.test.ts +0 -383
- package/core/src/auth/__tests__/totp-provider.test.ts +0 -294
- package/core/src/auth/__tests__/ui-login-provider.test.ts +0 -323
- package/core/src/auth/api-key-provider.ts +0 -75
- package/core/src/auth/aws-iam-provider.ts +0 -212
- package/core/src/auth/azure-ad-provider.ts +0 -126
- package/core/src/auth/basic-auth-provider.ts +0 -133
- package/core/src/auth/gcp-adc-provider.ts +0 -146
- package/core/src/auth/index.ts +0 -342
- package/core/src/auth/jwt-provider.ts +0 -193
- package/core/src/auth/manager.ts +0 -281
- package/core/src/auth/oauth2-provider.ts +0 -141
- package/core/src/auth/totp-provider.ts +0 -163
- package/core/src/auth/ui-login-provider.ts +0 -242
- package/core/src/cache/__tests__/lru-cache.test.ts +0 -564
- package/core/src/cache/index.ts +0 -13
- package/core/src/cache/lru-cache.ts +0 -536
- package/core/src/crawler/__tests__/journey-generator.test.ts +0 -344
- package/core/src/crawler/__tests__/selector-generator.test.ts +0 -211
- package/core/src/crawler/index.ts +0 -335
- package/core/src/crawler/journey-generator.ts +0 -471
- package/core/src/crawler/page-analyzer.ts +0 -857
- package/core/src/crawler/selector-generator.ts +0 -280
- package/core/src/crawler/types.ts +0 -475
- package/core/src/dashboard/__tests__/real-world.test.ts +0 -430
- package/core/src/dashboard/__tests__/server.test.ts +0 -283
- package/core/src/dashboard/__tests__/types.test.ts +0 -208
- package/core/src/dashboard/assets.ts +0 -692
- package/core/src/dashboard/index.ts +0 -17
- package/core/src/dashboard/server.ts +0 -401
- package/core/src/dashboard/types.ts +0 -78
- package/core/src/discoverer/__tests__/test-discoverer.test.ts +0 -444
- package/core/src/discoverer/index.ts +0 -374
- package/core/src/fixtures/__tests__/loader.test.ts +0 -246
- package/core/src/fixtures/__tests__/resolver.test.ts +0 -334
- package/core/src/fixtures/index.ts +0 -9
- package/core/src/fixtures/loader.ts +0 -200
- package/core/src/fixtures/resolver.ts +0 -221
- package/core/src/fixtures/types.ts +0 -86
- package/core/src/flakiness/__tests__/flakiness.test.ts +0 -554
- package/core/src/flakiness/index.ts +0 -536
- package/core/src/generation/__tests__/code-formatter.test.ts +0 -170
- package/core/src/generation/__tests__/code-generator-contract.test.ts +0 -207
- package/core/src/generation/__tests__/code-generator.test.ts +0 -586
- package/core/src/generation/__tests__/crawler-pack-generator.test.ts +0 -479
- package/core/src/generation/__tests__/generation-e2e-b2bshop.test.ts +0 -718
- package/core/src/generation/__tests__/generation-integration.test.ts +0 -655
- package/core/src/generation/__tests__/pack-generator.test.ts +0 -408
- package/core/src/generation/__tests__/prompt-builder.test.ts +0 -200
- package/core/src/generation/__tests__/real-provider-integration.test.ts +0 -414
- package/core/src/generation/__tests__/source-analyzer.test.ts +0 -774
- package/core/src/generation/__tests__/test-optimizer.test.ts +0 -255
- package/core/src/generation/code-formatter.ts +0 -408
- package/core/src/generation/code-generator.ts +0 -470
- package/core/src/generation/crawler-pack-generator.ts +0 -289
- package/core/src/generation/generator.ts +0 -113
- package/core/src/generation/index.ts +0 -59
- package/core/src/generation/pack-generator.ts +0 -527
- package/core/src/generation/prompt-builder.ts +0 -772
- package/core/src/generation/source-analyzer.ts +0 -830
- package/core/src/generation/test-optimizer.ts +0 -474
- package/core/src/generation/types.ts +0 -217
- package/core/src/hooks/__tests__/compose.test.ts +0 -636
- package/core/src/hooks/__tests__/runner.test.ts +0 -478
- package/core/src/hooks/compose.ts +0 -268
- package/core/src/hooks/runner.ts +0 -364
- package/core/src/index.ts +0 -255
- package/core/src/pack/__tests__/migrator.test.ts +0 -594
- package/core/src/pack/__tests__/validator.test.ts +0 -759
- package/core/src/pack/migrator.ts +0 -353
- package/core/src/pack/validator.ts +0 -359
- package/core/src/pack-v2/__tests__/loader.test.ts +0 -533
- package/core/src/pack-v2/__tests__/migrator.test.ts +0 -455
- package/core/src/pack-v2/__tests__/validator.test.ts +0 -609
- package/core/src/pack-v2/index.ts +0 -41
- package/core/src/pack-v2/loader.ts +0 -358
- package/core/src/pack-v2/migrator.ts +0 -540
- package/core/src/pack-v2/validator.ts +0 -731
- package/core/src/parallel/README.md +0 -143
- package/core/src/parallel/index.ts +0 -16
- package/core/src/parallel/parallel-runner.ts +0 -282
- package/core/src/pom/__tests__/loader.test.ts +0 -378
- package/core/src/pom/base-page.ts +0 -425
- package/core/src/pom/index.ts +0 -45
- package/core/src/pom/loader.ts +0 -480
- package/core/src/pom/types.ts +0 -146
- package/core/src/proof/__tests__/proof-roundtrip.test.ts +0 -149
- package/core/src/proof/__tests__/schema-validation-manual.mjs +0 -211
- package/core/src/proof/__tests__/schema-validation.test.ts +0 -336
- package/core/src/proof/__tests__/signer.test.ts +0 -486
- package/core/src/proof/__tests__/temporal-regression.test.ts +0 -537
- package/core/src/proof/__tests__/verifier-advanced.test.ts +0 -588
- package/core/src/proof/__tests__/verifier.test.ts +0 -413
- package/core/src/proof/bundle.ts +0 -290
- package/core/src/proof/canonicalize.ts +0 -116
- package/core/src/proof/index.ts +0 -74
- package/core/src/proof/schema.ts +0 -285
- package/core/src/proof/signer.ts +0 -293
- package/core/src/proof/verifier.ts +0 -380
- package/core/src/regression/__tests__/detector.test.ts +0 -396
- package/core/src/regression/__tests__/trend-analyzer.test.ts +0 -300
- package/core/src/regression/detector.ts +0 -629
- package/core/src/regression/index.ts +0 -34
- package/core/src/regression/trend-analyzer.ts +0 -468
- package/core/src/regression/types.ts +0 -295
- package/core/src/regression/vault.ts +0 -419
- package/core/src/repair/__tests__/repairer.test.ts +0 -572
- package/core/src/repair/__tests__/types.test.ts +0 -302
- package/core/src/repair/engine/__tests__/fixer.test.ts +0 -482
- package/core/src/repair/engine/__tests__/suggestion-engine.test.ts +0 -395
- package/core/src/repair/engine/fixer.ts +0 -271
- package/core/src/repair/engine/suggestion-engine.ts +0 -234
- package/core/src/repair/index.ts +0 -53
- package/core/src/repair/repairer.ts +0 -376
- package/core/src/repair/types.ts +0 -119
- package/core/src/repair/utils/__tests__/error-analyzer.test.ts +0 -454
- package/core/src/repair/utils/error-analyzer.ts +0 -308
- package/core/src/reporting/README.md +0 -144
- package/core/src/reporting/html-reporter.ts +0 -835
- package/core/src/reporting/index.ts +0 -16
- package/core/src/retry/README.md +0 -192
- package/core/src/retry/__tests__/flakiness-integration.test.ts +0 -475
- package/core/src/retry/__tests__/retry-engine.test.ts +0 -424
- package/core/src/retry/flakiness-integration.ts +0 -267
- package/core/src/retry/index.ts +0 -48
- package/core/src/retry/retry-engine.ts +0 -368
- package/core/src/retry/types.ts +0 -208
- package/core/src/retry/vault.ts +0 -413
- package/core/src/runner/__tests__/flakiness-integration.test.ts +0 -566
- package/core/src/runner/__tests__/phase3-e2e-b2bshop.test.ts +0 -218
- package/core/src/runner/__tests__/phase3-e2e-reqres.test.ts +0 -199
- package/core/src/runner/__tests__/phase3-runner.test.ts +0 -1118
- package/core/src/runner/e2e-helpers.ts +0 -216
- package/core/src/runner/phase3-runner.ts +0 -1536
- package/core/src/schemas/gherkin-report.json +0 -122
- package/core/src/secrets/__tests__/crypto.test.ts +0 -180
- package/core/src/secrets/crypto.ts +0 -289
- package/core/src/secrets/manager.ts +0 -272
- package/core/src/security/__tests__/hardening.test.ts +0 -480
- package/core/src/security/redaction-patterns-extended.ts +0 -278
- package/core/src/security/redactor.ts +0 -326
- package/core/src/self-healing/assertion-healer.ts +0 -485
- package/core/src/self-healing/engine.ts +0 -626
- package/core/src/self-healing/index.ts +0 -33
- package/core/src/self-healing/selector-healer.ts +0 -488
- package/core/src/self-healing/types.ts +0 -193
- package/core/src/serve/diagnostics-collector.ts +0 -201
- package/core/src/serve/health-checker.ts +0 -274
- package/core/src/serve/index.ts +0 -9
- package/core/src/serve/metrics-collector.ts +0 -386
- package/core/src/serve/process-manager.ts +0 -265
- package/core/src/serve/server.ts +0 -230
- package/core/src/slo/config.ts +0 -408
- package/core/src/slo/index.ts +0 -68
- package/core/src/slo/sli-calculator.ts +0 -474
- package/core/src/slo/slo-tracker.ts +0 -481
- package/core/src/slo/types.ts +0 -408
- package/core/src/slo/vault.ts +0 -600
- package/core/src/tui/__tests__/monitor.test.ts +0 -336
- package/core/src/tui/__tests__/real-world.test.ts +0 -376
- package/core/src/tui/__tests__/renderer.test.ts +0 -201
- package/core/src/tui/__tests__/types.test.ts +0 -295
- package/core/src/tui/index.ts +0 -19
- package/core/src/tui/monitor.ts +0 -331
- package/core/src/tui/renderer.ts +0 -269
- package/core/src/tui/types.ts +0 -68
- package/core/src/types/pack-v1.ts +0 -305
- package/core/src/types/pack-v2.ts +0 -525
- package/core/src/types/trust-score.ts +0 -258
- package/core/src/vault/__tests__/flakiness-vault.test.ts +0 -562
- package/core/src/vault/__tests__/vault.test.ts +0 -259
- package/core/src/vault/cas.ts +0 -323
- package/core/src/vault/index.ts +0 -1361
- package/core/src/vault/schema.sql +0 -168
- package/core/src/visual/README.md +0 -185
- package/core/src/visual/index.ts +0 -14
- package/core/src/visual/visual-regression.ts +0 -347
- package/core/src/watch/__tests__/watch-mode.test.ts +0 -192
- package/core/src/watch/index.ts +0 -14
- package/core/src/watch/watch-mode.ts +0 -565
- package/core/tsconfig.json +0 -12
- package/core/vitest.config.ts +0 -52
- package/docs/ARCHITECTURE.md +0 -901
- package/docs/AUDIT-GLOBAL-DEC2025.md +0 -271
- package/docs/BETA_TESTING.md +0 -257
- package/docs/BETA_TESTING_PLAN.md +0 -727
- package/docs/CERTIFICATION-REPORT.md +0 -142
- package/docs/COMPLETE_AUDIT_REFACTORING.md +0 -965
- package/docs/DEVELOPMENT.md +0 -545
- package/docs/DEVELOPMENT_HISTORY.md +0 -345
- package/docs/LIMITATIONS.md +0 -176
- package/docs/MIGRATION.md +0 -303
- package/docs/OPTION_3_4_EXPLORATION.md +0 -1257
- package/docs/PHASE1_PERFORMANCE.md +0 -144
- package/docs/QA360_Cloud.postman_collection.json +0 -89
- package/docs/QA360_TESTING_PHILOSOPHY.md +0 -769
- package/docs/QA_TEST_PLAN.md +0 -727
- package/docs/README.md +0 -50
- package/docs/STATUS.md +0 -198
- package/docs/STRATEGIC_STUDY_GOOSE_INTEGRATION.md +0 -615
- package/docs/USER_GUIDE.md +0 -687
- package/docs/WORK-DONE-ADAPTER-TESTS.md +0 -136
- package/docs/adapters-security.md +0 -485
- package/docs/architecture-diagram.mmd +0 -168
- package/docs/archive/ARCH-01-DAY6-BUILD-FIXES.md +0 -396
- package/docs/archive/ARCH-01-DAY6-FINAL-STATUS.md +0 -324
- package/docs/archive/ARCH-01_MCP_MERGE_ANALYSIS.md +0 -644
- package/docs/archive/ARCH-01_NEXT_STEPS.md +0 -60
- package/docs/archive/BRANCH_PROTECTION.md +0 -183
- package/docs/archive/CI_LOCKDOWN_CHECKLIST.md +0 -222
- package/docs/archive/HANDOFF_TEST-01.md +0 -669
- package/docs/archive/LEGAL_READY_PLACEHOLDERS.md +0 -372
- package/docs/archive/NODE_UPGRADE_GUIDE.md +0 -188
- package/docs/archive/PHASE1_COMPLETION.md +0 -386
- package/docs/archive/PHASE2_COMPLETION.md +0 -404
- package/docs/archive/PHASE3_AND_4_FINAL.md +0 -360
- package/docs/archive/PHASE3_COMPLETE.md +0 -301
- package/docs/archive/PHASE3_STATUS.md +0 -255
- package/docs/archive/PRE-WEEK2-AUDIT.md +0 -364
- package/docs/archive/README.md +0 -16
- package/docs/archive/SCHEMA_AJV_2020_FIX.md +0 -245
- package/docs/archive/TEST-01_AUDIT_REPORT.md +0 -240
- package/docs/archive/TEST-01_COVERAGE_PLAN.md +0 -423
- package/docs/archive/obsolete-proposals/dom-element-discovery-mode.md +0 -250
- package/docs/archive/obsolete-proposals/qa360-comprehensive-test-plan.md +0 -1249
- package/docs/archive/obsolete-proposals/qa360-quick-start-guide.md +0 -298
- package/docs/archive/obsolete-proposals/technical-plan-dom-discovery.md +0 -870
- package/docs/budgets-advanced.md +0 -308
- package/docs/examples/history-export-gc.md +0 -285
- package/docs/examples/pack-v2-complete.yaml +0 -158
- package/docs/examples/pack-v2-quickstart.yaml +0 -24
- package/docs/examples/pack-v2-ui-login.yaml +0 -81
- package/docs/examples/qa360-report.json +0 -50
- package/docs/history.md +0 -565
- package/docs/hooks.md +0 -304
- package/docs/llm-providers.md +0 -512
- package/docs/mcp-server.md +0 -651
- package/docs/mcp-tools.md +0 -1131
- package/docs/pack-v1.md +0 -383
- package/docs/pack-v2.md +0 -558
- package/docs/page-objects.md +0 -366
- package/docs/proofs.md +0 -670
- package/docs/quickstart-5min.md +0 -257
- package/docs/readiness-ci.md +0 -654
- package/docs/rfc/README.md +0 -20
- package/docs/rfc/proof-bundle-v1.md +0 -787
- package/docs/secrets.md +0 -392
- package/docs/serve.md +0 -494
- package/docs/unit-test-adapters.md +0 -168
- package/docs/vault.md +0 -491
- package/e2e/qa360-e2e.test.ts +0 -696
- package/e2e/vitest.config.ts +0 -18
- package/examples/README.md +0 -50
- package/examples/ci/docker-compose-serve.yml +0 -375
- package/examples/ci/github-actions-serve.yml +0 -345
- package/examples/ci/gitlab-ci-serve.yml +0 -407
- package/examples/datasets/README.md +0 -101
- package/examples/datasets/b2bshop.ts +0 -155
- package/examples/datasets/index.ts +0 -57
- package/examples/datasets/reqres.ts +0 -195
- package/examples/fixtures-demo/fixtures/users.yml +0 -39
- package/examples/fixtures-demo/pack.yml +0 -71
- package/examples/future-api/README.md +0 -16
- package/examples/future-api/diag.js +0 -7
- package/examples/future-api/health.js +0 -4
- package/examples/future-api/packs.js +0 -13
- package/examples/future-api/runpack.js +0 -10
- package/examples/generation/README.md +0 -148
- package/examples/generation/pack-generator-example.js +0 -115
- package/examples/generation/source-analyzer-example.js +0 -115
- package/examples/httpbin/pack.yml +0 -59
- package/examples/load-testing/mcp-load.yml +0 -115
- package/examples/load-testing/mcp-stdio.yml +0 -95
- package/examples/mcp/claude-desktop-config.json +0 -33
- package/examples/mcp/claude-desktop.json +0 -16
- package/examples/mcp/conversation-sample.md +0 -131
- package/examples/mcp/demo-60s.md +0 -330
- package/examples/mcp/sample-conversation.jsonl +0 -21
- package/examples/mcp/vscode-settings.json +0 -22
- package/examples/pack-v2-complete.yml +0 -242
- package/examples/pack-v2-examples.md +0 -244
- package/examples/pack-v2-quickstart.yml +0 -55
- package/examples/packs-business/ecommerce-api.yml +0 -121
- package/examples/packs-business/saas-dashboard-ui.yml +0 -133
- package/examples/packs-conformance/compose-multi.yml +0 -174
- package/examples/packs-conformance/full.yml +0 -152
- package/examples/packs-conformance/heavy-artifacts.yml +0 -152
- package/examples/packs-conformance/minimal.yml +0 -71
- package/examples/packs-conformance/secrets-missing.yml +0 -97
- package/examples/packs-conformance/timeouts.yml +0 -77
- package/examples/pom-demo/README.md +0 -104
- package/examples/pom-demo/pack.yml +0 -60
- package/examples/pom-demo/pages/DashboardPage.page.ts +0 -73
- package/examples/pom-demo/pages/LoginPage.page.ts +0 -76
- package/examples/proofs/e2e-playwright-proof.json +0 -75
- package/examples/proofs/httpbin-proof.json +0 -69
- package/examples/proofs/multi-adapter-proof.json +0 -117
- package/examples/proofs/test-proof.json +0 -26
- package/examples/restful-api-dev/README.md +0 -102
- package/examples/restful-api-dev/restful-api-advanced.yml +0 -29
- package/examples/restful-api-dev/restful-api-basic.yml +0 -29
- package/examples/web-lite/.github/workflows/qa360-phase3.yml +0 -73
- package/examples/web-lite/api-mock/server.js +0 -258
- package/examples/web-lite/pack.yml +0 -71
- package/examples/web-lite/services.yml +0 -43
- package/examples/web-lite/web-content/healthz +0 -1
- package/examples/web-lite/web-content/index.html +0 -259
- package/packages/mcp/CHANGELOG.md +0 -109
- package/packages/mcp/IMPLEMENTATION_SUMMARY.md +0 -350
- package/packages/mcp/LICENSE +0 -21
- package/packages/mcp/QUICK_START.md +0 -291
- package/packages/mcp/README.md +0 -294
- package/packages/mcp/TELEMETRY.md +0 -220
- package/packages/mcp/package.json +0 -91
- package/packages/mcp/scripts/generate-sbom-fallback.cjs +0 -84
- package/packages/mcp/scripts/safe-postinstall.cjs +0 -32
- package/packages/mcp/src/__tests__/contract.test.ts +0 -902
- package/packages/mcp/src/cli/cli.ts +0 -137
- package/packages/mcp/src/cli/doctor.ts +0 -286
- package/packages/mcp/src/cli/fix.ts +0 -99
- package/packages/mcp/src/cli/init.ts +0 -233
- package/packages/mcp/src/cli/postinstall.ts +0 -14
- package/packages/mcp/src/cli/reset.ts +0 -44
- package/packages/mcp/src/cli/telemetry.ts +0 -166
- package/packages/mcp/src/cli/test-dx.ts +0 -94
- package/packages/mcp/src/cli/uninstall.ts +0 -80
- package/packages/mcp/src/cli/up.ts +0 -178
- package/packages/mcp/src/index.ts +0 -12
- package/packages/mcp/src/scripts/e2e-local.ts +0 -337
- package/packages/mcp/src/scripts/verify-settings.ts +0 -242
- package/packages/mcp/src/security/audit.ts +0 -244
- package/packages/mcp/src/security/manager.ts +0 -242
- package/packages/mcp/src/server/full-server.ts +0 -212
- package/packages/mcp/src/server/minimal-server.ts +0 -134
- package/packages/mcp/src/tools/history.ts +0 -388
- package/packages/mcp/src/tools/pack.ts +0 -449
- package/packages/mcp/src/tools/registry.ts +0 -638
- package/packages/mcp/src/tools/report.ts +0 -100
- package/packages/mcp/src/tools/run.ts +0 -268
- package/packages/mcp/src/tools/secrets.ts +0 -198
- package/packages/mcp/src/tools/serve.ts +0 -221
- package/packages/mcp/src/tools/triage.ts +0 -532
- package/packages/mcp/src/tools/types.ts +0 -26
- package/packages/mcp/src/tools/vault.ts +0 -164
- package/packages/mcp/src/tools/verify.ts +0 -166
- package/packages/mcp/src/types/index.ts +0 -311
- package/packages/mcp/src/types/mcp-stubs.ts +0 -83
- package/packages/mcp/tsconfig.json +0 -16
- package/playwright.config.ts +0 -20
- package/pnpm-workspace.yaml +0 -4
- package/run-test-and-push.sh +0 -20
- package/scripts/build-proof-cli.sh +0 -110
- package/scripts/ci/check-windows-paths.js +0 -92
- package/scripts/ci/invariants.sh +0 -124
- package/scripts/ci/make-final-bundle.js +0 -106
- package/scripts/ci/mcp-run-multipack.js +0 -305
- package/scripts/ci/run-pack-suite.sh +0 -103
- package/scripts/ci/run-phase7-final.sh +0 -190
- package/scripts/ci/slo-assert.js +0 -158
- package/scripts/ci/test-fault-tolerance.sh +0 -301
- package/scripts/install-mcp.sh +0 -66
- package/scripts/mcp-smoke.mjs +0 -27
- package/scripts/smoke.sh +0 -26
- package/scripts/stress-test.js +0 -288
- package/scripts/sync-version.mjs +0 -50
- package/scripts/validate-examples.mjs +0 -404
- package/scripts/validation/simple-pack-check.sh +0 -51
- package/scripts/validation/validate-universal-pack.mjs +0 -77
- package/scripts/verify-persistence.js +0 -127
- package/test-pack.yaml +0 -43
- package/test-results/.last-run.json +0 -4
- package/test-runner.mjs +0 -87
- package/tests/artifacts.spec.js +0 -147
- package/tests/contracts.spec.js +0 -239
- package/tests/e2e/assertions.test.mjs +0 -370
- package/tests/e2e/crawler.test.mjs +0 -451
- package/tests/e2e/playwright-plus-plus.test.mjs +0 -604
- package/tests/e2e/proof-bundle.test.mjs +0 -258
- package/tests/e2e/real-world/saucedemo.test.mjs +0 -714
- package/tests/e2e/real-world/the-internet-herokuapp.test.mjs +0 -760
- package/tests/e2e/ui-actions.test.mjs +0 -546
- package/tests/gherkin.e2e.spec.ts +0 -310
- package/tests/no-console-errors.spec.js +0 -136
- package/tests/pdf.spec.ts +0 -252
- package/tests/run-pack.spec.ts +0 -58
- package/tsconfig.base.json +0 -15
- package/tsconfig.build.json +0 -8
- package/tsconfig.json +0 -37
- package/tsconfig.test.json +0 -18
- package/typedoc.json +0 -37
- package/ui/README.md +0 -50
- package/verify-proof.mjs +0 -60
|
@@ -1,1257 +0,0 @@
|
|
|
1
|
-
# Exploration Détaillée : Options 3 & 4
|
|
2
|
-
|
|
3
|
-
**Date** : 31 Décembre 2024
|
|
4
|
-
**Sujet** : Intégration IA pour QA360 - LLM Direct vs MCP Server
|
|
5
|
-
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
## Table des Matières
|
|
9
|
-
|
|
10
|
-
1. [Option 3 : Intégration LLM Directe](#option-3)
|
|
11
|
-
2. [Option 4 : Enhancement MCP Server](#option-4)
|
|
12
|
-
3. [Comparaison Détaillée](#comparaison)
|
|
13
|
-
4. [Recommandation Stratégique](#recommandation)
|
|
14
|
-
|
|
15
|
-
---
|
|
16
|
-
|
|
17
|
-
## Option 3 : Intégration LLM Directe {#option-3}
|
|
18
|
-
|
|
19
|
-
### Concept
|
|
20
|
-
|
|
21
|
-
Intégrer directement des providers LLM (OpenAI, Anthropic, etc.) dans QA360 pour générer des tests de manière intelligente.
|
|
22
|
-
|
|
23
|
-
### Architecture Proposée
|
|
24
|
-
|
|
25
|
-
```
|
|
26
|
-
┌─────────────────────────────────────────────────────────────────────────┐
|
|
27
|
-
│ QA360 CLI │
|
|
28
|
-
├─────────────────────────────────────────────────────────────────────────┤
|
|
29
|
-
│ │
|
|
30
|
-
│ ┌────────────────────────────────────────────────────────────────────┐ │
|
|
31
|
-
│ │ New: AI Module │ │
|
|
32
|
-
│ │ ┌────────────────┐ ┌────────────────┐ ┌────────────────────┐ │ │
|
|
33
|
-
│ │ │ LLM Provider │ │ Test Generator │ │ Smart Triage │ │ │
|
|
34
|
-
│ │ │ Abstraction │ │ │ │ │ │ │
|
|
35
|
-
│ │ └────────────────┘ └────────────────┘ └────────────────────┘ │ │
|
|
36
|
-
│ └────────────────────────────────────────────────────────────────────┘ │
|
|
37
|
-
│ ↓ │
|
|
38
|
-
│ ┌────────────────────────────────────────────────────────────────────┐ │
|
|
39
|
-
│ │ Existing: Commands │ │
|
|
40
|
-
│ │ ask | generate | triage | fix | chat │ │
|
|
41
|
-
│ └────────────────────────────────────────────────────────────────────┘ │
|
|
42
|
-
│ ↓ │
|
|
43
|
-
│ ┌────────────────────────────────────────────────────────────────────┐ │
|
|
44
|
-
│ │ Core Execution │ │
|
|
45
|
-
│ │ Phase3Runner → Adapters → Vault → Proof │ │
|
|
46
|
-
│ └────────────────────────────────────────────────────────────────────┘ │
|
|
47
|
-
│ │
|
|
48
|
-
└─────────────────────────────────────────────────────────────────────────┘
|
|
49
|
-
```
|
|
50
|
-
|
|
51
|
-
### Implémentation Technique
|
|
52
|
-
|
|
53
|
-
#### 1. Abstraction Multi-Provider
|
|
54
|
-
|
|
55
|
-
```typescript
|
|
56
|
-
// core/src/ai/providers/base.ts
|
|
57
|
-
export interface LLMProvider {
|
|
58
|
-
name: string;
|
|
59
|
-
models: string[];
|
|
60
|
-
generate(request: GenerationRequest): Promise<GenerationResponse>;
|
|
61
|
-
stream?(request: GenerationRequest): AsyncIterable<string>;
|
|
62
|
-
countTokens(text: string): number;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
export interface GenerationRequest {
|
|
66
|
-
prompt: string;
|
|
67
|
-
systemPrompt?: string;
|
|
68
|
-
maxTokens?: number;
|
|
69
|
-
temperature?: number;
|
|
70
|
-
jsonMode?: boolean; // Pour output structuré
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
export interface GenerationResponse {
|
|
74
|
-
content: string;
|
|
75
|
-
usage: {
|
|
76
|
-
promptTokens: number;
|
|
77
|
-
completionTokens: number;
|
|
78
|
-
totalTokens: number;
|
|
79
|
-
};
|
|
80
|
-
model: string;
|
|
81
|
-
finishReason: 'stop' | 'length' | 'content_filter';
|
|
82
|
-
}
|
|
83
|
-
```
|
|
84
|
-
|
|
85
|
-
#### 2. Implémentations Providers
|
|
86
|
-
|
|
87
|
-
```typescript
|
|
88
|
-
// core/src/ai/providers/openai.ts
|
|
89
|
-
export class OpenAIProvider implements LLMProvider {
|
|
90
|
-
name = 'openai';
|
|
91
|
-
models = ['gpt-4o', 'gpt-4o-mini', 'gpt-3.5-turbo'];
|
|
92
|
-
|
|
93
|
-
constructor(private client: OpenAI) {}
|
|
94
|
-
|
|
95
|
-
async generate(request: GenerationRequest): Promise<GenerationResponse> {
|
|
96
|
-
const response = await this.client.responses.create({
|
|
97
|
-
model: 'gpt-4o',
|
|
98
|
-
input: request.prompt,
|
|
99
|
-
});
|
|
100
|
-
// ...
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
// core/src/ai/providers/anthropic.ts
|
|
105
|
-
export class AnthropicProvider implements LLMProvider {
|
|
106
|
-
name = 'anthropic';
|
|
107
|
-
models = ['claude-sonnet-4-20250514', 'claude-opus-4-20250514', 'claude-haiku-4-20250514'];
|
|
108
|
-
|
|
109
|
-
constructor(private client: Anthropic) {}
|
|
110
|
-
|
|
111
|
-
async generate(request: GenerationRequest): Promise<GenerationResponse> {
|
|
112
|
-
const response = await this.client.messages.create({
|
|
113
|
-
model: 'claude-sonnet-4-20250514',
|
|
114
|
-
max_tokens: request.maxTokens || 4096,
|
|
115
|
-
messages: [{ role: 'user', content: request.prompt }],
|
|
116
|
-
});
|
|
117
|
-
// ...
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
// core/src/ai/providers/ollama.ts (pour local)
|
|
122
|
-
export class OllamaProvider implements LLMProvider {
|
|
123
|
-
name = 'ollama';
|
|
124
|
-
models = ['llama3.2', 'mistral', 'codellama', 'deepseek-coder'];
|
|
125
|
-
|
|
126
|
-
constructor(private baseUrl: string = 'http://localhost:11434') {}
|
|
127
|
-
|
|
128
|
-
async generate(request: GenerationRequest): Promise<GenerationResponse> {
|
|
129
|
-
const response = await fetch(`${this.baseUrl}/api/generate`, {
|
|
130
|
-
method: 'POST',
|
|
131
|
-
body: JSON.stringify({
|
|
132
|
-
model: 'llama3.2',
|
|
133
|
-
prompt: request.prompt,
|
|
134
|
-
stream: false,
|
|
135
|
-
}),
|
|
136
|
-
});
|
|
137
|
-
// ...
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
```
|
|
141
|
-
|
|
142
|
-
#### 3. Provider Manager avec Fallback
|
|
143
|
-
|
|
144
|
-
```typescript
|
|
145
|
-
// core/src/ai/manager.ts
|
|
146
|
-
export class LLMManager {
|
|
147
|
-
private providers: Map<string, LLMProvider> = new Map();
|
|
148
|
-
private primary: LLMProvider;
|
|
149
|
-
private fallback?: LLMProvider;
|
|
150
|
-
|
|
151
|
-
constructor(config: LLMConfig) {
|
|
152
|
-
// Initialiser providers
|
|
153
|
-
if (config.openai) {
|
|
154
|
-
this.providers.set('openai', new OpenAIProvider(config.openai.apiKey));
|
|
155
|
-
}
|
|
156
|
-
if (config.anthropic) {
|
|
157
|
-
this.providers.set('anthropic', new AnthropicProvider(config.anthropic.apiKey));
|
|
158
|
-
}
|
|
159
|
-
if (config.ollama) {
|
|
160
|
-
this.providers.set('ollama', new OllamaProvider(config.ollama.baseUrl));
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
this.primary = this.providers.get(config.primary) || this.providers.values().next().value;
|
|
164
|
-
this.fallback = config.fallback ? this.providers.get(config.fallback) : undefined;
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
async generate(request: GenerationRequest): Promise<GenerationResponse> {
|
|
168
|
-
try {
|
|
169
|
-
return await this.primary.generate(request);
|
|
170
|
-
} catch (error) {
|
|
171
|
-
if (this.fallback) {
|
|
172
|
-
console.warn(`Primary provider failed, trying fallback: ${error}`);
|
|
173
|
-
return await this.fallback.generate(request);
|
|
174
|
-
}
|
|
175
|
-
throw error;
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
// Optimisation coût : utiliser petit modèle pour résumés
|
|
180
|
-
async generateSummary(longText: string): Promise<string> {
|
|
181
|
-
const smallProvider = this.findCheapest();
|
|
182
|
-
const response = await smallProvider.generate({
|
|
183
|
-
prompt: `Summarize concisely: ${longText}`,
|
|
184
|
-
maxTokens: 500,
|
|
185
|
-
});
|
|
186
|
-
return response.content;
|
|
187
|
-
}
|
|
188
|
-
}
|
|
189
|
-
```
|
|
190
|
-
|
|
191
|
-
#### 4. Test Generator
|
|
192
|
-
|
|
193
|
-
```typescript
|
|
194
|
-
// core/src/ai/generators/test-generator.ts
|
|
195
|
-
export class TestGenerator {
|
|
196
|
-
constructor(private llm: LLMManager) {}
|
|
197
|
-
|
|
198
|
-
async generateFromOpenAPI(spec: OpenAPISpec): Promise<PackConfig> {
|
|
199
|
-
const systemPrompt = `You are a QA test generation expert. Generate a comprehensive QA360 pack YAML from OpenAPI spec.
|
|
200
|
-
|
|
201
|
-
Output format (JSON):
|
|
202
|
-
{
|
|
203
|
-
"name": "pack-name",
|
|
204
|
-
"version": "1.0.0",
|
|
205
|
-
"description": "...",
|
|
206
|
-
"gates": {
|
|
207
|
-
"api_smoke": {
|
|
208
|
-
"adapter": "playwright-api",
|
|
209
|
-
"config": {
|
|
210
|
-
"baseUrl": "...",
|
|
211
|
-
"requests": [
|
|
212
|
-
{"method": "GET", "path": "/health", "expect": {"status": 200}},
|
|
213
|
-
...
|
|
214
|
-
]
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
}
|
|
218
|
-
}`;
|
|
219
|
-
|
|
220
|
-
const userPrompt = `Generate tests for this OpenAPI spec:
|
|
221
|
-
${JSON.stringify(spec, null, 2)}
|
|
222
|
-
|
|
223
|
-
Focus on:
|
|
224
|
-
1. Critical health endpoints
|
|
225
|
-
2. Authentication flows
|
|
226
|
-
3. CRUD operations for main resources
|
|
227
|
-
4. Error responses
|
|
228
|
-
`;
|
|
229
|
-
|
|
230
|
-
const response = await this.llm.generate({
|
|
231
|
-
systemPrompt,
|
|
232
|
-
prompt: userPrompt,
|
|
233
|
-
jsonMode: true,
|
|
234
|
-
maxTokens: 8000,
|
|
235
|
-
});
|
|
236
|
-
|
|
237
|
-
return JSON.parse(response.content) as PackConfig;
|
|
238
|
-
}
|
|
239
|
-
|
|
240
|
-
async generateFromUserStories(stories: string): Promise<PackConfig> {
|
|
241
|
-
const systemPrompt = `You are a QA expert. Convert user stories into E2E tests using Playwright.
|
|
242
|
-
|
|
243
|
-
Focus on:
|
|
244
|
-
- Happy path scenarios
|
|
245
|
-
- Edge cases and error handling
|
|
246
|
-
- Accessibility checks
|
|
247
|
-
- Performance budgets
|
|
248
|
-
`;
|
|
249
|
-
|
|
250
|
-
const response = await this.llm.generate({
|
|
251
|
-
systemPrompt,
|
|
252
|
-
prompt: `Generate tests for these user stories:\n${stories}`,
|
|
253
|
-
jsonMode: true,
|
|
254
|
-
maxTokens: 6000,
|
|
255
|
-
});
|
|
256
|
-
|
|
257
|
-
return JSON.parse(response.content);
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
async generateFromCrawl(url: string): Promise<PackConfig> {
|
|
261
|
-
// D'abord crawler avec Playwright
|
|
262
|
-
const pages = await this.crawlApplication(url);
|
|
263
|
-
|
|
264
|
-
// Ensuite générer les tests
|
|
265
|
-
const response = await this.llm.generate({
|
|
266
|
-
prompt: `Generate E2E tests for application at ${url}.
|
|
267
|
-
Discovered pages: ${JSON.stringify(pages, null, 2)}`,
|
|
268
|
-
jsonMode: true,
|
|
269
|
-
});
|
|
270
|
-
|
|
271
|
-
return JSON.parse(response.content);
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
private async crawlApplication(url: string): Promise<PageInfo[]> {
|
|
275
|
-
// Implémentation crawl avec Playwright
|
|
276
|
-
// ...
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
```
|
|
280
|
-
|
|
281
|
-
#### 5. Smart Triage
|
|
282
|
-
|
|
283
|
-
```typescript
|
|
284
|
-
// core/src/ai/triage/smart-triage.ts
|
|
285
|
-
export class SmartTriage {
|
|
286
|
-
constructor(private llm: LLMManager) {}
|
|
287
|
-
|
|
288
|
-
async analyzeFailure(
|
|
289
|
-
runResult: RunResult,
|
|
290
|
-
context: { codebase?: string; logs?: string }
|
|
291
|
-
): Promise<TriageAnalysis> {
|
|
292
|
-
const systemPrompt = `You are a QA debugging expert. Analyze test failures and provide:
|
|
293
|
-
1. Root cause analysis
|
|
294
|
-
2. Suggested fixes with code examples
|
|
295
|
-
3. Confidence score (0-100)
|
|
296
|
-
4. Whether it can be auto-fixed`;
|
|
297
|
-
|
|
298
|
-
const userPrompt = `Analyze this test failure:
|
|
299
|
-
|
|
300
|
-
Gate: ${runResult.gate}
|
|
301
|
-
Status: ${runResult.status}
|
|
302
|
-
Error: ${runResult.error}
|
|
303
|
-
Logs: ${context.logs || 'N/A'}
|
|
304
|
-
|
|
305
|
-
Code context:
|
|
306
|
-
${context.codebase || 'N/A'}`;
|
|
307
|
-
|
|
308
|
-
const response = await this.llm.generate({
|
|
309
|
-
systemPrompt,
|
|
310
|
-
prompt: userPrompt,
|
|
311
|
-
jsonMode: true,
|
|
312
|
-
});
|
|
313
|
-
|
|
314
|
-
return JSON.parse(response.content) as TriageAnalysis;
|
|
315
|
-
}
|
|
316
|
-
|
|
317
|
-
async autoFix(
|
|
318
|
-
filePath: string,
|
|
319
|
-
error: TestError,
|
|
320
|
-
analysis: TriageAnalysis
|
|
321
|
-
): Promise<FixResult> {
|
|
322
|
-
if (!analysis.canAutoFix || analysis.confidence < 80) {
|
|
323
|
-
return { success: false, reason: 'Low confidence or not auto-fixable' };
|
|
324
|
-
}
|
|
325
|
-
|
|
326
|
-
const systemPrompt = `You are a code fixer. Modify the test file to fix the issue.
|
|
327
|
-
Return ONLY the complete fixed file content.`;
|
|
328
|
-
|
|
329
|
-
const currentContent = await fs.readFile(filePath, 'utf-8');
|
|
330
|
-
|
|
331
|
-
const response = await this.llm.generate({
|
|
332
|
-
systemPrompt,
|
|
333
|
-
prompt: `Fix this test file:
|
|
334
|
-
|
|
335
|
-
File: ${filePath}
|
|
336
|
-
Error: ${error.message}
|
|
337
|
-
Analysis: ${analysis.explanation}
|
|
338
|
-
|
|
339
|
-
Current content:
|
|
340
|
-
${currentContent}`,
|
|
341
|
-
});
|
|
342
|
-
|
|
343
|
-
await fs.writeFile(filePath, response.content, 'utf-8');
|
|
344
|
-
return { success: true, fixedContent: response.content };
|
|
345
|
-
}
|
|
346
|
-
}
|
|
347
|
-
```
|
|
348
|
-
|
|
349
|
-
#### 6. Nouvelles Commandes CLI
|
|
350
|
-
|
|
351
|
-
```typescript
|
|
352
|
-
// cli/src/commands/generate.ts
|
|
353
|
-
export async function generateCommand(options: GenerateOptions): Promise<void> {
|
|
354
|
-
const llm = new LLMManager(loadLLMConfig());
|
|
355
|
-
const generator = new TestGenerator(llm);
|
|
356
|
-
|
|
357
|
-
let pack: PackConfig;
|
|
358
|
-
|
|
359
|
-
switch (options.source) {
|
|
360
|
-
case 'openapi':
|
|
361
|
-
pack = await generator.generateFromOpenAPI(options.spec);
|
|
362
|
-
break;
|
|
363
|
-
case 'stories':
|
|
364
|
-
pack = await generator.generateFromUserStories(options.content);
|
|
365
|
-
break;
|
|
366
|
-
case 'crawl':
|
|
367
|
-
pack = await generator.generateFromCrawl(options.url);
|
|
368
|
-
break;
|
|
369
|
-
default:
|
|
370
|
-
pack = await generator.generateFromPrompt(options.prompt);
|
|
371
|
-
}
|
|
372
|
-
|
|
373
|
-
await savePack(pack, options.output);
|
|
374
|
-
console.log(`✅ Pack generated: ${options.output}`);
|
|
375
|
-
}
|
|
376
|
-
|
|
377
|
-
// cli/src/commands/triage.ts
|
|
378
|
-
export async function triageCommand(runId: string, options: TriageOptions): Promise<void> {
|
|
379
|
-
const run = await getRunResult(runId);
|
|
380
|
-
const context = await getFailureContext(runId);
|
|
381
|
-
|
|
382
|
-
const llm = new LLMManager(loadLLMConfig());
|
|
383
|
-
const triage = new SmartTriage(llm);
|
|
384
|
-
|
|
385
|
-
const analysis = await triage.analyzeFailure(run, context);
|
|
386
|
-
|
|
387
|
-
console.log(`\n🔍 Root Cause: ${analysis.rootCause}`);
|
|
388
|
-
console.log(`📊 Confidence: ${analysis.confidence}%`);
|
|
389
|
-
console.log(`\n💡 Suggested Fix:\n${analysis.suggestedFix}`);
|
|
390
|
-
|
|
391
|
-
if (options.autoFix && analysis.canAutoFix) {
|
|
392
|
-
const result = await triage.autoFix(analysis.fileToFix, run.error, analysis);
|
|
393
|
-
if (result.success) {
|
|
394
|
-
console.log(`✅ Auto-fixed: ${result.fileToFix}`);
|
|
395
|
-
}
|
|
396
|
-
}
|
|
397
|
-
}
|
|
398
|
-
|
|
399
|
-
// cli/src/commands/chat.ts
|
|
400
|
-
export async function chatCommand(): Promise<void> {
|
|
401
|
-
const llm = new LLMManager(loadLLMConfig());
|
|
402
|
-
const vault = new EvidenceVault();
|
|
403
|
-
|
|
404
|
-
const history: Message[] = [];
|
|
405
|
-
|
|
406
|
-
const rl = readline.createInterface({
|
|
407
|
-
input: process.stdin,
|
|
408
|
-
output: process.stdout,
|
|
409
|
-
});
|
|
410
|
-
|
|
411
|
-
while (true) {
|
|
412
|
-
const input = await question('\n> ');
|
|
413
|
-
if (input === 'exit') break;
|
|
414
|
-
|
|
415
|
-
// Ajouter contexte QA360
|
|
416
|
-
const context = await gatherQA360Context(input, vault);
|
|
417
|
-
|
|
418
|
-
const response = await llm.generate({
|
|
419
|
-
systemPrompt: `You are QA360 Assistant, a QA expert. Help with test creation, debugging, and quality analysis.`,
|
|
420
|
-
prompt: `${context}\n\nUser: ${input}`,
|
|
421
|
-
});
|
|
422
|
-
|
|
423
|
-
console.log(`\n
|
|
424
|
-
history.push({ role: 'user', content: input });
|
|
425
|
-
history.push({ role: 'assistant', content: response.content });
|
|
426
|
-
}
|
|
427
|
-
}
|
|
428
|
-
```
|
|
429
|
-
|
|
430
|
-
#### 7. Configuration
|
|
431
|
-
|
|
432
|
-
```yaml
|
|
433
|
-
# .qa360/ai.yml
|
|
434
|
-
ai:
|
|
435
|
-
enabled: true
|
|
436
|
-
|
|
437
|
-
providers:
|
|
438
|
-
openai:
|
|
439
|
-
apiKey: ${OPENAI_API_KEY}
|
|
440
|
-
models:
|
|
441
|
-
default: gpt-4o
|
|
442
|
-
cheap: gpt-4o-mini
|
|
443
|
-
fast: gpt-3.5-turbo
|
|
444
|
-
|
|
445
|
-
anthropic:
|
|
446
|
-
apiKey: ${ANTHROPIC_API_KEY}
|
|
447
|
-
models:
|
|
448
|
-
default: claude-sonnet-4-20250514
|
|
449
|
-
cheap: claude-haiku-4-20250514
|
|
450
|
-
|
|
451
|
-
ollama:
|
|
452
|
-
baseUrl: http://localhost:11434
|
|
453
|
-
models:
|
|
454
|
-
default: llama3.2
|
|
455
|
-
coder: deepseek-coder
|
|
456
|
-
|
|
457
|
-
primary: openai
|
|
458
|
-
fallback: anthropic
|
|
459
|
-
|
|
460
|
-
cost_optimization:
|
|
461
|
-
use_cheap_for_summaries: true
|
|
462
|
-
max_tokens_per_request: 8000
|
|
463
|
-
cache_enabled: true
|
|
464
|
-
|
|
465
|
-
features:
|
|
466
|
-
test_generation: true
|
|
467
|
-
smart_triage: true
|
|
468
|
-
auto_fix: true
|
|
469
|
-
chat_mode: true
|
|
470
|
-
```
|
|
471
|
-
|
|
472
|
-
### Avantages
|
|
473
|
-
|
|
474
|
-
| Avantage | Description |
|
|
475
|
-
|----------|-------------|
|
|
476
|
-
| **Contrôle total** | QA360 possède toute la logique, pas de dépendance externe |
|
|
477
|
-
| **Performances** | Pas de surcharge MCP, appels LLM directs |
|
|
478
|
-
| **Offline possible** | Support Ollama pour modèles locaux |
|
|
479
|
-
| **Flexibilité** | Multi-provider avec fallback intelligent |
|
|
480
|
-
| **Coût optimisé** | Utilisation de petits modèles pour les résumés |
|
|
481
|
-
| **Intégration profonde** | L'AI connaît toute la structure QA360 |
|
|
482
|
-
|
|
483
|
-
### Inconvénients
|
|
484
|
-
|
|
485
|
-
| Inconvénient | Description |
|
|
486
|
-
|--------------|-------------|
|
|
487
|
-
| **Maintenance** | QA360 doit maintenir les intégrations LLM |
|
|
488
|
-
| **Complexité** | Plus de code dans le core |
|
|
489
|
-
| **Mises à jour** | Doit suivre les évolutions des APIs LLM |
|
|
490
|
-
| **Dépendances** | Ajoute des dépendances externes (SDKs) |
|
|
491
|
-
| **Coût développement** | Plus de temps à implémenter |
|
|
492
|
-
|
|
493
|
-
---
|
|
494
|
-
|
|
495
|
-
## Option 4 : Enhancement MCP Server {#option-4}
|
|
496
|
-
|
|
497
|
-
### Concept
|
|
498
|
-
|
|
499
|
-
Renforcer le serveur MCP existant de QA360 et permettre à des agents externes (Goose, , Cursor) de l'utiliser.
|
|
500
|
-
|
|
501
|
-
### Architecture Proposée
|
|
502
|
-
|
|
503
|
-
```
|
|
504
|
-
┌─────────────────────────────────────────────────────────────────────────┐
|
|
505
|
-
│ External AI Agents │
|
|
506
|
-
│ ┌──────────┐ ┌──────────┐ ┌──────────┐ ┌──────────┐ ┌─────────┐ │
|
|
507
|
-
│ │ Goose │ │Cursor │ │Claude │ │Custom │ │Future │ │
|
|
508
|
-
│ │ │ │ │ │Code │ │Agent │ │Agents │ │
|
|
509
|
-
│ └────┬─────┘ └────┬─────┘ └────┬─────┘ └────┬─────┘ └────┬────┘ │
|
|
510
|
-
│ └──────────────┴──────────────┴──────────────┴────────────┴───────┘ │
|
|
511
|
-
│ ↓ │
|
|
512
|
-
│ ┌───────────────┐ │
|
|
513
|
-
│ │ MCP Protocol │ │
|
|
514
|
-
│ └───────┬───────┘ │
|
|
515
|
-
└──────────────────────────────┼───────────────────────────────────────────┘
|
|
516
|
-
↓
|
|
517
|
-
┌─────────────────────────────────────────────────────────────────────────┐
|
|
518
|
-
│ QA360 MCP Server (Enhanced) │
|
|
519
|
-
├─────────────────────────────────────────────────────────────────────────┤
|
|
520
|
-
│ ┌────────────────────────────────────────────────────────────────────┐ │
|
|
521
|
-
│ │ Enhanced Tools (40+) │ │
|
|
522
|
-
│ │ ┌─────────────┐ ┌─────────────┐ ┌─────────────┐ ┌─────────────┐ │ │
|
|
523
|
-
│ │ │ Test │ │ Codebase │ │ Generator │ │ Collabor. │ │ │
|
|
524
|
-
│ │ │ Execution │ │ Analysis │ │ Tools │ │ Tools │ │ │
|
|
525
|
-
│ │ └─────────────┘ └─────────────┘ └─────────────┘ └─────────────┘ │ │
|
|
526
|
-
│ └────────────────────────────────────────────────────────────────────┘ │
|
|
527
|
-
│ ↓ │
|
|
528
|
-
│ ┌────────────────────────────────────────────────────────────────────┐ │
|
|
529
|
-
│ │ QA360 Core │ │
|
|
530
|
-
│ │ Phase3Runner → Adapters → Vault → Proof │ │
|
|
531
|
-
│ └────────────────────────────────────────────────────────────────────┘ │
|
|
532
|
-
└─────────────────────────────────────────────────────────────────────────┘
|
|
533
|
-
```
|
|
534
|
-
|
|
535
|
-
### Implémentation Technique
|
|
536
|
-
|
|
537
|
-
#### 1. Nouveaux Outils MCP
|
|
538
|
-
|
|
539
|
-
```typescript
|
|
540
|
-
// packages/mcp/src/tools/enhanced/test-generator.ts
|
|
541
|
-
export class TestGeneratorTools {
|
|
542
|
-
/**
|
|
543
|
-
* Génère un pack depuis une spec OpenAPI
|
|
544
|
-
*/
|
|
545
|
-
async generateFromOpenAPI(args: {
|
|
546
|
-
specUrl?: string;
|
|
547
|
-
specContent?: string;
|
|
548
|
-
options?: {
|
|
549
|
-
includeAuth?: boolean;
|
|
550
|
-
includeCRUD?: boolean;
|
|
551
|
-
includeErrorCases?: boolean;
|
|
552
|
-
};
|
|
553
|
-
}): Promise<{
|
|
554
|
-
pack: string; // YAML
|
|
555
|
-
summary: {
|
|
556
|
-
endpointsCount: number;
|
|
557
|
-
testsGenerated: number;
|
|
558
|
-
coverageEstimate: string;
|
|
559
|
-
};
|
|
560
|
-
}> {
|
|
561
|
-
// Analyser la spec
|
|
562
|
-
const spec = args.specContent
|
|
563
|
-
? JSON.parse(args.specContent)
|
|
564
|
-
: await this.fetchSpec(args.specUrl);
|
|
565
|
-
|
|
566
|
-
// Extraire endpoints
|
|
567
|
-
const endpoints = this.extractEndpoints(spec);
|
|
568
|
-
|
|
569
|
-
// Générer les tests
|
|
570
|
-
const tests = this.generateTestsFromEndpoints(endpoints, args.options);
|
|
571
|
-
|
|
572
|
-
// Construire le pack YAML
|
|
573
|
-
const pack = this.buildPackYAML(tests);
|
|
574
|
-
|
|
575
|
-
return {
|
|
576
|
-
pack,
|
|
577
|
-
summary: {
|
|
578
|
-
endpointsCount: endpoints.length,
|
|
579
|
-
testsGenerated: tests.length,
|
|
580
|
-
coverageEstimate: this.estimateCoverage(tests, endpoints),
|
|
581
|
-
},
|
|
582
|
-
};
|
|
583
|
-
}
|
|
584
|
-
|
|
585
|
-
/**
|
|
586
|
-
* Génère des tests depuis une URL (crawling)
|
|
587
|
-
*/
|
|
588
|
-
async generateFromCrawl(args: {
|
|
589
|
-
url: string;
|
|
590
|
-
maxDepth?: number;
|
|
591
|
-
maxPages?: number;
|
|
592
|
-
selectors?: {
|
|
593
|
-
login?: string;
|
|
594
|
-
forms?: string;
|
|
595
|
-
navigation?: string;
|
|
596
|
-
};
|
|
597
|
-
}): Promise<{
|
|
598
|
-
pack: string;
|
|
599
|
-
discoveredPages: PageInfo[];
|
|
600
|
-
userFlows: UserFlow[];
|
|
601
|
-
}> {
|
|
602
|
-
// Lancer le crawl avec Playwright
|
|
603
|
-
const crawler = new QACrawler({
|
|
604
|
-
maxDepth: args.maxDepth || 2,
|
|
605
|
-
maxPages: args.maxPages || 20,
|
|
606
|
-
});
|
|
607
|
-
|
|
608
|
-
const { pages, flows } = await crawler.crawl(args.url);
|
|
609
|
-
|
|
610
|
-
// Générer les tests E2E
|
|
611
|
-
const tests = this.generateE2ETests(pages, flows);
|
|
612
|
-
|
|
613
|
-
return {
|
|
614
|
-
pack: this.buildPackYAML(tests),
|
|
615
|
-
discoveredPages: pages,
|
|
616
|
-
userFlows: flows,
|
|
617
|
-
};
|
|
618
|
-
}
|
|
619
|
-
|
|
620
|
-
/**
|
|
621
|
-
* Suggère des tests depuis le code
|
|
622
|
-
*/
|
|
623
|
-
async suggestTests(args: {
|
|
624
|
-
projectPath: string;
|
|
625
|
-
language?: string;
|
|
626
|
-
framework?: string;
|
|
627
|
-
}): Promise<{
|
|
628
|
-
suggestions: TestSuggestion[];
|
|
629
|
-
missingCoverage: CoverageGap[];
|
|
630
|
-
}> {
|
|
631
|
-
// Analyser le codebase
|
|
632
|
-
const analyzer = new CodeAnalyzer(args.projectPath);
|
|
633
|
-
|
|
634
|
-
// Trouver les fonctions sans tests
|
|
635
|
-
const untested = await analyzer.findUntestedFunctions();
|
|
636
|
-
|
|
637
|
-
// Suggérer des tests
|
|
638
|
-
const suggestions = untested.map(fn => ({
|
|
639
|
-
type: this.suggestTestType(fn),
|
|
640
|
-
description: this.suggestTestDescription(fn),
|
|
641
|
-
priority: this.calculatePriority(fn),
|
|
642
|
-
codeTemplate: this.generateTestTemplate(fn),
|
|
643
|
-
}));
|
|
644
|
-
|
|
645
|
-
return {
|
|
646
|
-
suggestions,
|
|
647
|
-
missingCoverage: await analyzer.getCoverageGaps(),
|
|
648
|
-
};
|
|
649
|
-
}
|
|
650
|
-
}
|
|
651
|
-
|
|
652
|
-
// packages/mcp/src/tools/enhanced/codebase-analyzer.ts
|
|
653
|
-
export class CodebaseAnalysisTools {
|
|
654
|
-
/**
|
|
655
|
-
* Analyse le code pour trouver des patterns testables
|
|
656
|
-
*/
|
|
657
|
-
async analyzeTestability(args: {
|
|
658
|
-
path: string;
|
|
659
|
-
includePatterns?: string[];
|
|
660
|
-
excludePatterns?: string[];
|
|
661
|
-
}): Promise<TestabilityReport> {
|
|
662
|
-
const analyzer = new TestabilityAnalyzer(args.path);
|
|
663
|
-
|
|
664
|
-
return {
|
|
665
|
-
functions: await analyzer.analyzeFunctions(),
|
|
666
|
-
apis: await analyzer.analyzeAPIs(),
|
|
667
|
-
components: await analyzer.analyzeComponents(),
|
|
668
|
-
testabilityScore: analyzer.calculateScore(),
|
|
669
|
-
recommendations: await analyzer.getRecommendations(),
|
|
670
|
-
};
|
|
671
|
-
}
|
|
672
|
-
|
|
673
|
-
/**
|
|
674
|
-
* Trouve les selectors fragiles
|
|
675
|
-
*/
|
|
676
|
-
async findFragileSelectors(args: {
|
|
677
|
-
testPath: string;
|
|
678
|
-
codebasePath: string;
|
|
679
|
-
}): Promise<FragileSelector[]> {
|
|
680
|
-
const parser = new SelectorParser();
|
|
681
|
-
const validators = [
|
|
682
|
-
new ClassNameValidator(),
|
|
683
|
-
new TextContentValidator(),
|
|
684
|
-
new AttributeValidator(),
|
|
685
|
-
];
|
|
686
|
-
|
|
687
|
-
const selectors = await parser.extractFromTestFiles(args.testPath);
|
|
688
|
-
const fragile: FragileSelector[] = [];
|
|
689
|
-
|
|
690
|
-
for (const selector of selectors) {
|
|
691
|
-
for (const validator of validators) {
|
|
692
|
-
if (!(await validator.validate(selector, args.codebasePath))) {
|
|
693
|
-
fragile.push({
|
|
694
|
-
selector: selector.value,
|
|
695
|
-
file: selector.file,
|
|
696
|
-
line: selector.line,
|
|
697
|
-
reason: validator.getReason(),
|
|
698
|
-
suggestion: validator.getSuggestion(),
|
|
699
|
-
});
|
|
700
|
-
}
|
|
701
|
-
}
|
|
702
|
-
}
|
|
703
|
-
|
|
704
|
-
return fragile;
|
|
705
|
-
}
|
|
706
|
-
}
|
|
707
|
-
|
|
708
|
-
// packages/mcp/src/tools/enhanced/smart-triage.ts
|
|
709
|
-
export class SmartTriageTools {
|
|
710
|
-
/**
|
|
711
|
-
* Analyse un échec avec contexte étendu
|
|
712
|
-
*/
|
|
713
|
-
async analyzeFailure(args: {
|
|
714
|
-
runId: string;
|
|
715
|
-
includeLogs?: boolean;
|
|
716
|
-
includeScreenshots?: boolean;
|
|
717
|
-
includeStackTrace?: boolean;
|
|
718
|
-
}): Promise<FailureAnalysis> {
|
|
719
|
-
const vault = new EvidenceVault();
|
|
720
|
-
const run = await vault.getRun(args.runId);
|
|
721
|
-
|
|
722
|
-
// Collecter le contexte
|
|
723
|
-
const context = await this.collectContext(run, args);
|
|
724
|
-
|
|
725
|
-
// Analyser avec heuristiques
|
|
726
|
-
const heuristics = this.runHeuristics(context);
|
|
727
|
-
|
|
728
|
-
return {
|
|
729
|
-
failure: {
|
|
730
|
-
gate: run.gate,
|
|
731
|
-
error: run.error,
|
|
732
|
-
timestamp: run.timestamp,
|
|
733
|
-
},
|
|
734
|
-
rootCause: heuristics.rootCause,
|
|
735
|
-
confidence: heuristics.confidence,
|
|
736
|
-
suggestedFixes: heuristics.fixes,
|
|
737
|
-
relatedRuns: await this.findRelatedRuns(run),
|
|
738
|
-
canAutoFix: heuristics.canAutoFix,
|
|
739
|
-
};
|
|
740
|
-
}
|
|
741
|
-
|
|
742
|
-
/**
|
|
743
|
-
* Génère un patch de correction
|
|
744
|
-
*/
|
|
745
|
-
async generateFix(args: {
|
|
746
|
-
runId: string;
|
|
747
|
-
filePath: string;
|
|
748
|
-
approach?: 'safe' | 'aggressive';
|
|
749
|
-
}): Promise<FixPatch> {
|
|
750
|
-
const analysis = await this.analyzeFailure({ runId: args.runId });
|
|
751
|
-
|
|
752
|
-
if (!analysis.canAutoFix) {
|
|
753
|
-
throw new Error('Cannot auto-fix this failure');
|
|
754
|
-
}
|
|
755
|
-
|
|
756
|
-
const fixer = new TestFixer(args.approach || 'safe');
|
|
757
|
-
return await fixer.generatePatch(args.filePath, analysis);
|
|
758
|
-
}
|
|
759
|
-
}
|
|
760
|
-
|
|
761
|
-
// packages/mcp/src/tools/enhanced/collaboration.ts
|
|
762
|
-
export class CollaborationTools {
|
|
763
|
-
/**
|
|
764
|
-
* Génère un rapport pour l'équipe
|
|
765
|
-
*/
|
|
766
|
-
async generateTeamReport(args: {
|
|
767
|
-
runId: string;
|
|
768
|
-
format?: 'markdown' | 'html' | 'slack';
|
|
769
|
-
include?: {
|
|
770
|
-
screenshots?: boolean;
|
|
771
|
-
logs?: boolean;
|
|
772
|
-
recommendations?: boolean;
|
|
773
|
-
};
|
|
774
|
-
}): Promise<TeamReport> {
|
|
775
|
-
const vault = new EvidenceVault();
|
|
776
|
-
const run = await vault.getRun(args.runId);
|
|
777
|
-
|
|
778
|
-
const report = new ReportGenerator();
|
|
779
|
-
|
|
780
|
-
return await report.generate({
|
|
781
|
-
run,
|
|
782
|
-
format: args.format || 'markdown',
|
|
783
|
-
include: args.include,
|
|
784
|
-
});
|
|
785
|
-
}
|
|
786
|
-
|
|
787
|
-
/**
|
|
788
|
-
* Compare deux runs pour régression
|
|
789
|
-
*/
|
|
790
|
-
async compareRuns(args: {
|
|
791
|
-
runA: string;
|
|
792
|
-
runB: string;
|
|
793
|
-
metrics?: string[];
|
|
794
|
-
}): Promise<RunComparison> {
|
|
795
|
-
const vault = new EvidenceVault();
|
|
796
|
-
const [runA, runB] = await Promise.all([
|
|
797
|
-
vault.getRun(args.runA),
|
|
798
|
-
vault.getRun(args.runB),
|
|
799
|
-
]);
|
|
800
|
-
|
|
801
|
-
return {
|
|
802
|
-
summary: this.compareSummary(runA, runB),
|
|
803
|
-
gates: this.compareGates(runA, runB),
|
|
804
|
-
regressions: this.findRegressions(runA, runB),
|
|
805
|
-
improvements: this.findImprovements(runA, runB),
|
|
806
|
-
};
|
|
807
|
-
}
|
|
808
|
-
}
|
|
809
|
-
```
|
|
810
|
-
|
|
811
|
-
#### 2. Outils d'Intégration Codebase
|
|
812
|
-
|
|
813
|
-
```typescript
|
|
814
|
-
// packages/mcp/src/tools/integration/git.ts
|
|
815
|
-
export class GitIntegrationTools {
|
|
816
|
-
async getChangedFiles(args: {
|
|
817
|
-
branch?: string;
|
|
818
|
-
commit?: string;
|
|
819
|
-
}): Promise<ChangedFile[]> {
|
|
820
|
-
// Utiliser git simple ou isogit pour éviter les dépendances
|
|
821
|
-
}
|
|
822
|
-
|
|
823
|
-
async getCommitInfo(args: {
|
|
824
|
-
sha: string;
|
|
825
|
-
}): Promise<CommitInfo> {
|
|
826
|
-
// Info sur le commit pour contexte
|
|
827
|
-
}
|
|
828
|
-
}
|
|
829
|
-
|
|
830
|
-
// packages/mcp/src/tools/integration/ci.ts
|
|
831
|
-
export class CIIntegrationTools {
|
|
832
|
-
async parseCIConfig(args: {
|
|
833
|
-
type: 'github' | 'gitlab' | 'jenkins';
|
|
834
|
-
}): Promise<CIConfig> {
|
|
835
|
-
// Parser les configs CI pour suggérer des intégrations
|
|
836
|
-
}
|
|
837
|
-
|
|
838
|
-
async generateCIStep(args: {
|
|
839
|
-
packPath: string;
|
|
840
|
-
ciType: 'github' | 'gitlab';
|
|
841
|
-
}): Promise<CIStep> {
|
|
842
|
-
// Générer la step CI pour QA360
|
|
843
|
-
}
|
|
844
|
-
}
|
|
845
|
-
```
|
|
846
|
-
|
|
847
|
-
#### 3. Instructions Riches pour Agents
|
|
848
|
-
|
|
849
|
-
```typescript
|
|
850
|
-
// packages/mcp/src/server.ts - Enhanced
|
|
851
|
-
const TOOL_INSTRUCTIONS = `
|
|
852
|
-
You are interacting with QA360, a cryptographic QA orchestration platform.
|
|
853
|
-
|
|
854
|
-
## Key Concepts
|
|
855
|
-
|
|
856
|
-
1. **Packs**: Test definitions in YAML format defining multiple quality gates
|
|
857
|
-
2. **Gates**: Individual test executions (api_smoke, ui, perf, sast, etc.)
|
|
858
|
-
3. **Adapters**: Test execution engines (Playwright, K6, Semgrep, etc.)
|
|
859
|
-
4. **Evidence Vault**: SQLite-based immutable audit trail
|
|
860
|
-
5. **Proofs**: Ed25519 cryptographic signatures for verification
|
|
861
|
-
|
|
862
|
-
## Available Tool Categories
|
|
863
|
-
|
|
864
|
-
### Test Generation
|
|
865
|
-
- qa360.generate.from_openapi: Generate tests from OpenAPI specs
|
|
866
|
-
- qa360.generate.from_crawl: Generate E2E tests by crawling
|
|
867
|
-
- qa360.generate.suggest: Suggest tests from code analysis
|
|
868
|
-
|
|
869
|
-
### Test Execution
|
|
870
|
-
- qa360.run: Execute a pack (requires permission)
|
|
871
|
-
- qa360.history.*: Query past runs, compare, trends
|
|
872
|
-
|
|
873
|
-
### Analysis & Triage
|
|
874
|
-
- qa360.analyze.testability: Analyze code testability
|
|
875
|
-
- qa360.triage.analyze: Deep failure analysis
|
|
876
|
-
- qa360.triage.fix: Generate auto-fix patches
|
|
877
|
-
|
|
878
|
-
### Collaboration
|
|
879
|
-
- qa360.report.team: Generate team-friendly reports
|
|
880
|
-
- qa360.compare.runs: Compare runs for regressions
|
|
881
|
-
|
|
882
|
-
## Best Practices
|
|
883
|
-
|
|
884
|
-
1. Always validate packs before running
|
|
885
|
-
2. Use suggest_tests before generating to understand coverage
|
|
886
|
-
3. Check historical trends before concluding on failures
|
|
887
|
-
4. Use triage.analyze before attempting fixes
|
|
888
|
-
5. Generate team reports for non-technical stakeholders
|
|
889
|
-
|
|
890
|
-
## Example Workflows
|
|
891
|
-
|
|
892
|
-
### For Test Generation:
|
|
893
|
-
1. Call qa360.generate.suggest_tests to see what's missing
|
|
894
|
-
2. Call qa360.generate.from_openapi for API tests
|
|
895
|
-
3. Call qa360.pack.validate to verify the pack
|
|
896
|
-
4. User can then run: qa360 run pack.yml
|
|
897
|
-
|
|
898
|
-
### For Debugging:
|
|
899
|
-
1. Call qa360.history.get to get run details
|
|
900
|
-
2. Call qa360.triage.analyze for root cause
|
|
901
|
-
3. Call qa360.compare.runs to check for regressions
|
|
902
|
-
4. If auto-fixable, call qa360.triage.fix
|
|
903
|
-
`;
|
|
904
|
-
```
|
|
905
|
-
|
|
906
|
-
#### 4. Enhanced Registry
|
|
907
|
-
|
|
908
|
-
```typescript
|
|
909
|
-
// packages/mcp/src/registry/enhanced.ts
|
|
910
|
-
export class EnhancedToolRegistry {
|
|
911
|
-
private tools = new Map<string, Tool>();
|
|
912
|
-
|
|
913
|
-
constructor() {
|
|
914
|
-
// Existing tools (23)
|
|
915
|
-
this.registerExistingTools();
|
|
916
|
-
|
|
917
|
-
// NEW: Test Generation (3 tools)
|
|
918
|
-
this.register('qa360.generate.from_openapi', new GenerateFromOpenAPITool());
|
|
919
|
-
this.register('qa360.generate.from_crawl', new GenerateFromCrawlTool());
|
|
920
|
-
this.register('qa360.generate.suggest', new SuggestTestsTool());
|
|
921
|
-
|
|
922
|
-
// NEW: Codebase Analysis (2 tools)
|
|
923
|
-
this.register('qa360.analyze.testability', new TestabilityTool());
|
|
924
|
-
this.register('qa360.analyze.fragile_selectors', new FragileSelectorsTool());
|
|
925
|
-
|
|
926
|
-
// NEW: Enhanced Triage (2 tools)
|
|
927
|
-
this.register('qa360.triage.analyze', new AnalyzeFailureTool());
|
|
928
|
-
this.register('qa360.triage.fix', new GenerateFixTool());
|
|
929
|
-
|
|
930
|
-
// NEW: Collaboration (3 tools)
|
|
931
|
-
this.register('qa360.report.team', new TeamReportTool());
|
|
932
|
-
this.register('qa360.compare.runs', new CompareRunsTool());
|
|
933
|
-
this.register('qa360.ai.explain', new AIExplainTool());
|
|
934
|
-
|
|
935
|
-
// NEW: Integrations (2 tools)
|
|
936
|
-
this.register('qa360.git.changed_files', new GitChangedFilesTool());
|
|
937
|
-
this.register('qa360.ci.generate_step', new CIGenerateStepTool());
|
|
938
|
-
}
|
|
939
|
-
|
|
940
|
-
// Total: 23 existing + 12 new = 35 tools
|
|
941
|
-
}
|
|
942
|
-
```
|
|
943
|
-
|
|
944
|
-
#### 5. Documentation MCP
|
|
945
|
-
|
|
946
|
-
```markdown
|
|
947
|
-
<!-- packages/mcp/README.md -->
|
|
948
|
-
# QA360 MCP Server
|
|
949
|
-
|
|
950
|
-
Enhanced MCP server with 35+ tools for AI-powered QA.
|
|
951
|
-
|
|
952
|
-
## Quick Start for Agent Developers
|
|
953
|
-
|
|
954
|
-
\`\`\`bash
|
|
955
|
-
# Install QA360
|
|
956
|
-
npm install -g qa360
|
|
957
|
-
|
|
958
|
-
# Start MCP server
|
|
959
|
-
qa360-mcp serve --allow-run
|
|
960
|
-
|
|
961
|
-
# In Claude Desktop settings.json:
|
|
962
|
-
\`\`\`json
|
|
963
|
-
{
|
|
964
|
-
"mcpServers": {
|
|
965
|
-
"qa360": {
|
|
966
|
-
"command": "qa360-mcp",
|
|
967
|
-
"args": ["serve", "--allow-run"]
|
|
968
|
-
}
|
|
969
|
-
}
|
|
970
|
-
}
|
|
971
|
-
\`\`\`
|
|
972
|
-
|
|
973
|
-
## Tool Categories
|
|
974
|
-
|
|
975
|
-
### Generation (3 tools)
|
|
976
|
-
- `qa360.generate.from_openapi` - Generate API tests from OpenAPI
|
|
977
|
-
- `qa360.generate.from_crawl` - Generate E2E tests by crawling
|
|
978
|
-
- `qa360.generate.suggest` - Suggest tests from code analysis
|
|
979
|
-
|
|
980
|
-
### Analysis (2 tools)
|
|
981
|
-
- `qa360.analyze.testability` - Analyze code testability
|
|
982
|
-
- `qa360.analyze.fragile_selectors` - Find fragile selectors
|
|
983
|
-
|
|
984
|
-
### Triage (2 tools)
|
|
985
|
-
- `qa360.triage.analyze` - Deep failure analysis
|
|
986
|
-
- `qa360.triage.fix` - Generate auto-fix patches
|
|
987
|
-
|
|
988
|
-
### Collaboration (3 tools)
|
|
989
|
-
- `qa360.report.team` - Generate team reports
|
|
990
|
-
- `qa360.compare.runs` - Compare runs
|
|
991
|
-
- `qa360.ai.explain` - Explain results in natural language
|
|
992
|
-
|
|
993
|
-
## Example Agent Usage
|
|
994
|
-
|
|
995
|
-
\`\`\`typescript
|
|
996
|
-
// In your agent code
|
|
997
|
-
const result = await mcp.callTool('qa360.generate.from_openapi', {
|
|
998
|
-
specUrl: 'https://api.example.com/openapi.json',
|
|
999
|
-
options: {
|
|
1000
|
-
includeAuth: true,
|
|
1001
|
-
includeCRUD: true
|
|
1002
|
-
}
|
|
1003
|
-
});
|
|
1004
|
-
|
|
1005
|
-
console.log(result.pack); // YAML pack
|
|
1006
|
-
\`\`\`
|
|
1007
|
-
```
|
|
1008
|
-
|
|
1009
|
-
### Avantages
|
|
1010
|
-
|
|
1011
|
-
| Avantage | Description |
|
|
1012
|
-
|----------|-------------|
|
|
1013
|
-
| **Déjà implémenté** | MCP server existe déjà avec 23 outils |
|
|
1014
|
-
| **Compatibilité agents** | Fonctionne avec Goose, , Cursor, etc. |
|
|
1015
|
-
| **Pas de dépendance LLM** | QA360 ne gère pas les providers LLM |
|
|
1016
|
-
| **Extensibilité** | Facile d'ajouter de nouveaux outils |
|
|
1017
|
-
| **Maintenance réduite** | Agents externes gèrent leur logique AI |
|
|
1018
|
-
| **Standard ouvert** | MCP est un standard de l'industrie |
|
|
1019
|
-
| **Sécurité** | Permissions granulaires déjà en place |
|
|
1020
|
-
| **Audit trail** |
|
|
1021
|
-
| **Future-proof** | Nouveaux agents compatibles automatiquement |
|
|
1022
|
-
|
|
1023
|
-
### Inconvénients
|
|
1024
|
-
|
|
1025
|
-
| Inconvénient | Description |
|
|
1026
|
-
|--------------|-------------|
|
|
1027
|
-
| **Dépendance externe** | Nécessite un agent AI externe |
|
|
1028
|
-
| **Expérience fractionnée** | L'utilisateur doit utiliser 2 outils |
|
|
1029
|
-
| **Limité par l'agent** | Dépend des capacités de l'agent externe |
|
|
1030
|
-
| **Latence MCP** | Surcharge de communication |
|
|
1031
|
-
| **Moins de contrôle** | QA360 ne contrôle pas l'expérience AI |
|
|
1032
|
-
|
|
1033
|
-
---
|
|
1034
|
-
|
|
1035
|
-
## Comparaison Détaillée {#comparaison}
|
|
1036
|
-
|
|
1037
|
-
### Tableau Comparatif
|
|
1038
|
-
|
|
1039
|
-
| Dimension | Option 3 (LLM Direct) | Option 4 (MCP Enhanced) |
|
|
1040
|
-
|-----------|----------------------|-------------------------|
|
|
1041
|
-
| **Développement** | 4-6 semaines | 2-3 semaines |
|
|
1042
|
-
| **Maintenance** | Élevée (SDKs LLM) | Faible (outils MCP) |
|
|
1043
|
-
| **Contrôle** | Total | Partagé avec agents |
|
|
1044
|
-
| **Coût LLM** | QA360 le gère | Utilisateur le gère |
|
|
1045
|
-
| **Dépendances** | +3-5 packages | +0 packages |
|
|
1046
|
-
| **Offline** | Oui (Ollama) | Oui (si agent local) |
|
|
1047
|
-
| **Extensibilité** | Modérée | Élevée |
|
|
1048
|
-
| **Expérience UX** | Unifiée | Fractionnée |
|
|
1049
|
-
| **Standard** | Propriétaire | MCP (ouvert) |
|
|
1050
|
-
| **Future-proof** | Dépend adoption | Dépend écosystème MCP |
|
|
1051
|
-
|
|
1052
|
-
### Matrice de Complexité
|
|
1053
|
-
|
|
1054
|
-
```
|
|
1055
|
-
Complexité de développement
|
|
1056
|
-
|
|
1057
|
-
Option 3 (LLM Direct):
|
|
1058
|
-
┌─────────────────────────────────────────────────────────────┐
|
|
1059
|
-
│ ████████████████████████████████████░░░░░░░░░░░░░░░░░░░░░ │ 70%
|
|
1060
|
-
│ - Provider abstraction │
|
|
1061
|
-
│ - Multi-provider support │
|
|
1062
|
-
│ - Test generation logic │
|
|
1063
|
-
│ - Smart triage │
|
|
1064
|
-
│ - Chat mode │
|
|
1065
|
-
│ - Error handling │
|
|
1066
|
-
│ - Cost optimization │
|
|
1067
|
-
└─────────────────────────────────────────────────────────────┘
|
|
1068
|
-
|
|
1069
|
-
Option 4 (MCP Enhanced):
|
|
1070
|
-
┌─────────────────────────────────────────────────────────────┐
|
|
1071
|
-
│ ████████████████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░ │ 40%
|
|
1072
|
-
│ - New tools (12) │
|
|
1073
|
-
│ - Tool descriptions │
|
|
1074
|
-
│ - Enhanced registry │
|
|
1075
|
-
│ - Documentation │
|
|
1076
|
-
│ - Testing │
|
|
1077
|
-
└─────────────────────────────────────────────────────────────┘
|
|
1078
|
-
```
|
|
1079
|
-
|
|
1080
|
-
### Analyse de Valeur
|
|
1081
|
-
|
|
1082
|
-
```
|
|
1083
|
-
Valeur pour l'utilisateur
|
|
1084
|
-
|
|
1085
|
-
Option 3 (LLM Direct):
|
|
1086
|
-
┌─────────────────────────────────────────────────────────────┐
|
|
1087
|
-
│ ██████████████████████████████████████████████████████████ │ 95%
|
|
1088
|
-
│ - One-stop shop │
|
|
1089
|
-
│ - No AI setup needed │
|
|
1090
|
-
│ - Works out of the box │
|
|
1091
|
-
│ - Optimized for QA360 │
|
|
1092
|
-
└─────────────────────────────────────────────────────────────┘
|
|
1093
|
-
|
|
1094
|
-
Option 4 (MCP Enhanced):
|
|
1095
|
-
┌─────────────────────────────────────────────────────────────┐
|
|
1096
|
-
│ ████████████████████████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░ │ 70%
|
|
1097
|
-
│ - Requires external agent │
|
|
1098
|
-
│ - More setup │
|
|
1099
|
-
│ - But more flexible │
|
|
1100
|
-
│ - Can use favorite agent │
|
|
1101
|
-
└─────────────────────────────────────────────────────────────┘
|
|
1102
|
-
```
|
|
1103
|
-
|
|
1104
|
-
---
|
|
1105
|
-
|
|
1106
|
-
## Recommandation Stratégique {#recommandation}
|
|
1107
|
-
|
|
1108
|
-
### Approche Hybride : Les Deux Options
|
|
1109
|
-
|
|
1110
|
-
**Ne pas choisir. Combiner.**
|
|
1111
|
-
|
|
1112
|
-
```
|
|
1113
|
-
┌─────────────────────────────────────────────────────────────────────────┐
|
|
1114
|
-
│ QA360 AI Strategy │
|
|
1115
|
-
├─────────────────────────────────────────────────────────────────────────┤
|
|
1116
|
-
│ │
|
|
1117
|
-
│ ┌────────────────────────────────────────────────────────────────────┐ │
|
|
1118
|
-
│ │ Option 3: LLM Direct │ │
|
|
1119
|
-
│ │ Pour utilisateurs qui veulent une solution tout-en-un │ │
|
|
1120
|
-
│ │ │ │
|
|
1121
|
-
│ │ Fonctions: │ │
|
|
1122
|
-
│ │ - qa360 generate --ai │ │
|
|
1123
|
-
│ │ - qa360 triage --ai │ │
|
|
1124
|
-
│ │ - qa360 chat │ │
|
|
1125
|
-
│ │ │ │
|
|
1126
|
-
│ │ Implémentation: Lite version │ │
|
|
1127
|
-
│ │ - Un seul provider (configurable) │ │
|
|
1128
|
-
│ │ - Fonctions essentielles seulement │ │
|
|
1129
|
-
│ │ - Coût maîtrisé │ │
|
|
1130
|
-
│ └────────────────────────────────────────────────────────────────────┘ │
|
|
1131
|
-
│ ↓ │
|
|
1132
|
-
│ ┌────────────────────────────────────────────────────────────────────┐ │
|
|
1133
|
-
│ │ Option 4: MCP Enhanced │ │
|
|
1134
|
-
│ │ Pour utilisateurs avec leur propre agent AI │ │
|
|
1135
|
-
│ │ │ │
|
|
1136
|
-
│ │ Fonctions: │ │
|
|
1137
|
-
│ │ - 35+ outils MCP │ │
|
|
1138
|
-
│ │ - Documentation agent-first │ │
|
|
1139
|
-
│ │ - Examples pour Goose, │ │
|
|
1140
|
-
│ │ │ │
|
|
1141
|
-
│ │ Implémentation: Full enhancement │ │
|
|
1142
|
-
│ │ - Tous les outils │ │
|
|
1143
|
-
│ │ - Instructions riches │ │
|
|
1144
|
-
│ │ - Examples et templates │ │
|
|
1145
|
-
│ └────────────────────────────────────────────────────────────────────┘ │
|
|
1146
|
-
│ │
|
|
1147
|
-
└─────────────────────────────────────────────────────────────────────────┘
|
|
1148
|
-
```
|
|
1149
|
-
|
|
1150
|
-
### Roadmap Phasée
|
|
1151
|
-
|
|
1152
|
-
#### Phase 1 : MCP Enhancement (Mois 1-2)
|
|
1153
|
-
**Quick win, impact immédiat**
|
|
1154
|
-
|
|
1155
|
-
- [ ] Ajouter 12 nouveaux outils MCP
|
|
1156
|
-
- [ ] Documenter les outils pour agents
|
|
1157
|
-
- [ ] Créer examples pour Goose,
|
|
1158
|
-
- [ ] Publier article sur intégration
|
|
1159
|
-
|
|
1160
|
-
**Livraison** : QA360 MCP Server v2 avec 35 outils
|
|
1161
|
-
|
|
1162
|
-
#### Phase 2 : LLM Lite Integration (Mois 3-4)
|
|
1163
|
-
**Fonctions essentielles pour utilisateurs sans agent**
|
|
1164
|
-
|
|
1165
|
-
- [ ] Abstraction LLM simple
|
|
1166
|
-
- [ ] Support OpenAI + Anthropic
|
|
1167
|
-
- [ ] Commande `qa360 generate --ai`
|
|
1168
|
-
- [ ] Configuration simple
|
|
1169
|
-
|
|
1170
|
-
**Livraison** : QA360 CLI avec AI basique
|
|
1171
|
-
|
|
1172
|
-
#### Phase 3 : Enhanced AI (Mois 5-6)
|
|
1173
|
-
**Fonctions avancées**
|
|
1174
|
-
|
|
1175
|
-
- [ ] Smart triage avec AI
|
|
1176
|
-
- [ ] Auto-fix basique
|
|
1177
|
-
- [ ] Support Ollama (local)
|
|
1178
|
-
- [ ] Optimisation coût
|
|
1179
|
-
|
|
1180
|
-
**Livraison** : QA360 AI complet
|
|
1181
|
-
|
|
1182
|
-
#### Phase 4 : Ecosystem (Mois 7+)
|
|
1183
|
-
**Intégrations et communauté**
|
|
1184
|
-
|
|
1185
|
-
- [ ] Plugins communauté
|
|
1186
|
-
- [ ] Templates par industrie
|
|
1187
|
-
- [ ] Intégrations CI/CD
|
|
1188
|
-
- [ ] Dashboard web
|
|
1189
|
-
|
|
1190
|
-
### Configuration Finale Proposée
|
|
1191
|
-
|
|
1192
|
-
```yaml
|
|
1193
|
-
# .qa360/config.yml
|
|
1194
|
-
ai:
|
|
1195
|
-
mode: hybrid # | mcp-only | embedded-only
|
|
1196
|
-
|
|
1197
|
-
embedded:
|
|
1198
|
-
provider: openai # | anthropic | ollama
|
|
1199
|
-
model: gpt-4o
|
|
1200
|
-
fallback: anthropic
|
|
1201
|
-
|
|
1202
|
-
features:
|
|
1203
|
-
test_generation: true
|
|
1204
|
-
smart_triage: true
|
|
1205
|
-
auto_fix: true
|
|
1206
|
-
|
|
1207
|
-
cost_optimization:
|
|
1208
|
-
use_cheap_model_for_summaries: true
|
|
1209
|
-
max_tokens_per_request: 8000
|
|
1210
|
-
|
|
1211
|
-
mcp:
|
|
1212
|
-
enabled: true
|
|
1213
|
-
enhanced_tools: true
|
|
1214
|
-
agent_instructions: true
|
|
1215
|
-
|
|
1216
|
-
tools:
|
|
1217
|
-
generation: true
|
|
1218
|
-
analysis: true
|
|
1219
|
-
triage: true
|
|
1220
|
-
collaboration: true
|
|
1221
|
-
|
|
1222
|
-
# L'utilisateur choisit son mode
|
|
1223
|
-
# - "embedded" : QA360 gère l'IA
|
|
1224
|
-
# - "mcp" : Utilise son agent préféré
|
|
1225
|
-
# - "hybrid" : Les deux disponibles
|
|
1226
|
-
```
|
|
1227
|
-
|
|
1228
|
-
### Conclusion
|
|
1229
|
-
|
|
1230
|
-
**L'approche hybride est la meilleure stratégie pour QA360 :**
|
|
1231
|
-
|
|
1232
|
-
1. **MCP Enhanced** = S'assurer que QA360 est compatible avec tous les agents
|
|
1233
|
-
2. **LLM Lite** = Pour les utilisateurs qui veulent du "tout-en-un"
|
|
1234
|
-
3. **Hybrid** = Flexibilité maximale pour tous les cas d'usage
|
|
1235
|
-
|
|
1236
|
-
**Cela permet à QA360 de :**
|
|
1237
|
-
- Être indispensable avec des agents externes
|
|
1238
|
-
- Être autonome pour ceux qui veulent simplicité
|
|
1239
|
-
- Resté agnostic face aux évolutions du marché IA
|
|
1240
|
-
- Capturer les deux segments d'utilisateurs
|
|
1241
|
-
|
|
1242
|
-
---
|
|
1243
|
-
|
|
1244
|
-
## Sources
|
|
1245
|
-
|
|
1246
|
-
### Option 3 Sources
|
|
1247
|
-
- [multi-llm-ts GitHub](https://github.com/nbonamy/multi-llm-ts) - Multi-provider LLM abstraction
|
|
1248
|
-
- [OpenAI Agents SDK TypeScript](https://techwithibrahim.medium.com/getting-started-with-openais-agents-sdk-for-typescript-6b551c42e1ae)
|
|
1249
|
-
- [LangChain 1.0 Best Practices](https://skywork.ai/blog/ai-agent/best-practices-langchain-1-0-production-ready-llm-apps/)
|
|
1250
|
-
- [Building AI Agents with TypeScript](https://medium.com/@vishwajeety14122/building-ai-agents-with-javascript-typescript-your-complete-guide-7cf969e7d85b)
|
|
1251
|
-
|
|
1252
|
-
### Option 4 Sources
|
|
1253
|
-
- [MCP TS Simple Template](https://github.com/ChenReuven/mcp-ts-simple-template)
|
|
1254
|
-
- [Building a TypeScript MCP Server - Medium](https://medium.com/@jageenshukla/building-a-typescript-mcp-server-a-guide-for-integrating-existing-services-5bde3fc13b23)
|
|
1255
|
-
- [How to Build an MCP Server in TypeScript - DEV.to](https://dev.to/shayy/how-to-build-an-mcp-server-in-typescript-4kp5)
|
|
1256
|
-
- [Build an MCP Server - Official Docs](https://modelcontextprotocol.io/docs/develop/build-server)
|
|
1257
|
-
- [MCP Server TypeScript Azure Guide](https://learn.microsoft.com/en-us/azure/developer/ai/build-mcp-server-ts)
|