@skillsmith/core 0.1.2 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (684) hide show
  1. package/README.md +235 -4
  2. package/dist/.tsbuildinfo +1 -1
  3. package/dist/src/analysis/CodebaseAnalyzer.d.ts +4 -134
  4. package/dist/src/analysis/CodebaseAnalyzer.d.ts.map +1 -1
  5. package/dist/src/analysis/CodebaseAnalyzer.js +7 -315
  6. package/dist/src/analysis/CodebaseAnalyzer.js.map +1 -1
  7. package/dist/src/analysis/__tests__/incremental.test.d.ts +13 -0
  8. package/dist/src/analysis/__tests__/incremental.test.d.ts.map +1 -0
  9. package/dist/src/analysis/__tests__/incremental.test.js +515 -0
  10. package/dist/src/analysis/__tests__/incremental.test.js.map +1 -0
  11. package/dist/src/analysis/__tests__/integration.test.d.ts +14 -0
  12. package/dist/src/analysis/__tests__/integration.test.d.ts.map +1 -0
  13. package/dist/src/analysis/__tests__/integration.test.js +1059 -0
  14. package/dist/src/analysis/__tests__/integration.test.js.map +1 -0
  15. package/dist/src/analysis/__tests__/metrics.test.d.ts +9 -0
  16. package/dist/src/analysis/__tests__/metrics.test.d.ts.map +1 -0
  17. package/dist/src/analysis/__tests__/metrics.test.js +369 -0
  18. package/dist/src/analysis/__tests__/metrics.test.js.map +1 -0
  19. package/dist/src/analysis/__tests__/performance.test.d.ts +15 -0
  20. package/dist/src/analysis/__tests__/performance.test.d.ts.map +1 -0
  21. package/dist/src/analysis/__tests__/performance.test.js +402 -0
  22. package/dist/src/analysis/__tests__/performance.test.js.map +1 -0
  23. package/dist/src/analysis/adapters/__tests__/go.test.d.ts +12 -0
  24. package/dist/src/analysis/adapters/__tests__/go.test.d.ts.map +1 -0
  25. package/dist/src/analysis/adapters/__tests__/go.test.js +561 -0
  26. package/dist/src/analysis/adapters/__tests__/go.test.js.map +1 -0
  27. package/dist/src/analysis/adapters/__tests__/python.test.d.ts +11 -0
  28. package/dist/src/analysis/adapters/__tests__/python.test.d.ts.map +1 -0
  29. package/dist/src/analysis/adapters/__tests__/python.test.js +669 -0
  30. package/dist/src/analysis/adapters/__tests__/python.test.js.map +1 -0
  31. package/dist/src/analysis/adapters/__tests__/rust.test.d.ts +12 -0
  32. package/dist/src/analysis/adapters/__tests__/rust.test.d.ts.map +1 -0
  33. package/dist/src/analysis/adapters/__tests__/rust.test.js +676 -0
  34. package/dist/src/analysis/adapters/__tests__/rust.test.js.map +1 -0
  35. package/dist/src/analysis/adapters/__tests__/typescript.test.d.ts +14 -0
  36. package/dist/src/analysis/adapters/__tests__/typescript.test.d.ts.map +1 -0
  37. package/dist/src/analysis/adapters/__tests__/typescript.test.js +381 -0
  38. package/dist/src/analysis/adapters/__tests__/typescript.test.js.map +1 -0
  39. package/dist/src/analysis/adapters/base.d.ts +83 -0
  40. package/dist/src/analysis/adapters/base.d.ts.map +1 -0
  41. package/dist/src/analysis/adapters/base.js +40 -0
  42. package/dist/src/analysis/adapters/base.js.map +1 -0
  43. package/dist/src/analysis/adapters/factory.d.ts +150 -0
  44. package/dist/src/analysis/adapters/factory.d.ts.map +1 -0
  45. package/dist/src/analysis/adapters/factory.js +244 -0
  46. package/dist/src/analysis/adapters/factory.js.map +1 -0
  47. package/dist/src/analysis/adapters/go.d.ts +131 -0
  48. package/dist/src/analysis/adapters/go.d.ts.map +1 -0
  49. package/dist/src/analysis/adapters/go.js +414 -0
  50. package/dist/src/analysis/adapters/go.js.map +1 -0
  51. package/dist/src/analysis/adapters/index.d.ts +20 -0
  52. package/dist/src/analysis/adapters/index.d.ts.map +1 -0
  53. package/dist/src/analysis/adapters/index.js +23 -0
  54. package/dist/src/analysis/adapters/index.js.map +1 -0
  55. package/dist/src/analysis/adapters/java.d.ts +154 -0
  56. package/dist/src/analysis/adapters/java.d.ts.map +1 -0
  57. package/dist/src/analysis/adapters/java.js +407 -0
  58. package/dist/src/analysis/adapters/java.js.map +1 -0
  59. package/dist/src/analysis/adapters/python.d.ts +165 -0
  60. package/dist/src/analysis/adapters/python.d.ts.map +1 -0
  61. package/dist/src/analysis/adapters/python.js +475 -0
  62. package/dist/src/analysis/adapters/python.js.map +1 -0
  63. package/dist/src/analysis/adapters/rust.d.ts +116 -0
  64. package/dist/src/analysis/adapters/rust.d.ts.map +1 -0
  65. package/dist/src/analysis/adapters/rust.js +476 -0
  66. package/dist/src/analysis/adapters/rust.js.map +1 -0
  67. package/dist/src/analysis/adapters/typescript.d.ts +68 -0
  68. package/dist/src/analysis/adapters/typescript.d.ts.map +1 -0
  69. package/dist/src/analysis/adapters/typescript.js +79 -0
  70. package/dist/src/analysis/adapters/typescript.js.map +1 -0
  71. package/dist/src/analysis/aggregator.d.ts +193 -0
  72. package/dist/src/analysis/aggregator.d.ts.map +1 -0
  73. package/dist/src/analysis/aggregator.js +283 -0
  74. package/dist/src/analysis/aggregator.js.map +1 -0
  75. package/dist/src/analysis/cache.d.ts +180 -0
  76. package/dist/src/analysis/cache.d.ts.map +1 -0
  77. package/dist/src/analysis/cache.js +279 -0
  78. package/dist/src/analysis/cache.js.map +1 -0
  79. package/dist/src/analysis/file-streamer.d.ts +136 -0
  80. package/dist/src/analysis/file-streamer.d.ts.map +1 -0
  81. package/dist/src/analysis/file-streamer.js +291 -0
  82. package/dist/src/analysis/file-streamer.js.map +1 -0
  83. package/dist/src/analysis/framework-detector.d.ts +47 -0
  84. package/dist/src/analysis/framework-detector.d.ts.map +1 -0
  85. package/dist/src/analysis/framework-detector.js +151 -0
  86. package/dist/src/analysis/framework-detector.js.map +1 -0
  87. package/dist/src/analysis/incremental-parser.d.ts +186 -0
  88. package/dist/src/analysis/incremental-parser.d.ts.map +1 -0
  89. package/dist/src/analysis/incremental-parser.js +291 -0
  90. package/dist/src/analysis/incremental-parser.js.map +1 -0
  91. package/dist/src/analysis/incremental.d.ts +186 -0
  92. package/dist/src/analysis/incremental.d.ts.map +1 -0
  93. package/dist/src/analysis/incremental.js +247 -0
  94. package/dist/src/analysis/incremental.js.map +1 -0
  95. package/dist/src/analysis/index.d.ts +29 -2
  96. package/dist/src/analysis/index.d.ts.map +1 -1
  97. package/dist/src/analysis/index.js +53 -2
  98. package/dist/src/analysis/index.js.map +1 -1
  99. package/dist/src/analysis/language-detector.d.ts +92 -0
  100. package/dist/src/analysis/language-detector.d.ts.map +1 -0
  101. package/dist/src/analysis/language-detector.js +602 -0
  102. package/dist/src/analysis/language-detector.js.map +1 -0
  103. package/dist/src/analysis/memory-monitor.d.ts +199 -0
  104. package/dist/src/analysis/memory-monitor.d.ts.map +1 -0
  105. package/dist/src/analysis/memory-monitor.js +271 -0
  106. package/dist/src/analysis/memory-monitor.js.map +1 -0
  107. package/dist/src/analysis/metrics.d.ts +300 -0
  108. package/dist/src/analysis/metrics.d.ts.map +1 -0
  109. package/dist/src/analysis/metrics.js +537 -0
  110. package/dist/src/analysis/metrics.js.map +1 -0
  111. package/dist/src/analysis/parsers.d.ts +43 -0
  112. package/dist/src/analysis/parsers.d.ts.map +1 -0
  113. package/dist/src/analysis/parsers.js +219 -0
  114. package/dist/src/analysis/parsers.js.map +1 -0
  115. package/dist/src/analysis/router.d.ts +264 -0
  116. package/dist/src/analysis/router.d.ts.map +1 -0
  117. package/dist/src/analysis/router.js +398 -0
  118. package/dist/src/analysis/router.js.map +1 -0
  119. package/dist/src/analysis/tree-cache.d.ts +208 -0
  120. package/dist/src/analysis/tree-cache.d.ts.map +1 -0
  121. package/dist/src/analysis/tree-cache.js +288 -0
  122. package/dist/src/analysis/tree-cache.js.map +1 -0
  123. package/dist/src/analysis/tree-sitter/manager.d.ts +141 -0
  124. package/dist/src/analysis/tree-sitter/manager.d.ts.map +1 -0
  125. package/dist/src/analysis/tree-sitter/manager.js +239 -0
  126. package/dist/src/analysis/tree-sitter/manager.js.map +1 -0
  127. package/dist/src/analysis/types.d.ts +203 -0
  128. package/dist/src/analysis/types.d.ts.map +1 -0
  129. package/dist/src/analysis/types.js +58 -0
  130. package/dist/src/analysis/types.js.map +1 -0
  131. package/dist/src/analysis/worker-pool.d.ts +141 -0
  132. package/dist/src/analysis/worker-pool.d.ts.map +1 -0
  133. package/dist/src/analysis/worker-pool.js +418 -0
  134. package/dist/src/analysis/worker-pool.js.map +1 -0
  135. package/dist/src/analytics/AnalyticsRepository.d.ts +4 -0
  136. package/dist/src/analytics/AnalyticsRepository.d.ts.map +1 -1
  137. package/dist/src/analytics/AnalyticsRepository.js +30 -48
  138. package/dist/src/analytics/AnalyticsRepository.js.map +1 -1
  139. package/dist/src/analytics/schema.d.ts +1 -1
  140. package/dist/src/analytics/schema.d.ts.map +1 -1
  141. package/dist/src/analytics/schema.js +140 -0
  142. package/dist/src/analytics/schema.js.map +1 -1
  143. package/dist/src/api/cache.d.ts +131 -0
  144. package/dist/src/api/cache.d.ts.map +1 -0
  145. package/dist/src/api/cache.js +264 -0
  146. package/dist/src/api/cache.js.map +1 -0
  147. package/dist/src/api/client.d.ts +286 -0
  148. package/dist/src/api/client.d.ts.map +1 -0
  149. package/dist/src/api/client.js +422 -0
  150. package/dist/src/api/client.js.map +1 -0
  151. package/dist/src/api/index.d.ts +12 -0
  152. package/dist/src/api/index.d.ts.map +1 -0
  153. package/dist/src/api/index.js +17 -0
  154. package/dist/src/api/index.js.map +1 -0
  155. package/dist/src/api/types.d.ts +251 -0
  156. package/dist/src/api/types.d.ts.map +1 -0
  157. package/dist/src/api/types.js +9 -0
  158. package/dist/src/api/types.js.map +1 -0
  159. package/dist/src/benchmarks/BenchmarkRunner.d.ts +6 -175
  160. package/dist/src/benchmarks/BenchmarkRunner.d.ts.map +1 -1
  161. package/dist/src/benchmarks/BenchmarkRunner.js +6 -123
  162. package/dist/src/benchmarks/BenchmarkRunner.js.map +1 -1
  163. package/dist/src/benchmarks/MemoryProfiler.d.ts +4 -262
  164. package/dist/src/benchmarks/MemoryProfiler.d.ts.map +1 -1
  165. package/dist/src/benchmarks/MemoryProfiler.js +4 -400
  166. package/dist/src/benchmarks/MemoryProfiler.js.map +1 -1
  167. package/dist/src/benchmarks/comparator.d.ts +38 -0
  168. package/dist/src/benchmarks/comparator.d.ts.map +1 -0
  169. package/dist/src/benchmarks/comparator.js +81 -0
  170. package/dist/src/benchmarks/comparator.js.map +1 -0
  171. package/dist/src/benchmarks/formatters.d.ts +30 -0
  172. package/dist/src/benchmarks/formatters.d.ts.map +1 -0
  173. package/dist/src/benchmarks/formatters.js +88 -0
  174. package/dist/src/benchmarks/formatters.js.map +1 -0
  175. package/dist/src/benchmarks/index.d.ts +5 -1
  176. package/dist/src/benchmarks/index.d.ts.map +1 -1
  177. package/dist/src/benchmarks/index.js +9 -2
  178. package/dist/src/benchmarks/index.js.map +1 -1
  179. package/dist/src/benchmarks/memory/MemoryProfiler.d.ts +165 -0
  180. package/dist/src/benchmarks/memory/MemoryProfiler.d.ts.map +1 -0
  181. package/dist/src/benchmarks/memory/MemoryProfiler.js +312 -0
  182. package/dist/src/benchmarks/memory/MemoryProfiler.js.map +1 -0
  183. package/dist/src/benchmarks/memory/baseline-manager.d.ts +64 -0
  184. package/dist/src/benchmarks/memory/baseline-manager.d.ts.map +1 -0
  185. package/dist/src/benchmarks/memory/baseline-manager.js +95 -0
  186. package/dist/src/benchmarks/memory/baseline-manager.js.map +1 -0
  187. package/dist/src/benchmarks/memory/index.d.ts +12 -0
  188. package/dist/src/benchmarks/memory/index.d.ts.map +1 -0
  189. package/dist/src/benchmarks/memory/index.js +12 -0
  190. package/dist/src/benchmarks/memory/index.js.map +1 -0
  191. package/dist/src/benchmarks/memory/leak-detector.d.ts +23 -0
  192. package/dist/src/benchmarks/memory/leak-detector.d.ts.map +1 -0
  193. package/dist/src/benchmarks/memory/leak-detector.js +46 -0
  194. package/dist/src/benchmarks/memory/leak-detector.js.map +1 -0
  195. package/dist/src/benchmarks/memory/regression-detector.d.ts +17 -0
  196. package/dist/src/benchmarks/memory/regression-detector.d.ts.map +1 -0
  197. package/dist/src/benchmarks/memory/regression-detector.js +56 -0
  198. package/dist/src/benchmarks/memory/regression-detector.js.map +1 -0
  199. package/dist/src/benchmarks/memory/types.d.ts +111 -0
  200. package/dist/src/benchmarks/memory/types.d.ts.map +1 -0
  201. package/dist/src/benchmarks/memory/types.js +7 -0
  202. package/dist/src/benchmarks/memory/types.js.map +1 -0
  203. package/dist/src/benchmarks/memory/utils.d.ts +17 -0
  204. package/dist/src/benchmarks/memory/utils.d.ts.map +1 -0
  205. package/dist/src/benchmarks/memory/utils.js +29 -0
  206. package/dist/src/benchmarks/memory/utils.js.map +1 -0
  207. package/dist/src/benchmarks/types.d.ts +175 -0
  208. package/dist/src/benchmarks/types.d.ts.map +1 -0
  209. package/dist/src/benchmarks/types.js +20 -0
  210. package/dist/src/benchmarks/types.js.map +1 -0
  211. package/dist/src/billing/BillingService.d.ts +139 -0
  212. package/dist/src/billing/BillingService.d.ts.map +1 -0
  213. package/dist/src/billing/BillingService.js +393 -0
  214. package/dist/src/billing/BillingService.js.map +1 -0
  215. package/dist/src/billing/GDPRComplianceService.d.ts +176 -0
  216. package/dist/src/billing/GDPRComplianceService.d.ts.map +1 -0
  217. package/dist/src/billing/GDPRComplianceService.js +361 -0
  218. package/dist/src/billing/GDPRComplianceService.js.map +1 -0
  219. package/dist/src/billing/StripeClient.d.ts +177 -0
  220. package/dist/src/billing/StripeClient.d.ts.map +1 -0
  221. package/dist/src/billing/StripeClient.js +462 -0
  222. package/dist/src/billing/StripeClient.js.map +1 -0
  223. package/dist/src/billing/StripeReconciliationJob.d.ts +95 -0
  224. package/dist/src/billing/StripeReconciliationJob.d.ts.map +1 -0
  225. package/dist/src/billing/StripeReconciliationJob.js +405 -0
  226. package/dist/src/billing/StripeReconciliationJob.js.map +1 -0
  227. package/dist/src/billing/StripeWebhookHandler.d.ts +92 -0
  228. package/dist/src/billing/StripeWebhookHandler.d.ts.map +1 -0
  229. package/dist/src/billing/StripeWebhookHandler.js +409 -0
  230. package/dist/src/billing/StripeWebhookHandler.js.map +1 -0
  231. package/dist/src/billing/index.d.ts +18 -0
  232. package/dist/src/billing/index.d.ts.map +1 -0
  233. package/dist/src/billing/index.js +19 -0
  234. package/dist/src/billing/index.js.map +1 -0
  235. package/dist/src/billing/types.d.ts +266 -0
  236. package/dist/src/billing/types.d.ts.map +1 -0
  237. package/dist/src/billing/types.js +23 -0
  238. package/dist/src/billing/types.js.map +1 -0
  239. package/dist/src/db/schema.d.ts +1 -1
  240. package/dist/src/db/schema.d.ts.map +1 -1
  241. package/dist/src/db/schema.js +41 -1
  242. package/dist/src/db/schema.js.map +1 -1
  243. package/dist/src/embeddings/hnsw-store.d.ts +568 -0
  244. package/dist/src/embeddings/hnsw-store.d.ts.map +1 -0
  245. package/dist/src/embeddings/hnsw-store.js +805 -0
  246. package/dist/src/embeddings/hnsw-store.js.map +1 -0
  247. package/dist/src/embeddings/index.d.ts +2 -0
  248. package/dist/src/embeddings/index.d.ts.map +1 -1
  249. package/dist/src/embeddings/index.js +2 -0
  250. package/dist/src/embeddings/index.js.map +1 -1
  251. package/dist/src/errors.d.ts +1 -0
  252. package/dist/src/errors.d.ts.map +1 -1
  253. package/dist/src/errors.js +1 -0
  254. package/dist/src/errors.js.map +1 -1
  255. package/dist/src/index.d.ts +7 -3
  256. package/dist/src/index.d.ts.map +1 -1
  257. package/dist/src/index.js +12 -4
  258. package/dist/src/index.js.map +1 -1
  259. package/dist/src/learning/PatternStore.d.ts +457 -0
  260. package/dist/src/learning/PatternStore.d.ts.map +1 -0
  261. package/dist/src/learning/PatternStore.js +893 -0
  262. package/dist/src/learning/PatternStore.js.map +1 -0
  263. package/dist/src/learning/ReasoningBankIntegration.d.ts +403 -0
  264. package/dist/src/learning/ReasoningBankIntegration.d.ts.map +1 -0
  265. package/dist/src/learning/ReasoningBankIntegration.js +627 -0
  266. package/dist/src/learning/ReasoningBankIntegration.js.map +1 -0
  267. package/dist/src/learning/index.d.ts +15 -0
  268. package/dist/src/learning/index.d.ts.map +1 -0
  269. package/dist/src/learning/index.js +15 -0
  270. package/dist/src/learning/index.js.map +1 -0
  271. package/dist/src/repositories/IndexerRepository.d.ts.map +1 -1
  272. package/dist/src/repositories/IndexerRepository.js +1 -0
  273. package/dist/src/repositories/IndexerRepository.js.map +1 -1
  274. package/dist/src/repositories/QuarantineRepository.d.ts +4 -251
  275. package/dist/src/repositories/QuarantineRepository.d.ts.map +1 -1
  276. package/dist/src/repositories/QuarantineRepository.js +4 -441
  277. package/dist/src/repositories/QuarantineRepository.js.map +1 -1
  278. package/dist/src/repositories/SkillRepository.d.ts.map +1 -1
  279. package/dist/src/repositories/SkillRepository.js +1 -0
  280. package/dist/src/repositories/SkillRepository.js.map +1 -1
  281. package/dist/src/repositories/SyncConfigRepository.d.ts +91 -0
  282. package/dist/src/repositories/SyncConfigRepository.d.ts.map +1 -0
  283. package/dist/src/repositories/SyncConfigRepository.js +202 -0
  284. package/dist/src/repositories/SyncConfigRepository.js.map +1 -0
  285. package/dist/src/repositories/SyncHistoryRepository.d.ts +104 -0
  286. package/dist/src/repositories/SyncHistoryRepository.d.ts.map +1 -0
  287. package/dist/src/repositories/SyncHistoryRepository.js +235 -0
  288. package/dist/src/repositories/SyncHistoryRepository.js.map +1 -0
  289. package/dist/src/repositories/quarantine/QuarantineRepository.d.ts +168 -0
  290. package/dist/src/repositories/quarantine/QuarantineRepository.d.ts.map +1 -0
  291. package/dist/src/repositories/quarantine/QuarantineRepository.js +341 -0
  292. package/dist/src/repositories/quarantine/QuarantineRepository.js.map +1 -0
  293. package/dist/src/repositories/quarantine/index.d.ts +10 -0
  294. package/dist/src/repositories/quarantine/index.d.ts.map +1 -0
  295. package/dist/src/repositories/quarantine/index.js +10 -0
  296. package/dist/src/repositories/quarantine/index.js.map +1 -0
  297. package/dist/src/repositories/quarantine/queries.d.ts +58 -0
  298. package/dist/src/repositories/quarantine/queries.d.ts.map +1 -0
  299. package/dist/src/repositories/quarantine/queries.js +88 -0
  300. package/dist/src/repositories/quarantine/queries.js.map +1 -0
  301. package/dist/src/repositories/quarantine/query-builder.d.ts +44 -0
  302. package/dist/src/repositories/quarantine/query-builder.d.ts.map +1 -0
  303. package/dist/src/repositories/quarantine/query-builder.js +87 -0
  304. package/dist/src/repositories/quarantine/query-builder.js.map +1 -0
  305. package/dist/src/repositories/quarantine/types.d.ts +155 -0
  306. package/dist/src/repositories/quarantine/types.d.ts.map +1 -0
  307. package/dist/src/repositories/quarantine/types.js +13 -0
  308. package/dist/src/repositories/quarantine/types.js.map +1 -0
  309. package/dist/src/routing/SONARouter.d.ts +154 -0
  310. package/dist/src/routing/SONARouter.d.ts.map +1 -0
  311. package/dist/src/routing/SONARouter.js +679 -0
  312. package/dist/src/routing/SONARouter.js.map +1 -0
  313. package/dist/src/routing/index.d.ts +9 -0
  314. package/dist/src/routing/index.d.ts.map +1 -0
  315. package/dist/src/routing/index.js +10 -0
  316. package/dist/src/routing/index.js.map +1 -0
  317. package/dist/src/routing/types.d.ts +331 -0
  318. package/dist/src/routing/types.d.ts.map +1 -0
  319. package/dist/src/routing/types.js +203 -0
  320. package/dist/src/routing/types.js.map +1 -0
  321. package/dist/src/scripts/__tests__/scan-imported-skills.test.d.ts +1 -0
  322. package/dist/src/scripts/__tests__/scan-imported-skills.test.d.ts.map +1 -1
  323. package/dist/src/scripts/__tests__/scan-imported-skills.test.js +12 -43
  324. package/dist/src/scripts/__tests__/scan-imported-skills.test.js.map +1 -1
  325. package/dist/src/scripts/github-import/checkpoint.d.ts +21 -0
  326. package/dist/src/scripts/github-import/checkpoint.d.ts.map +1 -0
  327. package/dist/src/scripts/github-import/checkpoint.js +52 -0
  328. package/dist/src/scripts/github-import/checkpoint.js.map +1 -0
  329. package/dist/src/scripts/github-import/deduplication.d.ts +15 -0
  330. package/dist/src/scripts/github-import/deduplication.d.ts.map +1 -0
  331. package/dist/src/scripts/github-import/deduplication.js +33 -0
  332. package/dist/src/scripts/github-import/deduplication.js.map +1 -0
  333. package/dist/src/scripts/github-import/github-client.d.ts +57 -0
  334. package/dist/src/scripts/github-import/github-client.d.ts.map +1 -0
  335. package/dist/src/scripts/github-import/github-client.js +473 -0
  336. package/dist/src/scripts/github-import/github-client.js.map +1 -0
  337. package/dist/src/scripts/github-import/index.d.ts +29 -0
  338. package/dist/src/scripts/github-import/index.d.ts.map +1 -0
  339. package/dist/src/scripts/github-import/index.js +191 -0
  340. package/dist/src/scripts/github-import/index.js.map +1 -0
  341. package/dist/src/scripts/github-import/output.d.ts +12 -0
  342. package/dist/src/scripts/github-import/output.d.ts.map +1 -0
  343. package/dist/src/scripts/github-import/output.js +34 -0
  344. package/dist/src/scripts/github-import/output.js.map +1 -0
  345. package/dist/src/scripts/github-import/types.d.ts +114 -0
  346. package/dist/src/scripts/github-import/types.d.ts.map +1 -0
  347. package/dist/src/scripts/github-import/types.js +47 -0
  348. package/dist/src/scripts/github-import/types.js.map +1 -0
  349. package/dist/src/scripts/github-import/utils.d.ts +13 -0
  350. package/dist/src/scripts/github-import/utils.d.ts.map +1 -0
  351. package/dist/src/scripts/github-import/utils.js +28 -0
  352. package/dist/src/scripts/github-import/utils.js.map +1 -0
  353. package/dist/src/scripts/import-github-skills.d.ts +3 -12
  354. package/dist/src/scripts/import-github-skills.d.ts.map +1 -1
  355. package/dist/src/scripts/import-github-skills.js +27 -402
  356. package/dist/src/scripts/import-github-skills.js.map +1 -1
  357. package/dist/src/scripts/merge-skills.d.ts +56 -0
  358. package/dist/src/scripts/merge-skills.d.ts.map +1 -0
  359. package/dist/src/scripts/merge-skills.js +411 -0
  360. package/dist/src/scripts/merge-skills.js.map +1 -0
  361. package/dist/src/scripts/scan-imported-skills.d.ts +7 -7
  362. package/dist/src/scripts/scan-imported-skills.d.ts.map +1 -1
  363. package/dist/src/scripts/scan-imported-skills.js +8 -397
  364. package/dist/src/scripts/scan-imported-skills.js.map +1 -1
  365. package/dist/src/scripts/skill-scanner/categorizer.d.ts +43 -0
  366. package/dist/src/scripts/skill-scanner/categorizer.d.ts.map +1 -0
  367. package/dist/src/scripts/skill-scanner/categorizer.js +61 -0
  368. package/dist/src/scripts/skill-scanner/categorizer.js.map +1 -0
  369. package/dist/src/scripts/skill-scanner/file-scanner.d.ts +43 -0
  370. package/dist/src/scripts/skill-scanner/file-scanner.d.ts.map +1 -0
  371. package/dist/src/scripts/skill-scanner/file-scanner.js +90 -0
  372. package/dist/src/scripts/skill-scanner/file-scanner.js.map +1 -0
  373. package/dist/src/scripts/skill-scanner/index.d.ts +29 -0
  374. package/dist/src/scripts/skill-scanner/index.d.ts.map +1 -0
  375. package/dist/src/scripts/skill-scanner/index.js +134 -0
  376. package/dist/src/scripts/skill-scanner/index.js.map +1 -0
  377. package/dist/src/scripts/skill-scanner/logger.d.ts +110 -0
  378. package/dist/src/scripts/skill-scanner/logger.d.ts.map +1 -0
  379. package/dist/src/scripts/skill-scanner/logger.js +358 -0
  380. package/dist/src/scripts/skill-scanner/logger.js.map +1 -0
  381. package/dist/src/scripts/skill-scanner/reporter.d.ts +56 -0
  382. package/dist/src/scripts/skill-scanner/reporter.d.ts.map +1 -0
  383. package/dist/src/scripts/skill-scanner/reporter.js +218 -0
  384. package/dist/src/scripts/skill-scanner/reporter.js.map +1 -0
  385. package/dist/src/scripts/skill-scanner/scanner.d.ts +47 -0
  386. package/dist/src/scripts/skill-scanner/scanner.d.ts.map +1 -0
  387. package/dist/src/scripts/skill-scanner/scanner.js +257 -0
  388. package/dist/src/scripts/skill-scanner/scanner.js.map +1 -0
  389. package/dist/src/scripts/skill-scanner/trust-scorer.d.ts +59 -0
  390. package/dist/src/scripts/skill-scanner/trust-scorer.d.ts.map +1 -0
  391. package/dist/src/scripts/skill-scanner/trust-scorer.js +62 -0
  392. package/dist/src/scripts/skill-scanner/trust-scorer.js.map +1 -0
  393. package/dist/src/scripts/skill-scanner/types.d.ts +142 -0
  394. package/dist/src/scripts/skill-scanner/types.d.ts.map +1 -0
  395. package/dist/src/scripts/skill-scanner/types.js +7 -0
  396. package/dist/src/scripts/skill-scanner/types.js.map +1 -0
  397. package/dist/src/scripts/validate-skills.d.ts +3 -172
  398. package/dist/src/scripts/validate-skills.d.ts.map +1 -1
  399. package/dist/src/scripts/validate-skills.js +6 -519
  400. package/dist/src/scripts/validate-skills.js.map +1 -1
  401. package/dist/src/scripts/validation/deduplication.d.ts +23 -0
  402. package/dist/src/scripts/validation/deduplication.d.ts.map +1 -0
  403. package/dist/src/scripts/validation/deduplication.js +127 -0
  404. package/dist/src/scripts/validation/deduplication.js.map +1 -0
  405. package/dist/src/scripts/validation/field-validators.d.ts +9 -0
  406. package/dist/src/scripts/validation/field-validators.d.ts.map +1 -0
  407. package/dist/src/scripts/validation/field-validators.js +135 -0
  408. package/dist/src/scripts/validation/field-validators.js.map +1 -0
  409. package/dist/src/scripts/validation/index.d.ts +29 -0
  410. package/dist/src/scripts/validation/index.d.ts.map +1 -0
  411. package/dist/src/scripts/validation/index.js +83 -0
  412. package/dist/src/scripts/validation/index.js.map +1 -0
  413. package/dist/src/scripts/validation/normalizers.d.ts +29 -0
  414. package/dist/src/scripts/validation/normalizers.d.ts.map +1 -0
  415. package/dist/src/scripts/validation/normalizers.js +79 -0
  416. package/dist/src/scripts/validation/normalizers.js.map +1 -0
  417. package/dist/src/scripts/validation/pipeline.d.ts +13 -0
  418. package/dist/src/scripts/validation/pipeline.d.ts.map +1 -0
  419. package/dist/src/scripts/validation/pipeline.js +126 -0
  420. package/dist/src/scripts/validation/pipeline.js.map +1 -0
  421. package/dist/src/scripts/validation/types.d.ts +128 -0
  422. package/dist/src/scripts/validation/types.d.ts.map +1 -0
  423. package/dist/src/scripts/validation/types.js +43 -0
  424. package/dist/src/scripts/validation/types.js.map +1 -0
  425. package/dist/src/security/SkillSandbox.d.ts +156 -0
  426. package/dist/src/security/SkillSandbox.d.ts.map +1 -0
  427. package/dist/src/security/SkillSandbox.js +303 -0
  428. package/dist/src/security/SkillSandbox.js.map +1 -0
  429. package/dist/src/security/index.d.ts +8 -5
  430. package/dist/src/security/index.d.ts.map +1 -1
  431. package/dist/src/security/index.js +13 -3
  432. package/dist/src/security/index.js.map +1 -1
  433. package/dist/src/security/rate-limiter/RateLimiter.d.ts +86 -0
  434. package/dist/src/security/rate-limiter/RateLimiter.d.ts.map +1 -0
  435. package/dist/src/security/rate-limiter/RateLimiter.js +260 -0
  436. package/dist/src/security/rate-limiter/RateLimiter.js.map +1 -0
  437. package/dist/src/security/rate-limiter/constants.d.ts +15 -0
  438. package/dist/src/security/rate-limiter/constants.d.ts.map +1 -0
  439. package/dist/src/security/rate-limiter/constants.js +15 -0
  440. package/dist/src/security/rate-limiter/constants.js.map +1 -0
  441. package/dist/src/security/rate-limiter/errors.d.ts +22 -0
  442. package/dist/src/security/rate-limiter/errors.d.ts.map +1 -0
  443. package/dist/src/security/rate-limiter/errors.js +32 -0
  444. package/dist/src/security/rate-limiter/errors.js.map +1 -0
  445. package/dist/src/security/rate-limiter/index.d.ts +12 -0
  446. package/dist/src/security/rate-limiter/index.d.ts.map +1 -0
  447. package/dist/src/security/rate-limiter/index.js +16 -0
  448. package/dist/src/security/rate-limiter/index.js.map +1 -0
  449. package/dist/src/security/rate-limiter/metrics-manager.d.ts +55 -0
  450. package/dist/src/security/rate-limiter/metrics-manager.d.ts.map +1 -0
  451. package/dist/src/security/rate-limiter/metrics-manager.js +144 -0
  452. package/dist/src/security/rate-limiter/metrics-manager.js.map +1 -0
  453. package/dist/src/security/rate-limiter/presets.d.ts +64 -0
  454. package/dist/src/security/rate-limiter/presets.d.ts.map +1 -0
  455. package/dist/src/security/rate-limiter/presets.js +65 -0
  456. package/dist/src/security/rate-limiter/presets.js.map +1 -0
  457. package/dist/src/security/rate-limiter/queue-manager.d.ts +59 -0
  458. package/dist/src/security/rate-limiter/queue-manager.d.ts.map +1 -0
  459. package/dist/src/security/rate-limiter/queue-manager.js +189 -0
  460. package/dist/src/security/rate-limiter/queue-manager.js.map +1 -0
  461. package/dist/src/security/rate-limiter/storage.d.ts +34 -0
  462. package/dist/src/security/rate-limiter/storage.d.ts.map +1 -0
  463. package/dist/src/security/rate-limiter/storage.js +80 -0
  464. package/dist/src/security/rate-limiter/storage.js.map +1 -0
  465. package/dist/src/security/rate-limiter/token-bucket.d.ts +44 -0
  466. package/dist/src/security/rate-limiter/token-bucket.d.ts.map +1 -0
  467. package/dist/src/security/rate-limiter/token-bucket.js +99 -0
  468. package/dist/src/security/rate-limiter/token-bucket.js.map +1 -0
  469. package/dist/src/security/rate-limiter/types.d.ts +104 -0
  470. package/dist/src/security/rate-limiter/types.d.ts.map +1 -0
  471. package/dist/src/security/rate-limiter/types.js +7 -0
  472. package/dist/src/security/rate-limiter/types.js.map +1 -0
  473. package/dist/src/security/sanitization.d.ts +85 -0
  474. package/dist/src/security/sanitization.d.ts.map +1 -1
  475. package/dist/src/security/sanitization.js +133 -0
  476. package/dist/src/security/sanitization.js.map +1 -1
  477. package/dist/src/security/{scanner.d.ts → scanner/SecurityScanner.d.ts} +28 -62
  478. package/dist/src/security/scanner/SecurityScanner.d.ts.map +1 -0
  479. package/dist/src/security/{scanner.js → scanner/SecurityScanner.js} +230 -222
  480. package/dist/src/security/scanner/SecurityScanner.js.map +1 -0
  481. package/dist/src/security/scanner/index.d.ts +11 -0
  482. package/dist/src/security/scanner/index.d.ts.map +1 -0
  483. package/dist/src/security/scanner/index.js +14 -0
  484. package/dist/src/security/scanner/index.js.map +1 -0
  485. package/dist/src/security/scanner/patterns.d.ts +27 -0
  486. package/dist/src/security/scanner/patterns.d.ts.map +1 -0
  487. package/dist/src/security/scanner/patterns.js +198 -0
  488. package/dist/src/security/scanner/patterns.js.map +1 -0
  489. package/dist/src/security/scanner/regex-utils.d.ts +33 -0
  490. package/dist/src/security/scanner/regex-utils.d.ts.map +1 -0
  491. package/dist/src/security/scanner/regex-utils.js +41 -0
  492. package/dist/src/security/scanner/regex-utils.js.map +1 -0
  493. package/dist/src/security/scanner/types.d.ts +75 -0
  494. package/dist/src/security/scanner/types.d.ts.map +1 -0
  495. package/dist/src/security/scanner/types.js +7 -0
  496. package/dist/src/security/scanner/types.js.map +1 -0
  497. package/dist/src/security/scanner/weights.d.ts +15 -0
  498. package/dist/src/security/scanner/weights.d.ts.map +1 -0
  499. package/dist/src/security/scanner/weights.js +29 -0
  500. package/dist/src/security/scanner/weights.js.map +1 -0
  501. package/dist/src/services/SearchService.d.ts.map +1 -1
  502. package/dist/src/services/SearchService.js +1 -0
  503. package/dist/src/services/SearchService.js.map +1 -1
  504. package/dist/src/session/SessionHealthMonitor.d.ts +5 -168
  505. package/dist/src/session/SessionHealthMonitor.d.ts.map +1 -1
  506. package/dist/src/session/SessionHealthMonitor.js +22 -91
  507. package/dist/src/session/SessionHealthMonitor.js.map +1 -1
  508. package/dist/src/session/SessionManager.d.ts +7 -0
  509. package/dist/src/session/SessionManager.d.ts.map +1 -1
  510. package/dist/src/session/SessionManager.js +117 -10
  511. package/dist/src/session/SessionManager.js.map +1 -1
  512. package/dist/src/session/health-checks.d.ts +37 -0
  513. package/dist/src/session/health-checks.d.ts.map +1 -0
  514. package/dist/src/session/health-checks.js +64 -0
  515. package/dist/src/session/health-checks.js.map +1 -0
  516. package/dist/src/session/health-types.d.ts +78 -0
  517. package/dist/src/session/health-types.d.ts.map +1 -0
  518. package/dist/src/session/health-types.js +16 -0
  519. package/dist/src/session/health-types.js.map +1 -0
  520. package/dist/src/session/index.d.ts +5 -1
  521. package/dist/src/session/index.d.ts.map +1 -1
  522. package/dist/src/session/index.js +9 -0
  523. package/dist/src/session/index.js.map +1 -1
  524. package/dist/src/session/metrics-collector.d.ts +23 -0
  525. package/dist/src/session/metrics-collector.d.ts.map +1 -0
  526. package/dist/src/session/metrics-collector.js +44 -0
  527. package/dist/src/session/metrics-collector.js.map +1 -0
  528. package/dist/src/session/typed-event-emitter.d.ts +70 -0
  529. package/dist/src/session/typed-event-emitter.d.ts.map +1 -0
  530. package/dist/src/session/typed-event-emitter.js +79 -0
  531. package/dist/src/session/typed-event-emitter.js.map +1 -0
  532. package/dist/src/sources/BaseSourceAdapter.d.ts +1 -1
  533. package/dist/src/sources/BaseSourceAdapter.d.ts.map +1 -1
  534. package/dist/src/sources/BaseSourceAdapter.js +2 -2
  535. package/dist/src/sources/BaseSourceAdapter.js.map +1 -1
  536. package/dist/src/sync/BackgroundSyncService.d.ts +90 -0
  537. package/dist/src/sync/BackgroundSyncService.d.ts.map +1 -0
  538. package/dist/src/sync/BackgroundSyncService.js +214 -0
  539. package/dist/src/sync/BackgroundSyncService.js.map +1 -0
  540. package/dist/src/sync/SyncEngine.d.ts +76 -0
  541. package/dist/src/sync/SyncEngine.d.ts.map +1 -0
  542. package/dist/src/sync/SyncEngine.js +292 -0
  543. package/dist/src/sync/SyncEngine.js.map +1 -0
  544. package/dist/src/sync/index.d.ts +11 -0
  545. package/dist/src/sync/index.d.ts.map +1 -0
  546. package/dist/src/sync/index.js +14 -0
  547. package/dist/src/sync/index.js.map +1 -0
  548. package/dist/src/telemetry/index.d.ts +1 -0
  549. package/dist/src/telemetry/index.d.ts.map +1 -1
  550. package/dist/src/telemetry/index.js +2 -0
  551. package/dist/src/telemetry/index.js.map +1 -1
  552. package/dist/src/telemetry/posthog.d.ts +147 -0
  553. package/dist/src/telemetry/posthog.d.ts.map +1 -0
  554. package/dist/src/telemetry/posthog.js +213 -0
  555. package/dist/src/telemetry/posthog.js.map +1 -0
  556. package/dist/src/testing/MultiLLMProvider.d.ts +374 -0
  557. package/dist/src/testing/MultiLLMProvider.d.ts.map +1 -0
  558. package/dist/src/testing/MultiLLMProvider.js +720 -0
  559. package/dist/src/testing/MultiLLMProvider.js.map +1 -0
  560. package/dist/src/testing/index.d.ts +8 -0
  561. package/dist/src/testing/index.d.ts.map +1 -0
  562. package/dist/src/testing/index.js +9 -0
  563. package/dist/src/testing/index.js.map +1 -0
  564. package/dist/src/types/skill.d.ts +3 -0
  565. package/dist/src/types/skill.d.ts.map +1 -1
  566. package/dist/src/types.d.ts +5 -1
  567. package/dist/src/types.d.ts.map +1 -1
  568. package/dist/src/types.js +2 -2
  569. package/dist/src/types.js.map +1 -1
  570. package/dist/tests/RateLimiter.test.js +4 -4
  571. package/dist/tests/RateLimiter.test.js.map +1 -1
  572. package/dist/tests/SecurityScanner.test.js +337 -1
  573. package/dist/tests/SecurityScanner.test.js.map +1 -1
  574. package/dist/tests/adapters-factory.test.d.ts +13 -0
  575. package/dist/tests/adapters-factory.test.d.ts.map +1 -0
  576. package/dist/tests/adapters-factory.test.js +308 -0
  577. package/dist/tests/adapters-factory.test.js.map +1 -0
  578. package/dist/tests/adapters-java.test.d.ts +13 -0
  579. package/dist/tests/adapters-java.test.d.ts.map +1 -0
  580. package/dist/tests/adapters-java.test.js +925 -0
  581. package/dist/tests/adapters-java.test.js.map +1 -0
  582. package/dist/tests/api/client.validation.test.d.ts +7 -0
  583. package/dist/tests/api/client.validation.test.d.ts.map +1 -0
  584. package/dist/tests/api/client.validation.test.js +183 -0
  585. package/dist/tests/api/client.validation.test.js.map +1 -0
  586. package/dist/tests/billing/BillingService.test.d.ts +7 -0
  587. package/dist/tests/billing/BillingService.test.d.ts.map +1 -0
  588. package/dist/tests/billing/BillingService.test.js +168 -0
  589. package/dist/tests/billing/BillingService.test.js.map +1 -0
  590. package/dist/tests/billing/GDPRCompliance.test.d.ts +7 -0
  591. package/dist/tests/billing/GDPRCompliance.test.d.ts.map +1 -0
  592. package/dist/tests/billing/GDPRCompliance.test.js +195 -0
  593. package/dist/tests/billing/GDPRCompliance.test.js.map +1 -0
  594. package/dist/tests/billing/StripeReconciliation.test.d.ts +7 -0
  595. package/dist/tests/billing/StripeReconciliation.test.d.ts.map +1 -0
  596. package/dist/tests/billing/StripeReconciliation.test.js +266 -0
  597. package/dist/tests/billing/StripeReconciliation.test.js.map +1 -0
  598. package/dist/tests/billing/stripe-validators.test.d.ts +7 -0
  599. package/dist/tests/billing/stripe-validators.test.d.ts.map +1 -0
  600. package/dist/tests/billing/stripe-validators.test.js +107 -0
  601. package/dist/tests/billing/stripe-validators.test.js.map +1 -0
  602. package/dist/tests/e2e/security/security.e2e.test.js +3 -3
  603. package/dist/tests/e2e/security/security.e2e.test.js.map +1 -1
  604. package/dist/tests/embeddings/hnsw-store.test.d.ts +7 -0
  605. package/dist/tests/embeddings/hnsw-store.test.d.ts.map +1 -0
  606. package/dist/tests/embeddings/hnsw-store.test.js +295 -0
  607. package/dist/tests/embeddings/hnsw-store.test.js.map +1 -0
  608. package/dist/tests/integration/neural/e2e-learning.test.d.ts +17 -0
  609. package/dist/tests/integration/neural/e2e-learning.test.d.ts.map +1 -0
  610. package/dist/tests/integration/neural/e2e-learning.test.js +238 -0
  611. package/dist/tests/integration/neural/e2e-learning.test.js.map +1 -0
  612. package/dist/tests/integration/neural/helpers.d.ts +132 -0
  613. package/dist/tests/integration/neural/helpers.d.ts.map +1 -0
  614. package/dist/tests/integration/neural/helpers.js +287 -0
  615. package/dist/tests/integration/neural/helpers.js.map +1 -0
  616. package/dist/tests/integration/neural/personalization.test.d.ts +21 -0
  617. package/dist/tests/integration/neural/personalization.test.d.ts.map +1 -0
  618. package/dist/tests/integration/neural/personalization.test.js +304 -0
  619. package/dist/tests/integration/neural/personalization.test.js.map +1 -0
  620. package/dist/tests/integration/neural/preference-learner.test.d.ts +23 -0
  621. package/dist/tests/integration/neural/preference-learner.test.d.ts.map +1 -0
  622. package/dist/tests/integration/neural/preference-learner.test.js +289 -0
  623. package/dist/tests/integration/neural/preference-learner.test.js.map +1 -0
  624. package/dist/tests/integration/neural/privacy.test.d.ts +19 -0
  625. package/dist/tests/integration/neural/privacy.test.d.ts.map +1 -0
  626. package/dist/tests/integration/neural/privacy.test.js +249 -0
  627. package/dist/tests/integration/neural/privacy.test.js.map +1 -0
  628. package/dist/tests/integration/neural/setup.d.ts +175 -0
  629. package/dist/tests/integration/neural/setup.d.ts.map +1 -0
  630. package/dist/tests/integration/neural/setup.js +487 -0
  631. package/dist/tests/integration/neural/setup.js.map +1 -0
  632. package/dist/tests/integration/neural/signal-collection.test.d.ts +21 -0
  633. package/dist/tests/integration/neural/signal-collection.test.d.ts.map +1 -0
  634. package/dist/tests/integration/neural/signal-collection.test.js +232 -0
  635. package/dist/tests/integration/neural/signal-collection.test.js.map +1 -0
  636. package/dist/tests/language-detector.test.d.ts +13 -0
  637. package/dist/tests/language-detector.test.d.ts.map +1 -0
  638. package/dist/tests/language-detector.test.js +674 -0
  639. package/dist/tests/language-detector.test.js.map +1 -0
  640. package/dist/tests/learning/PatternStore.test.d.ts +8 -0
  641. package/dist/tests/learning/PatternStore.test.d.ts.map +1 -0
  642. package/dist/tests/learning/PatternStore.test.js +589 -0
  643. package/dist/tests/learning/PatternStore.test.js.map +1 -0
  644. package/dist/tests/learning/ReasoningBankIntegration.test.d.ts +8 -0
  645. package/dist/tests/learning/ReasoningBankIntegration.test.d.ts.map +1 -0
  646. package/dist/tests/learning/ReasoningBankIntegration.test.js +269 -0
  647. package/dist/tests/learning/ReasoningBankIntegration.test.js.map +1 -0
  648. package/dist/tests/routing/SONARouter.test.d.ts +8 -0
  649. package/dist/tests/routing/SONARouter.test.d.ts.map +1 -0
  650. package/dist/tests/routing/SONARouter.test.js +400 -0
  651. package/dist/tests/routing/SONARouter.test.js.map +1 -0
  652. package/dist/tests/security/ContinuousSecurity.test.js +10 -12
  653. package/dist/tests/security/ContinuousSecurity.test.js.map +1 -1
  654. package/dist/tests/security/SkillSandbox.test.d.ts +8 -0
  655. package/dist/tests/security/SkillSandbox.test.d.ts.map +1 -0
  656. package/dist/tests/security/SkillSandbox.test.js +321 -0
  657. package/dist/tests/security/SkillSandbox.test.js.map +1 -0
  658. package/dist/tests/sync/SyncConfigRepository.test.d.ts +7 -0
  659. package/dist/tests/sync/SyncConfigRepository.test.d.ts.map +1 -0
  660. package/dist/tests/sync/SyncConfigRepository.test.js +154 -0
  661. package/dist/tests/sync/SyncConfigRepository.test.js.map +1 -0
  662. package/dist/tests/sync/SyncEngine.test.d.ts +7 -0
  663. package/dist/tests/sync/SyncEngine.test.d.ts.map +1 -0
  664. package/dist/tests/sync/SyncEngine.test.js +300 -0
  665. package/dist/tests/sync/SyncEngine.test.js.map +1 -0
  666. package/dist/tests/sync/SyncHistoryRepository.test.d.ts +7 -0
  667. package/dist/tests/sync/SyncHistoryRepository.test.d.ts.map +1 -0
  668. package/dist/tests/sync/SyncHistoryRepository.test.js +220 -0
  669. package/dist/tests/sync/SyncHistoryRepository.test.js.map +1 -0
  670. package/dist/tests/telemetry/posthog.test.d.ts +13 -0
  671. package/dist/tests/telemetry/posthog.test.d.ts.map +1 -0
  672. package/dist/tests/telemetry/posthog.test.js +600 -0
  673. package/dist/tests/telemetry/posthog.test.js.map +1 -0
  674. package/dist/tests/testing/MultiLLMProvider.test.d.ts +14 -0
  675. package/dist/tests/testing/MultiLLMProvider.test.d.ts.map +1 -0
  676. package/dist/tests/testing/MultiLLMProvider.test.js +438 -0
  677. package/dist/tests/testing/MultiLLMProvider.test.js.map +1 -0
  678. package/package.json +20 -5
  679. package/dist/src/security/RateLimiter.d.ts +0 -337
  680. package/dist/src/security/RateLimiter.d.ts.map +0 -1
  681. package/dist/src/security/RateLimiter.js +0 -782
  682. package/dist/src/security/RateLimiter.js.map +0 -1
  683. package/dist/src/security/scanner.d.ts.map +0 -1
  684. package/dist/src/security/scanner.js.map +0 -1
