@skillsmith/core 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/.tsbuildinfo +1 -0
- package/dist/src/__tests__/errors.test.d.ts +5 -0
- package/dist/src/__tests__/errors.test.d.ts.map +1 -0
- package/dist/src/__tests__/errors.test.js +115 -0
- package/dist/src/__tests__/errors.test.js.map +1 -0
- package/dist/src/activation/ActivationManager.d.ts +141 -0
- package/dist/src/activation/ActivationManager.d.ts.map +1 -0
- package/dist/src/activation/ActivationManager.js +282 -0
- package/dist/src/activation/ActivationManager.js.map +1 -0
- package/dist/src/activation/ZeroConfigActivator.d.ts +126 -0
- package/dist/src/activation/ZeroConfigActivator.d.ts.map +1 -0
- package/dist/src/activation/ZeroConfigActivator.js +259 -0
- package/dist/src/activation/ZeroConfigActivator.js.map +1 -0
- package/dist/src/activation/index.d.ts +8 -0
- package/dist/src/activation/index.d.ts.map +1 -0
- package/dist/src/activation/index.js +8 -0
- package/dist/src/activation/index.js.map +1 -0
- package/dist/src/analysis/CodebaseAnalyzer.d.ts +175 -0
- package/dist/src/analysis/CodebaseAnalyzer.d.ts.map +1 -0
- package/dist/src/analysis/CodebaseAnalyzer.js +495 -0
- package/dist/src/analysis/CodebaseAnalyzer.js.map +1 -0
- package/dist/src/analysis/index.d.ts +10 -0
- package/dist/src/analysis/index.d.ts.map +1 -0
- package/dist/src/analysis/index.js +10 -0
- package/dist/src/analysis/index.js.map +1 -0
- package/dist/src/analytics/AnalyticsRepository.d.ts +97 -0
- package/dist/src/analytics/AnalyticsRepository.d.ts.map +1 -0
- package/dist/src/analytics/AnalyticsRepository.js +376 -0
- package/dist/src/analytics/AnalyticsRepository.js.map +1 -0
- package/dist/src/analytics/ExperimentService.d.ts +70 -0
- package/dist/src/analytics/ExperimentService.d.ts.map +1 -0
- package/dist/src/analytics/ExperimentService.js +251 -0
- package/dist/src/analytics/ExperimentService.js.map +1 -0
- package/dist/src/analytics/ROIDashboardService.d.ts +55 -0
- package/dist/src/analytics/ROIDashboardService.d.ts.map +1 -0
- package/dist/src/analytics/ROIDashboardService.js +304 -0
- package/dist/src/analytics/ROIDashboardService.js.map +1 -0
- package/dist/src/analytics/UsageAnalyticsService.d.ts +55 -0
- package/dist/src/analytics/UsageAnalyticsService.d.ts.map +1 -0
- package/dist/src/analytics/UsageAnalyticsService.js +180 -0
- package/dist/src/analytics/UsageAnalyticsService.js.map +1 -0
- package/dist/src/analytics/anonymizer.d.ts +53 -0
- package/dist/src/analytics/anonymizer.d.ts.map +1 -0
- package/dist/src/analytics/anonymizer.js +107 -0
- package/dist/src/analytics/anonymizer.js.map +1 -0
- package/dist/src/analytics/constants.d.ts +19 -0
- package/dist/src/analytics/constants.d.ts.map +1 -0
- package/dist/src/analytics/constants.js +19 -0
- package/dist/src/analytics/constants.js.map +1 -0
- package/dist/src/analytics/index.d.ts +23 -0
- package/dist/src/analytics/index.d.ts.map +1 -0
- package/dist/src/analytics/index.js +23 -0
- package/dist/src/analytics/index.js.map +1 -0
- package/dist/src/analytics/metrics-aggregator.d.ts +98 -0
- package/dist/src/analytics/metrics-aggregator.d.ts.map +1 -0
- package/dist/src/analytics/metrics-aggregator.js +176 -0
- package/dist/src/analytics/metrics-aggregator.js.map +1 -0
- package/dist/src/analytics/metrics-exporter.d.ts +148 -0
- package/dist/src/analytics/metrics-exporter.d.ts.map +1 -0
- package/dist/src/analytics/metrics-exporter.js +244 -0
- package/dist/src/analytics/metrics-exporter.js.map +1 -0
- package/dist/src/analytics/schema.d.ts +20 -0
- package/dist/src/analytics/schema.d.ts.map +1 -0
- package/dist/src/analytics/schema.js +125 -0
- package/dist/src/analytics/schema.js.map +1 -0
- package/dist/src/analytics/storage.d.ts +76 -0
- package/dist/src/analytics/storage.d.ts.map +1 -0
- package/dist/src/analytics/storage.js +180 -0
- package/dist/src/analytics/storage.js.map +1 -0
- package/dist/src/analytics/types.d.ts +277 -0
- package/dist/src/analytics/types.d.ts.map +1 -0
- package/dist/src/analytics/types.js +10 -0
- package/dist/src/analytics/types.js.map +1 -0
- package/dist/src/analytics/usage-tracker.d.ts +132 -0
- package/dist/src/analytics/usage-tracker.d.ts.map +1 -0
- package/dist/src/analytics/usage-tracker.js +213 -0
- package/dist/src/analytics/usage-tracker.js.map +1 -0
- package/dist/src/benchmarks/BenchmarkRunner.d.ts +258 -0
- package/dist/src/benchmarks/BenchmarkRunner.d.ts.map +1 -0
- package/dist/src/benchmarks/BenchmarkRunner.js +453 -0
- package/dist/src/benchmarks/BenchmarkRunner.js.map +1 -0
- package/dist/src/benchmarks/IndexBenchmark.d.ts +101 -0
- package/dist/src/benchmarks/IndexBenchmark.d.ts.map +1 -0
- package/dist/src/benchmarks/IndexBenchmark.js +314 -0
- package/dist/src/benchmarks/IndexBenchmark.js.map +1 -0
- package/dist/src/benchmarks/MemoryProfiler.d.ts +266 -0
- package/dist/src/benchmarks/MemoryProfiler.d.ts.map +1 -0
- package/dist/src/benchmarks/MemoryProfiler.js +404 -0
- package/dist/src/benchmarks/MemoryProfiler.js.map +1 -0
- package/dist/src/benchmarks/SearchBenchmark.d.ts +71 -0
- package/dist/src/benchmarks/SearchBenchmark.d.ts.map +1 -0
- package/dist/src/benchmarks/SearchBenchmark.js +321 -0
- package/dist/src/benchmarks/SearchBenchmark.js.map +1 -0
- package/dist/src/benchmarks/cacheBenchmark.d.ts +75 -0
- package/dist/src/benchmarks/cacheBenchmark.d.ts.map +1 -0
- package/dist/src/benchmarks/cacheBenchmark.js +325 -0
- package/dist/src/benchmarks/cacheBenchmark.js.map +1 -0
- package/dist/src/benchmarks/cli.d.ts +17 -0
- package/dist/src/benchmarks/cli.d.ts.map +1 -0
- package/dist/src/benchmarks/cli.js +140 -0
- package/dist/src/benchmarks/cli.js.map +1 -0
- package/dist/src/benchmarks/embeddingBenchmark.d.ts +86 -0
- package/dist/src/benchmarks/embeddingBenchmark.d.ts.map +1 -0
- package/dist/src/benchmarks/embeddingBenchmark.js +329 -0
- package/dist/src/benchmarks/embeddingBenchmark.js.map +1 -0
- package/dist/src/benchmarks/index.d.ts +51 -0
- package/dist/src/benchmarks/index.d.ts.map +1 -0
- package/dist/src/benchmarks/index.js +201 -0
- package/dist/src/benchmarks/index.js.map +1 -0
- package/dist/src/benchmarks/stats.d.ts +56 -0
- package/dist/src/benchmarks/stats.d.ts.map +1 -0
- package/dist/src/benchmarks/stats.js +86 -0
- package/dist/src/benchmarks/stats.js.map +1 -0
- package/dist/src/cache/CacheEntry.d.ts +101 -0
- package/dist/src/cache/CacheEntry.d.ts.map +1 -0
- package/dist/src/cache/CacheEntry.js +238 -0
- package/dist/src/cache/CacheEntry.js.map +1 -0
- package/dist/src/cache/CacheManager.d.ts +167 -0
- package/dist/src/cache/CacheManager.d.ts.map +1 -0
- package/dist/src/cache/CacheManager.js +346 -0
- package/dist/src/cache/CacheManager.js.map +1 -0
- package/dist/src/cache/TieredCache.d.ts +97 -0
- package/dist/src/cache/TieredCache.d.ts.map +1 -0
- package/dist/src/cache/TieredCache.js +352 -0
- package/dist/src/cache/TieredCache.js.map +1 -0
- package/dist/src/cache/index.d.ts +63 -0
- package/dist/src/cache/index.d.ts.map +1 -0
- package/dist/src/cache/index.js +91 -0
- package/dist/src/cache/index.js.map +1 -0
- package/dist/src/cache/lru.d.ts +68 -0
- package/dist/src/cache/lru.d.ts.map +1 -0
- package/dist/src/cache/lru.js +105 -0
- package/dist/src/cache/lru.js.map +1 -0
- package/dist/src/cache/sqlite.d.ts +59 -0
- package/dist/src/cache/sqlite.d.ts.map +1 -0
- package/dist/src/cache/sqlite.js +159 -0
- package/dist/src/cache/sqlite.js.map +1 -0
- package/dist/src/db/quarantine-schema.d.ts +81 -0
- package/dist/src/db/quarantine-schema.d.ts.map +1 -0
- package/dist/src/db/quarantine-schema.js +110 -0
- package/dist/src/db/quarantine-schema.js.map +1 -0
- package/dist/src/db/schema.d.ts +65 -0
- package/dist/src/db/schema.d.ts.map +1 -0
- package/dist/src/db/schema.js +318 -0
- package/dist/src/db/schema.js.map +1 -0
- package/dist/src/embeddings/index.d.ts +158 -0
- package/dist/src/embeddings/index.d.ts.map +1 -0
- package/dist/src/embeddings/index.js +397 -0
- package/dist/src/embeddings/index.js.map +1 -0
- package/dist/src/errors/SkillsmithError.d.ts +118 -0
- package/dist/src/errors/SkillsmithError.d.ts.map +1 -0
- package/dist/src/errors/SkillsmithError.js +194 -0
- package/dist/src/errors/SkillsmithError.js.map +1 -0
- package/dist/src/errors/index.d.ts +36 -0
- package/dist/src/errors/index.d.ts.map +1 -0
- package/dist/src/errors/index.js +36 -0
- package/dist/src/errors/index.js.map +1 -0
- package/dist/src/errors.d.ts +72 -0
- package/dist/src/errors.d.ts.map +1 -0
- package/dist/src/errors.js +123 -0
- package/dist/src/errors.js.map +1 -0
- package/dist/src/index.d.ts +56 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +73 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/index.test.d.ts +2 -0
- package/dist/src/index.test.d.ts.map +1 -0
- package/dist/src/index.test.js +35 -0
- package/dist/src/index.test.js.map +1 -0
- package/dist/src/indexer/GitHubIndexer.d.ts +107 -0
- package/dist/src/indexer/GitHubIndexer.d.ts.map +1 -0
- package/dist/src/indexer/GitHubIndexer.js +202 -0
- package/dist/src/indexer/GitHubIndexer.js.map +1 -0
- package/dist/src/indexer/PartitionStrategy.d.ts +115 -0
- package/dist/src/indexer/PartitionStrategy.d.ts.map +1 -0
- package/dist/src/indexer/PartitionStrategy.js +207 -0
- package/dist/src/indexer/PartitionStrategy.js.map +1 -0
- package/dist/src/indexer/SkillParser.d.ts +112 -0
- package/dist/src/indexer/SkillParser.d.ts.map +1 -0
- package/dist/src/indexer/SkillParser.js +281 -0
- package/dist/src/indexer/SkillParser.js.map +1 -0
- package/dist/src/indexer/SwarmIndexer.d.ts +163 -0
- package/dist/src/indexer/SwarmIndexer.d.ts.map +1 -0
- package/dist/src/indexer/SwarmIndexer.js +300 -0
- package/dist/src/indexer/SwarmIndexer.js.map +1 -0
- package/dist/src/indexer/index.d.ts +12 -0
- package/dist/src/indexer/index.d.ts.map +1 -0
- package/dist/src/indexer/index.js +16 -0
- package/dist/src/indexer/index.js.map +1 -0
- package/dist/src/learning/interfaces.d.ts +338 -0
- package/dist/src/learning/interfaces.d.ts.map +1 -0
- package/dist/src/learning/interfaces.js +13 -0
- package/dist/src/learning/interfaces.js.map +1 -0
- package/dist/src/learning/types.d.ts +284 -0
- package/dist/src/learning/types.d.ts.map +1 -0
- package/dist/src/learning/types.js +112 -0
- package/dist/src/learning/types.js.map +1 -0
- package/dist/src/matching/OverlapDetector.d.ts +152 -0
- package/dist/src/matching/OverlapDetector.d.ts.map +1 -0
- package/dist/src/matching/OverlapDetector.js +218 -0
- package/dist/src/matching/OverlapDetector.js.map +1 -0
- package/dist/src/matching/SkillMatcher.d.ts +125 -0
- package/dist/src/matching/SkillMatcher.d.ts.map +1 -0
- package/dist/src/matching/SkillMatcher.js +206 -0
- package/dist/src/matching/SkillMatcher.js.map +1 -0
- package/dist/src/matching/index.d.ts +14 -0
- package/dist/src/matching/index.d.ts.map +1 -0
- package/dist/src/matching/index.js +12 -0
- package/dist/src/matching/index.js.map +1 -0
- package/dist/src/pipeline/DailyIndexPipeline.d.ts +220 -0
- package/dist/src/pipeline/DailyIndexPipeline.d.ts.map +1 -0
- package/dist/src/pipeline/DailyIndexPipeline.js +320 -0
- package/dist/src/pipeline/DailyIndexPipeline.js.map +1 -0
- package/dist/src/pipeline/index.d.ts +9 -0
- package/dist/src/pipeline/index.d.ts.map +1 -0
- package/dist/src/pipeline/index.js +9 -0
- package/dist/src/pipeline/index.js.map +1 -0
- package/dist/src/repositories/CacheRepository.d.ts +60 -0
- package/dist/src/repositories/CacheRepository.d.ts.map +1 -0
- package/dist/src/repositories/CacheRepository.js +148 -0
- package/dist/src/repositories/CacheRepository.js.map +1 -0
- package/dist/src/repositories/IndexerRepository.d.ts +126 -0
- package/dist/src/repositories/IndexerRepository.d.ts.map +1 -0
- package/dist/src/repositories/IndexerRepository.js +270 -0
- package/dist/src/repositories/IndexerRepository.js.map +1 -0
- package/dist/src/repositories/QuarantineRepository.d.ts +255 -0
- package/dist/src/repositories/QuarantineRepository.d.ts.map +1 -0
- package/dist/src/repositories/QuarantineRepository.js +445 -0
- package/dist/src/repositories/QuarantineRepository.js.map +1 -0
- package/dist/src/repositories/SkillRepository.d.ts +78 -0
- package/dist/src/repositories/SkillRepository.d.ts.map +1 -0
- package/dist/src/repositories/SkillRepository.js +208 -0
- package/dist/src/repositories/SkillRepository.js.map +1 -0
- package/dist/src/scoring/QualityScorer.d.ts +188 -0
- package/dist/src/scoring/QualityScorer.d.ts.map +1 -0
- package/dist/src/scoring/QualityScorer.js +342 -0
- package/dist/src/scoring/QualityScorer.js.map +1 -0
- package/dist/src/scoring/index.d.ts +9 -0
- package/dist/src/scoring/index.d.ts.map +1 -0
- package/dist/src/scoring/index.js +9 -0
- package/dist/src/scoring/index.js.map +1 -0
- package/dist/src/scripts/__tests__/scan-imported-skills.test.d.ts +5 -0
- package/dist/src/scripts/__tests__/scan-imported-skills.test.d.ts.map +1 -0
- package/dist/src/scripts/__tests__/scan-imported-skills.test.js +365 -0
- package/dist/src/scripts/__tests__/scan-imported-skills.test.js.map +1 -0
- package/dist/src/scripts/import-github-skills.d.ts +24 -0
- package/dist/src/scripts/import-github-skills.d.ts.map +1 -0
- package/dist/src/scripts/import-github-skills.js +545 -0
- package/dist/src/scripts/import-github-skills.js.map +1 -0
- package/dist/src/scripts/import-to-database.d.ts +60 -0
- package/dist/src/scripts/import-to-database.d.ts.map +1 -0
- package/dist/src/scripts/import-to-database.js +307 -0
- package/dist/src/scripts/import-to-database.js.map +1 -0
- package/dist/src/scripts/scan-imported-skills.d.ts +15 -0
- package/dist/src/scripts/scan-imported-skills.d.ts.map +1 -0
- package/dist/src/scripts/scan-imported-skills.js +405 -0
- package/dist/src/scripts/scan-imported-skills.js.map +1 -0
- package/dist/src/scripts/validate-skills.d.ts +180 -0
- package/dist/src/scripts/validate-skills.d.ts.map +1 -0
- package/dist/src/scripts/validate-skills.js +572 -0
- package/dist/src/scripts/validate-skills.js.map +1 -0
- package/dist/src/search/hybrid.d.ts +85 -0
- package/dist/src/search/hybrid.d.ts.map +1 -0
- package/dist/src/search/hybrid.js +291 -0
- package/dist/src/search/hybrid.js.map +1 -0
- package/dist/src/search/index.d.ts +6 -0
- package/dist/src/search/index.d.ts.map +1 -0
- package/dist/src/search/index.js +5 -0
- package/dist/src/search/index.js.map +1 -0
- package/dist/src/security/AuditLogger.d.ts +197 -0
- package/dist/src/security/AuditLogger.d.ts.map +1 -0
- package/dist/src/security/AuditLogger.js +398 -0
- package/dist/src/security/AuditLogger.js.map +1 -0
- package/dist/src/security/RateLimiter.d.ts +337 -0
- package/dist/src/security/RateLimiter.d.ts.map +1 -0
- package/dist/src/security/RateLimiter.js +782 -0
- package/dist/src/security/RateLimiter.js.map +1 -0
- package/dist/src/security/__tests__/pathValidation.test.d.ts +8 -0
- package/dist/src/security/__tests__/pathValidation.test.d.ts.map +1 -0
- package/dist/src/security/__tests__/pathValidation.test.js +249 -0
- package/dist/src/security/__tests__/pathValidation.test.js.map +1 -0
- package/dist/src/security/index.d.ts +18 -0
- package/dist/src/security/index.d.ts.map +1 -0
- package/dist/src/security/index.js +14 -0
- package/dist/src/security/index.js.map +1 -0
- package/dist/src/security/pathValidation.d.ts +95 -0
- package/dist/src/security/pathValidation.d.ts.map +1 -0
- package/dist/src/security/pathValidation.js +216 -0
- package/dist/src/security/pathValidation.js.map +1 -0
- package/dist/src/security/sanitization.d.ts +123 -0
- package/dist/src/security/sanitization.d.ts.map +1 -0
- package/dist/src/security/sanitization.js +378 -0
- package/dist/src/security/sanitization.js.map +1 -0
- package/dist/src/security/scanner.d.ts +151 -0
- package/dist/src/security/scanner.d.ts.map +1 -0
- package/dist/src/security/scanner.js +599 -0
- package/dist/src/security/scanner.js.map +1 -0
- package/dist/src/services/SearchService.d.ts +88 -0
- package/dist/src/services/SearchService.d.ts.map +1 -0
- package/dist/src/services/SearchService.js +305 -0
- package/dist/src/services/SearchService.js.map +1 -0
- package/dist/src/session/SessionContext.d.ts +116 -0
- package/dist/src/session/SessionContext.d.ts.map +1 -0
- package/dist/src/session/SessionContext.js +134 -0
- package/dist/src/session/SessionContext.js.map +1 -0
- package/dist/src/session/SessionHealthMonitor.d.ts +249 -0
- package/dist/src/session/SessionHealthMonitor.d.ts.map +1 -0
- package/dist/src/session/SessionHealthMonitor.js +302 -0
- package/dist/src/session/SessionHealthMonitor.js.map +1 -0
- package/dist/src/session/SessionManager.d.ts +179 -0
- package/dist/src/session/SessionManager.d.ts.map +1 -0
- package/dist/src/session/SessionManager.js +451 -0
- package/dist/src/session/SessionManager.js.map +1 -0
- package/dist/src/session/SessionRecovery.d.ts +84 -0
- package/dist/src/session/SessionRecovery.d.ts.map +1 -0
- package/dist/src/session/SessionRecovery.js +257 -0
- package/dist/src/session/SessionRecovery.js.map +1 -0
- package/dist/src/session/index.d.ts +40 -0
- package/dist/src/session/index.d.ts.map +1 -0
- package/dist/src/session/index.js +44 -0
- package/dist/src/session/index.js.map +1 -0
- package/dist/src/sources/BaseSourceAdapter.d.ts +144 -0
- package/dist/src/sources/BaseSourceAdapter.d.ts.map +1 -0
- package/dist/src/sources/BaseSourceAdapter.js +287 -0
- package/dist/src/sources/BaseSourceAdapter.js.map +1 -0
- package/dist/src/sources/GitHubSourceAdapter.d.ts +98 -0
- package/dist/src/sources/GitHubSourceAdapter.d.ts.map +1 -0
- package/dist/src/sources/GitHubSourceAdapter.js +269 -0
- package/dist/src/sources/GitHubSourceAdapter.js.map +1 -0
- package/dist/src/sources/GitLabSourceAdapter.d.ts +102 -0
- package/dist/src/sources/GitLabSourceAdapter.d.ts.map +1 -0
- package/dist/src/sources/GitLabSourceAdapter.js +310 -0
- package/dist/src/sources/GitLabSourceAdapter.js.map +1 -0
- package/dist/src/sources/ISourceAdapter.d.ts +110 -0
- package/dist/src/sources/ISourceAdapter.d.ts.map +1 -0
- package/dist/src/sources/ISourceAdapter.js +19 -0
- package/dist/src/sources/ISourceAdapter.js.map +1 -0
- package/dist/src/sources/LocalFilesystemAdapter.d.ts +112 -0
- package/dist/src/sources/LocalFilesystemAdapter.d.ts.map +1 -0
- package/dist/src/sources/LocalFilesystemAdapter.js +340 -0
- package/dist/src/sources/LocalFilesystemAdapter.js.map +1 -0
- package/dist/src/sources/RawUrlSourceAdapter.d.ts +128 -0
- package/dist/src/sources/RawUrlSourceAdapter.d.ts.map +1 -0
- package/dist/src/sources/RawUrlSourceAdapter.js +282 -0
- package/dist/src/sources/RawUrlSourceAdapter.js.map +1 -0
- package/dist/src/sources/SourceAdapterRegistry.d.ts +156 -0
- package/dist/src/sources/SourceAdapterRegistry.d.ts.map +1 -0
- package/dist/src/sources/SourceAdapterRegistry.js +242 -0
- package/dist/src/sources/SourceAdapterRegistry.js.map +1 -0
- package/dist/src/sources/SourceIndexer.d.ts +119 -0
- package/dist/src/sources/SourceIndexer.d.ts.map +1 -0
- package/dist/src/sources/SourceIndexer.js +285 -0
- package/dist/src/sources/SourceIndexer.js.map +1 -0
- package/dist/src/sources/index.d.ts +45 -0
- package/dist/src/sources/index.d.ts.map +1 -0
- package/dist/src/sources/index.js +51 -0
- package/dist/src/sources/index.js.map +1 -0
- package/dist/src/sources/shared.d.ts +125 -0
- package/dist/src/sources/shared.d.ts.map +1 -0
- package/dist/src/sources/shared.js +191 -0
- package/dist/src/sources/shared.js.map +1 -0
- package/dist/src/sources/types.d.ts +204 -0
- package/dist/src/sources/types.d.ts.map +1 -0
- package/dist/src/sources/types.js +6 -0
- package/dist/src/sources/types.js.map +1 -0
- package/dist/src/telemetry/index.d.ts +25 -0
- package/dist/src/telemetry/index.d.ts.map +1 -0
- package/dist/src/telemetry/index.js +32 -0
- package/dist/src/telemetry/index.js.map +1 -0
- package/dist/src/telemetry/metrics.d.ts +171 -0
- package/dist/src/telemetry/metrics.d.ts.map +1 -0
- package/dist/src/telemetry/metrics.js +401 -0
- package/dist/src/telemetry/metrics.js.map +1 -0
- package/dist/src/telemetry/prometheus.d.ts +81 -0
- package/dist/src/telemetry/prometheus.d.ts.map +1 -0
- package/dist/src/telemetry/prometheus.js +252 -0
- package/dist/src/telemetry/prometheus.js.map +1 -0
- package/dist/src/telemetry/tracer.d.ts +151 -0
- package/dist/src/telemetry/tracer.d.ts.map +1 -0
- package/dist/src/telemetry/tracer.js +391 -0
- package/dist/src/telemetry/tracer.js.map +1 -0
- package/dist/src/triggers/ContextScorer.d.ts +118 -0
- package/dist/src/triggers/ContextScorer.d.ts.map +1 -0
- package/dist/src/triggers/ContextScorer.js +265 -0
- package/dist/src/triggers/ContextScorer.js.map +1 -0
- package/dist/src/triggers/TriggerDetector.d.ts +178 -0
- package/dist/src/triggers/TriggerDetector.d.ts.map +1 -0
- package/dist/src/triggers/TriggerDetector.js +390 -0
- package/dist/src/triggers/TriggerDetector.js.map +1 -0
- package/dist/src/triggers/__tests__/ContextScorer.test.d.ts +6 -0
- package/dist/src/triggers/__tests__/ContextScorer.test.d.ts.map +1 -0
- package/dist/src/triggers/__tests__/ContextScorer.test.js +307 -0
- package/dist/src/triggers/__tests__/ContextScorer.test.js.map +1 -0
- package/dist/src/triggers/__tests__/TriggerDetector.test.d.ts +6 -0
- package/dist/src/triggers/__tests__/TriggerDetector.test.d.ts.map +1 -0
- package/dist/src/triggers/__tests__/TriggerDetector.test.js +249 -0
- package/dist/src/triggers/__tests__/TriggerDetector.test.js.map +1 -0
- package/dist/src/triggers/index.d.ts +8 -0
- package/dist/src/triggers/index.d.ts.map +1 -0
- package/dist/src/triggers/index.js +8 -0
- package/dist/src/triggers/index.js.map +1 -0
- package/dist/src/types/skill.d.ts +80 -0
- package/dist/src/types/skill.d.ts.map +1 -0
- package/dist/src/types/skill.js +5 -0
- package/dist/src/types/skill.js.map +1 -0
- package/dist/src/types.d.ts +88 -0
- package/dist/src/types.d.ts.map +1 -0
- package/dist/src/types.js +13 -0
- package/dist/src/types.js.map +1 -0
- package/dist/src/utils/index.d.ts +6 -0
- package/dist/src/utils/index.d.ts.map +1 -0
- package/dist/src/utils/index.js +6 -0
- package/dist/src/utils/index.js.map +1 -0
- package/dist/src/utils/logger.d.ts +172 -0
- package/dist/src/utils/logger.d.ts.map +1 -0
- package/dist/src/utils/logger.js +291 -0
- package/dist/src/utils/logger.js.map +1 -0
- package/dist/src/utils/retry.d.ts +97 -0
- package/dist/src/utils/retry.d.ts.map +1 -0
- package/dist/src/utils/retry.js +267 -0
- package/dist/src/utils/retry.js.map +1 -0
- package/dist/src/validation/index.d.ts +118 -0
- package/dist/src/validation/index.d.ts.map +1 -0
- package/dist/src/validation/index.js +434 -0
- package/dist/src/validation/index.js.map +1 -0
- package/dist/src/webhooks/WebhookHandler.d.ts +117 -0
- package/dist/src/webhooks/WebhookHandler.d.ts.map +1 -0
- package/dist/src/webhooks/WebhookHandler.js +349 -0
- package/dist/src/webhooks/WebhookHandler.js.map +1 -0
- package/dist/src/webhooks/WebhookPayload.d.ts +238 -0
- package/dist/src/webhooks/WebhookPayload.d.ts.map +1 -0
- package/dist/src/webhooks/WebhookPayload.js +244 -0
- package/dist/src/webhooks/WebhookPayload.js.map +1 -0
- package/dist/src/webhooks/WebhookQueue.d.ts +227 -0
- package/dist/src/webhooks/WebhookQueue.d.ts.map +1 -0
- package/dist/src/webhooks/WebhookQueue.js +328 -0
- package/dist/src/webhooks/WebhookQueue.js.map +1 -0
- package/dist/src/webhooks/index.d.ts +12 -0
- package/dist/src/webhooks/index.d.ts.map +1 -0
- package/dist/src/webhooks/index.js +15 -0
- package/dist/src/webhooks/index.js.map +1 -0
- package/dist/tests/Analytics.integration.test.d.ts +7 -0
- package/dist/tests/Analytics.integration.test.d.ts.map +1 -0
- package/dist/tests/Analytics.integration.test.js +367 -0
- package/dist/tests/Analytics.integration.test.js.map +1 -0
- package/dist/tests/AnalyticsRepository.test.d.ts +8 -0
- package/dist/tests/AnalyticsRepository.test.d.ts.map +1 -0
- package/dist/tests/AnalyticsRepository.test.js +399 -0
- package/dist/tests/AnalyticsRepository.test.js.map +1 -0
- package/dist/tests/AnalyticsStorage.test.d.ts +8 -0
- package/dist/tests/AnalyticsStorage.test.d.ts.map +1 -0
- package/dist/tests/AnalyticsStorage.test.js +271 -0
- package/dist/tests/AnalyticsStorage.test.js.map +1 -0
- package/dist/tests/AuditLogger.test.d.ts +8 -0
- package/dist/tests/AuditLogger.test.d.ts.map +1 -0
- package/dist/tests/AuditLogger.test.js +699 -0
- package/dist/tests/AuditLogger.test.js.map +1 -0
- package/dist/tests/BenchmarkRunner.test.d.ts +11 -0
- package/dist/tests/BenchmarkRunner.test.d.ts.map +1 -0
- package/dist/tests/BenchmarkRunner.test.js +641 -0
- package/dist/tests/BenchmarkRunner.test.js.map +1 -0
- package/dist/tests/CacheRepository.test.d.ts +5 -0
- package/dist/tests/CacheRepository.test.d.ts.map +1 -0
- package/dist/tests/CacheRepository.test.js +184 -0
- package/dist/tests/CacheRepository.test.js.map +1 -0
- package/dist/tests/CacheSecurity.test.d.ts +8 -0
- package/dist/tests/CacheSecurity.test.d.ts.map +1 -0
- package/dist/tests/CacheSecurity.test.js +273 -0
- package/dist/tests/CacheSecurity.test.js.map +1 -0
- package/dist/tests/CodebaseAnalyzer.test.d.ts +2 -0
- package/dist/tests/CodebaseAnalyzer.test.d.ts.map +1 -0
- package/dist/tests/CodebaseAnalyzer.test.js +347 -0
- package/dist/tests/CodebaseAnalyzer.test.js.map +1 -0
- package/dist/tests/DailyIndexPipeline.test.d.ts +7 -0
- package/dist/tests/DailyIndexPipeline.test.d.ts.map +1 -0
- package/dist/tests/DailyIndexPipeline.test.js +539 -0
- package/dist/tests/DailyIndexPipeline.test.js.map +1 -0
- package/dist/tests/EmbeddingService.test.d.ts +2 -0
- package/dist/tests/EmbeddingService.test.d.ts.map +1 -0
- package/dist/tests/EmbeddingService.test.js +252 -0
- package/dist/tests/EmbeddingService.test.js.map +1 -0
- package/dist/tests/ExperimentService.test.d.ts +7 -0
- package/dist/tests/ExperimentService.test.d.ts.map +1 -0
- package/dist/tests/ExperimentService.test.js +293 -0
- package/dist/tests/ExperimentService.test.js.map +1 -0
- package/dist/tests/GitHubIndexer.test.d.ts +10 -0
- package/dist/tests/GitHubIndexer.test.d.ts.map +1 -0
- package/dist/tests/GitHubIndexer.test.js +524 -0
- package/dist/tests/GitHubIndexer.test.js.map +1 -0
- package/dist/tests/GitHubSourceAdapter.test.d.ts +5 -0
- package/dist/tests/GitHubSourceAdapter.test.d.ts.map +1 -0
- package/dist/tests/GitHubSourceAdapter.test.js +385 -0
- package/dist/tests/GitHubSourceAdapter.test.js.map +1 -0
- package/dist/tests/MemoryProfiler.test.d.ts +12 -0
- package/dist/tests/MemoryProfiler.test.d.ts.map +1 -0
- package/dist/tests/MemoryProfiler.test.js +402 -0
- package/dist/tests/MemoryProfiler.test.js.map +1 -0
- package/dist/tests/OverlapDetector.test.d.ts +2 -0
- package/dist/tests/OverlapDetector.test.d.ts.map +1 -0
- package/dist/tests/OverlapDetector.test.js +340 -0
- package/dist/tests/OverlapDetector.test.js.map +1 -0
- package/dist/tests/QualityScorer.test.d.ts +7 -0
- package/dist/tests/QualityScorer.test.d.ts.map +1 -0
- package/dist/tests/QualityScorer.test.js +340 -0
- package/dist/tests/QualityScorer.test.js.map +1 -0
- package/dist/tests/QuarantineRepository.test.d.ts +7 -0
- package/dist/tests/QuarantineRepository.test.d.ts.map +1 -0
- package/dist/tests/QuarantineRepository.test.js +582 -0
- package/dist/tests/QuarantineRepository.test.js.map +1 -0
- package/dist/tests/ROIDashboardService.test.d.ts +7 -0
- package/dist/tests/ROIDashboardService.test.d.ts.map +1 -0
- package/dist/tests/ROIDashboardService.test.js +324 -0
- package/dist/tests/ROIDashboardService.test.js.map +1 -0
- package/dist/tests/RateLimiter.test.d.ts +7 -0
- package/dist/tests/RateLimiter.test.d.ts.map +1 -0
- package/dist/tests/RateLimiter.test.js +1017 -0
- package/dist/tests/RateLimiter.test.js.map +1 -0
- package/dist/tests/RawUrlSourceAdapter.security.test.d.ts +7 -0
- package/dist/tests/RawUrlSourceAdapter.security.test.d.ts.map +1 -0
- package/dist/tests/RawUrlSourceAdapter.security.test.js +455 -0
- package/dist/tests/RawUrlSourceAdapter.security.test.js.map +1 -0
- package/dist/tests/ScraperAdapters.test.d.ts +7 -0
- package/dist/tests/ScraperAdapters.test.d.ts.map +1 -0
- package/dist/tests/ScraperAdapters.test.js +748 -0
- package/dist/tests/ScraperAdapters.test.js.map +1 -0
- package/dist/tests/SearchQuality.test.d.ts +8 -0
- package/dist/tests/SearchQuality.test.d.ts.map +1 -0
- package/dist/tests/SearchQuality.test.js +397 -0
- package/dist/tests/SearchQuality.test.js.map +1 -0
- package/dist/tests/SearchService.test.d.ts +5 -0
- package/dist/tests/SearchService.test.d.ts.map +1 -0
- package/dist/tests/SearchService.test.js +218 -0
- package/dist/tests/SearchService.test.js.map +1 -0
- package/dist/tests/SecurityScanner.test.d.ts +6 -0
- package/dist/tests/SecurityScanner.test.d.ts.map +1 -0
- package/dist/tests/SecurityScanner.test.js +449 -0
- package/dist/tests/SecurityScanner.test.js.map +1 -0
- package/dist/tests/SessionHealthMonitor.test.d.ts +5 -0
- package/dist/tests/SessionHealthMonitor.test.d.ts.map +1 -0
- package/dist/tests/SessionHealthMonitor.test.js +449 -0
- package/dist/tests/SessionHealthMonitor.test.js.map +1 -0
- package/dist/tests/SessionManager.security.test.d.ts +10 -0
- package/dist/tests/SessionManager.security.test.d.ts.map +1 -0
- package/dist/tests/SessionManager.security.test.js +395 -0
- package/dist/tests/SessionManager.security.test.js.map +1 -0
- package/dist/tests/SessionManager.test.d.ts +8 -0
- package/dist/tests/SessionManager.test.d.ts.map +1 -0
- package/dist/tests/SessionManager.test.js +446 -0
- package/dist/tests/SessionManager.test.js.map +1 -0
- package/dist/tests/SkillMatcher.test.d.ts +2 -0
- package/dist/tests/SkillMatcher.test.d.ts.map +1 -0
- package/dist/tests/SkillMatcher.test.js +253 -0
- package/dist/tests/SkillMatcher.test.js.map +1 -0
- package/dist/tests/SkillRepository.test.d.ts +5 -0
- package/dist/tests/SkillRepository.test.d.ts.map +1 -0
- package/dist/tests/SkillRepository.test.js +237 -0
- package/dist/tests/SkillRepository.test.js.map +1 -0
- package/dist/tests/SwarmIndexer.test.d.ts +11 -0
- package/dist/tests/SwarmIndexer.test.d.ts.map +1 -0
- package/dist/tests/SwarmIndexer.test.js +374 -0
- package/dist/tests/SwarmIndexer.test.js.map +1 -0
- package/dist/tests/TieredCache.test.d.ts +7 -0
- package/dist/tests/TieredCache.test.d.ts.map +1 -0
- package/dist/tests/TieredCache.test.js +529 -0
- package/dist/tests/TieredCache.test.js.map +1 -0
- package/dist/tests/UsageAnalyticsService.test.d.ts +7 -0
- package/dist/tests/UsageAnalyticsService.test.d.ts.map +1 -0
- package/dist/tests/UsageAnalyticsService.test.js +238 -0
- package/dist/tests/UsageAnalyticsService.test.js.map +1 -0
- package/dist/tests/UsageTracker.test.d.ts +7 -0
- package/dist/tests/UsageTracker.test.d.ts.map +1 -0
- package/dist/tests/UsageTracker.test.js +196 -0
- package/dist/tests/UsageTracker.test.js.map +1 -0
- package/dist/tests/WebhookHandler.test.d.ts +10 -0
- package/dist/tests/WebhookHandler.test.d.ts.map +1 -0
- package/dist/tests/WebhookHandler.test.js +592 -0
- package/dist/tests/WebhookHandler.test.js.map +1 -0
- package/dist/tests/analytics/metrics-aggregator.test.d.ts +11 -0
- package/dist/tests/analytics/metrics-aggregator.test.d.ts.map +1 -0
- package/dist/tests/analytics/metrics-aggregator.test.js +273 -0
- package/dist/tests/analytics/metrics-aggregator.test.js.map +1 -0
- package/dist/tests/analytics/metrics-exporter.test.d.ts +11 -0
- package/dist/tests/analytics/metrics-exporter.test.d.ts.map +1 -0
- package/dist/tests/analytics/metrics-exporter.test.js +371 -0
- package/dist/tests/analytics/metrics-exporter.test.js.map +1 -0
- package/dist/tests/analytics/usage-tracker.test.d.ts +10 -0
- package/dist/tests/analytics/usage-tracker.test.d.ts.map +1 -0
- package/dist/tests/analytics/usage-tracker.test.js +151 -0
- package/dist/tests/analytics/usage-tracker.test.js.map +1 -0
- package/dist/tests/anonymizer.test.d.ts +8 -0
- package/dist/tests/anonymizer.test.d.ts.map +1 -0
- package/dist/tests/anonymizer.test.js +153 -0
- package/dist/tests/anonymizer.test.js.map +1 -0
- package/dist/tests/cache.test.d.ts +6 -0
- package/dist/tests/cache.test.d.ts.map +1 -0
- package/dist/tests/cache.test.js +170 -0
- package/dist/tests/cache.test.js.map +1 -0
- package/dist/tests/e2e/security/security.e2e.test.d.ts +8 -0
- package/dist/tests/e2e/security/security.e2e.test.d.ts.map +1 -0
- package/dist/tests/e2e/security/security.e2e.test.js +448 -0
- package/dist/tests/e2e/security/security.e2e.test.js.map +1 -0
- package/dist/tests/edge-cases/EdgeCases.test.d.ts +13 -0
- package/dist/tests/edge-cases/EdgeCases.test.d.ts.map +1 -0
- package/dist/tests/edge-cases/EdgeCases.test.js +844 -0
- package/dist/tests/edge-cases/EdgeCases.test.js.map +1 -0
- package/dist/tests/import-github-skills.test.d.ts +8 -0
- package/dist/tests/import-github-skills.test.d.ts.map +1 -0
- package/dist/tests/import-github-skills.test.js +390 -0
- package/dist/tests/import-github-skills.test.js.map +1 -0
- package/dist/tests/logger.test.d.ts +2 -0
- package/dist/tests/logger.test.d.ts.map +1 -0
- package/dist/tests/logger.test.js +417 -0
- package/dist/tests/logger.test.js.map +1 -0
- package/dist/tests/performance/LargeScalePerformance.test.d.ts +14 -0
- package/dist/tests/performance/LargeScalePerformance.test.d.ts.map +1 -0
- package/dist/tests/performance/LargeScalePerformance.test.js +558 -0
- package/dist/tests/performance/LargeScalePerformance.test.js.map +1 -0
- package/dist/tests/retry.test.d.ts +7 -0
- package/dist/tests/retry.test.d.ts.map +1 -0
- package/dist/tests/retry.test.js +302 -0
- package/dist/tests/retry.test.js.map +1 -0
- package/dist/tests/sanitization.test.d.ts +8 -0
- package/dist/tests/sanitization.test.d.ts.map +1 -0
- package/dist/tests/sanitization.test.js +413 -0
- package/dist/tests/sanitization.test.js.map +1 -0
- package/dist/tests/schema.test.d.ts +5 -0
- package/dist/tests/schema.test.d.ts.map +1 -0
- package/dist/tests/schema.test.js +167 -0
- package/dist/tests/schema.test.js.map +1 -0
- package/dist/tests/scripts/import-to-database.test.d.ts +11 -0
- package/dist/tests/scripts/import-to-database.test.d.ts.map +1 -0
- package/dist/tests/scripts/import-to-database.test.js +325 -0
- package/dist/tests/scripts/import-to-database.test.js.map +1 -0
- package/dist/tests/security/ContinuousSecurity.test.d.ts +6 -0
- package/dist/tests/security/ContinuousSecurity.test.d.ts.map +1 -0
- package/dist/tests/security/ContinuousSecurity.test.js +595 -0
- package/dist/tests/security/ContinuousSecurity.test.js.map +1 -0
- package/dist/tests/security/ReDoS.test.d.ts +8 -0
- package/dist/tests/security/ReDoS.test.d.ts.map +1 -0
- package/dist/tests/security/ReDoS.test.js +213 -0
- package/dist/tests/security/ReDoS.test.js.map +1 -0
- package/dist/tests/security.test.d.ts +5 -0
- package/dist/tests/security.test.d.ts.map +1 -0
- package/dist/tests/security.test.js +134 -0
- package/dist/tests/security.test.js.map +1 -0
- package/dist/tests/shared.test.d.ts +7 -0
- package/dist/tests/shared.test.d.ts.map +1 -0
- package/dist/tests/shared.test.js +480 -0
- package/dist/tests/shared.test.js.map +1 -0
- package/dist/tests/sources.test.d.ts +5 -0
- package/dist/tests/sources.test.d.ts.map +1 -0
- package/dist/tests/sources.test.js +369 -0
- package/dist/tests/sources.test.js.map +1 -0
- package/dist/tests/stats.test.d.ts +11 -0
- package/dist/tests/stats.test.d.ts.map +1 -0
- package/dist/tests/stats.test.js +124 -0
- package/dist/tests/stats.test.js.map +1 -0
- package/dist/tests/telemetry.test.d.ts +11 -0
- package/dist/tests/telemetry.test.d.ts.map +1 -0
- package/dist/tests/telemetry.test.js +424 -0
- package/dist/tests/telemetry.test.js.map +1 -0
- package/dist/tests/test-utils.d.ts +74 -0
- package/dist/tests/test-utils.d.ts.map +1 -0
- package/dist/tests/test-utils.js +98 -0
- package/dist/tests/test-utils.js.map +1 -0
- package/dist/tests/validate-skills.test.d.ts +5 -0
- package/dist/tests/validate-skills.test.d.ts.map +1 -0
- package/dist/tests/validate-skills.test.js +649 -0
- package/dist/tests/validate-skills.test.js.map +1 -0
- package/dist/tests/validation.test.d.ts +7 -0
- package/dist/tests/validation.test.d.ts.map +1 -0
- package/dist/tests/validation.test.js +495 -0
- package/dist/tests/validation.test.js.map +1 -0
- package/dist/tests/webhooks/WebhookHandler.idempotency.test.d.ts +8 -0
- package/dist/tests/webhooks/WebhookHandler.idempotency.test.d.ts.map +1 -0
- package/dist/tests/webhooks/WebhookHandler.idempotency.test.js +190 -0
- package/dist/tests/webhooks/WebhookHandler.idempotency.test.js.map +1 -0
- package/dist/tests/webhooks/WebhookPayload.security.test.d.ts +8 -0
- package/dist/tests/webhooks/WebhookPayload.security.test.d.ts.map +1 -0
- package/dist/tests/webhooks/WebhookPayload.security.test.js +204 -0
- package/dist/tests/webhooks/WebhookPayload.security.test.js.map +1 -0
- package/dist/vitest.config.d.ts +3 -0
- package/dist/vitest.config.d.ts.map +1 -0
- package/dist/vitest.config.js +13 -0
- package/dist/vitest.config.js.map +1 -0
- package/package.json +77 -0
|
@@ -0,0 +1,417 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, vi, afterEach } from 'vitest';
|
|
2
|
+
import { logger, createLogger, silentLogger, LogLevel, createAuditEvent, createSecurityEvent, getLogAggregator, setLogAggregator, } from '../src/utils/logger.js';
|
|
3
|
+
describe('Logger', () => {
|
|
4
|
+
let consoleWarnSpy;
|
|
5
|
+
let consoleErrorSpy;
|
|
6
|
+
let consoleInfoSpy;
|
|
7
|
+
let consoleDebugSpy;
|
|
8
|
+
let consoleLogSpy;
|
|
9
|
+
let originalAggregator;
|
|
10
|
+
beforeEach(() => {
|
|
11
|
+
consoleWarnSpy = vi.spyOn(console, 'warn').mockImplementation(() => { });
|
|
12
|
+
consoleErrorSpy = vi.spyOn(console, 'error').mockImplementation(() => { });
|
|
13
|
+
consoleInfoSpy = vi.spyOn(console, 'info').mockImplementation(() => { });
|
|
14
|
+
consoleDebugSpy = vi.spyOn(console, 'debug').mockImplementation(() => { });
|
|
15
|
+
consoleLogSpy = vi.spyOn(console, 'log').mockImplementation(() => { });
|
|
16
|
+
// Ensure NODE_ENV is set to 'test' for proper log suppression
|
|
17
|
+
process.env.NODE_ENV = 'test';
|
|
18
|
+
// Clear other environment variables
|
|
19
|
+
delete process.env.DEBUG;
|
|
20
|
+
delete process.env.LOG_FORMAT;
|
|
21
|
+
delete process.env.LOG_LEVEL;
|
|
22
|
+
delete process.env.AUDIT_LOG;
|
|
23
|
+
// Save original aggregator before any test modifies it
|
|
24
|
+
originalAggregator = getLogAggregator();
|
|
25
|
+
// Clear aggregator
|
|
26
|
+
if ('clear' in originalAggregator) {
|
|
27
|
+
;
|
|
28
|
+
originalAggregator.clear();
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
afterEach(() => {
|
|
32
|
+
vi.restoreAllMocks();
|
|
33
|
+
// Restore original aggregator in case a test replaced it
|
|
34
|
+
setLogAggregator(originalAggregator);
|
|
35
|
+
});
|
|
36
|
+
describe('Basic Logging', () => {
|
|
37
|
+
it('should log error messages in test mode', () => {
|
|
38
|
+
logger.error('Test error');
|
|
39
|
+
expect(consoleErrorSpy).toHaveBeenCalledWith(expect.stringContaining('[skillsmith] Test error'));
|
|
40
|
+
});
|
|
41
|
+
it('should suppress warn messages in test mode', () => {
|
|
42
|
+
logger.warn('Test warning');
|
|
43
|
+
expect(consoleWarnSpy).not.toHaveBeenCalled();
|
|
44
|
+
});
|
|
45
|
+
it('should suppress info messages without DEBUG', () => {
|
|
46
|
+
logger.info('Test info');
|
|
47
|
+
expect(consoleInfoSpy).not.toHaveBeenCalled();
|
|
48
|
+
});
|
|
49
|
+
it('should suppress debug messages without DEBUG', () => {
|
|
50
|
+
logger.debug('Test debug');
|
|
51
|
+
expect(consoleDebugSpy).not.toHaveBeenCalled();
|
|
52
|
+
});
|
|
53
|
+
it('should log info messages with DEBUG=true', () => {
|
|
54
|
+
process.env.DEBUG = 'true';
|
|
55
|
+
const debugLogger = createLogger('test');
|
|
56
|
+
debugLogger.info('Test info');
|
|
57
|
+
expect(consoleInfoSpy).toHaveBeenCalledWith(expect.stringContaining('[skillsmith:test] Test info'));
|
|
58
|
+
});
|
|
59
|
+
it('should log debug messages with DEBUG=true', () => {
|
|
60
|
+
process.env.DEBUG = 'true';
|
|
61
|
+
const debugLogger = createLogger('test');
|
|
62
|
+
debugLogger.debug('Test debug');
|
|
63
|
+
expect(consoleDebugSpy).toHaveBeenCalledWith(expect.stringContaining('[skillsmith:test] Test debug'));
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
describe('Context Injection', () => {
|
|
67
|
+
it('should include context in log messages', () => {
|
|
68
|
+
logger.error('Error with context', undefined, { userId: '123', action: 'fetch' });
|
|
69
|
+
const aggregator = getLogAggregator();
|
|
70
|
+
const logs = aggregator.getLogs();
|
|
71
|
+
const lastLog = logs[logs.length - 1];
|
|
72
|
+
expect(lastLog.context).toEqual({ userId: '123', action: 'fetch' });
|
|
73
|
+
});
|
|
74
|
+
it('should include error object in log entries', () => {
|
|
75
|
+
const error = new Error('Network failure');
|
|
76
|
+
logger.error('Failed to fetch', error);
|
|
77
|
+
const aggregator = getLogAggregator();
|
|
78
|
+
const logs = aggregator.getLogs();
|
|
79
|
+
const lastLog = logs[logs.length - 1];
|
|
80
|
+
expect(lastLog.error).toBe(error);
|
|
81
|
+
});
|
|
82
|
+
it('should format context in human-readable output', () => {
|
|
83
|
+
process.env.NODE_ENV = 'development';
|
|
84
|
+
const devLogger = createLogger('test');
|
|
85
|
+
devLogger.warn('Warning with context', { code: 'RATE_LIMIT' });
|
|
86
|
+
expect(consoleWarnSpy).toHaveBeenCalledWith(expect.stringContaining('{"code":"RATE_LIMIT"}'));
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
describe('Structured JSON Logging', () => {
|
|
90
|
+
it('should output JSON format when LOG_FORMAT=json', () => {
|
|
91
|
+
process.env.LOG_FORMAT = 'json';
|
|
92
|
+
const jsonLogger = createLogger('test');
|
|
93
|
+
jsonLogger.error('JSON error', new Error('test'));
|
|
94
|
+
const callArg = consoleErrorSpy.mock.calls[0][0];
|
|
95
|
+
expect(() => JSON.parse(callArg)).not.toThrow();
|
|
96
|
+
const parsed = JSON.parse(callArg);
|
|
97
|
+
expect(parsed).toMatchObject({
|
|
98
|
+
level: 'ERROR',
|
|
99
|
+
namespace: 'test',
|
|
100
|
+
message: 'JSON error',
|
|
101
|
+
});
|
|
102
|
+
expect(parsed.error).toMatchObject({
|
|
103
|
+
message: 'test',
|
|
104
|
+
});
|
|
105
|
+
});
|
|
106
|
+
it('should include timestamp in JSON format', () => {
|
|
107
|
+
process.env.LOG_FORMAT = 'json';
|
|
108
|
+
const jsonLogger = createLogger('test');
|
|
109
|
+
jsonLogger.error('Test');
|
|
110
|
+
const parsed = JSON.parse(consoleErrorSpy.mock.calls[0][0]);
|
|
111
|
+
expect(parsed.timestamp).toMatch(/^\d{4}-\d{2}-\d{2}T/);
|
|
112
|
+
});
|
|
113
|
+
});
|
|
114
|
+
describe('Log Levels', () => {
|
|
115
|
+
it('should respect LOG_LEVEL environment variable', () => {
|
|
116
|
+
process.env.LOG_LEVEL = String(LogLevel.ERROR);
|
|
117
|
+
process.env.NODE_ENV = 'development';
|
|
118
|
+
const levelLogger = createLogger('test');
|
|
119
|
+
levelLogger.warn('Should not log');
|
|
120
|
+
levelLogger.error('Should log');
|
|
121
|
+
expect(consoleWarnSpy).not.toHaveBeenCalled();
|
|
122
|
+
expect(consoleErrorSpy).toHaveBeenCalled();
|
|
123
|
+
});
|
|
124
|
+
it('should handle numeric log levels correctly', () => {
|
|
125
|
+
expect(LogLevel.DEBUG).toBe(0);
|
|
126
|
+
expect(LogLevel.INFO).toBe(1);
|
|
127
|
+
expect(LogLevel.WARN).toBe(2);
|
|
128
|
+
expect(LogLevel.ERROR).toBe(3);
|
|
129
|
+
expect(LogLevel.AUDIT).toBe(4);
|
|
130
|
+
expect(LogLevel.SECURITY).toBe(5);
|
|
131
|
+
});
|
|
132
|
+
});
|
|
133
|
+
describe('Namespaced Logger', () => {
|
|
134
|
+
it('should create logger with namespace', () => {
|
|
135
|
+
const namespacedLogger = createLogger('GitLabAdapter');
|
|
136
|
+
namespacedLogger.error('Namespaced error');
|
|
137
|
+
expect(consoleErrorSpy).toHaveBeenCalledWith(expect.stringContaining('[skillsmith:GitLabAdapter] Namespaced error'));
|
|
138
|
+
});
|
|
139
|
+
it('should maintain namespace in aggregated logs', () => {
|
|
140
|
+
const namespacedLogger = createLogger('TestNamespace');
|
|
141
|
+
namespacedLogger.error('Test');
|
|
142
|
+
const aggregator = getLogAggregator();
|
|
143
|
+
const logs = aggregator.getLogs();
|
|
144
|
+
const lastLog = logs[logs.length - 1];
|
|
145
|
+
expect(lastLog.namespace).toBe('TestNamespace');
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
describe('Silent Logger', () => {
|
|
149
|
+
it('should not output any logs', () => {
|
|
150
|
+
silentLogger.warn('Silent warn');
|
|
151
|
+
silentLogger.error('Silent error');
|
|
152
|
+
silentLogger.info('Silent info');
|
|
153
|
+
silentLogger.debug('Silent debug');
|
|
154
|
+
expect(consoleWarnSpy).not.toHaveBeenCalled();
|
|
155
|
+
expect(consoleErrorSpy).not.toHaveBeenCalled();
|
|
156
|
+
expect(consoleInfoSpy).not.toHaveBeenCalled();
|
|
157
|
+
expect(consoleDebugSpy).not.toHaveBeenCalled();
|
|
158
|
+
});
|
|
159
|
+
it('should not call audit or security methods', () => {
|
|
160
|
+
const auditEvent = createAuditEvent('skill.install', 'user', 'skill-id', 'install', 'success');
|
|
161
|
+
const securityEvent = createSecurityEvent('ssrf.blocked', 'high', 'http://evil.com', 'fetch', 'Blocked SSRF attempt');
|
|
162
|
+
silentLogger.auditLog(auditEvent);
|
|
163
|
+
silentLogger.securityLog(securityEvent);
|
|
164
|
+
expect(consoleLogSpy).not.toHaveBeenCalled();
|
|
165
|
+
expect(consoleWarnSpy).not.toHaveBeenCalled();
|
|
166
|
+
});
|
|
167
|
+
});
|
|
168
|
+
describe('Audit Logging', () => {
|
|
169
|
+
it('should log audit events with correct format', () => {
|
|
170
|
+
const auditEvent = {
|
|
171
|
+
eventType: 'skill.install',
|
|
172
|
+
timestamp: new Date().toISOString(),
|
|
173
|
+
actor: 'user',
|
|
174
|
+
resource: 'skill-123',
|
|
175
|
+
action: 'install',
|
|
176
|
+
result: 'success',
|
|
177
|
+
metadata: { version: '1.0.0' },
|
|
178
|
+
};
|
|
179
|
+
logger.auditLog(auditEvent);
|
|
180
|
+
const aggregator = getLogAggregator();
|
|
181
|
+
const auditEvents = aggregator.getAuditEvents();
|
|
182
|
+
expect(auditEvents).toHaveLength(1);
|
|
183
|
+
expect(auditEvents[0]).toEqual(auditEvent);
|
|
184
|
+
});
|
|
185
|
+
it('should format audit events for console output', () => {
|
|
186
|
+
process.env.AUDIT_LOG = 'true';
|
|
187
|
+
const auditLogger = createLogger('test');
|
|
188
|
+
const auditEvent = createAuditEvent('adapter.request', 'GitLabAdapter', 'https://gitlab.com/api', 'fetch', 'success');
|
|
189
|
+
auditLogger.auditLog(auditEvent);
|
|
190
|
+
expect(consoleLogSpy).toHaveBeenCalledWith(expect.stringContaining('[AUDIT] adapter.request'));
|
|
191
|
+
expect(consoleLogSpy).toHaveBeenCalledWith(expect.stringContaining('GitLabAdapter -> fetch on https://gitlab.com/api = success'));
|
|
192
|
+
});
|
|
193
|
+
it('should output audit events as JSON when LOG_FORMAT=json', () => {
|
|
194
|
+
process.env.LOG_FORMAT = 'json';
|
|
195
|
+
process.env.AUDIT_LOG = 'true';
|
|
196
|
+
const jsonLogger = createLogger('test');
|
|
197
|
+
const auditEvent = createAuditEvent('skill.fetch', 'system', 'skill-456', 'fetch', 'success');
|
|
198
|
+
jsonLogger.auditLog(auditEvent);
|
|
199
|
+
const callArg = consoleLogSpy.mock.calls[0][0];
|
|
200
|
+
const parsed = JSON.parse(callArg);
|
|
201
|
+
expect(parsed).toMatchObject({
|
|
202
|
+
eventType: 'skill.fetch',
|
|
203
|
+
actor: 'system',
|
|
204
|
+
resource: 'skill-456',
|
|
205
|
+
action: 'fetch',
|
|
206
|
+
result: 'success',
|
|
207
|
+
});
|
|
208
|
+
});
|
|
209
|
+
it('should include metadata in audit events', () => {
|
|
210
|
+
const auditEvent = createAuditEvent('skill.install', 'user', 'skill-789', 'install', 'success', { version: '2.0.0', author: 'test-author' });
|
|
211
|
+
logger.auditLog(auditEvent);
|
|
212
|
+
const aggregator = getLogAggregator();
|
|
213
|
+
const auditEvents = aggregator.getAuditEvents();
|
|
214
|
+
expect(auditEvents[0].metadata).toEqual({
|
|
215
|
+
version: '2.0.0',
|
|
216
|
+
author: 'test-author',
|
|
217
|
+
});
|
|
218
|
+
});
|
|
219
|
+
});
|
|
220
|
+
describe('Security Logging', () => {
|
|
221
|
+
it('should log security events with correct format', () => {
|
|
222
|
+
const securityEvent = {
|
|
223
|
+
eventType: 'ssrf.blocked',
|
|
224
|
+
timestamp: new Date().toISOString(),
|
|
225
|
+
severity: 'high',
|
|
226
|
+
resource: 'http://169.254.169.254/metadata',
|
|
227
|
+
action: 'fetch',
|
|
228
|
+
details: 'Blocked SSRF attempt to AWS metadata endpoint',
|
|
229
|
+
metadata: { adapter: 'GitHubAdapter' },
|
|
230
|
+
};
|
|
231
|
+
logger.securityLog(securityEvent);
|
|
232
|
+
const aggregator = getLogAggregator();
|
|
233
|
+
const securityEvents = aggregator.getSecurityEvents();
|
|
234
|
+
expect(securityEvents).toHaveLength(1);
|
|
235
|
+
expect(securityEvents[0]).toEqual(securityEvent);
|
|
236
|
+
});
|
|
237
|
+
it('should suppress security logs in test mode', () => {
|
|
238
|
+
const securityEvent = createSecurityEvent('path_traversal.blocked', 'critical', '../../etc/passwd', 'read', 'Blocked path traversal attempt');
|
|
239
|
+
logger.securityLog(securityEvent);
|
|
240
|
+
// Should not output to console in test mode
|
|
241
|
+
expect(consoleWarnSpy).not.toHaveBeenCalled();
|
|
242
|
+
// But should still aggregate
|
|
243
|
+
const aggregator = getLogAggregator();
|
|
244
|
+
const securityEvents = aggregator.getSecurityEvents();
|
|
245
|
+
expect(securityEvents).toHaveLength(1);
|
|
246
|
+
});
|
|
247
|
+
it('should format security events for console output', () => {
|
|
248
|
+
process.env.NODE_ENV = 'development';
|
|
249
|
+
const devLogger = createLogger('test');
|
|
250
|
+
const securityEvent = createSecurityEvent('malware.detected', 'critical', 'skill-malicious', 'scan', 'Detected malicious code pattern');
|
|
251
|
+
devLogger.securityLog(securityEvent);
|
|
252
|
+
expect(consoleWarnSpy).toHaveBeenCalledWith(expect.stringContaining('[SECURITY:CRITICAL] malware.detected'));
|
|
253
|
+
expect(consoleWarnSpy).toHaveBeenCalledWith(expect.stringContaining('scan on skill-malicious - Detected malicious code pattern'));
|
|
254
|
+
});
|
|
255
|
+
it('should output security events as JSON when LOG_FORMAT=json', () => {
|
|
256
|
+
process.env.LOG_FORMAT = 'json';
|
|
257
|
+
process.env.NODE_ENV = 'development';
|
|
258
|
+
const jsonLogger = createLogger('test');
|
|
259
|
+
const securityEvent = createSecurityEvent('validation.failed', 'medium', 'user-input', 'validate', 'Input validation failed');
|
|
260
|
+
jsonLogger.securityLog(securityEvent);
|
|
261
|
+
const callArg = consoleWarnSpy.mock.calls[0][0];
|
|
262
|
+
const parsed = JSON.parse(callArg);
|
|
263
|
+
expect(parsed).toMatchObject({
|
|
264
|
+
eventType: 'validation.failed',
|
|
265
|
+
severity: 'medium',
|
|
266
|
+
resource: 'user-input',
|
|
267
|
+
action: 'validate',
|
|
268
|
+
details: 'Input validation failed',
|
|
269
|
+
});
|
|
270
|
+
});
|
|
271
|
+
});
|
|
272
|
+
describe('Log Aggregation', () => {
|
|
273
|
+
it('should aggregate all log entries', () => {
|
|
274
|
+
logger.warn('Warn message');
|
|
275
|
+
logger.error('Error message');
|
|
276
|
+
logger.info('Info message');
|
|
277
|
+
const aggregator = getLogAggregator();
|
|
278
|
+
const logs = aggregator.getLogs();
|
|
279
|
+
expect(logs.length).toBeGreaterThanOrEqual(3);
|
|
280
|
+
});
|
|
281
|
+
it('should aggregate audit events separately', () => {
|
|
282
|
+
const auditEvent1 = createAuditEvent('skill.install', 'user', 'skill-1', 'install', 'success');
|
|
283
|
+
const auditEvent2 = createAuditEvent('skill.fetch', 'system', 'skill-2', 'fetch', 'success');
|
|
284
|
+
logger.auditLog(auditEvent1);
|
|
285
|
+
logger.auditLog(auditEvent2);
|
|
286
|
+
const aggregator = getLogAggregator();
|
|
287
|
+
const auditEvents = aggregator.getAuditEvents();
|
|
288
|
+
expect(auditEvents).toHaveLength(2);
|
|
289
|
+
expect(auditEvents[0].eventType).toBe('skill.install');
|
|
290
|
+
expect(auditEvents[1].eventType).toBe('skill.fetch');
|
|
291
|
+
});
|
|
292
|
+
it('should aggregate security events separately', () => {
|
|
293
|
+
const securityEvent1 = createSecurityEvent('ssrf.blocked', 'high', 'http://evil.com', 'fetch', 'Blocked');
|
|
294
|
+
const securityEvent2 = createSecurityEvent('path_traversal.blocked', 'critical', '../../etc/passwd', 'read', 'Blocked');
|
|
295
|
+
logger.securityLog(securityEvent1);
|
|
296
|
+
logger.securityLog(securityEvent2);
|
|
297
|
+
const aggregator = getLogAggregator();
|
|
298
|
+
const securityEvents = aggregator.getSecurityEvents();
|
|
299
|
+
expect(securityEvents).toHaveLength(2);
|
|
300
|
+
expect(securityEvents[0].eventType).toBe('ssrf.blocked');
|
|
301
|
+
expect(securityEvents[1].eventType).toBe('path_traversal.blocked');
|
|
302
|
+
});
|
|
303
|
+
it('should limit aggregator size to prevent memory leaks', () => {
|
|
304
|
+
const aggregator = getLogAggregator();
|
|
305
|
+
// Add more logs than the max size (default 10000)
|
|
306
|
+
for (let i = 0; i < 10005; i++) {
|
|
307
|
+
logger.error(`Error ${i}`);
|
|
308
|
+
}
|
|
309
|
+
const logs = aggregator.getLogs();
|
|
310
|
+
expect(logs.length).toBeLessThanOrEqual(10000);
|
|
311
|
+
});
|
|
312
|
+
it('should provide copies of logs to prevent external mutation', () => {
|
|
313
|
+
logger.error('Original error');
|
|
314
|
+
const aggregator = getLogAggregator();
|
|
315
|
+
const logs1 = aggregator.getLogs();
|
|
316
|
+
const logs2 = aggregator.getLogs();
|
|
317
|
+
expect(logs1).not.toBe(logs2); // Different array instances
|
|
318
|
+
expect(logs1).toEqual(logs2); // Same content
|
|
319
|
+
});
|
|
320
|
+
});
|
|
321
|
+
describe('Custom Log Aggregator', () => {
|
|
322
|
+
it('should allow setting custom aggregator', () => {
|
|
323
|
+
const customAggregator = {
|
|
324
|
+
add: vi.fn(),
|
|
325
|
+
addAudit: vi.fn(),
|
|
326
|
+
addSecurity: vi.fn(),
|
|
327
|
+
flush: vi.fn(),
|
|
328
|
+
getLogs: vi.fn(() => []),
|
|
329
|
+
getAuditEvents: vi.fn(() => []),
|
|
330
|
+
getSecurityEvents: vi.fn(() => []),
|
|
331
|
+
};
|
|
332
|
+
setLogAggregator(customAggregator);
|
|
333
|
+
logger.error('Test error');
|
|
334
|
+
expect(customAggregator.add).toHaveBeenCalled();
|
|
335
|
+
const auditEvent = createAuditEvent('skill.install', 'user', 'skill-1', 'install', 'success');
|
|
336
|
+
logger.auditLog(auditEvent);
|
|
337
|
+
expect(customAggregator.addAudit).toHaveBeenCalledWith(auditEvent);
|
|
338
|
+
const securityEvent = createSecurityEvent('ssrf.blocked', 'high', 'http://evil.com', 'fetch', 'Blocked');
|
|
339
|
+
logger.securityLog(securityEvent);
|
|
340
|
+
expect(customAggregator.addSecurity).toHaveBeenCalledWith(securityEvent);
|
|
341
|
+
});
|
|
342
|
+
});
|
|
343
|
+
describe('Helper Functions', () => {
|
|
344
|
+
it('createAuditEvent should create valid audit event with timestamp', () => {
|
|
345
|
+
const event = createAuditEvent('skill.install', 'user', 'skill-123', 'install', 'success', {
|
|
346
|
+
version: '1.0.0',
|
|
347
|
+
});
|
|
348
|
+
expect(event).toMatchObject({
|
|
349
|
+
eventType: 'skill.install',
|
|
350
|
+
actor: 'user',
|
|
351
|
+
resource: 'skill-123',
|
|
352
|
+
action: 'install',
|
|
353
|
+
result: 'success',
|
|
354
|
+
metadata: { version: '1.0.0' },
|
|
355
|
+
});
|
|
356
|
+
expect(event.timestamp).toMatch(/^\d{4}-\d{2}-\d{2}T/);
|
|
357
|
+
});
|
|
358
|
+
it('createSecurityEvent should create valid security event with timestamp', () => {
|
|
359
|
+
const event = createSecurityEvent('ssrf.blocked', 'high', 'http://evil.com', 'fetch', 'Blocked SSRF attempt', { ip: '1.2.3.4' });
|
|
360
|
+
expect(event).toMatchObject({
|
|
361
|
+
eventType: 'ssrf.blocked',
|
|
362
|
+
severity: 'high',
|
|
363
|
+
resource: 'http://evil.com',
|
|
364
|
+
action: 'fetch',
|
|
365
|
+
details: 'Blocked SSRF attempt',
|
|
366
|
+
metadata: { ip: '1.2.3.4' },
|
|
367
|
+
});
|
|
368
|
+
expect(event.timestamp).toMatch(/^\d{4}-\d{2}-\d{2}T/);
|
|
369
|
+
});
|
|
370
|
+
it('should create events without metadata', () => {
|
|
371
|
+
const auditEvent = createAuditEvent('cache.hit', 'system', 'cache-key', 'read', 'success');
|
|
372
|
+
expect(auditEvent.metadata).toBeUndefined();
|
|
373
|
+
const securityEvent = createSecurityEvent('rate_limit.exceeded', 'low', 'api-endpoint', 'request', 'Too many requests');
|
|
374
|
+
expect(securityEvent.metadata).toBeUndefined();
|
|
375
|
+
});
|
|
376
|
+
});
|
|
377
|
+
describe('Edge Cases', () => {
|
|
378
|
+
it('should handle undefined context gracefully', () => {
|
|
379
|
+
logger.error('Error without context');
|
|
380
|
+
const aggregator = getLogAggregator();
|
|
381
|
+
const logs = aggregator.getLogs();
|
|
382
|
+
expect(logs.length).toBeGreaterThan(0);
|
|
383
|
+
const lastLog = logs[logs.length - 1];
|
|
384
|
+
expect(lastLog).toBeDefined();
|
|
385
|
+
expect(lastLog.context).toBeUndefined();
|
|
386
|
+
});
|
|
387
|
+
it('should handle undefined error gracefully', () => {
|
|
388
|
+
logger.error('Error without error object');
|
|
389
|
+
const aggregator = getLogAggregator();
|
|
390
|
+
const logs = aggregator.getLogs();
|
|
391
|
+
expect(logs.length).toBeGreaterThan(0);
|
|
392
|
+
const lastLog = logs[logs.length - 1];
|
|
393
|
+
expect(lastLog).toBeDefined();
|
|
394
|
+
expect(lastLog.error).toBeUndefined();
|
|
395
|
+
});
|
|
396
|
+
it('should handle complex metadata objects', () => {
|
|
397
|
+
const complexMetadata = {
|
|
398
|
+
nested: { deep: { value: 'test' } },
|
|
399
|
+
array: [1, 2, 3],
|
|
400
|
+
null: null,
|
|
401
|
+
undefined: undefined,
|
|
402
|
+
};
|
|
403
|
+
const auditEvent = createAuditEvent('skill.scan', 'system', 'skill-complex', 'scan', 'success', complexMetadata);
|
|
404
|
+
logger.auditLog(auditEvent);
|
|
405
|
+
const aggregator = getLogAggregator();
|
|
406
|
+
const auditEvents = aggregator.getAuditEvents();
|
|
407
|
+
expect(auditEvents.length).toBeGreaterThan(0);
|
|
408
|
+
expect(auditEvents[0]).toBeDefined();
|
|
409
|
+
expect(auditEvents[0].metadata).toMatchObject({
|
|
410
|
+
nested: { deep: { value: 'test' } },
|
|
411
|
+
array: [1, 2, 3],
|
|
412
|
+
null: null,
|
|
413
|
+
});
|
|
414
|
+
});
|
|
415
|
+
});
|
|
416
|
+
});
|
|
417
|
+
//# sourceMappingURL=logger.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.test.js","sourceRoot":"","sources":["../../tests/logger.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SMI-867: Performance test suite for large-scale data
|
|
3
|
+
*
|
|
4
|
+
* Benchmarks:
|
|
5
|
+
* - Search latency at different scales (100, 1000, 4000 skills)
|
|
6
|
+
* - Concurrent search performance (10, 50 concurrent searches)
|
|
7
|
+
* - Memory usage monitoring (idle and during search)
|
|
8
|
+
* - FTS5 index rebuild performance
|
|
9
|
+
*
|
|
10
|
+
* Uses Vitest with performance.now() for timing
|
|
11
|
+
* Exports results to JSON for tracking/CI integration
|
|
12
|
+
*/
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=LargeScalePerformance.test.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LargeScalePerformance.test.d.ts","sourceRoot":"","sources":["../../../tests/performance/LargeScalePerformance.test.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG"}
|