@futdevpro/nts-dynamo 1.15.1 → 1.15.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (233) hide show
  1. package/.cursor/rules/__assistant_guide.mdc +30 -0
  2. package/.cursor/rules/__main.mdc +62 -0
  3. package/.cursor/rules/_ag_backend-structure.mdc +86 -0
  4. package/.cursor/rules/_ag_backend.mdc +16 -0
  5. package/.cursor/rules/_ag_debug.mdc +8 -0
  6. package/.cursor/rules/_ag_documentation_writing_rules.mdc +372 -0
  7. package/.cursor/rules/_ag_file-refactoring.mdc +113 -0
  8. package/.cursor/rules/_ag_fixes_rules.mdc +6 -0
  9. package/.cursor/rules/_ag_frontend-structure.mdc +87 -0
  10. package/.cursor/rules/_ag_frontend.mdc +40 -0
  11. package/.cursor/rules/_ag_import-rules.mdc +45 -0
  12. package/.cursor/rules/_ag_naming.mdc +116 -0
  13. package/.cursor/rules/_ag_running_commands.mdc +5 -0
  14. package/.cursor/rules/_ag_server-controller.mdc +6 -0
  15. package/.cursor/rules/_ag_should-be.mdc +7 -0
  16. package/.cursor/rules/_ag_swearing.mdc +47 -0
  17. package/.cursor/rules/ai_development_guide.md +61 -0
  18. package/.cursor/rules/ai_directives.md +114 -0
  19. package/.cursor/rules/cursor-rules.md +160 -0
  20. package/.cursor/rules/default-command.mdc +229 -0
  21. package/.cursor/rules/error_code_pattern.md +40 -0
  22. package/.cursor/rules/saved rule mcp server use.md +16 -0
  23. package/build/_models/control-models/app-params.control-model.d.ts.map +1 -1
  24. package/build/_models/control-models/app-params.control-model.js +6 -1
  25. package/build/_models/control-models/app-params.control-model.js.map +1 -1
  26. package/build/_modules/custom-data/custom-data.controller.d.ts.map +1 -1
  27. package/build/_modules/custom-data/custom-data.controller.js +1 -2
  28. package/build/_modules/custom-data/custom-data.controller.js.map +1 -1
  29. package/build/_services/core/api.service.d.ts.map +1 -1
  30. package/build/_services/core/api.service.js +1 -0
  31. package/build/_services/core/api.service.js.map +1 -1
  32. package/build/_services/server/app.server.d.ts.map +1 -1
  33. package/build/_services/server/app.server.js +11 -0
  34. package/build/_services/server/app.server.js.map +1 -1
  35. package/package.json +5 -4
  36. package/scripts/run-coverage-tests.js +5 -1
  37. package/spec/support/helpers/spec-reporter-loader.js +359 -0
  38. package/spec/support/helpers/ts-node-helper.js +84 -0
  39. package/spec/support/jasmine.coverage.json +2 -1
  40. package/spec/support/jasmine.json +3 -3
  41. package/src/_collections/archive.util.spec.ts +36 -0
  42. package/src/_collections/get-environment-settings.util.spec.ts +210 -0
  43. package/src/_collections/star.controller.spec.ts +224 -0
  44. package/src/_models/control-models/api-call-params.control-model.spec.ts +62 -3
  45. package/src/_models/control-models/app-ext-system-controls.control-model.spec.ts +52 -0
  46. package/src/_models/control-models/app-params.control-model.spec.ts +158 -2
  47. package/src/_models/control-models/app-params.control-model.ts +8 -2
  48. package/src/_models/control-models/endpoint-params.control-model.spec.ts +578 -0
  49. package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.spec.ts +242 -0
  50. package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.spec.ts +209 -0
  51. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-document.data-service.spec.ts +342 -0
  52. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.spec.ts +550 -0
  53. package/src/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.spec.ts +240 -0
  54. package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.spec.ts +462 -0
  55. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.spec.ts +437 -0
  56. package/src/_modules/ai/_services/ai-embedding.service-base.spec.ts +98 -0
  57. package/src/_modules/ai/_services/ai-llm-chat.service-base.spec.ts +229 -0
  58. package/src/_modules/ai/_services/ai-llm.service-base.spec.ts +250 -0
  59. package/src/_modules/ai/_services/ai-provider.service-base.spec.ts +79 -0
  60. package/src/_modules/assistant/_collections/ass.util.spec.ts +176 -0
  61. package/src/_modules/assistant/_services/ass-io.control-service.spec.ts +140 -0
  62. package/src/_modules/assistant/_services/ass-main.control-service.spec.ts +192 -0
  63. package/src/_modules/bot/_modules/discord-bot/_services/dib-messaging-provider.control-service.spec.ts +431 -0
  64. package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.spec.ts +160 -0
  65. package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.spec.ts +374 -0
  66. package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.spec.ts +344 -0
  67. package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.spec.ts +345 -0
  68. package/src/_modules/bot/_services/bot-commands.control-service.spec.ts +116 -0
  69. package/src/_modules/bot/_services/bot-io.control-service.spec.ts +285 -0
  70. package/src/_modules/bot/_services/bot-main.control-service.spec.ts +208 -0
  71. package/src/_modules/bot/_services/bot-messaging-provider.service-base.spec.ts +349 -0
  72. package/src/_modules/bot/_services/bot-routines.control-service.spec.ts +111 -0
  73. package/src/_modules/custom-data/custom-data.controller.spec.ts +49 -0
  74. package/src/_modules/custom-data/custom-data.controller.ts +1 -3
  75. package/src/_modules/custom-data/custom-data.data-service.spec.ts +54 -0
  76. package/src/_modules/custom-data/get-custom-data-routing-module.util.spec.ts +28 -0
  77. package/src/_modules/defaults/_services/default-auth.service.spec.ts +269 -0
  78. package/src/_modules/defaults/_services/default-socket-events.service.spec.ts +42 -0
  79. package/src/_modules/defaults/_services/default-user.data-service.spec.ts +187 -0
  80. package/src/_modules/discord-assistant/_collections/dias.util.spec.ts +366 -0
  81. package/src/_modules/discord-assistant/_services/dias-io.control-service.spec.ts +108 -0
  82. package/src/_modules/discord-assistant/_services/dias-main.control-service.spec.ts +22 -0
  83. package/src/_modules/discord-assistant/_services/dias.service-base.spec.ts +195 -0
  84. package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.spec.ts +34 -0
  85. package/src/_modules/discord-bot/_collections/dibo-operations.util.spec.ts +214 -0
  86. package/src/_modules/discord-bot/_services/dibo-commands.control-service.spec.ts +154 -0
  87. package/src/_modules/discord-bot/_services/dibo-io.control-service.spec.ts +264 -0
  88. package/src/_modules/discord-bot/_services/dibo-main.control-service.spec.ts +408 -0
  89. package/src/_modules/discord-bot/_services/dibo-routines.control-service.spec.ts +105 -0
  90. package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.spec.ts +418 -0
  91. package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.spec.ts +345 -0
  92. package/src/_modules/messaging/_collections/msg.util.spec.ts +226 -0
  93. package/src/_modules/messaging/_services/msg-events.service.spec.ts +219 -0
  94. package/src/_modules/messaging/_services/msg-main.control-service.spec.ts +147 -0
  95. package/src/_modules/messaging/_services/msg.controller.spec.ts +201 -0
  96. package/src/_modules/mock/data-model.mock.spec.ts +27 -24
  97. package/src/_modules/oauth2/_routes/oauth2.controller.spec.ts +107 -0
  98. package/src/_modules/oauth2/_services/oauth2.auth-service.spec.ts +254 -0
  99. package/src/_modules/oauth2/_services/oauth2.control-service.spec.ts +585 -0
  100. package/src/_modules/server/errors/errors.control-service.spec.ts +230 -0
  101. package/src/_modules/server/errors/errors.controller.spec.ts +165 -0
  102. package/src/_modules/server/errors/errors.data-service.spec.ts +355 -0
  103. package/src/_modules/server/server-status/server-status-snapshot.control-service.spec.ts +70 -0
  104. package/src/_modules/server/server-status/server-status-snapshot.data-service.spec.ts +77 -0
  105. package/src/_modules/server/server-status/server-status.control-service.spec.ts +516 -0
  106. package/src/_modules/server/server-status/server-status.controller.spec.ts +156 -0
  107. package/src/_modules/socket/_models/socket-client-service-params.control-model.spec.ts +6 -3
  108. package/src/_modules/socket/_models/socket-presence.control-model.spec.ts +164 -0
  109. package/src/_modules/socket/_services/socket-client.service.spec.ts +15 -0
  110. package/src/_modules/test/get-test-routing-module.util.spec.ts +28 -0
  111. package/src/_modules/test/test.controller.spec.ts +72 -0
  112. package/src/_modules/usage/usage.controller.spec.ts +81 -0
  113. package/src/_modules/usage/usage.data-service.spec.ts +332 -0
  114. package/src/_services/base/api.service-base.spec.ts +125 -0
  115. package/src/_services/base/archive-data.service.spec.ts +196 -0
  116. package/src/_services/base/data.service.spec.ts +493 -0
  117. package/src/_services/base/db.service.spec.ts +59 -18
  118. package/src/_services/base/singleton.service-base.spec.ts +28 -0
  119. package/src/_services/base/singleton.service.spec.ts +114 -0
  120. package/src/_services/core/api.service.ts +1 -0
  121. package/src/_services/core/auth.service.spec.ts +159 -0
  122. package/src/_services/core/email.service.spec.ts +14 -22
  123. package/src/_services/core/global.service.spec.ts +275 -0
  124. package/src/_services/core/service-collection.service.spec.ts +46 -0
  125. package/src/_services/route/routing-module.service.spec.ts +8 -6
  126. package/src/_services/server/app.server.ts +12 -0
  127. package/src/_services/shared.static-service.spec.ts +89 -0
  128. package/build/_collections/archive.util.spec.d.ts +0 -2
  129. package/build/_collections/archive.util.spec.d.ts.map +0 -1
  130. package/build/_collections/archive.util.spec.js +0 -21
  131. package/build/_collections/archive.util.spec.js.map +0 -1
  132. package/build/_models/control-models/api-call-params.control-model.spec.d.ts +0 -2
  133. package/build/_models/control-models/api-call-params.control-model.spec.d.ts.map +0 -1
  134. package/build/_models/control-models/api-call-params.control-model.spec.js +0 -80
  135. package/build/_models/control-models/api-call-params.control-model.spec.js.map +0 -1
  136. package/build/_models/control-models/app-params.control-model.spec.d.ts +0 -2
  137. package/build/_models/control-models/app-params.control-model.spec.d.ts.map +0 -1
  138. package/build/_models/control-models/app-params.control-model.spec.js +0 -59
  139. package/build/_models/control-models/app-params.control-model.spec.js.map +0 -1
  140. package/build/_models/control-models/app-system-controls.control-model.spec.d.ts +0 -2
  141. package/build/_models/control-models/app-system-controls.control-model.spec.d.ts.map +0 -1
  142. package/build/_models/control-models/app-system-controls.control-model.spec.js +0 -26
  143. package/build/_models/control-models/app-system-controls.control-model.spec.js.map +0 -1
  144. package/build/_models/control-models/http-settings.control-model.spec.d.ts +0 -2
  145. package/build/_models/control-models/http-settings.control-model.spec.d.ts.map +0 -1
  146. package/build/_models/control-models/http-settings.control-model.spec.js +0 -62
  147. package/build/_models/control-models/http-settings.control-model.spec.js.map +0 -1
  148. package/build/_models/control-models/system-control.control-model.spec.d.ts +0 -2
  149. package/build/_models/control-models/system-control.control-model.spec.d.ts.map +0 -1
  150. package/build/_models/control-models/system-control.control-model.spec.js +0 -24
  151. package/build/_models/control-models/system-control.control-model.spec.js.map +0 -1
  152. package/build/_modules/local-vector-search/_services/lvs-vector-pool.control-service.spec.d.ts +0 -2
  153. package/build/_modules/local-vector-search/_services/lvs-vector-pool.control-service.spec.d.ts.map +0 -1
  154. package/build/_modules/local-vector-search/_services/lvs-vector-pool.control-service.spec.js +0 -294
  155. package/build/_modules/local-vector-search/_services/lvs-vector-pool.control-service.spec.js.map +0 -1
  156. package/build/_modules/mock/app-params.mock.spec.d.ts +0 -2
  157. package/build/_modules/mock/app-params.mock.spec.d.ts.map +0 -1
  158. package/build/_modules/mock/app-params.mock.spec.js +0 -19
  159. package/build/_modules/mock/app-params.mock.spec.js.map +0 -1
  160. package/build/_modules/mock/auth-service.mock.spec.d.ts +0 -2
  161. package/build/_modules/mock/auth-service.mock.spec.d.ts.map +0 -1
  162. package/build/_modules/mock/auth-service.mock.spec.js +0 -40
  163. package/build/_modules/mock/auth-service.mock.spec.js.map +0 -1
  164. package/build/_modules/mock/controller.mock.spec.d.ts +0 -2
  165. package/build/_modules/mock/controller.mock.spec.d.ts.map +0 -1
  166. package/build/_modules/mock/controller.mock.spec.js +0 -23
  167. package/build/_modules/mock/controller.mock.spec.js.map +0 -1
  168. package/build/_modules/mock/data-model.mock.spec.d.ts +0 -2
  169. package/build/_modules/mock/data-model.mock.spec.d.ts.map +0 -1
  170. package/build/_modules/mock/data-model.mock.spec.js +0 -98
  171. package/build/_modules/mock/data-model.mock.spec.js.map +0 -1
  172. package/build/_modules/mock/email-service-collection.mock.spec.d.ts +0 -2
  173. package/build/_modules/mock/email-service-collection.mock.spec.d.ts.map +0 -1
  174. package/build/_modules/mock/email-service-collection.mock.spec.js +0 -21
  175. package/build/_modules/mock/email-service-collection.mock.spec.js.map +0 -1
  176. package/build/_modules/mock/email-service.mock.spec.d.ts +0 -2
  177. package/build/_modules/mock/email-service.mock.spec.d.ts.map +0 -1
  178. package/build/_modules/mock/email-service.mock.spec.js +0 -14
  179. package/build/_modules/mock/email-service.mock.spec.js.map +0 -1
  180. package/build/_modules/mock/socket-client.mock.spec.d.ts +0 -2
  181. package/build/_modules/mock/socket-client.mock.spec.d.ts.map +0 -1
  182. package/build/_modules/mock/socket-client.mock.spec.js +0 -32
  183. package/build/_modules/mock/socket-client.mock.spec.js.map +0 -1
  184. package/build/_modules/mock/socket-server.mock.spec.d.ts +0 -2
  185. package/build/_modules/mock/socket-server.mock.spec.d.ts.map +0 -1
  186. package/build/_modules/mock/socket-server.mock.spec.js +0 -36
  187. package/build/_modules/mock/socket-server.mock.spec.js.map +0 -1
  188. package/build/_modules/socket/_models/socket-client-service-params.control-model.spec.d.ts +0 -2
  189. package/build/_modules/socket/_models/socket-client-service-params.control-model.spec.d.ts.map +0 -1
  190. package/build/_modules/socket/_models/socket-client-service-params.control-model.spec.js +0 -22
  191. package/build/_modules/socket/_models/socket-client-service-params.control-model.spec.js.map +0 -1
  192. package/build/_modules/socket/_models/socket-server-service-params.control-model.spec.d.ts +0 -2
  193. package/build/_modules/socket/_models/socket-server-service-params.control-model.spec.d.ts.map +0 -1
  194. package/build/_modules/socket/_models/socket-server-service-params.control-model.spec.js +0 -29
  195. package/build/_modules/socket/_models/socket-server-service-params.control-model.spec.js.map +0 -1
  196. package/build/_modules/socket/_services/socket-server.service.spec.d.ts +0 -2
  197. package/build/_modules/socket/_services/socket-server.service.spec.d.ts.map +0 -1
  198. package/build/_modules/socket/_services/socket-server.service.spec.js +0 -9
  199. package/build/_modules/socket/_services/socket-server.service.spec.js.map +0 -1
  200. package/build/_modules/socket/app-extended.server.spec.d.ts +0 -2
  201. package/build/_modules/socket/app-extended.server.spec.d.ts.map +0 -1
  202. package/build/_modules/socket/app-extended.server.spec.js +0 -149
  203. package/build/_modules/socket/app-extended.server.spec.js.map +0 -1
  204. package/build/_services/base/db.service.spec.d.ts +0 -1
  205. package/build/_services/base/db.service.spec.d.ts.map +0 -1
  206. package/build/_services/base/db.service.spec.js +0 -28
  207. package/build/_services/base/db.service.spec.js.map +0 -1
  208. package/build/_services/core/api.service.spec.d.ts +0 -2
  209. package/build/_services/core/api.service.spec.d.ts.map +0 -1
  210. package/build/_services/core/api.service.spec.js +0 -109
  211. package/build/_services/core/api.service.spec.js.map +0 -1
  212. package/build/_services/core/email.service.spec.d.ts +0 -2
  213. package/build/_services/core/email.service.spec.d.ts.map +0 -1
  214. package/build/_services/core/email.service.spec.js +0 -77
  215. package/build/_services/core/email.service.spec.js.map +0 -1
  216. package/build/_services/route/controller.service.spec.d.ts +0 -2
  217. package/build/_services/route/controller.service.spec.d.ts.map +0 -1
  218. package/build/_services/route/controller.service.spec.js +0 -48
  219. package/build/_services/route/controller.service.spec.js.map +0 -1
  220. package/build/_services/route/routing-module.service.spec.d.ts +0 -2
  221. package/build/_services/route/routing-module.service.spec.d.ts.map +0 -1
  222. package/build/_services/route/routing-module.service.spec.js +0 -64
  223. package/build/_services/route/routing-module.service.spec.js.map +0 -1
  224. package/build/_services/server/app.server.spec.d.ts +0 -2
  225. package/build/_services/server/app.server.spec.d.ts.map +0 -1
  226. package/build/_services/server/app.server.spec.js +0 -80
  227. package/build/_services/server/app.server.spec.js.map +0 -1
  228. package/build/_services/shared.static-service.spec.d.ts +0 -2
  229. package/build/_services/shared.static-service.spec.d.ts.map +0 -1
  230. package/build/_services/shared.static-service.spec.js +0 -12
  231. package/build/_services/shared.static-service.spec.js.map +0 -1
  232. package/src/_modules/socket/app-extended.server.spec.ts +0 -227
  233. package/src/_services/server/app.server.spec.ts +0 -138
