@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.
Files changed (612) hide show
  1. package/dist/.tsbuildinfo +1 -1
  2. package/dist/src/analysis/CodebaseAnalyzer.d.ts.map +1 -1
  3. package/dist/src/analysis/CodebaseAnalyzer.js.map +1 -1
  4. package/dist/src/analysis/adapters/__tests__/python.test.js.map +1 -1
  5. package/dist/src/analysis/adapters/java-parsers.d.ts +64 -0
  6. package/dist/src/analysis/adapters/java-parsers.d.ts.map +1 -0
  7. package/dist/src/analysis/adapters/java-parsers.js +114 -0
  8. package/dist/src/analysis/adapters/java-parsers.js.map +1 -0
  9. package/dist/src/analysis/adapters/java.d.ts +1 -51
  10. package/dist/src/analysis/adapters/java.d.ts.map +1 -1
  11. package/dist/src/analysis/adapters/java.js +94 -205
  12. package/dist/src/analysis/adapters/java.js.map +1 -1
  13. package/dist/src/analysis/adapters/python-frameworks.d.ts +21 -0
  14. package/dist/src/analysis/adapters/python-frameworks.d.ts.map +1 -0
  15. package/dist/src/analysis/adapters/python-frameworks.js +86 -0
  16. package/dist/src/analysis/adapters/python-frameworks.js.map +1 -0
  17. package/dist/src/analysis/adapters/python.d.ts +0 -50
  18. package/dist/src/analysis/adapters/python.d.ts.map +1 -1
  19. package/dist/src/analysis/adapters/python.js +5 -120
  20. package/dist/src/analysis/adapters/python.js.map +1 -1
  21. package/dist/src/analysis/adapters/rust-parsers.d.ts +33 -0
  22. package/dist/src/analysis/adapters/rust-parsers.d.ts.map +1 -0
  23. package/dist/src/analysis/adapters/rust-parsers.js +94 -0
  24. package/dist/src/analysis/adapters/rust-parsers.js.map +1 -0
  25. package/dist/src/analysis/adapters/rust.d.ts +1 -43
  26. package/dist/src/analysis/adapters/rust.d.ts.map +1 -1
  27. package/dist/src/analysis/adapters/rust.js +74 -173
  28. package/dist/src/analysis/adapters/rust.js.map +1 -1
  29. package/dist/src/analysis/language-detector.d.ts +4 -20
  30. package/dist/src/analysis/language-detector.d.ts.map +1 -1
  31. package/dist/src/analysis/language-detector.js +2 -399
  32. package/dist/src/analysis/language-detector.js.map +1 -1
  33. package/dist/src/analysis/language-detector.patterns.d.ts +17 -0
  34. package/dist/src/analysis/language-detector.patterns.d.ts.map +1 -0
  35. package/dist/src/analysis/language-detector.patterns.js +413 -0
  36. package/dist/src/analysis/language-detector.patterns.js.map +1 -0
  37. package/dist/src/analysis/language-detector.types.d.ts +48 -0
  38. package/dist/src/analysis/language-detector.types.d.ts.map +1 -0
  39. package/dist/src/analysis/language-detector.types.js +6 -0
  40. package/dist/src/analysis/language-detector.types.js.map +1 -0
  41. package/dist/src/analysis/metrics.d.ts +22 -219
  42. package/dist/src/analysis/metrics.d.ts.map +1 -1
  43. package/dist/src/analysis/metrics.implementations.d.ts +39 -0
  44. package/dist/src/analysis/metrics.implementations.d.ts.map +1 -0
  45. package/dist/src/analysis/metrics.implementations.js +114 -0
  46. package/dist/src/analysis/metrics.implementations.js.map +1 -0
  47. package/dist/src/analysis/metrics.js +21 -224
  48. package/dist/src/analysis/metrics.js.map +1 -1
  49. package/dist/src/analysis/metrics.types.d.ts +79 -0
  50. package/dist/src/analysis/metrics.types.d.ts.map +1 -0
  51. package/dist/src/analysis/metrics.types.js +6 -0
  52. package/dist/src/analysis/metrics.types.js.map +1 -0
  53. package/dist/src/analysis/worker-pool.d.ts +25 -52
  54. package/dist/src/analysis/worker-pool.d.ts.map +1 -1
  55. package/dist/src/analysis/worker-pool.js +29 -181
  56. package/dist/src/analysis/worker-pool.js.map +1 -1
  57. package/dist/src/analysis/worker-types.d.ts +64 -0
  58. package/dist/src/analysis/worker-types.d.ts.map +1 -0
  59. package/dist/src/analysis/worker-types.js +11 -0
  60. package/dist/src/analysis/worker-types.js.map +1 -0
  61. package/dist/src/analysis/worker-utils.d.ts +49 -0
  62. package/dist/src/analysis/worker-utils.d.ts.map +1 -0
  63. package/dist/src/analysis/worker-utils.js +206 -0
  64. package/dist/src/analysis/worker-utils.js.map +1 -0
  65. package/dist/src/analytics/AnalyticsRepository.d.ts +1 -5
  66. package/dist/src/analytics/AnalyticsRepository.d.ts.map +1 -1
  67. package/dist/src/analytics/AnalyticsRepository.helpers.d.ts +28 -0
  68. package/dist/src/analytics/AnalyticsRepository.helpers.d.ts.map +1 -0
  69. package/dist/src/analytics/AnalyticsRepository.helpers.js +90 -0
  70. package/dist/src/analytics/AnalyticsRepository.helpers.js.map +1 -0
  71. package/dist/src/analytics/AnalyticsRepository.js +16 -129
  72. package/dist/src/analytics/AnalyticsRepository.js.map +1 -1
  73. package/dist/src/analytics/AnalyticsRepository.types.d.ts +82 -0
  74. package/dist/src/analytics/AnalyticsRepository.types.d.ts.map +1 -0
  75. package/dist/src/analytics/AnalyticsRepository.types.js +8 -0
  76. package/dist/src/analytics/AnalyticsRepository.types.js.map +1 -0
  77. package/dist/src/analytics/ROIDashboardService.js +4 -2
  78. package/dist/src/analytics/ROIDashboardService.js.map +1 -1
  79. package/dist/src/api/cache.d.ts.map +1 -1
  80. package/dist/src/api/cache.js.map +1 -1
  81. package/dist/src/api/client.d.ts +6 -121
  82. package/dist/src/api/client.d.ts.map +1 -1
  83. package/dist/src/api/client.js +29 -129
  84. package/dist/src/api/client.js.map +1 -1
  85. package/dist/src/api/schemas.d.ts +122 -0
  86. package/dist/src/api/schemas.d.ts.map +1 -0
  87. package/dist/src/api/schemas.js +71 -0
  88. package/dist/src/api/schemas.js.map +1 -0
  89. package/dist/src/api/types.d.ts +1 -1
  90. package/dist/src/api/types.d.ts.map +1 -1
  91. package/dist/src/api/utils.d.ts +35 -0
  92. package/dist/src/api/utils.d.ts.map +1 -0
  93. package/dist/src/api/utils.js +86 -0
  94. package/dist/src/api/utils.js.map +1 -0
  95. package/dist/src/benchmarks/BenchmarkRunner.d.ts.map +1 -1
  96. package/dist/src/benchmarks/BenchmarkRunner.js +1 -1
  97. package/dist/src/benchmarks/BenchmarkRunner.js.map +1 -1
  98. package/dist/src/billing/BillingService.d.ts +15 -53
  99. package/dist/src/billing/BillingService.d.ts.map +1 -1
  100. package/dist/src/billing/BillingService.helpers.d.ts +15 -0
  101. package/dist/src/billing/BillingService.helpers.d.ts.map +1 -0
  102. package/dist/src/billing/BillingService.helpers.js +45 -0
  103. package/dist/src/billing/BillingService.helpers.js.map +1 -0
  104. package/dist/src/billing/BillingService.js +49 -179
  105. package/dist/src/billing/BillingService.js.map +1 -1
  106. package/dist/src/billing/BillingService.types.d.ts +52 -0
  107. package/dist/src/billing/BillingService.types.d.ts.map +1 -0
  108. package/dist/src/billing/BillingService.types.js +6 -0
  109. package/dist/src/billing/BillingService.types.js.map +1 -0
  110. package/dist/src/billing/GDPRComplianceService.d.ts +2 -97
  111. package/dist/src/billing/GDPRComplianceService.d.ts.map +1 -1
  112. package/dist/src/billing/GDPRComplianceService.js.map +1 -1
  113. package/dist/src/billing/StripeClient.d.ts +6 -64
  114. package/dist/src/billing/StripeClient.d.ts.map +1 -1
  115. package/dist/src/billing/StripeClient.js +14 -71
  116. package/dist/src/billing/StripeClient.js.map +1 -1
  117. package/dist/src/billing/StripeReconciliationJob.d.ts +2 -47
  118. package/dist/src/billing/StripeReconciliationJob.d.ts.map +1 -1
  119. package/dist/src/billing/StripeReconciliationJob.js +1 -41
  120. package/dist/src/billing/StripeReconciliationJob.js.map +1 -1
  121. package/dist/src/billing/StripeWebhookHandler.d.ts +3 -46
  122. package/dist/src/billing/StripeWebhookHandler.d.ts.map +1 -1
  123. package/dist/src/billing/StripeWebhookHandler.js +14 -261
  124. package/dist/src/billing/StripeWebhookHandler.js.map +1 -1
  125. package/dist/src/billing/gdpr-types.d.ts +103 -0
  126. package/dist/src/billing/gdpr-types.d.ts.map +1 -0
  127. package/dist/src/billing/gdpr-types.js +7 -0
  128. package/dist/src/billing/gdpr-types.js.map +1 -0
  129. package/dist/src/billing/reconciliation-helpers.d.ts +16 -0
  130. package/dist/src/billing/reconciliation-helpers.d.ts.map +1 -0
  131. package/dist/src/billing/reconciliation-helpers.js +53 -0
  132. package/dist/src/billing/reconciliation-helpers.js.map +1 -0
  133. package/dist/src/billing/reconciliation-types.d.ts +71 -0
  134. package/dist/src/billing/reconciliation-types.d.ts.map +1 -0
  135. package/dist/src/billing/reconciliation-types.js +7 -0
  136. package/dist/src/billing/reconciliation-types.js.map +1 -0
  137. package/dist/src/billing/stripe-client-types.d.ts +45 -0
  138. package/dist/src/billing/stripe-client-types.d.ts.map +1 -0
  139. package/dist/src/billing/stripe-client-types.js +7 -0
  140. package/dist/src/billing/stripe-client-types.js.map +1 -0
  141. package/dist/src/billing/stripe-helpers.d.ts +17 -0
  142. package/dist/src/billing/stripe-helpers.d.ts.map +1 -0
  143. package/dist/src/billing/stripe-helpers.js +50 -0
  144. package/dist/src/billing/stripe-helpers.js.map +1 -0
  145. package/dist/src/billing/webhook-handlers.d.ts +56 -0
  146. package/dist/src/billing/webhook-handlers.d.ts.map +1 -0
  147. package/dist/src/billing/webhook-handlers.js +303 -0
  148. package/dist/src/billing/webhook-handlers.js.map +1 -0
  149. package/dist/src/billing/webhook-types.d.ts +42 -0
  150. package/dist/src/billing/webhook-types.d.ts.map +1 -0
  151. package/dist/src/billing/webhook-types.js +7 -0
  152. package/dist/src/billing/webhook-types.js.map +1 -0
  153. package/dist/src/config/index.d.ts +118 -0
  154. package/dist/src/config/index.d.ts.map +1 -0
  155. package/dist/src/config/index.js +172 -0
  156. package/dist/src/config/index.js.map +1 -0
  157. package/dist/src/db/migration-types.d.ts +101 -0
  158. package/dist/src/db/migration-types.d.ts.map +1 -0
  159. package/dist/src/db/migration-types.js +6 -0
  160. package/dist/src/db/migration-types.js.map +1 -0
  161. package/dist/src/db/migration.d.ts +32 -0
  162. package/dist/src/db/migration.d.ts.map +1 -0
  163. package/dist/src/db/migration.js +239 -0
  164. package/dist/src/db/migration.js.map +1 -0
  165. package/dist/src/db/schema.d.ts +2 -2
  166. package/dist/src/db/schema.d.ts.map +1 -1
  167. package/dist/src/db/schema.js +23 -1
  168. package/dist/src/db/schema.js.map +1 -1
  169. package/dist/src/embeddings/embedding-types.d.ts +44 -0
  170. package/dist/src/embeddings/embedding-types.d.ts.map +1 -0
  171. package/dist/src/embeddings/embedding-types.js +6 -0
  172. package/dist/src/embeddings/embedding-types.js.map +1 -0
  173. package/dist/src/embeddings/embedding-utils.d.ts +42 -0
  174. package/dist/src/embeddings/embedding-utils.d.ts.map +1 -0
  175. package/dist/src/embeddings/embedding-utils.js +121 -0
  176. package/dist/src/embeddings/embedding-utils.js.map +1 -0
  177. package/dist/src/embeddings/hnsw-store.d.ts +8 -518
  178. package/dist/src/embeddings/hnsw-store.d.ts.map +1 -1
  179. package/dist/src/embeddings/hnsw-store.helpers.d.ts +83 -0
  180. package/dist/src/embeddings/hnsw-store.helpers.d.ts.map +1 -0
  181. package/dist/src/embeddings/hnsw-store.helpers.js +147 -0
  182. package/dist/src/embeddings/hnsw-store.helpers.js.map +1 -0
  183. package/dist/src/embeddings/hnsw-store.js +66 -517
  184. package/dist/src/embeddings/hnsw-store.js.map +1 -1
  185. package/dist/src/embeddings/hnsw-store.types.d.ts +154 -0
  186. package/dist/src/embeddings/hnsw-store.types.d.ts.map +1 -0
  187. package/dist/src/embeddings/hnsw-store.types.js +26 -0
  188. package/dist/src/embeddings/hnsw-store.types.js.map +1 -0
  189. package/dist/src/embeddings/index.d.ts +36 -112
  190. package/dist/src/embeddings/index.d.ts.map +1 -1
  191. package/dist/src/embeddings/index.js +37 -210
  192. package/dist/src/embeddings/index.js.map +1 -1
  193. package/dist/src/errors.d.ts.map +1 -1
  194. package/dist/src/errors.js +1 -1
  195. package/dist/src/errors.js.map +1 -1
  196. package/dist/src/exports/repositories.d.ts +18 -0
  197. package/dist/src/exports/repositories.d.ts.map +1 -0
  198. package/dist/src/exports/repositories.js +30 -0
  199. package/dist/src/exports/repositories.js.map +1 -0
  200. package/dist/src/exports/services.d.ts +30 -0
  201. package/dist/src/exports/services.d.ts.map +1 -0
  202. package/dist/src/exports/services.js +70 -0
  203. package/dist/src/exports/services.js.map +1 -0
  204. package/dist/src/exports/types.d.ts +21 -0
  205. package/dist/src/exports/types.d.ts.map +1 -0
  206. package/dist/src/exports/types.js +12 -0
  207. package/dist/src/exports/types.js.map +1 -0
  208. package/dist/src/index.d.ts +10 -47
  209. package/dist/src/index.d.ts.map +1 -1
  210. package/dist/src/index.js +31 -48
  211. package/dist/src/index.js.map +1 -1
  212. package/dist/src/indexer/GitHubIndexer.d.ts.map +1 -1
  213. package/dist/src/indexer/GitHubIndexer.js +17 -4
  214. package/dist/src/indexer/GitHubIndexer.js.map +1 -1
  215. package/dist/src/indexer/SwarmIndexer.d.ts.map +1 -1
  216. package/dist/src/indexer/SwarmIndexer.js +1 -1
  217. package/dist/src/indexer/SwarmIndexer.js.map +1 -1
  218. package/dist/src/learning/PatternStore.d.ts +6 -426
  219. package/dist/src/learning/PatternStore.d.ts.map +1 -1
  220. package/dist/src/learning/PatternStore.helpers.d.ts +88 -0
  221. package/dist/src/learning/PatternStore.helpers.d.ts.map +1 -0
  222. package/dist/src/learning/PatternStore.helpers.js +286 -0
  223. package/dist/src/learning/PatternStore.helpers.js.map +1 -0
  224. package/dist/src/learning/PatternStore.js +52 -598
  225. package/dist/src/learning/PatternStore.js.map +1 -1
  226. package/dist/src/learning/PatternStore.queries.d.ts +83 -0
  227. package/dist/src/learning/PatternStore.queries.d.ts.map +1 -0
  228. package/dist/src/learning/PatternStore.queries.js +189 -0
  229. package/dist/src/learning/PatternStore.queries.js.map +1 -0
  230. package/dist/src/learning/PatternStore.types.d.ts +308 -0
  231. package/dist/src/learning/PatternStore.types.d.ts.map +1 -0
  232. package/dist/src/learning/PatternStore.types.js +44 -0
  233. package/dist/src/learning/PatternStore.types.js.map +1 -0
  234. package/dist/src/learning/ReasoningBankIntegration.d.ts +5 -345
  235. package/dist/src/learning/ReasoningBankIntegration.d.ts.map +1 -1
  236. package/dist/src/learning/ReasoningBankIntegration.helpers.d.ts +49 -0
  237. package/dist/src/learning/ReasoningBankIntegration.helpers.d.ts.map +1 -0
  238. package/dist/src/learning/ReasoningBankIntegration.helpers.js +180 -0
  239. package/dist/src/learning/ReasoningBankIntegration.helpers.js.map +1 -0
  240. package/dist/src/learning/ReasoningBankIntegration.js +21 -390
  241. package/dist/src/learning/ReasoningBankIntegration.js.map +1 -1
  242. package/dist/src/learning/ReasoningBankIntegration.types.d.ts +167 -0
  243. package/dist/src/learning/ReasoningBankIntegration.types.d.ts.map +1 -0
  244. package/dist/src/learning/ReasoningBankIntegration.types.js +51 -0
  245. package/dist/src/learning/ReasoningBankIntegration.types.js.map +1 -0
  246. package/dist/src/learning/interfaces.d.ts.map +1 -1
  247. package/dist/src/pipeline/DailyIndexPipeline.d.ts +4 -176
  248. package/dist/src/pipeline/DailyIndexPipeline.d.ts.map +1 -1
  249. package/dist/src/pipeline/DailyIndexPipeline.js +9 -83
  250. package/dist/src/pipeline/DailyIndexPipeline.js.map +1 -1
  251. package/dist/src/pipeline/pipeline-types.d.ts +132 -0
  252. package/dist/src/pipeline/pipeline-types.d.ts.map +1 -0
  253. package/dist/src/pipeline/pipeline-types.js +6 -0
  254. package/dist/src/pipeline/pipeline-types.js.map +1 -0
  255. package/dist/src/repositories/IndexerRepository.d.ts +1 -0
  256. package/dist/src/repositories/IndexerRepository.d.ts.map +1 -1
  257. package/dist/src/repositories/IndexerRepository.js +6 -0
  258. package/dist/src/repositories/IndexerRepository.js.map +1 -1
  259. package/dist/src/repositories/SkillRepository.d.ts.map +1 -1
  260. package/dist/src/repositories/SkillRepository.js +20 -5
  261. package/dist/src/repositories/SkillRepository.js.map +1 -1
  262. package/dist/src/routing/SONARouter.d.ts +3 -101
  263. package/dist/src/routing/SONARouter.d.ts.map +1 -1
  264. package/dist/src/routing/SONARouter.helpers.d.ts +112 -0
  265. package/dist/src/routing/SONARouter.helpers.d.ts.map +1 -0
  266. package/dist/src/routing/SONARouter.helpers.js +184 -0
  267. package/dist/src/routing/SONARouter.helpers.js.map +1 -0
  268. package/dist/src/routing/SONARouter.js +16 -318
  269. package/dist/src/routing/SONARouter.js.map +1 -1
  270. package/dist/src/routing/expert-types.d.ts +109 -0
  271. package/dist/src/routing/expert-types.d.ts.map +1 -0
  272. package/dist/src/routing/expert-types.js +162 -0
  273. package/dist/src/routing/expert-types.js.map +1 -0
  274. package/dist/src/routing/request-types.d.ts +113 -0
  275. package/dist/src/routing/request-types.d.ts.map +1 -0
  276. package/dist/src/routing/request-types.js +9 -0
  277. package/dist/src/routing/request-types.js.map +1 -0
  278. package/dist/src/routing/types.d.ts +5 -207
  279. package/dist/src/routing/types.d.ts.map +1 -1
  280. package/dist/src/routing/types.js +3 -153
  281. package/dist/src/routing/types.js.map +1 -1
  282. package/dist/src/scripts/github-import/github-auth.d.ts +17 -0
  283. package/dist/src/scripts/github-import/github-auth.d.ts.map +1 -0
  284. package/dist/src/scripts/github-import/github-auth.js +201 -0
  285. package/dist/src/scripts/github-import/github-auth.js.map +1 -0
  286. package/dist/src/scripts/github-import/github-client.d.ts +5 -5
  287. package/dist/src/scripts/github-import/github-client.d.ts.map +1 -1
  288. package/dist/src/scripts/github-import/github-client.js +5 -204
  289. package/dist/src/scripts/github-import/github-client.js.map +1 -1
  290. package/dist/src/scripts/ingest-lenny-skills.d.ts +40 -0
  291. package/dist/src/scripts/ingest-lenny-skills.d.ts.map +1 -0
  292. package/dist/src/scripts/ingest-lenny-skills.js +346 -0
  293. package/dist/src/scripts/ingest-lenny-skills.js.map +1 -0
  294. package/dist/src/scripts/merge-skills.d.ts +5 -27
  295. package/dist/src/scripts/merge-skills.d.ts.map +1 -1
  296. package/dist/src/scripts/merge-skills.js +4 -144
  297. package/dist/src/scripts/merge-skills.js.map +1 -1
  298. package/dist/src/scripts/merge-types.d.ts +72 -0
  299. package/dist/src/scripts/merge-types.d.ts.map +1 -0
  300. package/dist/src/scripts/merge-types.js +7 -0
  301. package/dist/src/scripts/merge-types.js.map +1 -0
  302. package/dist/src/scripts/merge-utils.d.ts +23 -0
  303. package/dist/src/scripts/merge-utils.d.ts.map +1 -0
  304. package/dist/src/scripts/merge-utils.js +150 -0
  305. package/dist/src/scripts/merge-utils.js.map +1 -0
  306. package/dist/src/scripts/review-categories.d.ts +41 -0
  307. package/dist/src/scripts/review-categories.d.ts.map +1 -0
  308. package/dist/src/scripts/review-categories.js +316 -0
  309. package/dist/src/scripts/review-categories.js.map +1 -0
  310. package/dist/src/scripts/review-lenny-skills.d.ts +26 -0
  311. package/dist/src/scripts/review-lenny-skills.d.ts.map +1 -0
  312. package/dist/src/scripts/review-lenny-skills.js +215 -0
  313. package/dist/src/scripts/review-lenny-skills.js.map +1 -0
  314. package/dist/src/scripts/sync-to-supabase.d.ts +10 -0
  315. package/dist/src/scripts/sync-to-supabase.d.ts.map +1 -0
  316. package/dist/src/scripts/sync-to-supabase.js +93 -0
  317. package/dist/src/scripts/sync-to-supabase.js.map +1 -0
  318. package/dist/src/security/AuditLogger.d.ts +4 -75
  319. package/dist/src/security/AuditLogger.d.ts.map +1 -1
  320. package/dist/src/security/AuditLogger.js +3 -12
  321. package/dist/src/security/AuditLogger.js.map +1 -1
  322. package/dist/src/security/__tests__/pathValidation.test.js.map +1 -1
  323. package/dist/src/security/audit-types.d.ts +96 -0
  324. package/dist/src/security/audit-types.d.ts.map +1 -0
  325. package/dist/src/security/audit-types.js +15 -0
  326. package/dist/src/security/audit-types.js.map +1 -0
  327. package/dist/src/security/sanitization.d.ts +1 -85
  328. package/dist/src/security/sanitization.d.ts.map +1 -1
  329. package/dist/src/security/sanitization.js +2 -133
  330. package/dist/src/security/sanitization.js.map +1 -1
  331. package/dist/src/security/scanner/SecurityScanner.d.ts +12 -88
  332. package/dist/src/security/scanner/SecurityScanner.d.ts.map +1 -1
  333. package/dist/src/security/scanner/SecurityScanner.formatters.d.ts +49 -0
  334. package/dist/src/security/scanner/SecurityScanner.formatters.d.ts.map +1 -0
  335. package/dist/src/security/scanner/SecurityScanner.formatters.js +139 -0
  336. package/dist/src/security/scanner/SecurityScanner.formatters.js.map +1 -0
  337. package/dist/src/security/scanner/SecurityScanner.helpers.d.ts +40 -0
  338. package/dist/src/security/scanner/SecurityScanner.helpers.d.ts.map +1 -0
  339. package/dist/src/security/scanner/SecurityScanner.helpers.js +142 -0
  340. package/dist/src/security/scanner/SecurityScanner.helpers.js.map +1 -0
  341. package/dist/src/security/scanner/SecurityScanner.js +26 -255
  342. package/dist/src/security/scanner/SecurityScanner.js.map +1 -1
  343. package/dist/src/security/stripe-validators.d.ts +92 -0
  344. package/dist/src/security/stripe-validators.d.ts.map +1 -0
  345. package/dist/src/security/stripe-validators.js +139 -0
  346. package/dist/src/security/stripe-validators.js.map +1 -0
  347. package/dist/src/services/SearchService.d.ts +5 -29
  348. package/dist/src/services/SearchService.d.ts.map +1 -1
  349. package/dist/src/services/SearchService.helpers.d.ts +42 -0
  350. package/dist/src/services/SearchService.helpers.d.ts.map +1 -0
  351. package/dist/src/services/SearchService.helpers.js +128 -0
  352. package/dist/src/services/SearchService.helpers.js.map +1 -0
  353. package/dist/src/services/SearchService.js +142 -128
  354. package/dist/src/services/SearchService.js.map +1 -1
  355. package/dist/src/services/SearchService.types.d.ts +53 -0
  356. package/dist/src/services/SearchService.types.d.ts.map +1 -0
  357. package/dist/src/services/SearchService.types.js +7 -0
  358. package/dist/src/services/SearchService.types.js.map +1 -0
  359. package/dist/src/services/SkillAnalyzer.d.ts +37 -0
  360. package/dist/src/services/SkillAnalyzer.d.ts.map +1 -0
  361. package/dist/src/services/SkillAnalyzer.helpers.d.ts +103 -0
  362. package/dist/src/services/SkillAnalyzer.helpers.d.ts.map +1 -0
  363. package/dist/src/services/SkillAnalyzer.helpers.js +237 -0
  364. package/dist/src/services/SkillAnalyzer.helpers.js.map +1 -0
  365. package/dist/src/services/SkillAnalyzer.js +270 -0
  366. package/dist/src/services/SkillAnalyzer.js.map +1 -0
  367. package/dist/src/services/SkillAnalyzer.types.d.ts +110 -0
  368. package/dist/src/services/SkillAnalyzer.types.d.ts.map +1 -0
  369. package/dist/src/services/SkillAnalyzer.types.js +9 -0
  370. package/dist/src/services/SkillAnalyzer.types.js.map +1 -0
  371. package/dist/src/services/SkillDecomposer.d.ts +37 -0
  372. package/dist/src/services/SkillDecomposer.d.ts.map +1 -0
  373. package/dist/src/services/SkillDecomposer.helpers.d.ts +75 -0
  374. package/dist/src/services/SkillDecomposer.helpers.d.ts.map +1 -0
  375. package/dist/src/services/SkillDecomposer.helpers.js +277 -0
  376. package/dist/src/services/SkillDecomposer.helpers.js.map +1 -0
  377. package/dist/src/services/SkillDecomposer.js +116 -0
  378. package/dist/src/services/SkillDecomposer.js.map +1 -0
  379. package/dist/src/services/SkillDecomposer.types.d.ts +104 -0
  380. package/dist/src/services/SkillDecomposer.types.d.ts.map +1 -0
  381. package/dist/src/services/SkillDecomposer.types.js +9 -0
  382. package/dist/src/services/SkillDecomposer.types.js.map +1 -0
  383. package/dist/src/services/SubagentGenerator.d.ts +77 -0
  384. package/dist/src/services/SubagentGenerator.d.ts.map +1 -0
  385. package/dist/src/services/SubagentGenerator.js +352 -0
  386. package/dist/src/services/SubagentGenerator.js.map +1 -0
  387. package/dist/src/services/TaskRunner.d.ts +227 -0
  388. package/dist/src/services/TaskRunner.d.ts.map +1 -0
  389. package/dist/src/services/TaskRunner.js +423 -0
  390. package/dist/src/services/TaskRunner.js.map +1 -0
  391. package/dist/src/services/TransformationService.d.ts +167 -0
  392. package/dist/src/services/TransformationService.d.ts.map +1 -0
  393. package/dist/src/services/TransformationService.js +315 -0
  394. package/dist/src/services/TransformationService.js.map +1 -0
  395. package/dist/src/services/__tests__/SkillAnalyzer.test.d.ts +6 -0
  396. package/dist/src/services/__tests__/SkillAnalyzer.test.d.ts.map +1 -0
  397. package/dist/src/services/__tests__/SkillAnalyzer.test.js +177 -0
  398. package/dist/src/services/__tests__/SkillAnalyzer.test.js.map +1 -0
  399. package/dist/src/services/__tests__/SkillDecomposer.test.d.ts +6 -0
  400. package/dist/src/services/__tests__/SkillDecomposer.test.d.ts.map +1 -0
  401. package/dist/src/services/__tests__/SkillDecomposer.test.js +235 -0
  402. package/dist/src/services/__tests__/SkillDecomposer.test.js.map +1 -0
  403. package/dist/src/services/__tests__/SubagentGenerator.test.d.ts +6 -0
  404. package/dist/src/services/__tests__/SubagentGenerator.test.d.ts.map +1 -0
  405. package/dist/src/services/__tests__/SubagentGenerator.test.js +174 -0
  406. package/dist/src/services/__tests__/SubagentGenerator.test.js.map +1 -0
  407. package/dist/src/services/__tests__/TaskRunner.test.d.ts +7 -0
  408. package/dist/src/services/__tests__/TaskRunner.test.d.ts.map +1 -0
  409. package/dist/src/services/__tests__/TaskRunner.test.js +316 -0
  410. package/dist/src/services/__tests__/TaskRunner.test.js.map +1 -0
  411. package/dist/src/services/__tests__/TransformationService.test.d.ts +6 -0
  412. package/dist/src/services/__tests__/TransformationService.test.d.ts.map +1 -0
  413. package/dist/src/services/__tests__/TransformationService.test.js +244 -0
  414. package/dist/src/services/__tests__/TransformationService.test.js.map +1 -0
  415. package/dist/src/session/SessionContext.js +1 -1
  416. package/dist/src/session/SessionContext.js.map +1 -1
  417. package/dist/src/session/SessionManager.d.ts +3 -67
  418. package/dist/src/session/SessionManager.d.ts.map +1 -1
  419. package/dist/src/session/SessionManager.helpers.d.ts +68 -0
  420. package/dist/src/session/SessionManager.helpers.d.ts.map +1 -0
  421. package/dist/src/session/SessionManager.helpers.js +152 -0
  422. package/dist/src/session/SessionManager.helpers.js.map +1 -0
  423. package/dist/src/session/SessionManager.js +58 -163
  424. package/dist/src/session/SessionManager.js.map +1 -1
  425. package/dist/src/session/SessionManager.types.d.ts +88 -0
  426. package/dist/src/session/SessionManager.types.d.ts.map +1 -0
  427. package/dist/src/session/SessionManager.types.js +27 -0
  428. package/dist/src/session/SessionManager.types.js.map +1 -0
  429. package/dist/src/session/SessionRecovery.d.ts.map +1 -1
  430. package/dist/src/session/SessionRecovery.js +3 -2
  431. package/dist/src/session/SessionRecovery.js.map +1 -1
  432. package/dist/src/sources/RawUrlSourceAdapter.js.map +1 -1
  433. package/dist/src/sources/SourceAdapterRegistry.js +1 -1
  434. package/dist/src/sources/SourceAdapterRegistry.js.map +1 -1
  435. package/dist/src/telemetry/metric-helpers.d.ts +47 -0
  436. package/dist/src/telemetry/metric-helpers.d.ts.map +1 -0
  437. package/dist/src/telemetry/metric-helpers.js +96 -0
  438. package/dist/src/telemetry/metric-helpers.js.map +1 -0
  439. package/dist/src/telemetry/metric-types.d.ts +73 -0
  440. package/dist/src/telemetry/metric-types.d.ts.map +1 -0
  441. package/dist/src/telemetry/metric-types.js +9 -0
  442. package/dist/src/telemetry/metric-types.js.map +1 -0
  443. package/dist/src/telemetry/metrics.d.ts +8 -119
  444. package/dist/src/telemetry/metrics.d.ts.map +1 -1
  445. package/dist/src/telemetry/metrics.js +20 -193
  446. package/dist/src/telemetry/metrics.js.map +1 -1
  447. package/dist/src/telemetry/span-utils.d.ts +30 -0
  448. package/dist/src/telemetry/span-utils.d.ts.map +1 -0
  449. package/dist/src/telemetry/span-utils.js +62 -0
  450. package/dist/src/telemetry/span-utils.js.map +1 -0
  451. package/dist/src/telemetry/tracer-types.d.ts +91 -0
  452. package/dist/src/telemetry/tracer-types.d.ts.map +1 -0
  453. package/dist/src/telemetry/tracer-types.js +6 -0
  454. package/dist/src/telemetry/tracer-types.js.map +1 -0
  455. package/dist/src/telemetry/tracer.d.ts +5 -122
  456. package/dist/src/telemetry/tracer.d.ts.map +1 -1
  457. package/dist/src/telemetry/tracer.js +24 -170
  458. package/dist/src/telemetry/tracer.js.map +1 -1
  459. package/dist/src/testing/MultiLLMProvider.d.ts +17 -293
  460. package/dist/src/testing/MultiLLMProvider.d.ts.map +1 -1
  461. package/dist/src/testing/MultiLLMProvider.helpers.d.ts +54 -0
  462. package/dist/src/testing/MultiLLMProvider.helpers.d.ts.map +1 -0
  463. package/dist/src/testing/MultiLLMProvider.helpers.js +126 -0
  464. package/dist/src/testing/MultiLLMProvider.helpers.js.map +1 -0
  465. package/dist/src/testing/MultiLLMProvider.js +50 -323
  466. package/dist/src/testing/MultiLLMProvider.js.map +1 -1
  467. package/dist/src/testing/MultiLLMProvider.types.d.ts +253 -0
  468. package/dist/src/testing/MultiLLMProvider.types.d.ts.map +1 -0
  469. package/dist/src/testing/MultiLLMProvider.types.js +111 -0
  470. package/dist/src/testing/MultiLLMProvider.types.js.map +1 -0
  471. package/dist/src/triggers/TriggerDetector.d.ts +6 -142
  472. package/dist/src/triggers/TriggerDetector.d.ts.map +1 -1
  473. package/dist/src/triggers/TriggerDetector.js +15 -247
  474. package/dist/src/triggers/TriggerDetector.js.map +1 -1
  475. package/dist/src/triggers/__tests__/TriggerDetector.test.js +1 -1
  476. package/dist/src/triggers/__tests__/TriggerDetector.test.js.map +1 -1
  477. package/dist/src/triggers/trigger-constants.d.ts +22 -0
  478. package/dist/src/triggers/trigger-constants.d.ts.map +1 -0
  479. package/dist/src/triggers/trigger-constants.js +185 -0
  480. package/dist/src/triggers/trigger-constants.js.map +1 -0
  481. package/dist/src/triggers/trigger-types.d.ts +90 -0
  482. package/dist/src/triggers/trigger-types.d.ts.map +1 -0
  483. package/dist/src/triggers/trigger-types.js +6 -0
  484. package/dist/src/triggers/trigger-types.js.map +1 -0
  485. package/dist/src/types/skill.d.ts +33 -1
  486. package/dist/src/types/skill.d.ts.map +1 -1
  487. package/dist/src/types/skill.js +11 -1
  488. package/dist/src/types/skill.js.map +1 -1
  489. package/dist/src/types.d.ts +28 -2
  490. package/dist/src/types.d.ts.map +1 -1
  491. package/dist/src/types.js +1 -0
  492. package/dist/src/types.js.map +1 -1
  493. package/dist/src/utils/retry.js +2 -2
  494. package/dist/src/utils/retry.js.map +1 -1
  495. package/dist/src/validation/index.d.ts +5 -105
  496. package/dist/src/validation/index.d.ts.map +1 -1
  497. package/dist/src/validation/index.js +9 -421
  498. package/dist/src/validation/index.js.map +1 -1
  499. package/dist/src/validation/input-validators.d.ts +68 -0
  500. package/dist/src/validation/input-validators.d.ts.map +1 -0
  501. package/dist/src/validation/input-validators.js +126 -0
  502. package/dist/src/validation/input-validators.js.map +1 -0
  503. package/dist/src/validation/path-validators.d.ts +23 -0
  504. package/dist/src/validation/path-validators.d.ts.map +1 -0
  505. package/dist/src/validation/path-validators.js +47 -0
  506. package/dist/src/validation/path-validators.js.map +1 -0
  507. package/dist/src/validation/url-validators.d.ts +55 -0
  508. package/dist/src/validation/url-validators.d.ts.map +1 -0
  509. package/dist/src/validation/url-validators.js +267 -0
  510. package/dist/src/validation/url-validators.js.map +1 -0
  511. package/dist/src/validation/validation-error.d.ts +14 -0
  512. package/dist/src/validation/validation-error.d.ts.map +1 -0
  513. package/dist/src/validation/validation-error.js +19 -0
  514. package/dist/src/validation/validation-error.js.map +1 -0
  515. package/dist/src/webhooks/WebhookHandler.d.ts.map +1 -1
  516. package/dist/src/webhooks/WebhookHandler.js.map +1 -1
  517. package/dist/src/webhooks/WebhookPayload.d.ts +4 -215
  518. package/dist/src/webhooks/WebhookPayload.d.ts.map +1 -1
  519. package/dist/src/webhooks/WebhookPayload.js +1 -122
  520. package/dist/src/webhooks/WebhookPayload.js.map +1 -1
  521. package/dist/src/webhooks/WebhookQueue.d.ts +2 -140
  522. package/dist/src/webhooks/WebhookQueue.d.ts.map +1 -1
  523. package/dist/src/webhooks/WebhookQueue.js +4 -11
  524. package/dist/src/webhooks/WebhookQueue.js.map +1 -1
  525. package/dist/src/webhooks/WebhookQueue.types.d.ts +149 -0
  526. package/dist/src/webhooks/WebhookQueue.types.d.ts.map +1 -0
  527. package/dist/src/webhooks/WebhookQueue.types.js +10 -0
  528. package/dist/src/webhooks/WebhookQueue.types.js.map +1 -0
  529. package/dist/src/webhooks/WebhookQueue.utils.d.ts +44 -0
  530. package/dist/src/webhooks/WebhookQueue.utils.d.ts.map +1 -0
  531. package/dist/src/webhooks/WebhookQueue.utils.js +58 -0
  532. package/dist/src/webhooks/WebhookQueue.utils.js.map +1 -0
  533. package/dist/src/webhooks/webhook-schemas.d.ts +213 -0
  534. package/dist/src/webhooks/webhook-schemas.d.ts.map +1 -0
  535. package/dist/src/webhooks/webhook-schemas.js +132 -0
  536. package/dist/src/webhooks/webhook-schemas.js.map +1 -0
  537. package/dist/src/webhooks/webhook-types.d.ts +222 -0
  538. package/dist/src/webhooks/webhook-types.d.ts.map +1 -0
  539. package/dist/src/webhooks/webhook-types.js +10 -0
  540. package/dist/src/webhooks/webhook-types.js.map +1 -0
  541. package/dist/tests/Analytics.integration.test.js +2 -2
  542. package/dist/tests/Analytics.integration.test.js.map +1 -1
  543. package/dist/tests/AnalyticsRepository.test.js +3 -5
  544. package/dist/tests/AnalyticsRepository.test.js.map +1 -1
  545. package/dist/tests/AnalyticsStorage.test.js.map +1 -1
  546. package/dist/tests/ApiPartialResponses.test.d.ts +12 -0
  547. package/dist/tests/ApiPartialResponses.test.d.ts.map +1 -0
  548. package/dist/tests/ApiPartialResponses.test.js +202 -0
  549. package/dist/tests/ApiPartialResponses.test.js.map +1 -0
  550. package/dist/tests/AuditLogger.test.js.map +1 -1
  551. package/dist/tests/BenchmarkRunner.test.js +6 -6
  552. package/dist/tests/BenchmarkRunner.test.js.map +1 -1
  553. package/dist/tests/CacheSecurity.test.js.map +1 -1
  554. package/dist/tests/CodebaseAnalyzer.test.js.map +1 -1
  555. package/dist/tests/DailyIndexPipeline.test.js.map +1 -1
  556. package/dist/tests/EmbeddingService.test.js.map +1 -1
  557. package/dist/tests/GitHubIndexer.test.js +4 -3
  558. package/dist/tests/GitHubIndexer.test.js.map +1 -1
  559. package/dist/tests/MemoryProfiler.test.js +3 -3
  560. package/dist/tests/MemoryProfiler.test.js.map +1 -1
  561. package/dist/tests/QualityScorer.test.js.map +1 -1
  562. package/dist/tests/RateLimiter.test.js.map +1 -1
  563. package/dist/tests/ScraperAdapters.test.js.map +1 -1
  564. package/dist/tests/SecurityScanner.test.js +4 -4
  565. package/dist/tests/SecurityScanner.test.js.map +1 -1
  566. package/dist/tests/SessionManager.security.test.js +1 -1
  567. package/dist/tests/SessionManager.security.test.js.map +1 -1
  568. package/dist/tests/SessionManager.test.js +4 -4
  569. package/dist/tests/SessionManager.test.js.map +1 -1
  570. package/dist/tests/SwarmIndexer.test.js +1 -1
  571. package/dist/tests/SwarmIndexer.test.js.map +1 -1
  572. package/dist/tests/TieredCache.test.js +2 -11
  573. package/dist/tests/TieredCache.test.js.map +1 -1
  574. package/dist/tests/WebhookHandler.test.js.map +1 -1
  575. package/dist/tests/fixtures/api-responses/index.d.ts +119 -0
  576. package/dist/tests/fixtures/api-responses/index.d.ts.map +1 -0
  577. package/dist/tests/fixtures/api-responses/index.js +419 -0
  578. package/dist/tests/fixtures/api-responses/index.js.map +1 -0
  579. package/dist/tests/integration/neural/neural-fixtures.d.ts +19 -0
  580. package/dist/tests/integration/neural/neural-fixtures.d.ts.map +1 -0
  581. package/dist/tests/integration/neural/neural-fixtures.js +49 -0
  582. package/dist/tests/integration/neural/neural-fixtures.js.map +1 -0
  583. package/dist/tests/integration/neural/neural-mocks-privacy.d.ts +78 -0
  584. package/dist/tests/integration/neural/neural-mocks-privacy.d.ts.map +1 -0
  585. package/dist/tests/integration/neural/neural-mocks-privacy.js +146 -0
  586. package/dist/tests/integration/neural/neural-mocks-privacy.js.map +1 -0
  587. package/dist/tests/integration/neural/neural-mocks.d.ts +90 -0
  588. package/dist/tests/integration/neural/neural-mocks.d.ts.map +1 -0
  589. package/dist/tests/integration/neural/neural-mocks.js +288 -0
  590. package/dist/tests/integration/neural/neural-mocks.js.map +1 -0
  591. package/dist/tests/integration/neural/neural-test-utils.d.ts +27 -0
  592. package/dist/tests/integration/neural/neural-test-utils.d.ts.map +1 -0
  593. package/dist/tests/integration/neural/neural-test-utils.js +35 -0
  594. package/dist/tests/integration/neural/neural-test-utils.js.map +1 -0
  595. package/dist/tests/integration/neural/setup.d.ts +6 -165
  596. package/dist/tests/integration/neural/setup.d.ts.map +1 -1
  597. package/dist/tests/integration/neural/setup.js +9 -477
  598. package/dist/tests/integration/neural/setup.js.map +1 -1
  599. package/dist/tests/logger.test.js +1 -1
  600. package/dist/tests/logger.test.js.map +1 -1
  601. package/dist/tests/performance/LargeScalePerformance.test.js +1 -1
  602. package/dist/tests/performance/LargeScalePerformance.test.js.map +1 -1
  603. package/dist/tests/sanitization.test.js.map +1 -1
  604. package/dist/tests/session/SessionManager.helpers.test.d.ts +8 -0
  605. package/dist/tests/session/SessionManager.helpers.test.d.ts.map +1 -0
  606. package/dist/tests/session/SessionManager.helpers.test.js +105 -0
  607. package/dist/tests/session/SessionManager.helpers.test.js.map +1 -0
  608. package/dist/tests/sources.test.js.map +1 -1
  609. package/dist/tests/webhooks/WebhookHandler.idempotency.test.js +1 -1
  610. package/dist/tests/webhooks/WebhookHandler.idempotency.test.js.map +1 -1
  611. package/dist/tests/webhooks/WebhookPayload.security.test.js.map +1 -1
  612. package/package.json +11 -11
