@futdevpro/nts-dynamo 1.15.83 → 1.15.84
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/.c8rc.json +26 -26
- package/.copilot/patterns.json +7 -7
- package/.cursor/rules/__assistant_guide.mdc +30 -30
- package/.cursor/rules/_ag_backend-structure.mdc +85 -85
- package/.cursor/rules/_ag_backend.mdc +16 -16
- package/.cursor/rules/_ag_frontend-structure.mdc +86 -86
- package/.cursor/rules/_ag_frontend.mdc +39 -39
- package/.cursor/rules/_ag_import-rules.mdc +44 -44
- package/.cursor/rules/_ag_naming.mdc +115 -115
- package/.cursor/rules/_ag_should-be.mdc +6 -6
- package/.cursor/rules/ai_development_guide.md +60 -60
- package/.cursor/rules/cursor-rules.md +160 -160
- package/.cursor/rules/default-command.mdc +464 -464
- package/.cursor/rules/error_code_pattern.md +39 -39
- package/.cursor/rules/saved rule mcp server use.md +15 -15
- package/.vscode/settings.json +10 -10
- package/HOWTO.md +15 -15
- package/LICENSE +21 -21
- package/__documentations/nts-integration-tests-2026-03-17.md +26 -26
- package/__documentations/plans/BEDROCK-HYPERPLAN.md +95 -95
- package/_specifications/BACKLOG.md +92 -92
- package/_specifications/TODO.md +15 -15
- package/_specifications/agent.md +138 -138
- package/build/_modules/server/errors/errors.controller.d.ts.map +1 -1
- package/build/_modules/server/errors/errors.controller.js +12 -1
- package/build/_modules/server/errors/errors.controller.js.map +1 -1
- package/eslint.config.js +3 -3
- package/nodemon.json +24 -24
- package/package.json +3 -3
- package/pnpm-workspace.yaml +5 -5
- package/scripts/run-coverage-tests.js +28 -28
- package/spec/support/helpers/spec-reporter-loader.js +359 -359
- package/spec/support/helpers/ts-node-helper.js +93 -93
- package/spec/support/jasmine.coverage.json +24 -24
- package/spec/support/jasmine.json +24 -24
- package/src/_collections/archive.util.spec.ts +57 -57
- package/src/_collections/archive.util.ts +18 -18
- package/src/_collections/atlas-default-db-options.const.ts +9 -9
- package/src/_collections/default-fallback-cache-max-age.const.spec.ts +11 -11
- package/src/_collections/default-fallback-cache-max-age.const.ts +2 -2
- package/src/_collections/default-not-found-page.const.spec.ts +19 -19
- package/src/_collections/default-not-found-page.const.ts +22 -22
- package/src/_collections/default-socket-path.const.spec.ts +12 -12
- package/src/_collections/default-socket-path.const.ts +2 -2
- package/src/_collections/get-environment-settings.util.spec.ts +210 -210
- package/src/_collections/get-environment-settings.util.ts +48 -48
- package/src/_collections/global-settings.const.ts +109 -109
- package/src/_collections/sample.env +21 -21
- package/src/_collections/star.controller.spec.ts +224 -224
- package/src/_collections/star.controller.ts +129 -129
- package/src/_enums/data-model-type.enum.ts +14 -14
- package/src/_enums/data-service-function.enum.ts +24 -24
- package/src/_enums/predefined-data-types.enum.ts +16 -16
- package/src/_enums/route-security.enum.ts +12 -12
- package/src/_models/control-models/api-call-params.control-model.spec.ts +152 -152
- package/src/_models/control-models/api-call-params.control-model.ts +142 -142
- package/src/_models/control-models/app-ext-system-controls.control-model.spec.ts +52 -52
- package/src/_models/control-models/app-ext-system-controls.control-model.ts +9 -9
- package/src/_models/control-models/app-params.control-model.spec.ts +225 -225
- package/src/_models/control-models/app-params.control-model.ts +136 -136
- package/src/_models/control-models/app-system-controls.control-model.spec.ts +31 -31
- package/src/_models/control-models/app-system-controls.control-model.ts +9 -9
- package/src/_models/control-models/endpoint-params.control-model.spec.ts +627 -627
- package/src/_models/control-models/endpoint-params.control-model.ts +627 -627
- package/src/_models/control-models/http-settings.control-model.spec.ts +77 -77
- package/src/_models/control-models/http-settings.control-model.ts +37 -37
- package/src/_models/control-models/system-control.control-model.spec.ts +27 -27
- package/src/_models/control-models/system-control.control-model.ts +12 -12
- package/src/_models/interfaces/certification-settings.interface.ts +7 -7
- package/src/_models/interfaces/environment-settings.interface.ts +59 -59
- package/src/_models/interfaces/global-log-settings.interface.ts +171 -171
- package/src/_models/interfaces/global-service-settings.interface.ts +47 -47
- package/src/_models/interfaces/global-settings.interface.ts +235 -235
- package/src/_models/interfaces/routing-module-settings.interface.ts +21 -21
- package/src/_models/interfaces/static-client-settings.interface.spec.ts +29 -29
- package/src/_models/interfaces/static-client-settings.interface.ts +28 -28
- package/src/_models/types/db-update.type.ts +100 -100
- package/src/_modules/ai/_models/ai-input-interfaces.ts +117 -117
- package/src/_modules/ai/_models/ai-test-generation-result.interface.ts +16 -16
- package/src/_modules/ai/_modules/anthropic/_services/aai-user-key.control-service.ts +138 -138
- package/src/_modules/ai/_modules/anthropic/index.ts +5 -5
- package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.spec.ts +242 -242
- package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.ts +639 -639
- package/src/_modules/ai/_modules/document-ai/_collections/dai-code-chunking.util.spec.ts +295 -295
- package/src/_modules/ai/_modules/document-ai/_collections/dai-code-chunking.util.ts +518 -518
- package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.spec.ts +209 -209
- package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.ts +85 -85
- package/src/_modules/ai/_modules/document-ai/_enums/dai-compare-result-type.enum.ts +7 -7
- package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-chunk.data-model.ts +146 -146
- package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-page.data-model.ts +162 -162
- package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-document.data-model.ts +99 -99
- package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-code-chunk.interface.ts +68 -68
- package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-chunk-compare-result.interface.ts +18 -18
- package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-page-compare-result.interface.ts +19 -19
- package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-document-compare-result.interface.ts +25 -25
- package/src/_modules/ai/_modules/document-ai/index.ts +30 -30
- package/src/_modules/ai/_modules/fdp-ai/_services/fdpai-user-key.control-service.ts +189 -189
- package/src/_modules/ai/_modules/fdp-ai/index.ts +5 -5
- package/src/_modules/ai/_modules/open-ai/_collections/oai-global-settings.const.ts +9 -9
- package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests-hu.conts.ts +82 -82
- package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests.conts.ts +75 -75
- package/src/_modules/ai/_modules/open-ai/_enums/oai-gpt-message-role.enum.ts +45 -45
- package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-global-settings.interface.ts +7 -7
- package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-gpt-message.interface.ts +7 -7
- package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-llm-predefined-requests.interface.ts +57 -57
- package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-doc-chunk-data.service.ts +292 -292
- package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-document.data-service.spec.ts +342 -342
- package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.spec.ts +550 -550
- package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.ts +630 -630
- package/src/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.spec.ts +332 -332
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.spec.ts +462 -462
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.ts +634 -634
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.spec.ts +489 -489
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.tools.spec.ts +173 -173
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.ts +1033 -1033
- package/src/_modules/ai/_modules/open-ai/_services/oai-user-key.control-service.ts +157 -157
- package/src/_modules/ai/_services/ai-embedding-mock.service.spec.ts +115 -115
- package/src/_modules/ai/_services/ai-embedding-mock.service.ts +212 -212
- package/src/_modules/ai/_services/ai-embedding-provider.registry.spec.ts +110 -110
- package/src/_modules/ai/_services/ai-embedding-provider.registry.ts +110 -110
- package/src/_modules/ai/_services/ai-embedding.service-base.spec.ts +98 -98
- package/src/_modules/ai/_services/ai-embedding.service-base.ts +48 -48
- package/src/_modules/ai/_services/ai-llm-chat.service-base.spec.ts +229 -229
- package/src/_modules/ai/_services/ai-llm-chat.service-base.ts +68 -68
- package/src/_modules/ai/_services/ai-llm.service-base.spec.ts +250 -250
- package/src/_modules/ai/_services/ai-llm.service-base.ts +519 -519
- package/src/_modules/ai/_services/ai-provider.service-base.spec.ts +158 -158
- package/src/_modules/ai/_services/ai-user-key.service-base.ts +59 -59
- package/src/_modules/ai/_services/lmstudio-embedding.control-service.spec.ts +197 -197
- package/src/_modules/ai/_services/lmstudio-embedding.control-service.ts +371 -371
- package/src/_modules/ai/index.ts +23 -23
- package/src/_modules/assistant/_collections/ass-global-settings.const.ts +13 -13
- package/src/_modules/assistant/_collections/ass.util.spec.ts +176 -176
- package/src/_modules/assistant/_collections/ass.util.ts +50 -50
- package/src/_modules/assistant/_models/ass-global-settings.interface.ts +15 -15
- package/src/_modules/assistant/_services/ass-io.control-service.spec.ts +140 -140
- package/src/_modules/assistant/_services/ass-main.control-service.spec.ts +192 -192
- package/src/_modules/assistant/_services/ass-main.control-service.ts +107 -107
- package/src/_modules/bot/_collections/bot-default-commands.const.ts +12 -12
- package/src/_modules/bot/_collections/bot-global-settings.const.ts +39 -39
- package/src/_modules/bot/_models/bot-channel-wrapper.interface.ts +62 -62
- package/src/_modules/bot/_models/bot-command.interface.ts +8 -8
- package/src/_modules/bot/_models/bot-global-settings.interface.ts +96 -96
- package/src/_modules/bot/_models/bot-last-mention-date.interface.ts +6 -6
- package/src/_modules/bot/_models/bot-last-message-date.interface.ts +5 -5
- package/src/_modules/bot/_models/bot-user-wrapper.interface.ts +41 -41
- package/src/_modules/bot/_modules/discord-bot/_models/dib-platform.types.ts +9 -9
- package/src/_modules/bot/_modules/discord-bot/_services/dib-messaging-provider.control-service.spec.ts +431 -431
- package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.spec.ts +160 -160
- package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.ts +55 -55
- package/src/_modules/bot/_modules/dynamo-bot/_models/dyb-platform.types.ts +15 -15
- package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.spec.ts +374 -374
- package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.ts +447 -447
- package/src/_modules/bot/_modules/dynamo-bot/index.ts +15 -15
- package/src/_modules/bot/_modules/slack-bot/_models/slb-platform.types.ts +9 -9
- package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.spec.ts +344 -344
- package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.ts +197 -197
- package/src/_modules/bot/_modules/teams-bot/_models/teb-platform.types.ts +9 -9
- package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.spec.ts +345 -345
- package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.ts +197 -197
- package/src/_modules/bot/_services/bot-commands.control-service.spec.ts +116 -116
- package/src/_modules/bot/_services/bot-io.control-service.spec.ts +285 -285
- package/src/_modules/bot/_services/bot-main.control-service.spec.ts +208 -208
- package/src/_modules/bot/_services/bot-messaging-provider.service-base.spec.ts +349 -349
- package/src/_modules/bot/_services/bot-routines.control-service.spec.ts +111 -111
- package/src/_modules/custom-data/custom-data.controller.spec.ts +49 -49
- package/src/_modules/custom-data/custom-data.controller.ts +67 -67
- package/src/_modules/custom-data/custom-data.data-service.spec.ts +54 -54
- package/src/_modules/custom-data/custom-data.data-service.ts +21 -21
- package/src/_modules/custom-data/get-custom-data-routing-module.util.spec.ts +28 -28
- package/src/_modules/custom-data/get-custom-data-routing-module.util.ts +24 -24
- package/src/_modules/custom-data/index.ts +9 -9
- package/src/_modules/data-readers/_collections/dynts-sqlite-reader.util.spec.ts +161 -161
- package/src/_modules/data-readers/_collections/dynts-sqlite-reader.util.ts +203 -203
- package/src/_modules/data-readers/_models/interfaces/dynts-sqlite-reader.interface.ts +33 -33
- package/src/_modules/data-readers/index.ts +11 -11
- package/src/_modules/defaults/_collections/default-endpoints.util.ts +487 -487
- package/src/_modules/defaults/_models/default-user.data-model.ts +72 -72
- package/src/_modules/defaults/_services/default-auth.service.spec.ts +269 -269
- package/src/_modules/defaults/_services/default-auth.service.ts +177 -177
- package/src/_modules/defaults/_services/default-socket-events.service.spec.ts +42 -42
- package/src/_modules/defaults/_services/default-socket-events.service.ts +61 -61
- package/src/_modules/defaults/_services/default-user.data-service.spec.ts +187 -187
- package/src/_modules/defaults/_services/default-user.data-service.ts +98 -98
- package/src/_modules/defaults/index.ts +17 -17
- package/src/_modules/discord-assistant/_collections/dias-global-settings.const.ts +19 -19
- package/src/_modules/discord-assistant/_collections/dias.util.spec.ts +366 -366
- package/src/_modules/discord-assistant/_collections/dias.util.ts +132 -132
- package/src/_modules/discord-assistant/_models/dias-global-settings.interface.ts +19 -19
- package/src/_modules/discord-assistant/_models/dias-knowledge.data-model.ts +52 -52
- package/src/_modules/discord-assistant/_services/dias-chunk.data-service.ts +177 -177
- package/src/_modules/discord-assistant/_services/dias-io.control-service.spec.ts +108 -108
- package/src/_modules/discord-assistant/_services/dias-io.control-service.ts +69 -69
- package/src/_modules/discord-assistant/_services/dias-main.control-service.spec.ts +22 -22
- package/src/_modules/discord-assistant/_services/dias-main.control-service.ts +27 -27
- package/src/_modules/discord-assistant/_services/dias.service-base.spec.ts +195 -195
- package/src/_modules/discord-assistant/_services/dias.service-base.ts +76 -76
- package/src/_modules/discord-assistant/index.ts +38 -38
- package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.spec.ts +34 -34
- package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.ts +11 -11
- package/src/_modules/discord-assistant-voiced/index.ts +36 -36
- package/src/_modules/discord-bot/_collections/dibo-default-commands.const.ts +16 -16
- package/src/_modules/discord-bot/_collections/dibo-global-settings.conts.ts +55 -55
- package/src/_modules/discord-bot/_collections/dibo-operations.util.spec.ts +214 -214
- package/src/_modules/discord-bot/_collections/dibo-operations.util.ts +387 -387
- package/src/_modules/discord-bot/_models/dibo-command.interface.ts +12 -12
- package/src/_modules/discord-bot/_models/dibo-global-settings.interface.ts +98 -98
- package/src/_modules/discord-bot/_models/dibo-last-mention-date.inteface.ts +7 -7
- package/src/_modules/discord-bot/_models/dibo-last-message-date.interface.ts +6 -6
- package/src/_modules/discord-bot/_services/dibo-commands.control-service.spec.ts +154 -154
- package/src/_modules/discord-bot/_services/dibo-commands.control-service.ts +153 -153
- package/src/_modules/discord-bot/_services/dibo-io.control-service.spec.ts +264 -264
- package/src/_modules/discord-bot/_services/dibo-io.control-service.ts +306 -306
- package/src/_modules/discord-bot/_services/dibo-main.control-service.spec.ts +408 -408
- package/src/_modules/discord-bot/_services/dibo-main.control-service.ts +487 -487
- package/src/_modules/discord-bot/_services/dibo-routines.control-service.spec.ts +105 -105
- package/src/_modules/discord-bot/index.ts +36 -36
- package/src/_modules/local-vector-search/_enums/lvs-search-mode.enum.ts +35 -35
- package/src/_modules/local-vector-search/_models/data-models/lvs-vector-persist.data-model.ts +59 -59
- package/src/_modules/local-vector-search/_models/lvs-search-result.interface.ts +17 -17
- package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.spec.ts +418 -418
- package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.ts +276 -276
- package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.spec.ts +480 -480
- package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.ts +416 -416
- package/src/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.spec.ts +198 -198
- package/src/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.ts +146 -146
- package/src/_modules/local-vector-search/_services/lvs-vector-persist.data-service.spec.ts +167 -167
- package/src/_modules/local-vector-search/_services/lvs-vector-persist.data-service.ts +106 -106
- package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.spec.ts +507 -507
- package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.ts +272 -272
- package/src/_modules/local-vector-search/index.ts +16 -16
- package/src/_modules/logs/index.ts +11 -11
- package/src/_modules/mcp/_models/interfaces/dynts-mcp.interface.ts +111 -111
- package/src/_modules/mcp/_services/dynts-mcp-server.service-base.spec.ts +142 -142
- package/src/_modules/mcp/_services/dynts-mcp-server.service-base.ts +120 -120
- package/src/_modules/mcp/_services/dynts-mcp.adapter.ts +168 -168
- package/src/_modules/mcp/index.ts +13 -13
- package/src/_modules/messaging/README.md +354 -354
- package/src/_modules/messaging/_collections/get-messaging-routing-module.util.ts +26 -26
- package/src/_modules/messaging/_collections/msg-global-settings.const.ts +22 -22
- package/src/_modules/messaging/_collections/msg.util.spec.ts +226 -226
- package/src/_modules/messaging/_models/msg-global-settings.interface.ts +37 -37
- package/src/_modules/messaging/_services/msg-conversation.data-service.ts +146 -146
- package/src/_modules/messaging/_services/msg-events.service.spec.ts +219 -219
- package/src/_modules/messaging/_services/msg-events.service.ts +267 -267
- package/src/_modules/messaging/_services/msg-integration.control-service.ts +179 -179
- package/src/_modules/messaging/_services/msg-main.control-service.spec.ts +147 -147
- package/src/_modules/messaging/_services/msg-main.control-service.ts +571 -571
- package/src/_modules/messaging/_services/msg-message.data-service.ts +129 -129
- package/src/_modules/messaging/_services/msg.controller.spec.ts +201 -201
- package/src/_modules/messaging/index.ts +30 -30
- package/src/_modules/mock/app-extended-server.mock.ts +201 -201
- package/src/_modules/mock/app-integration-test.mock.ts +51 -51
- package/src/_modules/mock/app-params.mock.spec.ts +21 -21
- package/src/_modules/mock/app-params.mock.ts +9 -9
- package/src/_modules/mock/app-server.mock.ts +188 -188
- package/src/_modules/mock/auth-service.mock.spec.ts +47 -47
- package/src/_modules/mock/auth-service.mock.ts +28 -28
- package/src/_modules/mock/controller.mock.spec.ts +26 -26
- package/src/_modules/mock/controller.mock.ts +16 -16
- package/src/_modules/mock/data-model.mock.spec.ts +111 -111
- package/src/_modules/mock/data-model.mock.ts +82 -82
- package/src/_modules/mock/email-service-collection.mock.spec.ts +24 -24
- package/src/_modules/mock/email-service-collection.mock.ts +15 -15
- package/src/_modules/mock/email-service.mock.spec.ts +17 -17
- package/src/_modules/mock/email-service.mock.ts +20 -20
- package/src/_modules/mock/email-template.mock.html +14 -14
- package/src/_modules/mock/endpoint.mock.ts +91 -91
- package/src/_modules/mock/socket-client.mock.spec.ts +40 -40
- package/src/_modules/mock/socket-client.mock.ts +45 -45
- package/src/_modules/mock/socket-server.mock.spec.ts +44 -44
- package/src/_modules/mock/socket-server.mock.ts +46 -46
- package/src/_modules/oauth2/_routes/oauth2.controller.spec.ts +107 -107
- package/src/_modules/oauth2/_routes/oauth2.controller.ts +98 -98
- package/src/_modules/oauth2/_services/oauth2.auth-service.spec.ts +254 -254
- package/src/_modules/oauth2/_services/oauth2.auth-service.ts +232 -232
- package/src/_modules/oauth2/_services/oauth2.control-service.spec.ts +585 -585
- package/src/_modules/oauth2/_services/oauth2.control-service.ts +653 -653
- package/src/_modules/oauth2/index.ts +17 -17
- package/src/_modules/scoped-config/_enums/dynts-scoped-config-level.enum.ts +22 -22
- package/src/_modules/scoped-config/_models/data-models/dynts-scoped-config.data-model.ts +81 -81
- package/src/_modules/scoped-config/_models/interfaces/dynts-scoped-config.interface.ts +107 -107
- package/src/_modules/scoped-config/_services/dynts-scoped-config.control-service.spec.ts +306 -306
- package/src/_modules/scoped-config/_services/dynts-scoped-config.control-service.ts +295 -295
- package/src/_modules/scoped-config/_services/dynts-scoped-config.data-service.spec.ts +118 -118
- package/src/_modules/scoped-config/_services/dynts-scoped-config.data-service.ts +105 -105
- package/src/_modules/scoped-config/index.ts +17 -17
- package/src/_modules/server/errors/errors.control-service.spec.ts +238 -238
- package/src/_modules/server/errors/errors.control-service.ts +100 -100
- package/src/_modules/server/errors/errors.controller.spec.ts +268 -268
- package/src/_modules/server/errors/errors.controller.ts +527 -515
- package/src/_modules/server/errors/errors.data-service.spec.ts +480 -480
- package/src/_modules/server/index.ts +30 -30
- package/src/_modules/server/server-status/server-status-snapshot.control-service.spec.ts +70 -70
- package/src/_modules/server/server-status/server-status-snapshot.control-service.ts +17 -17
- package/src/_modules/server/server-status/server-status-snapshot.data-service.spec.ts +77 -77
- package/src/_modules/server/server-status/server-status-snapshot.data-service.ts +37 -37
- package/src/_modules/server/server-status/server-status.control-service.spec.ts +576 -576
- package/src/_modules/server/server-status/server-status.control-service.ts +396 -396
- package/src/_modules/server/server-status/server-status.controller.spec.ts +255 -255
- package/src/_modules/server/server-status/server-status.controller.ts +272 -272
- package/src/_modules/socket/_enums/socket-security.enum.ts +11 -11
- package/src/_modules/socket/_models/socket-client-service-params.control-model.spec.ts +32 -32
- package/src/_modules/socket/_models/socket-client-service-params.control-model.ts +22 -22
- package/src/_modules/socket/_models/socket-presence.control-model.spec.ts +164 -164
- package/src/_modules/socket/_models/socket-presence.control-model.ts +210 -210
- package/src/_modules/socket/_models/socket-server-service-params.control-model.spec.ts +46 -46
- package/src/_modules/socket/_models/socket-server-service-params.control-model.ts +22 -22
- package/src/_modules/socket/_services/socket-client.service.spec.ts +15 -15
- package/src/_modules/socket/_services/socket-client.service.ts +260 -260
- package/src/_modules/socket/_services/socket-server.service.spec.ts +11 -11
- package/src/_modules/socket/app-extended.integration.spec.ts +85 -85
- package/src/_modules/socket/app-extended.server.ts +630 -630
- package/src/_modules/socket/index.ts +42 -42
- package/src/_modules/test/get-test-routing-module.util.spec.ts +28 -28
- package/src/_modules/test/get-test-routing-module.util.ts +23 -23
- package/src/_modules/test/index.ts +11 -11
- package/src/_modules/test/test.controller.spec.ts +72 -72
- package/src/_modules/test/test.controller.ts +115 -115
- package/src/_modules/usage/get-usage-routing-module.util.ts +22 -22
- package/src/_modules/usage/index.ts +15 -15
- package/src/_modules/usage/usage.controller.spec.ts +81 -81
- package/src/_modules/usage/usage.controller.ts +126 -126
- package/src/_modules/usage/usage.data-service.spec.ts +332 -332
- package/src/_modules/usage/usage.data-service.ts +185 -185
- package/src/_services/base/api.service-base.spec.ts +125 -125
- package/src/_services/base/api.service-base.ts +74 -74
- package/src/_services/base/archive-data.service.spec.ts +209 -209
- package/src/_services/base/archive-data.service.ts +224 -224
- package/src/_services/base/data.service.spec.ts +729 -729
- package/src/_services/base/data.service.ts +2740 -2740
- package/src/_services/base/db.service.spec.ts +73 -73
- package/src/_services/base/db.service.ts +1575 -1575
- package/src/_services/base/singleton.service-base.spec.ts +28 -28
- package/src/_services/base/singleton.service-base.ts +24 -24
- package/src/_services/base/singleton.service.spec.ts +114 -114
- package/src/_services/base/singleton.service.ts +38 -38
- package/src/_services/core/api.service.spec.ts +140 -140
- package/src/_services/core/auth.service.spec.ts +159 -159
- package/src/_services/core/auth.service.ts +174 -174
- package/src/_services/core/email.service.spec.ts +85 -85
- package/src/_services/core/email.service.ts +742 -742
- package/src/_services/core/global.service.spec.ts +292 -292
- package/src/_services/core/global.service.ts +487 -487
- package/src/_services/core/memory-guard.service.spec.ts +245 -245
- package/src/_services/core/memory-guard.service.ts +481 -481
- package/src/_services/core/service-collection.service.spec.ts +46 -46
- package/src/_services/core/service-collection.service.ts +6 -6
- package/src/_services/route/controller.service.spec.ts +53 -53
- package/src/_services/route/controller.service.ts +148 -148
- package/src/_services/route/routing-module.service.spec.ts +98 -98
- package/src/_services/route/routing-module.service.ts +330 -330
- package/src/_services/server/app.server.ts +1905 -1905
- package/src/_services/shared.static-service.spec.ts +99 -99
- package/src/_services/shared.static-service.ts +78 -78
- package/src/index.ts +97 -97
- package/tsconfig.app.json +12 -12
- package/tsconfig.json +42 -42
- package/.dynamo/logs/cicd-pipeline/output.log +0 -2791
- package/.dynamo/logs/cicd-pipeline/status.json +0 -94
|
@@ -1,295 +1,295 @@
|
|
|
1
|
-
import { DyNTS_DAI_CodeChunking_Util } from './dai-code-chunking.util';
|
|
2
|
-
import { DyNTS_DAI_CodeChunk } from '../_models/interfaces/dai-code-chunk.interface';
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* `DyNTS_DAI_CodeChunking_Util` spec-jei (BFR-AM-005) — AST-szemantikus kód-chunking.
|
|
6
|
-
* Tiszta (NEM Mongo / NEM network): minden teszt csak forrás-string-et chunkol.
|
|
7
|
-
*/
|
|
8
|
-
describe('| DyNTS_DAI_CodeChunking_Util', () => {
|
|
9
|
-
|
|
10
|
-
describe('| chunkTs — empty / tiny input', () => {
|
|
11
|
-
it('| should return empty list for empty content', () => {
|
|
12
|
-
expect(DyNTS_DAI_CodeChunking_Util.chunkTs('')).toEqual([]);
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
it('| should return empty list for whitespace-only content', () => {
|
|
16
|
-
expect(DyNTS_DAI_CodeChunking_Util.chunkTs(' \n \t \n ')).toEqual([]);
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
it('| should fall back to a single fallback chunk for tiny non-parseable content', () => {
|
|
20
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs('x');
|
|
21
|
-
expect(chunks.length).toBe(1);
|
|
22
|
-
expect(chunks[0].chunkType).toBe('fallback');
|
|
23
|
-
expect(chunks[0].content).toBe('x');
|
|
24
|
-
});
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
describe('| chunkTs — import-group', () => {
|
|
28
|
-
it('| should group consecutive imports into a single chunk', () => {
|
|
29
|
-
const code: string = [
|
|
30
|
-
`import { A } from './a';`,
|
|
31
|
-
`import { B } from './b';`,
|
|
32
|
-
`import * as c from './c';`,
|
|
33
|
-
``,
|
|
34
|
-
`export const value: number = 1;`,
|
|
35
|
-
].join('\n');
|
|
36
|
-
|
|
37
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
38
|
-
const importChunks: DyNTS_DAI_CodeChunk[] = chunks.filter((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'imports');
|
|
39
|
-
|
|
40
|
-
expect(importChunks.length).toBe(1);
|
|
41
|
-
expect(importChunks[0].content).toContain(`from './a'`);
|
|
42
|
-
expect(importChunks[0].content).toContain(`from './b'`);
|
|
43
|
-
expect(importChunks[0].content).toContain(`from './c'`);
|
|
44
|
-
expect(importChunks[0].symbolPath).toBe('');
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
it('| should treat re-export (export ... from) as part of the import group', () => {
|
|
48
|
-
const code: string = [
|
|
49
|
-
`import { A } from './a';`,
|
|
50
|
-
`export { B } from './b';`,
|
|
51
|
-
``,
|
|
52
|
-
`function helper(): void {}`,
|
|
53
|
-
].join('\n');
|
|
54
|
-
|
|
55
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
56
|
-
const importChunks: DyNTS_DAI_CodeChunk[] = chunks.filter((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'imports');
|
|
57
|
-
|
|
58
|
-
expect(importChunks.length).toBe(1);
|
|
59
|
-
expect(importChunks[0].content).toContain(`export { B } from './b'`);
|
|
60
|
-
});
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
describe('| chunkTs — top-level declarations', () => {
|
|
64
|
-
it('| should chunk an interface', () => {
|
|
65
|
-
const code: string = `export interface FooParams {\n a: string;\n b: number;\n}`;
|
|
66
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
67
|
-
|
|
68
|
-
const iface: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'interface');
|
|
69
|
-
expect(iface).toBeDefined();
|
|
70
|
-
expect(iface!.symbolName).toBe('FooParams');
|
|
71
|
-
expect(iface!.symbolPath).toBe('interface:FooParams');
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
it('| should chunk an enum', () => {
|
|
75
|
-
const code: string = `export enum Color {\n red = 'red',\n green = 'green',\n}`;
|
|
76
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
77
|
-
|
|
78
|
-
const en: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'enum');
|
|
79
|
-
expect(en).toBeDefined();
|
|
80
|
-
expect(en!.symbolPath).toBe('enum:Color');
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
it('| should chunk a type-alias', () => {
|
|
84
|
-
const code: string = `export type Id = string | number;`;
|
|
85
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
86
|
-
|
|
87
|
-
const typeChunk: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'type');
|
|
88
|
-
expect(typeChunk).toBeDefined();
|
|
89
|
-
expect(typeChunk!.symbolPath).toBe('type:Id');
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
it('| should chunk a standalone function', () => {
|
|
93
|
-
const code: string = `export function doThing(x: number): number {\n return x + 1;\n}`;
|
|
94
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
95
|
-
|
|
96
|
-
const fn: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'function');
|
|
97
|
-
expect(fn).toBeDefined();
|
|
98
|
-
expect(fn!.symbolPath).toBe('function:doThing');
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
it('| should classify an arrow-const as a function chunk', () => {
|
|
102
|
-
const code: string = `export const adder = (a: number, b: number): number => {\n return a + b;\n};`;
|
|
103
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
104
|
-
|
|
105
|
-
const fn: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'adder');
|
|
106
|
-
expect(fn).toBeDefined();
|
|
107
|
-
expect(fn!.chunkType).toBe('function');
|
|
108
|
-
expect(fn!.symbolPath).toBe('function:adder');
|
|
109
|
-
});
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
describe('| chunkTs — class (whole vs method-split)', () => {
|
|
113
|
-
it('| should keep a small class as a single chunk', () => {
|
|
114
|
-
const code: string = [
|
|
115
|
-
`export class Small {`,
|
|
116
|
-
` greet(): string { return 'hi'; }`,
|
|
117
|
-
`}`,
|
|
118
|
-
].join('\n');
|
|
119
|
-
|
|
120
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
121
|
-
const classChunks: DyNTS_DAI_CodeChunk[] = chunks.filter((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'class');
|
|
122
|
-
|
|
123
|
-
// Egyetlen, egész-osztály chunk (nincs metódus-bontás kis méretnél).
|
|
124
|
-
expect(classChunks.length).toBe(1);
|
|
125
|
-
expect(classChunks[0].symbolPath).toBe('class:Small');
|
|
126
|
-
expect(classChunks[0].content).toContain('greet');
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
it('| should split a large class by methods with class:Foo > method:bar symbolPaths', () => {
|
|
130
|
-
// Minden metódus body-ja kellően nagy, hogy az osztály a maxChunkSize fölé nőjön.
|
|
131
|
-
const body: string = ` const v = ${'1 + '.repeat(60)}1;\n return v;`;
|
|
132
|
-
const code: string = [
|
|
133
|
-
`export class BigService {`,
|
|
134
|
-
` alpha(): number {\n${body}\n }`,
|
|
135
|
-
` beta(): number {\n${body}\n }`,
|
|
136
|
-
` gamma(): number {\n${body}\n }`,
|
|
137
|
-
`}`,
|
|
138
|
-
].join('\n');
|
|
139
|
-
|
|
140
|
-
// maxChunkSize=400: minden metódus (~292) belefér egy chunkba, de az egész osztály (~911)
|
|
141
|
-
// NEM → pontosan osztály-fej + 3 metódus-chunk.
|
|
142
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code, { maxChunkSize: 400 });
|
|
143
|
-
|
|
144
|
-
const methodChunks: DyNTS_DAI_CodeChunk[] = chunks.filter((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'method');
|
|
145
|
-
const methodPaths: string[] = methodChunks.map((c: DyNTS_DAI_CodeChunk) => c.symbolPath);
|
|
146
|
-
|
|
147
|
-
expect(methodChunks.length).toBe(3);
|
|
148
|
-
expect(methodPaths).toContain('class:BigService > method:alpha');
|
|
149
|
-
expect(methodPaths).toContain('class:BigService > method:beta');
|
|
150
|
-
expect(methodPaths).toContain('class:BigService > method:gamma');
|
|
151
|
-
|
|
152
|
-
// Az osztály-fej külön chunk, class:BigService symbol-lánccal.
|
|
153
|
-
const classHeader: DyNTS_DAI_CodeChunk | undefined = chunks.find(
|
|
154
|
-
(c: DyNTS_DAI_CodeChunk) => c.chunkType === 'class' && c.symbolPath === 'class:BigService'
|
|
155
|
-
);
|
|
156
|
-
expect(classHeader).toBeDefined();
|
|
157
|
-
});
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
describe('| chunkTs — JSDoc + decorator bundling', () => {
|
|
161
|
-
it('| should bundle a leading JSDoc with the following node', () => {
|
|
162
|
-
const code: string = [
|
|
163
|
-
`/**`,
|
|
164
|
-
` * Helper function docs.`,
|
|
165
|
-
` */`,
|
|
166
|
-
`export function withDocs(): void {}`,
|
|
167
|
-
].join('\n');
|
|
168
|
-
|
|
169
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
170
|
-
const fn: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'withDocs');
|
|
171
|
-
|
|
172
|
-
expect(fn).toBeDefined();
|
|
173
|
-
expect(fn!.content).toContain('Helper function docs.');
|
|
174
|
-
expect(fn!.content).toContain('export function withDocs');
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
it('| should bundle decorators with the following class node', () => {
|
|
178
|
-
const code: string = [
|
|
179
|
-
`@Injectable()`,
|
|
180
|
-
`@Logged`,
|
|
181
|
-
`export class Decorated {`,
|
|
182
|
-
` run(): void {}`,
|
|
183
|
-
`}`,
|
|
184
|
-
].join('\n');
|
|
185
|
-
|
|
186
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
187
|
-
const cls: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'Decorated');
|
|
188
|
-
|
|
189
|
-
expect(cls).toBeDefined();
|
|
190
|
-
expect(cls!.content).toContain('@Injectable()');
|
|
191
|
-
expect(cls!.content).toContain('@Logged');
|
|
192
|
-
});
|
|
193
|
-
});
|
|
194
|
-
|
|
195
|
-
describe('| chunkTs — large-node sliding-split', () => {
|
|
196
|
-
it('| should sliding-split a single oversized function into sub-chunks', () => {
|
|
197
|
-
const longBody: string = Array.from({ length: 80 }, (_: unknown, i: number) => ` const x${i} = ${i};`).join('\n');
|
|
198
|
-
const code: string = `export function huge(): void {\n${longBody}\n}`;
|
|
199
|
-
|
|
200
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code, { maxChunkSize: 300, overlap: 50 });
|
|
201
|
-
|
|
202
|
-
// Több sub-chunk, mind ugyanazzal a symbol-lánccal + subChunkIndex-szel.
|
|
203
|
-
expect(chunks.length).toBeGreaterThan(1);
|
|
204
|
-
chunks.forEach((c: DyNTS_DAI_CodeChunk) => {
|
|
205
|
-
expect(c.symbolPath).toBe('function:huge');
|
|
206
|
-
expect(c.subChunkIndex).toBeGreaterThanOrEqual(0);
|
|
207
|
-
expect(c.content.length).toBeLessThanOrEqual(300);
|
|
208
|
-
});
|
|
209
|
-
// A sub-chunk-indexek 0-tól folytonosak.
|
|
210
|
-
expect(chunks[0].subChunkIndex).toBe(0);
|
|
211
|
-
});
|
|
212
|
-
});
|
|
213
|
-
|
|
214
|
-
describe('| chunkTs — positions', () => {
|
|
215
|
-
it('| should report 1-based source line numbers', () => {
|
|
216
|
-
const code: string = [
|
|
217
|
-
`import { A } from './a';`, // line 1
|
|
218
|
-
``, // line 2
|
|
219
|
-
`export function f(): void {`, // line 3
|
|
220
|
-
` return;`, // line 4
|
|
221
|
-
`}`, // line 5
|
|
222
|
-
].join('\n');
|
|
223
|
-
|
|
224
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
225
|
-
const fn: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'f');
|
|
226
|
-
|
|
227
|
-
expect(fn).toBeDefined();
|
|
228
|
-
expect(fn!.lineStart).toBe(3);
|
|
229
|
-
expect(fn!.lineEnd).toBe(5);
|
|
230
|
-
});
|
|
231
|
-
|
|
232
|
-
it('| should assign contiguous 0-based chunkIndex values', () => {
|
|
233
|
-
const code: string = [
|
|
234
|
-
`import { A } from './a';`,
|
|
235
|
-
`export interface I { x: number; }`,
|
|
236
|
-
`export type T = string;`,
|
|
237
|
-
`export function fn(): void {}`,
|
|
238
|
-
].join('\n');
|
|
239
|
-
|
|
240
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
241
|
-
chunks.forEach((c: DyNTS_DAI_CodeChunk, i: number) => {
|
|
242
|
-
expect(c.chunkIndex).toBe(i);
|
|
243
|
-
});
|
|
244
|
-
});
|
|
245
|
-
});
|
|
246
|
-
|
|
247
|
-
describe('| chunk — dispatcher routing', () => {
|
|
248
|
-
it('| should route .ts files through the AST chunker', () => {
|
|
249
|
-
const code: string = `export class Routed {\n go(): void {}\n}`;
|
|
250
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunk(code, 'foo.ts');
|
|
251
|
-
|
|
252
|
-
expect(chunks.some((c: DyNTS_DAI_CodeChunk) => c.symbolPath === 'class:Routed')).toBe(true);
|
|
253
|
-
});
|
|
254
|
-
|
|
255
|
-
it('| should route .tsx/.js/.jsx files through the AST chunker', () => {
|
|
256
|
-
const code: string = `export function widget(): void {}`;
|
|
257
|
-
expect(DyNTS_DAI_CodeChunking_Util.chunk(code, 'a.tsx').some((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'widget')).toBe(true);
|
|
258
|
-
expect(DyNTS_DAI_CodeChunking_Util.chunk(code, 'b.js').some((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'widget')).toBe(true);
|
|
259
|
-
expect(DyNTS_DAI_CodeChunking_Util.chunk(code, 'c.jsx').some((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'widget')).toBe(true);
|
|
260
|
-
});
|
|
261
|
-
|
|
262
|
-
it('| should route non-code (.md) content to fallback chunks (no semantic split)', () => {
|
|
263
|
-
const content: string = `# Title\n\nSome markdown text.`;
|
|
264
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunk(content, 'readme.md');
|
|
265
|
-
|
|
266
|
-
expect(chunks.length).toBe(1);
|
|
267
|
-
expect(chunks[0].chunkType).toBe('fallback');
|
|
268
|
-
expect(chunks[0].content).toContain('# Title');
|
|
269
|
-
});
|
|
270
|
-
|
|
271
|
-
it('| should return empty for empty non-code content', () => {
|
|
272
|
-
expect(DyNTS_DAI_CodeChunking_Util.chunk('', 'readme.md')).toEqual([]);
|
|
273
|
-
});
|
|
274
|
-
});
|
|
275
|
-
|
|
276
|
-
describe('| chunkTs — robustness (braces inside strings/templates)', () => {
|
|
277
|
-
it('| should not be confused by braces inside string and template literals (AST-correct)', () => {
|
|
278
|
-
// A FAM regex/brace-depth workaround itt tévedne; az AST helyesen kezeli.
|
|
279
|
-
const code: string = [
|
|
280
|
-
`export function tricky(): string {`,
|
|
281
|
-
' const a = "} not a real close {";',
|
|
282
|
-
' const b = `template ${ a } with } braces {`;',
|
|
283
|
-
` return a + b;`,
|
|
284
|
-
`}`,
|
|
285
|
-
`export interface AfterTricky { ok: boolean; }`,
|
|
286
|
-
].join('\n');
|
|
287
|
-
|
|
288
|
-
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
289
|
-
|
|
290
|
-
// A függvény ÉS az utána jövő interface is külön, helyes chunk (nem olvad össze).
|
|
291
|
-
expect(chunks.some((c: DyNTS_DAI_CodeChunk) => c.symbolPath === 'function:tricky')).toBe(true);
|
|
292
|
-
expect(chunks.some((c: DyNTS_DAI_CodeChunk) => c.symbolPath === 'interface:AfterTricky')).toBe(true);
|
|
293
|
-
});
|
|
294
|
-
});
|
|
295
|
-
});
|
|
1
|
+
import { DyNTS_DAI_CodeChunking_Util } from './dai-code-chunking.util';
|
|
2
|
+
import { DyNTS_DAI_CodeChunk } from '../_models/interfaces/dai-code-chunk.interface';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* `DyNTS_DAI_CodeChunking_Util` spec-jei (BFR-AM-005) — AST-szemantikus kód-chunking.
|
|
6
|
+
* Tiszta (NEM Mongo / NEM network): minden teszt csak forrás-string-et chunkol.
|
|
7
|
+
*/
|
|
8
|
+
describe('| DyNTS_DAI_CodeChunking_Util', () => {
|
|
9
|
+
|
|
10
|
+
describe('| chunkTs — empty / tiny input', () => {
|
|
11
|
+
it('| should return empty list for empty content', () => {
|
|
12
|
+
expect(DyNTS_DAI_CodeChunking_Util.chunkTs('')).toEqual([]);
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
it('| should return empty list for whitespace-only content', () => {
|
|
16
|
+
expect(DyNTS_DAI_CodeChunking_Util.chunkTs(' \n \t \n ')).toEqual([]);
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
it('| should fall back to a single fallback chunk for tiny non-parseable content', () => {
|
|
20
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs('x');
|
|
21
|
+
expect(chunks.length).toBe(1);
|
|
22
|
+
expect(chunks[0].chunkType).toBe('fallback');
|
|
23
|
+
expect(chunks[0].content).toBe('x');
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
describe('| chunkTs — import-group', () => {
|
|
28
|
+
it('| should group consecutive imports into a single chunk', () => {
|
|
29
|
+
const code: string = [
|
|
30
|
+
`import { A } from './a';`,
|
|
31
|
+
`import { B } from './b';`,
|
|
32
|
+
`import * as c from './c';`,
|
|
33
|
+
``,
|
|
34
|
+
`export const value: number = 1;`,
|
|
35
|
+
].join('\n');
|
|
36
|
+
|
|
37
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
38
|
+
const importChunks: DyNTS_DAI_CodeChunk[] = chunks.filter((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'imports');
|
|
39
|
+
|
|
40
|
+
expect(importChunks.length).toBe(1);
|
|
41
|
+
expect(importChunks[0].content).toContain(`from './a'`);
|
|
42
|
+
expect(importChunks[0].content).toContain(`from './b'`);
|
|
43
|
+
expect(importChunks[0].content).toContain(`from './c'`);
|
|
44
|
+
expect(importChunks[0].symbolPath).toBe('');
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
it('| should treat re-export (export ... from) as part of the import group', () => {
|
|
48
|
+
const code: string = [
|
|
49
|
+
`import { A } from './a';`,
|
|
50
|
+
`export { B } from './b';`,
|
|
51
|
+
``,
|
|
52
|
+
`function helper(): void {}`,
|
|
53
|
+
].join('\n');
|
|
54
|
+
|
|
55
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
56
|
+
const importChunks: DyNTS_DAI_CodeChunk[] = chunks.filter((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'imports');
|
|
57
|
+
|
|
58
|
+
expect(importChunks.length).toBe(1);
|
|
59
|
+
expect(importChunks[0].content).toContain(`export { B } from './b'`);
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
describe('| chunkTs — top-level declarations', () => {
|
|
64
|
+
it('| should chunk an interface', () => {
|
|
65
|
+
const code: string = `export interface FooParams {\n a: string;\n b: number;\n}`;
|
|
66
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
67
|
+
|
|
68
|
+
const iface: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'interface');
|
|
69
|
+
expect(iface).toBeDefined();
|
|
70
|
+
expect(iface!.symbolName).toBe('FooParams');
|
|
71
|
+
expect(iface!.symbolPath).toBe('interface:FooParams');
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
it('| should chunk an enum', () => {
|
|
75
|
+
const code: string = `export enum Color {\n red = 'red',\n green = 'green',\n}`;
|
|
76
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
77
|
+
|
|
78
|
+
const en: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'enum');
|
|
79
|
+
expect(en).toBeDefined();
|
|
80
|
+
expect(en!.symbolPath).toBe('enum:Color');
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
it('| should chunk a type-alias', () => {
|
|
84
|
+
const code: string = `export type Id = string | number;`;
|
|
85
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
86
|
+
|
|
87
|
+
const typeChunk: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'type');
|
|
88
|
+
expect(typeChunk).toBeDefined();
|
|
89
|
+
expect(typeChunk!.symbolPath).toBe('type:Id');
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
it('| should chunk a standalone function', () => {
|
|
93
|
+
const code: string = `export function doThing(x: number): number {\n return x + 1;\n}`;
|
|
94
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
95
|
+
|
|
96
|
+
const fn: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'function');
|
|
97
|
+
expect(fn).toBeDefined();
|
|
98
|
+
expect(fn!.symbolPath).toBe('function:doThing');
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
it('| should classify an arrow-const as a function chunk', () => {
|
|
102
|
+
const code: string = `export const adder = (a: number, b: number): number => {\n return a + b;\n};`;
|
|
103
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
104
|
+
|
|
105
|
+
const fn: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'adder');
|
|
106
|
+
expect(fn).toBeDefined();
|
|
107
|
+
expect(fn!.chunkType).toBe('function');
|
|
108
|
+
expect(fn!.symbolPath).toBe('function:adder');
|
|
109
|
+
});
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
describe('| chunkTs — class (whole vs method-split)', () => {
|
|
113
|
+
it('| should keep a small class as a single chunk', () => {
|
|
114
|
+
const code: string = [
|
|
115
|
+
`export class Small {`,
|
|
116
|
+
` greet(): string { return 'hi'; }`,
|
|
117
|
+
`}`,
|
|
118
|
+
].join('\n');
|
|
119
|
+
|
|
120
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
121
|
+
const classChunks: DyNTS_DAI_CodeChunk[] = chunks.filter((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'class');
|
|
122
|
+
|
|
123
|
+
// Egyetlen, egész-osztály chunk (nincs metódus-bontás kis méretnél).
|
|
124
|
+
expect(classChunks.length).toBe(1);
|
|
125
|
+
expect(classChunks[0].symbolPath).toBe('class:Small');
|
|
126
|
+
expect(classChunks[0].content).toContain('greet');
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
it('| should split a large class by methods with class:Foo > method:bar symbolPaths', () => {
|
|
130
|
+
// Minden metódus body-ja kellően nagy, hogy az osztály a maxChunkSize fölé nőjön.
|
|
131
|
+
const body: string = ` const v = ${'1 + '.repeat(60)}1;\n return v;`;
|
|
132
|
+
const code: string = [
|
|
133
|
+
`export class BigService {`,
|
|
134
|
+
` alpha(): number {\n${body}\n }`,
|
|
135
|
+
` beta(): number {\n${body}\n }`,
|
|
136
|
+
` gamma(): number {\n${body}\n }`,
|
|
137
|
+
`}`,
|
|
138
|
+
].join('\n');
|
|
139
|
+
|
|
140
|
+
// maxChunkSize=400: minden metódus (~292) belefér egy chunkba, de az egész osztály (~911)
|
|
141
|
+
// NEM → pontosan osztály-fej + 3 metódus-chunk.
|
|
142
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code, { maxChunkSize: 400 });
|
|
143
|
+
|
|
144
|
+
const methodChunks: DyNTS_DAI_CodeChunk[] = chunks.filter((c: DyNTS_DAI_CodeChunk) => c.chunkType === 'method');
|
|
145
|
+
const methodPaths: string[] = methodChunks.map((c: DyNTS_DAI_CodeChunk) => c.symbolPath);
|
|
146
|
+
|
|
147
|
+
expect(methodChunks.length).toBe(3);
|
|
148
|
+
expect(methodPaths).toContain('class:BigService > method:alpha');
|
|
149
|
+
expect(methodPaths).toContain('class:BigService > method:beta');
|
|
150
|
+
expect(methodPaths).toContain('class:BigService > method:gamma');
|
|
151
|
+
|
|
152
|
+
// Az osztály-fej külön chunk, class:BigService symbol-lánccal.
|
|
153
|
+
const classHeader: DyNTS_DAI_CodeChunk | undefined = chunks.find(
|
|
154
|
+
(c: DyNTS_DAI_CodeChunk) => c.chunkType === 'class' && c.symbolPath === 'class:BigService'
|
|
155
|
+
);
|
|
156
|
+
expect(classHeader).toBeDefined();
|
|
157
|
+
});
|
|
158
|
+
});
|
|
159
|
+
|
|
160
|
+
describe('| chunkTs — JSDoc + decorator bundling', () => {
|
|
161
|
+
it('| should bundle a leading JSDoc with the following node', () => {
|
|
162
|
+
const code: string = [
|
|
163
|
+
`/**`,
|
|
164
|
+
` * Helper function docs.`,
|
|
165
|
+
` */`,
|
|
166
|
+
`export function withDocs(): void {}`,
|
|
167
|
+
].join('\n');
|
|
168
|
+
|
|
169
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
170
|
+
const fn: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'withDocs');
|
|
171
|
+
|
|
172
|
+
expect(fn).toBeDefined();
|
|
173
|
+
expect(fn!.content).toContain('Helper function docs.');
|
|
174
|
+
expect(fn!.content).toContain('export function withDocs');
|
|
175
|
+
});
|
|
176
|
+
|
|
177
|
+
it('| should bundle decorators with the following class node', () => {
|
|
178
|
+
const code: string = [
|
|
179
|
+
`@Injectable()`,
|
|
180
|
+
`@Logged`,
|
|
181
|
+
`export class Decorated {`,
|
|
182
|
+
` run(): void {}`,
|
|
183
|
+
`}`,
|
|
184
|
+
].join('\n');
|
|
185
|
+
|
|
186
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
187
|
+
const cls: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'Decorated');
|
|
188
|
+
|
|
189
|
+
expect(cls).toBeDefined();
|
|
190
|
+
expect(cls!.content).toContain('@Injectable()');
|
|
191
|
+
expect(cls!.content).toContain('@Logged');
|
|
192
|
+
});
|
|
193
|
+
});
|
|
194
|
+
|
|
195
|
+
describe('| chunkTs — large-node sliding-split', () => {
|
|
196
|
+
it('| should sliding-split a single oversized function into sub-chunks', () => {
|
|
197
|
+
const longBody: string = Array.from({ length: 80 }, (_: unknown, i: number) => ` const x${i} = ${i};`).join('\n');
|
|
198
|
+
const code: string = `export function huge(): void {\n${longBody}\n}`;
|
|
199
|
+
|
|
200
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code, { maxChunkSize: 300, overlap: 50 });
|
|
201
|
+
|
|
202
|
+
// Több sub-chunk, mind ugyanazzal a symbol-lánccal + subChunkIndex-szel.
|
|
203
|
+
expect(chunks.length).toBeGreaterThan(1);
|
|
204
|
+
chunks.forEach((c: DyNTS_DAI_CodeChunk) => {
|
|
205
|
+
expect(c.symbolPath).toBe('function:huge');
|
|
206
|
+
expect(c.subChunkIndex).toBeGreaterThanOrEqual(0);
|
|
207
|
+
expect(c.content.length).toBeLessThanOrEqual(300);
|
|
208
|
+
});
|
|
209
|
+
// A sub-chunk-indexek 0-tól folytonosak.
|
|
210
|
+
expect(chunks[0].subChunkIndex).toBe(0);
|
|
211
|
+
});
|
|
212
|
+
});
|
|
213
|
+
|
|
214
|
+
describe('| chunkTs — positions', () => {
|
|
215
|
+
it('| should report 1-based source line numbers', () => {
|
|
216
|
+
const code: string = [
|
|
217
|
+
`import { A } from './a';`, // line 1
|
|
218
|
+
``, // line 2
|
|
219
|
+
`export function f(): void {`, // line 3
|
|
220
|
+
` return;`, // line 4
|
|
221
|
+
`}`, // line 5
|
|
222
|
+
].join('\n');
|
|
223
|
+
|
|
224
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
225
|
+
const fn: DyNTS_DAI_CodeChunk | undefined = chunks.find((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'f');
|
|
226
|
+
|
|
227
|
+
expect(fn).toBeDefined();
|
|
228
|
+
expect(fn!.lineStart).toBe(3);
|
|
229
|
+
expect(fn!.lineEnd).toBe(5);
|
|
230
|
+
});
|
|
231
|
+
|
|
232
|
+
it('| should assign contiguous 0-based chunkIndex values', () => {
|
|
233
|
+
const code: string = [
|
|
234
|
+
`import { A } from './a';`,
|
|
235
|
+
`export interface I { x: number; }`,
|
|
236
|
+
`export type T = string;`,
|
|
237
|
+
`export function fn(): void {}`,
|
|
238
|
+
].join('\n');
|
|
239
|
+
|
|
240
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
241
|
+
chunks.forEach((c: DyNTS_DAI_CodeChunk, i: number) => {
|
|
242
|
+
expect(c.chunkIndex).toBe(i);
|
|
243
|
+
});
|
|
244
|
+
});
|
|
245
|
+
});
|
|
246
|
+
|
|
247
|
+
describe('| chunk — dispatcher routing', () => {
|
|
248
|
+
it('| should route .ts files through the AST chunker', () => {
|
|
249
|
+
const code: string = `export class Routed {\n go(): void {}\n}`;
|
|
250
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunk(code, 'foo.ts');
|
|
251
|
+
|
|
252
|
+
expect(chunks.some((c: DyNTS_DAI_CodeChunk) => c.symbolPath === 'class:Routed')).toBe(true);
|
|
253
|
+
});
|
|
254
|
+
|
|
255
|
+
it('| should route .tsx/.js/.jsx files through the AST chunker', () => {
|
|
256
|
+
const code: string = `export function widget(): void {}`;
|
|
257
|
+
expect(DyNTS_DAI_CodeChunking_Util.chunk(code, 'a.tsx').some((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'widget')).toBe(true);
|
|
258
|
+
expect(DyNTS_DAI_CodeChunking_Util.chunk(code, 'b.js').some((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'widget')).toBe(true);
|
|
259
|
+
expect(DyNTS_DAI_CodeChunking_Util.chunk(code, 'c.jsx').some((c: DyNTS_DAI_CodeChunk) => c.symbolName === 'widget')).toBe(true);
|
|
260
|
+
});
|
|
261
|
+
|
|
262
|
+
it('| should route non-code (.md) content to fallback chunks (no semantic split)', () => {
|
|
263
|
+
const content: string = `# Title\n\nSome markdown text.`;
|
|
264
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunk(content, 'readme.md');
|
|
265
|
+
|
|
266
|
+
expect(chunks.length).toBe(1);
|
|
267
|
+
expect(chunks[0].chunkType).toBe('fallback');
|
|
268
|
+
expect(chunks[0].content).toContain('# Title');
|
|
269
|
+
});
|
|
270
|
+
|
|
271
|
+
it('| should return empty for empty non-code content', () => {
|
|
272
|
+
expect(DyNTS_DAI_CodeChunking_Util.chunk('', 'readme.md')).toEqual([]);
|
|
273
|
+
});
|
|
274
|
+
});
|
|
275
|
+
|
|
276
|
+
describe('| chunkTs — robustness (braces inside strings/templates)', () => {
|
|
277
|
+
it('| should not be confused by braces inside string and template literals (AST-correct)', () => {
|
|
278
|
+
// A FAM regex/brace-depth workaround itt tévedne; az AST helyesen kezeli.
|
|
279
|
+
const code: string = [
|
|
280
|
+
`export function tricky(): string {`,
|
|
281
|
+
' const a = "} not a real close {";',
|
|
282
|
+
' const b = `template ${ a } with } braces {`;',
|
|
283
|
+
` return a + b;`,
|
|
284
|
+
`}`,
|
|
285
|
+
`export interface AfterTricky { ok: boolean; }`,
|
|
286
|
+
].join('\n');
|
|
287
|
+
|
|
288
|
+
const chunks: DyNTS_DAI_CodeChunk[] = DyNTS_DAI_CodeChunking_Util.chunkTs(code);
|
|
289
|
+
|
|
290
|
+
// A függvény ÉS az utána jövő interface is külön, helyes chunk (nem olvad össze).
|
|
291
|
+
expect(chunks.some((c: DyNTS_DAI_CodeChunk) => c.symbolPath === 'function:tricky')).toBe(true);
|
|
292
|
+
expect(chunks.some((c: DyNTS_DAI_CodeChunk) => c.symbolPath === 'interface:AfterTricky')).toBe(true);
|
|
293
|
+
});
|
|
294
|
+
});
|
|
295
|
+
});
|