@futdevpro/nts-dynamo 1.15.41 → 1.15.43
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/.dynamo/logs/cicd-pipeline/output.log +2596 -0
- package/.dynamo/logs/cicd-pipeline/status.json +321 -0
- package/.github/workflows/main.yml +432 -432
- 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/_specifications/BACKLOG.md +92 -92
- package/_specifications/TODO.md +15 -15
- package/_specifications/agent.md +138 -138
- package/build/_models/control-models/endpoint-params.control-model.d.ts.map +1 -1
- package/build/_models/control-models/endpoint-params.control-model.js +20 -4
- package/build/_models/control-models/endpoint-params.control-model.js.map +1 -1
- package/eslint.config.js +3 -3
- package/nodemon.json +24 -24
- package/package.json +2 -2
- package/pnpm-workspace.yaml +8 -8
- 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/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 +578 -578
- package/src/_models/control-models/endpoint-params.control-model.ts +542 -526
- 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 +144 -144
- package/src/_models/interfaces/global-service-settings.interface.ts +47 -47
- 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-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-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 +28 -28
- 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.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/index.ts +13 -13
- 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/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/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-vector-pool.control-service.spec.ts +393 -393
- package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.ts +220 -220
- package/src/_modules/local-vector-search/index.ts +11 -11
- 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/server/errors/errors.control-service.spec.ts +238 -238
- package/src/_modules/server/errors/errors.control-service.ts +85 -85
- package/src/_modules/server/errors/errors.controller.spec.ts +241 -241
- package/src/_modules/server/errors/errors.controller.ts +431 -431
- package/src/_modules/server/errors/errors.data-service.spec.ts +355 -355
- 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 +524 -524
- package/src/_modules/server/server-status/server-status.control-service.ts +336 -336
- package/src/_modules/server/server-status/server-status.controller.spec.ts +162 -162
- package/src/_modules/server/server-status/server-status.controller.ts +131 -131
- 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 +196 -196
- package/src/_services/base/archive-data.service.ts +216 -216
- package/src/_services/base/data.service.spec.ts +674 -674
- package/src/_services/base/data.service.ts +2719 -2719
- 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 +275 -275
- package/src/_services/core/global.service.ts +461 -461
- 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/shared.static-service.spec.ts +99 -99
- package/src/_services/shared.static-service.ts +78 -78
- package/src/index.ts +95 -95
- package/tsconfig.app.json +12 -12
- package/tsconfig.json +42 -42
|
@@ -1,264 +1,264 @@
|
|
|
1
|
-
|
|
2
|
-
import { DyNTS_DiBo_IO_ControlService } from './dibo-io.control-service';
|
|
3
|
-
import { DyNTS_DiBo_Main_ControlService } from './dibo-main.control-service';
|
|
4
|
-
import { DyNTS_DiBo_Commands_ControlService } from './dibo-commands.control-service';
|
|
5
|
-
import { Message, TextChannel, Guild } from 'discord.js';
|
|
6
|
-
import { DyFM_Error } from '@futdevpro/fsm-dynamo';
|
|
7
|
-
import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
|
|
8
|
-
import { DyNTS_DiBo_global_settings } from '../_collections/dibo-global-settings.conts';
|
|
9
|
-
import { DyFM_EnvironmentFlag } from '@futdevpro/fsm-dynamo';
|
|
10
|
-
|
|
11
|
-
class TestDiBoIOService extends DyNTS_DiBo_IO_ControlService {
|
|
12
|
-
protected override mainDiscordBot_CS: any;
|
|
13
|
-
|
|
14
|
-
protected override getMainDiscordBotControlService(): DyNTS_DiBo_Main_ControlService {
|
|
15
|
-
return this.mainDiscordBot_CS;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
protected override getCommandsControlService(): DyNTS_DiBo_Commands_ControlService {
|
|
19
|
-
return this.commands_CS;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
async handleMessage(message: Message, issuer: string): Promise<Message> {
|
|
23
|
-
return message;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
static getInstance(): TestDiBoIOService {
|
|
27
|
-
return TestDiBoIOService.getSingletonInstance();
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
xdescribe('| DyNTS_DiBo_IO_ControlService', () => {
|
|
32
|
-
let service: TestDiBoIOService;
|
|
33
|
-
let mockMain_CS: jasmine.SpyObj<DyNTS_DiBo_Main_ControlService>;
|
|
34
|
-
let mockCommands_CS: jasmine.SpyObj<DyNTS_DiBo_Commands_ControlService>;
|
|
35
|
-
let mockGuild: jasmine.SpyObj<Guild>;
|
|
36
|
-
let mockMessage: jasmine.SpyObj<Message>;
|
|
37
|
-
let mockTextChannel: jasmine.SpyObj<TextChannel>;
|
|
38
|
-
|
|
39
|
-
beforeAll(() => {
|
|
40
|
-
if (!DyNTS_global_settings.systemShortCodeName) {
|
|
41
|
-
(DyNTS_global_settings as { systemShortCodeName?: string }).systemShortCodeName = 'TEST';
|
|
42
|
-
}
|
|
43
|
-
if (!DyNTS_global_settings.env_settings) {
|
|
44
|
-
(DyNTS_global_settings as { env_settings?: unknown }).env_settings = { environment: DyFM_EnvironmentFlag.local };
|
|
45
|
-
}
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
beforeEach(() => {
|
|
49
|
-
mockGuild = jasmine.createSpyObj('Guild', [], {
|
|
50
|
-
id: 'guild-123',
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
mockTextChannel = jasmine.createSpyObj('TextChannel', ['send'], {
|
|
54
|
-
id: 'channel-123',
|
|
55
|
-
name: 'test-channel',
|
|
56
|
-
isTextBased: () => true,
|
|
57
|
-
isDMBased: () => false,
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
mockMessage = jasmine.createSpyObj('Message', ['reply']);
|
|
61
|
-
// Set properties as writable/configurable so they can be modified in tests
|
|
62
|
-
Object.defineProperties(mockMessage, {
|
|
63
|
-
id: { value: 'message-123', writable: true, configurable: true },
|
|
64
|
-
content: { value: 'Test message', writable: true, configurable: true },
|
|
65
|
-
author: {
|
|
66
|
-
value: {
|
|
67
|
-
id: 'user-123',
|
|
68
|
-
username: 'test-user',
|
|
69
|
-
displayName: 'Test User',
|
|
70
|
-
bot: false,
|
|
71
|
-
},
|
|
72
|
-
writable: true,
|
|
73
|
-
configurable: true
|
|
74
|
-
},
|
|
75
|
-
channel: { value: mockTextChannel, writable: true, configurable: true },
|
|
76
|
-
reference: { value: null, writable: true, configurable: true },
|
|
77
|
-
cleanContent: { value: 'Test message', writable: true, configurable: true },
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
mockMain_CS = jasmine.createSpyObj('DyNTS_DiBo_Main_ControlService', [], {
|
|
81
|
-
discordServer: mockGuild,
|
|
82
|
-
botClientId: 'bot-123',
|
|
83
|
-
botDisplayName: 'Test Bot',
|
|
84
|
-
client: {
|
|
85
|
-
user: {
|
|
86
|
-
id: 'bot-123',
|
|
87
|
-
},
|
|
88
|
-
},
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
mockCommands_CS = jasmine.createSpyObj('DyNTS_DiBo_Commands_ControlService', ['handleCommand']);
|
|
92
|
-
|
|
93
|
-
service = new (TestDiBoIOService as any)();
|
|
94
|
-
(service as any).mainDiscordBot_CS = mockMain_CS;
|
|
95
|
-
(service as any).commands_CS = mockCommands_CS;
|
|
96
|
-
});
|
|
97
|
-
|
|
98
|
-
describe('| properties', () => {
|
|
99
|
-
it('| should return discordServer from main service', () => {
|
|
100
|
-
expect(service.discordServer).toBe(mockGuild);
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
it('| should return botClientId from main service', () => {
|
|
104
|
-
expect(service.botClientId).toBe('bot-123');
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
it('| should return botDisplayName from main service', () => {
|
|
108
|
-
expect(service.botDisplayName).toBe('Test Bot');
|
|
109
|
-
});
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
describe('| setup', () => {
|
|
113
|
-
it('| should setup service with main and commands services', async () => {
|
|
114
|
-
await service.setup('test-issuer');
|
|
115
|
-
|
|
116
|
-
expect((service as any).mainDiscordBot_CS).toBe(mockMain_CS);
|
|
117
|
-
expect((service as any).commands_CS).toBe(mockCommands_CS);
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
it('| should throw error if main service not found', async () => {
|
|
121
|
-
(service as any).getMainDiscordBotControlService = () => null;
|
|
122
|
-
|
|
123
|
-
try {
|
|
124
|
-
await service.setup('test-issuer');
|
|
125
|
-
fail('Should have thrown an error');
|
|
126
|
-
} catch (error) {
|
|
127
|
-
expect(error).toBeInstanceOf(DyFM_Error);
|
|
128
|
-
expect((error as DyFM_Error)._errorCode).toContain('DyNTS-DiBo-IO-S01');
|
|
129
|
-
}
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
it('| should throw error if commands service not found', async () => {
|
|
133
|
-
(service as any).getCommandsControlService = () => null;
|
|
134
|
-
|
|
135
|
-
try {
|
|
136
|
-
await service.setup('test-issuer');
|
|
137
|
-
fail('Should have thrown an error');
|
|
138
|
-
} catch (error) {
|
|
139
|
-
expect(error).toBeInstanceOf(DyFM_Error);
|
|
140
|
-
expect((error as DyFM_Error)._errorCode).toContain('DyNTS-DiBo-IO-S02');
|
|
141
|
-
}
|
|
142
|
-
});
|
|
143
|
-
});
|
|
144
|
-
|
|
145
|
-
describe('| start', () => {
|
|
146
|
-
it('| should start service successfully', async () => {
|
|
147
|
-
await service.start('test-issuer');
|
|
148
|
-
|
|
149
|
-
expect(service.discordServer).toBe(mockGuild);
|
|
150
|
-
});
|
|
151
|
-
|
|
152
|
-
it('| should throw error if discordServer not found', async () => {
|
|
153
|
-
(service as any).mainDiscordBot_CS = null;
|
|
154
|
-
|
|
155
|
-
try {
|
|
156
|
-
await service.start('test-issuer');
|
|
157
|
-
fail('Should have thrown an error');
|
|
158
|
-
} catch (error) {
|
|
159
|
-
expect(error).toBeInstanceOf(DyFM_Error);
|
|
160
|
-
expect((error as DyFM_Error)._errorCode).toContain('DyNTS-DiBo-IO-ST00');
|
|
161
|
-
}
|
|
162
|
-
});
|
|
163
|
-
});
|
|
164
|
-
|
|
165
|
-
describe('| handleNewMessage', () => {
|
|
166
|
-
it('| should handle message if for bot', async () => {
|
|
167
|
-
spyOn(service, 'getMessageIsForBotToHandle').and.returnValue(Promise.resolve(true));
|
|
168
|
-
spyOn(service, 'handleIfCommand').and.returnValue(Promise.resolve(false));
|
|
169
|
-
spyOn(service, 'handleMessage').and.returnValue(Promise.resolve(mockMessage));
|
|
170
|
-
|
|
171
|
-
await service.handleNewMessage(mockMessage, 'test-issuer');
|
|
172
|
-
|
|
173
|
-
expect(service.handleMessage).toHaveBeenCalled();
|
|
174
|
-
});
|
|
175
|
-
|
|
176
|
-
it('| should not handle message if not for bot', async () => {
|
|
177
|
-
spyOn(service, 'getMessageIsForBotToHandle').and.returnValue(Promise.resolve(false));
|
|
178
|
-
spyOn(service, 'handleMessage');
|
|
179
|
-
|
|
180
|
-
await service.handleNewMessage(mockMessage, 'test-issuer');
|
|
181
|
-
|
|
182
|
-
expect(service.handleMessage).not.toHaveBeenCalled();
|
|
183
|
-
});
|
|
184
|
-
|
|
185
|
-
it('| should handle command if message is command', async () => {
|
|
186
|
-
spyOn(service, 'getMessageIsForBotToHandle').and.returnValue(Promise.resolve(true));
|
|
187
|
-
const handleIfCommandSpy = spyOn(service, 'handleIfCommand').and.returnValue(Promise.resolve(true));
|
|
188
|
-
spyOn(service, 'handleMessage');
|
|
189
|
-
|
|
190
|
-
await service.handleNewMessage(mockMessage, 'test-issuer');
|
|
191
|
-
|
|
192
|
-
expect(service.handleMessage).not.toHaveBeenCalled();
|
|
193
|
-
// Since handleIfCommand is mocked, we verify it was called, not the underlying handleCommand
|
|
194
|
-
expect(handleIfCommandSpy).toHaveBeenCalled();
|
|
195
|
-
});
|
|
196
|
-
|
|
197
|
-
it('| should handle errors gracefully', async () => {
|
|
198
|
-
const error = new Error('Test error');
|
|
199
|
-
spyOn(service, 'getMessageIsForBotToHandle').and.throwError(error);
|
|
200
|
-
mockMessage.reply.and.returnValue(Promise.resolve(mockMessage as any));
|
|
201
|
-
|
|
202
|
-
try {
|
|
203
|
-
await service.handleNewMessage(mockMessage, 'test-issuer');
|
|
204
|
-
fail('Should have thrown an error');
|
|
205
|
-
} catch (err) {
|
|
206
|
-
expect(err).toBeInstanceOf(DyFM_Error);
|
|
207
|
-
}
|
|
208
|
-
});
|
|
209
|
-
});
|
|
210
|
-
|
|
211
|
-
describe('| handleIfCommand', () => {
|
|
212
|
-
it('| should handle command if message is command', async () => {
|
|
213
|
-
spyOn(service, 'isCommand').and.returnValue(Promise.resolve(true));
|
|
214
|
-
mockCommands_CS.handleCommand.and.returnValue(Promise.resolve());
|
|
215
|
-
|
|
216
|
-
const result = await service.handleIfCommand(mockMessage, 'test-issuer');
|
|
217
|
-
|
|
218
|
-
expect(result).toBe(true);
|
|
219
|
-
expect(mockCommands_CS.handleCommand).toHaveBeenCalled();
|
|
220
|
-
});
|
|
221
|
-
|
|
222
|
-
it('| should not handle if message is not command', async () => {
|
|
223
|
-
spyOn(service, 'isCommand').and.returnValue(Promise.resolve(false));
|
|
224
|
-
|
|
225
|
-
const result = await service.handleIfCommand(mockMessage, 'test-issuer');
|
|
226
|
-
|
|
227
|
-
expect(result).toBe(false);
|
|
228
|
-
expect(mockCommands_CS.handleCommand).not.toHaveBeenCalled();
|
|
229
|
-
});
|
|
230
|
-
});
|
|
231
|
-
|
|
232
|
-
describe('| isCommand', () => {
|
|
233
|
-
it('| should return true if message starts with command operator', async () => {
|
|
234
|
-
mockMessage.content = '!test command';
|
|
235
|
-
const originalCommandSettings = DyNTS_DiBo_global_settings.commandSettings;
|
|
236
|
-
(DyNTS_DiBo_global_settings as any).commandSettings = {
|
|
237
|
-
commandOperator: '!',
|
|
238
|
-
commands: [{ command: 'test' }],
|
|
239
|
-
};
|
|
240
|
-
|
|
241
|
-
const result = await service.isCommand(mockMessage, 'test-issuer');
|
|
242
|
-
|
|
243
|
-
expect(result).toBe(true);
|
|
244
|
-
|
|
245
|
-
(DyNTS_DiBo_global_settings as any).commandSettings = originalCommandSettings;
|
|
246
|
-
});
|
|
247
|
-
|
|
248
|
-
it('| should return false if message does not start with command operator', async () => {
|
|
249
|
-
mockMessage.content = 'test command';
|
|
250
|
-
const originalCommandSettings = DyNTS_DiBo_global_settings.commandSettings;
|
|
251
|
-
(DyNTS_DiBo_global_settings as any).commandSettings = {
|
|
252
|
-
commandOperator: '!',
|
|
253
|
-
commands: [{ command: 'test' }],
|
|
254
|
-
};
|
|
255
|
-
|
|
256
|
-
const result = await service.isCommand(mockMessage, 'test-issuer');
|
|
257
|
-
|
|
258
|
-
expect(result).toBe(false);
|
|
259
|
-
|
|
260
|
-
(DyNTS_DiBo_global_settings as any).commandSettings = originalCommandSettings;
|
|
261
|
-
});
|
|
262
|
-
});
|
|
263
|
-
});
|
|
264
|
-
|
|
1
|
+
|
|
2
|
+
import { DyNTS_DiBo_IO_ControlService } from './dibo-io.control-service';
|
|
3
|
+
import { DyNTS_DiBo_Main_ControlService } from './dibo-main.control-service';
|
|
4
|
+
import { DyNTS_DiBo_Commands_ControlService } from './dibo-commands.control-service';
|
|
5
|
+
import { Message, TextChannel, Guild } from 'discord.js';
|
|
6
|
+
import { DyFM_Error } from '@futdevpro/fsm-dynamo';
|
|
7
|
+
import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
|
|
8
|
+
import { DyNTS_DiBo_global_settings } from '../_collections/dibo-global-settings.conts';
|
|
9
|
+
import { DyFM_EnvironmentFlag } from '@futdevpro/fsm-dynamo';
|
|
10
|
+
|
|
11
|
+
class TestDiBoIOService extends DyNTS_DiBo_IO_ControlService {
|
|
12
|
+
protected override mainDiscordBot_CS: any;
|
|
13
|
+
|
|
14
|
+
protected override getMainDiscordBotControlService(): DyNTS_DiBo_Main_ControlService {
|
|
15
|
+
return this.mainDiscordBot_CS;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
protected override getCommandsControlService(): DyNTS_DiBo_Commands_ControlService {
|
|
19
|
+
return this.commands_CS;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
async handleMessage(message: Message, issuer: string): Promise<Message> {
|
|
23
|
+
return message;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
static getInstance(): TestDiBoIOService {
|
|
27
|
+
return TestDiBoIOService.getSingletonInstance();
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
xdescribe('| DyNTS_DiBo_IO_ControlService', () => {
|
|
32
|
+
let service: TestDiBoIOService;
|
|
33
|
+
let mockMain_CS: jasmine.SpyObj<DyNTS_DiBo_Main_ControlService>;
|
|
34
|
+
let mockCommands_CS: jasmine.SpyObj<DyNTS_DiBo_Commands_ControlService>;
|
|
35
|
+
let mockGuild: jasmine.SpyObj<Guild>;
|
|
36
|
+
let mockMessage: jasmine.SpyObj<Message>;
|
|
37
|
+
let mockTextChannel: jasmine.SpyObj<TextChannel>;
|
|
38
|
+
|
|
39
|
+
beforeAll(() => {
|
|
40
|
+
if (!DyNTS_global_settings.systemShortCodeName) {
|
|
41
|
+
(DyNTS_global_settings as { systemShortCodeName?: string }).systemShortCodeName = 'TEST';
|
|
42
|
+
}
|
|
43
|
+
if (!DyNTS_global_settings.env_settings) {
|
|
44
|
+
(DyNTS_global_settings as { env_settings?: unknown }).env_settings = { environment: DyFM_EnvironmentFlag.local };
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
beforeEach(() => {
|
|
49
|
+
mockGuild = jasmine.createSpyObj('Guild', [], {
|
|
50
|
+
id: 'guild-123',
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
mockTextChannel = jasmine.createSpyObj('TextChannel', ['send'], {
|
|
54
|
+
id: 'channel-123',
|
|
55
|
+
name: 'test-channel',
|
|
56
|
+
isTextBased: () => true,
|
|
57
|
+
isDMBased: () => false,
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
mockMessage = jasmine.createSpyObj('Message', ['reply']);
|
|
61
|
+
// Set properties as writable/configurable so they can be modified in tests
|
|
62
|
+
Object.defineProperties(mockMessage, {
|
|
63
|
+
id: { value: 'message-123', writable: true, configurable: true },
|
|
64
|
+
content: { value: 'Test message', writable: true, configurable: true },
|
|
65
|
+
author: {
|
|
66
|
+
value: {
|
|
67
|
+
id: 'user-123',
|
|
68
|
+
username: 'test-user',
|
|
69
|
+
displayName: 'Test User',
|
|
70
|
+
bot: false,
|
|
71
|
+
},
|
|
72
|
+
writable: true,
|
|
73
|
+
configurable: true
|
|
74
|
+
},
|
|
75
|
+
channel: { value: mockTextChannel, writable: true, configurable: true },
|
|
76
|
+
reference: { value: null, writable: true, configurable: true },
|
|
77
|
+
cleanContent: { value: 'Test message', writable: true, configurable: true },
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
mockMain_CS = jasmine.createSpyObj('DyNTS_DiBo_Main_ControlService', [], {
|
|
81
|
+
discordServer: mockGuild,
|
|
82
|
+
botClientId: 'bot-123',
|
|
83
|
+
botDisplayName: 'Test Bot',
|
|
84
|
+
client: {
|
|
85
|
+
user: {
|
|
86
|
+
id: 'bot-123',
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
mockCommands_CS = jasmine.createSpyObj('DyNTS_DiBo_Commands_ControlService', ['handleCommand']);
|
|
92
|
+
|
|
93
|
+
service = new (TestDiBoIOService as any)();
|
|
94
|
+
(service as any).mainDiscordBot_CS = mockMain_CS;
|
|
95
|
+
(service as any).commands_CS = mockCommands_CS;
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
describe('| properties', () => {
|
|
99
|
+
it('| should return discordServer from main service', () => {
|
|
100
|
+
expect(service.discordServer).toBe(mockGuild);
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
it('| should return botClientId from main service', () => {
|
|
104
|
+
expect(service.botClientId).toBe('bot-123');
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
it('| should return botDisplayName from main service', () => {
|
|
108
|
+
expect(service.botDisplayName).toBe('Test Bot');
|
|
109
|
+
});
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
describe('| setup', () => {
|
|
113
|
+
it('| should setup service with main and commands services', async () => {
|
|
114
|
+
await service.setup('test-issuer');
|
|
115
|
+
|
|
116
|
+
expect((service as any).mainDiscordBot_CS).toBe(mockMain_CS);
|
|
117
|
+
expect((service as any).commands_CS).toBe(mockCommands_CS);
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
it('| should throw error if main service not found', async () => {
|
|
121
|
+
(service as any).getMainDiscordBotControlService = () => null;
|
|
122
|
+
|
|
123
|
+
try {
|
|
124
|
+
await service.setup('test-issuer');
|
|
125
|
+
fail('Should have thrown an error');
|
|
126
|
+
} catch (error) {
|
|
127
|
+
expect(error).toBeInstanceOf(DyFM_Error);
|
|
128
|
+
expect((error as DyFM_Error)._errorCode).toContain('DyNTS-DiBo-IO-S01');
|
|
129
|
+
}
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
it('| should throw error if commands service not found', async () => {
|
|
133
|
+
(service as any).getCommandsControlService = () => null;
|
|
134
|
+
|
|
135
|
+
try {
|
|
136
|
+
await service.setup('test-issuer');
|
|
137
|
+
fail('Should have thrown an error');
|
|
138
|
+
} catch (error) {
|
|
139
|
+
expect(error).toBeInstanceOf(DyFM_Error);
|
|
140
|
+
expect((error as DyFM_Error)._errorCode).toContain('DyNTS-DiBo-IO-S02');
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
});
|
|
144
|
+
|
|
145
|
+
describe('| start', () => {
|
|
146
|
+
it('| should start service successfully', async () => {
|
|
147
|
+
await service.start('test-issuer');
|
|
148
|
+
|
|
149
|
+
expect(service.discordServer).toBe(mockGuild);
|
|
150
|
+
});
|
|
151
|
+
|
|
152
|
+
it('| should throw error if discordServer not found', async () => {
|
|
153
|
+
(service as any).mainDiscordBot_CS = null;
|
|
154
|
+
|
|
155
|
+
try {
|
|
156
|
+
await service.start('test-issuer');
|
|
157
|
+
fail('Should have thrown an error');
|
|
158
|
+
} catch (error) {
|
|
159
|
+
expect(error).toBeInstanceOf(DyFM_Error);
|
|
160
|
+
expect((error as DyFM_Error)._errorCode).toContain('DyNTS-DiBo-IO-ST00');
|
|
161
|
+
}
|
|
162
|
+
});
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
describe('| handleNewMessage', () => {
|
|
166
|
+
it('| should handle message if for bot', async () => {
|
|
167
|
+
spyOn(service, 'getMessageIsForBotToHandle').and.returnValue(Promise.resolve(true));
|
|
168
|
+
spyOn(service, 'handleIfCommand').and.returnValue(Promise.resolve(false));
|
|
169
|
+
spyOn(service, 'handleMessage').and.returnValue(Promise.resolve(mockMessage));
|
|
170
|
+
|
|
171
|
+
await service.handleNewMessage(mockMessage, 'test-issuer');
|
|
172
|
+
|
|
173
|
+
expect(service.handleMessage).toHaveBeenCalled();
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
it('| should not handle message if not for bot', async () => {
|
|
177
|
+
spyOn(service, 'getMessageIsForBotToHandle').and.returnValue(Promise.resolve(false));
|
|
178
|
+
spyOn(service, 'handleMessage');
|
|
179
|
+
|
|
180
|
+
await service.handleNewMessage(mockMessage, 'test-issuer');
|
|
181
|
+
|
|
182
|
+
expect(service.handleMessage).not.toHaveBeenCalled();
|
|
183
|
+
});
|
|
184
|
+
|
|
185
|
+
it('| should handle command if message is command', async () => {
|
|
186
|
+
spyOn(service, 'getMessageIsForBotToHandle').and.returnValue(Promise.resolve(true));
|
|
187
|
+
const handleIfCommandSpy = spyOn(service, 'handleIfCommand').and.returnValue(Promise.resolve(true));
|
|
188
|
+
spyOn(service, 'handleMessage');
|
|
189
|
+
|
|
190
|
+
await service.handleNewMessage(mockMessage, 'test-issuer');
|
|
191
|
+
|
|
192
|
+
expect(service.handleMessage).not.toHaveBeenCalled();
|
|
193
|
+
// Since handleIfCommand is mocked, we verify it was called, not the underlying handleCommand
|
|
194
|
+
expect(handleIfCommandSpy).toHaveBeenCalled();
|
|
195
|
+
});
|
|
196
|
+
|
|
197
|
+
it('| should handle errors gracefully', async () => {
|
|
198
|
+
const error = new Error('Test error');
|
|
199
|
+
spyOn(service, 'getMessageIsForBotToHandle').and.throwError(error);
|
|
200
|
+
mockMessage.reply.and.returnValue(Promise.resolve(mockMessage as any));
|
|
201
|
+
|
|
202
|
+
try {
|
|
203
|
+
await service.handleNewMessage(mockMessage, 'test-issuer');
|
|
204
|
+
fail('Should have thrown an error');
|
|
205
|
+
} catch (err) {
|
|
206
|
+
expect(err).toBeInstanceOf(DyFM_Error);
|
|
207
|
+
}
|
|
208
|
+
});
|
|
209
|
+
});
|
|
210
|
+
|
|
211
|
+
describe('| handleIfCommand', () => {
|
|
212
|
+
it('| should handle command if message is command', async () => {
|
|
213
|
+
spyOn(service, 'isCommand').and.returnValue(Promise.resolve(true));
|
|
214
|
+
mockCommands_CS.handleCommand.and.returnValue(Promise.resolve());
|
|
215
|
+
|
|
216
|
+
const result = await service.handleIfCommand(mockMessage, 'test-issuer');
|
|
217
|
+
|
|
218
|
+
expect(result).toBe(true);
|
|
219
|
+
expect(mockCommands_CS.handleCommand).toHaveBeenCalled();
|
|
220
|
+
});
|
|
221
|
+
|
|
222
|
+
it('| should not handle if message is not command', async () => {
|
|
223
|
+
spyOn(service, 'isCommand').and.returnValue(Promise.resolve(false));
|
|
224
|
+
|
|
225
|
+
const result = await service.handleIfCommand(mockMessage, 'test-issuer');
|
|
226
|
+
|
|
227
|
+
expect(result).toBe(false);
|
|
228
|
+
expect(mockCommands_CS.handleCommand).not.toHaveBeenCalled();
|
|
229
|
+
});
|
|
230
|
+
});
|
|
231
|
+
|
|
232
|
+
describe('| isCommand', () => {
|
|
233
|
+
it('| should return true if message starts with command operator', async () => {
|
|
234
|
+
mockMessage.content = '!test command';
|
|
235
|
+
const originalCommandSettings = DyNTS_DiBo_global_settings.commandSettings;
|
|
236
|
+
(DyNTS_DiBo_global_settings as any).commandSettings = {
|
|
237
|
+
commandOperator: '!',
|
|
238
|
+
commands: [{ command: 'test' }],
|
|
239
|
+
};
|
|
240
|
+
|
|
241
|
+
const result = await service.isCommand(mockMessage, 'test-issuer');
|
|
242
|
+
|
|
243
|
+
expect(result).toBe(true);
|
|
244
|
+
|
|
245
|
+
(DyNTS_DiBo_global_settings as any).commandSettings = originalCommandSettings;
|
|
246
|
+
});
|
|
247
|
+
|
|
248
|
+
it('| should return false if message does not start with command operator', async () => {
|
|
249
|
+
mockMessage.content = 'test command';
|
|
250
|
+
const originalCommandSettings = DyNTS_DiBo_global_settings.commandSettings;
|
|
251
|
+
(DyNTS_DiBo_global_settings as any).commandSettings = {
|
|
252
|
+
commandOperator: '!',
|
|
253
|
+
commands: [{ command: 'test' }],
|
|
254
|
+
};
|
|
255
|
+
|
|
256
|
+
const result = await service.isCommand(mockMessage, 'test-issuer');
|
|
257
|
+
|
|
258
|
+
expect(result).toBe(false);
|
|
259
|
+
|
|
260
|
+
(DyNTS_DiBo_global_settings as any).commandSettings = originalCommandSettings;
|
|
261
|
+
});
|
|
262
|
+
});
|
|
263
|
+
});
|
|
264
|
+
|