memento-mcp-server 0.1.0 → 1.7.1

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 (560) hide show
  1. package/INSTALL.en.md +303 -303
  2. package/INSTALL.md +303 -303
  3. package/README.en.md +331 -330
  4. package/README.md +432 -427
  5. package/dist/algorithms/hybrid-search-engine.d.ts +114 -44
  6. package/dist/algorithms/hybrid-search-engine.d.ts.map +1 -1
  7. package/dist/algorithms/hybrid-search-engine.js +261 -235
  8. package/dist/algorithms/hybrid-search-engine.js.map +1 -1
  9. package/dist/algorithms/search-engine.d.ts +2 -14
  10. package/dist/algorithms/search-engine.d.ts.map +1 -1
  11. package/dist/algorithms/search-engine.js +43 -35
  12. package/dist/algorithms/search-engine.js.map +1 -1
  13. package/dist/algorithms/vector-search-engine-migration.d.ts +67 -0
  14. package/dist/algorithms/vector-search-engine-migration.d.ts.map +1 -0
  15. package/dist/algorithms/vector-search-engine-migration.js +196 -0
  16. package/dist/algorithms/vector-search-engine-migration.js.map +1 -0
  17. package/dist/algorithms/vector-search-engine-refactored.d.ts +56 -0
  18. package/dist/algorithms/vector-search-engine-refactored.d.ts.map +1 -0
  19. package/dist/algorithms/vector-search-engine-refactored.js +101 -0
  20. package/dist/algorithms/vector-search-engine-refactored.js.map +1 -0
  21. package/dist/algorithms/vector-search-engine.d.ts +9 -2
  22. package/dist/algorithms/vector-search-engine.d.ts.map +1 -1
  23. package/dist/algorithms/vector-search-engine.js +245 -121
  24. package/dist/algorithms/vector-search-engine.js.map +1 -1
  25. package/dist/client/index.d.ts.map +1 -1
  26. package/dist/client/index.js +34 -11
  27. package/dist/client/index.js.map +1 -1
  28. package/dist/config/environment.d.ts +26 -0
  29. package/dist/config/environment.d.ts.map +1 -0
  30. package/dist/config/environment.js +103 -0
  31. package/dist/config/environment.js.map +1 -0
  32. package/dist/config/index.d.ts.map +1 -1
  33. package/dist/config/index.js +29 -50
  34. package/dist/config/index.js.map +1 -1
  35. package/dist/config/vector-search.config.d.ts +25 -0
  36. package/dist/config/vector-search.config.d.ts.map +1 -0
  37. package/dist/config/vector-search.config.js +40 -0
  38. package/dist/config/vector-search.config.js.map +1 -0
  39. package/dist/database/init.d.ts.map +1 -1
  40. package/dist/database/init.js +154 -17
  41. package/dist/database/init.js.map +1 -1
  42. package/dist/database/migrate.d.ts +2 -1
  43. package/dist/database/migrate.d.ts.map +1 -1
  44. package/dist/database/migrate.js +191 -18
  45. package/dist/database/migrate.js.map +1 -1
  46. package/dist/database/schema.sql +234 -159
  47. package/dist/factories/hybrid-search.factory.d.ts +20 -0
  48. package/dist/factories/hybrid-search.factory.d.ts.map +1 -0
  49. package/dist/factories/hybrid-search.factory.js +57 -0
  50. package/dist/factories/hybrid-search.factory.js.map +1 -0
  51. package/dist/factories/spaced-repetition.factory.d.ts +48 -0
  52. package/dist/factories/spaced-repetition.factory.d.ts.map +1 -0
  53. package/dist/factories/spaced-repetition.factory.js +187 -0
  54. package/dist/factories/spaced-repetition.factory.js.map +1 -0
  55. package/dist/factories/vector-search.factory.d.ts +25 -0
  56. package/dist/factories/vector-search.factory.d.ts.map +1 -0
  57. package/dist/factories/vector-search.factory.js +47 -0
  58. package/dist/factories/vector-search.factory.js.map +1 -0
  59. package/dist/interfaces/database.interface.d.ts +36 -0
  60. package/dist/interfaces/database.interface.d.ts.map +1 -0
  61. package/dist/interfaces/database.interface.js +6 -0
  62. package/dist/interfaces/database.interface.js.map +1 -0
  63. package/dist/interfaces/spaced-repetition.interface.d.ts +63 -0
  64. package/dist/interfaces/spaced-repetition.interface.d.ts.map +1 -0
  65. package/dist/interfaces/spaced-repetition.interface.js +6 -0
  66. package/dist/interfaces/spaced-repetition.interface.js.map +1 -0
  67. package/dist/repositories/vector-performance.repository.d.ts +25 -0
  68. package/dist/repositories/vector-performance.repository.d.ts.map +1 -0
  69. package/dist/repositories/vector-performance.repository.js +134 -0
  70. package/dist/repositories/vector-performance.repository.js.map +1 -0
  71. package/dist/repositories/vector-search.repository.d.ts +43 -0
  72. package/dist/repositories/vector-search.repository.d.ts.map +1 -0
  73. package/dist/repositories/vector-search.repository.js +377 -0
  74. package/dist/repositories/vector-search.repository.js.map +1 -0
  75. package/dist/server/http-server.d.ts.map +1 -1
  76. package/dist/server/http-server.js +25 -24
  77. package/dist/server/http-server.js.map +1 -1
  78. package/dist/server/index.d.ts +1 -0
  79. package/dist/server/index.d.ts.map +1 -1
  80. package/dist/server/index.js +3 -1
  81. package/dist/server/index.js.map +1 -1
  82. package/dist/services/alert-notification-service.d.ts +16 -0
  83. package/dist/services/alert-notification-service.d.ts.map +1 -0
  84. package/dist/services/alert-notification-service.js +44 -0
  85. package/dist/services/alert-notification-service.js.map +1 -0
  86. package/dist/services/async-optimizer.d.ts +62 -8
  87. package/dist/services/async-optimizer.d.ts.map +1 -1
  88. package/dist/services/async-optimizer.js +137 -8
  89. package/dist/services/async-optimizer.js.map +1 -1
  90. package/dist/services/batch-scheduler.d.ts +6 -0
  91. package/dist/services/batch-scheduler.d.ts.map +1 -1
  92. package/dist/services/batch-scheduler.js +59 -19
  93. package/dist/services/batch-scheduler.js.map +1 -1
  94. package/dist/services/cache-service.d.ts +32 -0
  95. package/dist/services/cache-service.d.ts.map +1 -1
  96. package/dist/services/cache-service.js +81 -6
  97. package/dist/services/cache-service.js.map +1 -1
  98. package/dist/services/database-optimizer.js +63 -63
  99. package/dist/services/database-optimizer.js.map +1 -1
  100. package/dist/services/embedding-migration-service.d.ts +24 -0
  101. package/dist/services/embedding-migration-service.d.ts.map +1 -0
  102. package/dist/services/embedding-migration-service.js +360 -0
  103. package/dist/services/embedding-migration-service.js.map +1 -0
  104. package/dist/services/embedding-provider-factory.d.ts +12 -5
  105. package/dist/services/embedding-provider-factory.d.ts.map +1 -1
  106. package/dist/services/embedding-provider-factory.js +107 -26
  107. package/dist/services/embedding-provider-factory.js.map +1 -1
  108. package/dist/services/forgetting-policy-service.js +17 -17
  109. package/dist/services/gemini-embedding-service.d.ts +1 -1
  110. package/dist/services/gemini-embedding-service.d.ts.map +1 -1
  111. package/dist/services/gemini-embedding-service.js +25 -18
  112. package/dist/services/gemini-embedding-service.js.map +1 -1
  113. package/dist/services/memory-embedding-service.d.ts +8 -0
  114. package/dist/services/memory-embedding-service.d.ts.map +1 -1
  115. package/dist/services/memory-embedding-service.js +180 -71
  116. package/dist/services/memory-embedding-service.js.map +1 -1
  117. package/dist/services/migration-history-service.d.ts +14 -0
  118. package/dist/services/migration-history-service.d.ts.map +1 -0
  119. package/dist/services/migration-history-service.js +270 -0
  120. package/dist/services/migration-history-service.js.map +1 -0
  121. package/dist/services/migration-monitor-service.d.ts +24 -0
  122. package/dist/services/migration-monitor-service.d.ts.map +1 -0
  123. package/dist/services/migration-monitor-service.js +93 -0
  124. package/dist/services/migration-monitor-service.js.map +1 -0
  125. package/dist/services/model-availability-service.d.ts +22 -0
  126. package/dist/services/model-availability-service.d.ts.map +1 -0
  127. package/dist/services/model-availability-service.js +140 -0
  128. package/dist/services/model-availability-service.js.map +1 -0
  129. package/dist/services/openai-embedding-service.d.ts +36 -0
  130. package/dist/services/openai-embedding-service.d.ts.map +1 -0
  131. package/dist/services/openai-embedding-service.js +192 -0
  132. package/dist/services/openai-embedding-service.js.map +1 -0
  133. package/dist/services/performance-monitor.d.ts +154 -10
  134. package/dist/services/performance-monitor.d.ts.map +1 -1
  135. package/dist/services/performance-monitor.js +446 -60
  136. package/dist/services/performance-monitor.js.map +1 -1
  137. package/dist/services/spaced-repetition/interval-calculation.service.d.ts +38 -0
  138. package/dist/services/spaced-repetition/interval-calculation.service.d.ts.map +1 -0
  139. package/dist/services/spaced-repetition/interval-calculation.service.js +105 -0
  140. package/dist/services/spaced-repetition/interval-calculation.service.js.map +1 -0
  141. package/dist/services/spaced-repetition/optimal-interval.service.d.ts +56 -0
  142. package/dist/services/spaced-repetition/optimal-interval.service.d.ts.map +1 -0
  143. package/dist/services/spaced-repetition/optimal-interval.service.js +163 -0
  144. package/dist/services/spaced-repetition/optimal-interval.service.js.map +1 -0
  145. package/dist/services/spaced-repetition/performance-analysis.service.d.ts +48 -0
  146. package/dist/services/spaced-repetition/performance-analysis.service.d.ts.map +1 -0
  147. package/dist/services/spaced-repetition/performance-analysis.service.js +174 -0
  148. package/dist/services/spaced-repetition/performance-analysis.service.js.map +1 -0
  149. package/dist/services/spaced-repetition/priority-calculation.service.d.ts +53 -0
  150. package/dist/services/spaced-repetition/priority-calculation.service.d.ts.map +1 -0
  151. package/dist/services/spaced-repetition/priority-calculation.service.js +161 -0
  152. package/dist/services/spaced-repetition/priority-calculation.service.js.map +1 -0
  153. package/dist/services/spaced-repetition/recall-probability.service.d.ts +36 -0
  154. package/dist/services/spaced-repetition/recall-probability.service.d.ts.map +1 -0
  155. package/dist/services/spaced-repetition/recall-probability.service.js +88 -0
  156. package/dist/services/spaced-repetition/recall-probability.service.js.map +1 -0
  157. package/dist/services/spaced-repetition/review-scheduling.service.d.ts +43 -0
  158. package/dist/services/spaced-repetition/review-scheduling.service.d.ts.map +1 -0
  159. package/dist/services/spaced-repetition/review-scheduling.service.js +130 -0
  160. package/dist/services/spaced-repetition/review-scheduling.service.js.map +1 -0
  161. package/dist/services/spaced-repetition/spaced-repetition-container.d.ts +69 -0
  162. package/dist/services/spaced-repetition/spaced-repetition-container.d.ts.map +1 -0
  163. package/dist/services/spaced-repetition/spaced-repetition-container.js +136 -0
  164. package/dist/services/spaced-repetition/spaced-repetition-container.js.map +1 -0
  165. package/dist/services/unified-embedding-service.d.ts +3 -0
  166. package/dist/services/unified-embedding-service.d.ts.map +1 -1
  167. package/dist/services/unified-embedding-service.js +58 -62
  168. package/dist/services/unified-embedding-service.js.map +1 -1
  169. package/dist/services/vector-compatibility-service.d.ts +68 -0
  170. package/dist/services/vector-compatibility-service.d.ts.map +1 -0
  171. package/dist/services/vector-compatibility-service.js +373 -0
  172. package/dist/services/vector-compatibility-service.js.map +1 -0
  173. package/dist/services/vector-search/vector-index-manager.d.ts +27 -0
  174. package/dist/services/vector-search/vector-index-manager.d.ts.map +1 -0
  175. package/dist/services/vector-search/vector-index-manager.js +66 -0
  176. package/dist/services/vector-search/vector-index-manager.js.map +1 -0
  177. package/dist/services/vector-search/vector-performance-tester.d.ts +30 -0
  178. package/dist/services/vector-search/vector-performance-tester.d.ts.map +1 -0
  179. package/dist/services/vector-search/vector-performance-tester.js +87 -0
  180. package/dist/services/vector-search/vector-performance-tester.js.map +1 -0
  181. package/dist/services/vector-search/vector-search-container.d.ts +41 -0
  182. package/dist/services/vector-search/vector-search-container.d.ts.map +1 -0
  183. package/dist/services/vector-search/vector-search-container.js +74 -0
  184. package/dist/services/vector-search/vector-search-container.js.map +1 -0
  185. package/dist/services/vector-search/vector-search-facade.d.ts +63 -0
  186. package/dist/services/vector-search/vector-search-facade.d.ts.map +1 -0
  187. package/dist/services/vector-search/vector-search-facade.js +91 -0
  188. package/dist/services/vector-search/vector-search-facade.js.map +1 -0
  189. package/dist/services/vector-search/vector-search-result-normalizer.d.ts +6 -0
  190. package/dist/services/vector-search/vector-search-result-normalizer.d.ts.map +1 -0
  191. package/dist/services/vector-search/vector-search-result-normalizer.js +65 -0
  192. package/dist/services/vector-search/vector-search-result-normalizer.js.map +1 -0
  193. package/dist/services/vector-search/vector-search.service.d.ts +33 -0
  194. package/dist/services/vector-search/vector-search.service.d.ts.map +1 -0
  195. package/dist/services/vector-search/vector-search.service.js +149 -0
  196. package/dist/services/vector-search/vector-search.service.js.map +1 -0
  197. package/dist/tools/forget-tool.js +14 -14
  198. package/dist/tools/pin-tool.js +14 -14
  199. package/dist/tools/unpin-tool.js +21 -21
  200. package/dist/types/alerts.types.d.ts +26 -0
  201. package/dist/types/alerts.types.d.ts.map +1 -0
  202. package/dist/types/alerts.types.js +2 -0
  203. package/dist/types/alerts.types.js.map +1 -0
  204. package/dist/types/embedding-provider-monitoring.types.d.ts +24 -0
  205. package/dist/types/embedding-provider-monitoring.types.d.ts.map +1 -0
  206. package/dist/types/embedding-provider-monitoring.types.js +2 -0
  207. package/dist/types/embedding-provider-monitoring.types.js.map +1 -0
  208. package/dist/types/embedding.types.d.ts +36 -1
  209. package/dist/types/embedding.types.d.ts.map +1 -1
  210. package/dist/types/migration.types.d.ts +131 -0
  211. package/dist/types/migration.types.d.ts.map +1 -0
  212. package/dist/types/migration.types.js +6 -0
  213. package/dist/types/migration.types.js.map +1 -0
  214. package/dist/types/spaced-repetition.types.d.ts +61 -0
  215. package/dist/types/spaced-repetition.types.d.ts.map +1 -0
  216. package/dist/types/spaced-repetition.types.js +6 -0
  217. package/dist/types/spaced-repetition.types.js.map +1 -0
  218. package/dist/types/vector-search.types.d.ts +96 -0
  219. package/dist/types/vector-search.types.d.ts.map +1 -0
  220. package/dist/types/vector-search.types.js +2 -0
  221. package/dist/types/vector-search.types.js.map +1 -0
  222. package/dist/utils/configuration-validator.d.ts +23 -0
  223. package/dist/utils/configuration-validator.d.ts.map +1 -0
  224. package/dist/utils/configuration-validator.js +102 -0
  225. package/dist/utils/configuration-validator.js.map +1 -0
  226. package/dist/utils/database.d.ts.map +1 -1
  227. package/dist/utils/database.js +101 -95
  228. package/dist/utils/database.js.map +1 -1
  229. package/dist/utils/environment-check.d.ts +8 -0
  230. package/dist/utils/environment-check.d.ts.map +1 -0
  231. package/dist/utils/environment-check.js +25 -0
  232. package/dist/utils/environment-check.js.map +1 -0
  233. package/dist/utils/logger.d.ts +8 -0
  234. package/dist/utils/logger.d.ts.map +1 -0
  235. package/dist/utils/logger.js +33 -0
  236. package/dist/utils/logger.js.map +1 -0
  237. package/package.json +139 -125
  238. package/scripts/auto-setup.js +234 -234
  239. package/scripts/backup-daily.bat +28 -28
  240. package/scripts/backup-embeddings.js +108 -108
  241. package/scripts/check-db-integrity.js +93 -93
  242. package/scripts/debug-embeddings.js +184 -184
  243. package/scripts/direct-sql-migration.sql +36 -36
  244. package/scripts/docker-migration.sh +105 -105
  245. package/scripts/fix-migration.js +93 -93
  246. package/scripts/fix-vector-dimensions.js +206 -206
  247. package/scripts/migrate-embedding-data.js +307 -307
  248. package/scripts/regenerate-embeddings.js +144 -144
  249. package/scripts/restore-legacy.ps1 +60 -60
  250. package/scripts/run-migration.js +122 -122
  251. package/scripts/safe-migration.js +150 -150
  252. package/scripts/simple-migrate.js +41 -41
  253. package/scripts/simple-update.js +123 -123
  254. package/src/database/schema.sql +234 -159
  255. package/.cursor/rules/cache-management.mdc +0 -171
  256. package/.cursor/rules/database-schema.mdc +0 -344
  257. package/.cursor/rules/deployment.mdc +0 -596
  258. package/.cursor/rules/error-logging.mdc +0 -298
  259. package/.cursor/rules/forgetting-algorithms.mdc +0 -426
  260. package/.cursor/rules/http-server.mdc +0 -432
  261. package/.cursor/rules/hybrid-search.mdc +0 -424
  262. package/.cursor/rules/implementation.mdc +0 -369
  263. package/.cursor/rules/lightweight-embedding.mdc +0 -178
  264. package/.cursor/rules/mcp-client-development.mdc +0 -0
  265. package/.cursor/rules/mcp-server-development.mdc +0 -0
  266. package/.cursor/rules/mcp-tools-architecture.mdc +0 -205
  267. package/.cursor/rules/memento-memory-rule.mdc +0 -8
  268. package/.cursor/rules/memento-project-overview.mdc +0 -0
  269. package/.cursor/rules/memory-algorithms.mdc +0 -502
  270. package/.cursor/rules/monitoring.mdc +0 -622
  271. package/.cursor/rules/performance-alerts.mdc +0 -537
  272. package/.cursor/rules/performance-monitoring.mdc +0 -345
  273. package/.cursor/rules/performance-optimization.mdc +0 -563
  274. package/.cursor/rules/project-structure.mdc +0 -310
  275. package/.cursor/rules/testing.mdc +0 -473
  276. package/.dockerignore +0 -15
  277. package/.eslintrc.json +0 -34
  278. package/.github/ISSUE_TEMPLATE/bug_report.md +0 -51
  279. package/.github/ISSUE_TEMPLATE/feature_request.md +0 -45
  280. package/.github/ISSUE_TEMPLATE/question.md +0 -31
  281. package/.github/PULL_REQUEST_TEMPLATE.md +0 -97
  282. package/AGENTS.md +0 -28
  283. package/CHANGELOG.md +0 -416
  284. package/CODE_OF_CONDUCT.md +0 -62
  285. package/CONTRIBUTING.md +0 -165
  286. package/DOCKER_SETUP_GUIDE.md +0 -84
  287. package/Dockerfile +0 -90
  288. package/backup/legacy-removal-20250930-201816/http-server-legacy.ts +0 -1068
  289. package/backup/legacy-removal-20250930-201816/rollback-to-legacy.ps1 +0 -46
  290. package/backup/legacy-removal-20250930-201816/rollback-to-legacy.sh +0 -48
  291. package/dist/server/index-backup.d.ts +0 -5
  292. package/dist/server/index-backup.d.ts.map +0 -1
  293. package/dist/server/index-backup.js +0 -793
  294. package/dist/server/index-backup.js.map +0 -1
  295. package/dist/server/index-refactored.d.ts +0 -6
  296. package/dist/server/index-refactored.d.ts.map +0 -1
  297. package/dist/server/index-refactored.js +0 -206
  298. package/dist/server/index-refactored.js.map +0 -1
  299. package/dist/services/performance-monitoring-integration.d.ts +0 -77
  300. package/dist/services/performance-monitoring-integration.d.ts.map +0 -1
  301. package/dist/services/performance-monitoring-integration.js +0 -177
  302. package/dist/services/performance-monitoring-integration.js.map +0 -1
  303. package/dist/test/debug-http-v2.d.ts +0 -5
  304. package/dist/test/debug-http-v2.d.ts.map +0 -1
  305. package/dist/test/debug-http-v2.js +0 -28
  306. package/dist/test/debug-http-v2.js.map +0 -1
  307. package/dist/test/performance-benchmark.d.ts +0 -57
  308. package/dist/test/performance-benchmark.d.ts.map +0 -1
  309. package/dist/test/performance-benchmark.js +0 -427
  310. package/dist/test/performance-benchmark.js.map +0 -1
  311. package/dist/test/test-alerts-direct.d.ts +0 -7
  312. package/dist/test/test-alerts-direct.d.ts.map +0 -1
  313. package/dist/test/test-alerts-direct.js +0 -101
  314. package/dist/test/test-alerts-direct.js.map +0 -1
  315. package/dist/test/test-batch-scheduler.d.ts +0 -2
  316. package/dist/test/test-batch-scheduler.d.ts.map +0 -1
  317. package/dist/test/test-batch-scheduler.js +0 -156
  318. package/dist/test/test-batch-scheduler.js.map +0 -1
  319. package/dist/test/test-client.d.ts +0 -5
  320. package/dist/test/test-client.d.ts.map +0 -1
  321. package/dist/test/test-client.js +0 -86
  322. package/dist/test/test-client.js.map +0 -1
  323. package/dist/test/test-embedding.d.ts +0 -6
  324. package/dist/test/test-embedding.d.ts.map +0 -1
  325. package/dist/test/test-embedding.js +0 -142
  326. package/dist/test/test-embedding.js.map +0 -1
  327. package/dist/test/test-error-logging.d.ts +0 -7
  328. package/dist/test/test-error-logging.d.ts.map +0 -1
  329. package/dist/test/test-error-logging.js +0 -105
  330. package/dist/test/test-error-logging.js.map +0 -1
  331. package/dist/test/test-forgetting.d.ts +0 -6
  332. package/dist/test/test-forgetting.d.ts.map +0 -1
  333. package/dist/test/test-forgetting.js +0 -154
  334. package/dist/test/test-forgetting.js.map +0 -1
  335. package/dist/test/test-gemini-embedding.d.ts +0 -7
  336. package/dist/test/test-gemini-embedding.d.ts.map +0 -1
  337. package/dist/test/test-gemini-embedding.js +0 -134
  338. package/dist/test/test-gemini-embedding.js.map +0 -1
  339. package/dist/test/test-http-server-v2-simple.d.ts +0 -6
  340. package/dist/test/test-http-server-v2-simple.d.ts.map +0 -1
  341. package/dist/test/test-http-server-v2-simple.js +0 -131
  342. package/dist/test/test-http-server-v2-simple.js.map +0 -1
  343. package/dist/test/test-http-server-v2.d.ts +0 -7
  344. package/dist/test/test-http-server-v2.d.ts.map +0 -1
  345. package/dist/test/test-http-server-v2.js +0 -529
  346. package/dist/test/test-http-server-v2.js.map +0 -1
  347. package/dist/test/test-lightweight-embedding.d.ts +0 -6
  348. package/dist/test/test-lightweight-embedding.d.ts.map +0 -1
  349. package/dist/test/test-lightweight-embedding.js +0 -189
  350. package/dist/test/test-lightweight-embedding.js.map +0 -1
  351. package/dist/test/test-m1-completion.d.ts +0 -7
  352. package/dist/test/test-m1-completion.d.ts.map +0 -1
  353. package/dist/test/test-m1-completion.js +0 -124
  354. package/dist/test/test-m1-completion.js.map +0 -1
  355. package/dist/test/test-memory-injection-prompt.d.ts +0 -2
  356. package/dist/test/test-memory-injection-prompt.d.ts.map +0 -1
  357. package/dist/test/test-memory-injection-prompt.js +0 -299
  358. package/dist/test/test-memory-injection-prompt.js.map +0 -1
  359. package/dist/test/test-performance-alerts.d.ts +0 -7
  360. package/dist/test/test-performance-alerts.d.ts.map +0 -1
  361. package/dist/test/test-performance-alerts.js +0 -109
  362. package/dist/test/test-performance-alerts.js.map +0 -1
  363. package/dist/test/test-performance-monitor.d.ts +0 -2
  364. package/dist/test/test-performance-monitor.d.ts.map +0 -1
  365. package/dist/test/test-performance-monitor.js +0 -182
  366. package/dist/test/test-performance-monitor.js.map +0 -1
  367. package/dist/test/test-performance-monitoring.d.ts +0 -6
  368. package/dist/test/test-performance-monitoring.d.ts.map +0 -1
  369. package/dist/test/test-performance-monitoring.js +0 -156
  370. package/dist/test/test-performance-monitoring.js.map +0 -1
  371. package/dist/test/test-search.d.ts +0 -5
  372. package/dist/test/test-search.d.ts.map +0 -1
  373. package/dist/test/test-search.js +0 -141
  374. package/dist/test/test-search.js.map +0 -1
  375. package/dist/test/test-simple-alerts.d.ts +0 -6
  376. package/dist/test/test-simple-alerts.d.ts.map +0 -1
  377. package/dist/test/test-simple-alerts.js +0 -106
  378. package/dist/test/test-simple-alerts.js.map +0 -1
  379. package/dist/test/test-vector-search-engine.d.ts +0 -2
  380. package/dist/test/test-vector-search-engine.d.ts.map +0 -1
  381. package/dist/test/test-vector-search-engine.js +0 -225
  382. package/dist/test/test-vector-search-engine.js.map +0 -1
  383. package/docker-compose.dev.yml +0 -50
  384. package/docker-compose.prod.yml +0 -77
  385. package/docker-compose.yml +0 -43
  386. package/docs/en/Memento-Goals.md +0 -217
  387. package/docs/en/Memento-M1-DetailSpecs.md +0 -130
  388. package/docs/en/Memento-Milestones.md +0 -135
  389. package/docs/en/Search-Ranking-Memory-Decay-Formulas.md +0 -177
  390. package/docs/en/api-reference.md +0 -658
  391. package/docs/en/architecture.md +0 -1302
  392. package/docs/en/developer-guide.md +0 -1005
  393. package/docs/en/user-manual.md +0 -595
  394. package/docs/ko/Memento-Goals.md +0 -217
  395. package/docs/ko/Memento-M1-DetailSpecs.md +0 -130
  396. package/docs/ko/Memento-Milestones.md +0 -134
  397. package/docs/ko/Search-Ranking-Memory-Decay-Formulas.md +0 -177
  398. package/docs/ko/api-reference.md +0 -658
  399. package/docs/ko/architecture.md +0 -1302
  400. package/docs/ko/developer-guide.md +0 -1006
  401. package/docs/ko/embedding-api-reference.md +0 -122
  402. package/docs/ko/embedding-configuration.md +0 -62
  403. package/docs/ko/embedding-performance-benchmark.md +0 -62
  404. package/docs/ko/embedding-service-guide.md +0 -314
  405. package/docs/ko/user-manual.md +0 -595
  406. package/env.example +0 -49
  407. package/install.sh +0 -191
  408. package/mcp-http-client.js +0 -218
  409. package/mcp.json +0 -0
  410. package/packages/mcp-client/docs/API-REFERENCE.md +0 -560
  411. package/packages/mcp-client/docs/BEST-PRACTICES.md +0 -564
  412. package/packages/mcp-client/docs/MIGRATION-GUIDE.md +0 -344
  413. package/packages/mcp-client/docs/PERFORMANCE-GUIDE.md +0 -476
  414. package/packages/mcp-client/docs/TROUBLESHOOTING.md +0 -564
  415. package/packages/mcp-client/package-lock.json +0 -907
  416. package/packages/mcp-client/package.json +0 -58
  417. package/packages/mcp-client/performance-optimizer.js +0 -428
  418. package/packages/mcp-client/test-basic.js +0 -65
  419. package/packages/mcp-client/test-integration.js +0 -366
  420. package/src/algorithms/forgetting-algorithm.spec.ts +0 -538
  421. package/src/algorithms/forgetting-algorithm.ts +0 -243
  422. package/src/algorithms/hybrid-search-engine.spec.ts +0 -484
  423. package/src/algorithms/hybrid-search-engine.ts +0 -489
  424. package/src/algorithms/search-engine.spec.ts +0 -429
  425. package/src/algorithms/search-engine.ts +0 -392
  426. package/src/algorithms/search-ranking.spec.ts +0 -293
  427. package/src/algorithms/search-ranking.ts +0 -407
  428. package/src/algorithms/spaced-repetition.spec.ts +0 -510
  429. package/src/algorithms/spaced-repetition.ts +0 -238
  430. package/src/algorithms/vector-search-engine.ts +0 -505
  431. package/src/client/index.spec.ts +0 -427
  432. package/src/client/index.ts +0 -222
  433. package/src/config/index.spec.ts +0 -339
  434. package/src/config/index.ts +0 -106
  435. package/src/database/init.spec.ts +0 -239
  436. package/src/database/init.ts +0 -130
  437. package/src/database/migrate.spec.ts +0 -293
  438. package/src/database/migrate.ts +0 -94
  439. package/src/database/migrations/001_add_embedding_metadata.sql +0 -29
  440. package/src/npm-client/context-injector.spec.ts +0 -335
  441. package/src/npm-client/context-injector.ts +0 -412
  442. package/src/npm-client/index.spec.ts +0 -108
  443. package/src/npm-client/index.ts +0 -96
  444. package/src/npm-client/memento-client.spec.ts +0 -549
  445. package/src/npm-client/memento-client.ts +0 -501
  446. package/src/npm-client/memory-manager.spec.ts +0 -374
  447. package/src/npm-client/memory-manager.ts +0 -414
  448. package/src/npm-client/types.spec.ts +0 -427
  449. package/src/npm-client/types.ts +0 -296
  450. package/src/npm-client/utils.spec.ts +0 -355
  451. package/src/npm-client/utils.ts +0 -423
  452. package/src/scripts/copy-assets.js +0 -37
  453. package/src/server/http-server.spec.ts +0 -648
  454. package/src/server/http-server.ts +0 -1030
  455. package/src/server/index-backup.ts +0 -875
  456. package/src/server/index-refactored.ts +0 -237
  457. package/src/server/index.spec.ts +0 -281
  458. package/src/server/index.ts +0 -347
  459. package/src/server/simple-mcp-server.spec.ts +0 -207
  460. package/src/server/simple-mcp-server.ts +0 -173
  461. package/src/services/async-optimizer.spec.ts +0 -569
  462. package/src/services/async-optimizer.ts +0 -484
  463. package/src/services/batch-scheduler.ts +0 -759
  464. package/src/services/cache-service.spec.ts +0 -372
  465. package/src/services/cache-service.ts +0 -434
  466. package/src/services/database-optimizer.spec.ts +0 -344
  467. package/src/services/database-optimizer.ts +0 -450
  468. package/src/services/embedding-provider-factory.ts +0 -173
  469. package/src/services/embedding-service.spec.ts +0 -342
  470. package/src/services/embedding-service.ts +0 -333
  471. package/src/services/error-logging-service.spec.ts +0 -416
  472. package/src/services/error-logging-service.ts +0 -383
  473. package/src/services/forgetting-policy-service.spec.ts +0 -140
  474. package/src/services/forgetting-policy-service.ts +0 -334
  475. package/src/services/gemini-embedding-service.spec.ts +0 -463
  476. package/src/services/gemini-embedding-service.ts +0 -283
  477. package/src/services/lightweight-embedding-service.spec.ts +0 -458
  478. package/src/services/lightweight-embedding-service.ts +0 -324
  479. package/src/services/memory-embedding-service.spec.ts +0 -417
  480. package/src/services/memory-embedding-service.ts +0 -289
  481. package/src/services/minilm-embedding-service.spec.ts +0 -104
  482. package/src/services/minilm-embedding-service.ts +0 -262
  483. package/src/services/performance-alert-service.spec.ts +0 -517
  484. package/src/services/performance-alert-service.ts +0 -477
  485. package/src/services/performance-monitor.spec.ts +0 -401
  486. package/src/services/performance-monitor.ts +0 -532
  487. package/src/services/performance-monitoring-integration.spec.ts +0 -478
  488. package/src/services/performance-monitoring-integration.ts.bak +0 -276
  489. package/src/services/unified-embedding-service.spec.ts +0 -224
  490. package/src/services/unified-embedding-service.ts +0 -255
  491. package/src/test/debug-http-v2.ts +0 -30
  492. package/src/test/embedding-integration-test.spec.ts +0 -295
  493. package/src/test/embedding-integration-test.ts +0 -295
  494. package/src/test/embedding-performance-benchmark.spec.ts +0 -354
  495. package/src/test/embedding-performance-benchmark.ts +0 -312
  496. package/src/test/performance-benchmark.ts +0 -565
  497. package/src/test/test-alerts-direct.ts +0 -136
  498. package/src/test/test-batch-scheduler-simple.spec.ts +0 -122
  499. package/src/test/test-batch-scheduler.spec.ts +0 -453
  500. package/src/test/test-batch-scheduler.ts +0 -182
  501. package/src/test/test-client.ts +0 -97
  502. package/src/test/test-embedding.ts +0 -153
  503. package/src/test/test-error-handling.spec.ts +0 -575
  504. package/src/test/test-error-logging.ts +0 -117
  505. package/src/test/test-forgetting.ts +0 -162
  506. package/src/test/test-gemini-embedding.ts +0 -159
  507. package/src/test/test-http-server-v2-simple.ts +0 -147
  508. package/src/test/test-http-server-v2.ts +0 -586
  509. package/src/test/test-hybrid-search-engine.spec.ts +0 -521
  510. package/src/test/test-integration-fixed.spec.ts +0 -612
  511. package/src/test/test-integration.spec.ts +0 -463
  512. package/src/test/test-lightweight-embedding.ts +0 -208
  513. package/src/test/test-m1-completion.spec.ts +0 -614
  514. package/src/test/test-m1-completion.ts +0 -141
  515. package/src/test/test-m1-integration.spec.ts +0 -514
  516. package/src/test/test-memory-injection-prompt.spec.ts +0 -650
  517. package/src/test/test-memory-injection-prompt.ts +0 -391
  518. package/src/test/test-performance-alerts.ts +0 -125
  519. package/src/test/test-performance-monitor-updates.spec.ts +0 -490
  520. package/src/test/test-performance-monitor.spec.ts +0 -284
  521. package/src/test/test-performance-monitor.ts +0 -228
  522. package/src/test/test-performance-monitoring.ts +0 -171
  523. package/src/test/test-search.ts +0 -151
  524. package/src/test/test-simple-alerts.ts +0 -136
  525. package/src/test/test-vector-search-engine.spec.ts +0 -408
  526. package/src/test/test-vector-search-engine.ts +0 -303
  527. package/src/tools/base-tool.ts +0 -189
  528. package/src/tools/cleanup-memory-tool.ts +0 -77
  529. package/src/tools/database-optimize-tool.ts +0 -79
  530. package/src/tools/error-stats.ts +0 -119
  531. package/src/tools/forget-tool.spec.ts +0 -613
  532. package/src/tools/forget-tool.ts +0 -454
  533. package/src/tools/forgetting-stats-tool.ts +0 -47
  534. package/src/tools/index.ts +0 -71
  535. package/src/tools/memory-injection-prompt.ts +0 -257
  536. package/src/tools/performance-alerts.ts +0 -226
  537. package/src/tools/performance-stats-tool.ts +0 -48
  538. package/src/tools/pin-tool.spec.ts +0 -497
  539. package/src/tools/pin-tool.ts +0 -277
  540. package/src/tools/recall-tool.spec.ts +0 -475
  541. package/src/tools/recall-tool.ts +0 -389
  542. package/src/tools/remember-tool.spec.ts +0 -469
  543. package/src/tools/remember-tool.ts +0 -112
  544. package/src/tools/resolve-error.ts +0 -69
  545. package/src/tools/tool-registry.ts +0 -417
  546. package/src/tools/types.ts +0 -63
  547. package/src/tools/unpin-tool.spec.ts +0 -549
  548. package/src/tools/unpin-tool.ts +0 -306
  549. package/src/types/embedding.types.ts +0 -78
  550. package/src/types/index.spec.ts +0 -420
  551. package/src/types/index.ts +0 -117
  552. package/src/utils/database.spec.ts +0 -77
  553. package/src/utils/database.ts +0 -458
  554. package/src/utils/stopwords.ts +0 -128
  555. package/start-docker-setup.bat +0 -38
  556. package/static/logo.png +0 -0
  557. package/static/memento_logo.svg +0 -2
  558. package/test-docker.js +0 -103
  559. package/tsconfig.json +0 -46
  560. package/vitest.config.ts +0 -23
