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,122 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
2
|
-
import { createBatchScheduler, BatchScheduler } from '../services/batch-scheduler.js';
|
|
3
|
-
import Database from 'better-sqlite3';
|
|
4
|
-
|
|
5
|
-
describe('BatchScheduler (Simple)', () => {
|
|
6
|
-
let db: Database.Database;
|
|
7
|
-
let batchScheduler: BatchScheduler;
|
|
8
|
-
|
|
9
|
-
beforeEach(() => {
|
|
10
|
-
// Create in-memory database for testing
|
|
11
|
-
db = new Database(':memory:');
|
|
12
|
-
// Initialize database schema
|
|
13
|
-
db.exec(`
|
|
14
|
-
CREATE TABLE memory_item (
|
|
15
|
-
id TEXT PRIMARY KEY,
|
|
16
|
-
type TEXT CHECK (type IN ('working','episodic','semantic','procedural')),
|
|
17
|
-
content TEXT NOT NULL,
|
|
18
|
-
importance REAL CHECK (importance >= 0 AND importance <= 1) DEFAULT 0.5,
|
|
19
|
-
privacy_scope TEXT CHECK (privacy_scope IN ('private','team','public')) DEFAULT 'private',
|
|
20
|
-
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
21
|
-
last_accessed TIMESTAMP,
|
|
22
|
-
pinned BOOLEAN DEFAULT FALSE,
|
|
23
|
-
source TEXT,
|
|
24
|
-
agent_id TEXT,
|
|
25
|
-
user_id TEXT,
|
|
26
|
-
project_id TEXT,
|
|
27
|
-
origin_trace TEXT
|
|
28
|
-
);
|
|
29
|
-
`);
|
|
30
|
-
|
|
31
|
-
batchScheduler = createBatchScheduler({
|
|
32
|
-
cleanupInterval: 1000, // 1초 for testing
|
|
33
|
-
monitoringInterval: 500, // 0.5초 for testing
|
|
34
|
-
enableLogging: false
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
afterEach(() => {
|
|
39
|
-
if (db) {
|
|
40
|
-
db.close();
|
|
41
|
-
}
|
|
42
|
-
batchScheduler.stop();
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
describe('초기화', () => {
|
|
46
|
-
it('should initialize successfully', async () => {
|
|
47
|
-
await expect(batchScheduler.start(db)).resolves.not.toThrow();
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
it('should not start if already running', async () => {
|
|
51
|
-
await batchScheduler.start(db);
|
|
52
|
-
await expect(batchScheduler.start(db)).rejects.toThrow('BatchScheduler is already running');
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
describe('상태 관리', () => {
|
|
57
|
-
it('should return correct status when not running', () => {
|
|
58
|
-
const status = batchScheduler.getStatus();
|
|
59
|
-
expect(status.isRunning).toBe(false);
|
|
60
|
-
expect(status.activeJobs).toEqual([]);
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
it('should return correct status when running', async () => {
|
|
64
|
-
await batchScheduler.start(db);
|
|
65
|
-
const status = batchScheduler.getStatus();
|
|
66
|
-
expect(status.isRunning).toBe(true);
|
|
67
|
-
expect(status.activeJobs).toContain('cleanup');
|
|
68
|
-
expect(status.activeJobs).toContain('monitoring');
|
|
69
|
-
});
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
describe('작업 실행', () => {
|
|
73
|
-
beforeEach(async () => {
|
|
74
|
-
await batchScheduler.start(db);
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
it('should run cleanup job successfully', async () => {
|
|
78
|
-
const result = await batchScheduler.runJob('cleanup');
|
|
79
|
-
expect(result.jobType).toBe('memory_cleanup');
|
|
80
|
-
expect(result.success).toBe(true);
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
it('should run monitoring job successfully', async () => {
|
|
84
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
85
|
-
expect(result.jobType).toBe('monitoring');
|
|
86
|
-
expect(result.success).toBe(true);
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
it('should handle unknown job type', async () => {
|
|
90
|
-
await expect(batchScheduler.runJob('unknown' as any)).rejects.toThrow('Unknown job type: unknown');
|
|
91
|
-
});
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
describe('중지', () => {
|
|
95
|
-
it('should stop all jobs', async () => {
|
|
96
|
-
await batchScheduler.start(db);
|
|
97
|
-
batchScheduler.stop();
|
|
98
|
-
|
|
99
|
-
const status = batchScheduler.getStatus();
|
|
100
|
-
expect(status.isRunning).toBe(false);
|
|
101
|
-
expect(status.activeJobs).toEqual([]);
|
|
102
|
-
});
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
describe('데이터베이스 통계', () => {
|
|
106
|
-
beforeEach(async () => {
|
|
107
|
-
await batchScheduler.start(db);
|
|
108
|
-
|
|
109
|
-
// Add some test data
|
|
110
|
-
db.prepare(`
|
|
111
|
-
INSERT INTO memory_item (id, type, content, importance, created_at)
|
|
112
|
-
VALUES ('test1', 'episodic', 'Test memory 1', 0.5, datetime('now'))
|
|
113
|
-
`).run();
|
|
114
|
-
});
|
|
115
|
-
|
|
116
|
-
it('should collect database statistics', async () => {
|
|
117
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
118
|
-
expect(result.success).toBe(true);
|
|
119
|
-
expect(result.details?.stats).toBeDefined();
|
|
120
|
-
});
|
|
121
|
-
});
|
|
122
|
-
});
|
|
@@ -1,453 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
2
|
-
import { getBatchScheduler, BatchScheduler } from '../services/batch-scheduler.js';
|
|
3
|
-
import { getPerformanceMonitor } from '../services/performance-monitor.js';
|
|
4
|
-
import { ForgettingPolicyService } from '../services/forgetting-policy-service.js';
|
|
5
|
-
import Database from 'better-sqlite3';
|
|
6
|
-
import { DatabaseUtils } from '../utils/database.js';
|
|
7
|
-
|
|
8
|
-
// Mock dependencies
|
|
9
|
-
import { vi } from 'vitest';
|
|
10
|
-
vi.mock('../services/performance-monitor.js');
|
|
11
|
-
vi.mock('../services/forgetting-policy-service.js');
|
|
12
|
-
|
|
13
|
-
describe('BatchScheduler', () => {
|
|
14
|
-
let db: Database.Database;
|
|
15
|
-
let batchScheduler: BatchScheduler;
|
|
16
|
-
let mockPerformanceMonitor: any;
|
|
17
|
-
let mockForgettingService: any;
|
|
18
|
-
|
|
19
|
-
beforeEach(() => {
|
|
20
|
-
// Create in-memory database for testing
|
|
21
|
-
db = new Database(':memory:');
|
|
22
|
-
// Initialize database schema
|
|
23
|
-
db.exec(`
|
|
24
|
-
CREATE TABLE memory_item (
|
|
25
|
-
id TEXT PRIMARY KEY,
|
|
26
|
-
type TEXT CHECK (type IN ('working','episodic','semantic','procedural')),
|
|
27
|
-
content TEXT NOT NULL,
|
|
28
|
-
importance REAL CHECK (importance >= 0 AND importance <= 1) DEFAULT 0.5,
|
|
29
|
-
privacy_scope TEXT CHECK (privacy_scope IN ('private','team','public')) DEFAULT 'private',
|
|
30
|
-
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
31
|
-
last_accessed TIMESTAMP,
|
|
32
|
-
pinned BOOLEAN DEFAULT FALSE,
|
|
33
|
-
source TEXT,
|
|
34
|
-
agent_id TEXT,
|
|
35
|
-
user_id TEXT,
|
|
36
|
-
project_id TEXT,
|
|
37
|
-
origin_trace TEXT
|
|
38
|
-
);
|
|
39
|
-
`);
|
|
40
|
-
|
|
41
|
-
// Mock performance monitor
|
|
42
|
-
mockPerformanceMonitor = {
|
|
43
|
-
initialize: vi.fn(),
|
|
44
|
-
collectMetrics: vi.fn().mockResolvedValue({
|
|
45
|
-
timestamp: new Date(),
|
|
46
|
-
cpu: { user: 0, system: 0 },
|
|
47
|
-
memory: { rss: 0, heapTotal: 0, heapUsed: 0, external: 0 },
|
|
48
|
-
database: { size: 0, memoryCount: 0, queryTime: 0 },
|
|
49
|
-
uptime: 0
|
|
50
|
-
}),
|
|
51
|
-
getActiveAlerts: vi.fn().mockReturnValue([])
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
// Mock forgetting service
|
|
55
|
-
mockForgettingService = {
|
|
56
|
-
executeMemoryCleanup: vi.fn().mockResolvedValue({
|
|
57
|
-
softDeleted: [],
|
|
58
|
-
hardDeleted: [],
|
|
59
|
-
reviewed: []
|
|
60
|
-
})
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
// Setup mocks
|
|
64
|
-
vi.mocked(getPerformanceMonitor).mockReturnValue(mockPerformanceMonitor);
|
|
65
|
-
vi.mocked(ForgettingPolicyService).mockImplementation(() => mockForgettingService);
|
|
66
|
-
|
|
67
|
-
batchScheduler = getBatchScheduler({
|
|
68
|
-
cleanupInterval: 1000, // 1초 for testing
|
|
69
|
-
monitoringInterval: 500, // 0.5초 for testing
|
|
70
|
-
enableLogging: false
|
|
71
|
-
});
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
afterEach(() => {
|
|
75
|
-
if (db) {
|
|
76
|
-
db.close();
|
|
77
|
-
}
|
|
78
|
-
batchScheduler.stop();
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
describe('초기화', () => {
|
|
82
|
-
it('should initialize successfully', async () => {
|
|
83
|
-
await expect(batchScheduler.start(db)).resolves.not.toThrow();
|
|
84
|
-
expect(mockPerformanceMonitor.initialize).toHaveBeenCalledWith(db);
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
it('should not start if already running', async () => {
|
|
88
|
-
await batchScheduler.start(db);
|
|
89
|
-
await expect(batchScheduler.start(db)).rejects.toThrow('BatchScheduler is already running');
|
|
90
|
-
});
|
|
91
|
-
});
|
|
92
|
-
|
|
93
|
-
describe('상태 관리', () => {
|
|
94
|
-
it('should return correct status when not running', () => {
|
|
95
|
-
const status = batchScheduler.getStatus();
|
|
96
|
-
expect(status.isRunning).toBe(false);
|
|
97
|
-
expect(status.activeJobs).toEqual([]);
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
it('should return correct status when running', async () => {
|
|
101
|
-
await batchScheduler.start(db);
|
|
102
|
-
const status = batchScheduler.getStatus();
|
|
103
|
-
expect(status.isRunning).toBe(true);
|
|
104
|
-
expect(status.activeJobs).toContain('cleanup');
|
|
105
|
-
expect(status.activeJobs).toContain('monitoring');
|
|
106
|
-
});
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
describe('작업 실행', () => {
|
|
110
|
-
beforeEach(async () => {
|
|
111
|
-
await batchScheduler.start(db);
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
it('should run cleanup job successfully', async () => {
|
|
115
|
-
const result = await batchScheduler.runJob('cleanup');
|
|
116
|
-
expect(result.jobType).toBe('memory_cleanup');
|
|
117
|
-
expect(result.success).toBe(true);
|
|
118
|
-
expect(mockForgettingService.executeMemoryCleanup).toHaveBeenCalledWith(db);
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
it('should run monitoring job successfully', async () => {
|
|
122
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
123
|
-
expect(result.jobType).toBe('monitoring');
|
|
124
|
-
expect(result.success).toBe(true);
|
|
125
|
-
expect(mockPerformanceMonitor.collectMetrics).toHaveBeenCalled();
|
|
126
|
-
});
|
|
127
|
-
|
|
128
|
-
it('should handle unknown job type', async () => {
|
|
129
|
-
await expect(batchScheduler.runJob('unknown' as any)).rejects.toThrow('Unknown job type: unknown');
|
|
130
|
-
});
|
|
131
|
-
});
|
|
132
|
-
|
|
133
|
-
describe('메모리 정리', () => {
|
|
134
|
-
beforeEach(async () => {
|
|
135
|
-
await batchScheduler.start(db);
|
|
136
|
-
});
|
|
137
|
-
|
|
138
|
-
it('should execute memory cleanup with correct parameters', async () => {
|
|
139
|
-
const result = await batchScheduler.runJob('cleanup');
|
|
140
|
-
expect(result.success).toBe(true);
|
|
141
|
-
expect(mockForgettingService.executeMemoryCleanup).toHaveBeenCalledWith(db);
|
|
142
|
-
});
|
|
143
|
-
|
|
144
|
-
it('should handle cleanup errors gracefully', async () => {
|
|
145
|
-
mockForgettingService.executeMemoryCleanup.mockRejectedValueOnce(new Error('Cleanup failed'));
|
|
146
|
-
const result = await batchScheduler.runJob('cleanup');
|
|
147
|
-
expect(result.success).toBe(false);
|
|
148
|
-
expect(result.errors).toContain('Cleanup failed');
|
|
149
|
-
});
|
|
150
|
-
});
|
|
151
|
-
|
|
152
|
-
describe('성능 모니터링', () => {
|
|
153
|
-
beforeEach(async () => {
|
|
154
|
-
await batchScheduler.start(db);
|
|
155
|
-
});
|
|
156
|
-
|
|
157
|
-
it('should collect performance metrics', async () => {
|
|
158
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
159
|
-
expect(mockPerformanceMonitor.collectMetrics).toHaveBeenCalled();
|
|
160
|
-
expect(result.success).toBe(true);
|
|
161
|
-
});
|
|
162
|
-
|
|
163
|
-
it('should handle monitoring errors gracefully', async () => {
|
|
164
|
-
mockPerformanceMonitor.collectMetrics.mockRejectedValueOnce(new Error('Monitoring failed'));
|
|
165
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
166
|
-
expect(result.success).toBe(false);
|
|
167
|
-
expect(result.errors).toContain('Monitoring failed');
|
|
168
|
-
});
|
|
169
|
-
});
|
|
170
|
-
|
|
171
|
-
describe('중지', () => {
|
|
172
|
-
it('should stop all jobs', async () => {
|
|
173
|
-
await batchScheduler.start(db);
|
|
174
|
-
batchScheduler.stop();
|
|
175
|
-
|
|
176
|
-
const status = batchScheduler.getStatus();
|
|
177
|
-
expect(status.isRunning).toBe(false);
|
|
178
|
-
expect(status.activeJobs).toEqual([]);
|
|
179
|
-
});
|
|
180
|
-
|
|
181
|
-
it('should handle multiple stop calls gracefully', async () => {
|
|
182
|
-
await batchScheduler.start(db);
|
|
183
|
-
batchScheduler.stop();
|
|
184
|
-
batchScheduler.stop(); // Should not throw
|
|
185
|
-
|
|
186
|
-
const status = batchScheduler.getStatus();
|
|
187
|
-
expect(status.isRunning).toBe(false);
|
|
188
|
-
});
|
|
189
|
-
|
|
190
|
-
it('should stop when not running', () => {
|
|
191
|
-
expect(() => batchScheduler.stop()).not.toThrow();
|
|
192
|
-
});
|
|
193
|
-
});
|
|
194
|
-
|
|
195
|
-
describe('데이터베이스 통계', () => {
|
|
196
|
-
beforeEach(async () => {
|
|
197
|
-
await batchScheduler.start(db);
|
|
198
|
-
|
|
199
|
-
// Add some test data
|
|
200
|
-
db.prepare(`
|
|
201
|
-
INSERT INTO memory_item (id, type, content, importance, created_at, pinned)
|
|
202
|
-
VALUES
|
|
203
|
-
('test1', 'episodic', 'Test memory 1', 0.5, datetime('now'), FALSE),
|
|
204
|
-
('test2', 'semantic', 'Test memory 2', 0.7, datetime('now', '-35 days'), TRUE),
|
|
205
|
-
('test3', 'working', 'Test memory 3', 0.3, datetime('now', '-1 day'), FALSE)
|
|
206
|
-
`).run();
|
|
207
|
-
});
|
|
208
|
-
|
|
209
|
-
it('should collect database statistics', async () => {
|
|
210
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
211
|
-
expect(result.success).toBe(true);
|
|
212
|
-
expect(result.details?.stats).toBeDefined();
|
|
213
|
-
});
|
|
214
|
-
|
|
215
|
-
it('should collect memory statistics by type', async () => {
|
|
216
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
217
|
-
const stats = result.details?.stats;
|
|
218
|
-
|
|
219
|
-
expect(stats.memoryStats).toBeDefined();
|
|
220
|
-
expect(Array.isArray(stats.memoryStats)).toBe(true);
|
|
221
|
-
|
|
222
|
-
const episodicStats = stats.memoryStats.find((s: any) => s.type === 'episodic');
|
|
223
|
-
expect(episodicStats).toBeDefined();
|
|
224
|
-
expect(episodicStats.count).toBe(1);
|
|
225
|
-
expect(episodicStats.pinned_count).toBe(0);
|
|
226
|
-
});
|
|
227
|
-
|
|
228
|
-
it('should calculate total memories count', async () => {
|
|
229
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
230
|
-
const stats = result.details?.stats;
|
|
231
|
-
|
|
232
|
-
expect(stats.totalMemories).toBe(3);
|
|
233
|
-
});
|
|
234
|
-
|
|
235
|
-
it('should estimate database size', async () => {
|
|
236
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
237
|
-
const stats = result.details?.stats;
|
|
238
|
-
|
|
239
|
-
expect(stats.estimatedSize).toBeGreaterThan(0);
|
|
240
|
-
expect(typeof stats.estimatedSize).toBe('number');
|
|
241
|
-
});
|
|
242
|
-
|
|
243
|
-
it('should handle empty database gracefully', async () => {
|
|
244
|
-
// Clear database
|
|
245
|
-
db.prepare('DELETE FROM memory_item').run();
|
|
246
|
-
|
|
247
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
248
|
-
const stats = result.details?.stats;
|
|
249
|
-
|
|
250
|
-
expect(stats.totalMemories).toBe(0);
|
|
251
|
-
expect(stats.memoryStats).toEqual([]);
|
|
252
|
-
});
|
|
253
|
-
});
|
|
254
|
-
|
|
255
|
-
describe('메트릭 수집', () => {
|
|
256
|
-
beforeEach(async () => {
|
|
257
|
-
await batchScheduler.start(db);
|
|
258
|
-
});
|
|
259
|
-
|
|
260
|
-
it('should collect basic metrics', async () => {
|
|
261
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
262
|
-
const metrics = result.details?.metrics;
|
|
263
|
-
|
|
264
|
-
expect(metrics).toBeDefined();
|
|
265
|
-
expect(metrics.memory).toBeDefined();
|
|
266
|
-
expect(metrics.cpu).toBeDefined();
|
|
267
|
-
expect(metrics.uptime).toBeDefined();
|
|
268
|
-
|
|
269
|
-
expect(metrics.memory).toHaveProperty('rss');
|
|
270
|
-
expect(metrics.memory).toHaveProperty('heapTotal');
|
|
271
|
-
expect(metrics.memory).toHaveProperty('heapUsed');
|
|
272
|
-
expect(metrics.memory).toHaveProperty('external');
|
|
273
|
-
|
|
274
|
-
expect(metrics.cpu).toHaveProperty('user');
|
|
275
|
-
expect(metrics.cpu).toHaveProperty('system');
|
|
276
|
-
|
|
277
|
-
expect(typeof metrics.uptime).toBe('number');
|
|
278
|
-
expect(metrics.uptime).toBeGreaterThan(0);
|
|
279
|
-
});
|
|
280
|
-
|
|
281
|
-
it('should collect memory usage metrics', async () => {
|
|
282
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
283
|
-
const metrics = result.details?.metrics;
|
|
284
|
-
|
|
285
|
-
expect(metrics.memory.rss).toBeGreaterThan(0);
|
|
286
|
-
expect(metrics.memory.heapTotal).toBeGreaterThan(0);
|
|
287
|
-
expect(metrics.memory.heapUsed).toBeGreaterThan(0);
|
|
288
|
-
expect(metrics.memory.heapUsed).toBeLessThanOrEqual(metrics.memory.heapTotal);
|
|
289
|
-
});
|
|
290
|
-
|
|
291
|
-
it('should collect CPU usage metrics', async () => {
|
|
292
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
293
|
-
const metrics = result.details?.metrics;
|
|
294
|
-
|
|
295
|
-
expect(typeof metrics.cpu.user).toBe('number');
|
|
296
|
-
expect(typeof metrics.cpu.system).toBe('number');
|
|
297
|
-
expect(metrics.cpu.user).toBeGreaterThanOrEqual(0);
|
|
298
|
-
expect(metrics.cpu.system).toBeGreaterThanOrEqual(0);
|
|
299
|
-
});
|
|
300
|
-
|
|
301
|
-
it('should collect uptime metrics', async () => {
|
|
302
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
303
|
-
const metrics = result.details?.metrics;
|
|
304
|
-
|
|
305
|
-
expect(metrics.uptime).toBeGreaterThan(0);
|
|
306
|
-
expect(typeof metrics.uptime).toBe('number');
|
|
307
|
-
});
|
|
308
|
-
});
|
|
309
|
-
|
|
310
|
-
describe('설정 관리', () => {
|
|
311
|
-
it('should create scheduler with custom config', () => {
|
|
312
|
-
const customConfig = {
|
|
313
|
-
cleanupInterval: 2000,
|
|
314
|
-
monitoringInterval: 1000,
|
|
315
|
-
maxBatchSize: 500,
|
|
316
|
-
enableLogging: false,
|
|
317
|
-
enableNotifications: true
|
|
318
|
-
};
|
|
319
|
-
|
|
320
|
-
const customScheduler = new BatchScheduler(customConfig);
|
|
321
|
-
expect(customScheduler).toBeDefined();
|
|
322
|
-
});
|
|
323
|
-
|
|
324
|
-
it('should use default config when none provided', () => {
|
|
325
|
-
const defaultScheduler = new BatchScheduler();
|
|
326
|
-
expect(defaultScheduler).toBeDefined();
|
|
327
|
-
});
|
|
328
|
-
});
|
|
329
|
-
|
|
330
|
-
describe('에러 처리', () => {
|
|
331
|
-
it('should handle database connection failure', async () => {
|
|
332
|
-
const nullDb = null as any;
|
|
333
|
-
|
|
334
|
-
const result = await batchScheduler.runJob('cleanup');
|
|
335
|
-
expect(result.success).toBe(false);
|
|
336
|
-
expect(result.errors).toContain('Database not initialized');
|
|
337
|
-
});
|
|
338
|
-
|
|
339
|
-
it('should handle forgetting service errors', async () => {
|
|
340
|
-
mockForgettingService.executeMemoryCleanup.mockRejectedValueOnce(
|
|
341
|
-
new Error('Database connection lost')
|
|
342
|
-
);
|
|
343
|
-
|
|
344
|
-
const result = await batchScheduler.runJob('cleanup');
|
|
345
|
-
expect(result.success).toBe(false);
|
|
346
|
-
expect(result.errors).toContain('Database connection lost');
|
|
347
|
-
});
|
|
348
|
-
|
|
349
|
-
it('should handle performance monitor errors', async () => {
|
|
350
|
-
mockPerformanceMonitor.collectMetrics.mockRejectedValueOnce(
|
|
351
|
-
new Error('Memory allocation failed')
|
|
352
|
-
);
|
|
353
|
-
|
|
354
|
-
const result = await batchScheduler.runJob('monitoring');
|
|
355
|
-
expect(result.success).toBe(false);
|
|
356
|
-
expect(result.errors).toContain('Memory allocation failed');
|
|
357
|
-
});
|
|
358
|
-
|
|
359
|
-
it('should continue running after job errors', async () => {
|
|
360
|
-
await batchScheduler.start(db);
|
|
361
|
-
|
|
362
|
-
// First job fails
|
|
363
|
-
mockForgettingService.executeMemoryCleanup.mockRejectedValueOnce(
|
|
364
|
-
new Error('Temporary failure')
|
|
365
|
-
);
|
|
366
|
-
|
|
367
|
-
const result1 = await batchScheduler.runJob('cleanup');
|
|
368
|
-
expect(result1.success).toBe(false);
|
|
369
|
-
|
|
370
|
-
// Second job should still work
|
|
371
|
-
mockForgettingService.executeMemoryCleanup.mockResolvedValueOnce({
|
|
372
|
-
softDeleted: [],
|
|
373
|
-
hardDeleted: [],
|
|
374
|
-
reviewed: []
|
|
375
|
-
});
|
|
376
|
-
|
|
377
|
-
const result2 = await batchScheduler.runJob('cleanup');
|
|
378
|
-
expect(result2.success).toBe(true);
|
|
379
|
-
});
|
|
380
|
-
});
|
|
381
|
-
|
|
382
|
-
describe('작업 스케줄링', () => {
|
|
383
|
-
it('should schedule jobs with correct intervals', async () => {
|
|
384
|
-
const customScheduler = new BatchScheduler({
|
|
385
|
-
cleanupInterval: 100,
|
|
386
|
-
monitoringInterval: 50,
|
|
387
|
-
enableLogging: false
|
|
388
|
-
});
|
|
389
|
-
|
|
390
|
-
await customScheduler.start(db);
|
|
391
|
-
|
|
392
|
-
const status = customScheduler.getStatus();
|
|
393
|
-
expect(status.isRunning).toBe(true);
|
|
394
|
-
expect(status.activeJobs).toContain('cleanup');
|
|
395
|
-
expect(status.activeJobs).toContain('monitoring');
|
|
396
|
-
|
|
397
|
-
customScheduler.stop();
|
|
398
|
-
});
|
|
399
|
-
|
|
400
|
-
it('should handle job execution errors gracefully', async () => {
|
|
401
|
-
await batchScheduler.start(db);
|
|
402
|
-
|
|
403
|
-
// Mock job to throw error
|
|
404
|
-
const originalRunJob = batchScheduler.runJob;
|
|
405
|
-
batchScheduler.runJob = vi.fn().mockRejectedValue(new Error('Job execution failed'));
|
|
406
|
-
|
|
407
|
-
// Should throw the expected error (비동기 함수이므로 await와 rejects 사용)
|
|
408
|
-
await expect(batchScheduler.runJob('cleanup')).rejects.toThrow('Job execution failed');
|
|
409
|
-
|
|
410
|
-
// Restore original method
|
|
411
|
-
batchScheduler.runJob = originalRunJob;
|
|
412
|
-
});
|
|
413
|
-
});
|
|
414
|
-
|
|
415
|
-
describe('로깅', () => {
|
|
416
|
-
it('should log when logging enabled', async () => {
|
|
417
|
-
const consoleSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
|
|
418
|
-
|
|
419
|
-
const loggingScheduler = new BatchScheduler({
|
|
420
|
-
enableLogging: true,
|
|
421
|
-
cleanupInterval: 100,
|
|
422
|
-
monitoringInterval: 50
|
|
423
|
-
});
|
|
424
|
-
|
|
425
|
-
await loggingScheduler.start(db);
|
|
426
|
-
await new Promise(resolve => setTimeout(resolve, 150)); // Wait for jobs to run
|
|
427
|
-
|
|
428
|
-
expect(consoleSpy).toHaveBeenCalled();
|
|
429
|
-
|
|
430
|
-
loggingScheduler.stop();
|
|
431
|
-
consoleSpy.mockRestore();
|
|
432
|
-
});
|
|
433
|
-
|
|
434
|
-
it('should not log when logging disabled', async () => {
|
|
435
|
-
const consoleSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
|
|
436
|
-
|
|
437
|
-
const noLoggingScheduler = new BatchScheduler({
|
|
438
|
-
enableLogging: false,
|
|
439
|
-
cleanupInterval: 100,
|
|
440
|
-
monitoringInterval: 50
|
|
441
|
-
});
|
|
442
|
-
|
|
443
|
-
await noLoggingScheduler.start(db);
|
|
444
|
-
await new Promise(resolve => setTimeout(resolve, 150)); // Wait for jobs to run
|
|
445
|
-
|
|
446
|
-
// Should not log anything
|
|
447
|
-
expect(consoleSpy).not.toHaveBeenCalled();
|
|
448
|
-
|
|
449
|
-
noLoggingScheduler.stop();
|
|
450
|
-
consoleSpy.mockRestore();
|
|
451
|
-
});
|
|
452
|
-
});
|
|
453
|
-
});
|