agentdb 1.0.12 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (503) hide show
  1. package/README.md +196 -838
  2. package/dist/benchmarks/comprehensive-benchmark.js +664 -0
  3. package/dist/benchmarks/frontier-benchmark.js +419 -0
  4. package/dist/benchmarks/reflexion-benchmark.js +370 -0
  5. package/dist/cli/agentdb-cli.d.ts +117 -0
  6. package/dist/cli/agentdb-cli.d.ts.map +1 -0
  7. package/dist/cli/agentdb-cli.js +718 -0
  8. package/dist/cli/agentdb-cli.js.map +1 -0
  9. package/dist/controllers/CausalMemoryGraph.d.ts +125 -0
  10. package/dist/controllers/CausalMemoryGraph.d.ts.map +1 -0
  11. package/dist/controllers/CausalMemoryGraph.js +323 -0
  12. package/dist/controllers/CausalMemoryGraph.js.map +1 -0
  13. package/dist/controllers/CausalRecall.d.ts +111 -0
  14. package/dist/controllers/CausalRecall.d.ts.map +1 -0
  15. package/dist/controllers/CausalRecall.js +282 -0
  16. package/dist/controllers/CausalRecall.js.map +1 -0
  17. package/dist/controllers/EmbeddingService.d.ts +37 -0
  18. package/dist/controllers/EmbeddingService.d.ts.map +1 -0
  19. package/dist/controllers/EmbeddingService.js +119 -0
  20. package/dist/controllers/EmbeddingService.js.map +1 -0
  21. package/dist/controllers/ExplainableRecall.d.ts +138 -0
  22. package/dist/controllers/ExplainableRecall.d.ts.map +1 -0
  23. package/dist/controllers/ExplainableRecall.js +388 -0
  24. package/dist/controllers/ExplainableRecall.js.map +1 -0
  25. package/dist/controllers/NightlyLearner.d.ts +113 -0
  26. package/dist/controllers/NightlyLearner.d.ts.map +1 -0
  27. package/dist/controllers/NightlyLearner.js +383 -0
  28. package/dist/controllers/NightlyLearner.js.map +1 -0
  29. package/dist/controllers/ReflexionMemory.d.ts +84 -0
  30. package/dist/controllers/ReflexionMemory.d.ts.map +1 -0
  31. package/dist/controllers/ReflexionMemory.js +240 -0
  32. package/dist/controllers/ReflexionMemory.js.map +1 -0
  33. package/dist/controllers/SkillLibrary.d.ts +96 -0
  34. package/dist/controllers/SkillLibrary.d.ts.map +1 -0
  35. package/dist/controllers/SkillLibrary.js +277 -0
  36. package/dist/controllers/SkillLibrary.js.map +1 -0
  37. package/dist/controllers/frontier-index.d.ts +14 -0
  38. package/dist/controllers/frontier-index.d.ts.map +1 -0
  39. package/dist/controllers/frontier-index.js +10 -0
  40. package/dist/controllers/frontier-index.js.map +1 -0
  41. package/dist/controllers/index.d.ts +12 -0
  42. package/dist/controllers/index.d.ts.map +1 -0
  43. package/dist/controllers/index.js +9 -0
  44. package/dist/controllers/index.js.map +1 -0
  45. package/dist/optimizations/BatchOperations.d.ts +61 -0
  46. package/dist/optimizations/BatchOperations.d.ts.map +1 -0
  47. package/dist/optimizations/BatchOperations.js +199 -0
  48. package/dist/optimizations/BatchOperations.js.map +1 -0
  49. package/dist/optimizations/QueryOptimizer.d.ts +82 -0
  50. package/dist/optimizations/QueryOptimizer.d.ts.map +1 -0
  51. package/dist/optimizations/QueryOptimizer.js +226 -0
  52. package/dist/optimizations/QueryOptimizer.js.map +1 -0
  53. package/dist/optimizations/index.d.ts +10 -0
  54. package/dist/optimizations/index.d.ts.map +1 -0
  55. package/dist/optimizations/index.js +8 -0
  56. package/dist/optimizations/index.js.map +1 -0
  57. package/dist/schemas/frontier-schema.sql +341 -0
  58. package/dist/schemas/schema.sql +382 -0
  59. package/dist/tests/frontier-features.test.js +665 -0
  60. package/package.json +54 -117
  61. package/src/cli/agentdb-cli.ts +861 -0
  62. package/src/cli/examples.sh +83 -0
  63. package/src/controllers/CausalMemoryGraph.ts +504 -0
  64. package/src/controllers/CausalRecall.ts +395 -0
  65. package/src/controllers/EmbeddingService.ts +141 -0
  66. package/src/controllers/ExplainableRecall.ts +577 -0
  67. package/src/controllers/NightlyLearner.ts +475 -0
  68. package/src/controllers/ReflexionMemory.ts +349 -0
  69. package/src/controllers/SkillLibrary.ts +391 -0
  70. package/src/controllers/frontier-index.ts +35 -0
  71. package/src/controllers/index.ts +13 -0
  72. package/src/optimizations/BatchOperations.ts +292 -0
  73. package/src/optimizations/QueryOptimizer.ts +294 -0
  74. package/src/optimizations/index.ts +11 -0
  75. package/src/schemas/frontier-schema.sql +341 -0
  76. package/src/schemas/schema.sql +382 -0
  77. package/CHANGELOG.md +0 -166
  78. package/LICENSE +0 -38
  79. package/LICENSE-APACHE +0 -190
  80. package/LICENSE-MIT +0 -21
  81. package/bin/agentdb.js +0 -733
  82. package/bin/benchmark.js +0 -165
  83. package/bin/plugin-cli-wrapper.mjs +0 -21
  84. package/dist/agentdb.js +0 -5352
  85. package/dist/agentdb.js.map +0 -7
  86. package/dist/agentdb.min.js +0 -143
  87. package/dist/agentdb.min.js.map +0 -7
  88. package/dist/cache/query-cache.d.ts +0 -105
  89. package/dist/cache/query-cache.d.ts.map +0 -1
  90. package/dist/cache/query-cache.js +0 -224
  91. package/dist/cache/query-cache.js.map +0 -1
  92. package/dist/cache/query-cache.mjs +0 -219
  93. package/dist/cli/cache/query-cache.d.ts +0 -104
  94. package/dist/cli/cache/query-cache.js +0 -244
  95. package/dist/cli/cli/db-commands.d.ts +0 -48
  96. package/dist/cli/cli/db-commands.js +0 -613
  97. package/dist/cli/commands.d.ts +0 -7
  98. package/dist/cli/commands.d.ts.map +0 -1
  99. package/dist/cli/commands.js +0 -113
  100. package/dist/cli/commands.js.map +0 -1
  101. package/dist/cli/commands.mjs +0 -104
  102. package/dist/cli/core/backend-interface.d.ts +0 -70
  103. package/dist/cli/core/backend-interface.js +0 -15
  104. package/dist/cli/core/native-backend.d.ts +0 -140
  105. package/dist/cli/core/native-backend.js +0 -432
  106. package/dist/cli/core/vector-db.d.ts +0 -126
  107. package/dist/cli/core/vector-db.js +0 -338
  108. package/dist/cli/core/wasm-backend.d.ts +0 -95
  109. package/dist/cli/core/wasm-backend.js +0 -418
  110. package/dist/cli/db-commands.d.ts +0 -49
  111. package/dist/cli/db-commands.d.ts.map +0 -1
  112. package/dist/cli/db-commands.js +0 -533
  113. package/dist/cli/db-commands.js.map +0 -1
  114. package/dist/cli/db-commands.mjs +0 -522
  115. package/dist/cli/generator.d.ts +0 -11
  116. package/dist/cli/generator.d.ts.map +0 -1
  117. package/dist/cli/generator.js +0 -567
  118. package/dist/cli/generator.js.map +0 -1
  119. package/dist/cli/generator.mjs +0 -527
  120. package/dist/cli/help.d.ts +0 -18
  121. package/dist/cli/help.d.ts.map +0 -1
  122. package/dist/cli/help.js +0 -676
  123. package/dist/cli/help.js.map +0 -1
  124. package/dist/cli/help.mjs +0 -667
  125. package/dist/cli/index/hnsw.d.ts +0 -164
  126. package/dist/cli/index/hnsw.js +0 -558
  127. package/dist/cli/plugin-cli.d.ts +0 -7
  128. package/dist/cli/plugin-cli.d.ts.map +0 -1
  129. package/dist/cli/plugin-cli.js +0 -295
  130. package/dist/cli/plugin-cli.js.map +0 -1
  131. package/dist/cli/plugin-cli.mjs +0 -289
  132. package/dist/cli/quantization/product-quantization.d.ts +0 -108
  133. package/dist/cli/quantization/product-quantization.js +0 -350
  134. package/dist/cli/query/query-builder.d.ts +0 -322
  135. package/dist/cli/query/query-builder.js +0 -600
  136. package/dist/cli/templates.d.ts +0 -14
  137. package/dist/cli/templates.d.ts.map +0 -1
  138. package/dist/cli/templates.js +0 -182
  139. package/dist/cli/templates.js.map +0 -1
  140. package/dist/cli/templates.mjs +0 -176
  141. package/dist/cli/types/index.d.ts +0 -116
  142. package/dist/cli/types/index.js +0 -5
  143. package/dist/cli/types.d.ts +0 -91
  144. package/dist/cli/types.d.ts.map +0 -1
  145. package/dist/cli/types.js +0 -6
  146. package/dist/cli/types.js.map +0 -1
  147. package/dist/cli/types.mjs +0 -4
  148. package/dist/cli/wizard/index.d.ts +0 -6
  149. package/dist/cli/wizard/index.d.ts.map +0 -1
  150. package/dist/cli/wizard/index.js +0 -138
  151. package/dist/cli/wizard/index.js.map +0 -1
  152. package/dist/cli/wizard/index.mjs +0 -131
  153. package/dist/cli/wizard/prompts.d.ts +0 -11
  154. package/dist/cli/wizard/prompts.d.ts.map +0 -1
  155. package/dist/cli/wizard/prompts.js +0 -482
  156. package/dist/cli/wizard/prompts.js.map +0 -1
  157. package/dist/cli/wizard/prompts.mjs +0 -470
  158. package/dist/cli/wizard/validator.d.ts +0 -13
  159. package/dist/cli/wizard/validator.d.ts.map +0 -1
  160. package/dist/cli/wizard/validator.js +0 -234
  161. package/dist/cli/wizard/validator.js.map +0 -1
  162. package/dist/cli/wizard/validator.mjs +0 -224
  163. package/dist/core/backend-interface.d.ts +0 -71
  164. package/dist/core/backend-interface.d.ts.map +0 -1
  165. package/dist/core/backend-interface.js +0 -16
  166. package/dist/core/backend-interface.js.map +0 -1
  167. package/dist/core/backend-interface.mjs +0 -12
  168. package/dist/core/native-backend.d.ts +0 -141
  169. package/dist/core/native-backend.d.ts.map +0 -1
  170. package/dist/core/native-backend.js +0 -457
  171. package/dist/core/native-backend.js.map +0 -1
  172. package/dist/core/native-backend.mjs +0 -449
  173. package/dist/core/vector-db.d.ts +0 -127
  174. package/dist/core/vector-db.d.ts.map +0 -1
  175. package/dist/core/vector-db.js +0 -270
  176. package/dist/core/vector-db.js.map +0 -1
  177. package/dist/core/vector-db.mjs +0 -265
  178. package/dist/core/wasm-backend.d.ts +0 -96
  179. package/dist/core/wasm-backend.d.ts.map +0 -1
  180. package/dist/core/wasm-backend.js +0 -393
  181. package/dist/core/wasm-backend.js.map +0 -1
  182. package/dist/core/wasm-backend.mjs +0 -385
  183. package/dist/index/hnsw-optimized.d.ts +0 -75
  184. package/dist/index/hnsw-optimized.d.ts.map +0 -1
  185. package/dist/index/hnsw-optimized.js +0 -412
  186. package/dist/index/hnsw-optimized.js.map +0 -1
  187. package/dist/index/hnsw-optimized.mjs +0 -407
  188. package/dist/index/hnsw.d.ts +0 -165
  189. package/dist/index/hnsw.d.ts.map +0 -1
  190. package/dist/index/hnsw.js +0 -521
  191. package/dist/index/hnsw.js.map +0 -1
  192. package/dist/index/hnsw.mjs +0 -516
  193. package/dist/index.browser.d.ts +0 -47
  194. package/dist/index.browser.d.ts.map +0 -1
  195. package/dist/index.browser.js +0 -72
  196. package/dist/index.browser.js.map +0 -1
  197. package/dist/index.browser.mjs +0 -54
  198. package/dist/index.d.ts +0 -59
  199. package/dist/index.d.ts.map +0 -1
  200. package/dist/index.js +0 -84
  201. package/dist/index.js.map +0 -1
  202. package/dist/index.mjs +0 -65
  203. package/dist/mcp/learning/core/experience-buffer.d.ts +0 -61
  204. package/dist/mcp/learning/core/experience-buffer.d.ts.map +0 -1
  205. package/dist/mcp/learning/core/experience-buffer.js +0 -175
  206. package/dist/mcp/learning/core/experience-buffer.js.map +0 -1
  207. package/dist/mcp/learning/core/experience-buffer.mjs +0 -170
  208. package/dist/mcp/learning/core/experience-recorder.d.ts +0 -40
  209. package/dist/mcp/learning/core/experience-recorder.d.ts.map +0 -1
  210. package/dist/mcp/learning/core/experience-recorder.js +0 -200
  211. package/dist/mcp/learning/core/experience-recorder.js.map +0 -1
  212. package/dist/mcp/learning/core/experience-recorder.mjs +0 -195
  213. package/dist/mcp/learning/core/learning-manager.d.ts +0 -66
  214. package/dist/mcp/learning/core/learning-manager.d.ts.map +0 -1
  215. package/dist/mcp/learning/core/learning-manager.js +0 -252
  216. package/dist/mcp/learning/core/learning-manager.js.map +0 -1
  217. package/dist/mcp/learning/core/learning-manager.mjs +0 -247
  218. package/dist/mcp/learning/core/policy-optimizer.d.ts +0 -53
  219. package/dist/mcp/learning/core/policy-optimizer.d.ts.map +0 -1
  220. package/dist/mcp/learning/core/policy-optimizer.js +0 -251
  221. package/dist/mcp/learning/core/policy-optimizer.js.map +0 -1
  222. package/dist/mcp/learning/core/policy-optimizer.mjs +0 -246
  223. package/dist/mcp/learning/core/reward-estimator.d.ts +0 -44
  224. package/dist/mcp/learning/core/reward-estimator.d.ts.map +0 -1
  225. package/dist/mcp/learning/core/reward-estimator.js +0 -158
  226. package/dist/mcp/learning/core/reward-estimator.js.map +0 -1
  227. package/dist/mcp/learning/core/reward-estimator.mjs +0 -153
  228. package/dist/mcp/learning/core/session-manager.d.ts +0 -63
  229. package/dist/mcp/learning/core/session-manager.d.ts.map +0 -1
  230. package/dist/mcp/learning/core/session-manager.js +0 -202
  231. package/dist/mcp/learning/core/session-manager.js.map +0 -1
  232. package/dist/mcp/learning/core/session-manager.mjs +0 -197
  233. package/dist/mcp/learning/index.d.ts +0 -19
  234. package/dist/mcp/learning/index.d.ts.map +0 -1
  235. package/dist/mcp/learning/index.js +0 -30
  236. package/dist/mcp/learning/index.js.map +0 -1
  237. package/dist/mcp/learning/index.mjs +0 -19
  238. package/dist/mcp/learning/tools/mcp-learning-tools.d.ts +0 -369
  239. package/dist/mcp/learning/tools/mcp-learning-tools.d.ts.map +0 -1
  240. package/dist/mcp/learning/tools/mcp-learning-tools.js +0 -361
  241. package/dist/mcp/learning/tools/mcp-learning-tools.js.map +0 -1
  242. package/dist/mcp/learning/tools/mcp-learning-tools.mjs +0 -356
  243. package/dist/mcp/learning/types/index.d.ts +0 -138
  244. package/dist/mcp/learning/types/index.d.ts.map +0 -1
  245. package/dist/mcp/learning/types/index.js +0 -6
  246. package/dist/mcp/learning/types/index.js.map +0 -1
  247. package/dist/mcp/learning/types/index.mjs +0 -4
  248. package/dist/mcp-server.d.ts +0 -29
  249. package/dist/mcp-server.d.ts.map +0 -1
  250. package/dist/mcp-server.js +0 -862
  251. package/dist/mcp-server.js.map +0 -1
  252. package/dist/mcp-server.mjs +0 -857
  253. package/dist/plugins/base-plugin.d.ts +0 -114
  254. package/dist/plugins/base-plugin.d.ts.map +0 -1
  255. package/dist/plugins/base-plugin.js +0 -313
  256. package/dist/plugins/base-plugin.js.map +0 -1
  257. package/dist/plugins/base-plugin.mjs +0 -275
  258. package/dist/plugins/implementations/active-learning.d.ts +0 -135
  259. package/dist/plugins/implementations/active-learning.d.ts.map +0 -1
  260. package/dist/plugins/implementations/active-learning.js +0 -372
  261. package/dist/plugins/implementations/active-learning.js.map +0 -1
  262. package/dist/plugins/implementations/active-learning.mjs +0 -367
  263. package/dist/plugins/implementations/actor-critic.d.ts +0 -64
  264. package/dist/plugins/implementations/actor-critic.d.ts.map +0 -1
  265. package/dist/plugins/implementations/actor-critic.js +0 -363
  266. package/dist/plugins/implementations/actor-critic.js.map +0 -1
  267. package/dist/plugins/implementations/actor-critic.mjs +0 -358
  268. package/dist/plugins/implementations/adversarial-training.d.ts +0 -133
  269. package/dist/plugins/implementations/adversarial-training.d.ts.map +0 -1
  270. package/dist/plugins/implementations/adversarial-training.js +0 -409
  271. package/dist/plugins/implementations/adversarial-training.js.map +0 -1
  272. package/dist/plugins/implementations/adversarial-training.mjs +0 -404
  273. package/dist/plugins/implementations/curriculum-learning.d.ts +0 -132
  274. package/dist/plugins/implementations/curriculum-learning.d.ts.map +0 -1
  275. package/dist/plugins/implementations/curriculum-learning.js +0 -354
  276. package/dist/plugins/implementations/curriculum-learning.js.map +0 -1
  277. package/dist/plugins/implementations/curriculum-learning.mjs +0 -349
  278. package/dist/plugins/implementations/decision-transformer.d.ts +0 -77
  279. package/dist/plugins/implementations/decision-transformer.d.ts.map +0 -1
  280. package/dist/plugins/implementations/decision-transformer.js +0 -422
  281. package/dist/plugins/implementations/decision-transformer.js.map +0 -1
  282. package/dist/plugins/implementations/decision-transformer.mjs +0 -417
  283. package/dist/plugins/implementations/federated-learning.d.ts +0 -126
  284. package/dist/plugins/implementations/federated-learning.d.ts.map +0 -1
  285. package/dist/plugins/implementations/federated-learning.js +0 -436
  286. package/dist/plugins/implementations/federated-learning.js.map +0 -1
  287. package/dist/plugins/implementations/federated-learning.mjs +0 -431
  288. package/dist/plugins/implementations/index.d.ts +0 -30
  289. package/dist/plugins/implementations/index.d.ts.map +0 -1
  290. package/dist/plugins/implementations/index.js +0 -45
  291. package/dist/plugins/implementations/index.js.map +0 -1
  292. package/dist/plugins/implementations/index.mjs +0 -31
  293. package/dist/plugins/implementations/multi-task-learning.d.ts +0 -115
  294. package/dist/plugins/implementations/multi-task-learning.d.ts.map +0 -1
  295. package/dist/plugins/implementations/multi-task-learning.js +0 -369
  296. package/dist/plugins/implementations/multi-task-learning.js.map +0 -1
  297. package/dist/plugins/implementations/multi-task-learning.mjs +0 -364
  298. package/dist/plugins/implementations/neural-architecture-search.d.ts +0 -148
  299. package/dist/plugins/implementations/neural-architecture-search.d.ts.map +0 -1
  300. package/dist/plugins/implementations/neural-architecture-search.js +0 -379
  301. package/dist/plugins/implementations/neural-architecture-search.js.map +0 -1
  302. package/dist/plugins/implementations/neural-architecture-search.mjs +0 -374
  303. package/dist/plugins/implementations/q-learning.d.ts +0 -98
  304. package/dist/plugins/implementations/q-learning.d.ts.map +0 -1
  305. package/dist/plugins/implementations/q-learning.js +0 -435
  306. package/dist/plugins/implementations/q-learning.js.map +0 -1
  307. package/dist/plugins/implementations/q-learning.mjs +0 -430
  308. package/dist/plugins/implementations/sarsa.d.ts +0 -103
  309. package/dist/plugins/implementations/sarsa.d.ts.map +0 -1
  310. package/dist/plugins/implementations/sarsa.js +0 -347
  311. package/dist/plugins/implementations/sarsa.js.map +0 -1
  312. package/dist/plugins/implementations/sarsa.mjs +0 -342
  313. package/dist/plugins/index.d.ts +0 -107
  314. package/dist/plugins/index.d.ts.map +0 -1
  315. package/dist/plugins/index.js +0 -179
  316. package/dist/plugins/index.js.map +0 -1
  317. package/dist/plugins/index.mjs +0 -168
  318. package/dist/plugins/interface.d.ts +0 -439
  319. package/dist/plugins/interface.d.ts.map +0 -1
  320. package/dist/plugins/interface.js +0 -12
  321. package/dist/plugins/interface.js.map +0 -1
  322. package/dist/plugins/interface.mjs +0 -10
  323. package/dist/plugins/learning-plugin.interface.d.ts +0 -257
  324. package/dist/plugins/learning-plugin.interface.d.ts.map +0 -1
  325. package/dist/plugins/learning-plugin.interface.js +0 -7
  326. package/dist/plugins/learning-plugin.interface.js.map +0 -1
  327. package/dist/plugins/learning-plugin.interface.mjs +0 -5
  328. package/dist/plugins/plugin-exports.d.ts +0 -71
  329. package/dist/plugins/plugin-exports.d.ts.map +0 -1
  330. package/dist/plugins/plugin-exports.js +0 -78
  331. package/dist/plugins/plugin-exports.js.map +0 -1
  332. package/dist/plugins/plugin-exports.mjs +0 -69
  333. package/dist/plugins/registry.d.ts +0 -206
  334. package/dist/plugins/registry.d.ts.map +0 -1
  335. package/dist/plugins/registry.js +0 -365
  336. package/dist/plugins/registry.js.map +0 -1
  337. package/dist/plugins/registry.mjs +0 -356
  338. package/dist/plugins/validator.d.ts +0 -63
  339. package/dist/plugins/validator.d.ts.map +0 -1
  340. package/dist/plugins/validator.js +0 -464
  341. package/dist/plugins/validator.js.map +0 -1
  342. package/dist/plugins/validator.mjs +0 -458
  343. package/dist/presets.d.ts +0 -65
  344. package/dist/presets.d.ts.map +0 -1
  345. package/dist/presets.js +0 -145
  346. package/dist/presets.js.map +0 -1
  347. package/dist/presets.mjs +0 -140
  348. package/dist/quantization/binary-quantization.d.ts +0 -104
  349. package/dist/quantization/binary-quantization.d.ts.map +0 -1
  350. package/dist/quantization/binary-quantization.js +0 -246
  351. package/dist/quantization/binary-quantization.js.map +0 -1
  352. package/dist/quantization/binary-quantization.mjs +0 -240
  353. package/dist/quantization/optimized-pq.d.ts +0 -138
  354. package/dist/quantization/optimized-pq.d.ts.map +0 -1
  355. package/dist/quantization/optimized-pq.js +0 -320
  356. package/dist/quantization/optimized-pq.js.map +0 -1
  357. package/dist/quantization/optimized-pq.mjs +0 -313
  358. package/dist/quantization/product-quantization.d.ts +0 -109
  359. package/dist/quantization/product-quantization.d.ts.map +0 -1
  360. package/dist/quantization/product-quantization.js +0 -287
  361. package/dist/quantization/product-quantization.js.map +0 -1
  362. package/dist/quantization/product-quantization.mjs +0 -282
  363. package/dist/quantization/scalar-quantization.d.ts +0 -100
  364. package/dist/quantization/scalar-quantization.d.ts.map +0 -1
  365. package/dist/quantization/scalar-quantization.js +0 -324
  366. package/dist/quantization/scalar-quantization.js.map +0 -1
  367. package/dist/quantization/scalar-quantization.mjs +0 -319
  368. package/dist/query/index.d.ts +0 -6
  369. package/dist/query/index.d.ts.map +0 -1
  370. package/dist/query/index.js +0 -9
  371. package/dist/query/index.js.map +0 -1
  372. package/dist/query/index.mjs +0 -4
  373. package/dist/query/query-builder.d.ts +0 -323
  374. package/dist/query/query-builder.d.ts.map +0 -1
  375. package/dist/query/query-builder.js +0 -524
  376. package/dist/query/query-builder.js.map +0 -1
  377. package/dist/query/query-builder.mjs +0 -519
  378. package/dist/reasoning/context-synthesizer.d.ts +0 -57
  379. package/dist/reasoning/context-synthesizer.d.ts.map +0 -1
  380. package/dist/reasoning/context-synthesizer.js +0 -224
  381. package/dist/reasoning/context-synthesizer.js.map +0 -1
  382. package/dist/reasoning/context-synthesizer.mjs +0 -219
  383. package/dist/reasoning/experience-curator.d.ts +0 -66
  384. package/dist/reasoning/experience-curator.d.ts.map +0 -1
  385. package/dist/reasoning/experience-curator.js +0 -288
  386. package/dist/reasoning/experience-curator.js.map +0 -1
  387. package/dist/reasoning/experience-curator.mjs +0 -283
  388. package/dist/reasoning/memory-optimizer.d.ts +0 -69
  389. package/dist/reasoning/memory-optimizer.d.ts.map +0 -1
  390. package/dist/reasoning/memory-optimizer.js +0 -331
  391. package/dist/reasoning/memory-optimizer.js.map +0 -1
  392. package/dist/reasoning/memory-optimizer.mjs +0 -326
  393. package/dist/reasoning/pattern-matcher.d.ts +0 -59
  394. package/dist/reasoning/pattern-matcher.d.ts.map +0 -1
  395. package/dist/reasoning/pattern-matcher.js +0 -229
  396. package/dist/reasoning/pattern-matcher.js.map +0 -1
  397. package/dist/reasoning/pattern-matcher.mjs +0 -224
  398. package/dist/reasoningbank/adapter/agentdb-adapter.d.ts +0 -118
  399. package/dist/reasoningbank/adapter/agentdb-adapter.d.ts.map +0 -1
  400. package/dist/reasoningbank/adapter/agentdb-adapter.js +0 -477
  401. package/dist/reasoningbank/adapter/agentdb-adapter.js.map +0 -1
  402. package/dist/reasoningbank/adapter/types.d.ts +0 -113
  403. package/dist/reasoningbank/adapter/types.d.ts.map +0 -1
  404. package/dist/reasoningbank/adapter/types.js +0 -9
  405. package/dist/reasoningbank/adapter/types.js.map +0 -1
  406. package/dist/reasoningbank/cli/commands.d.ts +0 -16
  407. package/dist/reasoningbank/cli/commands.d.ts.map +0 -1
  408. package/dist/reasoningbank/cli/commands.js +0 -272
  409. package/dist/reasoningbank/cli/commands.js.map +0 -1
  410. package/dist/reasoningbank/mcp/agentdb-tools.d.ts +0 -319
  411. package/dist/reasoningbank/mcp/agentdb-tools.d.ts.map +0 -1
  412. package/dist/reasoningbank/mcp/agentdb-tools.js +0 -301
  413. package/dist/reasoningbank/mcp/agentdb-tools.js.map +0 -1
  414. package/dist/reasoningbank/migration/migrate.d.ts +0 -25
  415. package/dist/reasoningbank/migration/migrate.d.ts.map +0 -1
  416. package/dist/reasoningbank/migration/migrate.js +0 -178
  417. package/dist/reasoningbank/migration/migrate.js.map +0 -1
  418. package/dist/reasoningbank/reasoning/context-synthesizer.d.ts +0 -37
  419. package/dist/reasoningbank/reasoning/context-synthesizer.d.ts.map +0 -1
  420. package/dist/reasoningbank/reasoning/context-synthesizer.js +0 -114
  421. package/dist/reasoningbank/reasoning/context-synthesizer.js.map +0 -1
  422. package/dist/reasoningbank/reasoning/experience-curator.d.ts +0 -39
  423. package/dist/reasoningbank/reasoning/experience-curator.d.ts.map +0 -1
  424. package/dist/reasoningbank/reasoning/experience-curator.js +0 -98
  425. package/dist/reasoningbank/reasoning/experience-curator.js.map +0 -1
  426. package/dist/reasoningbank/reasoning/memory-optimizer.d.ts +0 -44
  427. package/dist/reasoningbank/reasoning/memory-optimizer.d.ts.map +0 -1
  428. package/dist/reasoningbank/reasoning/memory-optimizer.js +0 -184
  429. package/dist/reasoningbank/reasoning/memory-optimizer.js.map +0 -1
  430. package/dist/reasoningbank/reasoning/pattern-matcher.d.ts +0 -40
  431. package/dist/reasoningbank/reasoning/pattern-matcher.d.ts.map +0 -1
  432. package/dist/reasoningbank/reasoning/pattern-matcher.js +0 -87
  433. package/dist/reasoningbank/reasoning/pattern-matcher.js.map +0 -1
  434. package/dist/reasoningbank/sync/quic-sync.d.ts +0 -77
  435. package/dist/reasoningbank/sync/quic-sync.d.ts.map +0 -1
  436. package/dist/reasoningbank/sync/quic-sync.js +0 -165
  437. package/dist/reasoningbank/sync/quic-sync.js.map +0 -1
  438. package/dist/sync/conflict.d.ts +0 -78
  439. package/dist/sync/conflict.d.ts.map +0 -1
  440. package/dist/sync/conflict.js +0 -202
  441. package/dist/sync/conflict.js.map +0 -1
  442. package/dist/sync/conflict.mjs +0 -196
  443. package/dist/sync/coordinator.d.ts +0 -111
  444. package/dist/sync/coordinator.d.ts.map +0 -1
  445. package/dist/sync/coordinator.js +0 -256
  446. package/dist/sync/coordinator.js.map +0 -1
  447. package/dist/sync/coordinator.mjs +0 -250
  448. package/dist/sync/delta.d.ts +0 -81
  449. package/dist/sync/delta.d.ts.map +0 -1
  450. package/dist/sync/delta.js +0 -245
  451. package/dist/sync/delta.js.map +0 -1
  452. package/dist/sync/delta.mjs +0 -238
  453. package/dist/sync/index.d.ts +0 -11
  454. package/dist/sync/index.d.ts.map +0 -1
  455. package/dist/sync/index.js +0 -22
  456. package/dist/sync/index.js.map +0 -1
  457. package/dist/sync/index.mjs +0 -9
  458. package/dist/sync/quic-sync.d.ts +0 -81
  459. package/dist/sync/quic-sync.d.ts.map +0 -1
  460. package/dist/sync/quic-sync.js +0 -329
  461. package/dist/sync/quic-sync.js.map +0 -1
  462. package/dist/sync/quic-sync.mjs +0 -323
  463. package/dist/sync/types.d.ts +0 -168
  464. package/dist/sync/types.d.ts.map +0 -1
  465. package/dist/sync/types.js +0 -8
  466. package/dist/sync/types.js.map +0 -1
  467. package/dist/sync/types.mjs +0 -6
  468. package/dist/types/index.d.ts +0 -117
  469. package/dist/types/index.d.ts.map +0 -1
  470. package/dist/types/index.js +0 -6
  471. package/dist/types/index.js.map +0 -1
  472. package/dist/types/index.mjs +0 -4
  473. package/dist/wasm/sql-wasm-debug.js +0 -6989
  474. package/dist/wasm/sql-wasm-debug.wasm +0 -0
  475. package/dist/wasm/sql-wasm.js +0 -188
  476. package/dist/wasm/sql-wasm.wasm +0 -0
  477. package/dist/wasm-loader.d.ts +0 -32
  478. package/dist/wasm-loader.d.ts.map +0 -1
  479. package/dist/wasm-loader.js +0 -78
  480. package/dist/wasm-loader.js.map +0 -1
  481. package/dist/wasm-loader.mjs +0 -67
  482. package/examples/adaptive-learning.ts +0 -284
  483. package/examples/browser/README.md +0 -732
  484. package/examples/browser/adaptive-recommendations/index.html +0 -427
  485. package/examples/browser/collaborative-filtering/index.html +0 -310
  486. package/examples/browser/continual-learning/index.html +0 -736
  487. package/examples/browser/experience-replay/index.html +0 -616
  488. package/examples/browser/index.html +0 -369
  489. package/examples/browser/meta-learning/index.html +0 -789
  490. package/examples/browser/neuro-symbolic/index.html +0 -692
  491. package/examples/browser/pattern-learning/index.html +0 -620
  492. package/examples/browser/quantum-inspired/index.html +0 -728
  493. package/examples/browser/rag/index.html +0 -624
  494. package/examples/browser/swarm-intelligence/index.html +0 -811
  495. package/examples/browser-basic.html +0 -170
  496. package/examples/browser-wasm-real.html +0 -231
  497. package/examples/hnsw-example.ts +0 -148
  498. package/examples/mcp-learning-example.ts +0 -220
  499. package/examples/node-basic.js +0 -70
  500. package/examples/quic-sync-example.ts +0 -310
  501. package/examples/quick-start.js +0 -68
  502. package/examples/test-v1.0.7-cdn.html +0 -190
  503. package/examples/wasm-example.ts +0 -222
