@futdevpro/fsm-dynamo 1.15.17 → 1.15.20

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 (543) hide show
  1. package/.cursor/rules/__assistant_guide.mdc +30 -30
  2. package/.cursor/rules/_ag_backend-structure.mdc +85 -85
  3. package/.cursor/rules/_ag_backend.mdc +16 -16
  4. package/.cursor/rules/_ag_frontend-structure.mdc +86 -86
  5. package/.cursor/rules/_ag_frontend.mdc +39 -39
  6. package/.cursor/rules/_ag_import-rules.mdc +44 -44
  7. package/.cursor/rules/_ag_naming.mdc +115 -115
  8. package/.cursor/rules/_ag_should-be.mdc +6 -6
  9. package/.cursor/rules/ai_development_guide.md +60 -60
  10. package/.cursor/rules/cursor-rules.md +160 -160
  11. package/.cursor/rules/default-command.mdc +464 -464
  12. package/.cursor/rules/error_code_pattern.md +39 -39
  13. package/.cursor/rules/saved rule mcp server use.md +15 -15
  14. package/.dynamo/pipeline.cicd.config.json +128 -128
  15. package/.github/workflows/main.yml +433 -433
  16. package/.vscode/settings.json +11 -11
  17. package/LICENSE +21 -21
  18. package/__documentations/2026-06-01-fr047-fc-foundation.md +48 -0
  19. package/build/_models/data-models/errors.data-model.d.ts +43 -0
  20. package/build/_models/data-models/errors.data-model.d.ts.map +1 -1
  21. package/build/_models/data-models/errors.data-model.js +30 -0
  22. package/build/_models/data-models/errors.data-model.js.map +1 -1
  23. package/build/_modules/ai/_models/ai-model-capabilities.interface.d.ts +8 -0
  24. package/build/_modules/ai/_models/ai-model-capabilities.interface.d.ts.map +1 -1
  25. package/build/_modules/ai/_modules/anthropic/_collections/aai-models.const.d.ts.map +1 -1
  26. package/build/_modules/ai/_modules/anthropic/_collections/aai-models.const.js +3 -0
  27. package/build/_modules/ai/_modules/anthropic/_collections/aai-models.const.js.map +1 -1
  28. package/build/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.d.ts.map +1 -1
  29. package/build/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.js +1 -0
  30. package/build/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.js.map +1 -1
  31. package/build/_modules/ai/_modules/google-ai/_collections/gai-models.const.d.ts.map +1 -1
  32. package/build/_modules/ai/_modules/google-ai/_collections/gai-models.const.js +4 -0
  33. package/build/_modules/ai/_modules/google-ai/_collections/gai-models.const.js.map +1 -1
  34. package/build/_modules/ai/_modules/local-ai/_collections/lai-models.const.d.ts.map +1 -1
  35. package/build/_modules/ai/_modules/local-ai/_collections/lai-models.const.js +2 -0
  36. package/build/_modules/ai/_modules/local-ai/_collections/lai-models.const.js.map +1 -1
  37. package/build/_modules/ai/_modules/open-ai/_collections/oai-models.const.d.ts.map +1 -1
  38. package/build/_modules/ai/_modules/open-ai/_collections/oai-models.const.js +11 -0
  39. package/build/_modules/ai/_modules/open-ai/_collections/oai-models.const.js.map +1 -1
  40. package/build/_modules/socket/_models/sck-socket-event.control-model.js +1 -1
  41. package/eslint.config.js +4 -4
  42. package/nodemon.json +22 -22
  43. package/package.json +11 -11
  44. package/scripts/crypto/CRYPTO-STABILITY-SOLUTION.md +196 -196
  45. package/scripts/crypto/README.md +113 -113
  46. package/scripts/crypto/demo-crypto-stability.js +120 -120
  47. package/scripts/crypto/stress-test-crypto.js +379 -379
  48. package/scripts/run-coverage-tests.js +24 -24
  49. package/spec/support/helpers/ts-node-helper.js +9 -9
  50. package/spec/support/jasmine.coverage.json +23 -23
  51. package/spec/support/jasmine.json +24 -24
  52. package/src/_collections/constants/data-sizes.const.ts +40 -40
  53. package/src/_collections/constants/error-defaults.const.ts +20 -20
  54. package/src/_collections/constants/global-settings.const.ts +24 -24
  55. package/src/_collections/constants/numbers.const.ts +40 -40
  56. package/src/_collections/constants/times.const.ts +45 -45
  57. package/src/_collections/utils/array.util.spec.ts +306 -306
  58. package/src/_collections/utils/array.util.ts +813 -813
  59. package/src/_collections/utils/async.util.spec.ts +354 -354
  60. package/src/_collections/utils/async.util.ts +197 -197
  61. package/src/_collections/utils/data.util.spec.ts +345 -345
  62. package/src/_collections/utils/data.util.ts +226 -226
  63. package/src/_collections/utils/json-error-helper.util.spec.ts +521 -521
  64. package/src/_collections/utils/json-error-helper.util.ts +301 -301
  65. package/src/_collections/utils/log.util.spec.ts +975 -975
  66. package/src/_collections/utils/log.util.ts +665 -665
  67. package/src/_collections/utils/math/box-bounds.spec.ts +73 -73
  68. package/src/_collections/utils/math/box-bounds.util.ts +183 -183
  69. package/src/_collections/utils/math/math.util.spec.ts +94 -94
  70. package/src/_collections/utils/math/math.util.ts +141 -141
  71. package/src/_collections/utils/math/random.util.spec.ts +82 -82
  72. package/src/_collections/utils/math/random.util.ts +139 -139
  73. package/src/_collections/utils/math/trigonometry.util.spec.ts +57 -57
  74. package/src/_collections/utils/math/trigonometry.util.ts +102 -102
  75. package/src/_collections/utils/math/vector2.util.spec.ts +94 -94
  76. package/src/_collections/utils/math/vector2.util.ts +653 -653
  77. package/src/_collections/utils/object.util.spec.ts +646 -646
  78. package/src/_collections/utils/regex/password-regex.util.spec.ts +51 -51
  79. package/src/_collections/utils/regex/password-regex.util.ts +65 -65
  80. package/src/_collections/utils/regex/regex.util.spec.ts +42 -42
  81. package/src/_collections/utils/regex/regex.util.ts +6 -6
  82. package/src/_collections/utils/regex/username-regex.util.spec.ts +61 -61
  83. package/src/_collections/utils/regex/username-regex.util.ts +35 -35
  84. package/src/_collections/utils/round-list.util.spec.ts +79 -79
  85. package/src/_collections/utils/round-list.util.ts +162 -162
  86. package/src/_collections/utils/stack.util.spec.ts +372 -372
  87. package/src/_collections/utils/stack.util.ts +164 -164
  88. package/src/_collections/utils/string-case.util.spec.ts +441 -441
  89. package/src/_collections/utils/string-case.util.ts +362 -362
  90. package/src/_collections/utils/string.util.spec.ts +975 -975
  91. package/src/_collections/utils/string.util.ts +449 -449
  92. package/src/_collections/utils/time.util.spec.ts +50 -50
  93. package/src/_collections/utils/time.util.ts +481 -481
  94. package/src/_collections/utils/type-cloning-facility.util.spec.ts +51 -51
  95. package/src/_collections/utils/type-cloning-facility.util.ts +168 -168
  96. package/src/_collections/utils/utilities.util.spec.ts +201 -201
  97. package/src/_collections/utils/utilities.util.ts +68 -68
  98. package/src/_collections/utils/uuid.util.spec.ts +30 -30
  99. package/src/_collections/utils/uuid.util.ts +50 -50
  100. package/src/_enums/basic-property-type.enum.ts +20 -20
  101. package/src/_enums/data-model-type.enum.ts +29 -29
  102. package/src/_enums/environment-flag.enum.ts +28 -28
  103. package/src/_enums/error-level.enum.ts +28 -28
  104. package/src/_enums/http/http-call-type.enum.ts +43 -43
  105. package/src/_enums/http/http-event-type.enum.ts +40 -40
  106. package/src/_enums/http/http-response-type.enum.ts +18 -18
  107. package/src/_enums/log-style.enum.ts +44 -44
  108. package/src/_enums/server-connection-status.enum.ts +6 -6
  109. package/src/_enums/time/day-of-week.enum.ts +55 -55
  110. package/src/_enums/time/month.enum.ts +25 -25
  111. package/src/_enums/time/relative-date.enum.ts +24 -24
  112. package/src/_models/control-models/data-model-params.control-model.spec.ts +85 -85
  113. package/src/_models/control-models/data-model-params.control-model.ts +300 -300
  114. package/src/_models/control-models/data-property-params.control-model.spec.ts +93 -93
  115. package/src/_models/control-models/data-property-params.control-model.ts +201 -201
  116. package/src/_models/control-models/error.control-model.spec.ts +912 -912
  117. package/src/_models/control-models/error.control-model.ts +1215 -1215
  118. package/src/_models/control-models/http/http-error-response.control-model.spec.ts +116 -116
  119. package/src/_models/control-models/http/http-error-response.control-model.ts +52 -52
  120. package/src/_models/control-models/http/http-headers.control-model.spec.ts +25 -25
  121. package/src/_models/control-models/http/http-headers.control-model.ts +124 -124
  122. package/src/_models/control-models/http/http-response.model-base.spec.ts +46 -46
  123. package/src/_models/control-models/http/http-response.model-base.ts +57 -57
  124. package/src/_models/control-models/poll.control-model.spec.ts +63 -63
  125. package/src/_models/control-models/poll.control-model.ts +151 -151
  126. package/src/_models/control-models/range-value.control-model.spec.ts +187 -187
  127. package/src/_models/control-models/range-value.control-model.ts +289 -289
  128. package/src/_models/control-models/server-status.control-model.spec.ts +66 -66
  129. package/src/_models/control-models/server-status.control-model.ts +85 -85
  130. package/src/_models/control-models/service-endpoint-settings-base.control-model.spec.ts +145 -145
  131. package/src/_models/control-models/service-endpoint-settings-base.control-model.ts +186 -186
  132. package/src/_models/data-models/errors.data-model.spec.ts +71 -71
  133. package/src/_models/data-models/errors.data-model.ts +148 -91
  134. package/src/_models/data-models/metadata.data-model.spec.ts +184 -184
  135. package/src/_models/data-models/metadata.data-model.ts +128 -128
  136. package/src/_models/interfaces/box-bounds.interface.ts +7 -7
  137. package/src/_models/interfaces/environment/global-log-settings.interface.ts +86 -86
  138. package/src/_models/interfaces/environment/global-settings.interface.ts +47 -47
  139. package/src/_models/interfaces/error-defaults.interface.ts +11 -11
  140. package/src/_models/interfaces/paged.interface.ts +12 -12
  141. package/src/_models/interfaces/random-weight.interface.ts +7 -7
  142. package/src/_models/interfaces/route-settings.interface.ts +15 -15
  143. package/src/_models/interfaces/search-query.interface.ts +23 -23
  144. package/src/_models/interfaces/search-result.interface.ts +5 -5
  145. package/src/_models/interfaces/server-error-statistics.interface.ts +24 -24
  146. package/src/_models/interfaces/vector2.interface.ts +20 -20
  147. package/src/_models/types/db-filter.type.ts +110 -110
  148. package/src/_models/types/db-sort.type.ts +4 -4
  149. package/src/_models/types/ds-filter.type.ts +68 -68
  150. package/src/_models/types/ds-sort.type.ts +21 -21
  151. package/src/_modules/ai/_collections/ai-model-ref.util.ts +88 -88
  152. package/src/_modules/ai/_collections/ai-model-registry.util.spec.ts +37 -37
  153. package/src/_modules/ai/_collections/ai-model-registry.util.ts +30 -30
  154. package/src/_modules/ai/_enums/ai-message-role.enum.ts +7 -7
  155. package/src/_modules/ai/_enums/ai-model-type.enum.ts +7 -7
  156. package/src/_modules/ai/_enums/ai-provider.enum.ts +7 -7
  157. package/src/_modules/ai/_models/ai-call-settings.interface.ts +84 -84
  158. package/src/_modules/ai/_models/ai-embedding-request.interface.ts +20 -20
  159. package/src/_modules/ai/_models/ai-embedding-response.interface.ts +26 -26
  160. package/src/_modules/ai/_models/ai-llm-request.interface.ts +24 -24
  161. package/src/_modules/ai/_models/ai-llm-response.interface.ts +30 -30
  162. package/src/_modules/ai/_models/ai-message.interface.ts +12 -12
  163. package/src/_modules/ai/_models/ai-model-capabilities.interface.ts +35 -27
  164. package/src/_modules/ai/_models/ai-model-info.interface.ts +63 -63
  165. package/src/_modules/ai/_models/ai-model-settings-schema.interface.ts +52 -52
  166. package/src/_modules/ai/_models/ai-provider-capabilities.interface.ts +28 -28
  167. package/src/_modules/ai/_models/ai-settings.interface.ts +17 -17
  168. package/src/_modules/ai/_models/ai-tool-call.interface.ts +18 -18
  169. package/src/_modules/ai/_models/ai-tool-handler.type.ts +11 -11
  170. package/src/_modules/ai/_models/ai-tool-result.interface.ts +16 -16
  171. package/src/_modules/ai/_models/ai-tool.interface.ts +16 -16
  172. package/src/_modules/ai/_models/ai-user-provider-config.control-model.ts +29 -29
  173. package/src/_modules/ai/_modules/anthropic/_collections/aai-models.const.ts +81 -78
  174. package/src/_modules/ai/_modules/anthropic/_enums/aai-model.enum.ts +19 -19
  175. package/src/_modules/ai/_modules/anthropic/_models/aai-call-settings.control-model.spec.ts +28 -28
  176. package/src/_modules/ai/_modules/anthropic/_models/aai-call-settings.control-model.ts +23 -23
  177. package/src/_modules/ai/_modules/anthropic/_models/aai-client-options.interface.ts +10 -10
  178. package/src/_modules/ai/_modules/anthropic/_models/aai-settings.control-model.spec.ts +22 -22
  179. package/src/_modules/ai/_modules/anthropic/_models/aai-settings.control-model.ts +27 -27
  180. package/src/_modules/ai/_modules/anthropic/_models/aai-user-provider-config.control-model.ts +20 -20
  181. package/src/_modules/ai/_modules/anthropic/index.ts +14 -14
  182. package/src/_modules/ai/_modules/document-ai/_models/dai-embedding-info.interface.ts +12 -12
  183. package/src/_modules/ai/_modules/document-ai/_models/dai-vector-search-params.interface.ts +22 -22
  184. package/src/_modules/ai/_modules/document-ai/index.ts +4 -4
  185. package/src/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.ts +34 -33
  186. package/src/_modules/ai/_modules/fdp-ai/_enums/fdpai-model.enum.ts +6 -6
  187. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-call-settings.control-model.ts +19 -19
  188. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-client-options.interface.ts +11 -11
  189. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-settings.control-model.ts +24 -24
  190. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-user-provider-config.control-model.ts +20 -20
  191. package/src/_modules/ai/_modules/fdp-ai/index.ts +11 -11
  192. package/src/_modules/ai/_modules/google-ai/_collections/gai-models.const.ts +99 -95
  193. package/src/_modules/ai/_modules/google-ai/_enums/gai-model.enum.ts +16 -16
  194. package/src/_modules/ai/_modules/google-ai/_models/gai-call-settings.control-model.spec.ts +28 -28
  195. package/src/_modules/ai/_modules/google-ai/_models/gai-call-settings.control-model.ts +21 -21
  196. package/src/_modules/ai/_modules/google-ai/_models/gai-client-options.interface.ts +8 -8
  197. package/src/_modules/ai/_modules/google-ai/_models/gai-settings.control-model.spec.ts +22 -22
  198. package/src/_modules/ai/_modules/google-ai/_models/gai-settings.control-model.ts +25 -25
  199. package/src/_modules/ai/_modules/google-ai/_models/gai-user-provider-config.control-model.ts +20 -20
  200. package/src/_modules/ai/_modules/google-ai/index.ts +14 -14
  201. package/src/_modules/ai/_modules/local-ai/_collections/lai-models.const.ts +53 -51
  202. package/src/_modules/ai/_modules/local-ai/_enums/lai-model.enum.ts +6 -6
  203. package/src/_modules/ai/_modules/local-ai/_models/lai-call-settings.control-model.spec.ts +28 -28
  204. package/src/_modules/ai/_modules/local-ai/_models/lai-call-settings.control-model.ts +18 -18
  205. package/src/_modules/ai/_modules/local-ai/_models/lai-client-options.interface.ts +9 -9
  206. package/src/_modules/ai/_modules/local-ai/_models/lai-settings.control-model.spec.ts +22 -22
  207. package/src/_modules/ai/_modules/local-ai/_models/lai-settings.control-model.ts +23 -23
  208. package/src/_modules/ai/_modules/local-ai/index.ts +14 -14
  209. package/src/_modules/ai/_modules/open-ai/_collections/oai-embedding-model-dimensions.const.ts +7 -7
  210. package/src/_modules/ai/_modules/open-ai/_collections/oai-models.const.ts +252 -241
  211. package/src/_modules/ai/_modules/open-ai/_enums/oai-model.enum.ts +179 -179
  212. package/src/_modules/ai/_modules/open-ai/_models/oai-call-settings.control-model.spec.ts +28 -28
  213. package/src/_modules/ai/_modules/open-ai/_models/oai-call-settings.control-model.ts +21 -21
  214. package/src/_modules/ai/_modules/open-ai/_models/oai-client-options.interface.ts +81 -81
  215. package/src/_modules/ai/_modules/open-ai/_models/oai-embedding-info.interface.ts +13 -13
  216. package/src/_modules/ai/_modules/open-ai/_models/oai-settings.control-model.spec.ts +22 -22
  217. package/src/_modules/ai/_modules/open-ai/_models/oai-settings.control-model.ts +25 -25
  218. package/src/_modules/ai/_modules/open-ai/_models/oai-user-provider-config.control-model.ts +21 -21
  219. package/src/_modules/ai/_modules/open-ai/index.ts +28 -28
  220. package/src/_modules/ai/index.ts +27 -27
  221. package/src/_modules/ci-tools/_enums/cit-ci-result-code.enum.ts +11 -11
  222. package/src/_modules/ci-tools/_enums/cit-ci-step-result-code.enum.ts +9 -9
  223. package/src/_modules/ci-tools/_models/cit-ci-result-info.data-models.spec.ts +58 -58
  224. package/src/_modules/ci-tools/_models/cit-ci-result-info.data-models.ts +77 -77
  225. package/src/_modules/ci-tools/_models/cit-ci-step-result.interface.ts +12 -12
  226. package/src/_modules/ci-tools/index.ts +8 -8
  227. package/src/_modules/crypto/_collections/crypto.util.simple.spec.ts +512 -512
  228. package/src/_modules/crypto/index.ts +13 -13
  229. package/src/_modules/custom-data/_collections/cud-module-settings.const.ts +21 -21
  230. package/src/_modules/custom-data/_models/cud.data-model.spec.ts +38 -38
  231. package/src/_modules/custom-data/_models/cud.data-model.ts +39 -39
  232. package/src/_modules/custom-data/index.ts +10 -10
  233. package/src/_modules/data-handler/_models/data-handler-settings.control-model.spec.ts +110 -110
  234. package/src/_modules/data-handler/_models/data-handler-settings.control-model.ts +110 -110
  235. package/src/_modules/data-handler/_models/data-handler.control-model.spec.ts +445 -445
  236. package/src/_modules/data-handler/_models/data-handler.control-model.ts +459 -459
  237. package/src/_modules/data-handler/_models/data-list-handler.control-model.spec.ts +263 -263
  238. package/src/_modules/data-handler/_models/data-list-handler.control-model.ts +252 -252
  239. package/src/_modules/data-handler/_models/data-search-handler.control-model.spec.ts +417 -417
  240. package/src/_modules/data-handler/_models/data-search-handler.control-model.ts +390 -390
  241. package/src/_modules/data-handler/_models/list-collector-data-handler.control-model.spec.ts +374 -374
  242. package/src/_modules/data-handler/_models/list-collector-data-handler.control-model.ts +274 -274
  243. package/src/_modules/data-handler/index.ts +6 -6
  244. package/src/_modules/location/_collections/assets/country-codes-ISO-3166.json +3239 -3239
  245. package/src/_modules/location/_collections/assets/country-divisions-ISO-3166-all-list.json +19035 -19035
  246. package/src/_modules/location/_collections/assets/country-divisions-ISO-3166.json +4993 -4993
  247. package/src/_modules/location/_collections/assets/country-phone-codes.json +1203 -1203
  248. package/src/_modules/location/_collections/assets/country-subdivisions/afghanistan.json +137 -137
  249. package/src/_modules/location/_collections/assets/country-subdivisions/albania.json +49 -49
  250. package/src/_modules/location/_collections/assets/country-subdivisions/algeria.json +193 -193
  251. package/src/_modules/location/_collections/assets/country-subdivisions/andorra.json +29 -29
  252. package/src/_modules/location/_collections/assets/country-subdivisions/angola.json +73 -73
  253. package/src/_modules/location/_collections/assets/country-subdivisions/antigua-and-barbuda.json +33 -33
  254. package/src/_modules/location/_collections/assets/country-subdivisions/argentina.json +97 -97
  255. package/src/_modules/location/_collections/assets/country-subdivisions/armenia.json +45 -45
  256. package/src/_modules/location/_collections/assets/country-subdivisions/australia.json +33 -33
  257. package/src/_modules/location/_collections/assets/country-subdivisions/austria.json +37 -37
  258. package/src/_modules/location/_collections/assets/country-subdivisions/azerbaijan.json +5 -5
  259. package/src/_modules/location/_collections/assets/country-subdivisions/bahamas.json +125 -125
  260. package/src/_modules/location/_collections/assets/country-subdivisions/bahrain.json +21 -21
  261. package/src/_modules/location/_collections/assets/country-subdivisions/bangladesh.json +29 -29
  262. package/src/_modules/location/_collections/assets/country-subdivisions/barbados.json +45 -45
  263. package/src/_modules/location/_collections/assets/country-subdivisions/belarus.json +29 -29
  264. package/src/_modules/location/_collections/assets/country-subdivisions/belgium.json +13 -13
  265. package/src/_modules/location/_collections/assets/country-subdivisions/belize.json +25 -25
  266. package/src/_modules/location/_collections/assets/country-subdivisions/benin.json +49 -49
  267. package/src/_modules/location/_collections/assets/country-subdivisions/bhutan.json +81 -81
  268. package/src/_modules/location/_collections/assets/country-subdivisions/bolivia.json +37 -37
  269. package/src/_modules/location/_collections/assets/country-subdivisions/bosnia-and-herzegovina.json +13 -13
  270. package/src/_modules/location/_collections/assets/country-subdivisions/botswana.json +65 -65
  271. package/src/_modules/location/_collections/assets/country-subdivisions/brazil.json +109 -109
  272. package/src/_modules/location/_collections/assets/country-subdivisions/brunei-darussalam.json +17 -17
  273. package/src/_modules/location/_collections/assets/country-subdivisions/bulgaria.json +113 -113
  274. package/src/_modules/location/_collections/assets/country-subdivisions/burkina-faso.json +53 -53
  275. package/src/_modules/location/_collections/assets/country-subdivisions/burundi.json +69 -69
  276. package/src/_modules/location/_collections/assets/country-subdivisions/cambodia.json +97 -97
  277. package/src/_modules/location/_collections/assets/country-subdivisions/cameroon.json +41 -41
  278. package/src/_modules/location/_collections/assets/country-subdivisions/canada.json +79 -79
  279. package/src/_modules/location/_collections/assets/country-subdivisions/cape-verde.json +9 -9
  280. package/src/_modules/location/_collections/assets/country-subdivisions/central-african-republic.json +69 -69
  281. package/src/_modules/location/_collections/assets/country-subdivisions/chad.json +89 -89
  282. package/src/_modules/location/_collections/assets/country-subdivisions/chile.json +61 -61
  283. package/src/_modules/location/_collections/assets/country-subdivisions/china.json +205 -205
  284. package/src/_modules/location/_collections/assets/country-subdivisions/colombia.json +133 -133
  285. package/src/_modules/location/_collections/assets/country-subdivisions/comoros.json +13 -13
  286. package/src/_modules/location/_collections/assets/country-subdivisions/congo-the-democratic-republic-of-the.json +45 -45
  287. package/src/_modules/location/_collections/assets/country-subdivisions/congo.json +49 -49
  288. package/src/_modules/location/_collections/assets/country-subdivisions/costa-rica.json +29 -29
  289. package/src/_modules/location/_collections/assets/country-subdivisions/cote-d-ivoire-republic-of.json +77 -77
  290. package/src/_modules/location/_collections/assets/country-subdivisions/croatia.json +85 -85
  291. package/src/_modules/location/_collections/assets/country-subdivisions/cuba.json +65 -65
  292. package/src/_modules/location/_collections/assets/country-subdivisions/cyprus.json +25 -25
  293. package/src/_modules/location/_collections/assets/country-subdivisions/czech-republic.json +57 -57
  294. package/src/_modules/location/_collections/assets/country-subdivisions/denmark.json +21 -21
  295. package/src/_modules/location/_collections/assets/country-subdivisions/djibouti.json +25 -25
  296. package/src/_modules/location/_collections/assets/country-subdivisions/dominica.json +41 -41
  297. package/src/_modules/location/_collections/assets/country-subdivisions/dominican-republic.json +41 -41
  298. package/src/_modules/location/_collections/assets/country-subdivisions/ecuador.json +97 -97
  299. package/src/_modules/location/_collections/assets/country-subdivisions/egypt.json +117 -117
  300. package/src/_modules/location/_collections/assets/country-subdivisions/el-salvador.json +57 -57
  301. package/src/_modules/location/_collections/assets/country-subdivisions/equatorial-guinea.json +9 -9
  302. package/src/_modules/location/_collections/assets/country-subdivisions/eritrea.json +25 -25
  303. package/src/_modules/location/_collections/assets/country-subdivisions/estonia.json +61 -61
  304. package/src/_modules/location/_collections/assets/country-subdivisions/ethiopia.json +45 -45
  305. package/src/_modules/location/_collections/assets/country-subdivisions/fiji.json +21 -21
  306. package/src/_modules/location/_collections/assets/country-subdivisions/finland.json +77 -77
  307. package/src/_modules/location/_collections/assets/country-subdivisions/france.json +133 -133
  308. package/src/_modules/location/_collections/assets/country-subdivisions/gabon.json +37 -37
  309. package/src/_modules/location/_collections/assets/country-subdivisions/gambia.json +25 -25
  310. package/src/_modules/location/_collections/assets/country-subdivisions/georgia.json +49 -49
  311. package/src/_modules/location/_collections/assets/country-subdivisions/germany.json +65 -65
  312. package/src/_modules/location/_collections/assets/country-subdivisions/ghana.json +41 -41
  313. package/src/_modules/location/_collections/assets/country-subdivisions/greece.json +53 -53
  314. package/src/_modules/location/_collections/assets/country-subdivisions/greenland.json +17 -17
  315. package/src/_modules/location/_collections/assets/country-subdivisions/grenada.json +29 -29
  316. package/src/_modules/location/_collections/assets/country-subdivisions/guatemala.json +89 -89
  317. package/src/_modules/location/_collections/assets/country-subdivisions/guinea-bissau.json +13 -13
  318. package/src/_modules/location/_collections/assets/country-subdivisions/guinea.json +33 -33
  319. package/src/_modules/location/_collections/assets/country-subdivisions/guyana.json +41 -41
  320. package/src/_modules/location/_collections/assets/country-subdivisions/haiti.json +41 -41
  321. package/src/_modules/location/_collections/assets/country-subdivisions/honduras.json +73 -73
  322. package/src/_modules/location/_collections/assets/country-subdivisions/hong-kong.json +4 -4
  323. package/src/_modules/location/_collections/assets/country-subdivisions/hungary.json +173 -173
  324. package/src/_modules/location/_collections/assets/country-subdivisions/iceland.json +37 -37
  325. package/src/_modules/location/_collections/assets/country-subdivisions/india.json +181 -181
  326. package/src/_modules/location/_collections/assets/country-subdivisions/indonesia.json +29 -29
  327. package/src/_modules/location/_collections/assets/country-subdivisions/iran-islamic-republic-of.json +125 -125
  328. package/src/_modules/location/_collections/assets/country-subdivisions/iraq.json +73 -73
  329. package/src/_modules/location/_collections/assets/country-subdivisions/ireland.json +17 -17
  330. package/src/_modules/location/_collections/assets/country-subdivisions/israel.json +25 -25
  331. package/src/_modules/location/_collections/assets/country-subdivisions/italy.json +81 -81
  332. package/src/_modules/location/_collections/assets/country-subdivisions/jamaica.json +57 -57
  333. package/src/_modules/location/_collections/assets/country-subdivisions/japan.json +189 -189
  334. package/src/_modules/location/_collections/assets/country-subdivisions/jordan.json +49 -49
  335. package/src/_modules/location/_collections/assets/country-subdivisions/kazakhstan.json +65 -65
  336. package/src/_modules/location/_collections/assets/country-subdivisions/kenya.json +33 -33
  337. package/src/_modules/location/_collections/assets/country-subdivisions/kiribati.json +13 -13
  338. package/src/_modules/location/_collections/assets/country-subdivisions/korea-democratic-people-s-republic-of.json +45 -45
  339. package/src/_modules/location/_collections/assets/country-subdivisions/korea-republic-of.json +69 -69
  340. package/src/_modules/location/_collections/assets/country-subdivisions/kuwait.json +25 -25
  341. package/src/_modules/location/_collections/assets/country-subdivisions/kyrgyzstan.json +33 -33
  342. package/src/_modules/location/_collections/assets/country-subdivisions/lao-people-s-democratic-republic.json +73 -73
  343. package/src/_modules/location/_collections/assets/country-subdivisions/latvia.json +477 -477
  344. package/src/_modules/location/_collections/assets/country-subdivisions/lebanon.json +33 -33
  345. package/src/_modules/location/_collections/assets/country-subdivisions/lesotho.json +41 -41
  346. package/src/_modules/location/_collections/assets/country-subdivisions/liberia.json +61 -61
  347. package/src/_modules/location/_collections/assets/country-subdivisions/libyan-arab-jamahiriya.json +89 -89
  348. package/src/_modules/location/_collections/assets/country-subdivisions/liechtenstein.json +45 -45
  349. package/src/_modules/location/_collections/assets/country-subdivisions/lithuania.json +41 -41
  350. package/src/_modules/location/_collections/assets/country-subdivisions/luxembourg.json +13 -13
  351. package/src/_modules/location/_collections/assets/country-subdivisions/macedonia-the-former-yugoslav-republic-of.json +337 -337
  352. package/src/_modules/location/_collections/assets/country-subdivisions/madagascar.json +25 -25
  353. package/src/_modules/location/_collections/assets/country-subdivisions/malawi.json +13 -13
  354. package/src/_modules/location/_collections/assets/country-subdivisions/malaysia.json +81 -81
  355. package/src/_modules/location/_collections/assets/country-subdivisions/maldives.json +33 -33
  356. package/src/_modules/location/_collections/assets/country-subdivisions/mali.json +37 -37
  357. package/src/_modules/location/_collections/assets/country-subdivisions/malta.json +273 -273
  358. package/src/_modules/location/_collections/assets/country-subdivisions/marshall-islands.json +9 -9
  359. package/src/_modules/location/_collections/assets/country-subdivisions/mauritania.json +53 -53
  360. package/src/_modules/location/_collections/assets/country-subdivisions/mauritius.json +69 -69
  361. package/src/_modules/location/_collections/assets/country-subdivisions/mexico.json +161 -161
  362. package/src/_modules/location/_collections/assets/country-subdivisions/micronesia-federated-states-of.json +17 -17
  363. package/src/_modules/location/_collections/assets/country-subdivisions/moldova-republic-of.json +149 -149
  364. package/src/_modules/location/_collections/assets/country-subdivisions/monaco.json +69 -69
  365. package/src/_modules/location/_collections/assets/country-subdivisions/mongolia.json +89 -89
  366. package/src/_modules/location/_collections/assets/country-subdivisions/montenegro.json +93 -93
  367. package/src/_modules/location/_collections/assets/country-subdivisions/morocco.json +65 -65
  368. package/src/_modules/location/_collections/assets/country-subdivisions/mozambique.json +45 -45
  369. package/src/_modules/location/_collections/assets/country-subdivisions/myanmar.json +57 -57
  370. package/src/_modules/location/_collections/assets/country-subdivisions/namibia.json +57 -57
  371. package/src/_modules/location/_collections/assets/country-subdivisions/nauru.json +57 -57
  372. package/src/_modules/location/_collections/assets/country-subdivisions/nepal.json +21 -21
  373. package/src/_modules/location/_collections/assets/country-subdivisions/netherlands.json +91 -91
  374. package/src/_modules/location/_collections/assets/country-subdivisions/new-zealand.json +111 -111
  375. package/src/_modules/location/_collections/assets/country-subdivisions/nicaragua.json +69 -69
  376. package/src/_modules/location/_collections/assets/country-subdivisions/niger.json +33 -33
  377. package/src/_modules/location/_collections/assets/country-subdivisions/nigeria.json +149 -149
  378. package/src/_modules/location/_collections/assets/country-subdivisions/norway.json +85 -85
  379. package/src/_modules/location/_collections/assets/country-subdivisions/oman.json +37 -37
  380. package/src/_modules/location/_collections/assets/country-subdivisions/pakistan.json +33 -33
  381. package/src/_modules/location/_collections/assets/country-subdivisions/palau.json +65 -65
  382. package/src/_modules/location/_collections/assets/country-subdivisions/palestinian-territory-occupied.json +65 -65
  383. package/src/_modules/location/_collections/assets/country-subdivisions/panama.json +53 -53
  384. package/src/_modules/location/_collections/assets/country-subdivisions/papua-new-guinea.json +81 -81
  385. package/src/_modules/location/_collections/assets/country-subdivisions/paraguay.json +73 -73
  386. package/src/_modules/location/_collections/assets/country-subdivisions/peru.json +105 -105
  387. package/src/_modules/location/_collections/assets/country-subdivisions/philippines.json +69 -69
  388. package/src/_modules/location/_collections/assets/country-subdivisions/poland.json +65 -65
  389. package/src/_modules/location/_collections/assets/country-subdivisions/portugal.json +81 -81
  390. package/src/_modules/location/_collections/assets/country-subdivisions/qatar.json +29 -29
  391. package/src/_modules/location/_collections/assets/country-subdivisions/romania.json +169 -169
  392. package/src/_modules/location/_collections/assets/country-subdivisions/russian-federation.json +499 -499
  393. package/src/_modules/location/_collections/assets/country-subdivisions/rwanda.json +21 -21
  394. package/src/_modules/location/_collections/assets/country-subdivisions/saint-helena-ascension-and-tristan-da-cunha.json +13 -13
  395. package/src/_modules/location/_collections/assets/country-subdivisions/saint-kitts-and-nevis.json +9 -9
  396. package/src/_modules/location/_collections/assets/country-subdivisions/saint-lucia.json +45 -45
  397. package/src/_modules/location/_collections/assets/country-subdivisions/saint-vincent-and-the-grenadines.json +25 -25
  398. package/src/_modules/location/_collections/assets/country-subdivisions/samoa.json +45 -45
  399. package/src/_modules/location/_collections/assets/country-subdivisions/san-marino.json +37 -37
  400. package/src/_modules/location/_collections/assets/country-subdivisions/sao-tome-and-principe.json +9 -9
  401. package/src/_modules/location/_collections/assets/country-subdivisions/saudi-arabia.json +53 -53
  402. package/src/_modules/location/_collections/assets/country-subdivisions/senegal.json +57 -57
  403. package/src/_modules/location/_collections/assets/country-subdivisions/serbia.json +9 -9
  404. package/src/_modules/location/_collections/assets/country-subdivisions/seychelles.json +101 -101
  405. package/src/_modules/location/_collections/assets/country-subdivisions/sierra-leone.json +17 -17
  406. package/src/_modules/location/_collections/assets/country-subdivisions/singapore.json +21 -21
  407. package/src/_modules/location/_collections/assets/country-subdivisions/slovakia.json +33 -33
  408. package/src/_modules/location/_collections/assets/country-subdivisions/slovenia.json +841 -841
  409. package/src/_modules/location/_collections/assets/country-subdivisions/solomon-islands.json +41 -41
  410. package/src/_modules/location/_collections/assets/country-subdivisions/somalia.json +73 -73
  411. package/src/_modules/location/_collections/assets/country-subdivisions/south-africa.json +37 -37
  412. package/src/_modules/location/_collections/assets/country-subdivisions/south-sudan.json +41 -41
  413. package/src/_modules/location/_collections/assets/country-subdivisions/spain.json +346 -346
  414. package/src/_modules/location/_collections/assets/country-subdivisions/sri-lanka.json +37 -37
  415. package/src/_modules/location/_collections/assets/country-subdivisions/sudan.json +69 -69
  416. package/src/_modules/location/_collections/assets/country-subdivisions/suriname.json +41 -41
  417. package/src/_modules/location/_collections/assets/country-subdivisions/swaziland.json +17 -17
  418. package/src/_modules/location/_collections/assets/country-subdivisions/sweden.json +85 -85
  419. package/src/_modules/location/_collections/assets/country-subdivisions/switzerland.json +105 -105
  420. package/src/_modules/location/_collections/assets/country-subdivisions/syrian-arab-republic.json +57 -57
  421. package/src/_modules/location/_collections/assets/country-subdivisions/taiwan-province-of-china.json +93 -93
  422. package/src/_modules/location/_collections/assets/country-subdivisions/tajikistan.json +17 -17
  423. package/src/_modules/location/_collections/assets/country-subdivisions/tanzania-united-republic-of.json +105 -105
  424. package/src/_modules/location/_collections/assets/country-subdivisions/thailand.json +313 -313
  425. package/src/_modules/location/_collections/assets/country-subdivisions/timor-leste.json +53 -53
  426. package/src/_modules/location/_collections/assets/country-subdivisions/togo.json +21 -21
  427. package/src/_modules/location/_collections/assets/country-subdivisions/tonga.json +21 -21
  428. package/src/_modules/location/_collections/assets/country-subdivisions/trinidad-and-tobago.json +65 -65
  429. package/src/_modules/location/_collections/assets/country-subdivisions/tunisia.json +97 -97
  430. package/src/_modules/location/_collections/assets/country-subdivisions/turkey.json +325 -325
  431. package/src/_modules/location/_collections/assets/country-subdivisions/turkmenistan.json +25 -25
  432. package/src/_modules/location/_collections/assets/country-subdivisions/tuvalu.json +33 -33
  433. package/src/_modules/location/_collections/assets/country-subdivisions/uganda.json +17 -17
  434. package/src/_modules/location/_collections/assets/country-subdivisions/ukraine.json +109 -109
  435. package/src/_modules/location/_collections/assets/country-subdivisions/united-arab-emirates.json +29 -29
  436. package/src/_modules/location/_collections/assets/country-subdivisions/united-kingdom.json +1196 -1196
  437. package/src/_modules/location/_collections/assets/country-subdivisions/united-states-minor-outlying-islands.json +37 -37
  438. package/src/_modules/location/_collections/assets/country-subdivisions/united-states.json +286 -286
  439. package/src/_modules/location/_collections/assets/country-subdivisions/uruguay.json +77 -77
  440. package/src/_modules/location/_collections/assets/country-subdivisions/uzbekistan.json +57 -57
  441. package/src/_modules/location/_collections/assets/country-subdivisions/vanuatu.json +25 -25
  442. package/src/_modules/location/_collections/assets/country-subdivisions/venezuela.json +101 -101
  443. package/src/_modules/location/_collections/assets/country-subdivisions/viet-nam.json +257 -257
  444. package/src/_modules/location/_collections/assets/country-subdivisions/yemen.json +85 -85
  445. package/src/_modules/location/_collections/assets/country-subdivisions/zambia.json +37 -37
  446. package/src/_modules/location/_collections/assets/country-subdivisions/zimbabwe.json +41 -41
  447. package/src/_modules/location/_collections/loc-country-divisions.const.ts +10 -10
  448. package/src/_modules/location/_collections/loc-country-isos.const.ts +8 -8
  449. package/src/_modules/location/_collections/loc-regions.util.spec.ts +61 -61
  450. package/src/_modules/location/_collections/loc-regions.util.ts +137 -137
  451. package/src/_modules/location/_collections/loc.util.spec.ts +52 -52
  452. package/src/_modules/location/_collections/loc.util.ts +74 -74
  453. package/src/_modules/location/_enums/loc-region.enum.ts +14 -14
  454. package/src/_modules/location/_enums/loc-sub-region.enum.ts +31 -31
  455. package/src/_modules/location/_enums/loc-subdivision-region-type.enum.ts +47 -47
  456. package/src/_modules/location/_models/loc-coordinates.interface.ts +7 -7
  457. package/src/_modules/location/_models/loc-country-division.interface.ts +8 -8
  458. package/src/_modules/location/_models/loc-country-iso.interface.ts +23 -23
  459. package/src/_modules/location/_models/loc-country-phone-code.interface.ts +9 -9
  460. package/src/_modules/location/_models/loc-division-collection.interface.ts +12 -12
  461. package/src/_modules/location/_models/loc-division-region-data.interface.ts +9 -9
  462. package/src/_modules/location/_models/loc-geo-ip-location.interface.ts +27 -27
  463. package/src/_modules/location/index.ts +22 -22
  464. package/src/_modules/messaging/README.md +279 -279
  465. package/src/_modules/messaging/_collections/msg-module-settings.const.ts +46 -46
  466. package/src/_modules/messaging/_enums/msg-attachment-type.enum.ts +26 -26
  467. package/src/_modules/messaging/_enums/msg-delivery-status.enum.ts +17 -17
  468. package/src/_modules/messaging/_enums/msg-event-key.enum.ts +31 -31
  469. package/src/_modules/messaging/_enums/msg-participant-role.enum.ts +20 -20
  470. package/src/_modules/messaging/_enums/msg-provider-type.enum.ts +7 -7
  471. package/src/_modules/messaging/_enums/msg-type.enum.ts +23 -23
  472. package/src/_modules/messaging/_models/msg-attachment.interface.ts +46 -46
  473. package/src/_modules/messaging/_models/msg-conversation.data-model.spec.ts +69 -69
  474. package/src/_modules/messaging/_models/msg-conversation.data-model.ts +96 -96
  475. package/src/_modules/messaging/_models/msg-mention.interface.ts +29 -29
  476. package/src/_modules/messaging/_models/msg-message.data-model.spec.ts +79 -79
  477. package/src/_modules/messaging/_models/msg-message.data-model.ts +127 -127
  478. package/src/_modules/messaging/_models/msg-participant.interface.ts +46 -46
  479. package/src/_modules/messaging/_models/msg-reaction.interface.ts +20 -20
  480. package/src/_modules/messaging/_models/msg-thread-info.interface.ts +35 -35
  481. package/src/_modules/messaging/_modules/agent/_enums/agt-process-step-type.enum.ts +35 -35
  482. package/src/_modules/messaging/_modules/agent/_enums/agt-tool-status.enum.ts +23 -23
  483. package/src/_modules/messaging/_modules/agent/_models/agt-process-step.interface.ts +55 -55
  484. package/src/_modules/messaging/_modules/agent/_models/agt-reasoning-info.interface.ts +26 -26
  485. package/src/_modules/messaging/_modules/agent/_models/agt-tool-usage.interface.ts +37 -37
  486. package/src/_modules/messaging/_modules/agent/index.ts +8 -8
  487. package/src/_modules/messaging/index.ts +28 -28
  488. package/src/_modules/pipe/_collections/pip-transforms.const.ts +42 -42
  489. package/src/_modules/pipe/_collections/utils/pip-country-pipe.util.spec.ts +47 -47
  490. package/src/_modules/pipe/_collections/utils/pip-country-pipe.util.ts +41 -41
  491. package/src/_modules/pipe/_collections/utils/pip-custom-pipe.util.spec.ts +39 -39
  492. package/src/_modules/pipe/_collections/utils/pip-custom-pipe.util.ts +30 -30
  493. package/src/_modules/pipe/_collections/utils/pip-division-pipe.util.spec.ts +41 -41
  494. package/src/_modules/pipe/_collections/utils/pip-division-pipe.util.ts +36 -36
  495. package/src/_modules/pipe/_collections/utils/pip-json-pipe.util.spec.ts +62 -62
  496. package/src/_modules/pipe/_collections/utils/pip-json-pipe.util.ts +17 -17
  497. package/src/_modules/pipe/_collections/utils/pip-list-pipe.util.spec.ts +34 -34
  498. package/src/_modules/pipe/_collections/utils/pip-list-pipe.util.ts +25 -25
  499. package/src/_modules/pipe/_collections/utils/pip-multi-pipe-pipe.util.spec.ts +67 -67
  500. package/src/_modules/pipe/_collections/utils/pip-multi-pipe-pipe.util.ts +226 -226
  501. package/src/_modules/pipe/_collections/utils/pip-obj-key-pipe.util.spec.ts +28 -28
  502. package/src/_modules/pipe/_collections/utils/pip-obj-key-pipe.util.ts +21 -21
  503. package/src/_modules/pipe/_collections/utils/pip-range-pipe.util.spec.ts +59 -59
  504. package/src/_modules/pipe/_collections/utils/pip-range-pipe.util.ts +106 -106
  505. package/src/_modules/pipe/_collections/utils/pip-region-pipe.util.spec.ts +31 -31
  506. package/src/_modules/pipe/_collections/utils/pip-region-pipe.util.ts +35 -35
  507. package/src/_modules/pipe/_collections/utils/pip-replace-pipe.util.spec.ts +44 -44
  508. package/src/_modules/pipe/_collections/utils/pip-replace-pipe.util.ts +23 -23
  509. package/src/_modules/pipe/_collections/utils/pip-slider-pipe.util.spec.ts +21 -21
  510. package/src/_modules/pipe/_collections/utils/pip-slider-pipe.util.ts +33 -33
  511. package/src/_modules/pipe/_collections/utils/pip-smart-replace-pipe.util.spec.ts +62 -62
  512. package/src/_modules/pipe/_collections/utils/pip-smart-replace-pipe.util.ts +80 -80
  513. package/src/_modules/pipe/_enums/pip-range-pipe-setting.enum.ts +15 -15
  514. package/src/_modules/pipe/_enums/pip.enum.ts +65 -65
  515. package/src/_modules/pipe/_models/pip-multi-pipe-settings.type.ts +8 -8
  516. package/src/_modules/pipe/_models/pip-transforms.interface.ts +30 -30
  517. package/src/_modules/pipe/index.ts +30 -30
  518. package/src/_modules/socket/_enums/sck-event-key.enum.ts +21 -21
  519. package/src/_modules/socket/_models/sck-client-params.control-model.spec.ts +67 -67
  520. package/src/_modules/socket/_models/sck-client-params.control-model.ts +50 -50
  521. package/src/_modules/socket/_models/sck-socket-event.control-model.spec.ts +66 -66
  522. package/src/_modules/socket/_models/sck-socket-event.control-model.ts +172 -172
  523. package/src/_modules/socket/_services/sck-client.service-base.spec.ts +99 -99
  524. package/src/_modules/socket/_services/sck-client.service-base.ts +353 -353
  525. package/src/_modules/socket/index.ts +14 -14
  526. package/src/_modules/test/_collections/tst-module-settings.const.ts +67 -67
  527. package/src/_modules/test/index.ts +5 -5
  528. package/src/_modules/usage/_collections/usg-module-settings.const.ts +33 -33
  529. package/src/_modules/usage/_models/usg-action.control-model.spec.ts +27 -27
  530. package/src/_modules/usage/_models/usg-action.control-model.ts +28 -28
  531. package/src/_modules/usage/_models/usg-daily-usage-data.control-model.spec.ts +36 -36
  532. package/src/_modules/usage/_models/usg-daily-usage-data.control-model.ts +35 -35
  533. package/src/_modules/usage/_models/usg-data.control-model.spec.ts +41 -41
  534. package/src/_modules/usage/_models/usg-data.control-model.ts +35 -35
  535. package/src/_modules/usage/_models/usg-session.data-model.spec.ts +97 -97
  536. package/src/_modules/usage/_models/usg-session.data-model.ts +72 -72
  537. package/src/_modules/usage/index.ts +11 -11
  538. package/src/index.ts +102 -102
  539. package/tsconfig.app.json +12 -12
  540. package/tsconfig.json +31 -31
  541. package/tsconfig.test.json +16 -16
  542. package/tslint.json +153 -153
  543. package/pipeline.cicd.config.json +0 -128
