agentic-qe 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/agents/analysis/code-analyzer.md +209 -0
- package/.claude/agents/analysis/code-review/analyze-code-quality.md +180 -0
- package/.claude/agents/architecture/system-design/arch-system-design.md +156 -0
- package/.claude/agents/base-template-generator.md +42 -0
- package/.claude/agents/consensus/byzantine-coordinator.md +63 -0
- package/.claude/agents/consensus/crdt-synchronizer.md +997 -0
- package/.claude/agents/consensus/gossip-coordinator.md +63 -0
- package/.claude/agents/consensus/performance-benchmarker.md +851 -0
- package/.claude/agents/consensus/quorum-manager.md +823 -0
- package/.claude/agents/consensus/raft-manager.md +63 -0
- package/.claude/agents/consensus/security-manager.md +622 -0
- package/.claude/agents/core/coder.md +266 -0
- package/.claude/agents/core/planner.md +168 -0
- package/.claude/agents/core/researcher.md +190 -0
- package/.claude/agents/core/reviewer.md +326 -0
- package/.claude/agents/core/tester.md +319 -0
- package/.claude/agents/data/ml/data-ml-model.md +193 -0
- package/.claude/agents/development/backend/dev-backend-api.md +142 -0
- package/.claude/agents/devops/ci-cd/ops-cicd-github.md +164 -0
- package/.claude/agents/documentation/api-docs/docs-api-openapi.md +174 -0
- package/.claude/agents/flow-nexus/app-store.md +88 -0
- package/.claude/agents/flow-nexus/authentication.md +69 -0
- package/.claude/agents/flow-nexus/challenges.md +81 -0
- package/.claude/agents/flow-nexus/neural-network.md +88 -0
- package/.claude/agents/flow-nexus/payments.md +83 -0
- package/.claude/agents/flow-nexus/sandbox.md +76 -0
- package/.claude/agents/flow-nexus/swarm.md +76 -0
- package/.claude/agents/flow-nexus/user-tools.md +96 -0
- package/.claude/agents/flow-nexus/workflow.md +84 -0
- package/.claude/agents/github/code-review-swarm.md +538 -0
- package/.claude/agents/github/github-modes.md +173 -0
- package/.claude/agents/github/issue-tracker.md +319 -0
- package/.claude/agents/github/multi-repo-swarm.md +553 -0
- package/.claude/agents/github/pr-manager.md +191 -0
- package/.claude/agents/github/project-board-sync.md +509 -0
- package/.claude/agents/github/release-manager.md +367 -0
- package/.claude/agents/github/release-swarm.md +583 -0
- package/.claude/agents/github/repo-architect.md +398 -0
- package/.claude/agents/github/swarm-issue.md +573 -0
- package/.claude/agents/github/swarm-pr.md +428 -0
- package/.claude/agents/github/sync-coordinator.md +452 -0
- package/.claude/agents/github/workflow-automation.md +635 -0
- package/.claude/agents/goal/code-goal-planner.md +446 -0
- package/.claude/agents/goal/goal-planner.md +168 -0
- package/.claude/agents/hive-mind/collective-intelligence-coordinator.md +130 -0
- package/.claude/agents/hive-mind/queen-coordinator.md +203 -0
- package/.claude/agents/hive-mind/scout-explorer.md +242 -0
- package/.claude/agents/hive-mind/swarm-memory-manager.md +193 -0
- package/.claude/agents/hive-mind/worker-specialist.md +217 -0
- package/.claude/agents/neural/safla-neural.md +74 -0
- package/.claude/agents/optimization/benchmark-suite.md +665 -0
- package/.claude/agents/optimization/load-balancer.md +431 -0
- package/.claude/agents/optimization/performance-monitor.md +672 -0
- package/.claude/agents/optimization/resource-allocator.md +674 -0
- package/.claude/agents/optimization/topology-optimizer.md +808 -0
- package/.claude/agents/qe-api-contract-validator.md +1088 -0
- package/.claude/agents/qe-chaos-engineer.md +736 -0
- package/.claude/agents/qe-coverage-analyzer.md +282 -0
- package/.claude/agents/qe-deployment-readiness.md +1109 -0
- package/.claude/agents/qe-flaky-test-hunter.md +1121 -0
- package/.claude/agents/qe-fleet-commander.md +641 -0
- package/.claude/agents/qe-performance-tester.md +354 -0
- package/.claude/agents/qe-production-intelligence.md +1162 -0
- package/.claude/agents/qe-quality-gate.md +294 -0
- package/.claude/agents/qe-regression-risk-analyzer.md +947 -0
- package/.claude/agents/qe-requirements-validator.md +691 -0
- package/.claude/agents/qe-security-scanner.md +430 -0
- package/.claude/agents/qe-test-data-architect.md +1007 -0
- package/.claude/agents/qe-test-executor.md +365 -0
- package/.claude/agents/qe-test-generator.md +332 -0
- package/.claude/agents/qe-visual-tester.md +754 -0
- package/.claude/agents/sparc/architecture.md +472 -0
- package/.claude/agents/sparc/pseudocode.md +318 -0
- package/.claude/agents/sparc/refinement.md +525 -0
- package/.claude/agents/sparc/specification.md +276 -0
- package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +226 -0
- package/.claude/agents/swarm/adaptive-coordinator.md +396 -0
- package/.claude/agents/swarm/hierarchical-coordinator.md +327 -0
- package/.claude/agents/swarm/mesh-coordinator.md +392 -0
- package/.claude/agents/templates/automation-smart-agent.md +205 -0
- package/.claude/agents/templates/coordinator-swarm-init.md +105 -0
- package/.claude/agents/templates/github-pr-manager.md +177 -0
- package/.claude/agents/templates/implementer-sparc-coder.md +259 -0
- package/.claude/agents/templates/memory-coordinator.md +187 -0
- package/.claude/agents/templates/migration-plan.md +746 -0
- package/.claude/agents/templates/orchestrator-task.md +139 -0
- package/.claude/agents/templates/performance-analyzer.md +199 -0
- package/.claude/agents/templates/sparc-coordinator.md +183 -0
- package/.claude/agents/testing/unit/tdd-london-swarm.md +244 -0
- package/.claude/agents/testing/validation/production-validator.md +395 -0
- package/.claude/aqe-fleet.json +47 -0
- package/.claude/commands/README.md +106 -0
- package/.claude/commands/agents/README.md +10 -0
- package/.claude/commands/agents/agent-capabilities.md +21 -0
- package/.claude/commands/agents/agent-coordination.md +28 -0
- package/.claude/commands/agents/agent-spawning.md +28 -0
- package/.claude/commands/agents/agent-types.md +26 -0
- package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +54 -0
- package/.claude/commands/analysis/README.md +9 -0
- package/.claude/commands/analysis/bottleneck-detect.md +162 -0
- package/.claude/commands/analysis/performance-bottlenecks.md +59 -0
- package/.claude/commands/analysis/performance-report.md +25 -0
- package/.claude/commands/analysis/token-efficiency.md +45 -0
- package/.claude/commands/analysis/token-usage.md +25 -0
- package/.claude/commands/aqe-analyze.md +344 -0
- package/.claude/commands/aqe-benchmark.md +466 -0
- package/.claude/commands/aqe-chaos.md +443 -0
- package/.claude/commands/aqe-execute.md +322 -0
- package/.claude/commands/aqe-fleet-status.md +431 -0
- package/.claude/commands/aqe-generate.md +301 -0
- package/.claude/commands/aqe-optimize.md +361 -0
- package/.claude/commands/aqe-report.md +411 -0
- package/.claude/commands/automation/README.md +9 -0
- package/.claude/commands/automation/auto-agent.md +122 -0
- package/.claude/commands/automation/self-healing.md +106 -0
- package/.claude/commands/automation/session-memory.md +90 -0
- package/.claude/commands/automation/smart-agents.md +73 -0
- package/.claude/commands/automation/smart-spawn.md +25 -0
- package/.claude/commands/automation/workflow-select.md +25 -0
- package/.claude/commands/coordination/README.md +9 -0
- package/.claude/commands/coordination/agent-spawn.md +25 -0
- package/.claude/commands/coordination/init.md +44 -0
- package/.claude/commands/coordination/orchestrate.md +43 -0
- package/.claude/commands/coordination/spawn.md +45 -0
- package/.claude/commands/coordination/swarm-init.md +85 -0
- package/.claude/commands/coordination/task-orchestrate.md +25 -0
- package/.claude/commands/flow-nexus/app-store.md +124 -0
- package/.claude/commands/flow-nexus/challenges.md +120 -0
- package/.claude/commands/flow-nexus/login-registration.md +65 -0
- package/.claude/commands/flow-nexus/neural-network.md +134 -0
- package/.claude/commands/flow-nexus/payments.md +116 -0
- package/.claude/commands/flow-nexus/sandbox.md +83 -0
- package/.claude/commands/flow-nexus/swarm.md +87 -0
- package/.claude/commands/flow-nexus/user-tools.md +152 -0
- package/.claude/commands/flow-nexus/workflow.md +115 -0
- package/.claude/commands/github/README.md +11 -0
- package/.claude/commands/github/code-review-swarm.md +514 -0
- package/.claude/commands/github/code-review.md +25 -0
- package/.claude/commands/github/github-modes.md +147 -0
- package/.claude/commands/github/github-swarm.md +121 -0
- package/.claude/commands/github/issue-tracker.md +292 -0
- package/.claude/commands/github/issue-triage.md +25 -0
- package/.claude/commands/github/multi-repo-swarm.md +519 -0
- package/.claude/commands/github/pr-enhance.md +26 -0
- package/.claude/commands/github/pr-manager.md +170 -0
- package/.claude/commands/github/project-board-sync.md +471 -0
- package/.claude/commands/github/release-manager.md +338 -0
- package/.claude/commands/github/release-swarm.md +544 -0
- package/.claude/commands/github/repo-analyze.md +25 -0
- package/.claude/commands/github/repo-architect.md +367 -0
- package/.claude/commands/github/swarm-issue.md +482 -0
- package/.claude/commands/github/swarm-pr.md +285 -0
- package/.claude/commands/github/sync-coordinator.md +301 -0
- package/.claude/commands/github/workflow-automation.md +442 -0
- package/.claude/commands/hive-mind/README.md +17 -0
- package/.claude/commands/hive-mind/hive-mind-consensus.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-init.md +18 -0
- package/.claude/commands/hive-mind/hive-mind-memory.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-metrics.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-resume.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-sessions.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-spawn.md +21 -0
- package/.claude/commands/hive-mind/hive-mind-status.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-stop.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-wizard.md +8 -0
- package/.claude/commands/hive-mind/hive-mind.md +27 -0
- package/.claude/commands/hooks/README.md +11 -0
- package/.claude/commands/hooks/overview.md +132 -0
- package/.claude/commands/hooks/post-edit.md +117 -0
- package/.claude/commands/hooks/post-task.md +112 -0
- package/.claude/commands/hooks/pre-edit.md +113 -0
- package/.claude/commands/hooks/pre-task.md +111 -0
- package/.claude/commands/hooks/session-end.md +118 -0
- package/.claude/commands/hooks/setup.md +103 -0
- package/.claude/commands/memory/README.md +9 -0
- package/.claude/commands/memory/memory-persist.md +25 -0
- package/.claude/commands/memory/memory-search.md +25 -0
- package/.claude/commands/memory/memory-usage.md +25 -0
- package/.claude/commands/memory/neural.md +47 -0
- package/.claude/commands/memory/usage.md +46 -0
- package/.claude/commands/monitoring/README.md +9 -0
- package/.claude/commands/monitoring/agent-metrics.md +25 -0
- package/.claude/commands/monitoring/agents.md +44 -0
- package/.claude/commands/monitoring/real-time-view.md +25 -0
- package/.claude/commands/monitoring/status.md +46 -0
- package/.claude/commands/monitoring/swarm-monitor.md +25 -0
- package/.claude/commands/optimization/README.md +9 -0
- package/.claude/commands/optimization/auto-topology.md +62 -0
- package/.claude/commands/optimization/cache-manage.md +25 -0
- package/.claude/commands/optimization/parallel-execute.md +25 -0
- package/.claude/commands/optimization/parallel-execution.md +50 -0
- package/.claude/commands/optimization/topology-optimize.md +25 -0
- package/.claude/commands/pair/commands.md +546 -0
- package/.claude/commands/pair/config.md +510 -0
- package/.claude/commands/pair/examples.md +512 -0
- package/.claude/commands/pair/modes.md +348 -0
- package/.claude/commands/pair/session.md +407 -0
- package/.claude/commands/pair/start.md +209 -0
- package/.claude/commands/sparc/analyzer.md +52 -0
- package/.claude/commands/sparc/architect.md +53 -0
- package/.claude/commands/sparc/batch-executor.md +54 -0
- package/.claude/commands/sparc/coder.md +54 -0
- package/.claude/commands/sparc/debugger.md +54 -0
- package/.claude/commands/sparc/designer.md +53 -0
- package/.claude/commands/sparc/documenter.md +54 -0
- package/.claude/commands/sparc/innovator.md +54 -0
- package/.claude/commands/sparc/memory-manager.md +54 -0
- package/.claude/commands/sparc/optimizer.md +54 -0
- package/.claude/commands/sparc/orchestrator.md +132 -0
- package/.claude/commands/sparc/researcher.md +54 -0
- package/.claude/commands/sparc/reviewer.md +54 -0
- package/.claude/commands/sparc/sparc-modes.md +174 -0
- package/.claude/commands/sparc/swarm-coordinator.md +54 -0
- package/.claude/commands/sparc/tdd.md +54 -0
- package/.claude/commands/sparc/tester.md +54 -0
- package/.claude/commands/sparc/workflow-manager.md +54 -0
- package/.claude/commands/stream-chain/pipeline.md +121 -0
- package/.claude/commands/stream-chain/run.md +70 -0
- package/.claude/commands/swarm/README.md +15 -0
- package/.claude/commands/swarm/analysis.md +95 -0
- package/.claude/commands/swarm/development.md +96 -0
- package/.claude/commands/swarm/examples.md +168 -0
- package/.claude/commands/swarm/maintenance.md +102 -0
- package/.claude/commands/swarm/optimization.md +117 -0
- package/.claude/commands/swarm/research.md +136 -0
- package/.claude/commands/swarm/swarm-analysis.md +8 -0
- package/.claude/commands/swarm/swarm-background.md +8 -0
- package/.claude/commands/swarm/swarm-init.md +19 -0
- package/.claude/commands/swarm/swarm-modes.md +8 -0
- package/.claude/commands/swarm/swarm-monitor.md +8 -0
- package/.claude/commands/swarm/swarm-spawn.md +19 -0
- package/.claude/commands/swarm/swarm-status.md +8 -0
- package/.claude/commands/swarm/swarm-strategies.md +8 -0
- package/.claude/commands/swarm/swarm.md +27 -0
- package/.claude/commands/swarm/testing.md +131 -0
- package/.claude/commands/training/README.md +9 -0
- package/.claude/commands/training/model-update.md +25 -0
- package/.claude/commands/training/neural-patterns.md +74 -0
- package/.claude/commands/training/neural-train.md +25 -0
- package/.claude/commands/training/pattern-learn.md +25 -0
- package/.claude/commands/training/specialization.md +63 -0
- package/.claude/commands/truth/start.md +143 -0
- package/.claude/commands/verify/check.md +50 -0
- package/.claude/commands/verify/start.md +128 -0
- package/.claude/commands/workflows/README.md +9 -0
- package/.claude/commands/workflows/development.md +78 -0
- package/.claude/commands/workflows/research.md +63 -0
- package/.claude/commands/workflows/workflow-create.md +25 -0
- package/.claude/commands/workflows/workflow-execute.md +25 -0
- package/.claude/commands/workflows/workflow-export.md +25 -0
- package/.claude/helpers/checkpoint-manager.sh +251 -0
- package/.claude/helpers/github-safe.js +106 -0
- package/.claude/helpers/github-setup.sh +28 -0
- package/.claude/helpers/quick-start.sh +19 -0
- package/.claude/helpers/setup-mcp.sh +18 -0
- package/.claude/helpers/standard-checkpoint-hooks.sh +179 -0
- package/.claude/settings.json +114 -0
- package/.claude/settings.local.json +10 -0
- package/CONTRIBUTING.md +897 -0
- package/LICENSE +21 -0
- package/README.md +632 -0
- package/bin/aqe +959 -0
- package/config/fleet.yaml +50 -0
- package/dist/agents/ApiContractValidatorAgent.d.ts +222 -0
- package/dist/agents/ApiContractValidatorAgent.d.ts.map +1 -0
- package/dist/agents/ApiContractValidatorAgent.js +787 -0
- package/dist/agents/ApiContractValidatorAgent.js.map +1 -0
- package/dist/agents/BaseAgent.d.ts +147 -0
- package/dist/agents/BaseAgent.d.ts.map +1 -0
- package/dist/agents/BaseAgent.js +374 -0
- package/dist/agents/BaseAgent.js.map +1 -0
- package/dist/agents/CoverageAnalyzerAgent.d.ts +103 -0
- package/dist/agents/CoverageAnalyzerAgent.d.ts.map +1 -0
- package/dist/agents/CoverageAnalyzerAgent.js +466 -0
- package/dist/agents/CoverageAnalyzerAgent.js.map +1 -0
- package/dist/agents/DeploymentReadinessAgent.d.ts +244 -0
- package/dist/agents/DeploymentReadinessAgent.d.ts.map +1 -0
- package/dist/agents/DeploymentReadinessAgent.js +974 -0
- package/dist/agents/DeploymentReadinessAgent.js.map +1 -0
- package/dist/agents/FlakyTestHunterAgent.d.ts +172 -0
- package/dist/agents/FlakyTestHunterAgent.d.ts.map +1 -0
- package/dist/agents/FlakyTestHunterAgent.js +867 -0
- package/dist/agents/FlakyTestHunterAgent.js.map +1 -0
- package/dist/agents/FleetCommanderAgent.d.ts +154 -0
- package/dist/agents/FleetCommanderAgent.d.ts.map +1 -0
- package/dist/agents/FleetCommanderAgent.js +924 -0
- package/dist/agents/FleetCommanderAgent.js.map +1 -0
- package/dist/agents/PerformanceTesterAgent.d.ts +194 -0
- package/dist/agents/PerformanceTesterAgent.d.ts.map +1 -0
- package/dist/agents/PerformanceTesterAgent.js +972 -0
- package/dist/agents/PerformanceTesterAgent.js.map +1 -0
- package/dist/agents/ProductionIntelligenceAgent.d.ts +224 -0
- package/dist/agents/ProductionIntelligenceAgent.d.ts.map +1 -0
- package/dist/agents/ProductionIntelligenceAgent.js +856 -0
- package/dist/agents/ProductionIntelligenceAgent.js.map +1 -0
- package/dist/agents/QualityAnalyzerAgent.d.ts +67 -0
- package/dist/agents/QualityAnalyzerAgent.d.ts.map +1 -0
- package/dist/agents/QualityAnalyzerAgent.js +453 -0
- package/dist/agents/QualityAnalyzerAgent.js.map +1 -0
- package/dist/agents/QualityGateAgent.d.ts +104 -0
- package/dist/agents/QualityGateAgent.d.ts.map +1 -0
- package/dist/agents/QualityGateAgent.js +522 -0
- package/dist/agents/QualityGateAgent.js.map +1 -0
- package/dist/agents/RegressionRiskAnalyzerAgent.d.ts +274 -0
- package/dist/agents/RegressionRiskAnalyzerAgent.d.ts.map +1 -0
- package/dist/agents/RegressionRiskAnalyzerAgent.js +1076 -0
- package/dist/agents/RegressionRiskAnalyzerAgent.js.map +1 -0
- package/dist/agents/RequirementsValidatorAgent.d.ts +195 -0
- package/dist/agents/RequirementsValidatorAgent.d.ts.map +1 -0
- package/dist/agents/RequirementsValidatorAgent.js +992 -0
- package/dist/agents/RequirementsValidatorAgent.js.map +1 -0
- package/dist/agents/SecurityScannerAgent.d.ts +126 -0
- package/dist/agents/SecurityScannerAgent.d.ts.map +1 -0
- package/dist/agents/SecurityScannerAgent.js +695 -0
- package/dist/agents/SecurityScannerAgent.js.map +1 -0
- package/dist/agents/TestDataArchitectAgent.d.ts +452 -0
- package/dist/agents/TestDataArchitectAgent.d.ts.map +1 -0
- package/dist/agents/TestDataArchitectAgent.js +1346 -0
- package/dist/agents/TestDataArchitectAgent.js.map +1 -0
- package/dist/agents/TestExecutorAgent.d.ts +101 -0
- package/dist/agents/TestExecutorAgent.d.ts.map +1 -0
- package/dist/agents/TestExecutorAgent.js +730 -0
- package/dist/agents/TestExecutorAgent.js.map +1 -0
- package/dist/agents/TestGeneratorAgent.d.ts +109 -0
- package/dist/agents/TestGeneratorAgent.d.ts.map +1 -0
- package/dist/agents/TestGeneratorAgent.js +450 -0
- package/dist/agents/TestGeneratorAgent.js.map +1 -0
- package/dist/agents/index.d.ts +51 -0
- package/dist/agents/index.d.ts.map +1 -0
- package/dist/agents/index.js +738 -0
- package/dist/agents/index.js.map +1 -0
- package/dist/cli/commands/analyze.d.ts +32 -0
- package/dist/cli/commands/analyze.d.ts.map +1 -0
- package/dist/cli/commands/analyze.js +764 -0
- package/dist/cli/commands/analyze.js.map +1 -0
- package/dist/cli/commands/fleet.d.ts +36 -0
- package/dist/cli/commands/fleet.d.ts.map +1 -0
- package/dist/cli/commands/fleet.js +745 -0
- package/dist/cli/commands/fleet.js.map +1 -0
- package/dist/cli/commands/generate.d.ts +24 -0
- package/dist/cli/commands/generate.d.ts.map +1 -0
- package/dist/cli/commands/generate.js +424 -0
- package/dist/cli/commands/generate.js.map +1 -0
- package/dist/cli/commands/init.d.ts +17 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +570 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/run.d.ts +25 -0
- package/dist/cli/commands/run.d.ts.map +1 -0
- package/dist/cli/commands/run.js +558 -0
- package/dist/cli/commands/run.js.map +1 -0
- package/dist/cli/index-spec.d.ts +3 -0
- package/dist/cli/index-spec.d.ts.map +1 -0
- package/dist/cli/index-spec.js +154 -0
- package/dist/cli/index-spec.js.map +1 -0
- package/dist/cli/index-working.d.ts +7 -0
- package/dist/cli/index-working.d.ts.map +1 -0
- package/dist/cli/index-working.js +470 -0
- package/dist/cli/index-working.js.map +1 -0
- package/dist/cli/index.d.ts +9 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +174 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/core/Agent.d.ts +189 -0
- package/dist/core/Agent.d.ts.map +1 -0
- package/dist/core/Agent.js +288 -0
- package/dist/core/Agent.js.map +1 -0
- package/dist/core/EventBus.d.ts +40 -0
- package/dist/core/EventBus.d.ts.map +1 -0
- package/dist/core/EventBus.js +114 -0
- package/dist/core/EventBus.js.map +1 -0
- package/dist/core/FleetManager.d.ts +219 -0
- package/dist/core/FleetManager.d.ts.map +1 -0
- package/dist/core/FleetManager.js +354 -0
- package/dist/core/FleetManager.js.map +1 -0
- package/dist/core/MemoryManager.d.ts +119 -0
- package/dist/core/MemoryManager.d.ts.map +1 -0
- package/dist/core/MemoryManager.js +460 -0
- package/dist/core/MemoryManager.js.map +1 -0
- package/dist/core/Task.d.ts +264 -0
- package/dist/core/Task.d.ts.map +1 -0
- package/dist/core/Task.js +397 -0
- package/dist/core/Task.js.map +1 -0
- package/dist/core/coverage-analyzer.d.ts +50 -0
- package/dist/core/coverage-analyzer.d.ts.map +1 -0
- package/dist/core/coverage-analyzer.js +146 -0
- package/dist/core/coverage-analyzer.js.map +1 -0
- package/dist/core/index.d.ts +14 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +20 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/quality-gate.d.ts +81 -0
- package/dist/core/quality-gate.d.ts.map +1 -0
- package/dist/core/quality-gate.js +254 -0
- package/dist/core/quality-gate.js.map +1 -0
- package/dist/coverage/coverage-collector.d.ts +62 -0
- package/dist/coverage/coverage-collector.d.ts.map +1 -0
- package/dist/coverage/coverage-collector.js +61 -0
- package/dist/coverage/coverage-collector.js.map +1 -0
- package/dist/coverage/coverage-reporter.d.ts +42 -0
- package/dist/coverage/coverage-reporter.d.ts.map +1 -0
- package/dist/coverage/coverage-reporter.js +53 -0
- package/dist/coverage/coverage-reporter.js.map +1 -0
- package/dist/index.d.ts +89 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +142 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/handlers/agent-spawn.d.ts +72 -0
- package/dist/mcp/handlers/agent-spawn.d.ts.map +1 -0
- package/dist/mcp/handlers/agent-spawn.js +255 -0
- package/dist/mcp/handlers/agent-spawn.js.map +1 -0
- package/dist/mcp/handlers/base-handler.d.ts +53 -0
- package/dist/mcp/handlers/base-handler.d.ts.map +1 -0
- package/dist/mcp/handlers/base-handler.js +77 -0
- package/dist/mcp/handlers/base-handler.js.map +1 -0
- package/dist/mcp/handlers/fleet-init.d.ts +55 -0
- package/dist/mcp/handlers/fleet-init.d.ts.map +1 -0
- package/dist/mcp/handlers/fleet-init.js +149 -0
- package/dist/mcp/handlers/fleet-init.js.map +1 -0
- package/dist/mcp/handlers/fleet-status.d.ts +103 -0
- package/dist/mcp/handlers/fleet-status.d.ts.map +1 -0
- package/dist/mcp/handlers/fleet-status.js +244 -0
- package/dist/mcp/handlers/fleet-status.js.map +1 -0
- package/dist/mcp/handlers/optimize-tests.d.ts +219 -0
- package/dist/mcp/handlers/optimize-tests.d.ts.map +1 -0
- package/dist/mcp/handlers/optimize-tests.js +532 -0
- package/dist/mcp/handlers/optimize-tests.js.map +1 -0
- package/dist/mcp/handlers/predict-defects.d.ts +194 -0
- package/dist/mcp/handlers/predict-defects.d.ts.map +1 -0
- package/dist/mcp/handlers/predict-defects.js +721 -0
- package/dist/mcp/handlers/predict-defects.js.map +1 -0
- package/dist/mcp/handlers/quality-analyze.d.ts +273 -0
- package/dist/mcp/handlers/quality-analyze.d.ts.map +1 -0
- package/dist/mcp/handlers/quality-analyze.js +702 -0
- package/dist/mcp/handlers/quality-analyze.js.map +1 -0
- package/dist/mcp/handlers/task-orchestrate.d.ts +152 -0
- package/dist/mcp/handlers/task-orchestrate.d.ts.map +1 -0
- package/dist/mcp/handlers/task-orchestrate.js +629 -0
- package/dist/mcp/handlers/task-orchestrate.js.map +1 -0
- package/dist/mcp/handlers/test-execute.d.ts +132 -0
- package/dist/mcp/handlers/test-execute.d.ts.map +1 -0
- package/dist/mcp/handlers/test-execute.js +436 -0
- package/dist/mcp/handlers/test-execute.js.map +1 -0
- package/dist/mcp/handlers/test-generate.d.ts +107 -0
- package/dist/mcp/handlers/test-generate.d.ts.map +1 -0
- package/dist/mcp/handlers/test-generate.js +437 -0
- package/dist/mcp/handlers/test-generate.js.map +1 -0
- package/dist/mcp/server.d.ts +99 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +214 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/services/AgentRegistry.d.ts +191 -0
- package/dist/mcp/services/AgentRegistry.d.ts.map +1 -0
- package/dist/mcp/services/AgentRegistry.js +403 -0
- package/dist/mcp/services/AgentRegistry.js.map +1 -0
- package/dist/mcp/services/HookExecutor.d.ts +165 -0
- package/dist/mcp/services/HookExecutor.d.ts.map +1 -0
- package/dist/mcp/services/HookExecutor.js +327 -0
- package/dist/mcp/services/HookExecutor.js.map +1 -0
- package/dist/mcp/start.d.ts +7 -0
- package/dist/mcp/start.d.ts.map +1 -0
- package/dist/mcp/start.js +35 -0
- package/dist/mcp/start.js.map +1 -0
- package/dist/mcp/tools.d.ts +81 -0
- package/dist/mcp/tools.d.ts.map +1 -0
- package/dist/mcp/tools.js +471 -0
- package/dist/mcp/tools.js.map +1 -0
- package/dist/optimization/sublinear-solver.d.ts +72 -0
- package/dist/optimization/sublinear-solver.d.ts.map +1 -0
- package/dist/optimization/sublinear-solver.js +263 -0
- package/dist/optimization/sublinear-solver.js.map +1 -0
- package/dist/scripts/verifyComplexity.d.ts +8 -0
- package/dist/scripts/verifyComplexity.d.ts.map +1 -0
- package/dist/scripts/verifyComplexity.js +56 -0
- package/dist/scripts/verifyComplexity.js.map +1 -0
- package/dist/types/api-contract.types.d.ts +273 -0
- package/dist/types/api-contract.types.d.ts.map +1 -0
- package/dist/types/api-contract.types.js +18 -0
- package/dist/types/api-contract.types.js.map +1 -0
- package/dist/types/errors.d.ts +104 -0
- package/dist/types/errors.d.ts.map +1 -0
- package/dist/types/errors.js +226 -0
- package/dist/types/errors.js.map +1 -0
- package/dist/types/events.d.ts +101 -0
- package/dist/types/events.d.ts.map +1 -0
- package/dist/types/events.js +6 -0
- package/dist/types/events.js.map +1 -0
- package/dist/types/index.d.ts +570 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +131 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/Config.d.ts +128 -0
- package/dist/utils/Config.d.ts.map +1 -0
- package/dist/utils/Config.js +232 -0
- package/dist/utils/Config.js.map +1 -0
- package/dist/utils/Database.d.ts +112 -0
- package/dist/utils/Database.d.ts.map +1 -0
- package/dist/utils/Database.js +352 -0
- package/dist/utils/Database.js.map +1 -0
- package/dist/utils/Logger.d.ts +58 -0
- package/dist/utils/Logger.d.ts.map +1 -0
- package/dist/utils/Logger.js +125 -0
- package/dist/utils/Logger.js.map +1 -0
- package/dist/utils/index.d.ts +9 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +14 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/sublinear/coverageOptimizer.d.ts +84 -0
- package/dist/utils/sublinear/coverageOptimizer.d.ts.map +1 -0
- package/dist/utils/sublinear/coverageOptimizer.js +415 -0
- package/dist/utils/sublinear/coverageOptimizer.js.map +1 -0
- package/dist/utils/sublinear/index.d.ts +50 -0
- package/dist/utils/sublinear/index.d.ts.map +1 -0
- package/dist/utils/sublinear/index.js +390 -0
- package/dist/utils/sublinear/index.js.map +1 -0
- package/dist/utils/sublinear/matrixSolver.d.ts +132 -0
- package/dist/utils/sublinear/matrixSolver.d.ts.map +1 -0
- package/dist/utils/sublinear/matrixSolver.js +642 -0
- package/dist/utils/sublinear/matrixSolver.js.map +1 -0
- package/dist/utils/sublinear/temporalPredictor.d.ts +195 -0
- package/dist/utils/sublinear/temporalPredictor.d.ts.map +1 -0
- package/dist/utils/sublinear/temporalPredictor.js +474 -0
- package/dist/utils/sublinear/temporalPredictor.js.map +1 -0
- package/dist/utils/sublinear/testSelector.d.ts +81 -0
- package/dist/utils/sublinear/testSelector.d.ts.map +1 -0
- package/dist/utils/sublinear/testSelector.js +303 -0
- package/dist/utils/sublinear/testSelector.js.map +1 -0
- package/package.json +131 -0
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Coverage Analyzer - Analyzes test coverage metrics
|
|
3
|
+
*/
|
|
4
|
+
export interface CoverageMetrics {
|
|
5
|
+
linesCovered: number;
|
|
6
|
+
totalLines: number;
|
|
7
|
+
branchesCovered: number;
|
|
8
|
+
totalBranches: number;
|
|
9
|
+
functionsCovered: number;
|
|
10
|
+
totalFunctions: number;
|
|
11
|
+
statementsCovered: number;
|
|
12
|
+
totalStatements: number;
|
|
13
|
+
percentage: number;
|
|
14
|
+
}
|
|
15
|
+
export interface CoverageReport {
|
|
16
|
+
overall: CoverageMetrics;
|
|
17
|
+
files: Map<string, CoverageMetrics>;
|
|
18
|
+
uncoveredLines: Map<string, number[]>;
|
|
19
|
+
timestamp: Date;
|
|
20
|
+
}
|
|
21
|
+
export declare class CoverageAnalyzer {
|
|
22
|
+
private threshold;
|
|
23
|
+
constructor(threshold?: number);
|
|
24
|
+
/**
|
|
25
|
+
* Analyze coverage data from Jest/Istanbul
|
|
26
|
+
*/
|
|
27
|
+
analyzeCoverage(coverageData: any): Promise<CoverageReport>;
|
|
28
|
+
/**
|
|
29
|
+
* Process coverage data for a single file
|
|
30
|
+
*/
|
|
31
|
+
private processFileCoverage;
|
|
32
|
+
/**
|
|
33
|
+
* Get uncovered line numbers for a file
|
|
34
|
+
*/
|
|
35
|
+
private getUncoveredLines;
|
|
36
|
+
/**
|
|
37
|
+
* Check if coverage meets threshold
|
|
38
|
+
*/
|
|
39
|
+
meetsThreshold(report: CoverageReport): boolean;
|
|
40
|
+
/**
|
|
41
|
+
* Get coverage gaps that need attention
|
|
42
|
+
*/
|
|
43
|
+
getCoverageGaps(report: CoverageReport): string[];
|
|
44
|
+
/**
|
|
45
|
+
* Generate coverage summary
|
|
46
|
+
*/
|
|
47
|
+
generateSummary(report: CoverageReport): string;
|
|
48
|
+
}
|
|
49
|
+
export default CoverageAnalyzer;
|
|
50
|
+
//# sourceMappingURL=coverage-analyzer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"coverage-analyzer.d.ts","sourceRoot":"","sources":["../../src/core/coverage-analyzer.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,MAAM,WAAW,eAAe;IAC9B,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,aAAa,EAAE,MAAM,CAAC;IACtB,gBAAgB,EAAE,MAAM,CAAC;IACzB,cAAc,EAAE,MAAM,CAAC;IACvB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,eAAe,EAAE,MAAM,CAAC;IACxB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,eAAe,CAAC;IACzB,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;IACpC,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;IACtC,SAAS,EAAE,IAAI,CAAC;CACjB;AAED,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,SAAS,CAAS;gBAEd,SAAS,GAAE,MAAW;IAIlC;;OAEG;IACG,eAAe,CAAC,YAAY,EAAE,GAAG,GAAG,OAAO,CAAC,cAAc,CAAC;IAuDjE;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAiC3B;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAgBzB;;OAEG;IACH,cAAc,CAAC,MAAM,EAAE,cAAc,GAAG,OAAO;IAI/C;;OAEG;IACH,eAAe,CAAC,MAAM,EAAE,cAAc,GAAG,MAAM,EAAE;IAYjD;;OAEG;IACH,eAAe,CAAC,MAAM,EAAE,cAAc,GAAG,MAAM;CAkBhD;AAED,eAAe,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Coverage Analyzer - Analyzes test coverage metrics
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.CoverageAnalyzer = void 0;
|
|
7
|
+
class CoverageAnalyzer {
|
|
8
|
+
constructor(threshold = 80) {
|
|
9
|
+
this.threshold = threshold;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Analyze coverage data from Jest/Istanbul
|
|
13
|
+
*/
|
|
14
|
+
async analyzeCoverage(coverageData) {
|
|
15
|
+
const files = new Map();
|
|
16
|
+
const uncoveredLines = new Map();
|
|
17
|
+
let totalLines = 0;
|
|
18
|
+
let coveredLines = 0;
|
|
19
|
+
let totalBranches = 0;
|
|
20
|
+
let coveredBranches = 0;
|
|
21
|
+
let totalFunctions = 0;
|
|
22
|
+
let coveredFunctions = 0;
|
|
23
|
+
let totalStatements = 0;
|
|
24
|
+
let coveredStatements = 0;
|
|
25
|
+
// Process coverage data for each file
|
|
26
|
+
for (const [filePath, fileCoverage] of Object.entries(coverageData)) {
|
|
27
|
+
const fileMetrics = this.processFileCoverage(fileCoverage);
|
|
28
|
+
files.set(filePath, fileMetrics);
|
|
29
|
+
// Track uncovered lines
|
|
30
|
+
const uncovered = this.getUncoveredLines(fileCoverage);
|
|
31
|
+
if (uncovered.length > 0) {
|
|
32
|
+
uncoveredLines.set(filePath, uncovered);
|
|
33
|
+
}
|
|
34
|
+
// Accumulate totals
|
|
35
|
+
totalLines += fileMetrics.totalLines;
|
|
36
|
+
coveredLines += fileMetrics.linesCovered;
|
|
37
|
+
totalBranches += fileMetrics.totalBranches;
|
|
38
|
+
coveredBranches += fileMetrics.branchesCovered;
|
|
39
|
+
totalFunctions += fileMetrics.totalFunctions;
|
|
40
|
+
coveredFunctions += fileMetrics.functionsCovered;
|
|
41
|
+
totalStatements += fileMetrics.totalStatements;
|
|
42
|
+
coveredStatements += fileMetrics.statementsCovered;
|
|
43
|
+
}
|
|
44
|
+
const overall = {
|
|
45
|
+
linesCovered: coveredLines,
|
|
46
|
+
totalLines,
|
|
47
|
+
branchesCovered: coveredBranches,
|
|
48
|
+
totalBranches,
|
|
49
|
+
functionsCovered: coveredFunctions,
|
|
50
|
+
totalFunctions,
|
|
51
|
+
statementsCovered: coveredStatements,
|
|
52
|
+
totalStatements,
|
|
53
|
+
percentage: totalLines > 0 ? (coveredLines / totalLines) * 100 : 0
|
|
54
|
+
};
|
|
55
|
+
return {
|
|
56
|
+
overall,
|
|
57
|
+
files,
|
|
58
|
+
uncoveredLines,
|
|
59
|
+
timestamp: new Date()
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Process coverage data for a single file
|
|
64
|
+
*/
|
|
65
|
+
processFileCoverage(fileCoverage) {
|
|
66
|
+
const statements = fileCoverage.s || {};
|
|
67
|
+
const branches = fileCoverage.b || {};
|
|
68
|
+
const functions = fileCoverage.f || {};
|
|
69
|
+
const lines = fileCoverage.statementMap || {};
|
|
70
|
+
const totalStatements = Object.keys(statements).length;
|
|
71
|
+
const coveredStatements = Object.values(statements).filter(count => count > 0).length;
|
|
72
|
+
const totalBranches = Object.values(branches).reduce((total, branch) => total + branch.length, 0);
|
|
73
|
+
const coveredBranches = Object.values(branches).reduce((total, branch) => total + branch.filter(count => count > 0).length, 0);
|
|
74
|
+
const totalFunctions = Object.keys(functions).length;
|
|
75
|
+
const coveredFunctions = Object.values(functions).filter(count => count > 0).length;
|
|
76
|
+
const totalLines = Object.keys(lines).length;
|
|
77
|
+
const coveredLines = Object.keys(statements).filter(key => statements[key] > 0).length;
|
|
78
|
+
return {
|
|
79
|
+
linesCovered: coveredLines,
|
|
80
|
+
totalLines,
|
|
81
|
+
branchesCovered: coveredBranches,
|
|
82
|
+
totalBranches: totalBranches,
|
|
83
|
+
functionsCovered: coveredFunctions,
|
|
84
|
+
totalFunctions,
|
|
85
|
+
statementsCovered: coveredStatements,
|
|
86
|
+
totalStatements,
|
|
87
|
+
percentage: totalLines > 0 ? (coveredLines / totalLines) * 100 : 0
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Get uncovered line numbers for a file
|
|
92
|
+
*/
|
|
93
|
+
getUncoveredLines(fileCoverage) {
|
|
94
|
+
const statements = fileCoverage.s || {};
|
|
95
|
+
const statementMap = fileCoverage.statementMap || {};
|
|
96
|
+
const uncovered = [];
|
|
97
|
+
for (const [statementId, count] of Object.entries(statements)) {
|
|
98
|
+
if (count === 0 && statementMap[statementId]) {
|
|
99
|
+
const location = statementMap[statementId];
|
|
100
|
+
uncovered.push(location.start.line);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
return [...new Set(uncovered)].sort((a, b) => a - b);
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Check if coverage meets threshold
|
|
107
|
+
*/
|
|
108
|
+
meetsThreshold(report) {
|
|
109
|
+
return report.overall.percentage >= this.threshold;
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Get coverage gaps that need attention
|
|
113
|
+
*/
|
|
114
|
+
getCoverageGaps(report) {
|
|
115
|
+
const gaps = [];
|
|
116
|
+
for (const [filePath, metrics] of report.files) {
|
|
117
|
+
if (metrics.percentage < this.threshold) {
|
|
118
|
+
gaps.push(`${filePath}: ${metrics.percentage.toFixed(1)}% (below ${this.threshold}%)`);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
return gaps;
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Generate coverage summary
|
|
125
|
+
*/
|
|
126
|
+
generateSummary(report) {
|
|
127
|
+
const { overall } = report;
|
|
128
|
+
const status = this.meetsThreshold(report) ? '✅ PASS' : '❌ FAIL';
|
|
129
|
+
return `
|
|
130
|
+
Coverage Report ${status}
|
|
131
|
+
========================
|
|
132
|
+
Overall: ${overall.percentage.toFixed(2)}%
|
|
133
|
+
Lines: ${overall.linesCovered}/${overall.totalLines}
|
|
134
|
+
Branches: ${overall.branchesCovered}/${overall.totalBranches}
|
|
135
|
+
Functions: ${overall.functionsCovered}/${overall.totalFunctions}
|
|
136
|
+
Statements: ${overall.statementsCovered}/${overall.totalStatements}
|
|
137
|
+
|
|
138
|
+
Threshold: ${this.threshold}%
|
|
139
|
+
Files analyzed: ${report.files.size}
|
|
140
|
+
Generated: ${report.timestamp.toISOString()}
|
|
141
|
+
`.trim();
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
exports.CoverageAnalyzer = CoverageAnalyzer;
|
|
145
|
+
exports.default = CoverageAnalyzer;
|
|
146
|
+
//# sourceMappingURL=coverage-analyzer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"coverage-analyzer.js","sourceRoot":"","sources":["../../src/core/coverage-analyzer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Core - Export all core classes
|
|
3
|
+
*/
|
|
4
|
+
export { FleetManager } from './FleetManager';
|
|
5
|
+
export { Agent, AgentStatus } from './Agent';
|
|
6
|
+
export { Task, TaskStatus, TaskPriority } from './Task';
|
|
7
|
+
export { EventBus } from './EventBus';
|
|
8
|
+
export { MemoryManager } from './MemoryManager';
|
|
9
|
+
export type { FleetStatus } from './FleetManager';
|
|
10
|
+
export type { AgentCapability, AgentMetrics } from './Agent';
|
|
11
|
+
export type { TaskMetadata, TaskRequirements } from './Task';
|
|
12
|
+
export type { FleetEvent } from './EventBus';
|
|
13
|
+
export type { MemoryOptions, MemorySearchOptions, MemoryStats } from './MemoryManager';
|
|
14
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAC7C,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,YAAY,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAClD,YAAY,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC7D,YAAY,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC7D,YAAY,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAC7C,YAAY,EAAE,aAAa,EAAE,mBAAmB,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Core - Export all core classes
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.MemoryManager = exports.EventBus = exports.TaskPriority = exports.TaskStatus = exports.Task = exports.AgentStatus = exports.Agent = exports.FleetManager = void 0;
|
|
7
|
+
var FleetManager_1 = require("./FleetManager");
|
|
8
|
+
Object.defineProperty(exports, "FleetManager", { enumerable: true, get: function () { return FleetManager_1.FleetManager; } });
|
|
9
|
+
var Agent_1 = require("./Agent");
|
|
10
|
+
Object.defineProperty(exports, "Agent", { enumerable: true, get: function () { return Agent_1.Agent; } });
|
|
11
|
+
Object.defineProperty(exports, "AgentStatus", { enumerable: true, get: function () { return Agent_1.AgentStatus; } });
|
|
12
|
+
var Task_1 = require("./Task");
|
|
13
|
+
Object.defineProperty(exports, "Task", { enumerable: true, get: function () { return Task_1.Task; } });
|
|
14
|
+
Object.defineProperty(exports, "TaskStatus", { enumerable: true, get: function () { return Task_1.TaskStatus; } });
|
|
15
|
+
Object.defineProperty(exports, "TaskPriority", { enumerable: true, get: function () { return Task_1.TaskPriority; } });
|
|
16
|
+
var EventBus_1 = require("./EventBus");
|
|
17
|
+
Object.defineProperty(exports, "EventBus", { enumerable: true, get: function () { return EventBus_1.EventBus; } });
|
|
18
|
+
var MemoryManager_1 = require("./MemoryManager");
|
|
19
|
+
Object.defineProperty(exports, "MemoryManager", { enumerable: true, get: function () { return MemoryManager_1.MemoryManager; } });
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":";AAAA;;GAEG;;;AAEH,+CAA8C;AAArC,4GAAA,YAAY,OAAA;AACrB,iCAA6C;AAApC,8FAAA,KAAK,OAAA;AAAE,oGAAA,WAAW,OAAA;AAC3B,+BAAwD;AAA/C,4FAAA,IAAI,OAAA;AAAE,kGAAA,UAAU,OAAA;AAAE,oGAAA,YAAY,OAAA;AACvC,uCAAsC;AAA7B,oGAAA,QAAQ,OAAA;AACjB,iDAAgD;AAAvC,8GAAA,aAAa,OAAA"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Quality Gate - Enforces quality standards and gates
|
|
3
|
+
*/
|
|
4
|
+
export interface QualityMetrics {
|
|
5
|
+
testCoverage: number;
|
|
6
|
+
testPassRate: number;
|
|
7
|
+
codeQuality: number;
|
|
8
|
+
securityScore: number;
|
|
9
|
+
performanceScore: number;
|
|
10
|
+
maintainabilityIndex: number;
|
|
11
|
+
}
|
|
12
|
+
export interface QualityRule {
|
|
13
|
+
name: string;
|
|
14
|
+
metric: keyof QualityMetrics;
|
|
15
|
+
threshold: number;
|
|
16
|
+
operator: 'gte' | 'lte' | 'eq';
|
|
17
|
+
weight: number;
|
|
18
|
+
required: boolean;
|
|
19
|
+
}
|
|
20
|
+
export interface QualityGateResult {
|
|
21
|
+
passed: boolean;
|
|
22
|
+
score: number;
|
|
23
|
+
violations: QualityViolation[];
|
|
24
|
+
metrics: QualityMetrics;
|
|
25
|
+
timestamp: Date;
|
|
26
|
+
}
|
|
27
|
+
export interface QualityViolation {
|
|
28
|
+
rule: string;
|
|
29
|
+
metric: string;
|
|
30
|
+
actual: number;
|
|
31
|
+
expected: number;
|
|
32
|
+
severity: 'error' | 'warning' | 'info';
|
|
33
|
+
message: string;
|
|
34
|
+
}
|
|
35
|
+
export declare class QualityGate {
|
|
36
|
+
private rules;
|
|
37
|
+
private strictMode;
|
|
38
|
+
constructor(rules?: QualityRule[], strictMode?: boolean);
|
|
39
|
+
/**
|
|
40
|
+
* Get default quality rules
|
|
41
|
+
*/
|
|
42
|
+
private getDefaultRules;
|
|
43
|
+
/**
|
|
44
|
+
* Evaluate quality metrics against gate rules
|
|
45
|
+
*/
|
|
46
|
+
evaluate(metrics: QualityMetrics): Promise<QualityGateResult>;
|
|
47
|
+
/**
|
|
48
|
+
* Check a single rule against a metric value
|
|
49
|
+
*/
|
|
50
|
+
private checkRule;
|
|
51
|
+
/**
|
|
52
|
+
* Calculate score for a single rule (0-10)
|
|
53
|
+
*/
|
|
54
|
+
private calculateRuleScore;
|
|
55
|
+
/**
|
|
56
|
+
* Determine if the quality gate passes
|
|
57
|
+
*/
|
|
58
|
+
private determineGateStatus;
|
|
59
|
+
/**
|
|
60
|
+
* Add or update a quality rule
|
|
61
|
+
*/
|
|
62
|
+
addRule(rule: QualityRule): void;
|
|
63
|
+
/**
|
|
64
|
+
* Remove a quality rule
|
|
65
|
+
*/
|
|
66
|
+
removeRule(ruleName: string): boolean;
|
|
67
|
+
/**
|
|
68
|
+
* Get current rules
|
|
69
|
+
*/
|
|
70
|
+
getRules(): QualityRule[];
|
|
71
|
+
/**
|
|
72
|
+
* Generate a detailed report
|
|
73
|
+
*/
|
|
74
|
+
generateReport(result: QualityGateResult): string;
|
|
75
|
+
/**
|
|
76
|
+
* Get recommendations based on violations
|
|
77
|
+
*/
|
|
78
|
+
getRecommendations(result: QualityGateResult): string[];
|
|
79
|
+
}
|
|
80
|
+
export default QualityGate;
|
|
81
|
+
//# sourceMappingURL=quality-gate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"quality-gate.d.ts","sourceRoot":"","sources":["../../src/core/quality-gate.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,MAAM,WAAW,cAAc;IAC7B,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,MAAM,CAAC;IACtB,gBAAgB,EAAE,MAAM,CAAC;IACzB,oBAAoB,EAAE,MAAM,CAAC;CAC9B;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,cAAc,CAAC;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,KAAK,GAAG,KAAK,GAAG,IAAI,CAAC;IAC/B,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,WAAW,iBAAiB;IAChC,MAAM,EAAE,OAAO,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,gBAAgB,EAAE,CAAC;IAC/B,OAAO,EAAE,cAAc,CAAC;IACxB,SAAS,EAAE,IAAI,CAAC;CACjB;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;IACvC,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,qBAAa,WAAW;IACtB,OAAO,CAAC,KAAK,CAAgB;IAC7B,OAAO,CAAC,UAAU,CAAU;gBAEhB,KAAK,GAAE,WAAW,EAAO,EAAE,UAAU,GAAE,OAAe;IAKlE;;OAEG;IACH,OAAO,CAAC,eAAe;IA6CvB;;OAEG;IACG,QAAQ,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,iBAAiB,CAAC;IA+BnE;;OAEG;IACH,OAAO,CAAC,SAAS;IAqCjB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAoB1B;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAkB3B;;OAEG;IACH,OAAO,CAAC,IAAI,EAAE,WAAW,GAAG,IAAI;IAShC;;OAEG;IACH,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO;IASrC;;OAEG;IACH,QAAQ,IAAI,WAAW,EAAE;IAIzB;;OAEG;IACH,cAAc,CAAC,MAAM,EAAE,iBAAiB,GAAG,MAAM;IAgCjD;;OAEG;IACH,kBAAkB,CAAC,MAAM,EAAE,iBAAiB,GAAG,MAAM,EAAE;CA4BxD;AAED,eAAe,WAAW,CAAC"}
|
|
@@ -0,0 +1,254 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Quality Gate - Enforces quality standards and gates
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.QualityGate = void 0;
|
|
7
|
+
class QualityGate {
|
|
8
|
+
constructor(rules = [], strictMode = false) {
|
|
9
|
+
this.rules = rules.length > 0 ? rules : this.getDefaultRules();
|
|
10
|
+
this.strictMode = strictMode;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Get default quality rules
|
|
14
|
+
*/
|
|
15
|
+
getDefaultRules() {
|
|
16
|
+
return [
|
|
17
|
+
{
|
|
18
|
+
name: 'Minimum Test Coverage',
|
|
19
|
+
metric: 'testCoverage',
|
|
20
|
+
threshold: 80,
|
|
21
|
+
operator: 'gte',
|
|
22
|
+
weight: 0.3,
|
|
23
|
+
required: true
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
name: 'Test Pass Rate',
|
|
27
|
+
metric: 'testPassRate',
|
|
28
|
+
threshold: 95,
|
|
29
|
+
operator: 'gte',
|
|
30
|
+
weight: 0.25,
|
|
31
|
+
required: true
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
name: 'Code Quality',
|
|
35
|
+
metric: 'codeQuality',
|
|
36
|
+
threshold: 7.0,
|
|
37
|
+
operator: 'gte',
|
|
38
|
+
weight: 0.2,
|
|
39
|
+
required: false
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
name: 'Security Score',
|
|
43
|
+
metric: 'securityScore',
|
|
44
|
+
threshold: 8.0,
|
|
45
|
+
operator: 'gte',
|
|
46
|
+
weight: 0.15,
|
|
47
|
+
required: true
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
name: 'Performance Score',
|
|
51
|
+
metric: 'performanceScore',
|
|
52
|
+
threshold: 7.5,
|
|
53
|
+
operator: 'gte',
|
|
54
|
+
weight: 0.1,
|
|
55
|
+
required: false
|
|
56
|
+
}
|
|
57
|
+
];
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Evaluate quality metrics against gate rules
|
|
61
|
+
*/
|
|
62
|
+
async evaluate(metrics) {
|
|
63
|
+
const violations = [];
|
|
64
|
+
let totalScore = 0;
|
|
65
|
+
let totalWeight = 0;
|
|
66
|
+
for (const rule of this.rules) {
|
|
67
|
+
const actual = metrics[rule.metric];
|
|
68
|
+
const violation = this.checkRule(rule, actual);
|
|
69
|
+
if (violation) {
|
|
70
|
+
violations.push(violation);
|
|
71
|
+
}
|
|
72
|
+
// Calculate weighted score
|
|
73
|
+
const ruleScore = this.calculateRuleScore(rule, actual);
|
|
74
|
+
totalScore += ruleScore * rule.weight;
|
|
75
|
+
totalWeight += rule.weight;
|
|
76
|
+
}
|
|
77
|
+
const overallScore = totalWeight > 0 ? totalScore / totalWeight : 0;
|
|
78
|
+
const passed = this.determineGateStatus(violations, overallScore);
|
|
79
|
+
return {
|
|
80
|
+
passed,
|
|
81
|
+
score: overallScore,
|
|
82
|
+
violations,
|
|
83
|
+
metrics,
|
|
84
|
+
timestamp: new Date()
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Check a single rule against a metric value
|
|
89
|
+
*/
|
|
90
|
+
checkRule(rule, actual) {
|
|
91
|
+
const { name, threshold, operator, required } = rule;
|
|
92
|
+
let violated = false;
|
|
93
|
+
switch (operator) {
|
|
94
|
+
case 'gte':
|
|
95
|
+
violated = actual < threshold;
|
|
96
|
+
break;
|
|
97
|
+
case 'lte':
|
|
98
|
+
violated = actual > threshold;
|
|
99
|
+
break;
|
|
100
|
+
case 'eq':
|
|
101
|
+
violated = actual !== threshold;
|
|
102
|
+
break;
|
|
103
|
+
}
|
|
104
|
+
if (!violated) {
|
|
105
|
+
return null;
|
|
106
|
+
}
|
|
107
|
+
const severity = required ? 'error' : 'warning';
|
|
108
|
+
const operatorText = {
|
|
109
|
+
'gte': 'at least',
|
|
110
|
+
'lte': 'at most',
|
|
111
|
+
'eq': 'exactly'
|
|
112
|
+
}[operator];
|
|
113
|
+
return {
|
|
114
|
+
rule: name,
|
|
115
|
+
metric: rule.metric,
|
|
116
|
+
actual,
|
|
117
|
+
expected: threshold,
|
|
118
|
+
severity,
|
|
119
|
+
message: `${name}: Expected ${operatorText} ${threshold}, got ${actual}`
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Calculate score for a single rule (0-10)
|
|
124
|
+
*/
|
|
125
|
+
calculateRuleScore(rule, actual) {
|
|
126
|
+
const { threshold, operator } = rule;
|
|
127
|
+
switch (operator) {
|
|
128
|
+
case 'gte':
|
|
129
|
+
if (actual >= threshold)
|
|
130
|
+
return 10;
|
|
131
|
+
return Math.max(0, (actual / threshold) * 10);
|
|
132
|
+
case 'lte':
|
|
133
|
+
if (actual <= threshold)
|
|
134
|
+
return 10;
|
|
135
|
+
return Math.max(0, 10 - ((actual - threshold) / threshold) * 10);
|
|
136
|
+
case 'eq':
|
|
137
|
+
return actual === threshold ? 10 : 0;
|
|
138
|
+
default:
|
|
139
|
+
return 0;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Determine if the quality gate passes
|
|
144
|
+
*/
|
|
145
|
+
determineGateStatus(violations, score) {
|
|
146
|
+
// In strict mode, any error violation fails the gate
|
|
147
|
+
if (this.strictMode) {
|
|
148
|
+
return !violations.some(v => v.severity === 'error');
|
|
149
|
+
}
|
|
150
|
+
// Otherwise, use a combination of violations and score
|
|
151
|
+
const errorViolations = violations.filter(v => v.severity === 'error').length;
|
|
152
|
+
const warningViolations = violations.filter(v => v.severity === 'warning').length;
|
|
153
|
+
// Fail if too many errors or score is too low
|
|
154
|
+
if (errorViolations > 0)
|
|
155
|
+
return false;
|
|
156
|
+
if (score < 6.0)
|
|
157
|
+
return false;
|
|
158
|
+
if (warningViolations > 3)
|
|
159
|
+
return false;
|
|
160
|
+
return true;
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Add or update a quality rule
|
|
164
|
+
*/
|
|
165
|
+
addRule(rule) {
|
|
166
|
+
const existingIndex = this.rules.findIndex(r => r.name === rule.name);
|
|
167
|
+
if (existingIndex >= 0) {
|
|
168
|
+
this.rules[existingIndex] = rule;
|
|
169
|
+
}
|
|
170
|
+
else {
|
|
171
|
+
this.rules.push(rule);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Remove a quality rule
|
|
176
|
+
*/
|
|
177
|
+
removeRule(ruleName) {
|
|
178
|
+
const index = this.rules.findIndex(r => r.name === ruleName);
|
|
179
|
+
if (index >= 0) {
|
|
180
|
+
this.rules.splice(index, 1);
|
|
181
|
+
return true;
|
|
182
|
+
}
|
|
183
|
+
return false;
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* Get current rules
|
|
187
|
+
*/
|
|
188
|
+
getRules() {
|
|
189
|
+
return [...this.rules];
|
|
190
|
+
}
|
|
191
|
+
/**
|
|
192
|
+
* Generate a detailed report
|
|
193
|
+
*/
|
|
194
|
+
generateReport(result) {
|
|
195
|
+
const { passed, score, violations, metrics } = result;
|
|
196
|
+
const status = passed ? '✅ PASSED' : '❌ FAILED';
|
|
197
|
+
let report = `
|
|
198
|
+
Quality Gate Report ${status}
|
|
199
|
+
=============================
|
|
200
|
+
Overall Score: ${score.toFixed(2)}/10
|
|
201
|
+
Status: ${passed ? 'PASSED' : 'FAILED'}
|
|
202
|
+
|
|
203
|
+
Metrics:
|
|
204
|
+
--------
|
|
205
|
+
Test Coverage: ${metrics.testCoverage.toFixed(1)}%
|
|
206
|
+
Test Pass Rate: ${metrics.testPassRate.toFixed(1)}%
|
|
207
|
+
Code Quality: ${metrics.codeQuality.toFixed(1)}/10
|
|
208
|
+
Security Score: ${metrics.securityScore.toFixed(1)}/10
|
|
209
|
+
Performance Score: ${metrics.performanceScore.toFixed(1)}/10
|
|
210
|
+
Maintainability: ${metrics.maintainabilityIndex.toFixed(1)}/10
|
|
211
|
+
`;
|
|
212
|
+
if (violations.length > 0) {
|
|
213
|
+
report += `\nViolations:\n-----------\n`;
|
|
214
|
+
violations.forEach(violation => {
|
|
215
|
+
const icon = violation.severity === 'error' ? '❌' : '⚠️';
|
|
216
|
+
report += `${icon} ${violation.message}\n`;
|
|
217
|
+
});
|
|
218
|
+
}
|
|
219
|
+
report += `\nGenerated: ${result.timestamp.toISOString()}`;
|
|
220
|
+
return report;
|
|
221
|
+
}
|
|
222
|
+
/**
|
|
223
|
+
* Get recommendations based on violations
|
|
224
|
+
*/
|
|
225
|
+
getRecommendations(result) {
|
|
226
|
+
const recommendations = [];
|
|
227
|
+
result.violations.forEach(violation => {
|
|
228
|
+
switch (violation.metric) {
|
|
229
|
+
case 'testCoverage':
|
|
230
|
+
recommendations.push('Increase test coverage by adding unit tests for uncovered code paths');
|
|
231
|
+
break;
|
|
232
|
+
case 'testPassRate':
|
|
233
|
+
recommendations.push('Fix failing tests and improve test reliability');
|
|
234
|
+
break;
|
|
235
|
+
case 'codeQuality':
|
|
236
|
+
recommendations.push('Refactor code to reduce complexity and improve readability');
|
|
237
|
+
break;
|
|
238
|
+
case 'securityScore':
|
|
239
|
+
recommendations.push('Address security vulnerabilities and improve secure coding practices');
|
|
240
|
+
break;
|
|
241
|
+
case 'performanceScore':
|
|
242
|
+
recommendations.push('Optimize performance bottlenecks and improve response times');
|
|
243
|
+
break;
|
|
244
|
+
case 'maintainabilityIndex':
|
|
245
|
+
recommendations.push('Improve code maintainability through better structure and documentation');
|
|
246
|
+
break;
|
|
247
|
+
}
|
|
248
|
+
});
|
|
249
|
+
return [...new Set(recommendations)];
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
exports.QualityGate = QualityGate;
|
|
253
|
+
exports.default = QualityGate;
|
|
254
|
+
//# sourceMappingURL=quality-gate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"quality-gate.js","sourceRoot":"","sources":["../../src/core/quality-gate.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CoverageCollector - Stub Implementation
|
|
3
|
+
* @module coverage/coverage-collector
|
|
4
|
+
* @description Collects code coverage data during test execution
|
|
5
|
+
*
|
|
6
|
+
* NOTE: This is a Phase 1 stub implementation for test compatibility.
|
|
7
|
+
* Full implementation will integrate with Agent architecture in Phase 2.
|
|
8
|
+
*/
|
|
9
|
+
export interface CoverageData {
|
|
10
|
+
lines: {
|
|
11
|
+
total: number;
|
|
12
|
+
covered: number;
|
|
13
|
+
percentage: number;
|
|
14
|
+
};
|
|
15
|
+
branches: {
|
|
16
|
+
total: number;
|
|
17
|
+
covered: number;
|
|
18
|
+
percentage: number;
|
|
19
|
+
};
|
|
20
|
+
functions: {
|
|
21
|
+
total: number;
|
|
22
|
+
covered: number;
|
|
23
|
+
percentage: number;
|
|
24
|
+
};
|
|
25
|
+
statements: {
|
|
26
|
+
total: number;
|
|
27
|
+
covered: number;
|
|
28
|
+
percentage: number;
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
export interface FileCoverage {
|
|
32
|
+
path: string;
|
|
33
|
+
coverage: CoverageData;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Stub implementation of CoverageCollector
|
|
37
|
+
*/
|
|
38
|
+
export declare class CoverageCollector {
|
|
39
|
+
private coverage;
|
|
40
|
+
constructor();
|
|
41
|
+
/**
|
|
42
|
+
* Starts coverage collection
|
|
43
|
+
*/
|
|
44
|
+
start(): Promise<void>;
|
|
45
|
+
/**
|
|
46
|
+
* Stops coverage collection
|
|
47
|
+
*/
|
|
48
|
+
stop(): Promise<void>;
|
|
49
|
+
/**
|
|
50
|
+
* Collects coverage for a file
|
|
51
|
+
*/
|
|
52
|
+
collect(filePath: string): Promise<FileCoverage>;
|
|
53
|
+
/**
|
|
54
|
+
* Gets all collected coverage data
|
|
55
|
+
*/
|
|
56
|
+
getData(): FileCoverage[];
|
|
57
|
+
/**
|
|
58
|
+
* Resets coverage data
|
|
59
|
+
*/
|
|
60
|
+
reset(): void;
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=coverage-collector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"coverage-collector.d.ts","sourceRoot":"","sources":["../../src/coverage/coverage-collector.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,CAAC;IAC9D,QAAQ,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,CAAC;IACjE,SAAS,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,CAAC;IAClE,UAAU,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,CAAC;CACpE;AAED,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,YAAY,CAAC;CACxB;AAED;;GAEG;AACH,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,QAAQ,CAA4B;;IAM5C;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5B;;OAEG;IACG,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAI3B;;OAEG;IACG,OAAO,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IActD;;OAEG;IACH,OAAO,IAAI,YAAY,EAAE;IAIzB;;OAEG;IACH,KAAK,IAAI,IAAI;CAGd"}
|