@@ -0,0 +1,925 @@
1
+ /**
2
+ * SMI-1307: Java Language Adapter Tests
3
+ *
4
+ * Comprehensive tests for the Java adapter including:
5
+ * - Import extraction (regular, static, wildcard)
6
+ * - Export detection (class, interface, enum, @interface)
7
+ * - Function extraction (with visibility, annotations, generics)
8
+ * - pom.xml parsing (Maven dependencies)
9
+ * - build.gradle parsing (Gradle dependencies)
10
+ * - Framework detection rules
11
+ */
12
+ import { describe, it, expect, beforeEach, afterEach } from 'vitest';
13
+ import { JavaAdapter, parsePomXml, parseBuildGradle } from '../src/analysis/adapters/java.js';
14
+ describe('JavaAdapter', () => {
15
+ let adapter;
16
+ beforeEach(() => {
17
+ adapter = new JavaAdapter();
18
+ });
19
+ afterEach(() => {
20
+ adapter.dispose();
21
+ });
22
+ describe('canHandle', () => {
23
+ it('handles .java files', () => {
24
+ expect(adapter.canHandle('Main.java')).toBe(true);
25
+ expect(adapter.canHandle('UserService.java')).toBe(true);
26
+ expect(adapter.canHandle('path/to/File.java')).toBe(true);
27
+ });
28
+ it('does not handle non-Java files', () => {
29
+ expect(adapter.canHandle('main.ts')).toBe(false);
30
+ expect(adapter.canHandle('main.py')).toBe(false);
31
+ expect(adapter.canHandle('main.go')).toBe(false);
32
+ expect(adapter.canHandle('main.rs')).toBe(false);
33
+ expect(adapter.canHandle('pom.xml')).toBe(false);
34
+ expect(adapter.canHandle('build.gradle')).toBe(false);
35
+ });
36
+ it('handles case-insensitive extensions', () => {
37
+ expect(adapter.canHandle('Main.JAVA')).toBe(true);
38
+ expect(adapter.canHandle('Main.Java')).toBe(true);
39
+ });
40
+ });
41
+ describe('parseFile - imports', () => {
42
+ it('extracts regular import', () => {
43
+ const content = `
44
+ package com.example;
45
+
46
+ import java.util.List;
47
+ `;
48
+ const result = adapter.parseFile(content, 'Main.java');
49
+ expect(result.imports).toHaveLength(1);
50
+ expect(result.imports[0]).toMatchObject({
51
+ module: 'java.util.List',
52
+ namedImports: ['List'],
53
+ isTypeOnly: true,
54
+ sourceFile: 'Main.java',
55
+ });
56
+ });
57
+ it('extracts static import', () => {
58
+ const content = `
59
+ package com.example;
60
+
61
+ import static org.junit.Assert.assertEquals;
62
+ `;
63
+ const result = adapter.parseFile(content, 'Test.java');
64
+ expect(result.imports).toHaveLength(1);
65
+ expect(result.imports[0]).toMatchObject({
66
+ module: 'org.junit.Assert.assertEquals',
67
+ namedImports: ['assertEquals'],
68
+ isTypeOnly: false, // Static imports are not type-only
69
+ sourceFile: 'Test.java',
70
+ });
71
+ });
72
+ it('extracts wildcard import', () => {
73
+ const content = `
74
+ package com.example;
75
+
76
+ import java.util.*;
77
+ `;
78
+ const result = adapter.parseFile(content, 'Main.java');
79
+ expect(result.imports).toHaveLength(1);
80
+ expect(result.imports[0]).toMatchObject({
81
+ module: 'java.util',
82
+ namedImports: [],
83
+ namespaceImport: '*',
84
+ sourceFile: 'Main.java',
85
+ });
86
+ });
87
+ it('extracts static wildcard import', () => {
88
+ const content = `
89
+ package com.example;
90
+
91
+ import static java.lang.Math.*;
92
+ `;
93
+ const result = adapter.parseFile(content, 'Math.java');
94
+ expect(result.imports).toHaveLength(1);
95
+ expect(result.imports[0]).toMatchObject({
96
+ module: 'java.lang.Math',
97
+ namespaceImport: '*',
98
+ isTypeOnly: false,
99
+ });
100
+ });
101
+ it('extracts multiple imports', () => {
102
+ const content = `
103
+ package com.example;
104
+
105
+ import java.util.List;
106
+ import java.util.Map;
107
+ import java.util.ArrayList;
108
+ import static org.junit.Assert.*;
109
+ import com.google.gson.Gson;
110
+ `;
111
+ const result = adapter.parseFile(content, 'Service.java');
112
+ expect(result.imports).toHaveLength(5);
113
+ expect(result.imports.map((i) => i.module)).toContain('java.util.List');
114
+ expect(result.imports.map((i) => i.module)).toContain('java.util.Map');
115
+ expect(result.imports.map((i) => i.module)).toContain('java.util.ArrayList');
116
+ expect(result.imports.map((i) => i.module)).toContain('org.junit.Assert');
117
+ expect(result.imports.map((i) => i.module)).toContain('com.google.gson.Gson');
118
+ });
119
+ it('records line numbers for imports', () => {
120
+ const content = `package com.example;
121
+
122
+ import java.util.List;
123
+ import java.util.Map;
124
+ `;
125
+ const result = adapter.parseFile(content, 'Main.java');
126
+ expect(result.imports[0].line).toBe(3);
127
+ expect(result.imports[1].line).toBe(4);
128
+ });
129
+ });
130
+ describe('parseFile - exports', () => {
131
+ it('detects public class', () => {
132
+ const content = `
133
+ package com.example;
134
+
135
+ public class UserService {
136
+ // class body
137
+ }
138
+ `;
139
+ const result = adapter.parseFile(content, 'UserService.java');
140
+ expect(result.exports).toHaveLength(1);
141
+ expect(result.exports[0]).toMatchObject({
142
+ name: 'UserService',
143
+ kind: 'class',
144
+ isDefault: false,
145
+ visibility: 'public',
146
+ sourceFile: 'UserService.java',
147
+ });
148
+ });
149
+ it('detects package-private class', () => {
150
+ const content = `
151
+ package com.example;
152
+
153
+ class InternalHelper {
154
+ // class body
155
+ }
156
+ `;
157
+ const result = adapter.parseFile(content, 'InternalHelper.java');
158
+ expect(result.exports).toHaveLength(1);
159
+ expect(result.exports[0]).toMatchObject({
160
+ name: 'InternalHelper',
161
+ kind: 'class',
162
+ visibility: 'internal',
163
+ });
164
+ });
165
+ it('detects public interface', () => {
166
+ const content = `
167
+ package com.example;
168
+
169
+ public interface UserRepository {
170
+ User findById(Long id);
171
+ }
172
+ `;
173
+ const result = adapter.parseFile(content, 'UserRepository.java');
174
+ expect(result.exports).toHaveLength(1);
175
+ expect(result.exports[0]).toMatchObject({
176
+ name: 'UserRepository',
177
+ kind: 'interface',
178
+ visibility: 'public',
179
+ });
180
+ });
181
+ it('detects public enum', () => {
182
+ const content = `
183
+ package com.example;
184
+
185
+ public enum Status {
186
+ ACTIVE,
187
+ INACTIVE,
188
+ PENDING
189
+ }
190
+ `;
191
+ const result = adapter.parseFile(content, 'Status.java');
192
+ expect(result.exports).toHaveLength(1);
193
+ expect(result.exports[0]).toMatchObject({
194
+ name: 'Status',
195
+ kind: 'enum',
196
+ visibility: 'public',
197
+ });
198
+ });
199
+ it('detects annotation type', () => {
200
+ const content = `
201
+ package com.example;
202
+
203
+ public @interface MyAnnotation {
204
+ String value();
205
+ }
206
+ `;
207
+ const result = adapter.parseFile(content, 'MyAnnotation.java');
208
+ expect(result.exports).toHaveLength(1);
209
+ expect(result.exports[0]).toMatchObject({
210
+ name: 'MyAnnotation',
211
+ kind: 'interface',
212
+ visibility: 'public',
213
+ });
214
+ });
215
+ it('detects abstract class', () => {
216
+ const content = `
217
+ package com.example;
218
+
219
+ public abstract class BaseService {
220
+ public abstract void process();
221
+ }
222
+ `;
223
+ const result = adapter.parseFile(content, 'BaseService.java');
224
+ expect(result.exports).toHaveLength(1);
225
+ expect(result.exports[0]).toMatchObject({
226
+ name: 'BaseService',
227
+ kind: 'class',
228
+ visibility: 'public',
229
+ });
230
+ });
231
+ it('detects generic class', () => {
232
+ const content = `
233
+ package com.example;
234
+
235
+ public class Repository<T, ID> {
236
+ // generic class body
237
+ }
238
+ `;
239
+ const result = adapter.parseFile(content, 'Repository.java');
240
+ expect(result.exports).toHaveLength(1);
241
+ expect(result.exports[0]).toMatchObject({
242
+ name: 'Repository',
243
+ kind: 'class',
244
+ visibility: 'public',
245
+ });
246
+ });
247
+ it('detects multiple classes in file', () => {
248
+ const content = `
249
+ package com.example;
250
+
251
+ public class MainClass {
252
+ }
253
+
254
+ class HelperClass {
255
+ }
256
+
257
+ interface SomeInterface {
258
+ }
259
+ `;
260
+ const result = adapter.parseFile(content, 'MainClass.java');
261
+ expect(result.exports).toHaveLength(3);
262
+ expect(result.exports.map((e) => e.name)).toEqual([
263
+ 'MainClass',
264
+ 'HelperClass',
265
+ 'SomeInterface',
266
+ ]);
267
+ });
268
+ });
269
+ describe('parseFile - functions', () => {
270
+ it('extracts public method', () => {
271
+ const content = `
272
+ package com.example;
273
+
274
+ public class Service {
275
+ public void doSomething() {
276
+ }
277
+ }
278
+ `;
279
+ const result = adapter.parseFile(content, 'Service.java');
280
+ expect(result.functions).toHaveLength(1);
281
+ expect(result.functions[0]).toMatchObject({
282
+ name: 'doSomething',
283
+ parameterCount: 0,
284
+ isAsync: false,
285
+ isExported: true,
286
+ sourceFile: 'Service.java',
287
+ });
288
+ });
289
+ it('extracts private method', () => {
290
+ const content = `
291
+ package com.example;
292
+
293
+ public class Service {
294
+ private void helperMethod() {
295
+ }
296
+ }
297
+ `;
298
+ const result = adapter.parseFile(content, 'Service.java');
299
+ expect(result.functions).toHaveLength(1);
300
+ expect(result.functions[0]).toMatchObject({
301
+ name: 'helperMethod',
302
+ isExported: false,
303
+ });
304
+ });
305
+ it('extracts protected method', () => {
306
+ const content = `
307
+ package com.example;
308
+
309
+ public class Service {
310
+ protected void inheritableMethod() {
311
+ }
312
+ }
313
+ `;
314
+ const result = adapter.parseFile(content, 'Service.java');
315
+ expect(result.functions).toHaveLength(1);
316
+ expect(result.functions[0]).toMatchObject({
317
+ name: 'inheritableMethod',
318
+ isExported: true, // protected is considered exported
319
+ });
320
+ });
321
+ it('extracts method with parameters', () => {
322
+ const content = `
323
+ package com.example;
324
+
325
+ public class Service {
326
+ public String greet(String name, int age) {
327
+ return "Hello " + name;
328
+ }
329
+ }
330
+ `;
331
+ const result = adapter.parseFile(content, 'Service.java');
332
+ expect(result.functions).toHaveLength(1);
333
+ expect(result.functions[0]).toMatchObject({
334
+ name: 'greet',
335
+ parameterCount: 2,
336
+ });
337
+ });
338
+ it('extracts static method', () => {
339
+ const content = `
340
+ package com.example;
341
+
342
+ public class Utils {
343
+ public static String format(String input) {
344
+ return input.trim();
345
+ }
346
+ }
347
+ `;
348
+ const result = adapter.parseFile(content, 'Utils.java');
349
+ expect(result.functions).toHaveLength(1);
350
+ expect(result.functions[0]).toMatchObject({
351
+ name: 'format',
352
+ parameterCount: 1,
353
+ isExported: true,
354
+ });
355
+ });
356
+ it('extracts generic method', () => {
357
+ const content = `
358
+ package com.example;
359
+
360
+ public class Utils {
361
+ public <T> List<T> filter(List<T> items, Predicate<T> predicate) {
362
+ return items.stream().filter(predicate).collect(Collectors.toList());
363
+ }
364
+ }
365
+ `;
366
+ const result = adapter.parseFile(content, 'Utils.java');
367
+ expect(result.functions).toHaveLength(1);
368
+ expect(result.functions[0]).toMatchObject({
369
+ name: 'filter',
370
+ parameterCount: 2,
371
+ });
372
+ });
373
+ it('extracts method with annotations', () => {
374
+ const content = `
375
+ package com.example;
376
+
377
+ public class Service {
378
+ @Override
379
+ public String toString() {
380
+ return "Service";
381
+ }
382
+
383
+ @Test
384
+ @DisplayName("Test method")
385
+ public void testSomething() {
386
+ }
387
+ }
388
+ `;
389
+ const result = adapter.parseFile(content, 'Service.java');
390
+ expect(result.functions).toHaveLength(2);
391
+ expect(result.functions[0].decorators).toEqual(['Override']);
392
+ expect(result.functions[1].decorators).toEqual(['Test', 'DisplayName']);
393
+ });
394
+ it('extracts abstract method', () => {
395
+ const content = `
396
+ package com.example;
397
+
398
+ public abstract class BaseService {
399
+ public abstract void process();
400
+ }
401
+ `;
402
+ const result = adapter.parseFile(content, 'BaseService.java');
403
+ expect(result.functions).toHaveLength(1);
404
+ expect(result.functions[0]).toMatchObject({
405
+ name: 'process',
406
+ parameterCount: 0,
407
+ });
408
+ });
409
+ it('handles generics in parameters correctly', () => {
410
+ const content = `
411
+ package com.example;
412
+
413
+ public class Service {
414
+ public void process(Map<String, List<Integer>> data, Function<String, Integer> mapper) {
415
+ }
416
+ }
417
+ `;
418
+ const result = adapter.parseFile(content, 'Service.java');
419
+ expect(result.functions).toHaveLength(1);
420
+ expect(result.functions[0]).toMatchObject({
421
+ name: 'process',
422
+ parameterCount: 2, // Should count correctly despite nested generics
423
+ });
424
+ });
425
+ it('records line numbers for methods', () => {
426
+ const content = `package com.example;
427
+
428
+ public class Service {
429
+ public void first() {}
430
+
431
+ public void second() {}
432
+
433
+ public void third() {}
434
+ }
435
+ `;
436
+ const result = adapter.parseFile(content, 'Service.java');
437
+ expect(result.functions).toHaveLength(3);
438
+ expect(result.functions[0].line).toBe(4);
439
+ expect(result.functions[1].line).toBe(6);
440
+ expect(result.functions[2].line).toBe(8);
441
+ });
442
+ });
443
+ describe('parseFile - complex cases', () => {
444
+ it('parses a complete Spring Boot controller', () => {
445
+ const content = `
446
+ package com.example.controller;
447
+
448
+ import org.springframework.beans.factory.annotation.Autowired;
449
+ import org.springframework.web.bind.annotation.*;
450
+ import java.util.List;
451
+
452
+ @RestController
453
+ @RequestMapping("/api/users")
454
+ public class UserController {
455
+
456
+ @Autowired
457
+ private UserService userService;
458
+
459
+ @GetMapping
460
+ public List<User> getAllUsers() {
461
+ return userService.findAll();
462
+ }
463
+
464
+ @GetMapping("/{id}")
465
+ public User getUserById(@PathVariable Long id) {
466
+ return userService.findById(id);
467
+ }
468
+
469
+ @PostMapping
470
+ public User createUser(@RequestBody User user) {
471
+ return userService.save(user);
472
+ }
473
+
474
+ @DeleteMapping("/{id}")
475
+ public void deleteUser(@PathVariable Long id) {
476
+ userService.deleteById(id);
477
+ }
478
+ }
479
+ `;
480
+ const result = adapter.parseFile(content, 'UserController.java');
481
+ // Imports
482
+ expect(result.imports.length).toBeGreaterThanOrEqual(3);
483
+ expect(result.imports.map((i) => i.module)).toContain('org.springframework.beans.factory.annotation.Autowired');
484
+ // Exports (class)
485
+ expect(result.exports).toHaveLength(1);
486
+ expect(result.exports[0].name).toBe('UserController');
487
+ // Functions
488
+ expect(result.functions).toHaveLength(4);
489
+ expect(result.functions.map((f) => f.name)).toEqual([
490
+ 'getAllUsers',
491
+ 'getUserById',
492
+ 'createUser',
493
+ 'deleteUser',
494
+ ]);
495
+ // Check annotations
496
+ expect(result.functions[0].decorators).toEqual(['GetMapping']);
497
+ expect(result.functions[2].decorators).toEqual(['PostMapping']);
498
+ });
499
+ it('parses JUnit test class', () => {
500
+ const content = `
501
+ package com.example.test;
502
+
503
+ import org.junit.jupiter.api.*;
504
+ import static org.junit.jupiter.api.Assertions.*;
505
+
506
+ class UserServiceTest {
507
+
508
+ private UserService userService;
509
+
510
+ @BeforeEach
511
+ void setUp() {
512
+ userService = new UserService();
513
+ }
514
+
515
+ @Test
516
+ @DisplayName("Should find user by ID")
517
+ void testFindById() {
518
+ User user = userService.findById(1L);
519
+ assertNotNull(user);
520
+ }
521
+
522
+ @Test
523
+ void testCreateUser() {
524
+ User user = new User("John");
525
+ User saved = userService.save(user);
526
+ assertEquals("John", saved.getName());
527
+ }
528
+ }
529
+ `;
530
+ const result = adapter.parseFile(content, 'UserServiceTest.java');
531
+ expect(result.imports).toHaveLength(2);
532
+ expect(result.exports).toHaveLength(1);
533
+ expect(result.exports[0].name).toBe('UserServiceTest');
534
+ expect(result.functions).toHaveLength(3);
535
+ expect(result.functions[0].decorators).toEqual(['BeforeEach']);
536
+ expect(result.functions[1].decorators).toEqual(['Test', 'DisplayName']);
537
+ expect(result.functions[2].decorators).toEqual(['Test']);
538
+ });
539
+ });
540
+ describe('getFrameworkRules', () => {
541
+ it('includes Spring Boot framework detection', () => {
542
+ const rules = adapter.getFrameworkRules();
543
+ const springBoot = rules.find((r) => r.name === 'Spring Boot');
544
+ expect(springBoot).toBeDefined();
545
+ expect(springBoot?.depIndicators).toContain('spring-boot');
546
+ expect(springBoot?.importIndicators).toContain('org.springframework.boot');
547
+ });
548
+ it('includes JUnit detection', () => {
549
+ const rules = adapter.getFrameworkRules();
550
+ const junit = rules.find((r) => r.name === 'JUnit');
551
+ expect(junit).toBeDefined();
552
+ expect(junit?.depIndicators).toContain('junit');
553
+ expect(junit?.importIndicators).toContain('org.junit');
554
+ });
555
+ it('includes Hibernate detection', () => {
556
+ const rules = adapter.getFrameworkRules();
557
+ const hibernate = rules.find((r) => r.name === 'Hibernate');
558
+ expect(hibernate).toBeDefined();
559
+ expect(hibernate?.depIndicators).toContain('hibernate');
560
+ expect(hibernate?.importIndicators).toContain('javax.persistence');
561
+ });
562
+ it('includes Lombok detection', () => {
563
+ const rules = adapter.getFrameworkRules();
564
+ const lombok = rules.find((r) => r.name === 'Lombok');
565
+ expect(lombok).toBeDefined();
566
+ expect(lombok?.depIndicators).toContain('lombok');
567
+ expect(lombok?.importIndicators).toContain('lombok');
568
+ });
569
+ it('includes Quarkus detection', () => {
570
+ const rules = adapter.getFrameworkRules();
571
+ const quarkus = rules.find((r) => r.name === 'Quarkus');
572
+ expect(quarkus).toBeDefined();
573
+ expect(quarkus?.depIndicators).toContain('io.quarkus');
574
+ });
575
+ it('includes Mockito detection', () => {
576
+ const rules = adapter.getFrameworkRules();
577
+ const mockito = rules.find((r) => r.name === 'Mockito');
578
+ expect(mockito).toBeDefined();
579
+ expect(mockito?.importIndicators).toContain('org.mockito');
580
+ });
581
+ });
582
+ describe('parseIncremental', () => {
583
+ it('returns same result as parseFile', () => {
584
+ const content = `
585
+ package com.example;
586
+
587
+ import java.util.List;
588
+
589
+ public class Service {
590
+ public void process() {
591
+ }
592
+ }
593
+ `;
594
+ const parseResult = adapter.parseFile(content, 'Service.java');
595
+ const incrementalResult = adapter.parseIncremental(content, 'Service.java');
596
+ expect(incrementalResult).toEqual(parseResult);
597
+ });
598
+ });
599
+ });
600
+ describe('parsePomXml', () => {
601
+ it('extracts single dependency', () => {
602
+ const content = `
603
+ <?xml version="1.0" encoding="UTF-8"?>
604
+ <project>
605
+ <dependencies>
606
+ <dependency>
607
+ <groupId>org.springframework.boot</groupId>
608
+ <artifactId>spring-boot-starter</artifactId>
609
+ <version>3.0.0</version>
610
+ </dependency>
611
+ </dependencies>
612
+ </project>
613
+ `;
614
+ const result = parsePomXml(content);
615
+ expect(result).toHaveLength(1);
616
+ expect(result[0]).toEqual({
617
+ name: 'org.springframework.boot:spring-boot-starter',
618
+ version: '3.0.0',
619
+ isDev: false,
620
+ });
621
+ });
622
+ it('extracts multiple dependencies', () => {
623
+ const content = `
624
+ <?xml version="1.0" encoding="UTF-8"?>
625
+ <project>
626
+ <dependencies>
627
+ <dependency>
628
+ <groupId>org.springframework.boot</groupId>
629
+ <artifactId>spring-boot-starter-web</artifactId>
630
+ <version>3.0.0</version>
631
+ </dependency>
632
+ <dependency>
633
+ <groupId>com.google.guava</groupId>
634
+ <artifactId>guava</artifactId>
635
+ <version>31.1-jre</version>
636
+ </dependency>
637
+ </dependencies>
638
+ </project>
639
+ `;
640
+ const result = parsePomXml(content);
641
+ expect(result).toHaveLength(2);
642
+ expect(result.map((d) => d.name)).toContain('org.springframework.boot:spring-boot-starter-web');
643
+ expect(result.map((d) => d.name)).toContain('com.google.guava:guava');
644
+ });
645
+ it('identifies test scope dependencies as dev', () => {
646
+ const content = `
647
+ <?xml version="1.0" encoding="UTF-8"?>
648
+ <project>
649
+ <dependencies>
650
+ <dependency>
651
+ <groupId>org.junit.jupiter</groupId>
652
+ <artifactId>junit-jupiter</artifactId>
653
+ <version>5.9.0</version>
654
+ <scope>test</scope>
655
+ </dependency>
656
+ </dependencies>
657
+ </project>
658
+ `;
659
+ const result = parsePomXml(content);
660
+ expect(result).toHaveLength(1);
661
+ expect(result[0].isDev).toBe(true);
662
+ });
663
+ it('identifies provided scope dependencies as dev', () => {
664
+ const content = `
665
+ <?xml version="1.0" encoding="UTF-8"?>
666
+ <project>
667
+ <dependencies>
668
+ <dependency>
669
+ <groupId>javax.servlet</groupId>
670
+ <artifactId>javax.servlet-api</artifactId>
671
+ <version>4.0.1</version>
672
+ <scope>provided</scope>
673
+ </dependency>
674
+ </dependencies>
675
+ </project>
676
+ `;
677
+ const result = parsePomXml(content);
678
+ expect(result).toHaveLength(1);
679
+ expect(result[0].isDev).toBe(true);
680
+ });
681
+ it('handles dependencies without version', () => {
682
+ const content = `
683
+ <?xml version="1.0" encoding="UTF-8"?>
684
+ <project>
685
+ <dependencies>
686
+ <dependency>
687
+ <groupId>org.springframework.boot</groupId>
688
+ <artifactId>spring-boot-starter</artifactId>
689
+ </dependency>
690
+ </dependencies>
691
+ </project>
692
+ `;
693
+ const result = parsePomXml(content);
694
+ expect(result).toHaveLength(1);
695
+ expect(result[0].version).toBe('unspecified');
696
+ });
697
+ it('ignores XML comments', () => {
698
+ const content = `
699
+ <?xml version="1.0" encoding="UTF-8"?>
700
+ <project>
701
+ <dependencies>
702
+ <!-- This is commented out
703
+ <dependency>
704
+ <groupId>com.example</groupId>
705
+ <artifactId>commented-out</artifactId>
706
+ <version>1.0.0</version>
707
+ </dependency>
708
+ -->
709
+ <dependency>
710
+ <groupId>com.example</groupId>
711
+ <artifactId>real-dependency</artifactId>
712
+ <version>2.0.0</version>
713
+ </dependency>
714
+ </dependencies>
715
+ </project>
716
+ `;
717
+ const result = parsePomXml(content);
718
+ expect(result).toHaveLength(1);
719
+ expect(result[0].name).toBe('com.example:real-dependency');
720
+ });
721
+ it('parses complete pom.xml with various scopes', () => {
722
+ const content = `
723
+ <?xml version="1.0" encoding="UTF-8"?>
724
+ <project xmlns="http://maven.apache.org/POM/4.0.0">
725
+ <modelVersion>4.0.0</modelVersion>
726
+ <groupId>com.example</groupId>
727
+ <artifactId>myapp</artifactId>
728
+ <version>1.0.0</version>
729
+
730
+ <dependencies>
731
+ <dependency>
732
+ <groupId>org.springframework.boot</groupId>
733
+ <artifactId>spring-boot-starter-web</artifactId>
734
+ <version>3.0.0</version>
735
+ </dependency>
736
+ <dependency>
737
+ <groupId>org.springframework.boot</groupId>
738
+ <artifactId>spring-boot-starter-data-jpa</artifactId>
739
+ <version>3.0.0</version>
740
+ </dependency>
741
+ <dependency>
742
+ <groupId>org.projectlombok</groupId>
743
+ <artifactId>lombok</artifactId>
744
+ <version>1.18.24</version>
745
+ <scope>provided</scope>
746
+ </dependency>
747
+ <dependency>
748
+ <groupId>org.junit.jupiter</groupId>
749
+ <artifactId>junit-jupiter</artifactId>
750
+ <version>5.9.0</version>
751
+ <scope>test</scope>
752
+ </dependency>
753
+ </dependencies>
754
+ </project>
755
+ `;
756
+ const result = parsePomXml(content);
757
+ expect(result).toHaveLength(4);
758
+ expect(result.filter((d) => d.isDev)).toHaveLength(2);
759
+ expect(result.filter((d) => !d.isDev)).toHaveLength(2);
760
+ });
761
+ });
762
+ describe('parseBuildGradle', () => {
763
+ it('extracts implementation dependency with single quotes', () => {
764
+ const content = `
765
+ plugins {
766
+ id 'java'
767
+ }
768
+
769
+ dependencies {
770
+ implementation 'org.springframework.boot:spring-boot-starter:3.0.0'
771
+ }
772
+ `;
773
+ const result = parseBuildGradle(content);
774
+ expect(result).toHaveLength(1);
775
+ expect(result[0]).toEqual({
776
+ name: 'org.springframework.boot:spring-boot-starter',
777
+ version: '3.0.0',
778
+ isDev: false,
779
+ });
780
+ });
781
+ it('extracts implementation dependency with double quotes', () => {
782
+ const content = `
783
+ plugins {
784
+ id 'java'
785
+ }
786
+
787
+ dependencies {
788
+ implementation "org.springframework.boot:spring-boot-starter:3.0.0"
789
+ }
790
+ `;
791
+ const result = parseBuildGradle(content);
792
+ expect(result).toHaveLength(1);
793
+ expect(result[0].name).toBe('org.springframework.boot:spring-boot-starter');
794
+ });
795
+ it('extracts Kotlin DSL style dependency', () => {
796
+ const content = `
797
+ plugins {
798
+ kotlin("jvm")
799
+ }
800
+
801
+ dependencies {
802
+ implementation("org.springframework.boot:spring-boot-starter:3.0.0")
803
+ }
804
+ `;
805
+ const result = parseBuildGradle(content);
806
+ expect(result).toHaveLength(1);
807
+ expect(result[0].name).toBe('org.springframework.boot:spring-boot-starter');
808
+ });
809
+ it('identifies testImplementation as dev dependency', () => {
810
+ const content = `
811
+ dependencies {
812
+ testImplementation 'org.junit.jupiter:junit-jupiter:5.9.0'
813
+ }
814
+ `;
815
+ const result = parseBuildGradle(content);
816
+ expect(result).toHaveLength(1);
817
+ expect(result[0].isDev).toBe(true);
818
+ });
819
+ it('extracts api dependency', () => {
820
+ const content = `
821
+ dependencies {
822
+ api 'org.apache.commons:commons-lang3:3.12.0'
823
+ }
824
+ `;
825
+ const result = parseBuildGradle(content);
826
+ expect(result).toHaveLength(1);
827
+ expect(result[0].isDev).toBe(false);
828
+ });
829
+ it('extracts annotationProcessor as dev dependency', () => {
830
+ const content = `
831
+ dependencies {
832
+ annotationProcessor 'org.projectlombok:lombok:1.18.24'
833
+ }
834
+ `;
835
+ const result = parseBuildGradle(content);
836
+ expect(result).toHaveLength(1);
837
+ expect(result[0].isDev).toBe(true);
838
+ });
839
+ it('handles dependency without version', () => {
840
+ const content = `
841
+ dependencies {
842
+ implementation 'org.springframework.boot:spring-boot-starter'
843
+ }
844
+ `;
845
+ const result = parseBuildGradle(content);
846
+ expect(result).toHaveLength(1);
847
+ expect(result[0].version).toBe('unspecified');
848
+ });
849
+ it('extracts multiple dependencies', () => {
850
+ const content = `
851
+ dependencies {
852
+ implementation 'org.springframework.boot:spring-boot-starter-web:3.0.0'
853
+ implementation 'org.springframework.boot:spring-boot-starter-data-jpa:3.0.0'
854
+ runtimeOnly 'org.postgresql:postgresql:42.5.0'
855
+ testImplementation 'org.springframework.boot:spring-boot-starter-test:3.0.0'
856
+ testImplementation 'org.junit.jupiter:junit-jupiter:5.9.0'
857
+ }
858
+ `;
859
+ const result = parseBuildGradle(content);
860
+ expect(result).toHaveLength(5);
861
+ expect(result.filter((d) => d.isDev)).toHaveLength(2);
862
+ expect(result.filter((d) => !d.isDev)).toHaveLength(3);
863
+ });
864
+ it('extracts Kotlin DSL with named parameters', () => {
865
+ const content = `
866
+ dependencies {
867
+ implementation(group = "org.springframework.boot", name = "spring-boot-starter", version = "3.0.0")
868
+ testImplementation(group = "org.junit.jupiter", name = "junit-jupiter", version = "5.9.0")
869
+ }
870
+ `;
871
+ const result = parseBuildGradle(content);
872
+ expect(result).toHaveLength(2);
873
+ expect(result[0]).toEqual({
874
+ name: 'org.springframework.boot:spring-boot-starter',
875
+ version: '3.0.0',
876
+ isDev: false,
877
+ });
878
+ expect(result[1].isDev).toBe(true);
879
+ });
880
+ it('ignores project dependencies', () => {
881
+ const content = `
882
+ dependencies {
883
+ implementation project(':core')
884
+ implementation 'org.springframework.boot:spring-boot-starter:3.0.0'
885
+ }
886
+ `;
887
+ const result = parseBuildGradle(content);
888
+ // Should only capture the external dependency, not the project reference
889
+ expect(result).toHaveLength(1);
890
+ expect(result[0].name).toBe('org.springframework.boot:spring-boot-starter');
891
+ });
892
+ it('parses complete build.gradle file', () => {
893
+ const content = `
894
+ plugins {
895
+ id 'java'
896
+ id 'org.springframework.boot' version '3.0.0'
897
+ }
898
+
899
+ group = 'com.example'
900
+ version = '1.0.0'
901
+
902
+ repositories {
903
+ mavenCentral()
904
+ }
905
+
906
+ dependencies {
907
+ implementation 'org.springframework.boot:spring-boot-starter-web:3.0.0'
908
+ implementation 'org.springframework.boot:spring-boot-starter-data-jpa:3.0.0'
909
+ compileOnly 'org.projectlombok:lombok:1.18.24'
910
+ annotationProcessor 'org.projectlombok:lombok:1.18.24'
911
+ runtimeOnly 'org.postgresql:postgresql:42.5.0'
912
+ testImplementation 'org.springframework.boot:spring-boot-starter-test:3.0.0'
913
+ }
914
+
915
+ test {
916
+ useJUnitPlatform()
917
+ }
918
+ `;
919
+ const result = parseBuildGradle(content);
920
+ expect(result.length).toBeGreaterThanOrEqual(5);
921
+ expect(result.map((d) => d.name)).toContain('org.springframework.boot:spring-boot-starter-web');
922
+ expect(result.map((d) => d.name)).toContain('org.projectlombok:lombok');
923
+ });
924
+ });
925
+ //# sourceMappingURL=adapters-java.test.js.map