@@ -1,912 +1,912 @@
1
-
2
-
3
- import { DyFM_error_defaults } from '../../_collections/constants/error-defaults.const';
4
- import { DyFM_Log } from '../../_collections/utils/log.util';
5
- import { DyFM_Error, DyFM_Error_Settings } from './error.control-model';
6
-
7
- function testFormatter(any: any): any {
8
- if (any instanceof Error) {
9
- return any;
10
- } else {
11
- return `\n${JSON.stringify(any, null, 2)}\n`;
12
- }
13
- }
14
-
15
- describe('| DyFM_Error;', (): void => {
16
- let error_base: Error;
17
- let error_0: DyFM_Error;
18
- let error_stack_1: DyFM_Error;
19
- let error_stack_withoutSubErrors_1: DyFM_Error;
20
- let error_stack_2: DyFM_Error;
21
- let error_stack_withoutSubErrors_2: DyFM_Error;
22
- let error_selfDefined: DyFM_Error;
23
-
24
- const message_base: string = '-TEST ERROR: something failed!-';
25
- const message_1: string = 'TEST ERROR MSG (1)';
26
- const message_2: string = 'TEST ERROR MSG (2)';
27
- const message_selfDefined: string = 'error.control-model.spec.js:89:29';
28
-
29
- const errorCode_0: string = 'ASD-ASD-001';
30
- const errorCode_1: string = 'ASD-ASD-002';
31
- const errorCode_2: string = 'ASD-ASD-003';
32
-
33
- const userMessage_0: string = 'DyFM_Error TEST was TEST! (0)';
34
- const userMessage_2: string = 'DyFM_Error TEST was TEST! (2)';
35
-
36
- const userMessageResult_0: string = userMessage_0 + `\n ErrorCode: ${errorCode_0}`;
37
- const userMessageResult_2: string = userMessage_2 + `\n ErrorCode: ${errorCode_2}`;
38
-
39
- const issuer: string = 'DyFM_Error TEST User';
40
- const issuerSystem: string = 'DyFM_FSM TEST';
41
- const issuerService_0: string = 'Service-0';
42
- const issuerService_1: string = 'Service-1';
43
-
44
- const additionalContent_1 = {
45
- test: 'test',
46
- test2: 'test2',
47
- };
48
- const additionalContent_2 = {
49
- test2: 'testZ',
50
- test3: 'test3',
51
- };
52
-
53
- const log: boolean = false;
54
- /* const log: boolean = true; */
55
-
56
- beforeEach(async (): Promise<void> => {
57
- error_base = new Error(message_base);
58
-
59
- error_0 = new DyFM_Error({
60
- userMessage: userMessage_0,
61
- addECToUserMsg: true,
62
- errorCode: errorCode_0,
63
- issuerSystem: issuerSystem,
64
- issuer: issuer,
65
- issuerService: issuerService_0,
66
- error: error_base,
67
- });
68
-
69
- error_stack_1 = new DyFM_Error({
70
- message: message_1,
71
- errorCode: errorCode_1,
72
- issuerService: issuerService_1,
73
- handled: true,
74
- additionalContent: additionalContent_1,
75
- error: error_0,
76
- });
77
-
78
- error_stack_withoutSubErrors_1 = {
79
- ...error_stack_1,
80
- } as DyFM_Error;
81
- error_stack_withoutSubErrors_1.errors.forEach((error: DyFM_Error): any => {
82
- const subError = { ...error } as DyFM_Error;
83
-
84
- delete subError.errors;
85
-
86
- return subError;
87
- });
88
-
89
- error_stack_2 = new DyFM_Error({
90
- message: message_2,
91
- userMessage: userMessage_2,
92
- addECToUserMsg: true,
93
- errorCode: errorCode_2,
94
- additionalContent: additionalContent_2,
95
- error: error_stack_1,
96
- });
97
-
98
- error_stack_withoutSubErrors_2 = {
99
- ...error_stack_2,
100
- } as DyFM_Error;
101
-
102
- error_stack_withoutSubErrors_2.errors = error_stack_withoutSubErrors_2.errors.map(
103
- (error: DyFM_Error): any => ({ ...error })
104
- );
105
-
106
- error_stack_withoutSubErrors_2.errors.forEach((subError: DyFM_Error): any => {
107
- delete subError.errors;
108
- });
109
-
110
- error_selfDefined = new DyFM_Error();
111
- });
112
-
113
- if (log) afterAll(async (): Promise<void> => {
114
- DyFM_Log.testLog('error_stack_2:\n', error_stack_2);
115
- DyFM_Log.testLog('error_stack_2.getFlat:\n', error_stack_2.getErrorsFlat());
116
- DyFM_Log.testLog('error_stack_2.getSimplified:\n', error_stack_2.getErrorSimplified());
117
- DyFM_Log.testLog('error_stack_withoutSubErrors_2:\n', error_stack_withoutSubErrors_2);
118
- DyFM_Log.testLog('error_selfDefined:\n', error_selfDefined);
119
- DyFM_Log.testLog('error_selfDefined.getFlat:\n', error_selfDefined.getErrorsFlat());
120
- DyFM_Log.testLog(
121
- 'error_selfDefined.getSimplified:\n', error_selfDefined.getErrorSimplified()
122
- );
123
- });
124
-
125
- describe('| should be defined;', (): void => {
126
- it('| error object', (): void => {
127
- expect(error_0).toBeDefined();
128
- });
129
-
130
- it('| error stack object', (): void => {
131
- expect(error_stack_1).toBeDefined();
132
- });
133
-
134
- it('| greater error stack object', (): void => {
135
- expect(error_stack_2).toBeDefined();
136
- });
137
-
138
- it('| self defined error object', (): void => {
139
- expect(error_selfDefined).toBeDefined();
140
- });
141
- });
142
-
143
- describe('| should be instance of DyFM_Error;', (): void => {
144
- it('| error as DyFM_Error object', (): void => {
145
- expect(error_0).toBeInstanceOf(DyFM_Error);
146
- });
147
-
148
- it('| error stack as DyFM_Error object', (): void => {
149
- expect(error_stack_1).toBeInstanceOf(DyFM_Error);
150
- });
151
-
152
- it('| greater error stack as DyFM_Error object', (): void => {
153
- expect(error_stack_2).toBeInstanceOf(DyFM_Error);
154
- });
155
-
156
- it('| self defined error as DyFM_Error object', (): void => {
157
- expect(error_selfDefined).toBeInstanceOf(DyFM_Error);
158
- });
159
- });
160
-
161
- describe('| should have the proper _errorCode;', (): void => {
162
- it('| on error_0', (): void => {
163
- expect(error_0._errorCode).toBe(errorCode_0);
164
- });
165
-
166
- it('| on error_stack_1', (): void => {
167
- expect(error_stack_1._errorCode).toBe(errorCode_0);
168
- });
169
-
170
- it('| on error_stack_2', (): void => {
171
- expect(error_stack_2._errorCode).toBe(errorCode_0);
172
- });
173
-
174
- it('| on self defined error', (): void => {
175
- expect(error_selfDefined._errorCode).toBe(DyFM_error_defaults.errorCode);
176
- });
177
- });
178
-
179
- describe('| should have the proper _errorCodes;', (): void => {
180
- it('| on error_0', (): void => {
181
- expect(error_0._errorCodes).toEqual([ errorCode_0 ]);
182
- });
183
-
184
- it('| on error_stack_1', (): void => {
185
- expect(error_stack_1._errorCodes).toEqual([ errorCode_0, errorCode_1 ]);
186
- });
187
-
188
- it('| on error_stack_2', (): void => {
189
- expect(error_stack_2._errorCodes).toEqual([ errorCode_0, errorCode_1, errorCode_2 ]);
190
- });
191
-
192
- it('| on self defined error', (): void => {
193
- expect(error_selfDefined._errorCodes).toEqual([ DyFM_error_defaults.errorCode ]);
194
- });
195
- });
196
-
197
- describe('| should have the proper _message;', (): void => {
198
- it('| on error_0', (): void => {
199
- expect(error_0._message).toBe(message_base);
200
- });
201
-
202
- it('| on error_stack_1', (): void => {
203
- expect(error_stack_1._message).toBe(message_base);
204
- });
205
-
206
- it('| on error_stack_2', (): void => {
207
- expect(error_stack_2._message).toBe(message_base);
208
- });
209
-
210
- it('| on self defined error (stack)', (): void => {
211
- expect(
212
- error_selfDefined._message.includes(message_selfDefined)
213
- ).withContext(
214
- `"${error_selfDefined._message}"` +
215
- '\n not contains' +
216
- `\n"${message_selfDefined}"` +
217
- '"\n '
218
- ).toBe(true);
219
- });
220
-
221
- it('| on self defined error (flag)', (): void => {
222
- expect(
223
- error_selfDefined._message.includes(DyFM_error_defaults.message)
224
- ).withContext(
225
- `"${error_selfDefined._message}"` +
226
- '\n not contains' +
227
- `\n"${DyFM_error_defaults.message}"` +
228
- '"\n '
229
- ).toBe(true);
230
- });
231
- });
232
-
233
- describe('| should have the proper _messages;', (): void => {
234
- it('| on error_0', (): void => {
235
- expect(error_0._messages).toEqual([ message_base ]);
236
- });
237
-
238
- it('| on error_stack_1', (): void => {
239
- expect(error_stack_1._messages).toEqual([ message_base, message_1 ]);
240
- });
241
-
242
- it('| on error_stack_2', (): void => {
243
- expect(error_stack_2._messages).toEqual([ message_base, message_1, message_2 ]);
244
- });
245
-
246
- it('| on self defined error (stack)', (): void => {
247
- expect(
248
- error_selfDefined._messages.length === 1 &&
249
- error_selfDefined._messages?.[0]?.includes(message_selfDefined)
250
- ).withContext(
251
- `"${error_selfDefined._messages?.[0]}"` +
252
- '\n not contains' +
253
- `\n"${message_selfDefined}"` +
254
- '"\n '
255
- ).toBe(true);
256
- });
257
-
258
- it('| on self defined error (flag)', (): void => {
259
- expect(
260
- error_selfDefined._messages.length === 1 &&
261
- error_selfDefined._messages?.[0]?.includes(DyFM_error_defaults.message)
262
- ).withContext(
263
- `"${error_selfDefined._messages?.[0]}"` +
264
- '\n not contains' +
265
- `\n"${DyFM_error_defaults.message}"` +
266
- '"\n '
267
- ).toBe(true);
268
- });
269
- });
270
-
271
- describe('| getSemanticMessage;', (): void => {
272
- it('| on non-DyFM_Error returns getErrorMessage only (no parentheses)', (): void => {
273
- const result: string = DyFM_Error.getSemanticMessage(error_base);
274
- expect(result).toBe(message_base);
275
- expect(result).not.toContain('(');
276
- });
277
-
278
- it('| on DyFM_Error with single _messages returns our message only', (): void => {
279
- const result: string = DyFM_Error.getSemanticMessage(error_0);
280
- expect(result).toBe(message_base);
281
- });
282
-
283
- it('| on DyFM_Error chain returns string containing outer message and root in parentheses when different', (): void => {
284
- const rootMsg: string = 'root-message';
285
- const outerMsg: string = 'outer-message';
286
- const errorInner: DyFM_Error = new DyFM_Error({
287
- message: rootMsg,
288
- error: new Error(),
289
- });
290
- const errorOuter: DyFM_Error = new DyFM_Error({
291
- message: outerMsg,
292
- errorCode: 'CUSTOM-SEM-001',
293
- error: errorInner,
294
- });
295
- expect(errorOuter._messages?.length).toBeGreaterThan(1);
296
- expect(errorOuter._messages?.[0]).toBe(rootMsg);
297
- expect(errorOuter._message).toBe(outerMsg);
298
- const result: string = DyFM_Error.getSemanticMessage(errorOuter);
299
- expect(result).toBe(`${outerMsg} (${rootMsg})`);
300
- });
301
-
302
- it('| on error_stack_2 returns main message (first equals our message so no parentheses)', (): void => {
303
- const result: string = DyFM_Error.getSemanticMessage(error_stack_2);
304
- expect(result).toBe(message_base);
305
- });
306
- });
307
-
308
- describe('| should have the proper __userMessage;', (): void => {
309
- it('| on error_0', (): void => {
310
- expect(error_0.__userMessage).toBe(userMessageResult_0);
311
- });
312
-
313
- it('| on error_stack_1', (): void => {
314
- expect(error_stack_1.__userMessage).toBe(userMessageResult_0);
315
- });
316
-
317
- it('| on error_stack_2', (): void => {
318
- expect(error_stack_2.__userMessage).toBe(userMessageResult_0);
319
- });
320
-
321
- it('| on self defined error', (): void => {
322
- expect(error_selfDefined.__userMessage).toBeUndefined();
323
- });
324
- });
325
-
326
- describe('| should have the proper __userMessages;', (): void => {
327
- it('| on error_0', (): void => {
328
- expect(error_0.__userMessages).toEqual([ userMessageResult_0 ]);
329
- });
330
-
331
- it('| on error_stack_1', (): void => {
332
- expect(error_stack_1.__userMessages).toEqual(
333
- [ userMessageResult_0, DyFM_error_defaults.userMessage ]
334
- );
335
- });
336
-
337
- it('| on error_stack_2', (): void => {
338
- expect(error_stack_2.__userMessages).toEqual(
339
- [ userMessageResult_0, DyFM_error_defaults.userMessage, userMessageResult_2 ]
340
- );
341
- });
342
-
343
- it('| on self defined error', (): void => {
344
- expect(error_selfDefined.__userMessages).toEqual([ DyFM_error_defaults.userMessage ]);
345
- });
346
- });
347
-
348
- describe('| should have proper error;', (): void => {
349
- it('| on error_0', (): void => {
350
- expect(testFormatter(error_0.error)).toBe(
351
- testFormatter(error_base)
352
- );
353
- });
354
-
355
- it('| on error_stack_1', (): void => {
356
- expect(testFormatter(error_stack_1.error)).toBe(
357
- testFormatter(error_base)
358
- );
359
- });
360
-
361
- it('| on error_stack_2', (): void => {
362
- expect(testFormatter(error_stack_2.error)).toBe(
363
- testFormatter(error_base)
364
- );
365
- });
366
-
367
- it('| on self defined error', (): void => {
368
- expect(testFormatter(error_selfDefined.error)).toBeDefined();
369
- });
370
- });
371
-
372
- describe('| should have the proper errors;', (): void => {
373
- it('| on error_0', (): void => {
374
- expect(error_0.errors).toEqual([ error_base ]);
375
- });
376
-
377
- it('| on error_stack_1', (): void => {
378
- const error_0_withoutSubErrors = { ...error_0 } as DyFM_Error;
379
-
380
- delete error_0_withoutSubErrors.errors;
381
- delete error_0_withoutSubErrors.additionalContent;
382
-
383
- expect(testFormatter(error_stack_1.errors)).toEqual(
384
- testFormatter([ error_base, error_0_withoutSubErrors ])
385
- );
386
- });
387
-
388
- it('| on error_stack_2', (): void => {
389
- const error_0_withoutSubErrors = { ...error_0 } as DyFM_Error;
390
- const error_stack_1_withoutSubErrors = { ...error_stack_1 } as DyFM_Error;
391
-
392
- delete error_0_withoutSubErrors.errors;
393
- delete error_0_withoutSubErrors.additionalContent;
394
- delete error_stack_1_withoutSubErrors.errors;
395
- delete error_stack_1_withoutSubErrors.additionalContent;
396
-
397
- expect(testFormatter(error_stack_2.errors)).toEqual(
398
- testFormatter([ error_base, error_0_withoutSubErrors, error_stack_1_withoutSubErrors ])
399
- );
400
- });
401
-
402
- it('| on self defined error', (): void => {
403
- expect(error_selfDefined?.errors?.length).toBe(1);
404
- });
405
- });
406
-
407
- describe('| should have proper handled;', (): void => {
408
- it('| on error_0', (): void => {
409
- expect(error_0.___handled).toBe(false);
410
- });
411
-
412
- it('| on error_stack_1', (): void => {
413
- expect(error_stack_1.___handled).toBe(true);
414
- });
415
-
416
- it('| on error_stack_2', (): void => {
417
- expect(error_stack_2.___handled).toBe(true);
418
- });
419
-
420
- it('| on self defined error', (): void => {
421
- expect(error_selfDefined.___handled).toBe(false);
422
- });
423
- });
424
-
425
- describe('| should have status: undefined;', (): void => {
426
- it('| on error_0', (): void => {
427
- expect(error_0.___status).toBe(undefined);
428
- });
429
-
430
- it('| on error_stack_1', (): void => {
431
- expect(error_stack_1.___status).toBe(undefined);
432
- });
433
-
434
- it('| on error_stack_2', (): void => {
435
- expect(error_stack_2.___status).toBe(undefined);
436
- });
437
-
438
- it('| on self defined error', (): void => {
439
- expect(error_selfDefined.___status).toBe(undefined);
440
- });
441
- });
442
-
443
- describe('| should have the proper issuer;', (): void => {
444
- it('| on error_0', (): void => {
445
- expect(error_0.___issuer).toBe(issuer);
446
- });
447
-
448
- it('| on error_stack_1', (): void => {
449
- expect(error_stack_1.___issuer).toBe(issuer);
450
- });
451
-
452
- it('| on error_stack_2', (): void => {
453
- expect(error_stack_2.___issuer).toBe(issuer);
454
- });
455
-
456
- it('| on self defined error', (): void => {
457
- expect(error_selfDefined.___issuer).toBe(DyFM_error_defaults.issuer);
458
- });
459
- });
460
-
461
- describe('| should have get proper additionalContent;', (): void => {
462
- it('| on error_0', (): void => {
463
- expect(error_0.additionalContent).toEqual({});
464
- });
465
-
466
- it('| on error_stack_1', (): void => {
467
- expect(error_stack_1.additionalContent).toEqual(additionalContent_1);
468
- });
469
-
470
- it('| on error_stack_2', (): void => {
471
- expect(error_stack_2.additionalContent).toEqual({
472
- ...additionalContent_1,
473
- ...additionalContent_2,
474
- });
475
- });
476
-
477
- it('| on self defined error', (): void => {
478
- expect(error_selfDefined.additionalContent).toEqual({});
479
- });
480
- });
481
-
482
- describe('| should have the proper issuerSystem;', (): void => {
483
- it('| on error_0', (): void => {
484
- expect(error_0.___issuerSystem).toBe(issuerSystem);
485
- });
486
-
487
- it('| on error_stack_1', (): void => {
488
- expect(error_stack_1.___issuerSystem).toBe(issuerSystem);
489
- });
490
-
491
- it('| on error_stack_2', (): void => {
492
- expect(error_stack_2.___issuerSystem).toBe(issuerSystem);
493
- });
494
-
495
- it('| on self defined error', (): void => {
496
- expect(error_selfDefined.___issuerSystem).toBe(DyFM_error_defaults.issuerSystem);
497
- });
498
- });
499
-
500
- describe('| should have the proper issuerService;', (): void => {
501
- it('| on error_0', (): void => {
502
- expect(error_0.___issuerService).toBe(issuerService_0);
503
- });
504
-
505
- it('| on error_stack_1', (): void => {
506
- expect(error_stack_1.___issuerService).toBe(issuerService_1);
507
- });
508
-
509
- it('| on error_stack_2', (): void => {
510
- expect(error_stack_2.___issuerService).toBe(issuerService_1);
511
- });
512
-
513
- it('| on self defined error', (): void => {
514
- expect(error_selfDefined.___issuerService).toBe(DyFM_error_defaults.issuerService);
515
- });
516
- });
517
-
518
- describe('| should have get proper simplified;', (): void => {
519
- let simplified: DyFM_Error_Settings;
520
-
521
- describe('| on error_0;', (): void => {
522
- beforeEach((): void => {
523
- simplified = error_0.getErrorSimplified();
524
- });
525
-
526
- it('| should be defined', (): void => {
527
- expect(simplified).toBeDefined();
528
- });
529
-
530
- it('| should have errorCode', (): void => {
531
- expect(simplified.errorCode).toBeDefined();
532
- });
533
-
534
- it('| should have message', (): void => {
535
- expect(simplified.message).toBeDefined();
536
- });
537
-
538
- it('| should have userMessage', (): void => {
539
- expect(simplified.userMessage).toBeDefined();
540
- });
541
-
542
- it('| should have stack', (): void => {
543
- expect(simplified.stack).toBeDefined();
544
- });
545
-
546
- it('| should not have error', (): void => {
547
- expect(simplified.error).toBeUndefined();
548
- });
549
-
550
- it('| should not have errors', (): void => {
551
- expect(simplified.errors).toBeUndefined();
552
- });
553
-
554
- it('| should not have simplified.error.error', (): void => {
555
- expect((simplified.error as DyFM_Error)?.error).toBeUndefined();
556
- });
557
-
558
- it('| should not have simplified.error.errors', (): void => {
559
- expect((simplified.error as DyFM_Error)?.errors).toBeUndefined();
560
- });
561
- });
562
-
563
- describe('| on error_stack_1;', (): void => {
564
- beforeEach((): void => {
565
- simplified = error_stack_1.getErrorSimplified();
566
- });
567
-
568
- it('| should be defined', (): void => {
569
- expect(simplified).toBeDefined();
570
- });
571
-
572
- it('| should have errorCode', (): void => {
573
- expect(simplified.errorCode).toBeDefined();
574
- });
575
-
576
- it('| should have message', (): void => {
577
- expect(simplified.message).toBeDefined();
578
- });
579
-
580
- it('| should have userMessage', (): void => {
581
- expect(simplified.userMessage).toBeDefined();
582
- });
583
-
584
- it('| should have stack', (): void => {
585
- expect(simplified.stack).toBeDefined();
586
- });
587
-
588
- it('| should not have error', (): void => {
589
- expect(simplified.error).toBeUndefined();
590
- });
591
-
592
- it('| should not have errors', (): void => {
593
- expect(simplified.errors).toBeUndefined();
594
- });
595
-
596
- it('| should not have simplified.error.error', (): void => {
597
- expect((simplified.error as DyFM_Error)?.error).toBeUndefined();
598
- });
599
-
600
- it('| should not have simplified.error.errors', (): void => {
601
- expect((simplified.error as DyFM_Error)?.errors).toBeUndefined();
602
- });
603
- });
604
-
605
- describe('| on error_stack_2;', (): void => {
606
- beforeEach((): void => {
607
- simplified = error_stack_2.getErrorSimplified();
608
- });
609
-
610
- it('| should be defined', (): void => {
611
- expect(simplified).toBeDefined();
612
- });
613
-
614
- it('| should have errorCode', (): void => {
615
- expect(simplified.errorCode).toBeDefined();
616
- });
617
-
618
- it('| should have message', (): void => {
619
- expect(simplified.message).toBeDefined();
620
- });
621
-
622
- it('| should have userMessage', (): void => {
623
- expect(simplified.userMessage).toBeDefined();
624
- });
625
-
626
- it('| should have stack', (): void => {
627
- expect(simplified.stack).toBeDefined();
628
- });
629
-
630
- it('| should not have error', (): void => {
631
- expect(simplified.error).toBeUndefined();
632
- });
633
-
634
- it('| should not have errors', (): void => {
635
- expect(simplified.errors).toBeUndefined();
636
- });
637
-
638
- it('| should not have simplified.error.error', (): void => {
639
- expect((simplified.error as DyFM_Error)?.error).toBeUndefined();
640
- });
641
-
642
- it('| should not have simplified.error.errors', (): void => {
643
- expect((simplified.error as DyFM_Error)?.errors).toBeUndefined();
644
- });
645
- });
646
-
647
- describe('| on self defined error;', (): void => {
648
- beforeEach((): void => {
649
- simplified = error_selfDefined.getErrorSimplified();
650
- });
651
-
652
- it('| should be defined', (): void => {
653
- expect(simplified).toBeDefined();
654
- });
655
-
656
- it('| should have errorCode', (): void => {
657
- expect(simplified.errorCode).toBeDefined();
658
- });
659
-
660
- it('| should have message', (): void => {
661
- expect(simplified.message).toBeDefined();
662
- });
663
-
664
- it('| should not have userMessage', (): void => {
665
- expect(simplified.userMessage).toBeUndefined();
666
- });
667
-
668
- it('| should have stack', (): void => {
669
- expect(simplified.stack).toBeDefined();
670
- });
671
-
672
- it('| should not have error', (): void => {
673
- expect(simplified.error).toBeUndefined();
674
- });
675
-
676
- it('| should not have errors', (): void => {
677
- expect(simplified.errors).toBeUndefined();
678
- });
679
-
680
- it('| should not have simplified.error.error', (): void => {
681
- expect((simplified.error as DyFM_Error)?.error).toBeUndefined();
682
- });
683
-
684
- it('| should not have simplified.error.errors', (): void => {
685
- expect((simplified.error as DyFM_Error)?.errors).toBeUndefined();
686
- });
687
- });
688
- });
689
-
690
- describe('| should have get proper flat;', (): void => {
691
- let flat;
692
-
693
- describe('| on error_0;', (): void => {
694
- beforeEach((): void => {
695
- flat = error_0.getErrorsFlat();
696
- });
697
-
698
- it('| should be defined', (): void => {
699
- expect(flat).toBeDefined();
700
- });
701
-
702
- it('| should have error', (): void => {
703
- expect(flat.error).toBeDefined();
704
- });
705
-
706
- describe('| errors...;', (): void => {
707
- it('| should have errors', (): void => {
708
- expect(flat?.errors).toBeDefined();
709
- });
710
-
711
- it('| should have 1 errors', (): void => {
712
- expect(flat?.errors?.length).toBe(1);
713
- });
714
-
715
- flat?.errors?.forEach((error: DyFM_Error, index: number): void => {
716
- describe(`on error[${index}];`, (): void => {
717
- it('| should be', (): void => {
718
- expect(error).toBeDefined();
719
- });
720
-
721
- it(`should have error[${index}].error`, (): void => {
722
- expect(error.error).toBeDefined();
723
- });
724
-
725
- it(`should not have error[${index}].errors`, (): void => {
726
- expect(error.errors).toBeUndefined();
727
- });
728
-
729
- it(`should not have error[${index}].error.error`, (): void => {
730
- expect((error.error as DyFM_Error)?.error).toBeUndefined();
731
- });
732
-
733
- it(`should not have error[${index}].error.errors`, (): void => {
734
- expect((error.error as DyFM_Error)?.errors).toBeUndefined();
735
- });
736
- });
737
- });
738
- });
739
- });
740
-
741
- describe('| on error_stack_1;', (): void => {
742
- beforeEach((): void => {
743
- flat = error_stack_1.getErrorsFlat();
744
- });
745
-
746
- it('| should be defined', (): void => {
747
- expect(flat).toBeDefined();
748
- });
749
-
750
- it('| should have error', (): void => {
751
- expect(flat.error).toBeDefined();
752
- });
753
-
754
- describe('| errors...;', (): void => {
755
- it('| should have errors', (): void => {
756
- expect(flat?.errors).toBeDefined();
757
- });
758
-
759
- it('| should have 2 errors', (): void => {
760
- expect(flat?.errors?.length).toBe(2);
761
- });
762
-
763
- flat?.errors?.forEach((error: DyFM_Error, index: number): void => {
764
- describe(`on error[${index}];`, (): void => {
765
- it('| should be', (): void => {
766
- expect(error).toBeDefined();
767
- });
768
-
769
- it(`should have error[${index}].error`, (): void => {
770
- expect(error.error).toBeDefined();
771
- });
772
-
773
- it(`should not have error[${index}].errors`, (): void => {
774
- expect(error.errors).toBeUndefined();
775
- });
776
-
777
- it('| should not have error[${index}].error.error', (): void => {
778
- expect((error.error as DyFM_Error)?.error).toBeUndefined();
779
- });
780
-
781
- it('| should not have error[${index}].error.errors', (): void => {
782
- expect((error.error as DyFM_Error)?.errors).toBeUndefined();
783
- });
784
- });
785
- });
786
- });
787
- });
788
-
789
- describe('| on error_stack_2;', (): void => {
790
- beforeEach((): void => {
791
- flat = error_stack_2.getErrorsFlat();
792
- });
793
-
794
- it('| should be defined', (): void => {
795
- expect(flat).toBeDefined();
796
- });
797
-
798
- it('| should have error', (): void => {
799
- expect(flat.error).toBeDefined();
800
- });
801
-
802
- describe('| errors...;', (): void => {
803
- it('| should have errors', (): void => {
804
- expect(flat?.errors).toBeDefined();
805
- });
806
-
807
- it('| should have 3 errors', (): void => {
808
- expect(flat?.errors?.length).toBe(3);
809
- });
810
-
811
- flat?.errors?.forEach((error: DyFM_Error, index: number): void => {
812
- describe(`on error[${index}];`, (): void => {
813
- it('| should be', (): void => {
814
- expect(error).toBeDefined();
815
- });
816
-
817
- it(`should have error[${index}].error`, (): void => {
818
- expect(error.error).toBeDefined();
819
- });
820
-
821
- it(`should not have error[${index}].errors`, (): void => {
822
- expect(error.errors).toBeUndefined();
823
- });
824
-
825
- it(`should not have error[${index}].error.error`, (): void => {
826
- expect((error.error as DyFM_Error)?.error).toBeUndefined();
827
- });
828
-
829
- it(`should not have error[${index}].error.errors`, (): void => {
830
- expect((error.error as DyFM_Error)?.errors).toBeUndefined();
831
- });
832
- });
833
- });
834
- });
835
- });
836
-
837
- describe('| on self defined error;', (): void => {
838
- beforeEach((): void => {
839
- flat = error_selfDefined.getErrorsFlat();
840
- });
841
-
842
- it('| should be defined', (): void => {
843
- expect(flat).toBeDefined();
844
- });
845
-
846
- it('| should have error', (): void => {
847
- expect(flat.error).toBeDefined();
848
- });
849
-
850
- describe('| errors...;', (): void => {
851
- it('| should have errors', (): void => {
852
- expect(flat?.errors).toBeDefined();
853
- });
854
-
855
- it('| should have 1 errors', (): void => {
856
- expect(flat?.errors?.length).toBe(1);
857
- });
858
-
859
- flat?.errors?.forEach((error: DyFM_Error, index: number): void => {
860
- describe(`on error[${index}];`, (): void => {
861
- it('| should be', (): void => {
862
- expect(error).toBeDefined();
863
- });
864
-
865
- it(`should have error[${index}].error`, (): void => {
866
- expect(error.error).toBeDefined();
867
- });
868
-
869
- it(`should not have error[${index}].errors`, (): void => {
870
- expect(error.errors).toBeUndefined();
871
- });
872
-
873
- it(`should not have error[${index}].error.error`, (): void => {
874
- expect((error.error as DyFM_Error)?.error).toBeUndefined();
875
- });
876
-
877
- it(`should not have error[${index}].error.errors`, (): void => {
878
- expect((error.error as DyFM_Error)?.errors).toBeUndefined();
879
- });
880
- });
881
- });
882
- });
883
- });
884
-
885
- describe('| stack', (): void => {
886
- it('| error lvl3 should have the stack from the first', (): void => {
887
- const error_lvl1 = new Error('error_lvl1');
888
-
889
- const error_lvl2 = new DyFM_Error({
890
- error: error_lvl1,
891
- });
892
-
893
- const error_lvl3 = new DyFM_Error({
894
- error: error_lvl2,
895
- });
896
-
897
- expect(error_lvl3.stack).toBe(error_lvl1.stack);
898
- });
899
- });
900
- });
901
-
902
- describe('| logSimple;', (): void => {
903
- it('| should not fail', (): void => {
904
- const error = new DyFM_Error({
905
- error: new Error('error'),
906
- });
907
-
908
- expect(error.logSimple('test')).toBeUndefined();
909
- });
910
- });
911
- });
912
-
1
+
2
+
3
+ import { DyFM_error_defaults } from '../../_collections/constants/error-defaults.const';
4
+ import { DyFM_Log } from '../../_collections/utils/log.util';
5
+ import { DyFM_Error, DyFM_Error_Settings } from './error.control-model';
6
+
7
+ function testFormatter(any: any): any {
8
+ if (any instanceof Error) {
9
+ return any;
10
+ } else {
11
+ return `\n${JSON.stringify(any, null, 2)}\n`;
12
+ }
13
+ }
14
+
15
+ describe('| DyFM_Error;', (): void => {
16
+ let error_base: Error;
17
+ let error_0: DyFM_Error;
18
+ let error_stack_1: DyFM_Error;
19
+ let error_stack_withoutSubErrors_1: DyFM_Error;
20
+ let error_stack_2: DyFM_Error;
21
+ let error_stack_withoutSubErrors_2: DyFM_Error;
22
+ let error_selfDefined: DyFM_Error;
23
+
24
+ const message_base: string = '-TEST ERROR: something failed!-';
25
+ const message_1: string = 'TEST ERROR MSG (1)';
26
+ const message_2: string = 'TEST ERROR MSG (2)';
27
+ const message_selfDefined: string = 'error.control-model.spec.js:89:29';
28
+
29
+ const errorCode_0: string = 'ASD-ASD-001';
30
+ const errorCode_1: string = 'ASD-ASD-002';
31
+ const errorCode_2: string = 'ASD-ASD-003';
32
+
33
+ const userMessage_0: string = 'DyFM_Error TEST was TEST! (0)';
34
+ const userMessage_2: string = 'DyFM_Error TEST was TEST! (2)';
35
+
36
+ const userMessageResult_0: string = userMessage_0 + `\n ErrorCode: ${errorCode_0}`;
37
+ const userMessageResult_2: string = userMessage_2 + `\n ErrorCode: ${errorCode_2}`;
38
+
39
+ const issuer: string = 'DyFM_Error TEST User';
40
+ const issuerSystem: string = 'DyFM_FSM TEST';
41
+ const issuerService_0: string = 'Service-0';
42
+ const issuerService_1: string = 'Service-1';
43
+
44
+ const additionalContent_1 = {
45
+ test: 'test',
46
+ test2: 'test2',
47
+ };
48
+ const additionalContent_2 = {
49
+ test2: 'testZ',
50
+ test3: 'test3',
51
+ };
52
+
53
+ const log: boolean = false;
54
+ /* const log: boolean = true; */
55
+
56
+ beforeEach(async (): Promise<void> => {
57
+ error_base = new Error(message_base);
58
+
59
+ error_0 = new DyFM_Error({
60
+ userMessage: userMessage_0,
61
+ addECToUserMsg: true,
62
+ errorCode: errorCode_0,
63
+ issuerSystem: issuerSystem,
64
+ issuer: issuer,
65
+ issuerService: issuerService_0,
66
+ error: error_base,
67
+ });
68
+
69
+ error_stack_1 = new DyFM_Error({
70
+ message: message_1,
71
+ errorCode: errorCode_1,
72
+ issuerService: issuerService_1,
73
+ handled: true,
74
+ additionalContent: additionalContent_1,
75
+ error: error_0,
76
+ });
77
+
78
+ error_stack_withoutSubErrors_1 = {
79
+ ...error_stack_1,
80
+ } as DyFM_Error;
81
+ error_stack_withoutSubErrors_1.errors.forEach((error: DyFM_Error): any => {
82
+ const subError = { ...error } as DyFM_Error;
83
+
84
+ delete subError.errors;
85
+
86
+ return subError;
87
+ });
88
+
89
+ error_stack_2 = new DyFM_Error({
90
+ message: message_2,
91
+ userMessage: userMessage_2,
92
+ addECToUserMsg: true,
93
+ errorCode: errorCode_2,
94
+ additionalContent: additionalContent_2,
95
+ error: error_stack_1,
96
+ });
97
+
98
+ error_stack_withoutSubErrors_2 = {
99
+ ...error_stack_2,
100
+ } as DyFM_Error;
101
+
102
+ error_stack_withoutSubErrors_2.errors = error_stack_withoutSubErrors_2.errors.map(
103
+ (error: DyFM_Error): any => ({ ...error })
104
+ );
105
+
106
+ error_stack_withoutSubErrors_2.errors.forEach((subError: DyFM_Error): any => {
107
+ delete subError.errors;
108
+ });
109
+
110
+ error_selfDefined = new DyFM_Error();
111
+ });
112
+
113
+ if (log) afterAll(async (): Promise<void> => {
114
+ DyFM_Log.testLog('error_stack_2:\n', error_stack_2);
115
+ DyFM_Log.testLog('error_stack_2.getFlat:\n', error_stack_2.getErrorsFlat());
116
+ DyFM_Log.testLog('error_stack_2.getSimplified:\n', error_stack_2.getErrorSimplified());
117
+ DyFM_Log.testLog('error_stack_withoutSubErrors_2:\n', error_stack_withoutSubErrors_2);
118
+ DyFM_Log.testLog('error_selfDefined:\n', error_selfDefined);
119
+ DyFM_Log.testLog('error_selfDefined.getFlat:\n', error_selfDefined.getErrorsFlat());
120
+ DyFM_Log.testLog(
121
+ 'error_selfDefined.getSimplified:\n', error_selfDefined.getErrorSimplified()
122
+ );
123
+ });
124
+
125
+ describe('| should be defined;', (): void => {
126
+ it('| error object', (): void => {
127
+ expect(error_0).toBeDefined();
128
+ });
129
+
130
+ it('| error stack object', (): void => {
131
+ expect(error_stack_1).toBeDefined();
132
+ });
133
+
134
+ it('| greater error stack object', (): void => {
135
+ expect(error_stack_2).toBeDefined();
136
+ });
137
+
138
+ it('| self defined error object', (): void => {
139
+ expect(error_selfDefined).toBeDefined();
140
+ });
141
+ });
142
+
143
+ describe('| should be instance of DyFM_Error;', (): void => {
144
+ it('| error as DyFM_Error object', (): void => {
145
+ expect(error_0).toBeInstanceOf(DyFM_Error);
146
+ });
147
+
148
+ it('| error stack as DyFM_Error object', (): void => {
149
+ expect(error_stack_1).toBeInstanceOf(DyFM_Error);
150
+ });
151
+
152
+ it('| greater error stack as DyFM_Error object', (): void => {
153
+ expect(error_stack_2).toBeInstanceOf(DyFM_Error);
154
+ });
155
+
156
+ it('| self defined error as DyFM_Error object', (): void => {
157
+ expect(error_selfDefined).toBeInstanceOf(DyFM_Error);
158
+ });
159
+ });
160
+
161
+ describe('| should have the proper _errorCode;', (): void => {
162
+ it('| on error_0', (): void => {
163
+ expect(error_0._errorCode).toBe(errorCode_0);
164
+ });
165
+
166
+ it('| on error_stack_1', (): void => {
167
+ expect(error_stack_1._errorCode).toBe(errorCode_0);
168
+ });
169
+
170
+ it('| on error_stack_2', (): void => {
171
+ expect(error_stack_2._errorCode).toBe(errorCode_0);
172
+ });
173
+
174
+ it('| on self defined error', (): void => {
175
+ expect(error_selfDefined._errorCode).toBe(DyFM_error_defaults.errorCode);
176
+ });
177
+ });
178
+
179
+ describe('| should have the proper _errorCodes;', (): void => {
180
+ it('| on error_0', (): void => {
181
+ expect(error_0._errorCodes).toEqual([ errorCode_0 ]);
182
+ });
183
+
184
+ it('| on error_stack_1', (): void => {
185
+ expect(error_stack_1._errorCodes).toEqual([ errorCode_0, errorCode_1 ]);
186
+ });
187
+
188
+ it('| on error_stack_2', (): void => {
189
+ expect(error_stack_2._errorCodes).toEqual([ errorCode_0, errorCode_1, errorCode_2 ]);
190
+ });
191
+
192
+ it('| on self defined error', (): void => {
193
+ expect(error_selfDefined._errorCodes).toEqual([ DyFM_error_defaults.errorCode ]);
194
+ });
195
+ });
196
+
197
+ describe('| should have the proper _message;', (): void => {
198
+ it('| on error_0', (): void => {
199
+ expect(error_0._message).toBe(message_base);
200
+ });
201
+
202
+ it('| on error_stack_1', (): void => {
203
+ expect(error_stack_1._message).toBe(message_base);
204
+ });
205
+
206
+ it('| on error_stack_2', (): void => {
207
+ expect(error_stack_2._message).toBe(message_base);
208
+ });
209
+
210
+ it('| on self defined error (stack)', (): void => {
211
+ expect(
212
+ error_selfDefined._message.includes(message_selfDefined)
213
+ ).withContext(
214
+ `"${error_selfDefined._message}"` +
215
+ '\n not contains' +
216
+ `\n"${message_selfDefined}"` +
217
+ '"\n '
218
+ ).toBe(true);
219
+ });
220
+
221
+ it('| on self defined error (flag)', (): void => {
222
+ expect(
223
+ error_selfDefined._message.includes(DyFM_error_defaults.message)
224
+ ).withContext(
225
+ `"${error_selfDefined._message}"` +
226
+ '\n not contains' +
227
+ `\n"${DyFM_error_defaults.message}"` +
228
+ '"\n '
229
+ ).toBe(true);
230
+ });
231
+ });
232
+
233
+ describe('| should have the proper _messages;', (): void => {
234
+ it('| on error_0', (): void => {
235
+ expect(error_0._messages).toEqual([ message_base ]);
236
+ });
237
+
238
+ it('| on error_stack_1', (): void => {
239
+ expect(error_stack_1._messages).toEqual([ message_base, message_1 ]);
240
+ });
241
+
242
+ it('| on error_stack_2', (): void => {
243
+ expect(error_stack_2._messages).toEqual([ message_base, message_1, message_2 ]);
244
+ });
245
+
246
+ it('| on self defined error (stack)', (): void => {
247
+ expect(
248
+ error_selfDefined._messages.length === 1 &&
249
+ error_selfDefined._messages?.[0]?.includes(message_selfDefined)
250
+ ).withContext(
251
+ `"${error_selfDefined._messages?.[0]}"` +
252
+ '\n not contains' +
253
+ `\n"${message_selfDefined}"` +
254
+ '"\n '
255
+ ).toBe(true);
256
+ });
257
+
258
+ it('| on self defined error (flag)', (): void => {
259
+ expect(
260
+ error_selfDefined._messages.length === 1 &&
261
+ error_selfDefined._messages?.[0]?.includes(DyFM_error_defaults.message)
262
+ ).withContext(
263
+ `"${error_selfDefined._messages?.[0]}"` +
264
+ '\n not contains' +
265
+ `\n"${DyFM_error_defaults.message}"` +
266
+ '"\n '
267
+ ).toBe(true);
268
+ });
269
+ });
270
+
271
+ describe('| getSemanticMessage;', (): void => {
272
+ it('| on non-DyFM_Error returns getErrorMessage only (no parentheses)', (): void => {
273
+ const result: string = DyFM_Error.getSemanticMessage(error_base);
274
+ expect(result).toBe(message_base);
275
+ expect(result).not.toContain('(');
276
+ });
277
+
278
+ it('| on DyFM_Error with single _messages returns our message only', (): void => {
279
+ const result: string = DyFM_Error.getSemanticMessage(error_0);
280
+ expect(result).toBe(message_base);
281
+ });
282
+
283
+ it('| on DyFM_Error chain returns string containing outer message and root in parentheses when different', (): void => {
284
+ const rootMsg: string = 'root-message';
285
+ const outerMsg: string = 'outer-message';
286
+ const errorInner: DyFM_Error = new DyFM_Error({
287
+ message: rootMsg,
288
+ error: new Error(),
289
+ });
290
+ const errorOuter: DyFM_Error = new DyFM_Error({
291
+ message: outerMsg,
292
+ errorCode: 'CUSTOM-SEM-001',
293
+ error: errorInner,
294
+ });
295
+ expect(errorOuter._messages?.length).toBeGreaterThan(1);
296
+ expect(errorOuter._messages?.[0]).toBe(rootMsg);
297
+ expect(errorOuter._message).toBe(outerMsg);
298
+ const result: string = DyFM_Error.getSemanticMessage(errorOuter);
299
+ expect(result).toBe(`${outerMsg} (${rootMsg})`);
300
+ });
301
+
302
+ it('| on error_stack_2 returns main message (first equals our message so no parentheses)', (): void => {
303
+ const result: string = DyFM_Error.getSemanticMessage(error_stack_2);
304
+ expect(result).toBe(message_base);
305
+ });
306
+ });
307
+
308
+ describe('| should have the proper __userMessage;', (): void => {
309
+ it('| on error_0', (): void => {
310
+ expect(error_0.__userMessage).toBe(userMessageResult_0);
311
+ });
312
+
313
+ it('| on error_stack_1', (): void => {
314
+ expect(error_stack_1.__userMessage).toBe(userMessageResult_0);
315
+ });
316
+
317
+ it('| on error_stack_2', (): void => {
318
+ expect(error_stack_2.__userMessage).toBe(userMessageResult_0);
319
+ });
320
+
321
+ it('| on self defined error', (): void => {
322
+ expect(error_selfDefined.__userMessage).toBeUndefined();
323
+ });
324
+ });
325
+
326
+ describe('| should have the proper __userMessages;', (): void => {
327
+ it('| on error_0', (): void => {
328
+ expect(error_0.__userMessages).toEqual([ userMessageResult_0 ]);
329
+ });
330
+
331
+ it('| on error_stack_1', (): void => {
332
+ expect(error_stack_1.__userMessages).toEqual(
333
+ [ userMessageResult_0, DyFM_error_defaults.userMessage ]
334
+ );
335
+ });
336
+
337
+ it('| on error_stack_2', (): void => {
338
+ expect(error_stack_2.__userMessages).toEqual(
339
+ [ userMessageResult_0, DyFM_error_defaults.userMessage, userMessageResult_2 ]
340
+ );
341
+ });
342
+
343
+ it('| on self defined error', (): void => {
344
+ expect(error_selfDefined.__userMessages).toEqual([ DyFM_error_defaults.userMessage ]);
345
+ });
346
+ });
347
+
348
+ describe('| should have proper error;', (): void => {
349
+ it('| on error_0', (): void => {
350
+ expect(testFormatter(error_0.error)).toBe(
351
+ testFormatter(error_base)
352
+ );
353
+ });
354
+
355
+ it('| on error_stack_1', (): void => {
356
+ expect(testFormatter(error_stack_1.error)).toBe(
357
+ testFormatter(error_base)
358
+ );
359
+ });
360
+
361
+ it('| on error_stack_2', (): void => {
362
+ expect(testFormatter(error_stack_2.error)).toBe(
363
+ testFormatter(error_base)
364
+ );
365
+ });
366
+
367
+ it('| on self defined error', (): void => {
368
+ expect(testFormatter(error_selfDefined.error)).toBeDefined();
369
+ });
370
+ });
371
+
372
+ describe('| should have the proper errors;', (): void => {
373
+ it('| on error_0', (): void => {
374
+ expect(error_0.errors).toEqual([ error_base ]);
375
+ });
376
+
377
+ it('| on error_stack_1', (): void => {
378
+ const error_0_withoutSubErrors = { ...error_0 } as DyFM_Error;
379
+
380
+ delete error_0_withoutSubErrors.errors;
381
+ delete error_0_withoutSubErrors.additionalContent;
382
+
383
+ expect(testFormatter(error_stack_1.errors)).toEqual(
384
+ testFormatter([ error_base, error_0_withoutSubErrors ])
385
+ );
386
+ });
387
+
388
+ it('| on error_stack_2', (): void => {
389
+ const error_0_withoutSubErrors = { ...error_0 } as DyFM_Error;
390
+ const error_stack_1_withoutSubErrors = { ...error_stack_1 } as DyFM_Error;
391
+
392
+ delete error_0_withoutSubErrors.errors;
393
+ delete error_0_withoutSubErrors.additionalContent;
394
+ delete error_stack_1_withoutSubErrors.errors;
395
+ delete error_stack_1_withoutSubErrors.additionalContent;
396
+
397
+ expect(testFormatter(error_stack_2.errors)).toEqual(
398
+ testFormatter([ error_base, error_0_withoutSubErrors, error_stack_1_withoutSubErrors ])
399
+ );
400
+ });
401
+
402
+ it('| on self defined error', (): void => {
403
+ expect(error_selfDefined?.errors?.length).toBe(1);
404
+ });
405
+ });
406
+
407
+ describe('| should have proper handled;', (): void => {
408
+ it('| on error_0', (): void => {
409
+ expect(error_0.___handled).toBe(false);
410
+ });
411
+
412
+ it('| on error_stack_1', (): void => {
413
+ expect(error_stack_1.___handled).toBe(true);
414
+ });
415
+
416
+ it('| on error_stack_2', (): void => {
417
+ expect(error_stack_2.___handled).toBe(true);
418
+ });
419
+
420
+ it('| on self defined error', (): void => {
421
+ expect(error_selfDefined.___handled).toBe(false);
422
+ });
423
+ });
424
+
425
+ describe('| should have status: undefined;', (): void => {
426
+ it('| on error_0', (): void => {
427
+ expect(error_0.___status).toBe(undefined);
428
+ });
429
+
430
+ it('| on error_stack_1', (): void => {
431
+ expect(error_stack_1.___status).toBe(undefined);
432
+ });
433
+
434
+ it('| on error_stack_2', (): void => {
435
+ expect(error_stack_2.___status).toBe(undefined);
436
+ });
437
+
438
+ it('| on self defined error', (): void => {
439
+ expect(error_selfDefined.___status).toBe(undefined);
440
+ });
441
+ });
442
+
443
+ describe('| should have the proper issuer;', (): void => {
444
+ it('| on error_0', (): void => {
445
+ expect(error_0.___issuer).toBe(issuer);
446
+ });
447
+
448
+ it('| on error_stack_1', (): void => {
449
+ expect(error_stack_1.___issuer).toBe(issuer);
450
+ });
451
+
452
+ it('| on error_stack_2', (): void => {
453
+ expect(error_stack_2.___issuer).toBe(issuer);
454
+ });
455
+
456
+ it('| on self defined error', (): void => {
457
+ expect(error_selfDefined.___issuer).toBe(DyFM_error_defaults.issuer);
458
+ });
459
+ });
460
+
461
+ describe('| should have get proper additionalContent;', (): void => {
462
+ it('| on error_0', (): void => {
463
+ expect(error_0.additionalContent).toEqual({});
464
+ });
465
+
466
+ it('| on error_stack_1', (): void => {
467
+ expect(error_stack_1.additionalContent).toEqual(additionalContent_1);
468
+ });
469
+
470
+ it('| on error_stack_2', (): void => {
471
+ expect(error_stack_2.additionalContent).toEqual({
472
+ ...additionalContent_1,
473
+ ...additionalContent_2,
474
+ });
475
+ });
476
+
477
+ it('| on self defined error', (): void => {
478
+ expect(error_selfDefined.additionalContent).toEqual({});
479
+ });
480
+ });
481
+
482
+ describe('| should have the proper issuerSystem;', (): void => {
483
+ it('| on error_0', (): void => {
484
+ expect(error_0.___issuerSystem).toBe(issuerSystem);
485
+ });
486
+
487
+ it('| on error_stack_1', (): void => {
488
+ expect(error_stack_1.___issuerSystem).toBe(issuerSystem);
489
+ });
490
+
491
+ it('| on error_stack_2', (): void => {
492
+ expect(error_stack_2.___issuerSystem).toBe(issuerSystem);
493
+ });
494
+
495
+ it('| on self defined error', (): void => {
496
+ expect(error_selfDefined.___issuerSystem).toBe(DyFM_error_defaults.issuerSystem);
497
+ });
498
+ });
499
+
500
+ describe('| should have the proper issuerService;', (): void => {
501
+ it('| on error_0', (): void => {
502
+ expect(error_0.___issuerService).toBe(issuerService_0);
503
+ });
504
+
505
+ it('| on error_stack_1', (): void => {
506
+ expect(error_stack_1.___issuerService).toBe(issuerService_1);
507
+ });
508
+
509
+ it('| on error_stack_2', (): void => {
510
+ expect(error_stack_2.___issuerService).toBe(issuerService_1);
511
+ });
512
+
513
+ it('| on self defined error', (): void => {
514
+ expect(error_selfDefined.___issuerService).toBe(DyFM_error_defaults.issuerService);
515
+ });
516
+ });
517
+
518
+ describe('| should have get proper simplified;', (): void => {
519
+ let simplified: DyFM_Error_Settings;
520
+
521
+ describe('| on error_0;', (): void => {
522
+ beforeEach((): void => {
523
+ simplified = error_0.getErrorSimplified();
524
+ });
525
+
526
+ it('| should be defined', (): void => {
527
+ expect(simplified).toBeDefined();
528
+ });
529
+
530
+ it('| should have errorCode', (): void => {
531
+ expect(simplified.errorCode).toBeDefined();
532
+ });
533
+
534
+ it('| should have message', (): void => {
535
+ expect(simplified.message).toBeDefined();
536
+ });
537
+
538
+ it('| should have userMessage', (): void => {
539
+ expect(simplified.userMessage).toBeDefined();
540
+ });
541
+
542
+ it('| should have stack', (): void => {
543
+ expect(simplified.stack).toBeDefined();
544
+ });
545
+
546
+ it('| should not have error', (): void => {
547
+ expect(simplified.error).toBeUndefined();
548
+ });
549
+
550
+ it('| should not have errors', (): void => {
551
+ expect(simplified.errors).toBeUndefined();
552
+ });
553
+
554
+ it('| should not have simplified.error.error', (): void => {
555
+ expect((simplified.error as DyFM_Error)?.error).toBeUndefined();
556
+ });
557
+
558
+ it('| should not have simplified.error.errors', (): void => {
559
+ expect((simplified.error as DyFM_Error)?.errors).toBeUndefined();
560
+ });
561
+ });
562
+
563
+ describe('| on error_stack_1;', (): void => {
564
+ beforeEach((): void => {
565
+ simplified = error_stack_1.getErrorSimplified();
566
+ });
567
+
568
+ it('| should be defined', (): void => {
569
+ expect(simplified).toBeDefined();
570
+ });
571
+
572
+ it('| should have errorCode', (): void => {
573
+ expect(simplified.errorCode).toBeDefined();
574
+ });
575
+
576
+ it('| should have message', (): void => {
577
+ expect(simplified.message).toBeDefined();
578
+ });
579
+
580
+ it('| should have userMessage', (): void => {
581
+ expect(simplified.userMessage).toBeDefined();
582
+ });
583
+
584
+ it('| should have stack', (): void => {
585
+ expect(simplified.stack).toBeDefined();
586
+ });
587
+
588
+ it('| should not have error', (): void => {
589
+ expect(simplified.error).toBeUndefined();
590
+ });
591
+
592
+ it('| should not have errors', (): void => {
593
+ expect(simplified.errors).toBeUndefined();
594
+ });
595
+
596
+ it('| should not have simplified.error.error', (): void => {
597
+ expect((simplified.error as DyFM_Error)?.error).toBeUndefined();
598
+ });
599
+
600
+ it('| should not have simplified.error.errors', (): void => {
601
+ expect((simplified.error as DyFM_Error)?.errors).toBeUndefined();
602
+ });
603
+ });
604
+
605
+ describe('| on error_stack_2;', (): void => {
606
+ beforeEach((): void => {
607
+ simplified = error_stack_2.getErrorSimplified();
608
+ });
609
+
610
+ it('| should be defined', (): void => {
611
+ expect(simplified).toBeDefined();
612
+ });
613
+
614
+ it('| should have errorCode', (): void => {
615
+ expect(simplified.errorCode).toBeDefined();
616
+ });
617
+
618
+ it('| should have message', (): void => {
619
+ expect(simplified.message).toBeDefined();
620
+ });
621
+
622
+ it('| should have userMessage', (): void => {
623
+ expect(simplified.userMessage).toBeDefined();
624
+ });
625
+
626
+ it('| should have stack', (): void => {
627
+ expect(simplified.stack).toBeDefined();
628
+ });
629
+
630
+ it('| should not have error', (): void => {
631
+ expect(simplified.error).toBeUndefined();
632
+ });
633
+
634
+ it('| should not have errors', (): void => {
635
+ expect(simplified.errors).toBeUndefined();
636
+ });
637
+
638
+ it('| should not have simplified.error.error', (): void => {
639
+ expect((simplified.error as DyFM_Error)?.error).toBeUndefined();
640
+ });
641
+
642
+ it('| should not have simplified.error.errors', (): void => {
643
+ expect((simplified.error as DyFM_Error)?.errors).toBeUndefined();
644
+ });
645
+ });
646
+
647
+ describe('| on self defined error;', (): void => {
648
+ beforeEach((): void => {
649
+ simplified = error_selfDefined.getErrorSimplified();
650
+ });
651
+
652
+ it('| should be defined', (): void => {
653
+ expect(simplified).toBeDefined();
654
+ });
655
+
656
+ it('| should have errorCode', (): void => {
657
+ expect(simplified.errorCode).toBeDefined();
658
+ });
659
+
660
+ it('| should have message', (): void => {
661
+ expect(simplified.message).toBeDefined();
662
+ });
663
+
664
+ it('| should not have userMessage', (): void => {
665
+ expect(simplified.userMessage).toBeUndefined();
666
+ });
667
+
668
+ it('| should have stack', (): void => {
669
+ expect(simplified.stack).toBeDefined();
670
+ });
671
+
672
+ it('| should not have error', (): void => {
673
+ expect(simplified.error).toBeUndefined();
674
+ });
675
+
676
+ it('| should not have errors', (): void => {
677
+ expect(simplified.errors).toBeUndefined();
678
+ });
679
+
680
+ it('| should not have simplified.error.error', (): void => {
681
+ expect((simplified.error as DyFM_Error)?.error).toBeUndefined();
682
+ });
683
+
684
+ it('| should not have simplified.error.errors', (): void => {
685
+ expect((simplified.error as DyFM_Error)?.errors).toBeUndefined();
686
+ });
687
+ });
688
+ });
689
+
690
+ describe('| should have get proper flat;', (): void => {
691
+ let flat;
692
+
693
+ describe('| on error_0;', (): void => {
694
+ beforeEach((): void => {
695
+ flat = error_0.getErrorsFlat();
696
+ });
697
+
698
+ it('| should be defined', (): void => {
699
+ expect(flat).toBeDefined();
700
+ });
701
+
702
+ it('| should have error', (): void => {
703
+ expect(flat.error).toBeDefined();
704
+ });
705
+
706
+ describe('| errors...;', (): void => {
707
+ it('| should have errors', (): void => {
708
+ expect(flat?.errors).toBeDefined();
709
+ });
710
+
711
+ it('| should have 1 errors', (): void => {
712
+ expect(flat?.errors?.length).toBe(1);
713
+ });
714
+
715
+ flat?.errors?.forEach((error: DyFM_Error, index: number): void => {
716
+ describe(`on error[${index}];`, (): void => {
717
+ it('| should be', (): void => {
718
+ expect(error).toBeDefined();
719
+ });
720
+
721
+ it(`should have error[${index}].error`, (): void => {
722
+ expect(error.error).toBeDefined();
723
+ });
724
+
725
+ it(`should not have error[${index}].errors`, (): void => {
726
+ expect(error.errors).toBeUndefined();
727
+ });
728
+
729
+ it(`should not have error[${index}].error.error`, (): void => {
730
+ expect((error.error as DyFM_Error)?.error).toBeUndefined();
731
+ });
732
+
733
+ it(`should not have error[${index}].error.errors`, (): void => {
734
+ expect((error.error as DyFM_Error)?.errors).toBeUndefined();
735
+ });
736
+ });
737
+ });
738
+ });
739
+ });
740
+
741
+ describe('| on error_stack_1;', (): void => {
742
+ beforeEach((): void => {
743
+ flat = error_stack_1.getErrorsFlat();
744
+ });
745
+
746
+ it('| should be defined', (): void => {
747
+ expect(flat).toBeDefined();
748
+ });
749
+
750
+ it('| should have error', (): void => {
751
+ expect(flat.error).toBeDefined();
752
+ });
753
+
754
+ describe('| errors...;', (): void => {
755
+ it('| should have errors', (): void => {
756
+ expect(flat?.errors).toBeDefined();
757
+ });
758
+
759
+ it('| should have 2 errors', (): void => {
760
+ expect(flat?.errors?.length).toBe(2);
761
+ });
762
+
763
+ flat?.errors?.forEach((error: DyFM_Error, index: number): void => {
764
+ describe(`on error[${index}];`, (): void => {
765
+ it('| should be', (): void => {
766
+ expect(error).toBeDefined();
767
+ });
768
+
769
+ it(`should have error[${index}].error`, (): void => {
770
+ expect(error.error).toBeDefined();
771
+ });
772
+
773
+ it(`should not have error[${index}].errors`, (): void => {
774
+ expect(error.errors).toBeUndefined();
775
+ });
776
+
777
+ it('| should not have error[${index}].error.error', (): void => {
778
+ expect((error.error as DyFM_Error)?.error).toBeUndefined();
779
+ });
780
+
781
+ it('| should not have error[${index}].error.errors', (): void => {
782
+ expect((error.error as DyFM_Error)?.errors).toBeUndefined();
783
+ });
784
+ });
785
+ });
786
+ });
787
+ });
788
+
789
+ describe('| on error_stack_2;', (): void => {
790
+ beforeEach((): void => {
791
+ flat = error_stack_2.getErrorsFlat();
792
+ });
793
+
794
+ it('| should be defined', (): void => {
795
+ expect(flat).toBeDefined();
796
+ });
797
+
798
+ it('| should have error', (): void => {
799
+ expect(flat.error).toBeDefined();
800
+ });
801
+
802
+ describe('| errors...;', (): void => {
803
+ it('| should have errors', (): void => {
804
+ expect(flat?.errors).toBeDefined();
805
+ });
806
+
807
+ it('| should have 3 errors', (): void => {
808
+ expect(flat?.errors?.length).toBe(3);
809
+ });
810
+
811
+ flat?.errors?.forEach((error: DyFM_Error, index: number): void => {
812
+ describe(`on error[${index}];`, (): void => {
813
+ it('| should be', (): void => {
814
+ expect(error).toBeDefined();
815
+ });
816
+
817
+ it(`should have error[${index}].error`, (): void => {
818
+ expect(error.error).toBeDefined();
819
+ });
820
+
821
+ it(`should not have error[${index}].errors`, (): void => {
822
+ expect(error.errors).toBeUndefined();
823
+ });
824
+
825
+ it(`should not have error[${index}].error.error`, (): void => {
826
+ expect((error.error as DyFM_Error)?.error).toBeUndefined();
827
+ });
828
+
829
+ it(`should not have error[${index}].error.errors`, (): void => {
830
+ expect((error.error as DyFM_Error)?.errors).toBeUndefined();
831
+ });
832
+ });
833
+ });
834
+ });
835
+ });
836
+
837
+ describe('| on self defined error;', (): void => {
838
+ beforeEach((): void => {
839
+ flat = error_selfDefined.getErrorsFlat();
840
+ });
841
+
842
+ it('| should be defined', (): void => {
843
+ expect(flat).toBeDefined();
844
+ });
845
+
846
+ it('| should have error', (): void => {
847
+ expect(flat.error).toBeDefined();
848
+ });
849
+
850
+ describe('| errors...;', (): void => {
851
+ it('| should have errors', (): void => {
852
+ expect(flat?.errors).toBeDefined();
853
+ });
854
+
855
+ it('| should have 1 errors', (): void => {
856
+ expect(flat?.errors?.length).toBe(1);
857
+ });
858
+
859
+ flat?.errors?.forEach((error: DyFM_Error, index: number): void => {
860
+ describe(`on error[${index}];`, (): void => {
861
+ it('| should be', (): void => {
862
+ expect(error).toBeDefined();
863
+ });
864
+
865
+ it(`should have error[${index}].error`, (): void => {
866
+ expect(error.error).toBeDefined();
867
+ });
868
+
869
+ it(`should not have error[${index}].errors`, (): void => {
870
+ expect(error.errors).toBeUndefined();
871
+ });
872
+
873
+ it(`should not have error[${index}].error.error`, (): void => {
874
+ expect((error.error as DyFM_Error)?.error).toBeUndefined();
875
+ });
876
+
877
+ it(`should not have error[${index}].error.errors`, (): void => {
878
+ expect((error.error as DyFM_Error)?.errors).toBeUndefined();
879
+ });
880
+ });
881
+ });
882
+ });
883
+ });
884
+
885
+ describe('| stack', (): void => {
886
+ it('| error lvl3 should have the stack from the first', (): void => {
887
+ const error_lvl1 = new Error('error_lvl1');
888
+
889
+ const error_lvl2 = new DyFM_Error({
890
+ error: error_lvl1,
891
+ });
892
+
893
+ const error_lvl3 = new DyFM_Error({
894
+ error: error_lvl2,
895
+ });
896
+
897
+ expect(error_lvl3.stack).toBe(error_lvl1.stack);
898
+ });
899
+ });
900
+ });
901
+
902
+ describe('| logSimple;', (): void => {
903
+ it('| should not fail', (): void => {
904
+ const error = new DyFM_Error({
905
+ error: new Error('error'),
906
+ });
907
+
908
+ expect(error.logSimple('test')).toBeUndefined();
909
+ });
910
+ });
911
+ });
912
+