@skillsmith/core 0.4.0 → 0.4.2
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 -1
- package/dist/src/analysis/CodebaseAnalyzer.d.ts.map +1 -1
- package/dist/src/analysis/CodebaseAnalyzer.js.map +1 -1
- package/dist/src/analysis/adapters/__tests__/python.test.js.map +1 -1
- package/dist/src/analysis/adapters/java-parsers.d.ts +64 -0
- package/dist/src/analysis/adapters/java-parsers.d.ts.map +1 -0
- package/dist/src/analysis/adapters/java-parsers.js +114 -0
- package/dist/src/analysis/adapters/java-parsers.js.map +1 -0
- package/dist/src/analysis/adapters/java.d.ts +1 -51
- package/dist/src/analysis/adapters/java.d.ts.map +1 -1
- package/dist/src/analysis/adapters/java.js +94 -205
- package/dist/src/analysis/adapters/java.js.map +1 -1
- package/dist/src/analysis/adapters/python-frameworks.d.ts +21 -0
- package/dist/src/analysis/adapters/python-frameworks.d.ts.map +1 -0
- package/dist/src/analysis/adapters/python-frameworks.js +86 -0
- package/dist/src/analysis/adapters/python-frameworks.js.map +1 -0
- package/dist/src/analysis/adapters/python.d.ts +0 -50
- package/dist/src/analysis/adapters/python.d.ts.map +1 -1
- package/dist/src/analysis/adapters/python.js +5 -120
- package/dist/src/analysis/adapters/python.js.map +1 -1
- package/dist/src/analysis/adapters/rust-parsers.d.ts +33 -0
- package/dist/src/analysis/adapters/rust-parsers.d.ts.map +1 -0
- package/dist/src/analysis/adapters/rust-parsers.js +94 -0
- package/dist/src/analysis/adapters/rust-parsers.js.map +1 -0
- package/dist/src/analysis/adapters/rust.d.ts +1 -43
- package/dist/src/analysis/adapters/rust.d.ts.map +1 -1
- package/dist/src/analysis/adapters/rust.js +74 -173
- package/dist/src/analysis/adapters/rust.js.map +1 -1
- package/dist/src/analysis/language-detector.d.ts +4 -20
- package/dist/src/analysis/language-detector.d.ts.map +1 -1
- package/dist/src/analysis/language-detector.js +2 -399
- package/dist/src/analysis/language-detector.js.map +1 -1
- package/dist/src/analysis/language-detector.patterns.d.ts +17 -0
- package/dist/src/analysis/language-detector.patterns.d.ts.map +1 -0
- package/dist/src/analysis/language-detector.patterns.js +413 -0
- package/dist/src/analysis/language-detector.patterns.js.map +1 -0
- package/dist/src/analysis/language-detector.types.d.ts +48 -0
- package/dist/src/analysis/language-detector.types.d.ts.map +1 -0
- package/dist/src/analysis/language-detector.types.js +6 -0
- package/dist/src/analysis/language-detector.types.js.map +1 -0
- package/dist/src/analysis/metrics.d.ts +22 -219
- package/dist/src/analysis/metrics.d.ts.map +1 -1
- package/dist/src/analysis/metrics.implementations.d.ts +39 -0
- package/dist/src/analysis/metrics.implementations.d.ts.map +1 -0
- package/dist/src/analysis/metrics.implementations.js +114 -0
- package/dist/src/analysis/metrics.implementations.js.map +1 -0
- package/dist/src/analysis/metrics.js +21 -224
- package/dist/src/analysis/metrics.js.map +1 -1
- package/dist/src/analysis/metrics.types.d.ts +79 -0
- package/dist/src/analysis/metrics.types.d.ts.map +1 -0
- package/dist/src/analysis/metrics.types.js +6 -0
- package/dist/src/analysis/metrics.types.js.map +1 -0
- package/dist/src/analysis/worker-pool.d.ts +25 -52
- package/dist/src/analysis/worker-pool.d.ts.map +1 -1
- package/dist/src/analysis/worker-pool.js +29 -181
- package/dist/src/analysis/worker-pool.js.map +1 -1
- package/dist/src/analysis/worker-types.d.ts +64 -0
- package/dist/src/analysis/worker-types.d.ts.map +1 -0
- package/dist/src/analysis/worker-types.js +11 -0
- package/dist/src/analysis/worker-types.js.map +1 -0
- package/dist/src/analysis/worker-utils.d.ts +49 -0
- package/dist/src/analysis/worker-utils.d.ts.map +1 -0
- package/dist/src/analysis/worker-utils.js +206 -0
- package/dist/src/analysis/worker-utils.js.map +1 -0
- package/dist/src/analytics/AnalyticsRepository.d.ts +1 -5
- package/dist/src/analytics/AnalyticsRepository.d.ts.map +1 -1
- package/dist/src/analytics/AnalyticsRepository.helpers.d.ts +28 -0
- package/dist/src/analytics/AnalyticsRepository.helpers.d.ts.map +1 -0
- package/dist/src/analytics/AnalyticsRepository.helpers.js +90 -0
- package/dist/src/analytics/AnalyticsRepository.helpers.js.map +1 -0
- package/dist/src/analytics/AnalyticsRepository.js +16 -129
- package/dist/src/analytics/AnalyticsRepository.js.map +1 -1
- package/dist/src/analytics/AnalyticsRepository.types.d.ts +82 -0
- package/dist/src/analytics/AnalyticsRepository.types.d.ts.map +1 -0
- package/dist/src/analytics/AnalyticsRepository.types.js +8 -0
- package/dist/src/analytics/AnalyticsRepository.types.js.map +1 -0
- package/dist/src/analytics/ROIDashboardService.js +4 -2
- package/dist/src/analytics/ROIDashboardService.js.map +1 -1
- package/dist/src/api/cache.d.ts.map +1 -1
- package/dist/src/api/cache.js.map +1 -1
- package/dist/src/api/client.d.ts +6 -121
- package/dist/src/api/client.d.ts.map +1 -1
- package/dist/src/api/client.js +29 -129
- package/dist/src/api/client.js.map +1 -1
- package/dist/src/api/schemas.d.ts +122 -0
- package/dist/src/api/schemas.d.ts.map +1 -0
- package/dist/src/api/schemas.js +71 -0
- package/dist/src/api/schemas.js.map +1 -0
- package/dist/src/api/types.d.ts +1 -1
- package/dist/src/api/types.d.ts.map +1 -1
- package/dist/src/api/utils.d.ts +35 -0
- package/dist/src/api/utils.d.ts.map +1 -0
- package/dist/src/api/utils.js +86 -0
- package/dist/src/api/utils.js.map +1 -0
- package/dist/src/benchmarks/BenchmarkRunner.d.ts.map +1 -1
- package/dist/src/benchmarks/BenchmarkRunner.js +1 -1
- package/dist/src/benchmarks/BenchmarkRunner.js.map +1 -1
- package/dist/src/billing/BillingService.d.ts +15 -53
- package/dist/src/billing/BillingService.d.ts.map +1 -1
- package/dist/src/billing/BillingService.helpers.d.ts +15 -0
- package/dist/src/billing/BillingService.helpers.d.ts.map +1 -0
- package/dist/src/billing/BillingService.helpers.js +45 -0
- package/dist/src/billing/BillingService.helpers.js.map +1 -0
- package/dist/src/billing/BillingService.js +49 -179
- package/dist/src/billing/BillingService.js.map +1 -1
- package/dist/src/billing/BillingService.types.d.ts +52 -0
- package/dist/src/billing/BillingService.types.d.ts.map +1 -0
- package/dist/src/billing/BillingService.types.js +6 -0
- package/dist/src/billing/BillingService.types.js.map +1 -0
- package/dist/src/billing/GDPRComplianceService.d.ts +2 -97
- package/dist/src/billing/GDPRComplianceService.d.ts.map +1 -1
- package/dist/src/billing/GDPRComplianceService.js.map +1 -1
- package/dist/src/billing/StripeClient.d.ts +6 -64
- package/dist/src/billing/StripeClient.d.ts.map +1 -1
- package/dist/src/billing/StripeClient.js +14 -71
- package/dist/src/billing/StripeClient.js.map +1 -1
- package/dist/src/billing/StripeReconciliationJob.d.ts +2 -47
- package/dist/src/billing/StripeReconciliationJob.d.ts.map +1 -1
- package/dist/src/billing/StripeReconciliationJob.js +1 -41
- package/dist/src/billing/StripeReconciliationJob.js.map +1 -1
- package/dist/src/billing/StripeWebhookHandler.d.ts +3 -46
- package/dist/src/billing/StripeWebhookHandler.d.ts.map +1 -1
- package/dist/src/billing/StripeWebhookHandler.js +14 -261
- package/dist/src/billing/StripeWebhookHandler.js.map +1 -1
- package/dist/src/billing/gdpr-types.d.ts +103 -0
- package/dist/src/billing/gdpr-types.d.ts.map +1 -0
- package/dist/src/billing/gdpr-types.js +7 -0
- package/dist/src/billing/gdpr-types.js.map +1 -0
- package/dist/src/billing/reconciliation-helpers.d.ts +16 -0
- package/dist/src/billing/reconciliation-helpers.d.ts.map +1 -0
- package/dist/src/billing/reconciliation-helpers.js +53 -0
- package/dist/src/billing/reconciliation-helpers.js.map +1 -0
- package/dist/src/billing/reconciliation-types.d.ts +71 -0
- package/dist/src/billing/reconciliation-types.d.ts.map +1 -0
- package/dist/src/billing/reconciliation-types.js +7 -0
- package/dist/src/billing/reconciliation-types.js.map +1 -0
- package/dist/src/billing/stripe-client-types.d.ts +45 -0
- package/dist/src/billing/stripe-client-types.d.ts.map +1 -0
- package/dist/src/billing/stripe-client-types.js +7 -0
- package/dist/src/billing/stripe-client-types.js.map +1 -0
- package/dist/src/billing/stripe-helpers.d.ts +17 -0
- package/dist/src/billing/stripe-helpers.d.ts.map +1 -0
- package/dist/src/billing/stripe-helpers.js +50 -0
- package/dist/src/billing/stripe-helpers.js.map +1 -0
- package/dist/src/billing/webhook-handlers.d.ts +56 -0
- package/dist/src/billing/webhook-handlers.d.ts.map +1 -0
- package/dist/src/billing/webhook-handlers.js +303 -0
- package/dist/src/billing/webhook-handlers.js.map +1 -0
- package/dist/src/billing/webhook-types.d.ts +42 -0
- package/dist/src/billing/webhook-types.d.ts.map +1 -0
- package/dist/src/billing/webhook-types.js +7 -0
- package/dist/src/billing/webhook-types.js.map +1 -0
- package/dist/src/config/index.d.ts +118 -0
- package/dist/src/config/index.d.ts.map +1 -0
- package/dist/src/config/index.js +172 -0
- package/dist/src/config/index.js.map +1 -0
- package/dist/src/db/migration-types.d.ts +101 -0
- package/dist/src/db/migration-types.d.ts.map +1 -0
- package/dist/src/db/migration-types.js +6 -0
- package/dist/src/db/migration-types.js.map +1 -0
- package/dist/src/db/migration.d.ts +32 -0
- package/dist/src/db/migration.d.ts.map +1 -0
- package/dist/src/db/migration.js +239 -0
- package/dist/src/db/migration.js.map +1 -0
- package/dist/src/db/schema.d.ts +2 -2
- package/dist/src/db/schema.d.ts.map +1 -1
- package/dist/src/db/schema.js +23 -1
- package/dist/src/db/schema.js.map +1 -1
- package/dist/src/embeddings/embedding-types.d.ts +44 -0
- package/dist/src/embeddings/embedding-types.d.ts.map +1 -0
- package/dist/src/embeddings/embedding-types.js +6 -0
- package/dist/src/embeddings/embedding-types.js.map +1 -0
- package/dist/src/embeddings/embedding-utils.d.ts +42 -0
- package/dist/src/embeddings/embedding-utils.d.ts.map +1 -0
- package/dist/src/embeddings/embedding-utils.js +121 -0
- package/dist/src/embeddings/embedding-utils.js.map +1 -0
- package/dist/src/embeddings/hnsw-store.d.ts +8 -518
- package/dist/src/embeddings/hnsw-store.d.ts.map +1 -1
- package/dist/src/embeddings/hnsw-store.helpers.d.ts +83 -0
- package/dist/src/embeddings/hnsw-store.helpers.d.ts.map +1 -0
- package/dist/src/embeddings/hnsw-store.helpers.js +147 -0
- package/dist/src/embeddings/hnsw-store.helpers.js.map +1 -0
- package/dist/src/embeddings/hnsw-store.js +66 -517
- package/dist/src/embeddings/hnsw-store.js.map +1 -1
- package/dist/src/embeddings/hnsw-store.types.d.ts +154 -0
- package/dist/src/embeddings/hnsw-store.types.d.ts.map +1 -0
- package/dist/src/embeddings/hnsw-store.types.js +26 -0
- package/dist/src/embeddings/hnsw-store.types.js.map +1 -0
- package/dist/src/embeddings/index.d.ts +36 -112
- package/dist/src/embeddings/index.d.ts.map +1 -1
- package/dist/src/embeddings/index.js +37 -210
- package/dist/src/embeddings/index.js.map +1 -1
- package/dist/src/errors.d.ts.map +1 -1
- package/dist/src/errors.js +1 -1
- package/dist/src/errors.js.map +1 -1
- package/dist/src/exports/repositories.d.ts +18 -0
- package/dist/src/exports/repositories.d.ts.map +1 -0
- package/dist/src/exports/repositories.js +30 -0
- package/dist/src/exports/repositories.js.map +1 -0
- package/dist/src/exports/services.d.ts +30 -0
- package/dist/src/exports/services.d.ts.map +1 -0
- package/dist/src/exports/services.js +70 -0
- package/dist/src/exports/services.js.map +1 -0
- package/dist/src/exports/types.d.ts +21 -0
- package/dist/src/exports/types.d.ts.map +1 -0
- package/dist/src/exports/types.js +12 -0
- package/dist/src/exports/types.js.map +1 -0
- package/dist/src/index.d.ts +10 -47
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +31 -48
- package/dist/src/index.js.map +1 -1
- package/dist/src/indexer/GitHubIndexer.d.ts.map +1 -1
- package/dist/src/indexer/GitHubIndexer.js +17 -4
- package/dist/src/indexer/GitHubIndexer.js.map +1 -1
- package/dist/src/indexer/SwarmIndexer.d.ts.map +1 -1
- package/dist/src/indexer/SwarmIndexer.js +1 -1
- package/dist/src/indexer/SwarmIndexer.js.map +1 -1
- package/dist/src/learning/PatternStore.d.ts +6 -426
- package/dist/src/learning/PatternStore.d.ts.map +1 -1
- package/dist/src/learning/PatternStore.helpers.d.ts +88 -0
- package/dist/src/learning/PatternStore.helpers.d.ts.map +1 -0
- package/dist/src/learning/PatternStore.helpers.js +286 -0
- package/dist/src/learning/PatternStore.helpers.js.map +1 -0
- package/dist/src/learning/PatternStore.js +52 -598
- package/dist/src/learning/PatternStore.js.map +1 -1
- package/dist/src/learning/PatternStore.queries.d.ts +83 -0
- package/dist/src/learning/PatternStore.queries.d.ts.map +1 -0
- package/dist/src/learning/PatternStore.queries.js +189 -0
- package/dist/src/learning/PatternStore.queries.js.map +1 -0
- package/dist/src/learning/PatternStore.types.d.ts +308 -0
- package/dist/src/learning/PatternStore.types.d.ts.map +1 -0
- package/dist/src/learning/PatternStore.types.js +44 -0
- package/dist/src/learning/PatternStore.types.js.map +1 -0
- package/dist/src/learning/ReasoningBankIntegration.d.ts +5 -345
- package/dist/src/learning/ReasoningBankIntegration.d.ts.map +1 -1
- package/dist/src/learning/ReasoningBankIntegration.helpers.d.ts +49 -0
- package/dist/src/learning/ReasoningBankIntegration.helpers.d.ts.map +1 -0
- package/dist/src/learning/ReasoningBankIntegration.helpers.js +180 -0
- package/dist/src/learning/ReasoningBankIntegration.helpers.js.map +1 -0
- package/dist/src/learning/ReasoningBankIntegration.js +21 -390
- package/dist/src/learning/ReasoningBankIntegration.js.map +1 -1
- package/dist/src/learning/ReasoningBankIntegration.types.d.ts +167 -0
- package/dist/src/learning/ReasoningBankIntegration.types.d.ts.map +1 -0
- package/dist/src/learning/ReasoningBankIntegration.types.js +51 -0
- package/dist/src/learning/ReasoningBankIntegration.types.js.map +1 -0
- package/dist/src/learning/interfaces.d.ts.map +1 -1
- package/dist/src/pipeline/DailyIndexPipeline.d.ts +4 -176
- package/dist/src/pipeline/DailyIndexPipeline.d.ts.map +1 -1
- package/dist/src/pipeline/DailyIndexPipeline.js +9 -83
- package/dist/src/pipeline/DailyIndexPipeline.js.map +1 -1
- package/dist/src/pipeline/pipeline-types.d.ts +132 -0
- package/dist/src/pipeline/pipeline-types.d.ts.map +1 -0
- package/dist/src/pipeline/pipeline-types.js +6 -0
- package/dist/src/pipeline/pipeline-types.js.map +1 -0
- package/dist/src/repositories/IndexerRepository.d.ts +1 -0
- package/dist/src/repositories/IndexerRepository.d.ts.map +1 -1
- package/dist/src/repositories/IndexerRepository.js +6 -0
- package/dist/src/repositories/IndexerRepository.js.map +1 -1
- package/dist/src/repositories/SkillRepository.d.ts.map +1 -1
- package/dist/src/repositories/SkillRepository.js +20 -5
- package/dist/src/repositories/SkillRepository.js.map +1 -1
- package/dist/src/routing/SONARouter.d.ts +3 -101
- package/dist/src/routing/SONARouter.d.ts.map +1 -1
- package/dist/src/routing/SONARouter.helpers.d.ts +112 -0
- package/dist/src/routing/SONARouter.helpers.d.ts.map +1 -0
- package/dist/src/routing/SONARouter.helpers.js +184 -0
- package/dist/src/routing/SONARouter.helpers.js.map +1 -0
- package/dist/src/routing/SONARouter.js +16 -318
- package/dist/src/routing/SONARouter.js.map +1 -1
- package/dist/src/routing/expert-types.d.ts +109 -0
- package/dist/src/routing/expert-types.d.ts.map +1 -0
- package/dist/src/routing/expert-types.js +162 -0
- package/dist/src/routing/expert-types.js.map +1 -0
- package/dist/src/routing/request-types.d.ts +113 -0
- package/dist/src/routing/request-types.d.ts.map +1 -0
- package/dist/src/routing/request-types.js +9 -0
- package/dist/src/routing/request-types.js.map +1 -0
- package/dist/src/routing/types.d.ts +5 -207
- package/dist/src/routing/types.d.ts.map +1 -1
- package/dist/src/routing/types.js +3 -153
- package/dist/src/routing/types.js.map +1 -1
- package/dist/src/scripts/github-import/github-auth.d.ts +17 -0
- package/dist/src/scripts/github-import/github-auth.d.ts.map +1 -0
- package/dist/src/scripts/github-import/github-auth.js +201 -0
- package/dist/src/scripts/github-import/github-auth.js.map +1 -0
- package/dist/src/scripts/github-import/github-client.d.ts +5 -5
- package/dist/src/scripts/github-import/github-client.d.ts.map +1 -1
- package/dist/src/scripts/github-import/github-client.js +5 -204
- package/dist/src/scripts/github-import/github-client.js.map +1 -1
- package/dist/src/scripts/ingest-lenny-skills.d.ts +40 -0
- package/dist/src/scripts/ingest-lenny-skills.d.ts.map +1 -0
- package/dist/src/scripts/ingest-lenny-skills.js +346 -0
- package/dist/src/scripts/ingest-lenny-skills.js.map +1 -0
- package/dist/src/scripts/merge-skills.d.ts +5 -27
- package/dist/src/scripts/merge-skills.d.ts.map +1 -1
- package/dist/src/scripts/merge-skills.js +4 -144
- package/dist/src/scripts/merge-skills.js.map +1 -1
- package/dist/src/scripts/merge-types.d.ts +72 -0
- package/dist/src/scripts/merge-types.d.ts.map +1 -0
- package/dist/src/scripts/merge-types.js +7 -0
- package/dist/src/scripts/merge-types.js.map +1 -0
- package/dist/src/scripts/merge-utils.d.ts +23 -0
- package/dist/src/scripts/merge-utils.d.ts.map +1 -0
- package/dist/src/scripts/merge-utils.js +150 -0
- package/dist/src/scripts/merge-utils.js.map +1 -0
- package/dist/src/scripts/review-categories.d.ts +41 -0
- package/dist/src/scripts/review-categories.d.ts.map +1 -0
- package/dist/src/scripts/review-categories.js +316 -0
- package/dist/src/scripts/review-categories.js.map +1 -0
- package/dist/src/scripts/review-lenny-skills.d.ts +26 -0
- package/dist/src/scripts/review-lenny-skills.d.ts.map +1 -0
- package/dist/src/scripts/review-lenny-skills.js +215 -0
- package/dist/src/scripts/review-lenny-skills.js.map +1 -0
- package/dist/src/scripts/sync-to-supabase.d.ts +10 -0
- package/dist/src/scripts/sync-to-supabase.d.ts.map +1 -0
- package/dist/src/scripts/sync-to-supabase.js +93 -0
- package/dist/src/scripts/sync-to-supabase.js.map +1 -0
- package/dist/src/security/AuditLogger.d.ts +4 -75
- package/dist/src/security/AuditLogger.d.ts.map +1 -1
- package/dist/src/security/AuditLogger.js +3 -12
- package/dist/src/security/AuditLogger.js.map +1 -1
- package/dist/src/security/__tests__/pathValidation.test.js.map +1 -1
- package/dist/src/security/audit-types.d.ts +96 -0
- package/dist/src/security/audit-types.d.ts.map +1 -0
- package/dist/src/security/audit-types.js +15 -0
- package/dist/src/security/audit-types.js.map +1 -0
- package/dist/src/security/sanitization.d.ts +1 -85
- package/dist/src/security/sanitization.d.ts.map +1 -1
- package/dist/src/security/sanitization.js +2 -133
- package/dist/src/security/sanitization.js.map +1 -1
- package/dist/src/security/scanner/SecurityScanner.d.ts +12 -88
- package/dist/src/security/scanner/SecurityScanner.d.ts.map +1 -1
- package/dist/src/security/scanner/SecurityScanner.formatters.d.ts +49 -0
- package/dist/src/security/scanner/SecurityScanner.formatters.d.ts.map +1 -0
- package/dist/src/security/scanner/SecurityScanner.formatters.js +139 -0
- package/dist/src/security/scanner/SecurityScanner.formatters.js.map +1 -0
- package/dist/src/security/scanner/SecurityScanner.helpers.d.ts +40 -0
- package/dist/src/security/scanner/SecurityScanner.helpers.d.ts.map +1 -0
- package/dist/src/security/scanner/SecurityScanner.helpers.js +142 -0
- package/dist/src/security/scanner/SecurityScanner.helpers.js.map +1 -0
- package/dist/src/security/scanner/SecurityScanner.js +26 -255
- package/dist/src/security/scanner/SecurityScanner.js.map +1 -1
- package/dist/src/security/stripe-validators.d.ts +92 -0
- package/dist/src/security/stripe-validators.d.ts.map +1 -0
- package/dist/src/security/stripe-validators.js +139 -0
- package/dist/src/security/stripe-validators.js.map +1 -0
- package/dist/src/services/SearchService.d.ts +5 -29
- package/dist/src/services/SearchService.d.ts.map +1 -1
- package/dist/src/services/SearchService.helpers.d.ts +42 -0
- package/dist/src/services/SearchService.helpers.d.ts.map +1 -0
- package/dist/src/services/SearchService.helpers.js +128 -0
- package/dist/src/services/SearchService.helpers.js.map +1 -0
- package/dist/src/services/SearchService.js +142 -128
- package/dist/src/services/SearchService.js.map +1 -1
- package/dist/src/services/SearchService.types.d.ts +53 -0
- package/dist/src/services/SearchService.types.d.ts.map +1 -0
- package/dist/src/services/SearchService.types.js +7 -0
- package/dist/src/services/SearchService.types.js.map +1 -0
- package/dist/src/services/SkillAnalyzer.d.ts +37 -0
- package/dist/src/services/SkillAnalyzer.d.ts.map +1 -0
- package/dist/src/services/SkillAnalyzer.helpers.d.ts +103 -0
- package/dist/src/services/SkillAnalyzer.helpers.d.ts.map +1 -0
- package/dist/src/services/SkillAnalyzer.helpers.js +237 -0
- package/dist/src/services/SkillAnalyzer.helpers.js.map +1 -0
- package/dist/src/services/SkillAnalyzer.js +270 -0
- package/dist/src/services/SkillAnalyzer.js.map +1 -0
- package/dist/src/services/SkillAnalyzer.types.d.ts +110 -0
- package/dist/src/services/SkillAnalyzer.types.d.ts.map +1 -0
- package/dist/src/services/SkillAnalyzer.types.js +9 -0
- package/dist/src/services/SkillAnalyzer.types.js.map +1 -0
- package/dist/src/services/SkillDecomposer.d.ts +37 -0
- package/dist/src/services/SkillDecomposer.d.ts.map +1 -0
- package/dist/src/services/SkillDecomposer.helpers.d.ts +75 -0
- package/dist/src/services/SkillDecomposer.helpers.d.ts.map +1 -0
- package/dist/src/services/SkillDecomposer.helpers.js +277 -0
- package/dist/src/services/SkillDecomposer.helpers.js.map +1 -0
- package/dist/src/services/SkillDecomposer.js +116 -0
- package/dist/src/services/SkillDecomposer.js.map +1 -0
- package/dist/src/services/SkillDecomposer.types.d.ts +104 -0
- package/dist/src/services/SkillDecomposer.types.d.ts.map +1 -0
- package/dist/src/services/SkillDecomposer.types.js +9 -0
- package/dist/src/services/SkillDecomposer.types.js.map +1 -0
- package/dist/src/services/SubagentGenerator.d.ts +77 -0
- package/dist/src/services/SubagentGenerator.d.ts.map +1 -0
- package/dist/src/services/SubagentGenerator.js +352 -0
- package/dist/src/services/SubagentGenerator.js.map +1 -0
- package/dist/src/services/TaskRunner.d.ts +227 -0
- package/dist/src/services/TaskRunner.d.ts.map +1 -0
- package/dist/src/services/TaskRunner.js +423 -0
- package/dist/src/services/TaskRunner.js.map +1 -0
- package/dist/src/services/TransformationService.d.ts +167 -0
- package/dist/src/services/TransformationService.d.ts.map +1 -0
- package/dist/src/services/TransformationService.js +315 -0
- package/dist/src/services/TransformationService.js.map +1 -0
- package/dist/src/services/__tests__/SkillAnalyzer.test.d.ts +6 -0
- package/dist/src/services/__tests__/SkillAnalyzer.test.d.ts.map +1 -0
- package/dist/src/services/__tests__/SkillAnalyzer.test.js +177 -0
- package/dist/src/services/__tests__/SkillAnalyzer.test.js.map +1 -0
- package/dist/src/services/__tests__/SkillDecomposer.test.d.ts +6 -0
- package/dist/src/services/__tests__/SkillDecomposer.test.d.ts.map +1 -0
- package/dist/src/services/__tests__/SkillDecomposer.test.js +235 -0
- package/dist/src/services/__tests__/SkillDecomposer.test.js.map +1 -0
- package/dist/src/services/__tests__/SubagentGenerator.test.d.ts +6 -0
- package/dist/src/services/__tests__/SubagentGenerator.test.d.ts.map +1 -0
- package/dist/src/services/__tests__/SubagentGenerator.test.js +174 -0
- package/dist/src/services/__tests__/SubagentGenerator.test.js.map +1 -0
- package/dist/src/services/__tests__/TaskRunner.test.d.ts +7 -0
- package/dist/src/services/__tests__/TaskRunner.test.d.ts.map +1 -0
- package/dist/src/services/__tests__/TaskRunner.test.js +316 -0
- package/dist/src/services/__tests__/TaskRunner.test.js.map +1 -0
- package/dist/src/services/__tests__/TransformationService.test.d.ts +6 -0
- package/dist/src/services/__tests__/TransformationService.test.d.ts.map +1 -0
- package/dist/src/services/__tests__/TransformationService.test.js +244 -0
- package/dist/src/services/__tests__/TransformationService.test.js.map +1 -0
- package/dist/src/session/SessionContext.js +1 -1
- package/dist/src/session/SessionContext.js.map +1 -1
- package/dist/src/session/SessionManager.d.ts +3 -67
- package/dist/src/session/SessionManager.d.ts.map +1 -1
- package/dist/src/session/SessionManager.helpers.d.ts +68 -0
- package/dist/src/session/SessionManager.helpers.d.ts.map +1 -0
- package/dist/src/session/SessionManager.helpers.js +152 -0
- package/dist/src/session/SessionManager.helpers.js.map +1 -0
- package/dist/src/session/SessionManager.js +58 -163
- package/dist/src/session/SessionManager.js.map +1 -1
- package/dist/src/session/SessionManager.types.d.ts +88 -0
- package/dist/src/session/SessionManager.types.d.ts.map +1 -0
- package/dist/src/session/SessionManager.types.js +27 -0
- package/dist/src/session/SessionManager.types.js.map +1 -0
- package/dist/src/session/SessionRecovery.d.ts.map +1 -1
- package/dist/src/session/SessionRecovery.js +3 -2
- package/dist/src/session/SessionRecovery.js.map +1 -1
- package/dist/src/sources/RawUrlSourceAdapter.js.map +1 -1
- package/dist/src/sources/SourceAdapterRegistry.js +1 -1
- package/dist/src/sources/SourceAdapterRegistry.js.map +1 -1
- package/dist/src/telemetry/metric-helpers.d.ts +47 -0
- package/dist/src/telemetry/metric-helpers.d.ts.map +1 -0
- package/dist/src/telemetry/metric-helpers.js +96 -0
- package/dist/src/telemetry/metric-helpers.js.map +1 -0
- package/dist/src/telemetry/metric-types.d.ts +73 -0
- package/dist/src/telemetry/metric-types.d.ts.map +1 -0
- package/dist/src/telemetry/metric-types.js +9 -0
- package/dist/src/telemetry/metric-types.js.map +1 -0
- package/dist/src/telemetry/metrics.d.ts +8 -119
- package/dist/src/telemetry/metrics.d.ts.map +1 -1
- package/dist/src/telemetry/metrics.js +20 -193
- package/dist/src/telemetry/metrics.js.map +1 -1
- package/dist/src/telemetry/span-utils.d.ts +30 -0
- package/dist/src/telemetry/span-utils.d.ts.map +1 -0
- package/dist/src/telemetry/span-utils.js +62 -0
- package/dist/src/telemetry/span-utils.js.map +1 -0
- package/dist/src/telemetry/tracer-types.d.ts +91 -0
- package/dist/src/telemetry/tracer-types.d.ts.map +1 -0
- package/dist/src/telemetry/tracer-types.js +6 -0
- package/dist/src/telemetry/tracer-types.js.map +1 -0
- package/dist/src/telemetry/tracer.d.ts +5 -122
- package/dist/src/telemetry/tracer.d.ts.map +1 -1
- package/dist/src/telemetry/tracer.js +24 -170
- package/dist/src/telemetry/tracer.js.map +1 -1
- package/dist/src/testing/MultiLLMProvider.d.ts +17 -293
- package/dist/src/testing/MultiLLMProvider.d.ts.map +1 -1
- package/dist/src/testing/MultiLLMProvider.helpers.d.ts +54 -0
- package/dist/src/testing/MultiLLMProvider.helpers.d.ts.map +1 -0
- package/dist/src/testing/MultiLLMProvider.helpers.js +126 -0
- package/dist/src/testing/MultiLLMProvider.helpers.js.map +1 -0
- package/dist/src/testing/MultiLLMProvider.js +50 -323
- package/dist/src/testing/MultiLLMProvider.js.map +1 -1
- package/dist/src/testing/MultiLLMProvider.types.d.ts +253 -0
- package/dist/src/testing/MultiLLMProvider.types.d.ts.map +1 -0
- package/dist/src/testing/MultiLLMProvider.types.js +111 -0
- package/dist/src/testing/MultiLLMProvider.types.js.map +1 -0
- package/dist/src/triggers/TriggerDetector.d.ts +6 -142
- package/dist/src/triggers/TriggerDetector.d.ts.map +1 -1
- package/dist/src/triggers/TriggerDetector.js +15 -247
- package/dist/src/triggers/TriggerDetector.js.map +1 -1
- package/dist/src/triggers/__tests__/TriggerDetector.test.js +1 -1
- package/dist/src/triggers/__tests__/TriggerDetector.test.js.map +1 -1
- package/dist/src/triggers/trigger-constants.d.ts +22 -0
- package/dist/src/triggers/trigger-constants.d.ts.map +1 -0
- package/dist/src/triggers/trigger-constants.js +185 -0
- package/dist/src/triggers/trigger-constants.js.map +1 -0
- package/dist/src/triggers/trigger-types.d.ts +90 -0
- package/dist/src/triggers/trigger-types.d.ts.map +1 -0
- package/dist/src/triggers/trigger-types.js +6 -0
- package/dist/src/triggers/trigger-types.js.map +1 -0
- package/dist/src/types/skill.d.ts +33 -1
- package/dist/src/types/skill.d.ts.map +1 -1
- package/dist/src/types/skill.js +11 -1
- package/dist/src/types/skill.js.map +1 -1
- package/dist/src/types.d.ts +28 -2
- package/dist/src/types.d.ts.map +1 -1
- package/dist/src/types.js +1 -0
- package/dist/src/types.js.map +1 -1
- package/dist/src/utils/retry.js +2 -2
- package/dist/src/utils/retry.js.map +1 -1
- package/dist/src/validation/index.d.ts +5 -105
- package/dist/src/validation/index.d.ts.map +1 -1
- package/dist/src/validation/index.js +9 -421
- package/dist/src/validation/index.js.map +1 -1
- package/dist/src/validation/input-validators.d.ts +68 -0
- package/dist/src/validation/input-validators.d.ts.map +1 -0
- package/dist/src/validation/input-validators.js +126 -0
- package/dist/src/validation/input-validators.js.map +1 -0
- package/dist/src/validation/path-validators.d.ts +23 -0
- package/dist/src/validation/path-validators.d.ts.map +1 -0
- package/dist/src/validation/path-validators.js +47 -0
- package/dist/src/validation/path-validators.js.map +1 -0
- package/dist/src/validation/url-validators.d.ts +55 -0
- package/dist/src/validation/url-validators.d.ts.map +1 -0
- package/dist/src/validation/url-validators.js +267 -0
- package/dist/src/validation/url-validators.js.map +1 -0
- package/dist/src/validation/validation-error.d.ts +14 -0
- package/dist/src/validation/validation-error.d.ts.map +1 -0
- package/dist/src/validation/validation-error.js +19 -0
- package/dist/src/validation/validation-error.js.map +1 -0
- package/dist/src/webhooks/WebhookHandler.d.ts.map +1 -1
- package/dist/src/webhooks/WebhookHandler.js.map +1 -1
- package/dist/src/webhooks/WebhookPayload.d.ts +4 -215
- package/dist/src/webhooks/WebhookPayload.d.ts.map +1 -1
- package/dist/src/webhooks/WebhookPayload.js +1 -122
- package/dist/src/webhooks/WebhookPayload.js.map +1 -1
- package/dist/src/webhooks/WebhookQueue.d.ts +2 -140
- package/dist/src/webhooks/WebhookQueue.d.ts.map +1 -1
- package/dist/src/webhooks/WebhookQueue.js +4 -11
- package/dist/src/webhooks/WebhookQueue.js.map +1 -1
- package/dist/src/webhooks/WebhookQueue.types.d.ts +149 -0
- package/dist/src/webhooks/WebhookQueue.types.d.ts.map +1 -0
- package/dist/src/webhooks/WebhookQueue.types.js +10 -0
- package/dist/src/webhooks/WebhookQueue.types.js.map +1 -0
- package/dist/src/webhooks/WebhookQueue.utils.d.ts +44 -0
- package/dist/src/webhooks/WebhookQueue.utils.d.ts.map +1 -0
- package/dist/src/webhooks/WebhookQueue.utils.js +58 -0
- package/dist/src/webhooks/WebhookQueue.utils.js.map +1 -0
- package/dist/src/webhooks/webhook-schemas.d.ts +213 -0
- package/dist/src/webhooks/webhook-schemas.d.ts.map +1 -0
- package/dist/src/webhooks/webhook-schemas.js +132 -0
- package/dist/src/webhooks/webhook-schemas.js.map +1 -0
- package/dist/src/webhooks/webhook-types.d.ts +222 -0
- package/dist/src/webhooks/webhook-types.d.ts.map +1 -0
- package/dist/src/webhooks/webhook-types.js +10 -0
- package/dist/src/webhooks/webhook-types.js.map +1 -0
- package/dist/tests/Analytics.integration.test.js +2 -2
- package/dist/tests/Analytics.integration.test.js.map +1 -1
- package/dist/tests/AnalyticsRepository.test.js +3 -5
- package/dist/tests/AnalyticsRepository.test.js.map +1 -1
- package/dist/tests/AnalyticsStorage.test.js.map +1 -1
- package/dist/tests/ApiPartialResponses.test.d.ts +12 -0
- package/dist/tests/ApiPartialResponses.test.d.ts.map +1 -0
- package/dist/tests/ApiPartialResponses.test.js +202 -0
- package/dist/tests/ApiPartialResponses.test.js.map +1 -0
- package/dist/tests/AuditLogger.test.js.map +1 -1
- package/dist/tests/BenchmarkRunner.test.js +6 -6
- package/dist/tests/BenchmarkRunner.test.js.map +1 -1
- package/dist/tests/CacheSecurity.test.js.map +1 -1
- package/dist/tests/CodebaseAnalyzer.test.js.map +1 -1
- package/dist/tests/DailyIndexPipeline.test.js.map +1 -1
- package/dist/tests/EmbeddingService.test.js.map +1 -1
- package/dist/tests/GitHubIndexer.test.js +4 -3
- package/dist/tests/GitHubIndexer.test.js.map +1 -1
- package/dist/tests/MemoryProfiler.test.js +3 -3
- package/dist/tests/MemoryProfiler.test.js.map +1 -1
- package/dist/tests/QualityScorer.test.js.map +1 -1
- package/dist/tests/RateLimiter.test.js.map +1 -1
- package/dist/tests/ScraperAdapters.test.js.map +1 -1
- package/dist/tests/SecurityScanner.test.js +4 -4
- package/dist/tests/SecurityScanner.test.js.map +1 -1
- package/dist/tests/SessionManager.security.test.js +1 -1
- package/dist/tests/SessionManager.security.test.js.map +1 -1
- package/dist/tests/SessionManager.test.js +4 -4
- package/dist/tests/SessionManager.test.js.map +1 -1
- package/dist/tests/SwarmIndexer.test.js +1 -1
- package/dist/tests/SwarmIndexer.test.js.map +1 -1
- package/dist/tests/TieredCache.test.js +2 -11
- package/dist/tests/TieredCache.test.js.map +1 -1
- package/dist/tests/WebhookHandler.test.js.map +1 -1
- package/dist/tests/fixtures/api-responses/index.d.ts +119 -0
- package/dist/tests/fixtures/api-responses/index.d.ts.map +1 -0
- package/dist/tests/fixtures/api-responses/index.js +419 -0
- package/dist/tests/fixtures/api-responses/index.js.map +1 -0
- package/dist/tests/integration/neural/neural-fixtures.d.ts +19 -0
- package/dist/tests/integration/neural/neural-fixtures.d.ts.map +1 -0
- package/dist/tests/integration/neural/neural-fixtures.js +49 -0
- package/dist/tests/integration/neural/neural-fixtures.js.map +1 -0
- package/dist/tests/integration/neural/neural-mocks-privacy.d.ts +78 -0
- package/dist/tests/integration/neural/neural-mocks-privacy.d.ts.map +1 -0
- package/dist/tests/integration/neural/neural-mocks-privacy.js +146 -0
- package/dist/tests/integration/neural/neural-mocks-privacy.js.map +1 -0
- package/dist/tests/integration/neural/neural-mocks.d.ts +90 -0
- package/dist/tests/integration/neural/neural-mocks.d.ts.map +1 -0
- package/dist/tests/integration/neural/neural-mocks.js +288 -0
- package/dist/tests/integration/neural/neural-mocks.js.map +1 -0
- package/dist/tests/integration/neural/neural-test-utils.d.ts +27 -0
- package/dist/tests/integration/neural/neural-test-utils.d.ts.map +1 -0
- package/dist/tests/integration/neural/neural-test-utils.js +35 -0
- package/dist/tests/integration/neural/neural-test-utils.js.map +1 -0
- package/dist/tests/integration/neural/setup.d.ts +6 -165
- package/dist/tests/integration/neural/setup.d.ts.map +1 -1
- package/dist/tests/integration/neural/setup.js +9 -477
- package/dist/tests/integration/neural/setup.js.map +1 -1
- package/dist/tests/logger.test.js +1 -1
- package/dist/tests/logger.test.js.map +1 -1
- package/dist/tests/performance/LargeScalePerformance.test.js +1 -1
- package/dist/tests/performance/LargeScalePerformance.test.js.map +1 -1
- package/dist/tests/sanitization.test.js.map +1 -1
- package/dist/tests/session/SessionManager.helpers.test.d.ts +8 -0
- package/dist/tests/session/SessionManager.helpers.test.d.ts.map +1 -0
- package/dist/tests/session/SessionManager.helpers.test.js +105 -0
- package/dist/tests/session/SessionManager.helpers.test.js.map +1 -0
- package/dist/tests/sources.test.js.map +1 -1
- package/dist/tests/webhooks/WebhookHandler.idempotency.test.js +1 -1
- package/dist/tests/webhooks/WebhookHandler.idempotency.test.js.map +1 -1
- package/dist/tests/webhooks/WebhookPayload.security.test.js.map +1 -1
- package/package.json +11 -11
|
@@ -0,0 +1,419 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* API Response Mocks for Testing
|
|
3
|
+
*
|
|
4
|
+
* SMI-1583: Partial and edge-case API response fixtures for comprehensive testing.
|
|
5
|
+
*
|
|
6
|
+
* IMPORTANT: These mocks match the actual API types from packages/core/src/api/types.ts
|
|
7
|
+
*
|
|
8
|
+
* These mocks cover:
|
|
9
|
+
* - Successful responses
|
|
10
|
+
* - Partial/incomplete data
|
|
11
|
+
* - Error responses
|
|
12
|
+
* - Rate limiting scenarios
|
|
13
|
+
* - Edge cases (empty results, pagination, etc.)
|
|
14
|
+
*/
|
|
15
|
+
// ============================================================================
|
|
16
|
+
// Successful Responses
|
|
17
|
+
// ============================================================================
|
|
18
|
+
export const MOCK_SKILL = {
|
|
19
|
+
id: 'test-author/test-skill',
|
|
20
|
+
name: 'test-skill',
|
|
21
|
+
description: 'A test skill for unit testing purposes',
|
|
22
|
+
author: 'test-author',
|
|
23
|
+
repo_url: 'https://github.com/test-author/test-skill',
|
|
24
|
+
quality_score: 0.85,
|
|
25
|
+
trust_tier: 'community',
|
|
26
|
+
tags: ['testing', 'mock', 'fixture'],
|
|
27
|
+
stars: 100,
|
|
28
|
+
created_at: '2025-01-01T00:00:00Z',
|
|
29
|
+
updated_at: '2025-01-15T00:00:00Z',
|
|
30
|
+
categories: ['Development'],
|
|
31
|
+
};
|
|
32
|
+
export const MOCK_SEARCH_RESULT = {
|
|
33
|
+
...MOCK_SKILL,
|
|
34
|
+
rank: 1,
|
|
35
|
+
};
|
|
36
|
+
export const MOCK_SEARCH_META = {
|
|
37
|
+
query: 'test',
|
|
38
|
+
total: 1,
|
|
39
|
+
limit: 20,
|
|
40
|
+
offset: 0,
|
|
41
|
+
filters: {
|
|
42
|
+
category: null,
|
|
43
|
+
trust_tier: null,
|
|
44
|
+
min_score: null,
|
|
45
|
+
},
|
|
46
|
+
};
|
|
47
|
+
export const MOCK_SEARCH_SUCCESS = {
|
|
48
|
+
status: 200,
|
|
49
|
+
headers: {
|
|
50
|
+
'content-type': 'application/json',
|
|
51
|
+
'x-ratelimit-limit': '100',
|
|
52
|
+
'x-ratelimit-remaining': '99',
|
|
53
|
+
'x-ratelimit-reset': String(Date.now() + 60000),
|
|
54
|
+
},
|
|
55
|
+
body: {
|
|
56
|
+
data: [MOCK_SEARCH_RESULT],
|
|
57
|
+
meta: MOCK_SEARCH_META,
|
|
58
|
+
},
|
|
59
|
+
};
|
|
60
|
+
export const MOCK_RECOMMENDED_SKILL = {
|
|
61
|
+
...MOCK_SKILL,
|
|
62
|
+
relevance_score: 0.95,
|
|
63
|
+
};
|
|
64
|
+
export const MOCK_RECOMMEND_META = {
|
|
65
|
+
stack: ['typescript', 'react'],
|
|
66
|
+
project_type: 'web',
|
|
67
|
+
total: 1,
|
|
68
|
+
limit: 10,
|
|
69
|
+
};
|
|
70
|
+
export const MOCK_RECOMMEND_SUCCESS = {
|
|
71
|
+
status: 200,
|
|
72
|
+
headers: {
|
|
73
|
+
'content-type': 'application/json',
|
|
74
|
+
},
|
|
75
|
+
body: {
|
|
76
|
+
data: [MOCK_RECOMMENDED_SKILL],
|
|
77
|
+
meta: MOCK_RECOMMEND_META,
|
|
78
|
+
},
|
|
79
|
+
};
|
|
80
|
+
export const MOCK_SKILL_RESPONSE = {
|
|
81
|
+
status: 200,
|
|
82
|
+
headers: {
|
|
83
|
+
'content-type': 'application/json',
|
|
84
|
+
},
|
|
85
|
+
body: {
|
|
86
|
+
data: MOCK_SKILL,
|
|
87
|
+
},
|
|
88
|
+
};
|
|
89
|
+
export const MOCK_HEALTH_SUCCESS = {
|
|
90
|
+
status: 200,
|
|
91
|
+
headers: {
|
|
92
|
+
'content-type': 'application/json',
|
|
93
|
+
},
|
|
94
|
+
body: {
|
|
95
|
+
status: 'healthy',
|
|
96
|
+
version: '1.0.0',
|
|
97
|
+
timestamp: new Date().toISOString(),
|
|
98
|
+
},
|
|
99
|
+
};
|
|
100
|
+
// ============================================================================
|
|
101
|
+
// Partial/Incomplete Responses
|
|
102
|
+
// ============================================================================
|
|
103
|
+
/**
|
|
104
|
+
* Skill with minimal fields (edge case for optional field handling)
|
|
105
|
+
*/
|
|
106
|
+
export const MOCK_SKILL_MINIMAL = {
|
|
107
|
+
id: 'minimal/skill',
|
|
108
|
+
name: 'minimal-skill',
|
|
109
|
+
description: null,
|
|
110
|
+
author: null,
|
|
111
|
+
repo_url: null,
|
|
112
|
+
quality_score: null,
|
|
113
|
+
trust_tier: 'experimental',
|
|
114
|
+
tags: [],
|
|
115
|
+
stars: null,
|
|
116
|
+
created_at: '2025-01-01T00:00:00Z',
|
|
117
|
+
updated_at: '2025-01-01T00:00:00Z',
|
|
118
|
+
};
|
|
119
|
+
/**
|
|
120
|
+
* Search response with empty results
|
|
121
|
+
*/
|
|
122
|
+
export const MOCK_SEARCH_EMPTY = {
|
|
123
|
+
status: 200,
|
|
124
|
+
headers: {
|
|
125
|
+
'content-type': 'application/json',
|
|
126
|
+
},
|
|
127
|
+
body: {
|
|
128
|
+
data: [],
|
|
129
|
+
meta: {
|
|
130
|
+
query: 'nonexistent-skill-xyz',
|
|
131
|
+
total: 0,
|
|
132
|
+
limit: 20,
|
|
133
|
+
offset: 0,
|
|
134
|
+
filters: {
|
|
135
|
+
category: null,
|
|
136
|
+
trust_tier: null,
|
|
137
|
+
min_score: null,
|
|
138
|
+
},
|
|
139
|
+
},
|
|
140
|
+
},
|
|
141
|
+
};
|
|
142
|
+
/**
|
|
143
|
+
* Search response with partial skill data (missing optional fields)
|
|
144
|
+
*/
|
|
145
|
+
export const MOCK_SEARCH_PARTIAL = {
|
|
146
|
+
status: 200,
|
|
147
|
+
headers: {
|
|
148
|
+
'content-type': 'application/json',
|
|
149
|
+
},
|
|
150
|
+
body: {
|
|
151
|
+
data: [{ ...MOCK_SKILL_MINIMAL, rank: 1 }],
|
|
152
|
+
meta: {
|
|
153
|
+
query: 'minimal',
|
|
154
|
+
total: 1,
|
|
155
|
+
limit: 20,
|
|
156
|
+
offset: 0,
|
|
157
|
+
filters: {
|
|
158
|
+
category: null,
|
|
159
|
+
trust_tier: null,
|
|
160
|
+
min_score: null,
|
|
161
|
+
},
|
|
162
|
+
},
|
|
163
|
+
},
|
|
164
|
+
};
|
|
165
|
+
/**
|
|
166
|
+
* Recommend response with no recommendations
|
|
167
|
+
*/
|
|
168
|
+
export const MOCK_RECOMMEND_EMPTY = {
|
|
169
|
+
status: 200,
|
|
170
|
+
headers: {
|
|
171
|
+
'content-type': 'application/json',
|
|
172
|
+
},
|
|
173
|
+
body: {
|
|
174
|
+
data: [],
|
|
175
|
+
meta: {
|
|
176
|
+
stack: ['obscure-tech'],
|
|
177
|
+
project_type: null,
|
|
178
|
+
total: 0,
|
|
179
|
+
limit: 10,
|
|
180
|
+
},
|
|
181
|
+
},
|
|
182
|
+
};
|
|
183
|
+
/**
|
|
184
|
+
* Paginated response (offset 20 of 50 total)
|
|
185
|
+
*/
|
|
186
|
+
export const MOCK_SEARCH_PAGINATED = {
|
|
187
|
+
status: 200,
|
|
188
|
+
headers: {
|
|
189
|
+
'content-type': 'application/json',
|
|
190
|
+
link: '</api/v1/skills/search?offset=0>; rel="first", </api/v1/skills/search?offset=40>; rel="last", </api/v1/skills/search?offset=40>; rel="next", </api/v1/skills/search?offset=0>; rel="prev"',
|
|
191
|
+
},
|
|
192
|
+
body: {
|
|
193
|
+
data: [MOCK_SEARCH_RESULT],
|
|
194
|
+
meta: {
|
|
195
|
+
query: 'development',
|
|
196
|
+
total: 50,
|
|
197
|
+
limit: 20,
|
|
198
|
+
offset: 20,
|
|
199
|
+
filters: {
|
|
200
|
+
category: null,
|
|
201
|
+
trust_tier: 'community',
|
|
202
|
+
min_score: null,
|
|
203
|
+
},
|
|
204
|
+
},
|
|
205
|
+
},
|
|
206
|
+
};
|
|
207
|
+
// ============================================================================
|
|
208
|
+
// Error Responses
|
|
209
|
+
// ============================================================================
|
|
210
|
+
export const MOCK_ERROR_NOT_FOUND = {
|
|
211
|
+
status: 404,
|
|
212
|
+
headers: {
|
|
213
|
+
'content-type': 'application/json',
|
|
214
|
+
},
|
|
215
|
+
body: {
|
|
216
|
+
error: 'Skill not found',
|
|
217
|
+
details: {
|
|
218
|
+
skill_id: 'nonexistent/skill',
|
|
219
|
+
},
|
|
220
|
+
},
|
|
221
|
+
};
|
|
222
|
+
export const MOCK_ERROR_VALIDATION = {
|
|
223
|
+
status: 400,
|
|
224
|
+
headers: {
|
|
225
|
+
'content-type': 'application/json',
|
|
226
|
+
},
|
|
227
|
+
body: {
|
|
228
|
+
error: 'Query must be at least 2 characters',
|
|
229
|
+
details: {
|
|
230
|
+
field: 'query',
|
|
231
|
+
provided: 'x',
|
|
232
|
+
},
|
|
233
|
+
},
|
|
234
|
+
};
|
|
235
|
+
export const MOCK_ERROR_UNAUTHORIZED = {
|
|
236
|
+
status: 401,
|
|
237
|
+
headers: {
|
|
238
|
+
'content-type': 'application/json',
|
|
239
|
+
},
|
|
240
|
+
body: {
|
|
241
|
+
error: 'Invalid or missing API key',
|
|
242
|
+
},
|
|
243
|
+
};
|
|
244
|
+
export const MOCK_ERROR_FORBIDDEN = {
|
|
245
|
+
status: 403,
|
|
246
|
+
headers: {
|
|
247
|
+
'content-type': 'application/json',
|
|
248
|
+
},
|
|
249
|
+
body: {
|
|
250
|
+
error: 'Insufficient permissions for this operation',
|
|
251
|
+
details: {
|
|
252
|
+
required_tier: 'team',
|
|
253
|
+
current_tier: 'community',
|
|
254
|
+
},
|
|
255
|
+
},
|
|
256
|
+
};
|
|
257
|
+
export const MOCK_ERROR_SERVER = {
|
|
258
|
+
status: 500,
|
|
259
|
+
headers: {
|
|
260
|
+
'content-type': 'application/json',
|
|
261
|
+
},
|
|
262
|
+
body: {
|
|
263
|
+
error: 'An unexpected error occurred',
|
|
264
|
+
},
|
|
265
|
+
};
|
|
266
|
+
export const MOCK_ERROR_SERVICE_UNAVAILABLE = {
|
|
267
|
+
status: 503,
|
|
268
|
+
headers: {
|
|
269
|
+
'content-type': 'application/json',
|
|
270
|
+
'retry-after': '30',
|
|
271
|
+
},
|
|
272
|
+
body: {
|
|
273
|
+
error: 'Service temporarily unavailable',
|
|
274
|
+
details: {
|
|
275
|
+
retry_after: 30,
|
|
276
|
+
},
|
|
277
|
+
},
|
|
278
|
+
};
|
|
279
|
+
// ============================================================================
|
|
280
|
+
// Rate Limiting Responses
|
|
281
|
+
// ============================================================================
|
|
282
|
+
export const MOCK_RATE_LIMIT_INFO = {
|
|
283
|
+
limit: 100,
|
|
284
|
+
remaining: 0,
|
|
285
|
+
reset: Date.now() + 60000,
|
|
286
|
+
};
|
|
287
|
+
export const MOCK_ERROR_RATE_LIMITED = {
|
|
288
|
+
status: 429,
|
|
289
|
+
headers: {
|
|
290
|
+
'content-type': 'application/json',
|
|
291
|
+
'x-ratelimit-limit': '100',
|
|
292
|
+
'x-ratelimit-remaining': '0',
|
|
293
|
+
'x-ratelimit-reset': String(Date.now() + 60000),
|
|
294
|
+
'retry-after': '60',
|
|
295
|
+
},
|
|
296
|
+
body: {
|
|
297
|
+
error: 'Too many requests',
|
|
298
|
+
details: {
|
|
299
|
+
limit: 100,
|
|
300
|
+
remaining: 0,
|
|
301
|
+
reset_at: new Date(Date.now() + 60000).toISOString(),
|
|
302
|
+
},
|
|
303
|
+
},
|
|
304
|
+
};
|
|
305
|
+
export const MOCK_RATE_LIMIT_WARNING = {
|
|
306
|
+
status: 200,
|
|
307
|
+
headers: {
|
|
308
|
+
'content-type': 'application/json',
|
|
309
|
+
'x-ratelimit-limit': '100',
|
|
310
|
+
'x-ratelimit-remaining': '5',
|
|
311
|
+
'x-ratelimit-reset': String(Date.now() + 60000),
|
|
312
|
+
},
|
|
313
|
+
body: MOCK_SEARCH_SUCCESS.body,
|
|
314
|
+
};
|
|
315
|
+
// ============================================================================
|
|
316
|
+
// Network/Timeout Scenarios
|
|
317
|
+
// ============================================================================
|
|
318
|
+
/**
|
|
319
|
+
* Simulates a slow response (for timeout testing)
|
|
320
|
+
*/
|
|
321
|
+
export const MOCK_SLOW_RESPONSE_DELAY_MS = 5000;
|
|
322
|
+
/**
|
|
323
|
+
* Simulates a partial response (connection closed mid-stream)
|
|
324
|
+
*/
|
|
325
|
+
export const MOCK_PARTIAL_JSON = '{"data": [{"id": "partial/skill"';
|
|
326
|
+
/**
|
|
327
|
+
* Simulates malformed JSON response
|
|
328
|
+
*/
|
|
329
|
+
export const MOCK_MALFORMED_JSON = '{"data": [invalid json here]}';
|
|
330
|
+
/**
|
|
331
|
+
* Simulates HTML error page (proxy/server misconfiguration)
|
|
332
|
+
*/
|
|
333
|
+
export const MOCK_HTML_ERROR_RESPONSE = `
|
|
334
|
+
<!DOCTYPE html>
|
|
335
|
+
<html>
|
|
336
|
+
<head><title>502 Bad Gateway</title></head>
|
|
337
|
+
<body><h1>502 Bad Gateway</h1></body>
|
|
338
|
+
</html>
|
|
339
|
+
`;
|
|
340
|
+
// ============================================================================
|
|
341
|
+
// Helper Functions
|
|
342
|
+
// ============================================================================
|
|
343
|
+
/**
|
|
344
|
+
* Create a mock fetch Response object
|
|
345
|
+
*/
|
|
346
|
+
export function createMockResponse(mock) {
|
|
347
|
+
const body = typeof mock.body === 'string' ? mock.body : JSON.stringify(mock.body);
|
|
348
|
+
return new Response(body, {
|
|
349
|
+
status: mock.status,
|
|
350
|
+
headers: new Headers(mock.headers),
|
|
351
|
+
});
|
|
352
|
+
}
|
|
353
|
+
/**
|
|
354
|
+
* Create a mock fetch function that returns a specific response
|
|
355
|
+
*/
|
|
356
|
+
export function createMockFetch(mock) {
|
|
357
|
+
return async () => createMockResponse(mock);
|
|
358
|
+
}
|
|
359
|
+
/**
|
|
360
|
+
* Create a mock fetch that fails with a network error
|
|
361
|
+
*/
|
|
362
|
+
export function createNetworkErrorFetch(message = 'Network error') {
|
|
363
|
+
return async () => {
|
|
364
|
+
throw new Error(message);
|
|
365
|
+
};
|
|
366
|
+
}
|
|
367
|
+
/**
|
|
368
|
+
* Create a mock fetch that times out
|
|
369
|
+
*/
|
|
370
|
+
export function createTimeoutFetch(delayMs = MOCK_SLOW_RESPONSE_DELAY_MS) {
|
|
371
|
+
return async () => {
|
|
372
|
+
await new Promise((resolve) => setTimeout(resolve, delayMs));
|
|
373
|
+
return createMockResponse(MOCK_SEARCH_SUCCESS);
|
|
374
|
+
};
|
|
375
|
+
}
|
|
376
|
+
/**
|
|
377
|
+
* Create a mock fetch that returns responses in sequence
|
|
378
|
+
*/
|
|
379
|
+
export function createSequentialFetch(responses) {
|
|
380
|
+
let callIndex = 0;
|
|
381
|
+
return async () => {
|
|
382
|
+
const response = responses[callIndex] || responses[responses.length - 1];
|
|
383
|
+
callIndex++;
|
|
384
|
+
return createMockResponse(response);
|
|
385
|
+
};
|
|
386
|
+
}
|
|
387
|
+
// ============================================================================
|
|
388
|
+
// Export all mocks for easy importing
|
|
389
|
+
// ============================================================================
|
|
390
|
+
export const API_MOCKS = {
|
|
391
|
+
// Success
|
|
392
|
+
searchSuccess: MOCK_SEARCH_SUCCESS,
|
|
393
|
+
recommendSuccess: MOCK_RECOMMEND_SUCCESS,
|
|
394
|
+
skillResponse: MOCK_SKILL_RESPONSE,
|
|
395
|
+
healthSuccess: MOCK_HEALTH_SUCCESS,
|
|
396
|
+
// Partial/Empty
|
|
397
|
+
searchEmpty: MOCK_SEARCH_EMPTY,
|
|
398
|
+
searchPartial: MOCK_SEARCH_PARTIAL,
|
|
399
|
+
searchPaginated: MOCK_SEARCH_PAGINATED,
|
|
400
|
+
recommendEmpty: MOCK_RECOMMEND_EMPTY,
|
|
401
|
+
skillMinimal: MOCK_SKILL_MINIMAL,
|
|
402
|
+
// Errors
|
|
403
|
+
errorNotFound: MOCK_ERROR_NOT_FOUND,
|
|
404
|
+
errorValidation: MOCK_ERROR_VALIDATION,
|
|
405
|
+
errorUnauthorized: MOCK_ERROR_UNAUTHORIZED,
|
|
406
|
+
errorForbidden: MOCK_ERROR_FORBIDDEN,
|
|
407
|
+
errorServer: MOCK_ERROR_SERVER,
|
|
408
|
+
errorServiceUnavailable: MOCK_ERROR_SERVICE_UNAVAILABLE,
|
|
409
|
+
errorRateLimited: MOCK_ERROR_RATE_LIMITED,
|
|
410
|
+
// Rate limiting
|
|
411
|
+
rateLimitWarning: MOCK_RATE_LIMIT_WARNING,
|
|
412
|
+
rateLimitInfo: MOCK_RATE_LIMIT_INFO,
|
|
413
|
+
// Edge cases
|
|
414
|
+
partialJson: MOCK_PARTIAL_JSON,
|
|
415
|
+
malformedJson: MOCK_MALFORMED_JSON,
|
|
416
|
+
htmlError: MOCK_HTML_ERROR_RESPONSE,
|
|
417
|
+
};
|
|
418
|
+
export default API_MOCKS;
|
|
419
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../tests/fixtures/api-responses/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SMI-1535: Neural Test Infrastructure - Fixtures
|
|
3
|
+
*
|
|
4
|
+
* Test fixtures and default profile creation for neural tests.
|
|
5
|
+
*
|
|
6
|
+
* @see packages/core/src/learning/types.ts
|
|
7
|
+
*/
|
|
8
|
+
import { type UserPreferenceProfile } from '../../../src/learning/types.js';
|
|
9
|
+
/**
|
|
10
|
+
* Create a default empty user preference profile
|
|
11
|
+
*
|
|
12
|
+
* Note: COLD_START_WEIGHTS only defines weights for a subset of SkillCategory values
|
|
13
|
+
* (TESTING, GIT, DEVOPS, DOCUMENTATION, FRONTEND, BACKEND). Categories not in
|
|
14
|
+
* COLD_START_WEIGHTS (DATABASE, SECURITY, PRODUCTIVITY, ANALYSIS) will have
|
|
15
|
+
* undefined weights, which is handled gracefully by the learning algorithm
|
|
16
|
+
* by defaulting to 0 when accessing missing keys.
|
|
17
|
+
*/
|
|
18
|
+
export declare function createDefaultProfile(): UserPreferenceProfile;
|
|
19
|
+
//# sourceMappingURL=neural-fixtures.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"neural-fixtures.d.ts","sourceRoot":"","sources":["../../../../tests/integration/neural/neural-fixtures.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EACL,KAAK,qBAAqB,EAG3B,MAAM,gCAAgC,CAAA;AAEvC;;;;;;;;GAQG;AACH,wBAAgB,oBAAoB,IAAI,qBAAqB,CAgC5D"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SMI-1535: Neural Test Infrastructure - Fixtures
|
|
3
|
+
*
|
|
4
|
+
* Test fixtures and default profile creation for neural tests.
|
|
5
|
+
*
|
|
6
|
+
* @see packages/core/src/learning/types.ts
|
|
7
|
+
*/
|
|
8
|
+
import { SkillCategory, COLD_START_WEIGHTS, } from '../../../src/learning/types.js';
|
|
9
|
+
/**
|
|
10
|
+
* Create a default empty user preference profile
|
|
11
|
+
*
|
|
12
|
+
* Note: COLD_START_WEIGHTS only defines weights for a subset of SkillCategory values
|
|
13
|
+
* (TESTING, GIT, DEVOPS, DOCUMENTATION, FRONTEND, BACKEND). Categories not in
|
|
14
|
+
* COLD_START_WEIGHTS (DATABASE, SECURITY, PRODUCTIVITY, ANALYSIS) will have
|
|
15
|
+
* undefined weights, which is handled gracefully by the learning algorithm
|
|
16
|
+
* by defaulting to 0 when accessing missing keys.
|
|
17
|
+
*/
|
|
18
|
+
export function createDefaultProfile() {
|
|
19
|
+
// Start with cold start weights and ensure all categories have explicit defaults
|
|
20
|
+
const categoryWeights = {
|
|
21
|
+
...COLD_START_WEIGHTS.category_weights,
|
|
22
|
+
};
|
|
23
|
+
// Add missing categories with neutral (0) weights for completeness
|
|
24
|
+
const allCategories = Object.values(SkillCategory);
|
|
25
|
+
for (const category of allCategories) {
|
|
26
|
+
if (categoryWeights[category] === undefined) {
|
|
27
|
+
categoryWeights[category] = 0;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
return {
|
|
31
|
+
version: 1,
|
|
32
|
+
last_updated: Date.now(),
|
|
33
|
+
signal_count: 0,
|
|
34
|
+
category_weights: categoryWeights,
|
|
35
|
+
trust_tier_weights: { ...COLD_START_WEIGHTS.trust_tier_weights },
|
|
36
|
+
keyword_weights: {},
|
|
37
|
+
negative_patterns: {
|
|
38
|
+
keywords: [],
|
|
39
|
+
categories: [],
|
|
40
|
+
skill_ids: [],
|
|
41
|
+
},
|
|
42
|
+
usage_patterns: {
|
|
43
|
+
avg_time_to_first_use_ms: 0,
|
|
44
|
+
utilization_rate: 0,
|
|
45
|
+
top_categories: [],
|
|
46
|
+
},
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=neural-fixtures.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"neural-fixtures.js","sourceRoot":"","sources":["../../../../tests/integration/neural/neural-fixtures.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAEL,aAAa,EACb,kBAAkB,GACnB,MAAM,gCAAgC,CAAA;AAEvC;;;;;;;;GAQG;AACH,MAAM,UAAU,oBAAoB;IAClC,iFAAiF;IACjF,MAAM,eAAe,GAA2C;QAC9D,GAAG,kBAAkB,CAAC,gBAAgB;KACvC,CAAA;IAED,mEAAmE;IACnE,MAAM,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,CAAA;IAClD,KAAK,MAAM,QAAQ,IAAI,aAAa,EAAE,CAAC;QACrC,IAAI,eAAe,CAAC,QAAQ,CAAC,KAAK,SAAS,EAAE,CAAC;YAC5C,eAAe,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAA;QAC/B,CAAC;IACH,CAAC;IAED,OAAO;QACL,OAAO,EAAE,CAAC;QACV,YAAY,EAAE,IAAI,CAAC,GAAG,EAAE;QACxB,YAAY,EAAE,CAAC;QACf,gBAAgB,EAAE,eAAe;QACjC,kBAAkB,EAAE,EAAE,GAAG,kBAAkB,CAAC,kBAAkB,EAAE;QAChE,eAAe,EAAE,EAAE;QACnB,iBAAiB,EAAE;YACjB,QAAQ,EAAE,EAAE;YACZ,UAAU,EAAE,EAAE;YACd,SAAS,EAAE,EAAE;SACd;QACD,cAAc,EAAE;YACd,wBAAwB,EAAE,CAAC;YAC3B,gBAAgB,EAAE,CAAC;YACnB,cAAc,EAAE,EAAE;SACnB;KACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SMI-1535: Neural Test Infrastructure - Privacy and Repository Mocks
|
|
3
|
+
*
|
|
4
|
+
* Mock implementations of privacy manager and user preference repository.
|
|
5
|
+
*
|
|
6
|
+
* @see packages/core/src/learning/interfaces.js
|
|
7
|
+
* @see packages/core/src/learning/types.js
|
|
8
|
+
*/
|
|
9
|
+
import type { IPrivacyManager, IUserPreferenceRepository } from '../../../src/learning/interfaces.js';
|
|
10
|
+
import { type SignalEvent, type UserPreferenceProfile, type UserDataExport, type AggregateStats } from '../../../src/learning/types.js';
|
|
11
|
+
/**
|
|
12
|
+
* Interface for signal collector methods used by MockPrivacyManager
|
|
13
|
+
*/
|
|
14
|
+
interface ISignalCollectorForPrivacy {
|
|
15
|
+
removeOldSignals(cutoffTimestamp: number): number;
|
|
16
|
+
getAllSignals(): SignalEvent[];
|
|
17
|
+
getSignalCount(): Promise<number>;
|
|
18
|
+
clear(): void;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Mock implementation of IPrivacyManager for testing
|
|
22
|
+
*/
|
|
23
|
+
export declare class MockPrivacyManager implements IPrivacyManager {
|
|
24
|
+
private signalCollector;
|
|
25
|
+
private profileRepo;
|
|
26
|
+
private auditLog;
|
|
27
|
+
constructor(signalCollector: ISignalCollectorForPrivacy, profileRepo: MockUserPreferenceRepository);
|
|
28
|
+
purgeOldSignals(retentionDays: number): Promise<number>;
|
|
29
|
+
exportUserData(): Promise<UserDataExport>;
|
|
30
|
+
wipeAllData(): Promise<number>;
|
|
31
|
+
anonymizeForAnalytics(): Promise<AggregateStats>;
|
|
32
|
+
getStorageSize(): Promise<number>;
|
|
33
|
+
/**
|
|
34
|
+
* Verify that no PII (Personally Identifiable Information) is stored.
|
|
35
|
+
*
|
|
36
|
+
* Mock Implementation Details
|
|
37
|
+
* ---------------------------
|
|
38
|
+
* This mock always returns true because the test environment uses
|
|
39
|
+
* controlled, synthetic data that never contains real PII.
|
|
40
|
+
*
|
|
41
|
+
* A real implementation should:
|
|
42
|
+
* 1. Scan signal events for PII patterns (emails, names, IPs, etc.)
|
|
43
|
+
* 2. Check that skill_id values don't contain user identifiers
|
|
44
|
+
* 3. Verify context fields don't leak sensitive project paths
|
|
45
|
+
* 4. Ensure keyword_weights don't contain personal identifiers
|
|
46
|
+
* 5. Validate that exported data is properly anonymized
|
|
47
|
+
*
|
|
48
|
+
* The mock skips these checks since test data is constructed with
|
|
49
|
+
* known-safe values (UUIDs, generic skill names, etc.).
|
|
50
|
+
*
|
|
51
|
+
* @returns Promise<boolean> - Always true in mock (no real PII checks)
|
|
52
|
+
*/
|
|
53
|
+
verifyPrivacy(): Promise<boolean>;
|
|
54
|
+
getAuditLog(): Array<{
|
|
55
|
+
operation: string;
|
|
56
|
+
timestamp: number;
|
|
57
|
+
details?: string;
|
|
58
|
+
}>;
|
|
59
|
+
/**
|
|
60
|
+
* Clear the audit log.
|
|
61
|
+
* Used in test cleanup to reset state between tests.
|
|
62
|
+
*/
|
|
63
|
+
clearAuditLog(): void;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Mock implementation of IUserPreferenceRepository for testing
|
|
67
|
+
*/
|
|
68
|
+
export declare class MockUserPreferenceRepository implements IUserPreferenceRepository {
|
|
69
|
+
private profiles;
|
|
70
|
+
private readonly defaultUserId;
|
|
71
|
+
getProfile(userId?: string): Promise<UserPreferenceProfile | null>;
|
|
72
|
+
saveProfile(profile: UserPreferenceProfile, userId?: string): Promise<void>;
|
|
73
|
+
deleteProfile(userId?: string): Promise<void>;
|
|
74
|
+
exists(userId?: string): Promise<boolean>;
|
|
75
|
+
clear(): void;
|
|
76
|
+
}
|
|
77
|
+
export {};
|
|
78
|
+
//# sourceMappingURL=neural-mocks-privacy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"neural-mocks-privacy.d.ts","sourceRoot":"","sources":["../../../../tests/integration/neural/neural-mocks-privacy.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EACV,eAAe,EACf,yBAAyB,EAC1B,MAAM,qCAAqC,CAAA;AAC5C,OAAO,EACL,KAAK,WAAW,EAChB,KAAK,qBAAqB,EAC1B,KAAK,cAAc,EACnB,KAAK,cAAc,EAGpB,MAAM,gCAAgC,CAAA;AAGvC;;GAEG;AACH,UAAU,0BAA0B;IAClC,gBAAgB,CAAC,eAAe,EAAE,MAAM,GAAG,MAAM,CAAA;IACjD,aAAa,IAAI,WAAW,EAAE,CAAA;IAC9B,cAAc,IAAI,OAAO,CAAC,MAAM,CAAC,CAAA;IACjC,KAAK,IAAI,IAAI,CAAA;CACd;AAED;;GAEG;AACH,qBAAa,kBAAmB,YAAW,eAAe;IAItD,OAAO,CAAC,eAAe;IACvB,OAAO,CAAC,WAAW;IAJrB,OAAO,CAAC,QAAQ,CAAwE;gBAG9E,eAAe,EAAE,0BAA0B,EAC3C,WAAW,EAAE,4BAA4B;IAG7C,eAAe,CAAC,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAWvD,cAAc,IAAI,OAAO,CAAC,cAAc,CAAC;IAkBzC,WAAW,IAAI,OAAO,CAAC,MAAM,CAAC;IAc9B,qBAAqB,IAAI,OAAO,CAAC,cAAc,CAAC;IA+BhD,cAAc,IAAI,OAAO,CAAC,MAAM,CAAC;IAKvC;;;;;;;;;;;;;;;;;;;OAmBG;IACG,aAAa,IAAI,OAAO,CAAC,OAAO,CAAC;IAKvC,WAAW,IAAI,KAAK,CAAC;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IAIhF;;;OAGG;IACH,aAAa,IAAI,IAAI;CAGtB;AAED;;GAEG;AACH,qBAAa,4BAA6B,YAAW,yBAAyB;IAC5E,OAAO,CAAC,QAAQ,CAA2C;IAC3D,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAY;IAEpC,UAAU,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,GAAG,IAAI,CAAC;IAIlE,WAAW,CAAC,OAAO,EAAE,qBAAqB,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI3E,aAAa,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI7C,MAAM,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAK/C,KAAK,IAAI,IAAI;CAGd"}
|