@@ -0,0 +1,665 @@
1
+ /**
2
+ * Comprehensive Tests for Frontier Features
3
+ *
4
+ * Validates:
5
+ * 1. CausalMemoryGraph - causal inference, uplift calculation, A/B testing
6
+ * 2. ExplainableRecall - minimal hitting sets, Merkle proofs, provenance
7
+ *
8
+ * NO MOCKING - Real SQLite database, real algorithms, real results
9
+ */
10
+ import Database from 'better-sqlite3';
11
+ import * as fs from 'fs';
12
+ import * as path from 'path';
13
+ import { CausalMemoryGraph } from '../controllers/CausalMemoryGraph';
14
+ import { ExplainableRecall } from '../controllers/ExplainableRecall';
15
+ describe('Frontier Features - CausalMemoryGraph', () => {
16
+ let db;
17
+ let causalGraph;
18
+ beforeEach(() => {
19
+ // Create in-memory database
20
+ db = new Database(':memory:');
21
+ // Load core schema
22
+ const coreSchema = fs.readFileSync(path.join(__dirname, '../schemas/schema.sql'), 'utf-8');
23
+ db.exec(coreSchema);
24
+ // Load frontier schema
25
+ const frontierSchema = fs.readFileSync(path.join(__dirname, '../schemas/frontier-schema.sql'), 'utf-8');
26
+ db.exec(frontierSchema);
27
+ causalGraph = new CausalMemoryGraph(db);
28
+ // Insert test episodes
29
+ const episodes = [
30
+ { session_id: 'session1', task: 'code_review', reward: 0.8, success: 1 },
31
+ { session_id: 'session1', task: 'bug_fix', reward: 0.9, success: 1 },
32
+ { session_id: 'session2', task: 'feature_impl', reward: 0.7, success: 1 },
33
+ { session_id: 'session2', task: 'testing', reward: 0.85, success: 1 },
34
+ { session_id: 'session3', task: 'refactoring', reward: 0.75, success: 1 },
35
+ ];
36
+ const stmt = db.prepare(`
37
+ INSERT INTO episodes (session_id, task, reward, success)
38
+ VALUES (?, ?, ?, ?)
39
+ `);
40
+ episodes.forEach(ep => {
41
+ stmt.run(ep.session_id, ep.task, ep.reward, ep.success);
42
+ });
43
+ });
44
+ afterEach(() => {
45
+ db.close();
46
+ });
47
+ test('should add causal edge with all properties', () => {
48
+ const edge = {
49
+ fromMemoryId: 1,
50
+ fromMemoryType: 'episode',
51
+ toMemoryId: 2,
52
+ toMemoryType: 'episode',
53
+ similarity: 0.85,
54
+ uplift: 0.15,
55
+ confidence: 0.9,
56
+ sampleSize: 100,
57
+ evidenceIds: ['exp1', 'exp2'],
58
+ mechanism: 'code_review improves bug_fix success'
59
+ };
60
+ const edgeId = causalGraph.addCausalEdge(edge);
61
+ expect(edgeId).toBeGreaterThan(0);
62
+ // Verify stored correctly
63
+ const stored = db.prepare('SELECT * FROM causal_edges WHERE id = ?').get(edgeId);
64
+ expect(stored.from_memory_id).toBe(1);
65
+ expect(stored.to_memory_id).toBe(2);
66
+ expect(stored.similarity).toBe(0.85);
67
+ expect(stored.uplift).toBe(0.15);
68
+ expect(stored.confidence).toBe(0.9);
69
+ expect(stored.sample_size).toBe(100);
70
+ expect(JSON.parse(stored.evidence_ids)).toEqual(['exp1', 'exp2']);
71
+ expect(stored.mechanism).toBe('code_review improves bug_fix success');
72
+ });
73
+ test('should create and track A/B experiment', () => {
74
+ const experiment = {
75
+ name: 'Test Code Review Impact',
76
+ hypothesis: 'Code review reduces bugs',
77
+ treatmentId: 1,
78
+ treatmentType: 'episode',
79
+ controlId: 3,
80
+ startTime: Date.now(),
81
+ sampleSize: 0,
82
+ status: 'running'
83
+ };
84
+ const expId = causalGraph.createExperiment(experiment);
85
+ expect(expId).toBeGreaterThan(0);
86
+ // Verify stored
87
+ const stored = db.prepare('SELECT * FROM causal_experiments WHERE id = ?').get(expId);
88
+ expect(stored.name).toBe('Test Code Review Impact');
89
+ expect(stored.status).toBe('running');
90
+ expect(stored.sample_size).toBe(0);
91
+ });
92
+ test('should record observations and update sample size', () => {
93
+ const expId = causalGraph.createExperiment({
94
+ name: 'Test Experiment',
95
+ hypothesis: 'Treatment improves outcome',
96
+ treatmentId: 1,
97
+ treatmentType: 'episode',
98
+ startTime: Date.now(),
99
+ sampleSize: 0,
100
+ status: 'running'
101
+ });
102
+ // Record treatment observation
103
+ causalGraph.recordObservation({
104
+ experimentId: expId,
105
+ episodeId: 1,
106
+ isTreatment: true,
107
+ outcomeValue: 0.9,
108
+ outcomeType: 'reward'
109
+ });
110
+ // Record control observation
111
+ causalGraph.recordObservation({
112
+ experimentId: expId,
113
+ episodeId: 2,
114
+ isTreatment: false,
115
+ outcomeValue: 0.7,
116
+ outcomeType: 'reward'
117
+ });
118
+ // Check sample size updated
119
+ const experiment = db.prepare('SELECT * FROM causal_experiments WHERE id = ?').get(expId);
120
+ expect(experiment.sample_size).toBe(2);
121
+ // Check observations stored
122
+ const observations = db.prepare('SELECT * FROM causal_observations WHERE experiment_id = ?').all(expId);
123
+ expect(observations).toHaveLength(2);
124
+ });
125
+ test('should calculate uplift with statistical significance', () => {
126
+ const expId = causalGraph.createExperiment({
127
+ name: 'Uplift Test',
128
+ hypothesis: 'Treatment increases reward',
129
+ treatmentId: 1,
130
+ treatmentType: 'episode',
131
+ startTime: Date.now(),
132
+ sampleSize: 0,
133
+ status: 'running'
134
+ });
135
+ // Record 50 treatment observations (mean ~0.8)
136
+ for (let i = 0; i < 50; i++) {
137
+ causalGraph.recordObservation({
138
+ experimentId: expId,
139
+ episodeId: 1,
140
+ isTreatment: true,
141
+ outcomeValue: 0.75 + Math.random() * 0.1, // 0.75-0.85
142
+ outcomeType: 'reward'
143
+ });
144
+ }
145
+ // Record 50 control observations (mean ~0.6)
146
+ for (let i = 0; i < 50; i++) {
147
+ causalGraph.recordObservation({
148
+ experimentId: expId,
149
+ episodeId: 2,
150
+ isTreatment: false,
151
+ outcomeValue: 0.55 + Math.random() * 0.1, // 0.55-0.65
152
+ outcomeType: 'reward'
153
+ });
154
+ }
155
+ const result = causalGraph.calculateUplift(expId);
156
+ // Validate results
157
+ expect(result.uplift).toBeGreaterThan(0.1); // Treatment > Control
158
+ expect(result.uplift).toBeLessThan(0.3); // Reasonable range
159
+ expect(result.pValue).toBeLessThan(0.05); // Statistically significant
160
+ expect(result.confidenceInterval[0]).toBeLessThan(result.uplift);
161
+ expect(result.confidenceInterval[1]).toBeGreaterThan(result.uplift);
162
+ // Verify experiment updated
163
+ const experiment = db.prepare('SELECT * FROM causal_experiments WHERE id = ?').get(expId);
164
+ expect(experiment.status).toBe('completed');
165
+ expect(experiment.uplift).toBeCloseTo(result.uplift, 5);
166
+ expect(experiment.p_value).toBeCloseTo(result.pValue, 5);
167
+ });
168
+ test('should query causal effects by confidence and uplift', () => {
169
+ // Add multiple causal edges
170
+ causalGraph.addCausalEdge({
171
+ fromMemoryId: 1,
172
+ fromMemoryType: 'episode',
173
+ toMemoryId: 2,
174
+ toMemoryType: 'episode',
175
+ similarity: 0.8,
176
+ uplift: 0.2,
177
+ confidence: 0.9,
178
+ sampleSize: 100
179
+ });
180
+ causalGraph.addCausalEdge({
181
+ fromMemoryId: 1,
182
+ fromMemoryType: 'episode',
183
+ toMemoryId: 3,
184
+ toMemoryType: 'episode',
185
+ similarity: 0.7,
186
+ uplift: 0.05, // Low uplift
187
+ confidence: 0.95,
188
+ sampleSize: 80
189
+ });
190
+ causalGraph.addCausalEdge({
191
+ fromMemoryId: 1,
192
+ fromMemoryType: 'episode',
193
+ toMemoryId: 4,
194
+ toMemoryType: 'episode',
195
+ similarity: 0.85,
196
+ uplift: 0.25,
197
+ confidence: 0.4, // Low confidence
198
+ sampleSize: 50
199
+ });
200
+ // Query with filters
201
+ const effects = causalGraph.queryCausalEffects({
202
+ interventionMemoryId: 1,
203
+ interventionMemoryType: 'episode',
204
+ minConfidence: 0.8,
205
+ minUplift: 0.1
206
+ });
207
+ // Should only return first edge (high confidence + high uplift)
208
+ expect(effects).toHaveLength(1);
209
+ expect(effects[0].toMemoryId).toBe(2);
210
+ expect(effects[0].confidence).toBe(0.9);
211
+ expect(effects[0].uplift).toBe(0.2);
212
+ });
213
+ test('should find multi-hop causal chains', () => {
214
+ // Create chain: 1 -> 2 -> 3
215
+ causalGraph.addCausalEdge({
216
+ fromMemoryId: 1,
217
+ fromMemoryType: 'episode',
218
+ toMemoryId: 2,
219
+ toMemoryType: 'episode',
220
+ similarity: 0.8,
221
+ uplift: 0.1,
222
+ confidence: 0.9,
223
+ sampleSize: 100
224
+ });
225
+ causalGraph.addCausalEdge({
226
+ fromMemoryId: 2,
227
+ fromMemoryType: 'episode',
228
+ toMemoryId: 3,
229
+ toMemoryType: 'episode',
230
+ similarity: 0.75,
231
+ uplift: 0.15,
232
+ confidence: 0.85,
233
+ sampleSize: 80
234
+ });
235
+ // Also add direct edge 1 -> 3 (lower uplift)
236
+ causalGraph.addCausalEdge({
237
+ fromMemoryId: 1,
238
+ fromMemoryType: 'episode',
239
+ toMemoryId: 3,
240
+ toMemoryType: 'episode',
241
+ similarity: 0.7,
242
+ uplift: 0.05,
243
+ confidence: 0.8,
244
+ sampleSize: 60
245
+ });
246
+ const chains = causalGraph.getCausalChain(1, 3, 5);
247
+ // Should find both paths
248
+ expect(chains.length).toBeGreaterThanOrEqual(1);
249
+ // The 2-hop path should have higher total uplift
250
+ const twoHopChain = chains.find(c => c.path.length === 3); // [1, 2, 3]
251
+ expect(twoHopChain).toBeDefined();
252
+ expect(twoHopChain.path).toEqual([1, 2, 3]);
253
+ expect(twoHopChain.totalUplift).toBeCloseTo(0.25, 1); // 0.1 + 0.15
254
+ expect(twoHopChain.confidence).toBeGreaterThanOrEqual(0.85); // Min of chain
255
+ });
256
+ test('should detect potential confounders', () => {
257
+ // Create scenario where episode 3 might be a confounder
258
+ // for the relationship between episode 1 and episode 2
259
+ const edgeId = causalGraph.addCausalEdge({
260
+ fromMemoryId: 1,
261
+ fromMemoryType: 'episode',
262
+ toMemoryId: 2,
263
+ toMemoryType: 'episode',
264
+ similarity: 0.8,
265
+ uplift: 0.2,
266
+ confidence: 0.9,
267
+ sampleSize: 100
268
+ });
269
+ const result = causalGraph.detectConfounders(edgeId);
270
+ // Should return confounders array (may be empty in test data)
271
+ expect(result).toHaveProperty('confounders');
272
+ expect(Array.isArray(result.confounders)).toBe(true);
273
+ // Each confounder should have required properties
274
+ result.confounders.forEach(conf => {
275
+ expect(conf).toHaveProperty('memoryId');
276
+ expect(conf).toHaveProperty('correlationWithTreatment');
277
+ expect(conf).toHaveProperty('correlationWithOutcome');
278
+ expect(conf).toHaveProperty('confounderScore');
279
+ expect(conf.confounderScore).toBeGreaterThan(0.3);
280
+ });
281
+ });
282
+ test('should calculate causal gain vs baseline', () => {
283
+ // Add causal edges from treatment (episode 1) to outcomes
284
+ causalGraph.addCausalEdge({
285
+ fromMemoryId: 1,
286
+ fromMemoryType: 'episode',
287
+ toMemoryId: 2,
288
+ toMemoryType: 'episode',
289
+ similarity: 0.85,
290
+ uplift: 0.2,
291
+ confidence: 0.9,
292
+ mechanism: 'improves outcome'
293
+ });
294
+ const result = causalGraph.calculateCausalGain(1, 'reward');
295
+ // Should calculate difference between treated and untreated episodes
296
+ expect(result).toHaveProperty('causalGain');
297
+ expect(result).toHaveProperty('confidence');
298
+ expect(result).toHaveProperty('mechanism');
299
+ expect(result.confidence).toBeGreaterThanOrEqual(0);
300
+ expect(result.confidence).toBeLessThanOrEqual(1);
301
+ expect(typeof result.causalGain).toBe('number');
302
+ });
303
+ });
304
+ describe('Frontier Features - ExplainableRecall', () => {
305
+ let db;
306
+ let explainableRecall;
307
+ beforeEach(() => {
308
+ db = new Database(':memory:');
309
+ const coreSchema = fs.readFileSync(path.join(__dirname, '../schemas/schema.sql'), 'utf-8');
310
+ db.exec(coreSchema);
311
+ const frontierSchema = fs.readFileSync(path.join(__dirname, '../schemas/frontier-schema.sql'), 'utf-8');
312
+ db.exec(frontierSchema);
313
+ explainableRecall = new ExplainableRecall(db);
314
+ // Insert test episodes
315
+ for (let i = 1; i <= 10; i++) {
316
+ db.prepare(`
317
+ INSERT INTO episodes (session_id, task, reward, success)
318
+ VALUES (?, ?, ?, ?)
319
+ `).run(`session${i}`, `task${i}`, 0.8, 1);
320
+ }
321
+ });
322
+ afterEach(() => {
323
+ db.close();
324
+ });
325
+ test('should create recall certificate with minimal hitting set', () => {
326
+ const chunks = [
327
+ { id: '1', type: 'episode', content: 'Implement authentication', relevance: 0.9 },
328
+ { id: '2', type: 'episode', content: 'Add JWT tokens', relevance: 0.85 },
329
+ { id: '3', type: 'episode', content: 'Hash passwords', relevance: 0.8 },
330
+ { id: '4', type: 'episode', content: 'Setup database', relevance: 0.7 }
331
+ ];
332
+ const requirements = [
333
+ 'authentication',
334
+ 'security',
335
+ 'tokens'
336
+ ];
337
+ const certificate = explainableRecall.createCertificate({
338
+ queryId: 'q1',
339
+ queryText: 'How to implement secure authentication?',
340
+ chunks,
341
+ requirements,
342
+ accessLevel: 'internal'
343
+ });
344
+ // Validate certificate structure
345
+ expect(certificate).toHaveProperty('id');
346
+ expect(certificate.queryId).toBe('q1');
347
+ expect(certificate.chunkIds).toEqual(['1', '2', '3', '4']);
348
+ expect(certificate.chunkTypes).toEqual(['episode', 'episode', 'episode', 'episode']);
349
+ // Validate minimal hitting set
350
+ expect(certificate.minimalWhy).toBeDefined();
351
+ expect(certificate.minimalWhy.length).toBeGreaterThan(0);
352
+ expect(certificate.minimalWhy.length).toBeLessThanOrEqual(chunks.length);
353
+ // Redundancy ratio should be >= 1
354
+ expect(certificate.redundancyRatio).toBeGreaterThanOrEqual(1);
355
+ expect(certificate.redundancyRatio).toBe(chunks.length / certificate.minimalWhy.length);
356
+ // Completeness should be 0-1
357
+ expect(certificate.completenessScore).toBeGreaterThanOrEqual(0);
358
+ expect(certificate.completenessScore).toBeLessThanOrEqual(1);
359
+ // Merkle root should exist
360
+ expect(certificate.merkleRoot).toBeDefined();
361
+ expect(certificate.merkleRoot.length).toBeGreaterThan(0);
362
+ // Source hashes should match chunks
363
+ expect(certificate.sourceHashes).toHaveLength(chunks.length);
364
+ // Access level
365
+ expect(certificate.accessLevel).toBe('internal');
366
+ // Latency tracking
367
+ expect(certificate.latencyMs).toBeGreaterThan(0);
368
+ });
369
+ test('should verify certificate integrity', () => {
370
+ const chunks = [
371
+ { id: '1', type: 'episode', content: 'Test content 1', relevance: 0.9 },
372
+ { id: '2', type: 'episode', content: 'Test content 2', relevance: 0.8 }
373
+ ];
374
+ const certificate = explainableRecall.createCertificate({
375
+ queryId: 'q2',
376
+ queryText: 'Test query',
377
+ chunks,
378
+ requirements: ['test'],
379
+ accessLevel: 'public'
380
+ });
381
+ // Verify the certificate
382
+ const verification = explainableRecall.verifyCertificate(certificate.id);
383
+ expect(verification.valid).toBe(true);
384
+ expect(verification.issues).toHaveLength(0);
385
+ });
386
+ test('should detect tampered certificate', () => {
387
+ const chunks = [
388
+ { id: '1', type: 'episode', content: 'Original content', relevance: 0.9 }
389
+ ];
390
+ const certificate = explainableRecall.createCertificate({
391
+ queryId: 'q3',
392
+ queryText: 'Test query',
393
+ chunks,
394
+ requirements: ['test'],
395
+ accessLevel: 'internal'
396
+ });
397
+ // Tamper with the certificate in database
398
+ db.prepare(`
399
+ UPDATE recall_certificates
400
+ SET chunk_ids = ?
401
+ WHERE id = ?
402
+ `).run(JSON.stringify(['1', '999']), certificate.id);
403
+ // Verification should fail
404
+ const verification = explainableRecall.verifyCertificate(certificate.id);
405
+ expect(verification.valid).toBe(false);
406
+ expect(verification.issues.length).toBeGreaterThan(0);
407
+ expect(verification.issues[0]).toContain('Merkle root');
408
+ });
409
+ test('should provide justification for each chunk', () => {
410
+ const chunks = [
411
+ { id: '1', type: 'episode', content: 'Setup API endpoint', relevance: 0.9 },
412
+ { id: '2', type: 'episode', content: 'Add validation', relevance: 0.85 }
413
+ ];
414
+ const certificate = explainableRecall.createCertificate({
415
+ queryId: 'q4',
416
+ queryText: 'How to create API?',
417
+ chunks,
418
+ requirements: ['api', 'validation'],
419
+ accessLevel: 'internal'
420
+ });
421
+ // Get justification for first chunk
422
+ const justification = explainableRecall.getJustification(certificate.id, '1');
423
+ expect(justification).toBeDefined();
424
+ expect(justification.chunkId).toBe('1');
425
+ expect(justification.chunkType).toBe('episode');
426
+ expect(justification.reason).toBeDefined();
427
+ expect(justification.necessityScore).toBeGreaterThanOrEqual(0);
428
+ expect(justification.necessityScore).toBeLessThanOrEqual(1);
429
+ expect(justification.pathElements).toBeDefined();
430
+ expect(Array.isArray(justification.pathElements)).toBe(true);
431
+ });
432
+ test('should track provenance lineage', () => {
433
+ // Create source with provenance
434
+ const sourceId = explainableRecall.createProvenance({
435
+ sourceType: 'episode',
436
+ sourceId: 1,
437
+ creator: 'test_user'
438
+ });
439
+ expect(sourceId).toBeGreaterThan(0);
440
+ // Get the content hash
441
+ const source = db.prepare('SELECT * FROM provenance_sources WHERE id = ?').get(sourceId);
442
+ expect(source).toBeDefined();
443
+ expect(source.content_hash).toBeDefined();
444
+ // Track lineage
445
+ const lineage = explainableRecall.getProvenanceLineage(source.content_hash);
446
+ expect(lineage).toHaveLength(1);
447
+ expect(lineage[0].sourceType).toBe('episode');
448
+ expect(lineage[0].sourceId).toBe(1);
449
+ expect(lineage[0].creator).toBe('test_user');
450
+ });
451
+ test('should audit certificate for quality metrics', () => {
452
+ const chunks = [
453
+ { id: '1', type: 'episode', content: 'Content 1', relevance: 0.95 },
454
+ { id: '2', type: 'episode', content: 'Content 2', relevance: 0.9 },
455
+ { id: '3', type: 'episode', content: 'Content 3', relevance: 0.85 },
456
+ { id: '4', type: 'episode', content: 'Content 4', relevance: 0.5 } // Low relevance
457
+ ];
458
+ const certificate = explainableRecall.createCertificate({
459
+ queryId: 'q5',
460
+ queryText: 'Test audit query',
461
+ chunks,
462
+ requirements: ['req1', 'req2'],
463
+ accessLevel: 'internal'
464
+ });
465
+ const audit = explainableRecall.auditCertificate(certificate.id);
466
+ // Validate audit structure
467
+ expect(audit).toHaveProperty('certificateId');
468
+ expect(audit).toHaveProperty('queryText');
469
+ expect(audit).toHaveProperty('totalChunks');
470
+ expect(audit).toHaveProperty('minimalSetSize');
471
+ expect(audit).toHaveProperty('redundancyRatio');
472
+ expect(audit).toHaveProperty('completenessScore');
473
+ expect(audit).toHaveProperty('avgNecessityScore');
474
+ expect(audit).toHaveProperty('provenanceVerified');
475
+ expect(audit).toHaveProperty('qualityScore');
476
+ expect(audit.certificateId).toBe(certificate.id);
477
+ expect(audit.totalChunks).toBe(4);
478
+ expect(audit.minimalSetSize).toBeGreaterThan(0);
479
+ expect(audit.redundancyRatio).toBeGreaterThanOrEqual(1);
480
+ expect(audit.qualityScore).toBeGreaterThanOrEqual(0);
481
+ expect(audit.qualityScore).toBeLessThanOrEqual(1);
482
+ expect(audit.provenanceVerified).toBe(true);
483
+ });
484
+ test('should handle empty chunks gracefully', () => {
485
+ const certificate = explainableRecall.createCertificate({
486
+ queryId: 'q6',
487
+ queryText: 'Empty query',
488
+ chunks: [],
489
+ requirements: ['test'],
490
+ accessLevel: 'public'
491
+ });
492
+ expect(certificate.chunkIds).toHaveLength(0);
493
+ expect(certificate.minimalWhy).toHaveLength(0);
494
+ expect(certificate.redundancyRatio).toBe(0);
495
+ expect(certificate.completenessScore).toBe(0);
496
+ });
497
+ test('should calculate correct minimal hitting set', () => {
498
+ // Test case: Each chunk covers different requirements
499
+ const chunks = [
500
+ { id: '1', type: 'episode', content: 'auth implementation', relevance: 0.9 },
501
+ { id: '2', type: 'episode', content: 'database setup', relevance: 0.85 },
502
+ { id: '3', type: 'episode', content: 'API endpoints', relevance: 0.8 }
503
+ ];
504
+ const requirements = ['auth', 'database', 'api'];
505
+ const certificate = explainableRecall.createCertificate({
506
+ queryId: 'q7',
507
+ queryText: 'Full stack implementation',
508
+ chunks,
509
+ requirements,
510
+ accessLevel: 'internal'
511
+ });
512
+ // All chunks should be in minimal set (each covers unique requirement)
513
+ expect(certificate.minimalWhy.length).toBe(3);
514
+ expect(certificate.redundancyRatio).toBe(1.0);
515
+ });
516
+ test('should generate valid Merkle proofs', () => {
517
+ const chunks = Array.from({ length: 8 }, (_, i) => ({
518
+ id: `${i + 1}`,
519
+ type: 'episode',
520
+ content: `Content ${i + 1}`,
521
+ relevance: 0.9 - i * 0.05
522
+ }));
523
+ const certificate = explainableRecall.createCertificate({
524
+ queryId: 'q8',
525
+ queryText: 'Merkle test',
526
+ chunks,
527
+ requirements: ['test'],
528
+ accessLevel: 'internal'
529
+ });
530
+ // Merkle root should be deterministic
531
+ expect(certificate.merkleRoot).toBeDefined();
532
+ expect(certificate.merkleRoot.length).toBe(64); // SHA-256 hex = 64 chars
533
+ // Source hashes should match chunks
534
+ expect(certificate.sourceHashes).toHaveLength(8);
535
+ certificate.sourceHashes.forEach(hash => {
536
+ expect(hash.length).toBe(64);
537
+ });
538
+ });
539
+ });
540
+ describe('Frontier Features - Integration Tests', () => {
541
+ let db;
542
+ let causalGraph;
543
+ let explainableRecall;
544
+ beforeEach(() => {
545
+ db = new Database(':memory:');
546
+ const coreSchema = fs.readFileSync(path.join(__dirname, '../schemas/schema.sql'), 'utf-8');
547
+ db.exec(coreSchema);
548
+ const frontierSchema = fs.readFileSync(path.join(__dirname, '../schemas/frontier-schema.sql'), 'utf-8');
549
+ db.exec(frontierSchema);
550
+ causalGraph = new CausalMemoryGraph(db);
551
+ explainableRecall = new ExplainableRecall(db);
552
+ });
553
+ afterEach(() => {
554
+ db.close();
555
+ });
556
+ test('should combine causal reasoning with explainable recall', () => {
557
+ // 1. Insert episodes
558
+ for (let i = 1; i <= 5; i++) {
559
+ db.prepare(`
560
+ INSERT INTO episodes (session_id, task, reward, success)
561
+ VALUES (?, ?, ?, ?)
562
+ `).run(`session${i}`, `task${i}`, 0.7 + i * 0.05, 1);
563
+ }
564
+ // 2. Add causal edges
565
+ causalGraph.addCausalEdge({
566
+ fromMemoryId: 1,
567
+ fromMemoryType: 'episode',
568
+ toMemoryId: 2,
569
+ toMemoryType: 'episode',
570
+ similarity: 0.85,
571
+ uplift: 0.15,
572
+ confidence: 0.9,
573
+ mechanism: 'task1 improves task2'
574
+ });
575
+ // 3. Create retrieval with provenance
576
+ const chunks = [
577
+ { id: '1', type: 'episode', content: 'First task', relevance: 0.9 },
578
+ { id: '2', type: 'episode', content: 'Second task', relevance: 0.85 }
579
+ ];
580
+ const certificate = explainableRecall.createCertificate({
581
+ queryId: 'integrated_q1',
582
+ queryText: 'Show me tasks with causal relationships',
583
+ chunks,
584
+ requirements: ['causal', 'evidence'],
585
+ accessLevel: 'internal'
586
+ });
587
+ // 4. Verify we can query both systems
588
+ const causalEffects = causalGraph.queryCausalEffects({
589
+ interventionMemoryId: 1,
590
+ interventionMemoryType: 'episode',
591
+ minConfidence: 0.8
592
+ });
593
+ expect(causalEffects.length).toBeGreaterThan(0);
594
+ expect(certificate).toBeDefined();
595
+ expect(certificate.minimalWhy.length).toBeGreaterThan(0);
596
+ // 5. Audit the certificate
597
+ const audit = explainableRecall.auditCertificate(certificate.id);
598
+ expect(audit.provenanceVerified).toBe(true);
599
+ });
600
+ test('should handle large-scale causal experiments efficiently', () => {
601
+ // Create experiment with many observations
602
+ const expId = causalGraph.createExperiment({
603
+ name: 'Large Scale Test',
604
+ hypothesis: 'Treatment improves outcome at scale',
605
+ treatmentId: 1,
606
+ treatmentType: 'episode',
607
+ startTime: Date.now(),
608
+ sampleSize: 0,
609
+ status: 'running'
610
+ });
611
+ const startTime = Date.now();
612
+ // Record 1000 observations
613
+ for (let i = 0; i < 1000; i++) {
614
+ causalGraph.recordObservation({
615
+ experimentId: expId,
616
+ episodeId: i % 10 + 1,
617
+ isTreatment: i % 2 === 0,
618
+ outcomeValue: (i % 2 === 0 ? 0.8 : 0.6) + Math.random() * 0.1,
619
+ outcomeType: 'reward'
620
+ });
621
+ }
622
+ const recordTime = Date.now() - startTime;
623
+ // Calculate uplift
624
+ const calcStart = Date.now();
625
+ const result = causalGraph.calculateUplift(expId);
626
+ const calcTime = Date.now() - calcStart;
627
+ // Performance assertions
628
+ expect(recordTime).toBeLessThan(1000); // < 1 second to record 1000 observations
629
+ expect(calcTime).toBeLessThan(100); // < 100ms to calculate uplift
630
+ // Result assertions
631
+ expect(result.uplift).toBeGreaterThan(0.1);
632
+ expect(result.pValue).toBeLessThan(0.05);
633
+ });
634
+ test('should handle concurrent certificate creation', () => {
635
+ const chunks = Array.from({ length: 10 }, (_, i) => ({
636
+ id: `${i + 1}`,
637
+ type: 'episode',
638
+ content: `Content ${i + 1}`,
639
+ relevance: 0.9 - i * 0.05
640
+ }));
641
+ // Create multiple certificates concurrently
642
+ const certificates = [];
643
+ for (let i = 0; i < 10; i++) {
644
+ const cert = explainableRecall.createCertificate({
645
+ queryId: `concurrent_q${i}`,
646
+ queryText: `Concurrent query ${i}`,
647
+ chunks: chunks.slice(0, i + 1),
648
+ requirements: ['test'],
649
+ accessLevel: 'internal'
650
+ });
651
+ certificates.push(cert);
652
+ }
653
+ // All should succeed
654
+ expect(certificates).toHaveLength(10);
655
+ certificates.forEach((cert, idx) => {
656
+ expect(cert.queryId).toBe(`concurrent_q${idx}`);
657
+ expect(cert.chunkIds.length).toBe(idx + 1);
658
+ });
659
+ // All should be verifiable
660
+ certificates.forEach(cert => {
661
+ const verification = explainableRecall.verifyCertificate(cert.id);
662
+ expect(verification.valid).toBe(true);
663
+ });
664
+ });
665
+ });