@@ -1,575 +0,0 @@
1
- import { describe, it, expect, beforeEach, afterEach, vi } from 'vitest';
2
- import { HybridSearchEngine } from '../algorithms/hybrid-search-engine.js';
3
- import { getVectorSearchEngine } from '../algorithms/vector-search-engine.js';
4
- import { getBatchScheduler } from '../services/batch-scheduler.js';
5
- import { getPerformanceMonitor } from '../services/performance-monitor.js';
6
- import { MemoryInjectionPrompt } from '../tools/memory-injection-prompt.js';
7
- import Database from 'better-sqlite3';
8
- import { DatabaseUtils } from '../utils/database.js';
9
-
10
- // Mock dependencies
11
- vi.mock('../algorithms/search-engine.js', () => ({
12
- SearchEngine: vi.fn().mockImplementation(() => ({
13
- search: vi.fn().mockResolvedValue({
14
- items: [],
15
- total_count: 0,
16
- query_time: 0
17
- })
18
- }))
19
- }));
20
- vi.mock('../services/memory-embedding-service.js', () => ({
21
- MemoryEmbeddingService: vi.fn().mockImplementation(() => ({
22
- isAvailable: vi.fn().mockReturnValue(false),
23
- generateEmbedding: vi.fn().mockRejectedValue(new Error('Embedding service unavailable')),
24
- searchBySimilarity: vi.fn().mockResolvedValue([]),
25
- getEmbeddingStats: vi.fn().mockResolvedValue({})
26
- }))
27
- }));
28
- vi.mock('../services/forgetting-policy-service.js', () => ({
29
- ForgettingPolicyService: vi.fn().mockImplementation(() => ({
30
- executeMemoryCleanup: vi.fn().mockRejectedValue(new Error('Forgetting service unavailable'))
31
- }))
32
- }));
33
-
34
- describe('Error Handling and Recovery Tests', () => {
35
- let db: Database.Database;
36
- let hybridSearchEngine: HybridSearchEngine;
37
- let vectorSearchEngine: ReturnType<typeof getVectorSearchEngine>;
38
- let batchScheduler: ReturnType<typeof getBatchScheduler>;
39
- let performanceMonitor: ReturnType<typeof getPerformanceMonitor>;
40
- let memoryInjectionPrompt: MemoryInjectionPrompt;
41
-
42
- beforeEach(async () => {
43
- // Create in-memory database for testing
44
- db = new Database(':memory:');
45
- await DatabaseUtils.initializeDatabase(db);
46
-
47
- // Initialize services
48
- hybridSearchEngine = new HybridSearchEngine();
49
- vectorSearchEngine = getVectorSearchEngine();
50
- vectorSearchEngine.initialize(db);
51
-
52
- batchScheduler = getBatchScheduler({
53
- cleanupInterval: 1000,
54
- monitoringInterval: 500,
55
- enableLogging: false
56
- });
57
-
58
- performanceMonitor = getPerformanceMonitor();
59
- performanceMonitor.initialize(db);
60
-
61
- memoryInjectionPrompt = new MemoryInjectionPrompt();
62
- });
63
-
64
- afterEach(() => {
65
- if (db) {
66
- db.close();
67
- }
68
- vi.clearAllMocks();
69
- });
70
-
71
- describe('데이터베이스 연결 실패', () => {
72
- it('should handle database connection loss gracefully', async () => {
73
- // Close database to simulate connection loss
74
- db.close();
75
-
76
- // Hybrid search should handle gracefully - it should not throw but return empty results
77
- const result = await hybridSearchEngine.search(db, {
78
- query: 'test',
79
- limit: 5
80
- });
81
-
82
- expect(result).toBeDefined();
83
- expect(result.items).toBeDefined();
84
- expect(Array.isArray(result.items)).toBe(true);
85
- });
86
-
87
- it('should handle database corruption', async () => {
88
- // Simulate database corruption by closing and reopening
89
- db.close();
90
- db = new Database(':memory:');
91
-
92
- // Should not throw during initialization
93
- expect(() => {
94
- vectorSearchEngine.initialize(db);
95
- }).not.toThrow();
96
- });
97
-
98
- it('should handle database timeout', async () => {
99
- // Mock slow database operations
100
- const originalPrepare = db.prepare;
101
- db.prepare = vi.fn().mockImplementation((query: string) => {
102
- return {
103
- all: vi.fn().mockImplementation(() => {
104
- return new Promise((resolve, reject) => {
105
- setTimeout(() => reject(new Error('Database timeout')), 100);
106
- });
107
- })
108
- };
109
- });
110
-
111
- const results = await vectorSearchEngine.search(Array(1536).fill(0.1));
112
- expect(results).toEqual([]);
113
-
114
- // Restore original
115
- db.prepare = originalPrepare;
116
- });
117
- });
118
-
119
- describe('메모리 부족 상황', () => {
120
- it('should handle memory allocation failures', async () => {
121
- // Mock memory allocation failure
122
- const originalMemoryUsage = process.memoryUsage;
123
- process.memoryUsage = vi.fn().mockReturnValue({
124
- rss: 0,
125
- heapTotal: 1000,
126
- heapUsed: 999, // 99.9% usage
127
- external: 0,
128
- arrayBuffers: 0
129
- });
130
-
131
- const metrics = await performanceMonitor.collectMetrics();
132
- expect(metrics).toBeDefined();
133
-
134
- // Should trigger memory alert
135
- const alerts = performanceMonitor.getActiveAlerts();
136
- const memoryAlert = alerts.find(a => a.type === 'memory');
137
- expect(memoryAlert).toBeDefined();
138
-
139
- // Restore original function
140
- process.memoryUsage = originalMemoryUsage;
141
- });
142
-
143
- it('should handle large query vectors', async () => {
144
- // Test with extremely large vector
145
- const largeVector = Array(10000).fill(0.1);
146
-
147
- const results = await vectorSearchEngine.search(largeVector, {
148
- limit: 5
149
- });
150
-
151
- expect(Array.isArray(results)).toBe(true);
152
- });
153
-
154
- it('should handle memory pressure in batch operations', async () => {
155
- await batchScheduler.start(db);
156
-
157
- // Simulate memory pressure
158
- const originalMemoryUsage = process.memoryUsage;
159
- process.memoryUsage = vi.fn().mockReturnValue({
160
- rss: 0,
161
- heapTotal: 1000,
162
- heapUsed: 950, // 95% usage
163
- external: 0,
164
- arrayBuffers: 0
165
- });
166
-
167
- const result = await batchScheduler.runJob('monitoring');
168
- expect(result.success).toBe(true);
169
-
170
- // Should collect metrics even under memory pressure
171
- expect(result.details?.metrics).toBeDefined();
172
-
173
- // Restore original function
174
- process.memoryUsage = originalMemoryUsage;
175
-
176
- batchScheduler.stop();
177
- });
178
- });
179
-
180
- describe('잘못된 입력 데이터', () => {
181
- it('should handle invalid search queries', async () => {
182
- const invalidQueries = [
183
- '', // Empty query
184
- null, // Null query
185
- undefined, // Undefined query
186
- 'a'.repeat(10000), // Extremely long query
187
- '🚀'.repeat(1000), // Emoji spam
188
- '<script>alert("xss")</script>', // XSS attempt
189
- 'DROP TABLE memory_item;', // SQL injection attempt
190
- ];
191
-
192
- for (const query of invalidQueries) {
193
- if (query === null || query === undefined) continue;
194
-
195
- const result = await hybridSearchEngine.search(db, {
196
- query: query as string,
197
- limit: 5
198
- });
199
-
200
- expect(result).toBeDefined();
201
- expect(result.items).toBeDefined();
202
- expect(Array.isArray(result.items)).toBe(true);
203
- }
204
- });
205
-
206
- it('should handle invalid vector dimensions', async () => {
207
- const invalidVectors = [
208
- [], // Empty vector
209
- Array(100).fill(0.1), // Wrong dimensions
210
- Array(5000).fill(0.1), // Too large
211
- [1, 2, 3, 'invalid', 5], // Mixed types
212
- Array(1536).fill(NaN), // NaN values
213
- Array(1536).fill(Infinity), // Infinity values
214
- ];
215
-
216
- for (const vector of invalidVectors) {
217
- const results = await vectorSearchEngine.search(vector as number[]);
218
- expect(Array.isArray(results)).toBe(true);
219
- }
220
- });
221
-
222
- it('should handle invalid memory injection parameters', async () => {
223
- const invalidParams = [
224
- { query: '', token_budget: -1, max_memories: 0 },
225
- { query: 'test', token_budget: 0, max_memories: -1 },
226
- { query: 'test', token_budget: 1000000, max_memories: 1000000 },
227
- { query: null, token_budget: 1000, max_memories: 5 },
228
- { query: 'test', token_budget: 'invalid', max_memories: 5 },
229
- ];
230
-
231
- for (const params of invalidParams) {
232
- if (params.query === null) continue;
233
-
234
- try {
235
- const result = await memoryInjectionPrompt.execute(
236
- params as any,
237
- {
238
- db,
239
- services: { hybridSearchEngine }
240
- }
241
- );
242
-
243
- expect(result).toBeDefined();
244
- } catch (error) {
245
- // Should handle gracefully
246
- expect(error).toBeDefined();
247
- }
248
- }
249
- });
250
- });
251
-
252
- describe('서비스 간 통신 실패', () => {
253
- it('should handle search engine failures', async () => {
254
- // Mock search engine failure
255
- const mockSearchEngine = {
256
- search: vi.fn().mockRejectedValue(new Error('Search engine unavailable'))
257
- };
258
-
259
- // This should be handled by the hybrid search engine
260
- const result = await hybridSearchEngine.search(db, {
261
- query: 'test',
262
- limit: 5
263
- });
264
-
265
- // Should still return results (possibly empty or from fallback)
266
- expect(result).toBeDefined();
267
- expect(result.items).toBeDefined();
268
- });
269
-
270
- it('should handle embedding service failures', async () => {
271
- // Mock embedding service failure
272
- const mockEmbeddingService = {
273
- isAvailable: vi.fn().mockReturnValue(false),
274
- generateEmbedding: vi.fn().mockRejectedValue(new Error('Embedding service unavailable')),
275
- searchBySimilarity: vi.fn().mockRejectedValue(new Error('Embedding service unavailable'))
276
- };
277
-
278
- // Should fallback gracefully
279
- const result = await hybridSearchEngine.search(db, {
280
- query: 'test',
281
- limit: 5
282
- });
283
-
284
- expect(result).toBeDefined();
285
- expect(result.items).toBeDefined();
286
- });
287
-
288
- it('should handle forgetting service failures', async () => {
289
- // Mock forgetting service failure
290
- const mockForgettingService = {
291
- executeMemoryCleanup: vi.fn().mockRejectedValue(new Error('Forgetting service unavailable'))
292
- };
293
-
294
- const result = await batchScheduler.runJob('cleanup');
295
-
296
- expect(result.success).toBe(false);
297
- expect(result.errors).toContain('Forgetting service unavailable');
298
- });
299
-
300
- it('should handle performance monitor failures', async () => {
301
- // Mock performance monitor failure by mocking the actual service
302
- const originalCollectMetrics = performanceMonitor.collectMetrics;
303
- performanceMonitor.collectMetrics = vi.fn().mockRejectedValue(new Error('Performance monitor unavailable'));
304
-
305
- const result = await batchScheduler.runJob('monitoring');
306
-
307
- expect(result.success).toBe(false);
308
- expect(result.errors).toContain('Performance monitor unavailable');
309
-
310
- // Restore original method
311
- performanceMonitor.collectMetrics = originalCollectMetrics;
312
- });
313
- });
314
-
315
- describe('리소스 제한 상황', () => {
316
- it('should handle CPU overload', async () => {
317
- // Mock high CPU usage
318
- const originalCpuUsage = process.cpuUsage;
319
- process.cpuUsage = vi.fn().mockReturnValue({
320
- user: 1000000, // High user time
321
- system: 1000000 // High system time
322
- });
323
-
324
- const metrics = await performanceMonitor.collectMetrics();
325
- expect(metrics).toBeDefined();
326
- expect(metrics.cpu.user).toBe(1000000);
327
- expect(metrics.cpu.system).toBe(1000000);
328
-
329
- // Restore original function
330
- process.cpuUsage = originalCpuUsage;
331
- });
332
-
333
- it('should handle disk space issues', async () => {
334
- // Mock large database size
335
- const originalPrepare = db.prepare;
336
- db.prepare = vi.fn().mockImplementation((query: string) => {
337
- if (query.includes('PRAGMA page_count')) {
338
- return { get: () => ({ page_count: 10000000 }) }; // Very large DB
339
- }
340
- if (query.includes('PRAGMA page_size')) {
341
- return { get: () => ({ page_size: 4096 }) };
342
- }
343
- if (query.includes('SELECT COUNT(*)')) {
344
- return { get: () => ({ count: 0 }) };
345
- }
346
- return originalPrepare.call(db, query);
347
- });
348
-
349
- const metrics = await performanceMonitor.collectMetrics();
350
- expect(metrics).toBeDefined();
351
-
352
- // Should trigger database size alert
353
- const alerts = performanceMonitor.getActiveAlerts();
354
- const dbAlert = alerts.find(a => a.type === 'database');
355
- expect(dbAlert).toBeDefined();
356
-
357
- // Restore original function
358
- db.prepare = originalPrepare;
359
- });
360
-
361
- it('should handle network timeouts', async () => {
362
- // Mock network timeout in external services
363
- const originalSetTimeout = global.setTimeout;
364
- let timeoutErrorThrown = false;
365
-
366
- global.setTimeout = vi.fn().mockImplementation((callback: any, delay: number) => {
367
- if (delay > 1000) {
368
- // Simulate timeout by throwing error immediately
369
- timeoutErrorThrown = true;
370
- throw new Error('Network timeout');
371
- }
372
- return originalSetTimeout(callback, delay);
373
- });
374
-
375
- // Should handle timeouts gracefully
376
- try {
377
- const result = await hybridSearchEngine.search(db, {
378
- query: 'test',
379
- limit: 5
380
- });
381
-
382
- // If no error was thrown, the result should be defined
383
- expect(result).toBeDefined();
384
- expect(result.items).toBeDefined();
385
- expect(Array.isArray(result.items)).toBe(true);
386
- } catch (error) {
387
- // If timeout error was thrown, it should be handled gracefully
388
- if (timeoutErrorThrown) {
389
- expect(error).toBeDefined();
390
- expect(error instanceof Error).toBe(true);
391
- } else {
392
- // Re-throw unexpected errors
393
- throw error;
394
- }
395
- }
396
-
397
- // Restore original function
398
- global.setTimeout = originalSetTimeout;
399
- });
400
- });
401
-
402
- describe('동시성 및 경쟁 상태', () => {
403
- it('should handle concurrent database access', async () => {
404
- const promises = [];
405
-
406
- // Simulate concurrent database operations
407
- for (let i = 0; i < 10; i++) {
408
- promises.push(
409
- hybridSearchEngine.search(db, {
410
- query: `concurrent test ${i}`,
411
- limit: 5
412
- })
413
- );
414
- }
415
-
416
- const results = await Promise.all(promises);
417
-
418
- expect(results.length).toBe(10);
419
- results.forEach(result => {
420
- expect(result).toBeDefined();
421
- expect(result.items).toBeDefined();
422
- });
423
- });
424
-
425
- it('should handle scheduler start/stop race conditions', async () => {
426
- const promises = [];
427
-
428
- // Simulate concurrent start/stop operations
429
- for (let i = 0; i < 5; i++) {
430
- promises.push(batchScheduler.start(db));
431
- promises.push(batchScheduler.stop());
432
- }
433
-
434
- // Should handle gracefully
435
- await Promise.allSettled(promises);
436
-
437
- const status = batchScheduler.getStatus();
438
- expect(status).toBeDefined();
439
- });
440
-
441
- it('should handle memory injection concurrent access', async () => {
442
- const promises = [];
443
-
444
- // Simulate concurrent memory injection - skip this test for now as MemoryInjectionPrompt needs proper setup
445
- // This test requires proper mocking of the MemoryInjectionPrompt class
446
- expect(true).toBe(true); // Placeholder test
447
- });
448
- });
449
-
450
- describe('데이터 무결성 및 복구', () => {
451
- it('should handle corrupted memory data', async () => {
452
- // Insert corrupted data with valid type and importance but invalid date
453
- db.prepare(`
454
- INSERT INTO memory_item (id, type, content, importance, created_at)
455
- VALUES (?, ?, ?, ?, ?)
456
- `).run('corrupted1', 'episodic', 'content', 0.5, 'invalid_date');
457
-
458
- // Should handle gracefully
459
- const result = await hybridSearchEngine.search(db, {
460
- query: 'test',
461
- limit: 5
462
- });
463
-
464
- expect(result).toBeDefined();
465
- expect(result.items).toBeDefined();
466
- });
467
-
468
- it('should handle missing required fields', async () => {
469
- // Insert incomplete data
470
- db.prepare(`
471
- INSERT INTO memory_item (id, type, content)
472
- VALUES (?, ?, ?)
473
- `).run('incomplete1', 'episodic', 'content');
474
-
475
- // Should handle gracefully
476
- const result = await hybridSearchEngine.search(db, {
477
- query: 'test',
478
- limit: 5
479
- });
480
-
481
- expect(result).toBeDefined();
482
- expect(result.items).toBeDefined();
483
- });
484
-
485
- it('should recover from partial failures', async () => {
486
- await batchScheduler.start(db);
487
-
488
- // Simulate partial failure by mocking the forgetting service
489
- const originalRunJob = batchScheduler.runJob;
490
- let callCount = 0;
491
- batchScheduler.runJob = vi.fn().mockImplementation(async (jobType: string) => {
492
- callCount++;
493
- if (callCount === 1) {
494
- return { success: false, errors: ['First call failed'] };
495
- }
496
- // For second call, return success
497
- return { success: true, details: { message: 'Recovery successful' } };
498
- });
499
-
500
- // First call should fail
501
- const result1 = await batchScheduler.runJob('cleanup');
502
- expect(result1.success).toBe(false);
503
-
504
- // Second call should succeed
505
- const result2 = await batchScheduler.runJob('cleanup');
506
- expect(result2.success).toBe(true);
507
-
508
- // Restore original method
509
- batchScheduler.runJob = originalRunJob;
510
-
511
- batchScheduler.stop();
512
- });
513
- });
514
-
515
- describe('시스템 한계 및 스트레스 테스트', () => {
516
- it('should handle maximum memory limit', async () => {
517
- // Test with maximum possible memory count
518
- const maxMemories = 10000;
519
-
520
- for (let i = 0; i < maxMemories; i++) {
521
- db.prepare(`
522
- INSERT INTO memory_item (id, type, content, importance, created_at)
523
- VALUES (?, ?, ?, ?, ?)
524
- `).run(`stress_${i}`, 'episodic', `Stress test memory ${i}`, 0.5, new Date().toISOString());
525
- }
526
-
527
- const result = await hybridSearchEngine.search(db, {
528
- query: 'stress test',
529
- limit: 100
530
- });
531
-
532
- expect(result).toBeDefined();
533
- expect(result.items).toBeDefined();
534
- });
535
-
536
- it('should handle extremely long content', async () => {
537
- const longContent = 'a'.repeat(100000); // 100KB content
538
-
539
- db.prepare(`
540
- INSERT INTO memory_item (id, type, content, importance, created_at)
541
- VALUES (?, ?, ?, ?, ?)
542
- `).run('long_content', 'episodic', longContent, 0.5, new Date().toISOString());
543
-
544
- const result = await hybridSearchEngine.search(db, {
545
- query: 'long content',
546
- limit: 5
547
- });
548
-
549
- expect(result).toBeDefined();
550
- expect(result.items).toBeDefined();
551
- });
552
-
553
- it('should handle rapid successive operations', async () => {
554
- const operations = [];
555
-
556
- // Rapid successive operations
557
- for (let i = 0; i < 100; i++) {
558
- operations.push(
559
- hybridSearchEngine.search(db, {
560
- query: `rapid test ${i}`,
561
- limit: 1
562
- })
563
- );
564
- }
565
-
566
- const results = await Promise.all(operations);
567
-
568
- expect(results.length).toBe(100);
569
- results.forEach(result => {
570
- expect(result).toBeDefined();
571
- expect(result.items).toBeDefined();
572
- });
573
- });
574
- });
575
- });
@@ -1,117 +0,0 @@
1
- /**
2
- * 에러 로깅 시스템 테스트
3
- * 에러 로깅 서비스의 기능을 테스트하고 통계를 확인
4
- */
5
-
6
- import { createMementoClient } from '../client/index.js';
7
- import { ErrorLoggingService, ErrorSeverity, ErrorCategory } from '../services/error-logging-service.js';
8
-
9
- async function testErrorLogging() {
10
- console.log('🔍 에러 로깅 시스템 테스트 시작');
11
-
12
- let client;
13
- try {
14
- // MCP 클라이언트 연결
15
- client = createMementoClient();
16
- await client.connect();
17
- console.log('✅ MCP 클라이언트 연결 완료');
18
-
19
- // 1. 에러 통계 조회 (초기 상태)
20
- console.log('\n📊 초기 에러 통계:');
21
- const initialStats = await client.callTool('error_stats', { hours: 1 });
22
- console.log(JSON.stringify(initialStats, null, 2));
23
-
24
- // 2. 의도적으로 에러 발생시키기 (remember 도구에 잘못된 파라미터)
25
- console.log('\n⚠️ 의도적 에러 발생 테스트:');
26
-
27
- try {
28
- await client.remember({
29
- content: '', // 빈 내용으로 에러 발생
30
- type: 'episodic' as any, // 타입 우회
31
- importance: 1.5 // 범위 초과
32
- });
33
- } catch (error) {
34
- console.log('✅ 예상된 에러 발생:', (error as Error).message);
35
- }
36
-
37
- try {
38
- await client.recall({
39
- query: '', // 빈 쿼리로 에러 발생
40
- limit: -1 // 잘못된 제한값
41
- });
42
- } catch (error) {
43
- console.log('✅ 예상된 에러 발생:', (error as Error).message);
44
- }
45
-
46
- // 3. 에러 통계 재조회
47
- console.log('\n📊 에러 발생 후 통계:');
48
- const afterErrorStats = await client.callTool('error_stats', {
49
- hours: 1,
50
- includeResolved: false,
51
- limit: 10
52
- });
53
- console.log(JSON.stringify(afterErrorStats, null, 2));
54
-
55
- // 4. 특정 심각도별 에러 조회
56
- console.log('\n🔍 HIGH 심각도 에러 조회:');
57
- const highSeverityStats = await client.callTool('error_stats', {
58
- hours: 1,
59
- severity: 'high',
60
- limit: 5
61
- });
62
- console.log(JSON.stringify(highSeverityStats, null, 2));
63
-
64
- // 5. 에러 해결 테스트 (첫 번째 에러 해결)
65
- if (afterErrorStats.stats && afterErrorStats.stats.filteredErrors && afterErrorStats.stats.filteredErrors.length > 0) {
66
- const firstError = afterErrorStats.stats.filteredErrors[0];
67
- console.log(`\n🔧 에러 해결 테스트: ${firstError.id}`);
68
-
69
- const resolveResult = await client.callTool('resolve_error', {
70
- errorId: firstError.id,
71
- resolvedBy: 'test_user',
72
- reason: '테스트용 에러 해결'
73
- });
74
- console.log('해결 결과:', JSON.stringify(resolveResult, null, 2));
75
-
76
- // 6. 해결 후 통계 확인
77
- console.log('\n📊 에러 해결 후 통계:');
78
- const afterResolveStats = await client.callTool('error_stats', {
79
- hours: 1,
80
- includeResolved: true,
81
- limit: 10
82
- });
83
- console.log(JSON.stringify(afterResolveStats, null, 2));
84
- }
85
-
86
- // 7. 활성 알림 확인
87
- console.log('\n🚨 활성 알림 확인:');
88
- const alertStats = await client.callTool('error_stats', { hours: 1 });
89
- if (alertStats.alerts && alertStats.alerts.length > 0) {
90
- console.log('활성 알림:', JSON.stringify(alertStats.alerts, null, 2));
91
- } else {
92
- console.log('활성 알림 없음');
93
- }
94
-
95
- // 8. 성능 통계와 비교
96
- console.log('\n📈 성능 통계와 비교:');
97
- const performanceStats = await client.callTool('performance_stats', {});
98
- console.log('성능 통계:', JSON.stringify(performanceStats, null, 2));
99
-
100
- } catch (error) {
101
- console.error('❌ 테스트 실패:', error);
102
- } finally {
103
- if (client) {
104
- await client.disconnect();
105
- console.log('🔌 MCP 클라이언트 연결 해제');
106
- }
107
- }
108
-
109
- console.log('\n🎉 에러 로깅 시스템 테스트 완료');
110
- }
111
-
112
- // 직접 실행
113
- if (import.meta.url === `file://${process.argv[1]}`) {
114
- testErrorLogging().catch(console.error);
115
- }
116
-
117
- export { testErrorLogging };