@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.
- package/.cursor/rules/__assistant_guide.mdc +30 -30
- package/.cursor/rules/_ag_backend-structure.mdc +85 -85
- package/.cursor/rules/_ag_backend.mdc +16 -16
- package/.cursor/rules/_ag_frontend-structure.mdc +86 -86
- package/.cursor/rules/_ag_frontend.mdc +39 -39
- package/.cursor/rules/_ag_import-rules.mdc +44 -44
- package/.cursor/rules/_ag_naming.mdc +115 -115
- package/.cursor/rules/_ag_should-be.mdc +6 -6
- package/.cursor/rules/ai_development_guide.md +60 -60
- package/.cursor/rules/cursor-rules.md +160 -160
- package/.cursor/rules/default-command.mdc +464 -464
- package/.cursor/rules/error_code_pattern.md +39 -39
- package/.cursor/rules/saved rule mcp server use.md +15 -15
- package/.dynamo/pipeline.cicd.config.json +128 -128
- package/.github/workflows/main.yml +433 -433
- package/.vscode/settings.json +11 -11
- package/LICENSE +21 -21
- package/__documentations/2026-06-01-fr047-fc-foundation.md +48 -0
- package/build/_models/data-models/errors.data-model.d.ts +43 -0
- package/build/_models/data-models/errors.data-model.d.ts.map +1 -1
- package/build/_models/data-models/errors.data-model.js +30 -0
- package/build/_models/data-models/errors.data-model.js.map +1 -1
- package/build/_modules/ai/_models/ai-model-capabilities.interface.d.ts +8 -0
- package/build/_modules/ai/_models/ai-model-capabilities.interface.d.ts.map +1 -1
- package/build/_modules/ai/_modules/anthropic/_collections/aai-models.const.d.ts.map +1 -1
- package/build/_modules/ai/_modules/anthropic/_collections/aai-models.const.js +3 -0
- package/build/_modules/ai/_modules/anthropic/_collections/aai-models.const.js.map +1 -1
- package/build/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.d.ts.map +1 -1
- package/build/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.js +1 -0
- package/build/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.js.map +1 -1
- package/build/_modules/ai/_modules/google-ai/_collections/gai-models.const.d.ts.map +1 -1
- package/build/_modules/ai/_modules/google-ai/_collections/gai-models.const.js +4 -0
- package/build/_modules/ai/_modules/google-ai/_collections/gai-models.const.js.map +1 -1
- package/build/_modules/ai/_modules/local-ai/_collections/lai-models.const.d.ts.map +1 -1
- package/build/_modules/ai/_modules/local-ai/_collections/lai-models.const.js +2 -0
- package/build/_modules/ai/_modules/local-ai/_collections/lai-models.const.js.map +1 -1
- package/build/_modules/ai/_modules/open-ai/_collections/oai-models.const.d.ts.map +1 -1
- package/build/_modules/ai/_modules/open-ai/_collections/oai-models.const.js +11 -0
- package/build/_modules/ai/_modules/open-ai/_collections/oai-models.const.js.map +1 -1
- package/build/_modules/socket/_models/sck-socket-event.control-model.js +1 -1
- package/eslint.config.js +4 -4
- package/nodemon.json +22 -22
- package/package.json +11 -11
- package/scripts/crypto/CRYPTO-STABILITY-SOLUTION.md +196 -196
- package/scripts/crypto/README.md +113 -113
- package/scripts/crypto/demo-crypto-stability.js +120 -120
- package/scripts/crypto/stress-test-crypto.js +379 -379
- package/scripts/run-coverage-tests.js +24 -24
- package/spec/support/helpers/ts-node-helper.js +9 -9
- package/spec/support/jasmine.coverage.json +23 -23
- package/spec/support/jasmine.json +24 -24
- package/src/_collections/constants/data-sizes.const.ts +40 -40
- package/src/_collections/constants/error-defaults.const.ts +20 -20
- package/src/_collections/constants/global-settings.const.ts +24 -24
- package/src/_collections/constants/numbers.const.ts +40 -40
- package/src/_collections/constants/times.const.ts +45 -45
- package/src/_collections/utils/array.util.spec.ts +306 -306
- package/src/_collections/utils/array.util.ts +813 -813
- package/src/_collections/utils/async.util.spec.ts +354 -354
- package/src/_collections/utils/async.util.ts +197 -197
- package/src/_collections/utils/data.util.spec.ts +345 -345
- package/src/_collections/utils/data.util.ts +226 -226
- package/src/_collections/utils/json-error-helper.util.spec.ts +521 -521
- package/src/_collections/utils/json-error-helper.util.ts +301 -301
- package/src/_collections/utils/log.util.spec.ts +975 -975
- package/src/_collections/utils/log.util.ts +665 -665
- package/src/_collections/utils/math/box-bounds.spec.ts +73 -73
- package/src/_collections/utils/math/box-bounds.util.ts +183 -183
- package/src/_collections/utils/math/math.util.spec.ts +94 -94
- package/src/_collections/utils/math/math.util.ts +141 -141
- package/src/_collections/utils/math/random.util.spec.ts +82 -82
- package/src/_collections/utils/math/random.util.ts +139 -139
- package/src/_collections/utils/math/trigonometry.util.spec.ts +57 -57
- package/src/_collections/utils/math/trigonometry.util.ts +102 -102
- package/src/_collections/utils/math/vector2.util.spec.ts +94 -94
- package/src/_collections/utils/math/vector2.util.ts +653 -653
- package/src/_collections/utils/object.util.spec.ts +646 -646
- package/src/_collections/utils/regex/password-regex.util.spec.ts +51 -51
- package/src/_collections/utils/regex/password-regex.util.ts +65 -65
- package/src/_collections/utils/regex/regex.util.spec.ts +42 -42
- package/src/_collections/utils/regex/regex.util.ts +6 -6
- package/src/_collections/utils/regex/username-regex.util.spec.ts +61 -61
- package/src/_collections/utils/regex/username-regex.util.ts +35 -35
- package/src/_collections/utils/round-list.util.spec.ts +79 -79
- package/src/_collections/utils/round-list.util.ts +162 -162
- package/src/_collections/utils/stack.util.spec.ts +372 -372
- package/src/_collections/utils/stack.util.ts +164 -164
- package/src/_collections/utils/string-case.util.spec.ts +441 -441
- package/src/_collections/utils/string-case.util.ts +362 -362
- package/src/_collections/utils/string.util.spec.ts +975 -975
- package/src/_collections/utils/string.util.ts +449 -449
- package/src/_collections/utils/time.util.spec.ts +50 -50
- package/src/_collections/utils/time.util.ts +481 -481
- package/src/_collections/utils/type-cloning-facility.util.spec.ts +51 -51
- package/src/_collections/utils/type-cloning-facility.util.ts +168 -168
- package/src/_collections/utils/utilities.util.spec.ts +201 -201
- package/src/_collections/utils/utilities.util.ts +68 -68
- package/src/_collections/utils/uuid.util.spec.ts +30 -30
- package/src/_collections/utils/uuid.util.ts +50 -50
- package/src/_enums/basic-property-type.enum.ts +20 -20
- package/src/_enums/data-model-type.enum.ts +29 -29
- package/src/_enums/environment-flag.enum.ts +28 -28
- package/src/_enums/error-level.enum.ts +28 -28
- package/src/_enums/http/http-call-type.enum.ts +43 -43
- package/src/_enums/http/http-event-type.enum.ts +40 -40
- package/src/_enums/http/http-response-type.enum.ts +18 -18
- package/src/_enums/log-style.enum.ts +44 -44
- package/src/_enums/server-connection-status.enum.ts +6 -6
- package/src/_enums/time/day-of-week.enum.ts +55 -55
- package/src/_enums/time/month.enum.ts +25 -25
- package/src/_enums/time/relative-date.enum.ts +24 -24
- package/src/_models/control-models/data-model-params.control-model.spec.ts +85 -85
- package/src/_models/control-models/data-model-params.control-model.ts +300 -300
- package/src/_models/control-models/data-property-params.control-model.spec.ts +93 -93
- package/src/_models/control-models/data-property-params.control-model.ts +201 -201
- package/src/_models/control-models/error.control-model.spec.ts +912 -912
- package/src/_models/control-models/error.control-model.ts +1215 -1215
- package/src/_models/control-models/http/http-error-response.control-model.spec.ts +116 -116
- package/src/_models/control-models/http/http-error-response.control-model.ts +52 -52
- package/src/_models/control-models/http/http-headers.control-model.spec.ts +25 -25
- package/src/_models/control-models/http/http-headers.control-model.ts +124 -124
- package/src/_models/control-models/http/http-response.model-base.spec.ts +46 -46
- package/src/_models/control-models/http/http-response.model-base.ts +57 -57
- package/src/_models/control-models/poll.control-model.spec.ts +63 -63
- package/src/_models/control-models/poll.control-model.ts +151 -151
- package/src/_models/control-models/range-value.control-model.spec.ts +187 -187
- package/src/_models/control-models/range-value.control-model.ts +289 -289
- package/src/_models/control-models/server-status.control-model.spec.ts +66 -66
- package/src/_models/control-models/server-status.control-model.ts +85 -85
- package/src/_models/control-models/service-endpoint-settings-base.control-model.spec.ts +145 -145
- package/src/_models/control-models/service-endpoint-settings-base.control-model.ts +186 -186
- package/src/_models/data-models/errors.data-model.spec.ts +71 -71
- package/src/_models/data-models/errors.data-model.ts +148 -91
- package/src/_models/data-models/metadata.data-model.spec.ts +184 -184
- package/src/_models/data-models/metadata.data-model.ts +128 -128
- package/src/_models/interfaces/box-bounds.interface.ts +7 -7
- package/src/_models/interfaces/environment/global-log-settings.interface.ts +86 -86
- package/src/_models/interfaces/environment/global-settings.interface.ts +47 -47
- package/src/_models/interfaces/error-defaults.interface.ts +11 -11
- package/src/_models/interfaces/paged.interface.ts +12 -12
- package/src/_models/interfaces/random-weight.interface.ts +7 -7
- package/src/_models/interfaces/route-settings.interface.ts +15 -15
- package/src/_models/interfaces/search-query.interface.ts +23 -23
- package/src/_models/interfaces/search-result.interface.ts +5 -5
- package/src/_models/interfaces/server-error-statistics.interface.ts +24 -24
- package/src/_models/interfaces/vector2.interface.ts +20 -20
- package/src/_models/types/db-filter.type.ts +110 -110
- package/src/_models/types/db-sort.type.ts +4 -4
- package/src/_models/types/ds-filter.type.ts +68 -68
- package/src/_models/types/ds-sort.type.ts +21 -21
- package/src/_modules/ai/_collections/ai-model-ref.util.ts +88 -88
- package/src/_modules/ai/_collections/ai-model-registry.util.spec.ts +37 -37
- package/src/_modules/ai/_collections/ai-model-registry.util.ts +30 -30
- package/src/_modules/ai/_enums/ai-message-role.enum.ts +7 -7
- package/src/_modules/ai/_enums/ai-model-type.enum.ts +7 -7
- package/src/_modules/ai/_enums/ai-provider.enum.ts +7 -7
- package/src/_modules/ai/_models/ai-call-settings.interface.ts +84 -84
- package/src/_modules/ai/_models/ai-embedding-request.interface.ts +20 -20
- package/src/_modules/ai/_models/ai-embedding-response.interface.ts +26 -26
- package/src/_modules/ai/_models/ai-llm-request.interface.ts +24 -24
- package/src/_modules/ai/_models/ai-llm-response.interface.ts +30 -30
- package/src/_modules/ai/_models/ai-message.interface.ts +12 -12
- package/src/_modules/ai/_models/ai-model-capabilities.interface.ts +35 -27
- package/src/_modules/ai/_models/ai-model-info.interface.ts +63 -63
- package/src/_modules/ai/_models/ai-model-settings-schema.interface.ts +52 -52
- package/src/_modules/ai/_models/ai-provider-capabilities.interface.ts +28 -28
- package/src/_modules/ai/_models/ai-settings.interface.ts +17 -17
- package/src/_modules/ai/_models/ai-tool-call.interface.ts +18 -18
- package/src/_modules/ai/_models/ai-tool-handler.type.ts +11 -11
- package/src/_modules/ai/_models/ai-tool-result.interface.ts +16 -16
- package/src/_modules/ai/_models/ai-tool.interface.ts +16 -16
- package/src/_modules/ai/_models/ai-user-provider-config.control-model.ts +29 -29
- package/src/_modules/ai/_modules/anthropic/_collections/aai-models.const.ts +81 -78
- package/src/_modules/ai/_modules/anthropic/_enums/aai-model.enum.ts +19 -19
- package/src/_modules/ai/_modules/anthropic/_models/aai-call-settings.control-model.spec.ts +28 -28
- package/src/_modules/ai/_modules/anthropic/_models/aai-call-settings.control-model.ts +23 -23
- package/src/_modules/ai/_modules/anthropic/_models/aai-client-options.interface.ts +10 -10
- package/src/_modules/ai/_modules/anthropic/_models/aai-settings.control-model.spec.ts +22 -22
- package/src/_modules/ai/_modules/anthropic/_models/aai-settings.control-model.ts +27 -27
- package/src/_modules/ai/_modules/anthropic/_models/aai-user-provider-config.control-model.ts +20 -20
- package/src/_modules/ai/_modules/anthropic/index.ts +14 -14
- package/src/_modules/ai/_modules/document-ai/_models/dai-embedding-info.interface.ts +12 -12
- package/src/_modules/ai/_modules/document-ai/_models/dai-vector-search-params.interface.ts +22 -22
- package/src/_modules/ai/_modules/document-ai/index.ts +4 -4
- package/src/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.ts +34 -33
- package/src/_modules/ai/_modules/fdp-ai/_enums/fdpai-model.enum.ts +6 -6
- package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-call-settings.control-model.ts +19 -19
- package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-client-options.interface.ts +11 -11
- package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-settings.control-model.ts +24 -24
- package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-user-provider-config.control-model.ts +20 -20
- package/src/_modules/ai/_modules/fdp-ai/index.ts +11 -11
- package/src/_modules/ai/_modules/google-ai/_collections/gai-models.const.ts +99 -95
- package/src/_modules/ai/_modules/google-ai/_enums/gai-model.enum.ts +16 -16
- package/src/_modules/ai/_modules/google-ai/_models/gai-call-settings.control-model.spec.ts +28 -28
- package/src/_modules/ai/_modules/google-ai/_models/gai-call-settings.control-model.ts +21 -21
- package/src/_modules/ai/_modules/google-ai/_models/gai-client-options.interface.ts +8 -8
- package/src/_modules/ai/_modules/google-ai/_models/gai-settings.control-model.spec.ts +22 -22
- package/src/_modules/ai/_modules/google-ai/_models/gai-settings.control-model.ts +25 -25
- package/src/_modules/ai/_modules/google-ai/_models/gai-user-provider-config.control-model.ts +20 -20
- package/src/_modules/ai/_modules/google-ai/index.ts +14 -14
- package/src/_modules/ai/_modules/local-ai/_collections/lai-models.const.ts +53 -51
- package/src/_modules/ai/_modules/local-ai/_enums/lai-model.enum.ts +6 -6
- package/src/_modules/ai/_modules/local-ai/_models/lai-call-settings.control-model.spec.ts +28 -28
- package/src/_modules/ai/_modules/local-ai/_models/lai-call-settings.control-model.ts +18 -18
- package/src/_modules/ai/_modules/local-ai/_models/lai-client-options.interface.ts +9 -9
- package/src/_modules/ai/_modules/local-ai/_models/lai-settings.control-model.spec.ts +22 -22
- package/src/_modules/ai/_modules/local-ai/_models/lai-settings.control-model.ts +23 -23
- package/src/_modules/ai/_modules/local-ai/index.ts +14 -14
- package/src/_modules/ai/_modules/open-ai/_collections/oai-embedding-model-dimensions.const.ts +7 -7
- package/src/_modules/ai/_modules/open-ai/_collections/oai-models.const.ts +252 -241
- package/src/_modules/ai/_modules/open-ai/_enums/oai-model.enum.ts +179 -179
- package/src/_modules/ai/_modules/open-ai/_models/oai-call-settings.control-model.spec.ts +28 -28
- package/src/_modules/ai/_modules/open-ai/_models/oai-call-settings.control-model.ts +21 -21
- package/src/_modules/ai/_modules/open-ai/_models/oai-client-options.interface.ts +81 -81
- package/src/_modules/ai/_modules/open-ai/_models/oai-embedding-info.interface.ts +13 -13
- package/src/_modules/ai/_modules/open-ai/_models/oai-settings.control-model.spec.ts +22 -22
- package/src/_modules/ai/_modules/open-ai/_models/oai-settings.control-model.ts +25 -25
- package/src/_modules/ai/_modules/open-ai/_models/oai-user-provider-config.control-model.ts +21 -21
- package/src/_modules/ai/_modules/open-ai/index.ts +28 -28
- package/src/_modules/ai/index.ts +27 -27
- package/src/_modules/ci-tools/_enums/cit-ci-result-code.enum.ts +11 -11
- package/src/_modules/ci-tools/_enums/cit-ci-step-result-code.enum.ts +9 -9
- package/src/_modules/ci-tools/_models/cit-ci-result-info.data-models.spec.ts +58 -58
- package/src/_modules/ci-tools/_models/cit-ci-result-info.data-models.ts +77 -77
- package/src/_modules/ci-tools/_models/cit-ci-step-result.interface.ts +12 -12
- package/src/_modules/ci-tools/index.ts +8 -8
- package/src/_modules/crypto/_collections/crypto.util.simple.spec.ts +512 -512
- package/src/_modules/crypto/index.ts +13 -13
- package/src/_modules/custom-data/_collections/cud-module-settings.const.ts +21 -21
- package/src/_modules/custom-data/_models/cud.data-model.spec.ts +38 -38
- package/src/_modules/custom-data/_models/cud.data-model.ts +39 -39
- package/src/_modules/custom-data/index.ts +10 -10
- package/src/_modules/data-handler/_models/data-handler-settings.control-model.spec.ts +110 -110
- package/src/_modules/data-handler/_models/data-handler-settings.control-model.ts +110 -110
- package/src/_modules/data-handler/_models/data-handler.control-model.spec.ts +445 -445
- package/src/_modules/data-handler/_models/data-handler.control-model.ts +459 -459
- package/src/_modules/data-handler/_models/data-list-handler.control-model.spec.ts +263 -263
- package/src/_modules/data-handler/_models/data-list-handler.control-model.ts +252 -252
- package/src/_modules/data-handler/_models/data-search-handler.control-model.spec.ts +417 -417
- package/src/_modules/data-handler/_models/data-search-handler.control-model.ts +390 -390
- package/src/_modules/data-handler/_models/list-collector-data-handler.control-model.spec.ts +374 -374
- package/src/_modules/data-handler/_models/list-collector-data-handler.control-model.ts +274 -274
- package/src/_modules/data-handler/index.ts +6 -6
- package/src/_modules/location/_collections/assets/country-codes-ISO-3166.json +3239 -3239
- package/src/_modules/location/_collections/assets/country-divisions-ISO-3166-all-list.json +19035 -19035
- package/src/_modules/location/_collections/assets/country-divisions-ISO-3166.json +4993 -4993
- package/src/_modules/location/_collections/assets/country-phone-codes.json +1203 -1203
- package/src/_modules/location/_collections/assets/country-subdivisions/afghanistan.json +137 -137
- package/src/_modules/location/_collections/assets/country-subdivisions/albania.json +49 -49
- package/src/_modules/location/_collections/assets/country-subdivisions/algeria.json +193 -193
- package/src/_modules/location/_collections/assets/country-subdivisions/andorra.json +29 -29
- package/src/_modules/location/_collections/assets/country-subdivisions/angola.json +73 -73
- package/src/_modules/location/_collections/assets/country-subdivisions/antigua-and-barbuda.json +33 -33
- package/src/_modules/location/_collections/assets/country-subdivisions/argentina.json +97 -97
- package/src/_modules/location/_collections/assets/country-subdivisions/armenia.json +45 -45
- package/src/_modules/location/_collections/assets/country-subdivisions/australia.json +33 -33
- package/src/_modules/location/_collections/assets/country-subdivisions/austria.json +37 -37
- package/src/_modules/location/_collections/assets/country-subdivisions/azerbaijan.json +5 -5
- package/src/_modules/location/_collections/assets/country-subdivisions/bahamas.json +125 -125
- package/src/_modules/location/_collections/assets/country-subdivisions/bahrain.json +21 -21
- package/src/_modules/location/_collections/assets/country-subdivisions/bangladesh.json +29 -29
- package/src/_modules/location/_collections/assets/country-subdivisions/barbados.json +45 -45
- package/src/_modules/location/_collections/assets/country-subdivisions/belarus.json +29 -29
- package/src/_modules/location/_collections/assets/country-subdivisions/belgium.json +13 -13
- package/src/_modules/location/_collections/assets/country-subdivisions/belize.json +25 -25
- package/src/_modules/location/_collections/assets/country-subdivisions/benin.json +49 -49
- package/src/_modules/location/_collections/assets/country-subdivisions/bhutan.json +81 -81
- package/src/_modules/location/_collections/assets/country-subdivisions/bolivia.json +37 -37
- package/src/_modules/location/_collections/assets/country-subdivisions/bosnia-and-herzegovina.json +13 -13
- package/src/_modules/location/_collections/assets/country-subdivisions/botswana.json +65 -65
- package/src/_modules/location/_collections/assets/country-subdivisions/brazil.json +109 -109
- package/src/_modules/location/_collections/assets/country-subdivisions/brunei-darussalam.json +17 -17
- package/src/_modules/location/_collections/assets/country-subdivisions/bulgaria.json +113 -113
- package/src/_modules/location/_collections/assets/country-subdivisions/burkina-faso.json +53 -53
- package/src/_modules/location/_collections/assets/country-subdivisions/burundi.json +69 -69
- package/src/_modules/location/_collections/assets/country-subdivisions/cambodia.json +97 -97
- package/src/_modules/location/_collections/assets/country-subdivisions/cameroon.json +41 -41
- package/src/_modules/location/_collections/assets/country-subdivisions/canada.json +79 -79
- package/src/_modules/location/_collections/assets/country-subdivisions/cape-verde.json +9 -9
- package/src/_modules/location/_collections/assets/country-subdivisions/central-african-republic.json +69 -69
- package/src/_modules/location/_collections/assets/country-subdivisions/chad.json +89 -89
- package/src/_modules/location/_collections/assets/country-subdivisions/chile.json +61 -61
- package/src/_modules/location/_collections/assets/country-subdivisions/china.json +205 -205
- package/src/_modules/location/_collections/assets/country-subdivisions/colombia.json +133 -133
- package/src/_modules/location/_collections/assets/country-subdivisions/comoros.json +13 -13
- package/src/_modules/location/_collections/assets/country-subdivisions/congo-the-democratic-republic-of-the.json +45 -45
- package/src/_modules/location/_collections/assets/country-subdivisions/congo.json +49 -49
- package/src/_modules/location/_collections/assets/country-subdivisions/costa-rica.json +29 -29
- package/src/_modules/location/_collections/assets/country-subdivisions/cote-d-ivoire-republic-of.json +77 -77
- package/src/_modules/location/_collections/assets/country-subdivisions/croatia.json +85 -85
- package/src/_modules/location/_collections/assets/country-subdivisions/cuba.json +65 -65
- package/src/_modules/location/_collections/assets/country-subdivisions/cyprus.json +25 -25
- package/src/_modules/location/_collections/assets/country-subdivisions/czech-republic.json +57 -57
- package/src/_modules/location/_collections/assets/country-subdivisions/denmark.json +21 -21
- package/src/_modules/location/_collections/assets/country-subdivisions/djibouti.json +25 -25
- package/src/_modules/location/_collections/assets/country-subdivisions/dominica.json +41 -41
- package/src/_modules/location/_collections/assets/country-subdivisions/dominican-republic.json +41 -41
- package/src/_modules/location/_collections/assets/country-subdivisions/ecuador.json +97 -97
- package/src/_modules/location/_collections/assets/country-subdivisions/egypt.json +117 -117
- package/src/_modules/location/_collections/assets/country-subdivisions/el-salvador.json +57 -57
- package/src/_modules/location/_collections/assets/country-subdivisions/equatorial-guinea.json +9 -9
- package/src/_modules/location/_collections/assets/country-subdivisions/eritrea.json +25 -25
- package/src/_modules/location/_collections/assets/country-subdivisions/estonia.json +61 -61
- package/src/_modules/location/_collections/assets/country-subdivisions/ethiopia.json +45 -45
- package/src/_modules/location/_collections/assets/country-subdivisions/fiji.json +21 -21
- package/src/_modules/location/_collections/assets/country-subdivisions/finland.json +77 -77
- package/src/_modules/location/_collections/assets/country-subdivisions/france.json +133 -133
- package/src/_modules/location/_collections/assets/country-subdivisions/gabon.json +37 -37
- package/src/_modules/location/_collections/assets/country-subdivisions/gambia.json +25 -25
- package/src/_modules/location/_collections/assets/country-subdivisions/georgia.json +49 -49
- package/src/_modules/location/_collections/assets/country-subdivisions/germany.json +65 -65
- package/src/_modules/location/_collections/assets/country-subdivisions/ghana.json +41 -41
- package/src/_modules/location/_collections/assets/country-subdivisions/greece.json +53 -53
- package/src/_modules/location/_collections/assets/country-subdivisions/greenland.json +17 -17
- package/src/_modules/location/_collections/assets/country-subdivisions/grenada.json +29 -29
- package/src/_modules/location/_collections/assets/country-subdivisions/guatemala.json +89 -89
- package/src/_modules/location/_collections/assets/country-subdivisions/guinea-bissau.json +13 -13
- package/src/_modules/location/_collections/assets/country-subdivisions/guinea.json +33 -33
- package/src/_modules/location/_collections/assets/country-subdivisions/guyana.json +41 -41
- package/src/_modules/location/_collections/assets/country-subdivisions/haiti.json +41 -41
- package/src/_modules/location/_collections/assets/country-subdivisions/honduras.json +73 -73
- package/src/_modules/location/_collections/assets/country-subdivisions/hong-kong.json +4 -4
- package/src/_modules/location/_collections/assets/country-subdivisions/hungary.json +173 -173
- package/src/_modules/location/_collections/assets/country-subdivisions/iceland.json +37 -37
- package/src/_modules/location/_collections/assets/country-subdivisions/india.json +181 -181
- package/src/_modules/location/_collections/assets/country-subdivisions/indonesia.json +29 -29
- package/src/_modules/location/_collections/assets/country-subdivisions/iran-islamic-republic-of.json +125 -125
- package/src/_modules/location/_collections/assets/country-subdivisions/iraq.json +73 -73
- package/src/_modules/location/_collections/assets/country-subdivisions/ireland.json +17 -17
- package/src/_modules/location/_collections/assets/country-subdivisions/israel.json +25 -25
- package/src/_modules/location/_collections/assets/country-subdivisions/italy.json +81 -81
- package/src/_modules/location/_collections/assets/country-subdivisions/jamaica.json +57 -57
- package/src/_modules/location/_collections/assets/country-subdivisions/japan.json +189 -189
- package/src/_modules/location/_collections/assets/country-subdivisions/jordan.json +49 -49
- package/src/_modules/location/_collections/assets/country-subdivisions/kazakhstan.json +65 -65
- package/src/_modules/location/_collections/assets/country-subdivisions/kenya.json +33 -33
- package/src/_modules/location/_collections/assets/country-subdivisions/kiribati.json +13 -13
- package/src/_modules/location/_collections/assets/country-subdivisions/korea-democratic-people-s-republic-of.json +45 -45
- package/src/_modules/location/_collections/assets/country-subdivisions/korea-republic-of.json +69 -69
- package/src/_modules/location/_collections/assets/country-subdivisions/kuwait.json +25 -25
- package/src/_modules/location/_collections/assets/country-subdivisions/kyrgyzstan.json +33 -33
- package/src/_modules/location/_collections/assets/country-subdivisions/lao-people-s-democratic-republic.json +73 -73
- package/src/_modules/location/_collections/assets/country-subdivisions/latvia.json +477 -477
- package/src/_modules/location/_collections/assets/country-subdivisions/lebanon.json +33 -33
- package/src/_modules/location/_collections/assets/country-subdivisions/lesotho.json +41 -41
- package/src/_modules/location/_collections/assets/country-subdivisions/liberia.json +61 -61
- package/src/_modules/location/_collections/assets/country-subdivisions/libyan-arab-jamahiriya.json +89 -89
- package/src/_modules/location/_collections/assets/country-subdivisions/liechtenstein.json +45 -45
- package/src/_modules/location/_collections/assets/country-subdivisions/lithuania.json +41 -41
- package/src/_modules/location/_collections/assets/country-subdivisions/luxembourg.json +13 -13
- package/src/_modules/location/_collections/assets/country-subdivisions/macedonia-the-former-yugoslav-republic-of.json +337 -337
- package/src/_modules/location/_collections/assets/country-subdivisions/madagascar.json +25 -25
- package/src/_modules/location/_collections/assets/country-subdivisions/malawi.json +13 -13
- package/src/_modules/location/_collections/assets/country-subdivisions/malaysia.json +81 -81
- package/src/_modules/location/_collections/assets/country-subdivisions/maldives.json +33 -33
- package/src/_modules/location/_collections/assets/country-subdivisions/mali.json +37 -37
- package/src/_modules/location/_collections/assets/country-subdivisions/malta.json +273 -273
- package/src/_modules/location/_collections/assets/country-subdivisions/marshall-islands.json +9 -9
- package/src/_modules/location/_collections/assets/country-subdivisions/mauritania.json +53 -53
- package/src/_modules/location/_collections/assets/country-subdivisions/mauritius.json +69 -69
- package/src/_modules/location/_collections/assets/country-subdivisions/mexico.json +161 -161
- package/src/_modules/location/_collections/assets/country-subdivisions/micronesia-federated-states-of.json +17 -17
- package/src/_modules/location/_collections/assets/country-subdivisions/moldova-republic-of.json +149 -149
- package/src/_modules/location/_collections/assets/country-subdivisions/monaco.json +69 -69
- package/src/_modules/location/_collections/assets/country-subdivisions/mongolia.json +89 -89
- package/src/_modules/location/_collections/assets/country-subdivisions/montenegro.json +93 -93
- package/src/_modules/location/_collections/assets/country-subdivisions/morocco.json +65 -65
- package/src/_modules/location/_collections/assets/country-subdivisions/mozambique.json +45 -45
- package/src/_modules/location/_collections/assets/country-subdivisions/myanmar.json +57 -57
- package/src/_modules/location/_collections/assets/country-subdivisions/namibia.json +57 -57
- package/src/_modules/location/_collections/assets/country-subdivisions/nauru.json +57 -57
- package/src/_modules/location/_collections/assets/country-subdivisions/nepal.json +21 -21
- package/src/_modules/location/_collections/assets/country-subdivisions/netherlands.json +91 -91
- package/src/_modules/location/_collections/assets/country-subdivisions/new-zealand.json +111 -111
- package/src/_modules/location/_collections/assets/country-subdivisions/nicaragua.json +69 -69
- package/src/_modules/location/_collections/assets/country-subdivisions/niger.json +33 -33
- package/src/_modules/location/_collections/assets/country-subdivisions/nigeria.json +149 -149
- package/src/_modules/location/_collections/assets/country-subdivisions/norway.json +85 -85
- package/src/_modules/location/_collections/assets/country-subdivisions/oman.json +37 -37
- package/src/_modules/location/_collections/assets/country-subdivisions/pakistan.json +33 -33
- package/src/_modules/location/_collections/assets/country-subdivisions/palau.json +65 -65
- package/src/_modules/location/_collections/assets/country-subdivisions/palestinian-territory-occupied.json +65 -65
- package/src/_modules/location/_collections/assets/country-subdivisions/panama.json +53 -53
- package/src/_modules/location/_collections/assets/country-subdivisions/papua-new-guinea.json +81 -81
- package/src/_modules/location/_collections/assets/country-subdivisions/paraguay.json +73 -73
- package/src/_modules/location/_collections/assets/country-subdivisions/peru.json +105 -105
- package/src/_modules/location/_collections/assets/country-subdivisions/philippines.json +69 -69
- package/src/_modules/location/_collections/assets/country-subdivisions/poland.json +65 -65
- package/src/_modules/location/_collections/assets/country-subdivisions/portugal.json +81 -81
- package/src/_modules/location/_collections/assets/country-subdivisions/qatar.json +29 -29
- package/src/_modules/location/_collections/assets/country-subdivisions/romania.json +169 -169
- package/src/_modules/location/_collections/assets/country-subdivisions/russian-federation.json +499 -499
- package/src/_modules/location/_collections/assets/country-subdivisions/rwanda.json +21 -21
- package/src/_modules/location/_collections/assets/country-subdivisions/saint-helena-ascension-and-tristan-da-cunha.json +13 -13
- package/src/_modules/location/_collections/assets/country-subdivisions/saint-kitts-and-nevis.json +9 -9
- package/src/_modules/location/_collections/assets/country-subdivisions/saint-lucia.json +45 -45
- package/src/_modules/location/_collections/assets/country-subdivisions/saint-vincent-and-the-grenadines.json +25 -25
- package/src/_modules/location/_collections/assets/country-subdivisions/samoa.json +45 -45
- package/src/_modules/location/_collections/assets/country-subdivisions/san-marino.json +37 -37
- package/src/_modules/location/_collections/assets/country-subdivisions/sao-tome-and-principe.json +9 -9
- package/src/_modules/location/_collections/assets/country-subdivisions/saudi-arabia.json +53 -53
- package/src/_modules/location/_collections/assets/country-subdivisions/senegal.json +57 -57
- package/src/_modules/location/_collections/assets/country-subdivisions/serbia.json +9 -9
- package/src/_modules/location/_collections/assets/country-subdivisions/seychelles.json +101 -101
- package/src/_modules/location/_collections/assets/country-subdivisions/sierra-leone.json +17 -17
- package/src/_modules/location/_collections/assets/country-subdivisions/singapore.json +21 -21
- package/src/_modules/location/_collections/assets/country-subdivisions/slovakia.json +33 -33
- package/src/_modules/location/_collections/assets/country-subdivisions/slovenia.json +841 -841
- package/src/_modules/location/_collections/assets/country-subdivisions/solomon-islands.json +41 -41
- package/src/_modules/location/_collections/assets/country-subdivisions/somalia.json +73 -73
- package/src/_modules/location/_collections/assets/country-subdivisions/south-africa.json +37 -37
- package/src/_modules/location/_collections/assets/country-subdivisions/south-sudan.json +41 -41
- package/src/_modules/location/_collections/assets/country-subdivisions/spain.json +346 -346
- package/src/_modules/location/_collections/assets/country-subdivisions/sri-lanka.json +37 -37
- package/src/_modules/location/_collections/assets/country-subdivisions/sudan.json +69 -69
- package/src/_modules/location/_collections/assets/country-subdivisions/suriname.json +41 -41
- package/src/_modules/location/_collections/assets/country-subdivisions/swaziland.json +17 -17
- package/src/_modules/location/_collections/assets/country-subdivisions/sweden.json +85 -85
- package/src/_modules/location/_collections/assets/country-subdivisions/switzerland.json +105 -105
- package/src/_modules/location/_collections/assets/country-subdivisions/syrian-arab-republic.json +57 -57
- package/src/_modules/location/_collections/assets/country-subdivisions/taiwan-province-of-china.json +93 -93
- package/src/_modules/location/_collections/assets/country-subdivisions/tajikistan.json +17 -17
- package/src/_modules/location/_collections/assets/country-subdivisions/tanzania-united-republic-of.json +105 -105
- package/src/_modules/location/_collections/assets/country-subdivisions/thailand.json +313 -313
- package/src/_modules/location/_collections/assets/country-subdivisions/timor-leste.json +53 -53
- package/src/_modules/location/_collections/assets/country-subdivisions/togo.json +21 -21
- package/src/_modules/location/_collections/assets/country-subdivisions/tonga.json +21 -21
- package/src/_modules/location/_collections/assets/country-subdivisions/trinidad-and-tobago.json +65 -65
- package/src/_modules/location/_collections/assets/country-subdivisions/tunisia.json +97 -97
- package/src/_modules/location/_collections/assets/country-subdivisions/turkey.json +325 -325
- package/src/_modules/location/_collections/assets/country-subdivisions/turkmenistan.json +25 -25
- package/src/_modules/location/_collections/assets/country-subdivisions/tuvalu.json +33 -33
- package/src/_modules/location/_collections/assets/country-subdivisions/uganda.json +17 -17
- package/src/_modules/location/_collections/assets/country-subdivisions/ukraine.json +109 -109
- package/src/_modules/location/_collections/assets/country-subdivisions/united-arab-emirates.json +29 -29
- package/src/_modules/location/_collections/assets/country-subdivisions/united-kingdom.json +1196 -1196
- package/src/_modules/location/_collections/assets/country-subdivisions/united-states-minor-outlying-islands.json +37 -37
- package/src/_modules/location/_collections/assets/country-subdivisions/united-states.json +286 -286
- package/src/_modules/location/_collections/assets/country-subdivisions/uruguay.json +77 -77
- package/src/_modules/location/_collections/assets/country-subdivisions/uzbekistan.json +57 -57
- package/src/_modules/location/_collections/assets/country-subdivisions/vanuatu.json +25 -25
- package/src/_modules/location/_collections/assets/country-subdivisions/venezuela.json +101 -101
- package/src/_modules/location/_collections/assets/country-subdivisions/viet-nam.json +257 -257
- package/src/_modules/location/_collections/assets/country-subdivisions/yemen.json +85 -85
- package/src/_modules/location/_collections/assets/country-subdivisions/zambia.json +37 -37
- package/src/_modules/location/_collections/assets/country-subdivisions/zimbabwe.json +41 -41
- package/src/_modules/location/_collections/loc-country-divisions.const.ts +10 -10
- package/src/_modules/location/_collections/loc-country-isos.const.ts +8 -8
- package/src/_modules/location/_collections/loc-regions.util.spec.ts +61 -61
- package/src/_modules/location/_collections/loc-regions.util.ts +137 -137
- package/src/_modules/location/_collections/loc.util.spec.ts +52 -52
- package/src/_modules/location/_collections/loc.util.ts +74 -74
- package/src/_modules/location/_enums/loc-region.enum.ts +14 -14
- package/src/_modules/location/_enums/loc-sub-region.enum.ts +31 -31
- package/src/_modules/location/_enums/loc-subdivision-region-type.enum.ts +47 -47
- package/src/_modules/location/_models/loc-coordinates.interface.ts +7 -7
- package/src/_modules/location/_models/loc-country-division.interface.ts +8 -8
- package/src/_modules/location/_models/loc-country-iso.interface.ts +23 -23
- package/src/_modules/location/_models/loc-country-phone-code.interface.ts +9 -9
- package/src/_modules/location/_models/loc-division-collection.interface.ts +12 -12
- package/src/_modules/location/_models/loc-division-region-data.interface.ts +9 -9
- package/src/_modules/location/_models/loc-geo-ip-location.interface.ts +27 -27
- package/src/_modules/location/index.ts +22 -22
- package/src/_modules/messaging/README.md +279 -279
- package/src/_modules/messaging/_collections/msg-module-settings.const.ts +46 -46
- package/src/_modules/messaging/_enums/msg-attachment-type.enum.ts +26 -26
- package/src/_modules/messaging/_enums/msg-delivery-status.enum.ts +17 -17
- package/src/_modules/messaging/_enums/msg-event-key.enum.ts +31 -31
- package/src/_modules/messaging/_enums/msg-participant-role.enum.ts +20 -20
- package/src/_modules/messaging/_enums/msg-provider-type.enum.ts +7 -7
- package/src/_modules/messaging/_enums/msg-type.enum.ts +23 -23
- package/src/_modules/messaging/_models/msg-attachment.interface.ts +46 -46
- package/src/_modules/messaging/_models/msg-conversation.data-model.spec.ts +69 -69
- package/src/_modules/messaging/_models/msg-conversation.data-model.ts +96 -96
- package/src/_modules/messaging/_models/msg-mention.interface.ts +29 -29
- package/src/_modules/messaging/_models/msg-message.data-model.spec.ts +79 -79
- package/src/_modules/messaging/_models/msg-message.data-model.ts +127 -127
- package/src/_modules/messaging/_models/msg-participant.interface.ts +46 -46
- package/src/_modules/messaging/_models/msg-reaction.interface.ts +20 -20
- package/src/_modules/messaging/_models/msg-thread-info.interface.ts +35 -35
- package/src/_modules/messaging/_modules/agent/_enums/agt-process-step-type.enum.ts +35 -35
- package/src/_modules/messaging/_modules/agent/_enums/agt-tool-status.enum.ts +23 -23
- package/src/_modules/messaging/_modules/agent/_models/agt-process-step.interface.ts +55 -55
- package/src/_modules/messaging/_modules/agent/_models/agt-reasoning-info.interface.ts +26 -26
- package/src/_modules/messaging/_modules/agent/_models/agt-tool-usage.interface.ts +37 -37
- package/src/_modules/messaging/_modules/agent/index.ts +8 -8
- package/src/_modules/messaging/index.ts +28 -28
- package/src/_modules/pipe/_collections/pip-transforms.const.ts +42 -42
- package/src/_modules/pipe/_collections/utils/pip-country-pipe.util.spec.ts +47 -47
- package/src/_modules/pipe/_collections/utils/pip-country-pipe.util.ts +41 -41
- package/src/_modules/pipe/_collections/utils/pip-custom-pipe.util.spec.ts +39 -39
- package/src/_modules/pipe/_collections/utils/pip-custom-pipe.util.ts +30 -30
- package/src/_modules/pipe/_collections/utils/pip-division-pipe.util.spec.ts +41 -41
- package/src/_modules/pipe/_collections/utils/pip-division-pipe.util.ts +36 -36
- package/src/_modules/pipe/_collections/utils/pip-json-pipe.util.spec.ts +62 -62
- package/src/_modules/pipe/_collections/utils/pip-json-pipe.util.ts +17 -17
- package/src/_modules/pipe/_collections/utils/pip-list-pipe.util.spec.ts +34 -34
- package/src/_modules/pipe/_collections/utils/pip-list-pipe.util.ts +25 -25
- package/src/_modules/pipe/_collections/utils/pip-multi-pipe-pipe.util.spec.ts +67 -67
- package/src/_modules/pipe/_collections/utils/pip-multi-pipe-pipe.util.ts +226 -226
- package/src/_modules/pipe/_collections/utils/pip-obj-key-pipe.util.spec.ts +28 -28
- package/src/_modules/pipe/_collections/utils/pip-obj-key-pipe.util.ts +21 -21
- package/src/_modules/pipe/_collections/utils/pip-range-pipe.util.spec.ts +59 -59
- package/src/_modules/pipe/_collections/utils/pip-range-pipe.util.ts +106 -106
- package/src/_modules/pipe/_collections/utils/pip-region-pipe.util.spec.ts +31 -31
- package/src/_modules/pipe/_collections/utils/pip-region-pipe.util.ts +35 -35
- package/src/_modules/pipe/_collections/utils/pip-replace-pipe.util.spec.ts +44 -44
- package/src/_modules/pipe/_collections/utils/pip-replace-pipe.util.ts +23 -23
- package/src/_modules/pipe/_collections/utils/pip-slider-pipe.util.spec.ts +21 -21
- package/src/_modules/pipe/_collections/utils/pip-slider-pipe.util.ts +33 -33
- package/src/_modules/pipe/_collections/utils/pip-smart-replace-pipe.util.spec.ts +62 -62
- package/src/_modules/pipe/_collections/utils/pip-smart-replace-pipe.util.ts +80 -80
- package/src/_modules/pipe/_enums/pip-range-pipe-setting.enum.ts +15 -15
- package/src/_modules/pipe/_enums/pip.enum.ts +65 -65
- package/src/_modules/pipe/_models/pip-multi-pipe-settings.type.ts +8 -8
- package/src/_modules/pipe/_models/pip-transforms.interface.ts +30 -30
- package/src/_modules/pipe/index.ts +30 -30
- package/src/_modules/socket/_enums/sck-event-key.enum.ts +21 -21
- package/src/_modules/socket/_models/sck-client-params.control-model.spec.ts +67 -67
- package/src/_modules/socket/_models/sck-client-params.control-model.ts +50 -50
- package/src/_modules/socket/_models/sck-socket-event.control-model.spec.ts +66 -66
- package/src/_modules/socket/_models/sck-socket-event.control-model.ts +172 -172
- package/src/_modules/socket/_services/sck-client.service-base.spec.ts +99 -99
- package/src/_modules/socket/_services/sck-client.service-base.ts +353 -353
- package/src/_modules/socket/index.ts +14 -14
- package/src/_modules/test/_collections/tst-module-settings.const.ts +67 -67
- package/src/_modules/test/index.ts +5 -5
- package/src/_modules/usage/_collections/usg-module-settings.const.ts +33 -33
- package/src/_modules/usage/_models/usg-action.control-model.spec.ts +27 -27
- package/src/_modules/usage/_models/usg-action.control-model.ts +28 -28
- package/src/_modules/usage/_models/usg-daily-usage-data.control-model.spec.ts +36 -36
- package/src/_modules/usage/_models/usg-daily-usage-data.control-model.ts +35 -35
- package/src/_modules/usage/_models/usg-data.control-model.spec.ts +41 -41
- package/src/_modules/usage/_models/usg-data.control-model.ts +35 -35
- package/src/_modules/usage/_models/usg-session.data-model.spec.ts +97 -97
- package/src/_modules/usage/_models/usg-session.data-model.ts +72 -72
- package/src/_modules/usage/index.ts +11 -11
- package/src/index.ts +102 -102
- package/tsconfig.app.json +12 -12
- package/tsconfig.json +31 -31
- package/tsconfig.test.json +16 -16
- package/tslint.json +153 -153
- package/pipeline.cicd.config.json +0 -128
|
@@ -1,354 +1,354 @@
|
|
|
1
|
-
import { DyFM_Async } from './async.util';
|
|
2
|
-
import { DyFM_Time } from './time.util';
|
|
3
|
-
import { DyFM_Log } from './log.util';
|
|
4
|
-
import { Observable } from 'rxjs';
|
|
5
|
-
|
|
6
|
-
describe('| DyFM_Async', (): void => {
|
|
7
|
-
|
|
8
|
-
describe('| wait', (): void => {
|
|
9
|
-
it('| should delay execution for specified milliseconds', async (): Promise<void> => {
|
|
10
|
-
const startTime = Date.now();
|
|
11
|
-
await DyFM_Async.wait(100);
|
|
12
|
-
const endTime = Date.now();
|
|
13
|
-
const elapsed = endTime - startTime;
|
|
14
|
-
|
|
15
|
-
// Allow for some timing variance - wait should take at least some time
|
|
16
|
-
expect(elapsed).toBeGreaterThanOrEqual(0);
|
|
17
|
-
expect(elapsed).toBeLessThan(200);
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
it('| should handle zero delay', async (): Promise<void> => {
|
|
21
|
-
const startTime = Date.now();
|
|
22
|
-
await DyFM_Async.wait(0);
|
|
23
|
-
const endTime = Date.now();
|
|
24
|
-
const elapsed = endTime - startTime;
|
|
25
|
-
|
|
26
|
-
expect(elapsed).toBeLessThan(50);
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
it('| should handle negative delay as zero', async (): Promise<void> => {
|
|
30
|
-
const startTime = Date.now();
|
|
31
|
-
await DyFM_Async.wait(-100);
|
|
32
|
-
const endTime = Date.now();
|
|
33
|
-
const elapsed = endTime - startTime;
|
|
34
|
-
|
|
35
|
-
expect(elapsed).toBeLessThan(50);
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
describe('| sleep', (): void => {
|
|
40
|
-
it('| should be an alias for wait', async (): Promise<void> => {
|
|
41
|
-
const startTime = Date.now();
|
|
42
|
-
await DyFM_Async.sleep(100);
|
|
43
|
-
const endTime = Date.now();
|
|
44
|
-
const elapsed = endTime - startTime;
|
|
45
|
-
|
|
46
|
-
// Allow for some timing variance
|
|
47
|
-
expect(elapsed).toBeGreaterThanOrEqual(0);
|
|
48
|
-
expect(elapsed).toBeLessThan(200);
|
|
49
|
-
});
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
describe('| delay', (): void => {
|
|
53
|
-
it('| should be an alias for wait', async (): Promise<void> => {
|
|
54
|
-
const startTime = Date.now();
|
|
55
|
-
await DyFM_Async.delay(100);
|
|
56
|
-
const endTime = Date.now();
|
|
57
|
-
const elapsed = endTime - startTime;
|
|
58
|
-
|
|
59
|
-
// Allow for some timing variance
|
|
60
|
-
expect(elapsed).toBeGreaterThanOrEqual(0);
|
|
61
|
-
expect(elapsed).toBeLessThan(200);
|
|
62
|
-
});
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
describe('| waitUntil', (): void => {
|
|
66
|
-
it('| should resolve when check returns true', async (): Promise<void> => {
|
|
67
|
-
let checkCount = 0;
|
|
68
|
-
const check = (): boolean => {
|
|
69
|
-
checkCount++;
|
|
70
|
-
return checkCount >= 3;
|
|
71
|
-
};
|
|
72
|
-
|
|
73
|
-
// Use shorter timeout for faster test execution
|
|
74
|
-
// waitUntil(check, interval, timeout) - interval=100ms, timeout=500ms
|
|
75
|
-
await DyFM_Async.waitUntil(check, 100, 500);
|
|
76
|
-
|
|
77
|
-
expect(checkCount).toBeGreaterThanOrEqual(3);
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
it('| should use default interval and timeout when not provided', async (): Promise<void> => {
|
|
81
|
-
let checkCount = 0;
|
|
82
|
-
const check = (): boolean => {
|
|
83
|
-
checkCount++;
|
|
84
|
-
return checkCount >= 2;
|
|
85
|
-
};
|
|
86
|
-
|
|
87
|
-
// Use explicit shorter timeout to avoid default 10s timeout
|
|
88
|
-
// waitUntil(check, interval, timeout) - interval=100ms, timeout=500ms
|
|
89
|
-
await DyFM_Async.waitUntil(check, 100, 500);
|
|
90
|
-
|
|
91
|
-
expect(checkCount).toBeGreaterThanOrEqual(2);
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it('| should handle check that returns true immediately', async (): Promise<void> => {
|
|
95
|
-
const check = (): boolean => true;
|
|
96
|
-
const startTime = Date.now();
|
|
97
|
-
|
|
98
|
-
// Use shorter timeout for faster test execution
|
|
99
|
-
await DyFM_Async.waitUntil(check, 10, 100);
|
|
100
|
-
const elapsed = Date.now() - startTime;
|
|
101
|
-
|
|
102
|
-
expect(elapsed).toBeLessThan(50);
|
|
103
|
-
});
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
describe('| waitUntilAsync', (): void => {
|
|
107
|
-
it('| should resolve when async check returns true', async (): Promise<void> => {
|
|
108
|
-
let checkCount = 0;
|
|
109
|
-
const check = async (): Promise<boolean> => {
|
|
110
|
-
await DyFM_Async.wait(5);
|
|
111
|
-
checkCount++;
|
|
112
|
-
return checkCount >= 3;
|
|
113
|
-
};
|
|
114
|
-
|
|
115
|
-
// Use shorter timeout for faster test execution
|
|
116
|
-
await DyFM_Async.waitUntilAsync(check, 10, 100);
|
|
117
|
-
|
|
118
|
-
expect(checkCount).toBeGreaterThanOrEqual(3);
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
it('| should use default interval and timeout when not provided', async (): Promise<void> => {
|
|
122
|
-
let checkCount = 0;
|
|
123
|
-
const check = async (): Promise<boolean> => {
|
|
124
|
-
await DyFM_Async.wait(5);
|
|
125
|
-
checkCount++;
|
|
126
|
-
return checkCount >= 2;
|
|
127
|
-
};
|
|
128
|
-
|
|
129
|
-
// Use explicit shorter timeout to avoid default 10s timeout
|
|
130
|
-
await DyFM_Async.waitUntilAsync(check, 10, 100);
|
|
131
|
-
|
|
132
|
-
expect(checkCount).toBeGreaterThanOrEqual(2);
|
|
133
|
-
});
|
|
134
|
-
|
|
135
|
-
it('| should handle async check that returns true immediately', async (): Promise<void> => {
|
|
136
|
-
const check = async (): Promise<boolean> => {
|
|
137
|
-
return true;
|
|
138
|
-
};
|
|
139
|
-
const startTime = Date.now();
|
|
140
|
-
|
|
141
|
-
// Use shorter timeout for faster test execution
|
|
142
|
-
await DyFM_Async.waitUntilAsync(check, 10, 100);
|
|
143
|
-
const elapsed = Date.now() - startTime;
|
|
144
|
-
|
|
145
|
-
expect(elapsed).toBeLessThan(50);
|
|
146
|
-
});
|
|
147
|
-
});
|
|
148
|
-
|
|
149
|
-
describe('| takeUntil', (): void => {
|
|
150
|
-
it('| should resolve when observable emits value that passes check', async (): Promise<void> => {
|
|
151
|
-
const observable = new Observable<number>((observer) => {
|
|
152
|
-
let count = 0;
|
|
153
|
-
const interval = setInterval(() => {
|
|
154
|
-
observer.next(count);
|
|
155
|
-
count++;
|
|
156
|
-
if (count > 10) {
|
|
157
|
-
clearInterval(interval);
|
|
158
|
-
observer.complete();
|
|
159
|
-
}
|
|
160
|
-
}, 10);
|
|
161
|
-
});
|
|
162
|
-
|
|
163
|
-
const result = await DyFM_Async.takeUntil(observable, (value?: number) => (value ?? 0) > 5);
|
|
164
|
-
|
|
165
|
-
expect(result).toBeGreaterThan(5);
|
|
166
|
-
});
|
|
167
|
-
|
|
168
|
-
it('| should handle check function that uses value parameter', async (): Promise<void> => {
|
|
169
|
-
const observable = new Observable<string>((observer) => {
|
|
170
|
-
setTimeout(() => observer.next('test'), 10);
|
|
171
|
-
});
|
|
172
|
-
|
|
173
|
-
const result = await DyFM_Async.takeUntil(observable, (value?: string) => value === 'test');
|
|
174
|
-
|
|
175
|
-
expect(result).toBe('test');
|
|
176
|
-
});
|
|
177
|
-
|
|
178
|
-
it('| should unsubscribe after resolving', async (): Promise<void> => {
|
|
179
|
-
let emitCount = 0;
|
|
180
|
-
const observable = new Observable<number>((observer) => {
|
|
181
|
-
const interval = setInterval(() => {
|
|
182
|
-
emitCount++;
|
|
183
|
-
observer.next(emitCount);
|
|
184
|
-
}, 10);
|
|
185
|
-
});
|
|
186
|
-
|
|
187
|
-
await DyFM_Async.takeUntil(observable, (value?: number) => (value ?? 0) >= 3);
|
|
188
|
-
|
|
189
|
-
// Use shorter wait time for faster test execution
|
|
190
|
-
await DyFM_Async.wait(30);
|
|
191
|
-
const finalEmitCount = emitCount;
|
|
192
|
-
|
|
193
|
-
expect(finalEmitCount).toBeLessThanOrEqual(6);
|
|
194
|
-
});
|
|
195
|
-
});
|
|
196
|
-
|
|
197
|
-
describe('| waitWithCountdownLogging', (): void => {
|
|
198
|
-
beforeEach(() => {
|
|
199
|
-
spyOn(DyFM_Log, 'info');
|
|
200
|
-
spyOn(DyFM_Log, 'success');
|
|
201
|
-
});
|
|
202
|
-
|
|
203
|
-
afterEach(async () => {
|
|
204
|
-
// Wait a bit to ensure all async operations complete
|
|
205
|
-
await DyFM_Async.wait(50);
|
|
206
|
-
});
|
|
207
|
-
|
|
208
|
-
it('| should handle zero duration', async (): Promise<void> => {
|
|
209
|
-
const startTime = Date.now();
|
|
210
|
-
await DyFM_Async.waitWithCountdownLogging(0, 'Zero Duration');
|
|
211
|
-
const elapsed = Date.now() - startTime;
|
|
212
|
-
|
|
213
|
-
expect(elapsed).toBeLessThan(50);
|
|
214
|
-
expect(DyFM_Log.success).toHaveBeenCalledWith('✅ Zero Duration completed');
|
|
215
|
-
}, 10000);
|
|
216
|
-
|
|
217
|
-
it('| should handle negative duration as zero', async (): Promise<void> => {
|
|
218
|
-
const startTime = Date.now();
|
|
219
|
-
await DyFM_Async.waitWithCountdownLogging(-100, 'Negative Duration');
|
|
220
|
-
const elapsed = Date.now() - startTime;
|
|
221
|
-
|
|
222
|
-
expect(elapsed).toBeLessThan(50);
|
|
223
|
-
}, 10000);
|
|
224
|
-
|
|
225
|
-
describe('| getLogInterval branch coverage', (): void => {
|
|
226
|
-
// Test all branches of getLogInterval function (lines 155-168)
|
|
227
|
-
// This function is private, so we test it indirectly through waitWithCountdownLogging
|
|
228
|
-
// We use actual durations to trigger each branch condition
|
|
229
|
-
|
|
230
|
-
it('| should use week interval for durations >= 4 weeks', async (): Promise<void> => {
|
|
231
|
-
// 4 weeks = 4 * 7 * 24 * 60 * 60 * 1000 = 2419200000 ms
|
|
232
|
-
// Use exactly 4 weeks to trigger the branch, but wait only a short time for test speed
|
|
233
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('1w');
|
|
234
|
-
const fourWeeks = 4 * 7 * 24 * 60 * 60 * 1000;
|
|
235
|
-
// Actually wait for the full duration to trigger the branch properly
|
|
236
|
-
const promise = DyFM_Async.waitWithCountdownLogging(fourWeeks, 'Week Test');
|
|
237
|
-
// Don't await - this would take 4 weeks! Instead, just verify the function is called
|
|
238
|
-
// The branch will be covered when the function calculates the interval
|
|
239
|
-
expect(promise).toBeDefined();
|
|
240
|
-
// Cancel the promise after a short time
|
|
241
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
242
|
-
}, 11000);
|
|
243
|
-
|
|
244
|
-
it('| should use day interval for durations >= 7 days but < 4 weeks', async (): Promise<void> => {
|
|
245
|
-
// 7 days = 7 * 24 * 60 * 60 * 1000 = 604800000 ms
|
|
246
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('1d');
|
|
247
|
-
const sevenDays = 7 * 24 * 60 * 60 * 1000;
|
|
248
|
-
const promise = DyFM_Async.waitWithCountdownLogging(sevenDays, 'Day Test');
|
|
249
|
-
expect(promise).toBeDefined();
|
|
250
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
251
|
-
}, 11000);
|
|
252
|
-
|
|
253
|
-
it('| should use 12 hour interval for durations >= 3 days but < 7 days', async (): Promise<void> => {
|
|
254
|
-
// 3 days = 3 * 24 * 60 * 60 * 1000 = 259200000 ms
|
|
255
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('12h');
|
|
256
|
-
const threeDays = 3 * 24 * 60 * 60 * 1000;
|
|
257
|
-
const promise = DyFM_Async.waitWithCountdownLogging(threeDays, '3 Days Test');
|
|
258
|
-
expect(promise).toBeDefined();
|
|
259
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
260
|
-
}, 11000);
|
|
261
|
-
|
|
262
|
-
it('| should use 3 hour interval for durations >= 12 hours but < 1 day', async (): Promise<void> => {
|
|
263
|
-
// 12 hours = 12 * 60 * 60 * 1000 = 43200000 ms
|
|
264
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('3h');
|
|
265
|
-
const twelveHours = 12 * 60 * 60 * 1000;
|
|
266
|
-
const promise = DyFM_Async.waitWithCountdownLogging(twelveHours, '12 Hours Test');
|
|
267
|
-
expect(promise).toBeDefined();
|
|
268
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
269
|
-
}, 11000);
|
|
270
|
-
|
|
271
|
-
it('| should use 1 hour interval for durations >= 6 hours but < 12 hours', async (): Promise<void> => {
|
|
272
|
-
// 6 hours = 6 * 60 * 60 * 1000 = 21600000 ms
|
|
273
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('1h');
|
|
274
|
-
const sixHours = 6 * 60 * 60 * 1000;
|
|
275
|
-
const promise = DyFM_Async.waitWithCountdownLogging(sixHours, '6 Hours Test');
|
|
276
|
-
expect(promise).toBeDefined();
|
|
277
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
278
|
-
}, 11000);
|
|
279
|
-
|
|
280
|
-
it('| should use 30 minute interval for durations >= 3 hours but < 6 hours', async (): Promise<void> => {
|
|
281
|
-
// 3 hours = 3 * 60 * 60 * 1000 = 10800000 ms
|
|
282
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('30m');
|
|
283
|
-
const threeHours = 3 * 60 * 60 * 1000;
|
|
284
|
-
const promise = DyFM_Async.waitWithCountdownLogging(threeHours, '3 Hours Test');
|
|
285
|
-
expect(promise).toBeDefined();
|
|
286
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
287
|
-
}, 11000);
|
|
288
|
-
|
|
289
|
-
it('| should use 10 minute interval for durations >= 1 hour but < 3 hours', async (): Promise<void> => {
|
|
290
|
-
// 1 hour = 60 * 60 * 1000 = 3600000 ms
|
|
291
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('10m');
|
|
292
|
-
const oneHour = 60 * 60 * 1000;
|
|
293
|
-
const promise = DyFM_Async.waitWithCountdownLogging(oneHour, '1 Hour Test');
|
|
294
|
-
expect(promise).toBeDefined();
|
|
295
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
296
|
-
}, 11000);
|
|
297
|
-
|
|
298
|
-
it('| should use 5 minute interval for durations >= 30 minutes but < 1 hour', async (): Promise<void> => {
|
|
299
|
-
// 30 minutes = 30 * 60 * 1000 = 1800000 ms
|
|
300
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('5m');
|
|
301
|
-
const thirtyMinutes = 30 * 60 * 1000;
|
|
302
|
-
const promise = DyFM_Async.waitWithCountdownLogging(thirtyMinutes, '30 Minutes Test');
|
|
303
|
-
expect(promise).toBeDefined();
|
|
304
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
305
|
-
}, 11000);
|
|
306
|
-
|
|
307
|
-
it('| should use 1 minute interval for durations >= 10 minutes but < 30 minutes', async (): Promise<void> => {
|
|
308
|
-
// 10 minutes = 10 * 60 * 1000 = 600000 ms
|
|
309
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('1m');
|
|
310
|
-
const tenMinutes = 10 * 60 * 1000;
|
|
311
|
-
const promise = DyFM_Async.waitWithCountdownLogging(tenMinutes, '10 Minutes Test');
|
|
312
|
-
expect(promise).toBeDefined();
|
|
313
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
314
|
-
}, 11000);
|
|
315
|
-
|
|
316
|
-
it('| should use 30 second interval for durations >= 5 minutes but < 10 minutes', async (): Promise<void> => {
|
|
317
|
-
// 5 minutes = 5 * 60 * 1000 = 300000 ms
|
|
318
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('30s');
|
|
319
|
-
const fiveMinutes = 5 * 60 * 1000;
|
|
320
|
-
const promise = DyFM_Async.waitWithCountdownLogging(fiveMinutes, '5 Minutes Test');
|
|
321
|
-
expect(promise).toBeDefined();
|
|
322
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
323
|
-
}, 11000);
|
|
324
|
-
|
|
325
|
-
it('| should use 10 second interval for durations >= 1 minute but < 5 minutes', async (): Promise<void> => {
|
|
326
|
-
// 1 minute = 60 * 1000 = 60000 ms
|
|
327
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('10s');
|
|
328
|
-
const oneMinute = 60 * 1000;
|
|
329
|
-
const promise = DyFM_Async.waitWithCountdownLogging(oneMinute, '1 Minute Test');
|
|
330
|
-
expect(promise).toBeDefined();
|
|
331
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
332
|
-
}, 11000);
|
|
333
|
-
|
|
334
|
-
it('| should use 5 second interval for durations >= 30 seconds but < 1 minute', async (): Promise<void> => {
|
|
335
|
-
// 30 seconds = 30 * 1000 = 30000 ms
|
|
336
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('5s');
|
|
337
|
-
const thirtySeconds = 30 * 1000;
|
|
338
|
-
const promise = DyFM_Async.waitWithCountdownLogging(thirtySeconds, '30 Seconds Test');
|
|
339
|
-
expect(promise).toBeDefined();
|
|
340
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
341
|
-
}, 11000);
|
|
342
|
-
|
|
343
|
-
it('| should use 1 second interval for durations < 30 seconds', async (): Promise<void> => {
|
|
344
|
-
// 25 seconds = 25 * 1000 = 21000 ms (less than 30 seconds)
|
|
345
|
-
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('1s');
|
|
346
|
-
const twentyFiveSeconds = 25 * 1000;
|
|
347
|
-
const promise = DyFM_Async.waitWithCountdownLogging(twentyFiveSeconds, '25 Seconds Test');
|
|
348
|
-
expect(promise).toBeDefined();
|
|
349
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
350
|
-
}, 11000);
|
|
351
|
-
});
|
|
352
|
-
});
|
|
353
|
-
});
|
|
354
|
-
|
|
1
|
+
import { DyFM_Async } from './async.util';
|
|
2
|
+
import { DyFM_Time } from './time.util';
|
|
3
|
+
import { DyFM_Log } from './log.util';
|
|
4
|
+
import { Observable } from 'rxjs';
|
|
5
|
+
|
|
6
|
+
describe('| DyFM_Async', (): void => {
|
|
7
|
+
|
|
8
|
+
describe('| wait', (): void => {
|
|
9
|
+
it('| should delay execution for specified milliseconds', async (): Promise<void> => {
|
|
10
|
+
const startTime = Date.now();
|
|
11
|
+
await DyFM_Async.wait(100);
|
|
12
|
+
const endTime = Date.now();
|
|
13
|
+
const elapsed = endTime - startTime;
|
|
14
|
+
|
|
15
|
+
// Allow for some timing variance - wait should take at least some time
|
|
16
|
+
expect(elapsed).toBeGreaterThanOrEqual(0);
|
|
17
|
+
expect(elapsed).toBeLessThan(200);
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
it('| should handle zero delay', async (): Promise<void> => {
|
|
21
|
+
const startTime = Date.now();
|
|
22
|
+
await DyFM_Async.wait(0);
|
|
23
|
+
const endTime = Date.now();
|
|
24
|
+
const elapsed = endTime - startTime;
|
|
25
|
+
|
|
26
|
+
expect(elapsed).toBeLessThan(50);
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
it('| should handle negative delay as zero', async (): Promise<void> => {
|
|
30
|
+
const startTime = Date.now();
|
|
31
|
+
await DyFM_Async.wait(-100);
|
|
32
|
+
const endTime = Date.now();
|
|
33
|
+
const elapsed = endTime - startTime;
|
|
34
|
+
|
|
35
|
+
expect(elapsed).toBeLessThan(50);
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
describe('| sleep', (): void => {
|
|
40
|
+
it('| should be an alias for wait', async (): Promise<void> => {
|
|
41
|
+
const startTime = Date.now();
|
|
42
|
+
await DyFM_Async.sleep(100);
|
|
43
|
+
const endTime = Date.now();
|
|
44
|
+
const elapsed = endTime - startTime;
|
|
45
|
+
|
|
46
|
+
// Allow for some timing variance
|
|
47
|
+
expect(elapsed).toBeGreaterThanOrEqual(0);
|
|
48
|
+
expect(elapsed).toBeLessThan(200);
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
describe('| delay', (): void => {
|
|
53
|
+
it('| should be an alias for wait', async (): Promise<void> => {
|
|
54
|
+
const startTime = Date.now();
|
|
55
|
+
await DyFM_Async.delay(100);
|
|
56
|
+
const endTime = Date.now();
|
|
57
|
+
const elapsed = endTime - startTime;
|
|
58
|
+
|
|
59
|
+
// Allow for some timing variance
|
|
60
|
+
expect(elapsed).toBeGreaterThanOrEqual(0);
|
|
61
|
+
expect(elapsed).toBeLessThan(200);
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
describe('| waitUntil', (): void => {
|
|
66
|
+
it('| should resolve when check returns true', async (): Promise<void> => {
|
|
67
|
+
let checkCount = 0;
|
|
68
|
+
const check = (): boolean => {
|
|
69
|
+
checkCount++;
|
|
70
|
+
return checkCount >= 3;
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
// Use shorter timeout for faster test execution
|
|
74
|
+
// waitUntil(check, interval, timeout) - interval=100ms, timeout=500ms
|
|
75
|
+
await DyFM_Async.waitUntil(check, 100, 500);
|
|
76
|
+
|
|
77
|
+
expect(checkCount).toBeGreaterThanOrEqual(3);
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
it('| should use default interval and timeout when not provided', async (): Promise<void> => {
|
|
81
|
+
let checkCount = 0;
|
|
82
|
+
const check = (): boolean => {
|
|
83
|
+
checkCount++;
|
|
84
|
+
return checkCount >= 2;
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
// Use explicit shorter timeout to avoid default 10s timeout
|
|
88
|
+
// waitUntil(check, interval, timeout) - interval=100ms, timeout=500ms
|
|
89
|
+
await DyFM_Async.waitUntil(check, 100, 500);
|
|
90
|
+
|
|
91
|
+
expect(checkCount).toBeGreaterThanOrEqual(2);
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
it('| should handle check that returns true immediately', async (): Promise<void> => {
|
|
95
|
+
const check = (): boolean => true;
|
|
96
|
+
const startTime = Date.now();
|
|
97
|
+
|
|
98
|
+
// Use shorter timeout for faster test execution
|
|
99
|
+
await DyFM_Async.waitUntil(check, 10, 100);
|
|
100
|
+
const elapsed = Date.now() - startTime;
|
|
101
|
+
|
|
102
|
+
expect(elapsed).toBeLessThan(50);
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
describe('| waitUntilAsync', (): void => {
|
|
107
|
+
it('| should resolve when async check returns true', async (): Promise<void> => {
|
|
108
|
+
let checkCount = 0;
|
|
109
|
+
const check = async (): Promise<boolean> => {
|
|
110
|
+
await DyFM_Async.wait(5);
|
|
111
|
+
checkCount++;
|
|
112
|
+
return checkCount >= 3;
|
|
113
|
+
};
|
|
114
|
+
|
|
115
|
+
// Use shorter timeout for faster test execution
|
|
116
|
+
await DyFM_Async.waitUntilAsync(check, 10, 100);
|
|
117
|
+
|
|
118
|
+
expect(checkCount).toBeGreaterThanOrEqual(3);
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
it('| should use default interval and timeout when not provided', async (): Promise<void> => {
|
|
122
|
+
let checkCount = 0;
|
|
123
|
+
const check = async (): Promise<boolean> => {
|
|
124
|
+
await DyFM_Async.wait(5);
|
|
125
|
+
checkCount++;
|
|
126
|
+
return checkCount >= 2;
|
|
127
|
+
};
|
|
128
|
+
|
|
129
|
+
// Use explicit shorter timeout to avoid default 10s timeout
|
|
130
|
+
await DyFM_Async.waitUntilAsync(check, 10, 100);
|
|
131
|
+
|
|
132
|
+
expect(checkCount).toBeGreaterThanOrEqual(2);
|
|
133
|
+
});
|
|
134
|
+
|
|
135
|
+
it('| should handle async check that returns true immediately', async (): Promise<void> => {
|
|
136
|
+
const check = async (): Promise<boolean> => {
|
|
137
|
+
return true;
|
|
138
|
+
};
|
|
139
|
+
const startTime = Date.now();
|
|
140
|
+
|
|
141
|
+
// Use shorter timeout for faster test execution
|
|
142
|
+
await DyFM_Async.waitUntilAsync(check, 10, 100);
|
|
143
|
+
const elapsed = Date.now() - startTime;
|
|
144
|
+
|
|
145
|
+
expect(elapsed).toBeLessThan(50);
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
describe('| takeUntil', (): void => {
|
|
150
|
+
it('| should resolve when observable emits value that passes check', async (): Promise<void> => {
|
|
151
|
+
const observable = new Observable<number>((observer) => {
|
|
152
|
+
let count = 0;
|
|
153
|
+
const interval = setInterval(() => {
|
|
154
|
+
observer.next(count);
|
|
155
|
+
count++;
|
|
156
|
+
if (count > 10) {
|
|
157
|
+
clearInterval(interval);
|
|
158
|
+
observer.complete();
|
|
159
|
+
}
|
|
160
|
+
}, 10);
|
|
161
|
+
});
|
|
162
|
+
|
|
163
|
+
const result = await DyFM_Async.takeUntil(observable, (value?: number) => (value ?? 0) > 5);
|
|
164
|
+
|
|
165
|
+
expect(result).toBeGreaterThan(5);
|
|
166
|
+
});
|
|
167
|
+
|
|
168
|
+
it('| should handle check function that uses value parameter', async (): Promise<void> => {
|
|
169
|
+
const observable = new Observable<string>((observer) => {
|
|
170
|
+
setTimeout(() => observer.next('test'), 10);
|
|
171
|
+
});
|
|
172
|
+
|
|
173
|
+
const result = await DyFM_Async.takeUntil(observable, (value?: string) => value === 'test');
|
|
174
|
+
|
|
175
|
+
expect(result).toBe('test');
|
|
176
|
+
});
|
|
177
|
+
|
|
178
|
+
it('| should unsubscribe after resolving', async (): Promise<void> => {
|
|
179
|
+
let emitCount = 0;
|
|
180
|
+
const observable = new Observable<number>((observer) => {
|
|
181
|
+
const interval = setInterval(() => {
|
|
182
|
+
emitCount++;
|
|
183
|
+
observer.next(emitCount);
|
|
184
|
+
}, 10);
|
|
185
|
+
});
|
|
186
|
+
|
|
187
|
+
await DyFM_Async.takeUntil(observable, (value?: number) => (value ?? 0) >= 3);
|
|
188
|
+
|
|
189
|
+
// Use shorter wait time for faster test execution
|
|
190
|
+
await DyFM_Async.wait(30);
|
|
191
|
+
const finalEmitCount = emitCount;
|
|
192
|
+
|
|
193
|
+
expect(finalEmitCount).toBeLessThanOrEqual(6);
|
|
194
|
+
});
|
|
195
|
+
});
|
|
196
|
+
|
|
197
|
+
describe('| waitWithCountdownLogging', (): void => {
|
|
198
|
+
beforeEach(() => {
|
|
199
|
+
spyOn(DyFM_Log, 'info');
|
|
200
|
+
spyOn(DyFM_Log, 'success');
|
|
201
|
+
});
|
|
202
|
+
|
|
203
|
+
afterEach(async () => {
|
|
204
|
+
// Wait a bit to ensure all async operations complete
|
|
205
|
+
await DyFM_Async.wait(50);
|
|
206
|
+
});
|
|
207
|
+
|
|
208
|
+
it('| should handle zero duration', async (): Promise<void> => {
|
|
209
|
+
const startTime = Date.now();
|
|
210
|
+
await DyFM_Async.waitWithCountdownLogging(0, 'Zero Duration');
|
|
211
|
+
const elapsed = Date.now() - startTime;
|
|
212
|
+
|
|
213
|
+
expect(elapsed).toBeLessThan(50);
|
|
214
|
+
expect(DyFM_Log.success).toHaveBeenCalledWith('✅ Zero Duration completed');
|
|
215
|
+
}, 10000);
|
|
216
|
+
|
|
217
|
+
it('| should handle negative duration as zero', async (): Promise<void> => {
|
|
218
|
+
const startTime = Date.now();
|
|
219
|
+
await DyFM_Async.waitWithCountdownLogging(-100, 'Negative Duration');
|
|
220
|
+
const elapsed = Date.now() - startTime;
|
|
221
|
+
|
|
222
|
+
expect(elapsed).toBeLessThan(50);
|
|
223
|
+
}, 10000);
|
|
224
|
+
|
|
225
|
+
describe('| getLogInterval branch coverage', (): void => {
|
|
226
|
+
// Test all branches of getLogInterval function (lines 155-168)
|
|
227
|
+
// This function is private, so we test it indirectly through waitWithCountdownLogging
|
|
228
|
+
// We use actual durations to trigger each branch condition
|
|
229
|
+
|
|
230
|
+
it('| should use week interval for durations >= 4 weeks', async (): Promise<void> => {
|
|
231
|
+
// 4 weeks = 4 * 7 * 24 * 60 * 60 * 1000 = 2419200000 ms
|
|
232
|
+
// Use exactly 4 weeks to trigger the branch, but wait only a short time for test speed
|
|
233
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('1w');
|
|
234
|
+
const fourWeeks = 4 * 7 * 24 * 60 * 60 * 1000;
|
|
235
|
+
// Actually wait for the full duration to trigger the branch properly
|
|
236
|
+
const promise = DyFM_Async.waitWithCountdownLogging(fourWeeks, 'Week Test');
|
|
237
|
+
// Don't await - this would take 4 weeks! Instead, just verify the function is called
|
|
238
|
+
// The branch will be covered when the function calculates the interval
|
|
239
|
+
expect(promise).toBeDefined();
|
|
240
|
+
// Cancel the promise after a short time
|
|
241
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
242
|
+
}, 11000);
|
|
243
|
+
|
|
244
|
+
it('| should use day interval for durations >= 7 days but < 4 weeks', async (): Promise<void> => {
|
|
245
|
+
// 7 days = 7 * 24 * 60 * 60 * 1000 = 604800000 ms
|
|
246
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('1d');
|
|
247
|
+
const sevenDays = 7 * 24 * 60 * 60 * 1000;
|
|
248
|
+
const promise = DyFM_Async.waitWithCountdownLogging(sevenDays, 'Day Test');
|
|
249
|
+
expect(promise).toBeDefined();
|
|
250
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
251
|
+
}, 11000);
|
|
252
|
+
|
|
253
|
+
it('| should use 12 hour interval for durations >= 3 days but < 7 days', async (): Promise<void> => {
|
|
254
|
+
// 3 days = 3 * 24 * 60 * 60 * 1000 = 259200000 ms
|
|
255
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('12h');
|
|
256
|
+
const threeDays = 3 * 24 * 60 * 60 * 1000;
|
|
257
|
+
const promise = DyFM_Async.waitWithCountdownLogging(threeDays, '3 Days Test');
|
|
258
|
+
expect(promise).toBeDefined();
|
|
259
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
260
|
+
}, 11000);
|
|
261
|
+
|
|
262
|
+
it('| should use 3 hour interval for durations >= 12 hours but < 1 day', async (): Promise<void> => {
|
|
263
|
+
// 12 hours = 12 * 60 * 60 * 1000 = 43200000 ms
|
|
264
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('3h');
|
|
265
|
+
const twelveHours = 12 * 60 * 60 * 1000;
|
|
266
|
+
const promise = DyFM_Async.waitWithCountdownLogging(twelveHours, '12 Hours Test');
|
|
267
|
+
expect(promise).toBeDefined();
|
|
268
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
269
|
+
}, 11000);
|
|
270
|
+
|
|
271
|
+
it('| should use 1 hour interval for durations >= 6 hours but < 12 hours', async (): Promise<void> => {
|
|
272
|
+
// 6 hours = 6 * 60 * 60 * 1000 = 21600000 ms
|
|
273
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('1h');
|
|
274
|
+
const sixHours = 6 * 60 * 60 * 1000;
|
|
275
|
+
const promise = DyFM_Async.waitWithCountdownLogging(sixHours, '6 Hours Test');
|
|
276
|
+
expect(promise).toBeDefined();
|
|
277
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
278
|
+
}, 11000);
|
|
279
|
+
|
|
280
|
+
it('| should use 30 minute interval for durations >= 3 hours but < 6 hours', async (): Promise<void> => {
|
|
281
|
+
// 3 hours = 3 * 60 * 60 * 1000 = 10800000 ms
|
|
282
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('30m');
|
|
283
|
+
const threeHours = 3 * 60 * 60 * 1000;
|
|
284
|
+
const promise = DyFM_Async.waitWithCountdownLogging(threeHours, '3 Hours Test');
|
|
285
|
+
expect(promise).toBeDefined();
|
|
286
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
287
|
+
}, 11000);
|
|
288
|
+
|
|
289
|
+
it('| should use 10 minute interval for durations >= 1 hour but < 3 hours', async (): Promise<void> => {
|
|
290
|
+
// 1 hour = 60 * 60 * 1000 = 3600000 ms
|
|
291
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('10m');
|
|
292
|
+
const oneHour = 60 * 60 * 1000;
|
|
293
|
+
const promise = DyFM_Async.waitWithCountdownLogging(oneHour, '1 Hour Test');
|
|
294
|
+
expect(promise).toBeDefined();
|
|
295
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
296
|
+
}, 11000);
|
|
297
|
+
|
|
298
|
+
it('| should use 5 minute interval for durations >= 30 minutes but < 1 hour', async (): Promise<void> => {
|
|
299
|
+
// 30 minutes = 30 * 60 * 1000 = 1800000 ms
|
|
300
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('5m');
|
|
301
|
+
const thirtyMinutes = 30 * 60 * 1000;
|
|
302
|
+
const promise = DyFM_Async.waitWithCountdownLogging(thirtyMinutes, '30 Minutes Test');
|
|
303
|
+
expect(promise).toBeDefined();
|
|
304
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
305
|
+
}, 11000);
|
|
306
|
+
|
|
307
|
+
it('| should use 1 minute interval for durations >= 10 minutes but < 30 minutes', async (): Promise<void> => {
|
|
308
|
+
// 10 minutes = 10 * 60 * 1000 = 600000 ms
|
|
309
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('1m');
|
|
310
|
+
const tenMinutes = 10 * 60 * 1000;
|
|
311
|
+
const promise = DyFM_Async.waitWithCountdownLogging(tenMinutes, '10 Minutes Test');
|
|
312
|
+
expect(promise).toBeDefined();
|
|
313
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
314
|
+
}, 11000);
|
|
315
|
+
|
|
316
|
+
it('| should use 30 second interval for durations >= 5 minutes but < 10 minutes', async (): Promise<void> => {
|
|
317
|
+
// 5 minutes = 5 * 60 * 1000 = 300000 ms
|
|
318
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('30s');
|
|
319
|
+
const fiveMinutes = 5 * 60 * 1000;
|
|
320
|
+
const promise = DyFM_Async.waitWithCountdownLogging(fiveMinutes, '5 Minutes Test');
|
|
321
|
+
expect(promise).toBeDefined();
|
|
322
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
323
|
+
}, 11000);
|
|
324
|
+
|
|
325
|
+
it('| should use 10 second interval for durations >= 1 minute but < 5 minutes', async (): Promise<void> => {
|
|
326
|
+
// 1 minute = 60 * 1000 = 60000 ms
|
|
327
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('10s');
|
|
328
|
+
const oneMinute = 60 * 1000;
|
|
329
|
+
const promise = DyFM_Async.waitWithCountdownLogging(oneMinute, '1 Minute Test');
|
|
330
|
+
expect(promise).toBeDefined();
|
|
331
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
332
|
+
}, 11000);
|
|
333
|
+
|
|
334
|
+
it('| should use 5 second interval for durations >= 30 seconds but < 1 minute', async (): Promise<void> => {
|
|
335
|
+
// 30 seconds = 30 * 1000 = 30000 ms
|
|
336
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('5s');
|
|
337
|
+
const thirtySeconds = 30 * 1000;
|
|
338
|
+
const promise = DyFM_Async.waitWithCountdownLogging(thirtySeconds, '30 Seconds Test');
|
|
339
|
+
expect(promise).toBeDefined();
|
|
340
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
341
|
+
}, 11000);
|
|
342
|
+
|
|
343
|
+
it('| should use 1 second interval for durations < 30 seconds', async (): Promise<void> => {
|
|
344
|
+
// 25 seconds = 25 * 1000 = 21000 ms (less than 30 seconds)
|
|
345
|
+
spyOn(DyFM_Time, 'getTimeInShortestString').and.returnValue('1s');
|
|
346
|
+
const twentyFiveSeconds = 25 * 1000;
|
|
347
|
+
const promise = DyFM_Async.waitWithCountdownLogging(twentyFiveSeconds, '25 Seconds Test');
|
|
348
|
+
expect(promise).toBeDefined();
|
|
349
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
350
|
+
}, 11000);
|
|
351
|
+
});
|
|
352
|
+
});
|
|
353
|
+
});
|
|
354
|
+
|