@@ -4,172 +4,13 @@
4
4
  * Provides test context factory and mock implementations for
5
5
  * the Recommendation Learning Loop integration tests.
6
6
  *
7
+ * This file re-exports all neural test infrastructure from
8
+ * modular files for backwards compatibility.
9
+ *
7
10
  * @see packages/core/src/learning/interfaces.ts
8
11
  * @see packages/core/src/learning/types.ts
9
12
  */
10
- import type { ISignalCollector, IPreferenceLearner, IPersonalizationEngine, IPrivacyManager, IUserPreferenceRepository } from '../../../src/learning/interfaces.js';
11
- import { type SignalEvent, type SignalFilter, type RecommendationContext, type SignalMetadata, type DismissReason, type UserPreferenceProfile, type LearningConfig, type PersonalizedRecommendation, type UserDataExport, type AggregateStats } from '../../../src/learning/types.js';
12
- /**
13
- * Neural test context containing all mock service instances
14
- */
15
- export interface NeuralTestContext {
16
- signalCollector: MockSignalCollector;
17
- preferenceLearner: MockPreferenceLearner;
18
- personalizationEngine: MockPersonalizationEngine;
19
- privacyManager: MockPrivacyManager;
20
- profileRepository: MockUserPreferenceRepository;
21
- }
22
- /**
23
- * Create a fresh neural test context with all mock services
24
- */
25
- export declare function createNeuralTestContext(): NeuralTestContext;
26
- /**
27
- * Clean up a neural test context (release resources)
28
- */
29
- export declare function cleanupNeuralTestContext(ctx: NeuralTestContext): Promise<void>;
30
- /**
31
- * Create a default empty user preference profile
32
- *
33
- * Note: COLD_START_WEIGHTS only defines weights for a subset of SkillCategory values
34
- * (TESTING, GIT, DEVOPS, DOCUMENTATION, FRONTEND, BACKEND). Categories not in
35
- * COLD_START_WEIGHTS (DATABASE, SECURITY, PRODUCTIVITY, ANALYSIS) will have
36
- * undefined weights, which is handled gracefully by the learning algorithm
37
- * by defaulting to 0 when accessing missing keys.
38
- */
39
- export declare function createDefaultProfile(): UserPreferenceProfile;
40
- /**
41
- * Mock implementation of ISignalCollector for testing
42
- */
43
- export declare class MockSignalCollector implements ISignalCollector {
44
- private signals;
45
- recordAccept(skillId: string, context: RecommendationContext, metadata?: SignalMetadata): Promise<void>;
46
- recordDismiss(skillId: string, context: RecommendationContext, reason?: DismissReason): Promise<void>;
47
- recordUsage(skillId: string, frequency: 'daily' | 'weekly'): Promise<void>;
48
- recordAbandonment(skillId: string, daysSinceInstall: number): Promise<void>;
49
- recordUninstall(skillId: string, daysSinceInstall: number): Promise<void>;
50
- getSignals(filter: SignalFilter, limit?: number): Promise<SignalEvent[]>;
51
- getSignalCount(): Promise<number>;
52
- getSignalsForSkill(skillId: string): Promise<SignalEvent[]>;
53
- clear(): void;
54
- getAllSignals(): SignalEvent[];
55
- addSignal(signal: SignalEvent): void;
56
- removeOldSignals(cutoffTimestamp: number): number;
57
- }
58
- /**
59
- * Mock implementation of IPreferenceLearner for testing
60
- */
61
- export declare class MockPreferenceLearner implements IPreferenceLearner {
62
- private config;
63
- updateProfile(profile: UserPreferenceProfile, signal: SignalEvent): Promise<UserPreferenceProfile>;
64
- batchUpdateProfile(profile: UserPreferenceProfile, signals: SignalEvent[]): Promise<UserPreferenceProfile>;
65
- decayWeights(profile: UserPreferenceProfile, decayFactor?: number): Promise<UserPreferenceProfile>;
66
- calculatePersonalizedScore(skillData: {
67
- id: string;
68
- category?: string;
69
- trustTier?: string;
70
- keywords?: string[];
71
- triggerPhrases?: string[];
72
- }, baseScore: number, profile: UserPreferenceProfile): PersonalizedRecommendation;
73
- getConfig(): LearningConfig;
74
- setConfig(config: Partial<LearningConfig>): void;
75
- private clampWeight;
76
- }
77
- /**
78
- * Mock implementation of IPersonalizationEngine for testing
79
- */
80
- export declare class MockPersonalizationEngine implements IPersonalizationEngine {
81
- private learner;
82
- private profileRepo;
83
- private signalCollector;
84
- constructor(learner: MockPreferenceLearner, profileRepo: MockUserPreferenceRepository, signalCollector: MockSignalCollector);
85
- personalizeRecommendations(baseRecommendations: Array<{
86
- skill_id: string;
87
- base_score: number;
88
- skill_data: {
89
- category?: string;
90
- trustTier?: string;
91
- keywords?: string[];
92
- };
93
- }>, userId?: string): Promise<PersonalizedRecommendation[]>;
94
- /**
95
- * Determine if personalization should be applied.
96
- *
97
- * IMPORTANT: Mock Implementation Limitation
98
- * -----------------------------------------
99
- * This mock checks the GLOBAL signal count across all users, not the
100
- * per-user signal count. This is a simplification for testing purposes.
101
- *
102
- * In a real implementation, shouldPersonalize should:
103
- * 1. Look up the user's profile by userId
104
- * 2. Check that user's individual signal_count against the threshold
105
- * 3. Return true only if that specific user has enough signals
106
- *
107
- * The mock behavior works for single-user test scenarios but does not
108
- * accurately model multi-user environments where each user has their
109
- * own signal history and personalization threshold.
110
- *
111
- * @param _userId - User ID (ignored in mock - uses global count)
112
- * @returns Promise<boolean> - True if global signal count meets threshold
113
- */
114
- shouldPersonalize(_userId?: string): Promise<boolean>;
115
- getUserProfile(userId?: string): Promise<UserPreferenceProfile>;
116
- resetToDefault(userId?: string): Promise<void>;
117
- }
118
- /**
119
- * Mock implementation of IPrivacyManager for testing
120
- */
121
- export declare class MockPrivacyManager implements IPrivacyManager {
122
- private signalCollector;
123
- private profileRepo;
124
- private auditLog;
125
- constructor(signalCollector: MockSignalCollector, profileRepo: MockUserPreferenceRepository);
126
- purgeOldSignals(retentionDays: number): Promise<number>;
127
- exportUserData(): Promise<UserDataExport>;
128
- wipeAllData(): Promise<number>;
129
- anonymizeForAnalytics(): Promise<AggregateStats>;
130
- getStorageSize(): Promise<number>;
131
- /**
132
- * Verify that no PII (Personally Identifiable Information) is stored.
133
- *
134
- * Mock Implementation Details
135
- * ---------------------------
136
- * This mock always returns true because the test environment uses
137
- * controlled, synthetic data that never contains real PII.
138
- *
139
- * A real implementation should:
140
- * 1. Scan signal events for PII patterns (emails, names, IPs, etc.)
141
- * 2. Check that skill_id values don't contain user identifiers
142
- * 3. Verify context fields don't leak sensitive project paths
143
- * 4. Ensure keyword_weights don't contain personal identifiers
144
- * 5. Validate that exported data is properly anonymized
145
- *
146
- * The mock skips these checks since test data is constructed with
147
- * known-safe values (UUIDs, generic skill names, etc.).
148
- *
149
- * @returns Promise<boolean> - Always true in mock (no real PII checks)
150
- */
151
- verifyPrivacy(): Promise<boolean>;
152
- getAuditLog(): Array<{
153
- operation: string;
154
- timestamp: number;
155
- details?: string;
156
- }>;
157
- /**
158
- * Clear the audit log.
159
- * Used in test cleanup to reset state between tests.
160
- */
161
- clearAuditLog(): void;
162
- }
163
- /**
164
- * Mock implementation of IUserPreferenceRepository for testing
165
- */
166
- export declare class MockUserPreferenceRepository implements IUserPreferenceRepository {
167
- private profiles;
168
- private readonly defaultUserId;
169
- getProfile(userId?: string): Promise<UserPreferenceProfile | null>;
170
- saveProfile(profile: UserPreferenceProfile, userId?: string): Promise<void>;
171
- deleteProfile(userId?: string): Promise<void>;
172
- exists(userId?: string): Promise<boolean>;
173
- clear(): void;
174
- }
13
+ export { createDefaultProfile } from './neural-fixtures.js';
14
+ export { type NeuralTestContext, createNeuralTestContext, cleanupNeuralTestContext, } from './neural-test-utils.js';
15
+ export { MockSignalCollector, MockPreferenceLearner, MockPersonalizationEngine, MockPrivacyManager, MockUserPreferenceRepository, } from './neural-mocks.js';
175
16
  //# sourceMappingURL=setup.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"setup.d.ts","sourceRoot":"","sources":["../../../../tests/integration/neural/setup.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"setup.d.ts","sourceRoot":"","sources":["../../../../tests/integration/neural/setup.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAGH,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAA;AAG3D,OAAO,EACL,KAAK,iBAAiB,EACtB,uBAAuB,EACvB,wBAAwB,GACzB,MAAM,wBAAwB,CAAA;AAG/B,OAAO,EACL,mBAAmB,EACnB,qBAAqB,EACrB,yBAAyB,EACzB,kBAAkB,EAClB,4BAA4B,GAC7B,MAAM,mBAAmB,CAAA"}
