memento-mcp-server 1.6.0 → 1.7.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/INSTALL.en.md +303 -303
- package/INSTALL.md +303 -303
- package/README.en.md +331 -330
- package/README.md +432 -432
- package/dist/algorithms/hybrid-search-engine.d.ts +114 -44
- package/dist/algorithms/hybrid-search-engine.d.ts.map +1 -1
- package/dist/algorithms/hybrid-search-engine.js +261 -235
- package/dist/algorithms/hybrid-search-engine.js.map +1 -1
- package/dist/algorithms/search-engine.d.ts +2 -14
- package/dist/algorithms/search-engine.d.ts.map +1 -1
- package/dist/algorithms/search-engine.js +43 -35
- package/dist/algorithms/search-engine.js.map +1 -1
- package/dist/algorithms/vector-search-engine-migration.d.ts +67 -0
- package/dist/algorithms/vector-search-engine-migration.d.ts.map +1 -0
- package/dist/algorithms/vector-search-engine-migration.js +196 -0
- package/dist/algorithms/vector-search-engine-migration.js.map +1 -0
- package/dist/algorithms/vector-search-engine-refactored.d.ts +56 -0
- package/dist/algorithms/vector-search-engine-refactored.d.ts.map +1 -0
- package/dist/algorithms/vector-search-engine-refactored.js +101 -0
- package/dist/algorithms/vector-search-engine-refactored.js.map +1 -0
- package/dist/algorithms/vector-search-engine.d.ts +9 -2
- package/dist/algorithms/vector-search-engine.d.ts.map +1 -1
- package/dist/algorithms/vector-search-engine.js +245 -121
- package/dist/algorithms/vector-search-engine.js.map +1 -1
- package/dist/client/index.d.ts.map +1 -1
- package/dist/client/index.js +34 -11
- package/dist/client/index.js.map +1 -1
- package/dist/config/environment.d.ts +26 -0
- package/dist/config/environment.d.ts.map +1 -0
- package/dist/config/environment.js +103 -0
- package/dist/config/environment.js.map +1 -0
- package/dist/config/index.d.ts.map +1 -1
- package/dist/config/index.js +29 -50
- package/dist/config/index.js.map +1 -1
- package/dist/config/vector-search.config.d.ts +25 -0
- package/dist/config/vector-search.config.d.ts.map +1 -0
- package/dist/config/vector-search.config.js +40 -0
- package/dist/config/vector-search.config.js.map +1 -0
- package/dist/database/init.d.ts.map +1 -1
- package/dist/database/init.js +154 -17
- package/dist/database/init.js.map +1 -1
- package/dist/database/migrate.d.ts +2 -1
- package/dist/database/migrate.d.ts.map +1 -1
- package/dist/database/migrate.js +191 -18
- package/dist/database/migrate.js.map +1 -1
- package/dist/database/schema.sql +234 -159
- package/dist/factories/hybrid-search.factory.d.ts +20 -0
- package/dist/factories/hybrid-search.factory.d.ts.map +1 -0
- package/dist/factories/hybrid-search.factory.js +57 -0
- package/dist/factories/hybrid-search.factory.js.map +1 -0
- package/dist/factories/spaced-repetition.factory.d.ts +48 -0
- package/dist/factories/spaced-repetition.factory.d.ts.map +1 -0
- package/dist/factories/spaced-repetition.factory.js +187 -0
- package/dist/factories/spaced-repetition.factory.js.map +1 -0
- package/dist/factories/vector-search.factory.d.ts +25 -0
- package/dist/factories/vector-search.factory.d.ts.map +1 -0
- package/dist/factories/vector-search.factory.js +47 -0
- package/dist/factories/vector-search.factory.js.map +1 -0
- package/dist/interfaces/database.interface.d.ts +36 -0
- package/dist/interfaces/database.interface.d.ts.map +1 -0
- package/dist/interfaces/database.interface.js +6 -0
- package/dist/interfaces/database.interface.js.map +1 -0
- package/dist/interfaces/spaced-repetition.interface.d.ts +63 -0
- package/dist/interfaces/spaced-repetition.interface.d.ts.map +1 -0
- package/dist/interfaces/spaced-repetition.interface.js +6 -0
- package/dist/interfaces/spaced-repetition.interface.js.map +1 -0
- package/dist/repositories/vector-performance.repository.d.ts +25 -0
- package/dist/repositories/vector-performance.repository.d.ts.map +1 -0
- package/dist/repositories/vector-performance.repository.js +134 -0
- package/dist/repositories/vector-performance.repository.js.map +1 -0
- package/dist/repositories/vector-search.repository.d.ts +43 -0
- package/dist/repositories/vector-search.repository.d.ts.map +1 -0
- package/dist/repositories/vector-search.repository.js +377 -0
- package/dist/repositories/vector-search.repository.js.map +1 -0
- package/dist/server/http-server.d.ts.map +1 -1
- package/dist/server/http-server.js +25 -24
- package/dist/server/http-server.js.map +1 -1
- package/dist/server/index.d.ts +1 -0
- package/dist/server/index.d.ts.map +1 -1
- package/dist/server/index.js +7 -7
- package/dist/server/index.js.map +1 -1
- package/dist/services/alert-notification-service.d.ts +16 -0
- package/dist/services/alert-notification-service.d.ts.map +1 -0
- package/dist/services/alert-notification-service.js +44 -0
- package/dist/services/alert-notification-service.js.map +1 -0
- package/dist/services/async-optimizer.d.ts +62 -8
- package/dist/services/async-optimizer.d.ts.map +1 -1
- package/dist/services/async-optimizer.js +137 -8
- package/dist/services/async-optimizer.js.map +1 -1
- package/dist/services/batch-scheduler.d.ts +6 -0
- package/dist/services/batch-scheduler.d.ts.map +1 -1
- package/dist/services/batch-scheduler.js +59 -19
- package/dist/services/batch-scheduler.js.map +1 -1
- package/dist/services/cache-service.d.ts +32 -0
- package/dist/services/cache-service.d.ts.map +1 -1
- package/dist/services/cache-service.js +81 -6
- package/dist/services/cache-service.js.map +1 -1
- package/dist/services/database-optimizer.js +63 -63
- package/dist/services/database-optimizer.js.map +1 -1
- package/dist/services/embedding-migration-service.d.ts +24 -0
- package/dist/services/embedding-migration-service.d.ts.map +1 -0
- package/dist/services/embedding-migration-service.js +360 -0
- package/dist/services/embedding-migration-service.js.map +1 -0
- package/dist/services/embedding-provider-factory.d.ts +12 -5
- package/dist/services/embedding-provider-factory.d.ts.map +1 -1
- package/dist/services/embedding-provider-factory.js +107 -26
- package/dist/services/embedding-provider-factory.js.map +1 -1
- package/dist/services/forgetting-policy-service.js +17 -17
- package/dist/services/gemini-embedding-service.d.ts +1 -1
- package/dist/services/gemini-embedding-service.d.ts.map +1 -1
- package/dist/services/gemini-embedding-service.js +25 -18
- package/dist/services/gemini-embedding-service.js.map +1 -1
- package/dist/services/memory-embedding-service.d.ts +8 -0
- package/dist/services/memory-embedding-service.d.ts.map +1 -1
- package/dist/services/memory-embedding-service.js +180 -71
- package/dist/services/memory-embedding-service.js.map +1 -1
- package/dist/services/migration-history-service.d.ts +14 -0
- package/dist/services/migration-history-service.d.ts.map +1 -0
- package/dist/services/migration-history-service.js +270 -0
- package/dist/services/migration-history-service.js.map +1 -0
- package/dist/services/migration-monitor-service.d.ts +24 -0
- package/dist/services/migration-monitor-service.d.ts.map +1 -0
- package/dist/services/migration-monitor-service.js +93 -0
- package/dist/services/migration-monitor-service.js.map +1 -0
- package/dist/services/model-availability-service.d.ts +22 -0
- package/dist/services/model-availability-service.d.ts.map +1 -0
- package/dist/services/model-availability-service.js +140 -0
- package/dist/services/model-availability-service.js.map +1 -0
- package/dist/services/openai-embedding-service.d.ts +36 -0
- package/dist/services/openai-embedding-service.d.ts.map +1 -0
- package/dist/services/openai-embedding-service.js +192 -0
- package/dist/services/openai-embedding-service.js.map +1 -0
- package/dist/services/performance-monitor.d.ts +154 -10
- package/dist/services/performance-monitor.d.ts.map +1 -1
- package/dist/services/performance-monitor.js +446 -60
- package/dist/services/performance-monitor.js.map +1 -1
- package/dist/services/spaced-repetition/interval-calculation.service.d.ts +38 -0
- package/dist/services/spaced-repetition/interval-calculation.service.d.ts.map +1 -0
- package/dist/services/spaced-repetition/interval-calculation.service.js +105 -0
- package/dist/services/spaced-repetition/interval-calculation.service.js.map +1 -0
- package/dist/services/spaced-repetition/optimal-interval.service.d.ts +56 -0
- package/dist/services/spaced-repetition/optimal-interval.service.d.ts.map +1 -0
- package/dist/services/spaced-repetition/optimal-interval.service.js +163 -0
- package/dist/services/spaced-repetition/optimal-interval.service.js.map +1 -0
- package/dist/services/spaced-repetition/performance-analysis.service.d.ts +48 -0
- package/dist/services/spaced-repetition/performance-analysis.service.d.ts.map +1 -0
- package/dist/services/spaced-repetition/performance-analysis.service.js +174 -0
- package/dist/services/spaced-repetition/performance-analysis.service.js.map +1 -0
- package/dist/services/spaced-repetition/priority-calculation.service.d.ts +53 -0
- package/dist/services/spaced-repetition/priority-calculation.service.d.ts.map +1 -0
- package/dist/services/spaced-repetition/priority-calculation.service.js +161 -0
- package/dist/services/spaced-repetition/priority-calculation.service.js.map +1 -0
- package/dist/services/spaced-repetition/recall-probability.service.d.ts +36 -0
- package/dist/services/spaced-repetition/recall-probability.service.d.ts.map +1 -0
- package/dist/services/spaced-repetition/recall-probability.service.js +88 -0
- package/dist/services/spaced-repetition/recall-probability.service.js.map +1 -0
- package/dist/services/spaced-repetition/review-scheduling.service.d.ts +43 -0
- package/dist/services/spaced-repetition/review-scheduling.service.d.ts.map +1 -0
- package/dist/services/spaced-repetition/review-scheduling.service.js +130 -0
- package/dist/services/spaced-repetition/review-scheduling.service.js.map +1 -0
- package/dist/services/spaced-repetition/spaced-repetition-container.d.ts +69 -0
- package/dist/services/spaced-repetition/spaced-repetition-container.d.ts.map +1 -0
- package/dist/services/spaced-repetition/spaced-repetition-container.js +136 -0
- package/dist/services/spaced-repetition/spaced-repetition-container.js.map +1 -0
- package/dist/services/unified-embedding-service.d.ts +3 -0
- package/dist/services/unified-embedding-service.d.ts.map +1 -1
- package/dist/services/unified-embedding-service.js +58 -62
- package/dist/services/unified-embedding-service.js.map +1 -1
- package/dist/services/vector-compatibility-service.d.ts +68 -0
- package/dist/services/vector-compatibility-service.d.ts.map +1 -0
- package/dist/services/vector-compatibility-service.js +373 -0
- package/dist/services/vector-compatibility-service.js.map +1 -0
- package/dist/services/vector-search/vector-index-manager.d.ts +27 -0
- package/dist/services/vector-search/vector-index-manager.d.ts.map +1 -0
- package/dist/services/vector-search/vector-index-manager.js +66 -0
- package/dist/services/vector-search/vector-index-manager.js.map +1 -0
- package/dist/services/vector-search/vector-performance-tester.d.ts +30 -0
- package/dist/services/vector-search/vector-performance-tester.d.ts.map +1 -0
- package/dist/services/vector-search/vector-performance-tester.js +87 -0
- package/dist/services/vector-search/vector-performance-tester.js.map +1 -0
- package/dist/services/vector-search/vector-search-container.d.ts +41 -0
- package/dist/services/vector-search/vector-search-container.d.ts.map +1 -0
- package/dist/services/vector-search/vector-search-container.js +74 -0
- package/dist/services/vector-search/vector-search-container.js.map +1 -0
- package/dist/services/vector-search/vector-search-facade.d.ts +63 -0
- package/dist/services/vector-search/vector-search-facade.d.ts.map +1 -0
- package/dist/services/vector-search/vector-search-facade.js +91 -0
- package/dist/services/vector-search/vector-search-facade.js.map +1 -0
- package/dist/services/vector-search/vector-search-result-normalizer.d.ts +6 -0
- package/dist/services/vector-search/vector-search-result-normalizer.d.ts.map +1 -0
- package/dist/services/vector-search/vector-search-result-normalizer.js +65 -0
- package/dist/services/vector-search/vector-search-result-normalizer.js.map +1 -0
- package/dist/services/vector-search/vector-search.service.d.ts +33 -0
- package/dist/services/vector-search/vector-search.service.d.ts.map +1 -0
- package/dist/services/vector-search/vector-search.service.js +149 -0
- package/dist/services/vector-search/vector-search.service.js.map +1 -0
- package/dist/tools/forget-tool.js +14 -14
- package/dist/tools/pin-tool.js +14 -14
- package/dist/tools/unpin-tool.js +21 -21
- package/dist/types/alerts.types.d.ts +26 -0
- package/dist/types/alerts.types.d.ts.map +1 -0
- package/dist/types/alerts.types.js +2 -0
- package/dist/types/alerts.types.js.map +1 -0
- package/dist/types/embedding-provider-monitoring.types.d.ts +24 -0
- package/dist/types/embedding-provider-monitoring.types.d.ts.map +1 -0
- package/dist/types/embedding-provider-monitoring.types.js +2 -0
- package/dist/types/embedding-provider-monitoring.types.js.map +1 -0
- package/dist/types/embedding.types.d.ts +36 -1
- package/dist/types/embedding.types.d.ts.map +1 -1
- package/dist/types/migration.types.d.ts +131 -0
- package/dist/types/migration.types.d.ts.map +1 -0
- package/dist/types/migration.types.js +6 -0
- package/dist/types/migration.types.js.map +1 -0
- package/dist/types/spaced-repetition.types.d.ts +61 -0
- package/dist/types/spaced-repetition.types.d.ts.map +1 -0
- package/dist/types/spaced-repetition.types.js +6 -0
- package/dist/types/spaced-repetition.types.js.map +1 -0
- package/dist/types/vector-search.types.d.ts +96 -0
- package/dist/types/vector-search.types.d.ts.map +1 -0
- package/dist/types/vector-search.types.js +2 -0
- package/dist/types/vector-search.types.js.map +1 -0
- package/dist/utils/configuration-validator.d.ts +23 -0
- package/dist/utils/configuration-validator.d.ts.map +1 -0
- package/dist/utils/configuration-validator.js +102 -0
- package/dist/utils/configuration-validator.js.map +1 -0
- package/dist/utils/database.d.ts.map +1 -1
- package/dist/utils/database.js +101 -95
- package/dist/utils/database.js.map +1 -1
- package/dist/utils/environment-check.d.ts +8 -0
- package/dist/utils/environment-check.d.ts.map +1 -0
- package/dist/utils/environment-check.js +25 -0
- package/dist/utils/environment-check.js.map +1 -0
- package/dist/utils/logger.d.ts +8 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +33 -0
- package/dist/utils/logger.js.map +1 -0
- package/package.json +139 -125
- package/scripts/auto-setup.js +233 -233
- package/scripts/backup-daily.bat +28 -28
- package/scripts/backup-embeddings.js +108 -108
- package/scripts/check-db-integrity.js +93 -93
- package/scripts/debug-embeddings.js +184 -184
- package/scripts/direct-sql-migration.sql +36 -36
- package/scripts/docker-migration.sh +105 -105
- package/scripts/fix-migration.js +93 -93
- package/scripts/fix-vector-dimensions.js +206 -206
- package/scripts/migrate-embedding-data.js +307 -307
- package/scripts/regenerate-embeddings.js +144 -144
- package/scripts/restore-legacy.ps1 +60 -60
- package/scripts/run-migration.js +122 -122
- package/scripts/safe-migration.js +150 -150
- package/scripts/simple-migrate.js +41 -41
- package/scripts/simple-update.js +123 -123
- package/src/database/schema.sql +234 -159
- package/.cursor/rules/cache-management.mdc +0 -171
- package/.cursor/rules/database-schema.mdc +0 -344
- package/.cursor/rules/deployment.mdc +0 -596
- package/.cursor/rules/error-logging.mdc +0 -298
- package/.cursor/rules/forgetting-algorithms.mdc +0 -426
- package/.cursor/rules/http-server.mdc +0 -432
- package/.cursor/rules/hybrid-search.mdc +0 -424
- package/.cursor/rules/implementation.mdc +0 -369
- package/.cursor/rules/lightweight-embedding.mdc +0 -178
- package/.cursor/rules/mcp-client-development.mdc +0 -0
- package/.cursor/rules/mcp-server-development.mdc +0 -0
- package/.cursor/rules/mcp-tools-architecture.mdc +0 -205
- package/.cursor/rules/memento-memory-rule.mdc +0 -8
- package/.cursor/rules/memento-project-overview.mdc +0 -0
- package/.cursor/rules/memory-algorithms.mdc +0 -502
- package/.cursor/rules/monitoring.mdc +0 -622
- package/.cursor/rules/performance-alerts.mdc +0 -537
- package/.cursor/rules/performance-monitoring.mdc +0 -345
- package/.cursor/rules/performance-optimization.mdc +0 -563
- package/.cursor/rules/project-structure.mdc +0 -310
- package/.cursor/rules/testing.mdc +0 -473
- package/.dockerignore +0 -15
- package/.eslintrc.json +0 -34
- package/.github/ISSUE_TEMPLATE/bug_report.md +0 -51
- package/.github/ISSUE_TEMPLATE/feature_request.md +0 -45
- package/.github/ISSUE_TEMPLATE/question.md +0 -31
- package/.github/PULL_REQUEST_TEMPLATE.md +0 -97
- package/AGENTS.md +0 -28
- package/CHANGELOG.md +0 -416
- package/CODE_OF_CONDUCT.md +0 -62
- package/CONTRIBUTING.md +0 -165
- package/DOCKER_SETUP_GUIDE.md +0 -84
- package/Dockerfile +0 -90
- package/backup/legacy-removal-20250930-201816/http-server-legacy.ts +0 -1068
- package/backup/legacy-removal-20250930-201816/rollback-to-legacy.ps1 +0 -46
- package/backup/legacy-removal-20250930-201816/rollback-to-legacy.sh +0 -48
- package/dist/server/index-backup.d.ts +0 -5
- package/dist/server/index-backup.d.ts.map +0 -1
- package/dist/server/index-backup.js +0 -793
- package/dist/server/index-backup.js.map +0 -1
- package/dist/server/index-refactored.d.ts +0 -6
- package/dist/server/index-refactored.d.ts.map +0 -1
- package/dist/server/index-refactored.js +0 -206
- package/dist/server/index-refactored.js.map +0 -1
- package/dist/services/performance-monitoring-integration.d.ts +0 -77
- package/dist/services/performance-monitoring-integration.d.ts.map +0 -1
- package/dist/services/performance-monitoring-integration.js +0 -177
- package/dist/services/performance-monitoring-integration.js.map +0 -1
- package/dist/test/debug-http-v2.d.ts +0 -5
- package/dist/test/debug-http-v2.d.ts.map +0 -1
- package/dist/test/debug-http-v2.js +0 -28
- package/dist/test/debug-http-v2.js.map +0 -1
- package/dist/test/performance-benchmark.d.ts +0 -57
- package/dist/test/performance-benchmark.d.ts.map +0 -1
- package/dist/test/performance-benchmark.js +0 -427
- package/dist/test/performance-benchmark.js.map +0 -1
- package/dist/test/test-alerts-direct.d.ts +0 -7
- package/dist/test/test-alerts-direct.d.ts.map +0 -1
- package/dist/test/test-alerts-direct.js +0 -101
- package/dist/test/test-alerts-direct.js.map +0 -1
- package/dist/test/test-batch-scheduler.d.ts +0 -2
- package/dist/test/test-batch-scheduler.d.ts.map +0 -1
- package/dist/test/test-batch-scheduler.js +0 -156
- package/dist/test/test-batch-scheduler.js.map +0 -1
- package/dist/test/test-client.d.ts +0 -5
- package/dist/test/test-client.d.ts.map +0 -1
- package/dist/test/test-client.js +0 -86
- package/dist/test/test-client.js.map +0 -1
- package/dist/test/test-embedding.d.ts +0 -6
- package/dist/test/test-embedding.d.ts.map +0 -1
- package/dist/test/test-embedding.js +0 -142
- package/dist/test/test-embedding.js.map +0 -1
- package/dist/test/test-error-logging.d.ts +0 -7
- package/dist/test/test-error-logging.d.ts.map +0 -1
- package/dist/test/test-error-logging.js +0 -105
- package/dist/test/test-error-logging.js.map +0 -1
- package/dist/test/test-forgetting.d.ts +0 -6
- package/dist/test/test-forgetting.d.ts.map +0 -1
- package/dist/test/test-forgetting.js +0 -154
- package/dist/test/test-forgetting.js.map +0 -1
- package/dist/test/test-gemini-embedding.d.ts +0 -7
- package/dist/test/test-gemini-embedding.d.ts.map +0 -1
- package/dist/test/test-gemini-embedding.js +0 -134
- package/dist/test/test-gemini-embedding.js.map +0 -1
- package/dist/test/test-http-server-v2-simple.d.ts +0 -6
- package/dist/test/test-http-server-v2-simple.d.ts.map +0 -1
- package/dist/test/test-http-server-v2-simple.js +0 -131
- package/dist/test/test-http-server-v2-simple.js.map +0 -1
- package/dist/test/test-http-server-v2.d.ts +0 -7
- package/dist/test/test-http-server-v2.d.ts.map +0 -1
- package/dist/test/test-http-server-v2.js +0 -529
- package/dist/test/test-http-server-v2.js.map +0 -1
- package/dist/test/test-lightweight-embedding.d.ts +0 -6
- package/dist/test/test-lightweight-embedding.d.ts.map +0 -1
- package/dist/test/test-lightweight-embedding.js +0 -189
- package/dist/test/test-lightweight-embedding.js.map +0 -1
- package/dist/test/test-m1-completion.d.ts +0 -7
- package/dist/test/test-m1-completion.d.ts.map +0 -1
- package/dist/test/test-m1-completion.js +0 -124
- package/dist/test/test-m1-completion.js.map +0 -1
- package/dist/test/test-memory-injection-prompt.d.ts +0 -2
- package/dist/test/test-memory-injection-prompt.d.ts.map +0 -1
- package/dist/test/test-memory-injection-prompt.js +0 -299
- package/dist/test/test-memory-injection-prompt.js.map +0 -1
- package/dist/test/test-performance-alerts.d.ts +0 -7
- package/dist/test/test-performance-alerts.d.ts.map +0 -1
- package/dist/test/test-performance-alerts.js +0 -109
- package/dist/test/test-performance-alerts.js.map +0 -1
- package/dist/test/test-performance-monitor.d.ts +0 -2
- package/dist/test/test-performance-monitor.d.ts.map +0 -1
- package/dist/test/test-performance-monitor.js +0 -182
- package/dist/test/test-performance-monitor.js.map +0 -1
- package/dist/test/test-performance-monitoring.d.ts +0 -6
- package/dist/test/test-performance-monitoring.d.ts.map +0 -1
- package/dist/test/test-performance-monitoring.js +0 -156
- package/dist/test/test-performance-monitoring.js.map +0 -1
- package/dist/test/test-search.d.ts +0 -5
- package/dist/test/test-search.d.ts.map +0 -1
- package/dist/test/test-search.js +0 -141
- package/dist/test/test-search.js.map +0 -1
- package/dist/test/test-simple-alerts.d.ts +0 -6
- package/dist/test/test-simple-alerts.d.ts.map +0 -1
- package/dist/test/test-simple-alerts.js +0 -106
- package/dist/test/test-simple-alerts.js.map +0 -1
- package/dist/test/test-vector-search-engine.d.ts +0 -2
- package/dist/test/test-vector-search-engine.d.ts.map +0 -1
- package/dist/test/test-vector-search-engine.js +0 -225
- package/dist/test/test-vector-search-engine.js.map +0 -1
- package/docker-compose.dev.yml +0 -50
- package/docker-compose.prod.yml +0 -77
- package/docker-compose.yml +0 -43
- package/docs/en/Memento-Goals.md +0 -217
- package/docs/en/Memento-M1-DetailSpecs.md +0 -130
- package/docs/en/Memento-Milestones.md +0 -135
- package/docs/en/Search-Ranking-Memory-Decay-Formulas.md +0 -177
- package/docs/en/api-reference.md +0 -658
- package/docs/en/architecture.md +0 -1302
- package/docs/en/developer-guide.md +0 -1005
- package/docs/en/user-manual.md +0 -595
- package/docs/ko/Memento-Goals.md +0 -217
- package/docs/ko/Memento-M1-DetailSpecs.md +0 -130
- package/docs/ko/Memento-Milestones.md +0 -134
- package/docs/ko/Search-Ranking-Memory-Decay-Formulas.md +0 -177
- package/docs/ko/api-reference.md +0 -658
- package/docs/ko/architecture.md +0 -1302
- package/docs/ko/developer-guide.md +0 -1006
- package/docs/ko/embedding-api-reference.md +0 -122
- package/docs/ko/embedding-configuration.md +0 -62
- package/docs/ko/embedding-performance-benchmark.md +0 -62
- package/docs/ko/embedding-service-guide.md +0 -314
- package/docs/ko/user-manual.md +0 -595
- package/env.example +0 -49
- package/install.sh +0 -191
- package/mcp-http-client.js +0 -218
- package/mcp.json +0 -0
- package/packages/mcp-client/docs/API-REFERENCE.md +0 -560
- package/packages/mcp-client/docs/BEST-PRACTICES.md +0 -564
- package/packages/mcp-client/docs/MIGRATION-GUIDE.md +0 -344
- package/packages/mcp-client/docs/PERFORMANCE-GUIDE.md +0 -476
- package/packages/mcp-client/docs/TROUBLESHOOTING.md +0 -564
- package/packages/mcp-client/package-lock.json +0 -907
- package/packages/mcp-client/package.json +0 -58
- package/packages/mcp-client/performance-optimizer.js +0 -428
- package/packages/mcp-client/test-basic.js +0 -65
- package/packages/mcp-client/test-integration.js +0 -366
- package/src/algorithms/forgetting-algorithm.spec.ts +0 -538
- package/src/algorithms/forgetting-algorithm.ts +0 -243
- package/src/algorithms/hybrid-search-engine.spec.ts +0 -484
- package/src/algorithms/hybrid-search-engine.ts +0 -489
- package/src/algorithms/search-engine.spec.ts +0 -429
- package/src/algorithms/search-engine.ts +0 -392
- package/src/algorithms/search-ranking.spec.ts +0 -293
- package/src/algorithms/search-ranking.ts +0 -407
- package/src/algorithms/spaced-repetition.spec.ts +0 -510
- package/src/algorithms/spaced-repetition.ts +0 -238
- package/src/algorithms/vector-search-engine.ts +0 -505
- package/src/client/index.spec.ts +0 -427
- package/src/client/index.ts +0 -222
- package/src/config/index.spec.ts +0 -339
- package/src/config/index.ts +0 -106
- package/src/database/init.spec.ts +0 -239
- package/src/database/init.ts +0 -130
- package/src/database/migrate.spec.ts +0 -293
- package/src/database/migrate.ts +0 -94
- package/src/database/migrations/001_add_embedding_metadata.sql +0 -29
- package/src/npm-client/context-injector.spec.ts +0 -335
- package/src/npm-client/context-injector.ts +0 -412
- package/src/npm-client/index.spec.ts +0 -108
- package/src/npm-client/index.ts +0 -96
- package/src/npm-client/memento-client.spec.ts +0 -549
- package/src/npm-client/memento-client.ts +0 -501
- package/src/npm-client/memory-manager.spec.ts +0 -374
- package/src/npm-client/memory-manager.ts +0 -414
- package/src/npm-client/types.spec.ts +0 -427
- package/src/npm-client/types.ts +0 -296
- package/src/npm-client/utils.spec.ts +0 -355
- package/src/npm-client/utils.ts +0 -423
- package/src/scripts/copy-assets.js +0 -37
- package/src/server/http-server.spec.ts +0 -648
- package/src/server/http-server.ts +0 -1030
- package/src/server/index-backup.ts +0 -875
- package/src/server/index-refactored.ts +0 -237
- package/src/server/index.spec.ts +0 -281
- package/src/server/index.ts +0 -347
- package/src/server/simple-mcp-server.spec.ts +0 -207
- package/src/server/simple-mcp-server.ts +0 -173
- package/src/services/async-optimizer.spec.ts +0 -569
- package/src/services/async-optimizer.ts +0 -484
- package/src/services/batch-scheduler.ts +0 -759
- package/src/services/cache-service.spec.ts +0 -372
- package/src/services/cache-service.ts +0 -434
- package/src/services/database-optimizer.spec.ts +0 -344
- package/src/services/database-optimizer.ts +0 -450
- package/src/services/embedding-provider-factory.ts +0 -173
- package/src/services/embedding-service.spec.ts +0 -342
- package/src/services/embedding-service.ts +0 -333
- package/src/services/error-logging-service.spec.ts +0 -416
- package/src/services/error-logging-service.ts +0 -383
- package/src/services/forgetting-policy-service.spec.ts +0 -140
- package/src/services/forgetting-policy-service.ts +0 -334
- package/src/services/gemini-embedding-service.spec.ts +0 -463
- package/src/services/gemini-embedding-service.ts +0 -283
- package/src/services/lightweight-embedding-service.spec.ts +0 -458
- package/src/services/lightweight-embedding-service.ts +0 -324
- package/src/services/memory-embedding-service.spec.ts +0 -417
- package/src/services/memory-embedding-service.ts +0 -289
- package/src/services/minilm-embedding-service.spec.ts +0 -104
- package/src/services/minilm-embedding-service.ts +0 -262
- package/src/services/performance-alert-service.spec.ts +0 -517
- package/src/services/performance-alert-service.ts +0 -477
- package/src/services/performance-monitor.spec.ts +0 -401
- package/src/services/performance-monitor.ts +0 -532
- package/src/services/performance-monitoring-integration.spec.ts +0 -478
- package/src/services/performance-monitoring-integration.ts.bak +0 -276
- package/src/services/unified-embedding-service.spec.ts +0 -224
- package/src/services/unified-embedding-service.ts +0 -255
- package/src/test/debug-http-v2.ts +0 -30
- package/src/test/embedding-integration-test.spec.ts +0 -295
- package/src/test/embedding-integration-test.ts +0 -295
- package/src/test/embedding-performance-benchmark.spec.ts +0 -354
- package/src/test/embedding-performance-benchmark.ts +0 -312
- package/src/test/performance-benchmark.ts +0 -565
- package/src/test/test-alerts-direct.ts +0 -136
- package/src/test/test-batch-scheduler-simple.spec.ts +0 -122
- package/src/test/test-batch-scheduler.spec.ts +0 -453
- package/src/test/test-batch-scheduler.ts +0 -182
- package/src/test/test-client.ts +0 -97
- package/src/test/test-embedding.ts +0 -153
- package/src/test/test-error-handling.spec.ts +0 -575
- package/src/test/test-error-logging.ts +0 -117
- package/src/test/test-forgetting.ts +0 -162
- package/src/test/test-gemini-embedding.ts +0 -159
- package/src/test/test-http-server-v2-simple.ts +0 -147
- package/src/test/test-http-server-v2.ts +0 -586
- package/src/test/test-hybrid-search-engine.spec.ts +0 -521
- package/src/test/test-integration-fixed.spec.ts +0 -612
- package/src/test/test-integration.spec.ts +0 -463
- package/src/test/test-lightweight-embedding.ts +0 -208
- package/src/test/test-m1-completion.spec.ts +0 -614
- package/src/test/test-m1-completion.ts +0 -141
- package/src/test/test-m1-integration.spec.ts +0 -514
- package/src/test/test-memory-injection-prompt.spec.ts +0 -650
- package/src/test/test-memory-injection-prompt.ts +0 -391
- package/src/test/test-performance-alerts.ts +0 -125
- package/src/test/test-performance-monitor-updates.spec.ts +0 -490
- package/src/test/test-performance-monitor.spec.ts +0 -284
- package/src/test/test-performance-monitor.ts +0 -228
- package/src/test/test-performance-monitoring.ts +0 -171
- package/src/test/test-search.ts +0 -151
- package/src/test/test-simple-alerts.ts +0 -136
- package/src/test/test-vector-search-engine.spec.ts +0 -408
- package/src/test/test-vector-search-engine.ts +0 -303
- package/src/tools/base-tool.ts +0 -189
- package/src/tools/cleanup-memory-tool.ts +0 -77
- package/src/tools/database-optimize-tool.ts +0 -79
- package/src/tools/error-stats.ts +0 -119
- package/src/tools/forget-tool.spec.ts +0 -613
- package/src/tools/forget-tool.ts +0 -454
- package/src/tools/forgetting-stats-tool.ts +0 -47
- package/src/tools/index.ts +0 -71
- package/src/tools/memory-injection-prompt.ts +0 -257
- package/src/tools/performance-alerts.ts +0 -226
- package/src/tools/performance-stats-tool.ts +0 -48
- package/src/tools/pin-tool.spec.ts +0 -497
- package/src/tools/pin-tool.ts +0 -277
- package/src/tools/recall-tool.spec.ts +0 -475
- package/src/tools/recall-tool.ts +0 -389
- package/src/tools/remember-tool.spec.ts +0 -469
- package/src/tools/remember-tool.ts +0 -112
- package/src/tools/resolve-error.ts +0 -69
- package/src/tools/tool-registry.ts +0 -417
- package/src/tools/types.ts +0 -63
- package/src/tools/unpin-tool.spec.ts +0 -549
- package/src/tools/unpin-tool.ts +0 -306
- package/src/types/embedding.types.ts +0 -78
- package/src/types/index.spec.ts +0 -420
- package/src/types/index.ts +0 -117
- package/src/utils/database.spec.ts +0 -77
- package/src/utils/database.ts +0 -458
- package/src/utils/stopwords.ts +0 -128
- package/start-docker-setup.bat +0 -38
- package/static/logo.png +0 -0
- package/static/memento_logo.svg +0 -2
- package/test-docker.js +0 -103
- package/tsconfig.json +0 -46
- 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 };
|