@@ -0,0 +1,116 @@
1
+
2
+ import { DyNTS_Bot_Commands_ControlService } from './bot-commands.control-service';
3
+ import { DyNTS_Bot_Main_ControlService } from './bot-main.control-service';
4
+ import { DyNTS_Bot_MessageWrapper } from '../_models/bot-message-wrapper.interface';
5
+ import { DyNTS_Bot_MessagingProvider_ServiceBase } from './bot-messaging-provider.service-base';
6
+ import { DyFM_Error, DyFM_EnvironmentFlag } from '@futdevpro/fsm-dynamo';
7
+ import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
8
+ import { DyNTS_GlobalService } from '../../../_services/core/global.service';
9
+
10
+ class TestBotCommandsService extends DyNTS_Bot_Commands_ControlService {
11
+ protected declare mainBot_CS: any;
12
+ protected getMainBotControlService(): DyNTS_Bot_Main_ControlService {
13
+ return {
14
+ defaultProvider: {
15
+ botId: 'bot-123',
16
+ },
17
+ } as any;
18
+ }
19
+
20
+ static getInstance(): TestBotCommandsService {
21
+ return TestBotCommandsService.getSingletonInstance();
22
+ }
23
+ }
24
+
25
+ xdescribe('| DyNTS_Bot_Commands_ControlService', () => {
26
+ let service: TestBotCommandsService;
27
+ let mockDBService: jasmine.SpyObj<{
28
+ find: (f: unknown) => Promise<unknown[]>;
29
+ getAll: () => Promise<unknown[]>;
30
+ getDataById: (id: string) => Promise<unknown>;
31
+ }>;
32
+
33
+ beforeAll(() => {
34
+ if (!DyNTS_global_settings.systemShortCodeName) {
35
+ (DyNTS_global_settings as { systemShortCodeName?: string }).systemShortCodeName = 'TEST';
36
+ }
37
+ });
38
+
39
+ beforeEach(() => {
40
+ DyNTS_global_settings.env_settings = {
41
+ environment: DyFM_EnvironmentFlag.local,
42
+ mongoUri: 'mongodb://localhost:27017/test',
43
+ } as typeof DyNTS_global_settings.env_settings;
44
+
45
+ mockDBService = jasmine.createSpyObj('DyNTS_DBService', [
46
+ 'find', 'findOne', 'getDataById', 'getAll', 'getDataListByIds', 'getDataByDependencyId',
47
+ 'getDataListByDependencyId', 'getDataListByDependencyIds', 'createData', 'modifyData',
48
+ 'markDeletedById', 'trueDeleteDataById', 'trueDeleteAllData', 'restoreDeletedById',
49
+ ]);
50
+ spyOn(DyNTS_GlobalService, 'getDBService').and.returnValue(mockDBService as never);
51
+ spyOn(DyNTS_GlobalService, 'getDBServiceByKey').and.returnValue(mockDBService as never);
52
+
53
+ service = TestBotCommandsService.getInstance();
54
+ });
55
+
56
+ it('| should be a singleton instance', () => {
57
+ const instance1 = TestBotCommandsService.getInstance();
58
+ const instance2 = TestBotCommandsService.getInstance();
59
+
60
+ expect(instance1).toBe(instance2);
61
+ expect(instance1).toBeInstanceOf(TestBotCommandsService);
62
+ });
63
+
64
+ describe('| defaultProvider', () => {
65
+ it('| should return default provider from main bot service', () => {
66
+ (service as any).mainBot_CS = (service as any).getMainBotControlService();
67
+
68
+ expect(service.defaultProvider).toBeDefined();
69
+ });
70
+ });
71
+
72
+ describe('| setup', () => {
73
+ it('| should setup main bot service', async () => {
74
+ await service.setup('issuer-123');
75
+
76
+ expect((service as any).mainBot_CS).toBeDefined();
77
+ });
78
+
79
+ it('| should throw error when main bot service not found', async () => {
80
+ const serviceWithoutMainBot = new (class extends TestBotCommandsService {
81
+ protected override getMainBotControlService(): any {
82
+ return null;
83
+ }
84
+ } as any)();
85
+
86
+ await expectAsync(
87
+ serviceWithoutMainBot.setup('issuer-123')
88
+ ).toBeRejected();
89
+ });
90
+ });
91
+
92
+ describe('| start', () => {
93
+ it('| should throw error when default provider not started', async () => {
94
+ const serviceWithoutProvider = new (class extends TestBotCommandsService {
95
+ protected override getMainBotControlService(): any {
96
+ return {
97
+ defaultProvider: null,
98
+ };
99
+ }
100
+ } as any)();
101
+
102
+ await expectAsync(
103
+ serviceWithoutProvider.start('issuer-123')
104
+ ).toBeRejected();
105
+ });
106
+
107
+ it('| should succeed when default provider is started', async () => {
108
+ (service as any).mainBot_CS = (service as any).getMainBotControlService();
109
+
110
+ await expectAsync(
111
+ service.start('issuer-123')
112
+ ).toBeResolved();
113
+ });
114
+ });
115
+ });
116
+
@@ -0,0 +1,285 @@
1
+
2
+ import { DyNTS_Bot_IO_ControlService } from './bot-io.control-service';
3
+ import { DyNTS_Bot_Main_ControlService } from './bot-main.control-service';
4
+ import { DyNTS_Bot_Commands_ControlService } from './bot-commands.control-service';
5
+ import { DyNTS_Bot_MessageWrapper } from '../_models/bot-message-wrapper.interface';
6
+ import { DyNTS_Bot_MessagingProvider_ServiceBase } from './bot-messaging-provider.service-base';
7
+ import { DyFM_Error, DyFM_EnvironmentFlag } from '@futdevpro/fsm-dynamo';
8
+ import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
9
+
10
+ class TestBotIOService extends DyNTS_Bot_IO_ControlService {
11
+ protected declare mainBot_CS: any;
12
+ protected getMainBotControlService(): any {
13
+ return {
14
+ defaultProvider: {
15
+ botId: 'bot-123',
16
+ botDisplayName: 'TestBot',
17
+ },
18
+ } as any;
19
+ }
20
+
21
+ protected getCommandsControlService(): DyNTS_Bot_Commands_ControlService {
22
+ return {
23
+ handleCommand: jasmine.createSpy('handleCommand').and.returnValue(Promise.resolve()),
24
+ } as any;
25
+ }
26
+
27
+ handleMessage = async (message: any, issuer: string): Promise<any> => {
28
+ return message;
29
+ };
30
+
31
+ static getInstance(): TestBotIOService {
32
+ return TestBotIOService.getSingletonInstance();
33
+ }
34
+ }
35
+
36
+ xdescribe('| DyNTS_Bot_IO_ControlService', () => {
37
+ let service: TestBotIOService;
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
+ service = TestBotIOService.getInstance();
50
+ });
51
+
52
+ it('| should be a singleton instance', () => {
53
+ const instance1 = TestBotIOService.getInstance();
54
+ const instance2 = TestBotIOService.getInstance();
55
+
56
+ expect(instance1).toBe(instance2);
57
+ expect(instance1).toBeInstanceOf(TestBotIOService);
58
+ });
59
+
60
+ describe('| defaultProvider', () => {
61
+ it('| should return default provider from main bot service', () => {
62
+ (service as any).mainBot_CS = (service as any).getMainBotControlService();
63
+
64
+ expect(service.defaultProvider).toBeDefined();
65
+ expect(service.defaultProvider.botId).toBe('bot-123');
66
+ });
67
+ });
68
+
69
+ describe('| setup', () => {
70
+ it('| should setup main bot and commands services', async () => {
71
+ await service.setup('issuer-123');
72
+
73
+ expect((service as any).mainBot_CS).toBeDefined();
74
+ expect((service as any).commands_CS).toBeDefined();
75
+ });
76
+
77
+ it('| should throw error when main bot service not found', async () => {
78
+ const serviceWithoutMainBot = new (class extends TestBotIOService {
79
+ protected override getMainBotControlService(): any {
80
+ return null;
81
+ }
82
+ } as any)();
83
+
84
+ await expectAsync(
85
+ serviceWithoutMainBot.setup('issuer-123')
86
+ ).toBeRejected();
87
+ });
88
+
89
+ it('| should throw error when commands service not found', async () => {
90
+ const serviceWithoutCommands = new (class extends TestBotIOService {
91
+ protected override getCommandsControlService(): any {
92
+ return null;
93
+ }
94
+ } as any)();
95
+
96
+ await expectAsync(
97
+ serviceWithoutCommands.setup('issuer-123')
98
+ ).toBeRejected();
99
+ });
100
+ });
101
+
102
+ describe('| start', () => {
103
+ it('| should throw error when default provider not initialized', async () => {
104
+ const serviceWithoutProvider = new (class extends TestBotIOService {
105
+ protected override getMainBotControlService(): any {
106
+ return {
107
+ defaultProvider: null,
108
+ };
109
+ }
110
+ } as any)();
111
+
112
+ await expectAsync(
113
+ serviceWithoutProvider.start('issuer-123')
114
+ ).toBeRejected();
115
+ });
116
+
117
+ it('| should succeed when default provider is initialized', async () => {
118
+ (service as any).mainBot_CS = (service as any).getMainBotControlService();
119
+
120
+ await expectAsync(
121
+ service.start('issuer-123')
122
+ ).toBeResolved();
123
+ });
124
+ });
125
+
126
+ describe('| getMessageIsForBotToHandle', () => {
127
+ it('| should return false when bot not initialized', async () => {
128
+ const mockMessage = {
129
+ provider: null,
130
+ content: 'Test message',
131
+ } as any;
132
+
133
+ const result = await service.getMessageIsForBotToHandle(mockMessage, 'issuer-123');
134
+
135
+ expect(result).toBe(false);
136
+ });
137
+
138
+ it('| should return false when message has skip flags', async () => {
139
+ const mockMessage = {
140
+ provider: {
141
+ botId: 'bot-123',
142
+ botDisplayName: 'Bot',
143
+ },
144
+ content: '[BOT-SKIP] Test message',
145
+ authorId: 'user-123',
146
+ isBot: false,
147
+ channelName: 'test-channel',
148
+ } as any;
149
+ spyOn(DyNTS_global_settings, 'bot_settings').and.returnValue({
150
+ messageSettings: {
151
+ skipFlags: ['[BOT-SKIP]'],
152
+ },
153
+ channelSettings: {
154
+ allowedChannels: ['test-channel'],
155
+ defaultChannels: [],
156
+ dmIsAllowed: false,
157
+ },
158
+ allowedUsers: 'all',
159
+ debugLevel: 1,
160
+ } as any);
161
+ (service as any).mainBot_CS = (service as any).getMainBotControlService();
162
+
163
+ const result = await service.getMessageIsForBotToHandle(mockMessage, 'issuer-123');
164
+
165
+ expect(result).toBe(false);
166
+ });
167
+
168
+ it('| should return false when message is from bot and bots not allowed', async () => {
169
+ const mockMessage = {
170
+ provider: {
171
+ botId: 'bot-123',
172
+ botDisplayName: 'Bot',
173
+ },
174
+ content: 'Test message',
175
+ authorId: 'bot-456',
176
+ isBot: true,
177
+ channelName: 'test-channel',
178
+ } as any;
179
+ spyOn(DyNTS_global_settings, 'bot_settings').and.returnValue({
180
+ messageSettings: {
181
+ skipFlags: [],
182
+ },
183
+ channelSettings: {
184
+ allowedChannels: ['test-channel'],
185
+ defaultChannels: [],
186
+ dmIsAllowed: false,
187
+ },
188
+ allowedUsers: 'all',
189
+ allowBotsInteractEachOther: false,
190
+ debugLevel: 1,
191
+ } as any);
192
+ (service as any).mainBot_CS = (service as any).getMainBotControlService();
193
+
194
+ const result = await service.getMessageIsForBotToHandle(mockMessage, 'issuer-123');
195
+
196
+ expect(result).toBe(false);
197
+ });
198
+ });
199
+
200
+ describe('| handleIfCommand', () => {
201
+ it('| should handle command when message is a command', async () => {
202
+ const mockMessage = {
203
+ content: '!test',
204
+ provider: {
205
+ botId: 'bot-123',
206
+ },
207
+ } as any;
208
+ (service as any).commands_CS = (service as any).getCommandsControlService();
209
+ spyOn(service, 'isCommand').and.returnValue(Promise.resolve(true));
210
+
211
+ const result = await service.handleIfCommand(mockMessage, 'issuer-123');
212
+
213
+ expect(result).toBe(true);
214
+ expect((service as any).commands_CS.handleCommand).toHaveBeenCalledWith(mockMessage, 'issuer-123');
215
+ });
216
+
217
+ it('| should return false when message is not a command', async () => {
218
+ const mockMessage = {
219
+ content: 'Regular message',
220
+ } as any;
221
+ spyOn(service, 'isCommand').and.returnValue(Promise.resolve(false));
222
+
223
+ const result = await service.handleIfCommand(mockMessage, 'issuer-123');
224
+
225
+ expect(result).toBe(false);
226
+ });
227
+ });
228
+
229
+ describe('| isCommand', () => {
230
+ it('| should return true when message starts with command operator', async () => {
231
+ const mockMessage = {
232
+ content: '!test command',
233
+ } as any;
234
+ const orig = (DyNTS_global_settings as { bot_settings?: unknown }).bot_settings;
235
+ (DyNTS_global_settings as { bot_settings: unknown }).bot_settings = {
236
+ commandSettings: {
237
+ commandOperator: '!',
238
+ commands: [{ command: 'test' }],
239
+ },
240
+ };
241
+
242
+ const result = await service.isCommand(mockMessage, 'issuer-123');
243
+
244
+ expect(result).toBe(true);
245
+ (DyNTS_global_settings as { bot_settings: unknown }).bot_settings = orig;
246
+ });
247
+
248
+ it('| should return false when message does not start with command operator', async () => {
249
+ const mockMessage = {
250
+ content: 'regular message',
251
+ } as any;
252
+ const orig = (DyNTS_global_settings as { bot_settings?: unknown }).bot_settings;
253
+ (DyNTS_global_settings as { bot_settings: unknown }).bot_settings = {
254
+ commandSettings: {
255
+ commandOperator: '!',
256
+ commands: [],
257
+ },
258
+ };
259
+
260
+ const result = await service.isCommand(mockMessage, 'issuer-123');
261
+
262
+ expect(result).toBe(false);
263
+ (DyNTS_global_settings as { bot_settings: unknown }).bot_settings = orig;
264
+ });
265
+
266
+ it('| should return true when no command operator is set', async () => {
267
+ const mockMessage = {
268
+ content: 'test',
269
+ } as any;
270
+ const orig = (DyNTS_global_settings as { bot_settings?: unknown }).bot_settings;
271
+ (DyNTS_global_settings as { bot_settings: unknown }).bot_settings = {
272
+ commandSettings: {
273
+ commandOperator: '',
274
+ commands: [{ command: 'test' }],
275
+ },
276
+ };
277
+
278
+ const result = await service.isCommand(mockMessage, 'issuer-123');
279
+
280
+ expect(result).toBe(true);
281
+ (DyNTS_global_settings as { bot_settings: unknown }).bot_settings = orig;
282
+ });
283
+ });
284
+ });
285
+
@@ -0,0 +1,208 @@
1
+
2
+ import { DyNTS_Bot_Main_ControlService } from './bot-main.control-service';
3
+ import { DyNTS_Bot_IO_ControlService } from './bot-io.control-service';
4
+ import { DyNTS_Bot_Routines_ControlService } from './bot-routines.control-service';
5
+ import { DyNTS_Bot_Commands_ControlService } from './bot-commands.control-service';
6
+ import { DyNTS_Bot_MessagingProvider_ServiceBase } from './bot-messaging-provider.service-base';
7
+ import { DyFM_Msg_Provider_Type } from '@futdevpro/fsm-dynamo/messaging';
8
+ import { DyFM_Error, DyFM_Async } from '@futdevpro/fsm-dynamo';
9
+ import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
10
+ import { second } from '@futdevpro/fsm-dynamo';
11
+
12
+ class TestBotMainService extends DyNTS_Bot_Main_ControlService<DyFM_Msg_Provider_Type> {
13
+ protected getBotIOControlService(): DyNTS_Bot_IO_ControlService {
14
+ return {
15
+ setup: jasmine.createSpy('setup').and.returnValue(Promise.resolve()),
16
+ start: jasmine.createSpy('start').and.returnValue(Promise.resolve()),
17
+ } as any;
18
+ }
19
+
20
+ protected getRoutinesControlService(): DyNTS_Bot_Routines_ControlService {
21
+ return {
22
+ setup: jasmine.createSpy('setup').and.returnValue(Promise.resolve()),
23
+ start: jasmine.createSpy('start').and.returnValue(Promise.resolve()),
24
+ } as any;
25
+ }
26
+
27
+ protected getCommandsControlService(): DyNTS_Bot_Commands_ControlService {
28
+ return {
29
+ setup: jasmine.createSpy('setup').and.returnValue(Promise.resolve()),
30
+ start: jasmine.createSpy('start').and.returnValue(Promise.resolve()),
31
+ } as any;
32
+ }
33
+
34
+ protected defaultProviderType: DyFM_Msg_Provider_Type = DyFM_Msg_Provider_Type.discord;
35
+ protected availableProviders: DyNTS_Bot_MessagingProvider_ServiceBase<any, any, any>[] = [
36
+ {
37
+ type: DyFM_Msg_Provider_Type.discord,
38
+ setup: jasmine.createSpy('setup').and.returnValue(Promise.resolve()),
39
+ start: jasmine.createSpy('start').and.returnValue(Promise.resolve()),
40
+ create_onErrorEventListener: jasmine.createSpy('create_onErrorEventListener'),
41
+ create_onMessageEventListener: jasmine.createSpy('create_onMessageEventListener'),
42
+ sendReport: jasmine.createSpy('sendReport').and.returnValue(Promise.resolve()),
43
+ name: 'TestProvider',
44
+ config: { reportChannelName: 'test-channel' },
45
+ } as any,
46
+ ];
47
+
48
+ static getInstance(): TestBotMainService {
49
+ return TestBotMainService.getSingletonInstance();
50
+ }
51
+ }
52
+
53
+ xdescribe('| DyNTS_Bot_Main_ControlService', () => {
54
+ let service: TestBotMainService;
55
+
56
+ beforeEach(() => {
57
+ service = TestBotMainService.getInstance();
58
+ });
59
+
60
+ afterEach(async () => {
61
+ try {
62
+ // Megvárjuk, hogy a bot leálljon és a process listener-ek lefussanak
63
+ await DyFM_Async.delay(200);
64
+
65
+ // Biztosítjuk, hogy a provider-ek ne próbáljanak üzenetet küldeni
66
+ if (service && (service as any)._providers) {
67
+ const providers = (service as any)._providers as Map<any, any>;
68
+ providers.forEach((provider) => {
69
+ if (provider) {
70
+ // Eltávolítjuk a sendMessageToChannelByName metódust, hogy ne próbáljon üzenetet küldeni
71
+ if (typeof provider.sendMessageToChannelByName === 'function') {
72
+ provider.sendMessageToChannelByName = undefined;
73
+ }
74
+ // Invalidáljuk a config-ot is, hogy ne legyen reportChannelName
75
+ if (provider.config) {
76
+ provider.config.reportChannelName = undefined;
77
+ provider.config = undefined;
78
+ }
79
+ // Invalidáljuk a name-et is
80
+ provider.name = undefined;
81
+ }
82
+ });
83
+ // Töröljük a providers map-et is
84
+ (service as any)._providers.clear();
85
+ }
86
+
87
+ // Invalidáljuk a defaultProvider-t is
88
+ if (service && (service as any)._defaultProvider) {
89
+ (service as any)._defaultProvider = undefined;
90
+ }
91
+
92
+ await DyFM_Async.delay(200);
93
+ } catch (error) {
94
+ // Csendes hiba-kezelés
95
+ }
96
+ });
97
+
98
+ afterAll(async () => {
99
+ try {
100
+ // Végleges cleanup a tesztek végén - megvárjuk, hogy minden process listener lefusson
101
+ await DyFM_Async.delay(500);
102
+
103
+ // Invalidáljuk a service-t is
104
+ if (service) {
105
+ (service as any)._providers = undefined;
106
+ (service as any)._defaultProvider = undefined;
107
+ }
108
+
109
+ await DyFM_Async.delay(500);
110
+ } catch (error) {
111
+ // Csendes hiba-kezelés
112
+ }
113
+ });
114
+
115
+ it('| should be a singleton instance', () => {
116
+ const instance1 = TestBotMainService.getInstance();
117
+ const instance2 = TestBotMainService.getInstance();
118
+
119
+ expect(instance1).toBe(instance2);
120
+ expect(instance1).toBeInstanceOf(TestBotMainService);
121
+ });
122
+
123
+ describe('| defaultProvider', () => {
124
+ it('| should return default provider after setup', async () => {
125
+ await service.setup('issuer-123');
126
+
127
+ expect(service.defaultProvider).toBeDefined();
128
+ });
129
+ });
130
+
131
+ describe('| setup', () => {
132
+ it('| should throw error when no providers configured', async () => {
133
+ const serviceWithoutProviders = new (class extends TestBotMainService {
134
+ protected override availableProviders: any[] = [];
135
+ } as any)();
136
+
137
+ // Expect rejection - may be DyFM_Error or Error
138
+ await expectAsync(
139
+ serviceWithoutProviders.setup('issuer-123')
140
+ ).toBeRejected();
141
+ });
142
+
143
+ it('| should throw error when default provider type not set', async () => {
144
+ const serviceWithoutDefaultType = new (class extends TestBotMainService {
145
+ protected override defaultProviderType: any = undefined;
146
+ } as any)();
147
+
148
+ // Expect rejection - may be DyFM_Error or Error
149
+ await expectAsync(
150
+ serviceWithoutDefaultType.setup('issuer-123')
151
+ ).toBeRejected();
152
+ });
153
+
154
+ it('| should setup all services', async () => {
155
+ await service.setup('issuer-123');
156
+
157
+ expect(service.botIO_CS).toBeDefined();
158
+ expect(service.routines_CS).toBeDefined();
159
+ expect(service.commands_CS).toBeDefined();
160
+ });
161
+
162
+ it('| should throw error when botIO_CS not found', async () => {
163
+ const serviceWithoutBotIO = new (class extends TestBotMainService {
164
+ protected override getBotIOControlService(): any {
165
+ return null;
166
+ }
167
+ } as any)();
168
+
169
+ await expectAsync(
170
+ serviceWithoutBotIO.setup('issuer-123')
171
+ ).toBeRejected();
172
+ });
173
+ });
174
+
175
+ describe('| start', () => {
176
+ it('| should start routines and botIO services', async () => {
177
+ (service as any).botIO_CS = (service as any).getBotIOControlService();
178
+ (service as any).routines_CS = (service as any).getRoutinesControlService();
179
+
180
+ await service.start('issuer-123');
181
+
182
+ expect(service.routines_CS.start).toHaveBeenCalledWith('issuer-123');
183
+ expect(service.botIO_CS.start).toHaveBeenCalledWith('issuer-123');
184
+ });
185
+ });
186
+
187
+ describe('| getProviderByType', () => {
188
+ it('| should return provider by type', async () => {
189
+ await service.setup('issuer-123');
190
+
191
+ const provider = service.getProviderByType(DyFM_Msg_Provider_Type.discord);
192
+
193
+ expect(provider).toBeDefined();
194
+ expect(provider.type).toBe(DyFM_Msg_Provider_Type.discord);
195
+ });
196
+ });
197
+
198
+ describe('| sendReport', () => {
199
+ it('| should send report via default provider', async () => {
200
+ await service.setup('issuer-123');
201
+
202
+ await service.sendReport('Test report');
203
+
204
+ expect(service.defaultProvider.sendReport).toHaveBeenCalledWith('Test report');
205
+ });
206
+ });
207
+ });
208
+