@@ -4,484 +4,16 @@
4
4
  * Provides test context factory and mock implementations for
5
5
  * the Recommendation Learning Loop integration tests.
6
6
  *
7
+ * This file re-exports all neural test infrastructure from
8
+ * modular files for backwards compatibility.
9
+ *
7
10
  * @see packages/core/src/learning/interfaces.ts
8
11
  * @see packages/core/src/learning/types.ts
9
12
  */
10
- import { randomUUID } from 'node:crypto';
11
- import { SignalType, SkillCategory, DEFAULT_LEARNING_CONFIG, SIGNAL_WEIGHTS, COLD_START_WEIGHTS, } from '../../../src/learning/types.js';
12
- /**
13
- * Create a fresh neural test context with all mock services
14
- */
15
- export function createNeuralTestContext() {
16
- const profileRepository = new MockUserPreferenceRepository();
17
- const signalCollector = new MockSignalCollector();
18
- const preferenceLearner = new MockPreferenceLearner();
19
- const personalizationEngine = new MockPersonalizationEngine(preferenceLearner, profileRepository, signalCollector);
20
- const privacyManager = new MockPrivacyManager(signalCollector, profileRepository);
21
- return {
22
- signalCollector,
23
- preferenceLearner,
24
- personalizationEngine,
25
- privacyManager,
26
- profileRepository,
27
- };
28
- }
29
- /**
30
- * Clean up a neural test context (release resources)
31
- */
32
- export async function cleanupNeuralTestContext(ctx) {
33
- // Clear all stored data
34
- ctx.signalCollector.clear();
35
- ctx.profileRepository.clear();
36
- ctx.privacyManager.clearAuditLog();
37
- }
38
- /**
39
- * Create a default empty user preference profile
40
- *
41
- * Note: COLD_START_WEIGHTS only defines weights for a subset of SkillCategory values
42
- * (TESTING, GIT, DEVOPS, DOCUMENTATION, FRONTEND, BACKEND). Categories not in
43
- * COLD_START_WEIGHTS (DATABASE, SECURITY, PRODUCTIVITY, ANALYSIS) will have
44
- * undefined weights, which is handled gracefully by the learning algorithm
45
- * by defaulting to 0 when accessing missing keys.
46
- */
47
- export function createDefaultProfile() {
48
- // Start with cold start weights and ensure all categories have explicit defaults
49
- const categoryWeights = {
50
- ...COLD_START_WEIGHTS.category_weights,
51
- };
52
- // Add missing categories with neutral (0) weights for completeness
53
- const allCategories = Object.values(SkillCategory);
54
- for (const category of allCategories) {
55
- if (categoryWeights[category] === undefined) {
56
- categoryWeights[category] = 0;
57
- }
58
- }
59
- return {
60
- version: 1,
61
- last_updated: Date.now(),
62
- signal_count: 0,
63
- category_weights: categoryWeights,
64
- trust_tier_weights: { ...COLD_START_WEIGHTS.trust_tier_weights },
65
- keyword_weights: {},
66
- negative_patterns: {
67
- keywords: [],
68
- categories: [],
69
- skill_ids: [],
70
- },
71
- usage_patterns: {
72
- avg_time_to_first_use_ms: 0,
73
- utilization_rate: 0,
74
- top_categories: [],
75
- },
76
- };
77
- }
78
- /**
79
- * Mock implementation of ISignalCollector for testing
80
- */
81
- export class MockSignalCollector {
82
- signals = [];
83
- async recordAccept(skillId, context, metadata) {
84
- this.signals.push({
85
- id: randomUUID(),
86
- type: SignalType.ACCEPT,
87
- skill_id: skillId,
88
- timestamp: Date.now(),
89
- context,
90
- metadata,
91
- });
92
- }
93
- async recordDismiss(skillId, context, reason) {
94
- this.signals.push({
95
- id: randomUUID(),
96
- type: SignalType.DISMISS,
97
- skill_id: skillId,
98
- timestamp: Date.now(),
99
- context,
100
- dismiss_reason: reason,
101
- });
102
- }
103
- async recordUsage(skillId, frequency) {
104
- const type = frequency === 'daily' ? SignalType.USAGE_DAILY : SignalType.USAGE_WEEKLY;
105
- this.signals.push({
106
- id: randomUUID(),
107
- type,
108
- skill_id: skillId,
109
- timestamp: Date.now(),
110
- context: { installed_skills: [], original_score: 0 },
111
- });
112
- }
113
- async recordAbandonment(skillId, daysSinceInstall) {
114
- this.signals.push({
115
- id: randomUUID(),
116
- type: SignalType.ABANDONED,
117
- skill_id: skillId,
118
- timestamp: Date.now(),
119
- context: { installed_skills: [], original_score: 0 },
120
- metadata: { extra: { days_since_install: daysSinceInstall } },
121
- });
122
- }
123
- async recordUninstall(skillId, daysSinceInstall) {
124
- this.signals.push({
125
- id: randomUUID(),
126
- type: SignalType.UNINSTALL,
127
- skill_id: skillId,
128
- timestamp: Date.now(),
129
- context: { installed_skills: [], original_score: 0 },
130
- metadata: { extra: { days_since_install: daysSinceInstall } },
131
- });
132
- }
133
- async getSignals(filter, limit) {
134
- let result = [...this.signals];
135
- if (filter.skill_id) {
136
- result = result.filter((s) => s.skill_id === filter.skill_id);
137
- }
138
- if (filter.type) {
139
- const types = Array.isArray(filter.type) ? filter.type : [filter.type];
140
- result = result.filter((s) => types.includes(s.type));
141
- }
142
- if (filter.time_range) {
143
- result = result.filter((s) => s.timestamp >= filter.time_range.start && s.timestamp <= filter.time_range.end);
144
- }
145
- if (filter.category) {
146
- result = result.filter((s) => s.context.category === filter.category);
147
- }
148
- if (limit) {
149
- result = result.slice(0, limit);
150
- }
151
- return result;
152
- }
153
- async getSignalCount() {
154
- return this.signals.length;
155
- }
156
- async getSignalsForSkill(skillId) {
157
- return this.signals.filter((s) => s.skill_id === skillId);
158
- }
159
- // Test helpers
160
- clear() {
161
- this.signals = [];
162
- }
163
- getAllSignals() {
164
- return [...this.signals];
165
- }
166
- addSignal(signal) {
167
- this.signals.push(signal);
168
- }
169
- removeOldSignals(cutoffTimestamp) {
170
- const before = this.signals.length;
171
- this.signals = this.signals.filter((s) => s.timestamp >= cutoffTimestamp);
172
- return before - this.signals.length;
173
- }
174
- }
175
- /**
176
- * Mock implementation of IPreferenceLearner for testing
177
- */
178
- export class MockPreferenceLearner {
179
- config = { ...DEFAULT_LEARNING_CONFIG };
180
- async updateProfile(profile, signal) {
181
- const weight = SIGNAL_WEIGHTS[signal.type];
182
- const category = signal.context.category;
183
- const trustTier = signal.context.trust_tier;
184
- const updated = { ...profile };
185
- updated.last_updated = Date.now();
186
- updated.signal_count++;
187
- // Update category weight
188
- if (category) {
189
- const currentWeight = updated.category_weights[category] ?? 0;
190
- const newWeight = this.clampWeight(currentWeight + weight * this.config.learning_rate);
191
- updated.category_weights = { ...updated.category_weights, [category]: newWeight };
192
- }
193
- // Update trust tier weight
194
- if (trustTier) {
195
- const currentWeight = updated.trust_tier_weights[trustTier] ?? 0;
196
- const newWeight = this.clampWeight(currentWeight + weight * this.config.learning_rate);
197
- updated.trust_tier_weights = { ...updated.trust_tier_weights, [trustTier]: newWeight };
198
- }
199
- // Track negative patterns for dismiss/uninstall
200
- if (signal.type === SignalType.DISMISS || signal.type === SignalType.UNINSTALL) {
201
- if (!updated.negative_patterns.skill_ids.includes(signal.skill_id)) {
202
- updated.negative_patterns = {
203
- ...updated.negative_patterns,
204
- skill_ids: [...updated.negative_patterns.skill_ids, signal.skill_id],
205
- };
206
- }
207
- }
208
- return updated;
209
- }
210
- async batchUpdateProfile(profile, signals) {
211
- let updated = profile;
212
- for (const signal of signals) {
213
- updated = await this.updateProfile(updated, signal);
214
- }
215
- return updated;
216
- }
217
- async decayWeights(profile, decayFactor) {
218
- const factor = decayFactor ?? this.config.decay_factor;
219
- const updated = { ...profile };
220
- // Decay category weights
221
- const newCategoryWeights = {};
222
- for (const [cat, weight] of Object.entries(updated.category_weights)) {
223
- newCategoryWeights[cat] = weight * factor;
224
- }
225
- updated.category_weights = newCategoryWeights;
226
- // Decay trust tier weights
227
- const newTrustWeights = {};
228
- for (const [tier, weight] of Object.entries(updated.trust_tier_weights)) {
229
- newTrustWeights[tier] = weight * factor;
230
- }
231
- updated.trust_tier_weights = newTrustWeights;
232
- // Decay keyword weights
233
- const newKeywordWeights = {};
234
- for (const [keyword, weight] of Object.entries(updated.keyword_weights)) {
235
- newKeywordWeights[keyword] = weight * factor;
236
- }
237
- updated.keyword_weights = newKeywordWeights;
238
- updated.last_updated = Date.now();
239
- return updated;
240
- }
241
- calculatePersonalizedScore(skillData, baseScore, profile) {
242
- let categoryBoost = 0;
243
- let trustBoost = 0;
244
- let keywordBoost = 0;
245
- let antiPenalty = 0;
246
- // Category boost
247
- if (skillData.category) {
248
- categoryBoost = profile.category_weights[skillData.category] ?? 0;
249
- }
250
- // Trust tier boost
251
- if (skillData.trustTier) {
252
- trustBoost = profile.trust_tier_weights[skillData.trustTier] ?? 0;
253
- }
254
- // Keyword boost
255
- if (skillData.keywords) {
256
- for (const kw of skillData.keywords) {
257
- keywordBoost += profile.keyword_weights[kw] ?? 0;
258
- }
259
- }
260
- // Anti-penalty for skills in negative patterns
261
- if (profile.negative_patterns.skill_ids.includes(skillData.id)) {
262
- antiPenalty = -0.5; // Strong penalty
263
- }
264
- // Calculate personalized score, clamped to [0, 1]
265
- const totalAdjustment = (categoryBoost + trustBoost + keywordBoost + antiPenalty) * 0.1;
266
- const personalizedScore = Math.max(0, Math.min(1, baseScore + totalAdjustment));
267
- return {
268
- skill_id: skillData.id,
269
- base_score: baseScore,
270
- personalized_score: personalizedScore,
271
- personalization_applied: profile.signal_count >= this.config.min_signals_threshold,
272
- score_breakdown: {
273
- category_boost: categoryBoost,
274
- trust_boost: trustBoost,
275
- keyword_boost: keywordBoost,
276
- anti_penalty: antiPenalty,
277
- },
278
- };
279
- }
280
- getConfig() {
281
- return { ...this.config };
282
- }
283
- setConfig(config) {
284
- this.config = { ...this.config, ...config };
285
- }
286
- clampWeight(weight) {
287
- return Math.max(this.config.weight_bounds.min, Math.min(this.config.weight_bounds.max, weight));
288
- }
289
- }
290
- /**
291
- * Mock implementation of IPersonalizationEngine for testing
292
- */
293
- export class MockPersonalizationEngine {
294
- learner;
295
- profileRepo;
296
- signalCollector;
297
- constructor(learner, profileRepo, signalCollector) {
298
- this.learner = learner;
299
- this.profileRepo = profileRepo;
300
- this.signalCollector = signalCollector;
301
- }
302
- async personalizeRecommendations(baseRecommendations, userId) {
303
- const profile = await this.getUserProfile(userId);
304
- const shouldApply = await this.shouldPersonalize(userId);
305
- const results = baseRecommendations.map((rec) => {
306
- const result = this.learner.calculatePersonalizedScore({ id: rec.skill_id, ...rec.skill_data }, rec.base_score, profile);
307
- // Only apply personalization if threshold met
308
- if (!shouldApply) {
309
- return {
310
- ...result,
311
- personalized_score: rec.base_score,
312
- personalization_applied: false,
313
- };
314
- }
315
- return result;
316
- });
317
- // Sort by personalized score descending
318
- return results.sort((a, b) => b.personalized_score - a.personalized_score);
319
- }
320
- /**
321
- * Determine if personalization should be applied.
322
- *
323
- * IMPORTANT: Mock Implementation Limitation
324
- * -----------------------------------------
325
- * This mock checks the GLOBAL signal count across all users, not the
326
- * per-user signal count. This is a simplification for testing purposes.
327
- *
328
- * In a real implementation, shouldPersonalize should:
329
- * 1. Look up the user's profile by userId
330
- * 2. Check that user's individual signal_count against the threshold
331
- * 3. Return true only if that specific user has enough signals
332
- *
333
- * The mock behavior works for single-user test scenarios but does not
334
- * accurately model multi-user environments where each user has their
335
- * own signal history and personalization threshold.
336
- *
337
- * @param _userId - User ID (ignored in mock - uses global count)
338
- * @returns Promise<boolean> - True if global signal count meets threshold
339
- */
340
- async shouldPersonalize(_userId) {
341
- const count = await this.signalCollector.getSignalCount();
342
- return count >= this.learner.getConfig().min_signals_threshold;
343
- }
344
- async getUserProfile(userId) {
345
- const profile = await this.profileRepo.getProfile(userId);
346
- return profile ?? createDefaultProfile();
347
- }
348
- async resetToDefault(userId) {
349
- await this.profileRepo.deleteProfile(userId);
350
- }
351
- }
352
- /**
353
- * Mock implementation of IPrivacyManager for testing
354
- */
355
- export class MockPrivacyManager {
356
- signalCollector;
357
- profileRepo;
358
- auditLog = [];
359
- constructor(signalCollector, profileRepo) {
360
- this.signalCollector = signalCollector;
361
- this.profileRepo = profileRepo;
362
- }
363
- async purgeOldSignals(retentionDays) {
364
- const cutoff = Date.now() - retentionDays * 24 * 60 * 60 * 1000;
365
- const deleted = this.signalCollector.removeOldSignals(cutoff);
366
- this.auditLog.push({
367
- operation: 'purgeOldSignals',
368
- timestamp: Date.now(),
369
- details: `Deleted ${deleted} signals older than ${retentionDays} days`,
370
- });
371
- return deleted;
372
- }
373
- async exportUserData() {
374
- const profile = (await this.profileRepo.getProfile()) ?? createDefaultProfile();
375
- const signals = this.signalCollector.getAllSignals();
376
- this.auditLog.push({
377
- operation: 'exportUserData',
378
- timestamp: Date.now(),
379
- });
380
- return {
381
- exported_at: Date.now(),
382
- version: profile.version,
383
- profile,
384
- signals,
385
- stats: [], // Simplified for testing
386
- };
387
- }
388
- async wipeAllData() {
389
- const signalCount = await this.signalCollector.getSignalCount();
390
- this.signalCollector.clear();
391
- await this.profileRepo.deleteProfile();
392
- this.auditLog.push({
393
- operation: 'wipeAllData',
394
- timestamp: Date.now(),
395
- details: `Wiped ${signalCount} signals and profile`,
396
- });
397
- return signalCount + 1; // signals + profile
398
- }
399
- async anonymizeForAnalytics() {
400
- const signals = this.signalCollector.getAllSignals();
401
- const signalCounts = {};
402
- const categoryCounts = new Map();
403
- for (const signal of signals) {
404
- signalCounts[signal.type] = (signalCounts[signal.type] ?? 0) + 1;
405
- const cat = signal.context.category;
406
- if (cat) {
407
- categoryCounts.set(cat, (categoryCounts.get(cat) ?? 0) + 1);
408
- }
409
- }
410
- const acceptCount = signalCounts[SignalType.ACCEPT] ?? 0;
411
- const dismissCount = signalCounts[SignalType.DISMISS] ?? 0;
412
- const acceptRate = acceptCount + dismissCount > 0 ? acceptCount / (acceptCount + dismissCount) : 0;
413
- return {
414
- date: new Date().toISOString().split('T')[0],
415
- total_signals: signals.length,
416
- signal_counts: signalCounts,
417
- avg_accept_rate: acceptRate,
418
- avg_utilization_rate: 0, // Simplified
419
- popular_categories: Array.from(categoryCounts.entries())
420
- .sort((a, b) => b[1] - a[1])
421
- .slice(0, 5)
422
- .map(([category, count]) => ({ category, count })),
423
- };
424
- }
425
- async getStorageSize() {
426
- const signals = this.signalCollector.getAllSignals();
427
- return JSON.stringify(signals).length; // Approximate size in bytes
428
- }
429
- /**
430
- * Verify that no PII (Personally Identifiable Information) is stored.
431
- *
432
- * Mock Implementation Details
433
- * ---------------------------
434
- * This mock always returns true because the test environment uses
435
- * controlled, synthetic data that never contains real PII.
436
- *
437
- * A real implementation should:
438
- * 1. Scan signal events for PII patterns (emails, names, IPs, etc.)
439
- * 2. Check that skill_id values don't contain user identifiers
440
- * 3. Verify context fields don't leak sensitive project paths
441
- * 4. Ensure keyword_weights don't contain personal identifiers
442
- * 5. Validate that exported data is properly anonymized
443
- *
444
- * The mock skips these checks since test data is constructed with
445
- * known-safe values (UUIDs, generic skill names, etc.).
446
- *
447
- * @returns Promise<boolean> - Always true in mock (no real PII checks)
448
- */
449
- async verifyPrivacy() {
450
- return true;
451
- }
452
- // Test helper to get audit log
453
- getAuditLog() {
454
- return [...this.auditLog];
455
- }
456
- /**
457
- * Clear the audit log.
458
- * Used in test cleanup to reset state between tests.
459
- */
460
- clearAuditLog() {
461
- this.auditLog = [];
462
- }
463
- }
464
- /**
465
- * Mock implementation of IUserPreferenceRepository for testing
466
- */
467
- export class MockUserPreferenceRepository {
468
- profiles = new Map();
469
- defaultUserId = 'default';
470
- async getProfile(userId) {
471
- return this.profiles.get(userId ?? this.defaultUserId) ?? null;
472
- }
473
- async saveProfile(profile, userId) {
474
- this.profiles.set(userId ?? this.defaultUserId, { ...profile });
475
- }
476
- async deleteProfile(userId) {
477
- this.profiles.delete(userId ?? this.defaultUserId);
478
- }
479
- async exists(userId) {
480
- return this.profiles.has(userId ?? this.defaultUserId);
481
- }
482
- // Test helper
483
- clear() {
484
- this.profiles.clear();
485
- }
486
- }
13
+ // Re-export fixtures
14
+ export { createDefaultProfile } from './neural-fixtures.js';
15
+ // Re-export test utilities
16
+ export { createNeuralTestContext, cleanupNeuralTestContext, } from './neural-test-utils.js';
17
+ // Re-export mock implementations
18
+ export { MockSignalCollector, MockPreferenceLearner, MockPersonalizationEngine, MockPrivacyManager, MockUserPreferenceRepository, } from './neural-mocks.js';
487
19
  //# sourceMappingURL=setup.js.map