@futdevpro/fsm-dynamo 1.15.18 → 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/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 -35
- 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 -81
- 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 -34
- 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 -99
- 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 -53
- 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 -252
- 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,521 +1,521 @@
|
|
|
1
|
-
import { DyFM_JsonErrorHelper, JsonErrorLineInfo } from './json-error-helper.util';
|
|
2
|
-
|
|
3
|
-
describe('| DyFM_JsonErrorHelper', (): void => {
|
|
4
|
-
|
|
5
|
-
describe('| extractLineInfoFromJsonError', (): void => {
|
|
6
|
-
it('| should extract line info from error with position', (): void => {
|
|
7
|
-
const errorMessage = 'Expected property name or "}" in JSON at position 10';
|
|
8
|
-
const jsonInput = '{"name": "John", "age": 30}';
|
|
9
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
10
|
-
|
|
11
|
-
expect(result).not.toBeNull();
|
|
12
|
-
expect(result?.lineNumber).toBe(1);
|
|
13
|
-
expect(result?.characterPosition).toBe(10);
|
|
14
|
-
expect(result?.contextLines).toContain(jsonInput);
|
|
15
|
-
});
|
|
16
|
-
|
|
17
|
-
it('| should handle multi-line JSON with position', (): void => {
|
|
18
|
-
const errorMessage = 'Unexpected token } in JSON at position 25';
|
|
19
|
-
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
20
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
21
|
-
|
|
22
|
-
expect(result).not.toBeNull();
|
|
23
|
-
expect(result?.lineNumber).toBeGreaterThan(0);
|
|
24
|
-
expect(result?.contextLines.length).toBeGreaterThan(0);
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
it('| should return null for error without position', (): void => {
|
|
28
|
-
const errorMessage = 'Invalid JSON format';
|
|
29
|
-
const jsonInput = '{"name": "John"}';
|
|
30
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
31
|
-
|
|
32
|
-
expect(result).toBeNull();
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
it('| should handle "Unexpected end of JSON input" error', (): void => {
|
|
36
|
-
const errorMessage = 'Unexpected end of JSON input at position 14';
|
|
37
|
-
const jsonInput = '{"name": "John"';
|
|
38
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
39
|
-
|
|
40
|
-
expect(result).not.toBeNull();
|
|
41
|
-
expect(result?.lineNumber).toBeGreaterThan(0);
|
|
42
|
-
});
|
|
43
|
-
|
|
44
|
-
it('| should use custom contextLines parameter', (): void => {
|
|
45
|
-
const errorMessage = 'Expected property name or "}" in JSON at position 10';
|
|
46
|
-
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
47
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput, 2);
|
|
48
|
-
|
|
49
|
-
expect(result).not.toBeNull();
|
|
50
|
-
if (result) {
|
|
51
|
-
expect(result.contextLines.length).toBeLessThanOrEqual(5);
|
|
52
|
-
}
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
it('| should handle position beyond string length', (): void => {
|
|
56
|
-
const errorMessage = 'Unexpected token in JSON at position 1000';
|
|
57
|
-
const jsonInput = '{"name": "John"}';
|
|
58
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
59
|
-
|
|
60
|
-
expect(result).toBeNull();
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
it('| should handle invalid position values', (): void => {
|
|
64
|
-
const errorMessage = 'Unexpected token in JSON at position -1';
|
|
65
|
-
const jsonInput = '{"name": "John"}';
|
|
66
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
67
|
-
|
|
68
|
-
expect(result).toBeNull();
|
|
69
|
-
});
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
describe('| formatJsonErrorForLogging', (): void => {
|
|
73
|
-
it('| should format error with line info', (): void => {
|
|
74
|
-
const lineInfo: JsonErrorLineInfo = {
|
|
75
|
-
lineNumber: 2,
|
|
76
|
-
contextLines: ['{"name": "John",', '"age": 30}'],
|
|
77
|
-
characterPosition: 5
|
|
78
|
-
};
|
|
79
|
-
const errorMessage = 'Expected property name or "}" in JSON at position 10';
|
|
80
|
-
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
81
|
-
|
|
82
|
-
expect(result.length).toBeGreaterThan(0);
|
|
83
|
-
expect(result[0]).toContain('JSON parsing failed');
|
|
84
|
-
expect(result.some(line => line.includes('Error at line'))).toBe(true);
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
it('| should include context lines in formatted output', (): void => {
|
|
88
|
-
const lineInfo: JsonErrorLineInfo = {
|
|
89
|
-
lineNumber: 1,
|
|
90
|
-
contextLines: ['{"name": "John"}'],
|
|
91
|
-
characterPosition: 5
|
|
92
|
-
};
|
|
93
|
-
const errorMessage = 'Test error';
|
|
94
|
-
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
95
|
-
|
|
96
|
-
expect(result.some(line => line.includes('Context'))).toBe(true);
|
|
97
|
-
expect(result.some(line => line.includes('1:'))).toBe(true);
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
it('| should mark error line with >>>', (): void => {
|
|
101
|
-
const lineInfo: JsonErrorLineInfo = {
|
|
102
|
-
lineNumber: 2,
|
|
103
|
-
contextLines: ['line1', 'line2', 'line3'],
|
|
104
|
-
characterPosition: 5
|
|
105
|
-
};
|
|
106
|
-
const errorMessage = 'Test error';
|
|
107
|
-
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
108
|
-
|
|
109
|
-
expect(result.some(line => line.includes('>>>'))).toBe(true);
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
it('| should handle empty context lines', (): void => {
|
|
113
|
-
const lineInfo: JsonErrorLineInfo = {
|
|
114
|
-
lineNumber: 1,
|
|
115
|
-
contextLines: [],
|
|
116
|
-
characterPosition: 0
|
|
117
|
-
};
|
|
118
|
-
const errorMessage = 'Test error';
|
|
119
|
-
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
120
|
-
|
|
121
|
-
expect(result.length).toBeGreaterThan(0);
|
|
122
|
-
expect(result[0]).toContain('JSON parsing failed');
|
|
123
|
-
});
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
describe('| parseJsonWithEnhancedError', (): void => {
|
|
127
|
-
it('| should parse valid JSON successfully', (): void => {
|
|
128
|
-
const jsonString = '{"name": "John", "age": 30}';
|
|
129
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
130
|
-
|
|
131
|
-
expect(result).toEqual({ name: 'John', age: 30 });
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
it('| should throw enhanced error for invalid JSON', (): void => {
|
|
135
|
-
const jsonString = '{"name": "John", "age": }';
|
|
136
|
-
|
|
137
|
-
try {
|
|
138
|
-
DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
139
|
-
fail('Expected error to be thrown');
|
|
140
|
-
} catch (error) {
|
|
141
|
-
expect(error).toBeInstanceOf(Error);
|
|
142
|
-
const errorMessage = (error as Error).message;
|
|
143
|
-
expect(errorMessage).toContain('JSON parsing failed');
|
|
144
|
-
}
|
|
145
|
-
});
|
|
146
|
-
|
|
147
|
-
it('| should throw error for null input', (): void => {
|
|
148
|
-
try {
|
|
149
|
-
DyFM_JsonErrorHelper.parseJsonWithEnhancedError(null as any);
|
|
150
|
-
fail('Expected error to be thrown');
|
|
151
|
-
} catch (error) {
|
|
152
|
-
expect(error).toBeInstanceOf(Error);
|
|
153
|
-
expect((error as Error).message).toContain('Invalid JSON input');
|
|
154
|
-
}
|
|
155
|
-
});
|
|
156
|
-
|
|
157
|
-
it('| should throw error for undefined input', (): void => {
|
|
158
|
-
try {
|
|
159
|
-
DyFM_JsonErrorHelper.parseJsonWithEnhancedError(undefined as any);
|
|
160
|
-
fail('Expected error to be thrown');
|
|
161
|
-
} catch (error) {
|
|
162
|
-
expect(error).toBeInstanceOf(Error);
|
|
163
|
-
expect((error as Error).message).toContain('Invalid JSON input');
|
|
164
|
-
}
|
|
165
|
-
});
|
|
166
|
-
|
|
167
|
-
it('| should throw error for non-string input', (): void => {
|
|
168
|
-
try {
|
|
169
|
-
DyFM_JsonErrorHelper.parseJsonWithEnhancedError(123 as any);
|
|
170
|
-
fail('Expected error to be thrown');
|
|
171
|
-
} catch (error) {
|
|
172
|
-
expect(error).toBeInstanceOf(Error);
|
|
173
|
-
expect((error as Error).message).toContain('Invalid JSON input');
|
|
174
|
-
}
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
it('| should use custom contextLines parameter', (): void => {
|
|
178
|
-
const jsonString = '{"name": "John", "age": }';
|
|
179
|
-
|
|
180
|
-
try {
|
|
181
|
-
DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString, undefined, 1);
|
|
182
|
-
fail('Expected error to be thrown');
|
|
183
|
-
} catch (error) {
|
|
184
|
-
expect(error).toBeInstanceOf(Error);
|
|
185
|
-
const errorMessage = (error as Error).message;
|
|
186
|
-
expect(errorMessage).toContain('JSON parsing failed');
|
|
187
|
-
}
|
|
188
|
-
});
|
|
189
|
-
|
|
190
|
-
it('| should handle reviver function', (): void => {
|
|
191
|
-
const jsonString = '{"name": "John", "age": 30}';
|
|
192
|
-
const reviver = (key: string, value: any): any => {
|
|
193
|
-
if (key === 'age') {
|
|
194
|
-
return value * 2;
|
|
195
|
-
}
|
|
196
|
-
return value;
|
|
197
|
-
};
|
|
198
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString, reviver);
|
|
199
|
-
|
|
200
|
-
expect(result).toEqual({ name: 'John', age: 60 });
|
|
201
|
-
});
|
|
202
|
-
|
|
203
|
-
it('| should provide enhanced error for multi-line JSON', (): void => {
|
|
204
|
-
const jsonString = '{\n "name": "John",\n "age": \n}';
|
|
205
|
-
|
|
206
|
-
try {
|
|
207
|
-
DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
208
|
-
fail('Expected error to be thrown');
|
|
209
|
-
} catch (error) {
|
|
210
|
-
expect(error).toBeInstanceOf(Error);
|
|
211
|
-
const errorMessage = (error as Error).message;
|
|
212
|
-
expect(errorMessage).toContain('JSON parsing failed');
|
|
213
|
-
}
|
|
214
|
-
});
|
|
215
|
-
|
|
216
|
-
it('| should handle empty string', (): void => {
|
|
217
|
-
try {
|
|
218
|
-
DyFM_JsonErrorHelper.parseJsonWithEnhancedError('');
|
|
219
|
-
fail('Expected error to be thrown');
|
|
220
|
-
} catch (error) {
|
|
221
|
-
expect(error).toBeInstanceOf(Error);
|
|
222
|
-
}
|
|
223
|
-
});
|
|
224
|
-
|
|
225
|
-
it('| should parse valid JSON array', (): void => {
|
|
226
|
-
const jsonString = '[1, 2, 3, "test"]';
|
|
227
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
228
|
-
|
|
229
|
-
expect(result).toEqual([1, 2, 3, 'test']);
|
|
230
|
-
});
|
|
231
|
-
|
|
232
|
-
it('| should parse valid JSON string', (): void => {
|
|
233
|
-
const jsonString = '"simple string"';
|
|
234
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
235
|
-
|
|
236
|
-
expect(result).toBe('simple string');
|
|
237
|
-
});
|
|
238
|
-
|
|
239
|
-
it('| should parse valid JSON number', (): void => {
|
|
240
|
-
const jsonString = '42.5';
|
|
241
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
242
|
-
|
|
243
|
-
expect(result).toBe(42.5);
|
|
244
|
-
});
|
|
245
|
-
|
|
246
|
-
it('| should parse valid JSON boolean', (): void => {
|
|
247
|
-
const jsonString = 'true';
|
|
248
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
249
|
-
|
|
250
|
-
expect(result).toBe(true);
|
|
251
|
-
});
|
|
252
|
-
|
|
253
|
-
it('| should parse valid JSON null', (): void => {
|
|
254
|
-
const jsonString = 'null';
|
|
255
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
256
|
-
|
|
257
|
-
expect(result).toBeNull();
|
|
258
|
-
});
|
|
259
|
-
|
|
260
|
-
it('| should handle position at end of string', (): void => {
|
|
261
|
-
const errorMessage = 'Unexpected end of JSON input at position 14';
|
|
262
|
-
const jsonInput = '{"name": "John"}';
|
|
263
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
264
|
-
|
|
265
|
-
expect(result).not.toBeNull();
|
|
266
|
-
if (result) {
|
|
267
|
-
expect(result.lineNumber).toBeGreaterThan(0);
|
|
268
|
-
}
|
|
269
|
-
});
|
|
270
|
-
|
|
271
|
-
it('| should handle position at start of string', (): void => {
|
|
272
|
-
const errorMessage = 'Unexpected token in JSON at position 0';
|
|
273
|
-
const jsonInput = 'invalid';
|
|
274
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
275
|
-
|
|
276
|
-
expect(result).not.toBeNull();
|
|
277
|
-
if (result) {
|
|
278
|
-
expect(result.characterPosition).toBe(0);
|
|
279
|
-
}
|
|
280
|
-
});
|
|
281
|
-
|
|
282
|
-
it('| should handle very large contextLines parameter', (): void => {
|
|
283
|
-
const errorMessage = 'Expected property name or "}" in JSON at position 10';
|
|
284
|
-
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
285
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput, 100);
|
|
286
|
-
|
|
287
|
-
expect(result).not.toBeNull();
|
|
288
|
-
if (result) {
|
|
289
|
-
// The function may return more context lines than requested due to implementation
|
|
290
|
-
// We just check that it returns a reasonable number
|
|
291
|
-
expect(result.contextLines.length).toBeGreaterThan(0);
|
|
292
|
-
expect(result.contextLines.length).toBeLessThanOrEqual(100);
|
|
293
|
-
}
|
|
294
|
-
});
|
|
295
|
-
|
|
296
|
-
it('| should handle zero contextLines parameter', (): void => {
|
|
297
|
-
const errorMessage = 'Expected property name or "}" in JSON at position 10';
|
|
298
|
-
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
299
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput, 0);
|
|
300
|
-
|
|
301
|
-
expect(result).not.toBeNull();
|
|
302
|
-
if (result) {
|
|
303
|
-
expect(result.contextLines.length).toBeGreaterThan(0);
|
|
304
|
-
}
|
|
305
|
-
});
|
|
306
|
-
|
|
307
|
-
it('| should return null when position is greater than jsonInput length', (): void => {
|
|
308
|
-
// Test case for line 82-83: position > jsonInput.length returns null
|
|
309
|
-
const errorMessage = 'Unexpected end of JSON input';
|
|
310
|
-
const jsonInput = '{"name": "John"}';
|
|
311
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput, 5);
|
|
312
|
-
expect(result).toBeNull();
|
|
313
|
-
});
|
|
314
|
-
|
|
315
|
-
it('| should handle formatJsonForBetterErrors with non-string input', (): void => {
|
|
316
|
-
// Test case for line 293-294: formatJsonForBetterErrors handles non-string input
|
|
317
|
-
const result = (DyFM_JsonErrorHelper as any).formatJsonForBetterErrors(null);
|
|
318
|
-
expect(result).toBe('');
|
|
319
|
-
});
|
|
320
|
-
|
|
321
|
-
it('| should handle formatJsonForBetterErrors with undefined input', (): void => {
|
|
322
|
-
// Test case for line 293-294: formatJsonForBetterErrors handles undefined input
|
|
323
|
-
const result = (DyFM_JsonErrorHelper as any).formatJsonForBetterErrors(undefined);
|
|
324
|
-
expect(result).toBe('');
|
|
325
|
-
});
|
|
326
|
-
|
|
327
|
-
it('| should handle formatJsonForBetterErrors with empty string', (): void => {
|
|
328
|
-
// Test case for formatJsonForBetterErrors with empty string
|
|
329
|
-
const result = (DyFM_JsonErrorHelper as any).formatJsonForBetterErrors('');
|
|
330
|
-
expect(result).toBeDefined();
|
|
331
|
-
});
|
|
332
|
-
|
|
333
|
-
it('| should handle formatJsonForBetterErrors with complex JSON', (): void => {
|
|
334
|
-
// Test case for formatJsonForBetterErrors with complex JSON formatting
|
|
335
|
-
const complexJson = '{"level1":{"level2":{"level3":"value","array":[1,2,3]},"other":"data"},"simple":"value"}';
|
|
336
|
-
const result = (DyFM_JsonErrorHelper as any).formatJsonForBetterErrors(complexJson);
|
|
337
|
-
expect(result).toBeDefined();
|
|
338
|
-
expect(result).toContain('\n');
|
|
339
|
-
});
|
|
340
|
-
|
|
341
|
-
it('| should handle extractLineInfoFromJsonError with token matching without position', (): void => {
|
|
342
|
-
// Test case for lines 60-62: token matching without position
|
|
343
|
-
const errorMessage = "Unexpected token '}'";
|
|
344
|
-
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
345
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
346
|
-
|
|
347
|
-
// Should try to find token position
|
|
348
|
-
expect(result).toBeDefined();
|
|
349
|
-
});
|
|
350
|
-
|
|
351
|
-
it('| should handle extractLineInfoFromJsonError with different error message formats', (): void => {
|
|
352
|
-
// Test various error message formats
|
|
353
|
-
const formats = [
|
|
354
|
-
'Unexpected token } in JSON at position 25',
|
|
355
|
-
'Expected property name or "}" in JSON at position 10',
|
|
356
|
-
'Unexpected end of JSON input at position 14',
|
|
357
|
-
'Unexpected token }',
|
|
358
|
-
'Expected double-quoted property name in JSON at position 5',
|
|
359
|
-
];
|
|
360
|
-
|
|
361
|
-
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
362
|
-
|
|
363
|
-
formats.forEach(errorMessage => {
|
|
364
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
365
|
-
// Some may return null, some may return line info
|
|
366
|
-
expect(result === null || (result && result.lineNumber > 0)).toBeTrue();
|
|
367
|
-
});
|
|
368
|
-
});
|
|
369
|
-
|
|
370
|
-
it('| should handle extractLineInfoFromJsonError with token match but no newlines', (): void => {
|
|
371
|
-
// Test case for line 62: token matching when jsonInput doesn't include newlines
|
|
372
|
-
const errorMessage = "Unexpected token '}'";
|
|
373
|
-
const jsonInput = '{"name": "John", "age": 30}'; // No newlines
|
|
374
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
375
|
-
|
|
376
|
-
// Should return null when no newlines and no position
|
|
377
|
-
expect(result).toBeNull();
|
|
378
|
-
});
|
|
379
|
-
|
|
380
|
-
it('| should handle extractLineInfoFromJsonError with token found at position', (): void => {
|
|
381
|
-
// Test case for lines 65-68: token found at position
|
|
382
|
-
const errorMessage = "Unexpected token '}'";
|
|
383
|
-
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
384
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
385
|
-
|
|
386
|
-
// May or may not find the token, but should handle gracefully
|
|
387
|
-
expect(result === null || (result && result.lineNumber > 0)).toBeTrue();
|
|
388
|
-
});
|
|
389
|
-
|
|
390
|
-
it('| should handle extractLineInfoFromJsonError edge cases in position extraction', (): void => {
|
|
391
|
-
// Test edge cases: position at start, middle, end
|
|
392
|
-
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
393
|
-
|
|
394
|
-
// Position at start
|
|
395
|
-
let result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError('Error at position 0', jsonInput);
|
|
396
|
-
expect(result === null || (result && result.characterPosition >= 0)).toBeTrue();
|
|
397
|
-
|
|
398
|
-
// Position in middle
|
|
399
|
-
result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError('Error at position 10', jsonInput);
|
|
400
|
-
expect(result === null || (result && result.lineNumber > 0)).toBeTrue();
|
|
401
|
-
|
|
402
|
-
// Position at end (equal to length)
|
|
403
|
-
const endPosition = jsonInput.length;
|
|
404
|
-
result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(`Error at position ${endPosition}`, jsonInput);
|
|
405
|
-
expect(result === null || (result && result.lineNumber > 0)).toBeTrue();
|
|
406
|
-
});
|
|
407
|
-
|
|
408
|
-
it('| should handle error messages with different formats', (): void => {
|
|
409
|
-
const errorMessage = 'Unexpected token } in JSON at position 25';
|
|
410
|
-
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
411
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
412
|
-
|
|
413
|
-
expect(result).not.toBeNull();
|
|
414
|
-
});
|
|
415
|
-
|
|
416
|
-
it('| should handle empty error message', (): void => {
|
|
417
|
-
const errorMessage = '';
|
|
418
|
-
const jsonInput = '{"name": "John"}';
|
|
419
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
420
|
-
|
|
421
|
-
expect(result).toBeNull();
|
|
422
|
-
});
|
|
423
|
-
|
|
424
|
-
it('| should handle empty jsonInput', (): void => {
|
|
425
|
-
const errorMessage = 'Unexpected token in JSON at position 0';
|
|
426
|
-
const jsonInput = '';
|
|
427
|
-
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
428
|
-
|
|
429
|
-
expect(result).not.toBeNull();
|
|
430
|
-
if (result) {
|
|
431
|
-
expect(result.contextLines).toContain('(invalid or empty input)');
|
|
432
|
-
}
|
|
433
|
-
});
|
|
434
|
-
|
|
435
|
-
it('| should handle formatJsonErrorForLogging with single line context', (): void => {
|
|
436
|
-
const lineInfo: JsonErrorLineInfo = {
|
|
437
|
-
lineNumber: 1,
|
|
438
|
-
contextLines: ['{"name": "John"}'],
|
|
439
|
-
characterPosition: 5
|
|
440
|
-
};
|
|
441
|
-
const errorMessage = 'Test error';
|
|
442
|
-
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
443
|
-
|
|
444
|
-
expect(result.some(line => line.includes('>>>'))).toBe(true);
|
|
445
|
-
expect(result.some(line => line.includes('1:'))).toBe(true);
|
|
446
|
-
});
|
|
447
|
-
|
|
448
|
-
it('| should handle formatJsonErrorForLogging with multiple context lines', (): void => {
|
|
449
|
-
const lineInfo: JsonErrorLineInfo = {
|
|
450
|
-
lineNumber: 3,
|
|
451
|
-
contextLines: ['line1', 'line2', 'line3', 'line4', 'line5'],
|
|
452
|
-
characterPosition: 5
|
|
453
|
-
};
|
|
454
|
-
const errorMessage = 'Test error';
|
|
455
|
-
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
456
|
-
|
|
457
|
-
expect(result.some(line => line.includes('>>>'))).toBe(true);
|
|
458
|
-
expect(result.some(line => line.includes('3:'))).toBe(true);
|
|
459
|
-
});
|
|
460
|
-
|
|
461
|
-
it('| should handle formatJsonErrorForLogging with empty lines in context', (): void => {
|
|
462
|
-
const lineInfo: JsonErrorLineInfo = {
|
|
463
|
-
lineNumber: 2,
|
|
464
|
-
contextLines: ['line1', '', 'line3'],
|
|
465
|
-
characterPosition: 5
|
|
466
|
-
};
|
|
467
|
-
const errorMessage = 'Test error';
|
|
468
|
-
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
469
|
-
|
|
470
|
-
expect(result.some(line => line.includes('(empty line)'))).toBe(true);
|
|
471
|
-
});
|
|
472
|
-
|
|
473
|
-
it('| should handle parseJsonWithEnhancedError with complex nested JSON', (): void => {
|
|
474
|
-
const jsonString = '{"level1": {"level2": {"level3": "value"}}}';
|
|
475
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
476
|
-
|
|
477
|
-
expect(result.level1.level2.level3).toBe('value');
|
|
478
|
-
});
|
|
479
|
-
|
|
480
|
-
it('| should handle parseJsonWithEnhancedError with array containing objects', (): void => {
|
|
481
|
-
const jsonString = '[{"id": 1}, {"id": 2}]';
|
|
482
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
483
|
-
|
|
484
|
-
expect(result).toEqual([{ id: 1 }, { id: 2 }]);
|
|
485
|
-
});
|
|
486
|
-
|
|
487
|
-
it('| should handle parseJsonWithEnhancedError with special characters', (): void => {
|
|
488
|
-
const jsonString = '{"message": "Hello\\nWorld\\tTab"}';
|
|
489
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
490
|
-
|
|
491
|
-
expect(result.message).toBe('Hello\nWorld\tTab');
|
|
492
|
-
});
|
|
493
|
-
|
|
494
|
-
it('| should handle parseJsonWithEnhancedError with unicode characters', (): void => {
|
|
495
|
-
const jsonString = '{"unicode": "🚀 Test ñáéíóú"}';
|
|
496
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
497
|
-
|
|
498
|
-
expect(result.unicode).toBe('🚀 Test ñáéíóú');
|
|
499
|
-
});
|
|
500
|
-
|
|
501
|
-
it('| should handle parseJsonWithEnhancedError with scientific notation', (): void => {
|
|
502
|
-
const jsonString = '{"small": 1e-10, "large": 1e10}';
|
|
503
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
504
|
-
|
|
505
|
-
expect(result.small).toBe(1e-10);
|
|
506
|
-
expect(result.large).toBe(1e10);
|
|
507
|
-
});
|
|
508
|
-
|
|
509
|
-
it('| should handle parseJsonWithEnhancedError with reviver that returns undefined', (): void => {
|
|
510
|
-
const jsonString = '{"keep": "value", "remove": "value"}';
|
|
511
|
-
const reviver = (key: string, value: any): any => {
|
|
512
|
-
return key === 'remove' ? undefined : value;
|
|
513
|
-
};
|
|
514
|
-
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString, reviver);
|
|
515
|
-
|
|
516
|
-
expect(result.keep).toBe('value');
|
|
517
|
-
expect(result.remove).toBeUndefined();
|
|
518
|
-
});
|
|
519
|
-
});
|
|
520
|
-
});
|
|
521
|
-
|
|
1
|
+
import { DyFM_JsonErrorHelper, JsonErrorLineInfo } from './json-error-helper.util';
|
|
2
|
+
|
|
3
|
+
describe('| DyFM_JsonErrorHelper', (): void => {
|
|
4
|
+
|
|
5
|
+
describe('| extractLineInfoFromJsonError', (): void => {
|
|
6
|
+
it('| should extract line info from error with position', (): void => {
|
|
7
|
+
const errorMessage = 'Expected property name or "}" in JSON at position 10';
|
|
8
|
+
const jsonInput = '{"name": "John", "age": 30}';
|
|
9
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
10
|
+
|
|
11
|
+
expect(result).not.toBeNull();
|
|
12
|
+
expect(result?.lineNumber).toBe(1);
|
|
13
|
+
expect(result?.characterPosition).toBe(10);
|
|
14
|
+
expect(result?.contextLines).toContain(jsonInput);
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
it('| should handle multi-line JSON with position', (): void => {
|
|
18
|
+
const errorMessage = 'Unexpected token } in JSON at position 25';
|
|
19
|
+
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
20
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
21
|
+
|
|
22
|
+
expect(result).not.toBeNull();
|
|
23
|
+
expect(result?.lineNumber).toBeGreaterThan(0);
|
|
24
|
+
expect(result?.contextLines.length).toBeGreaterThan(0);
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
it('| should return null for error without position', (): void => {
|
|
28
|
+
const errorMessage = 'Invalid JSON format';
|
|
29
|
+
const jsonInput = '{"name": "John"}';
|
|
30
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
31
|
+
|
|
32
|
+
expect(result).toBeNull();
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
it('| should handle "Unexpected end of JSON input" error', (): void => {
|
|
36
|
+
const errorMessage = 'Unexpected end of JSON input at position 14';
|
|
37
|
+
const jsonInput = '{"name": "John"';
|
|
38
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
39
|
+
|
|
40
|
+
expect(result).not.toBeNull();
|
|
41
|
+
expect(result?.lineNumber).toBeGreaterThan(0);
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
it('| should use custom contextLines parameter', (): void => {
|
|
45
|
+
const errorMessage = 'Expected property name or "}" in JSON at position 10';
|
|
46
|
+
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
47
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput, 2);
|
|
48
|
+
|
|
49
|
+
expect(result).not.toBeNull();
|
|
50
|
+
if (result) {
|
|
51
|
+
expect(result.contextLines.length).toBeLessThanOrEqual(5);
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
it('| should handle position beyond string length', (): void => {
|
|
56
|
+
const errorMessage = 'Unexpected token in JSON at position 1000';
|
|
57
|
+
const jsonInput = '{"name": "John"}';
|
|
58
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
59
|
+
|
|
60
|
+
expect(result).toBeNull();
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
it('| should handle invalid position values', (): void => {
|
|
64
|
+
const errorMessage = 'Unexpected token in JSON at position -1';
|
|
65
|
+
const jsonInput = '{"name": "John"}';
|
|
66
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
67
|
+
|
|
68
|
+
expect(result).toBeNull();
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
describe('| formatJsonErrorForLogging', (): void => {
|
|
73
|
+
it('| should format error with line info', (): void => {
|
|
74
|
+
const lineInfo: JsonErrorLineInfo = {
|
|
75
|
+
lineNumber: 2,
|
|
76
|
+
contextLines: ['{"name": "John",', '"age": 30}'],
|
|
77
|
+
characterPosition: 5
|
|
78
|
+
};
|
|
79
|
+
const errorMessage = 'Expected property name or "}" in JSON at position 10';
|
|
80
|
+
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
81
|
+
|
|
82
|
+
expect(result.length).toBeGreaterThan(0);
|
|
83
|
+
expect(result[0]).toContain('JSON parsing failed');
|
|
84
|
+
expect(result.some(line => line.includes('Error at line'))).toBe(true);
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
it('| should include context lines in formatted output', (): void => {
|
|
88
|
+
const lineInfo: JsonErrorLineInfo = {
|
|
89
|
+
lineNumber: 1,
|
|
90
|
+
contextLines: ['{"name": "John"}'],
|
|
91
|
+
characterPosition: 5
|
|
92
|
+
};
|
|
93
|
+
const errorMessage = 'Test error';
|
|
94
|
+
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
95
|
+
|
|
96
|
+
expect(result.some(line => line.includes('Context'))).toBe(true);
|
|
97
|
+
expect(result.some(line => line.includes('1:'))).toBe(true);
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
it('| should mark error line with >>>', (): void => {
|
|
101
|
+
const lineInfo: JsonErrorLineInfo = {
|
|
102
|
+
lineNumber: 2,
|
|
103
|
+
contextLines: ['line1', 'line2', 'line3'],
|
|
104
|
+
characterPosition: 5
|
|
105
|
+
};
|
|
106
|
+
const errorMessage = 'Test error';
|
|
107
|
+
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
108
|
+
|
|
109
|
+
expect(result.some(line => line.includes('>>>'))).toBe(true);
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
it('| should handle empty context lines', (): void => {
|
|
113
|
+
const lineInfo: JsonErrorLineInfo = {
|
|
114
|
+
lineNumber: 1,
|
|
115
|
+
contextLines: [],
|
|
116
|
+
characterPosition: 0
|
|
117
|
+
};
|
|
118
|
+
const errorMessage = 'Test error';
|
|
119
|
+
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
120
|
+
|
|
121
|
+
expect(result.length).toBeGreaterThan(0);
|
|
122
|
+
expect(result[0]).toContain('JSON parsing failed');
|
|
123
|
+
});
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
describe('| parseJsonWithEnhancedError', (): void => {
|
|
127
|
+
it('| should parse valid JSON successfully', (): void => {
|
|
128
|
+
const jsonString = '{"name": "John", "age": 30}';
|
|
129
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
130
|
+
|
|
131
|
+
expect(result).toEqual({ name: 'John', age: 30 });
|
|
132
|
+
});
|
|
133
|
+
|
|
134
|
+
it('| should throw enhanced error for invalid JSON', (): void => {
|
|
135
|
+
const jsonString = '{"name": "John", "age": }';
|
|
136
|
+
|
|
137
|
+
try {
|
|
138
|
+
DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
139
|
+
fail('Expected error to be thrown');
|
|
140
|
+
} catch (error) {
|
|
141
|
+
expect(error).toBeInstanceOf(Error);
|
|
142
|
+
const errorMessage = (error as Error).message;
|
|
143
|
+
expect(errorMessage).toContain('JSON parsing failed');
|
|
144
|
+
}
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
it('| should throw error for null input', (): void => {
|
|
148
|
+
try {
|
|
149
|
+
DyFM_JsonErrorHelper.parseJsonWithEnhancedError(null as any);
|
|
150
|
+
fail('Expected error to be thrown');
|
|
151
|
+
} catch (error) {
|
|
152
|
+
expect(error).toBeInstanceOf(Error);
|
|
153
|
+
expect((error as Error).message).toContain('Invalid JSON input');
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
|
|
157
|
+
it('| should throw error for undefined input', (): void => {
|
|
158
|
+
try {
|
|
159
|
+
DyFM_JsonErrorHelper.parseJsonWithEnhancedError(undefined as any);
|
|
160
|
+
fail('Expected error to be thrown');
|
|
161
|
+
} catch (error) {
|
|
162
|
+
expect(error).toBeInstanceOf(Error);
|
|
163
|
+
expect((error as Error).message).toContain('Invalid JSON input');
|
|
164
|
+
}
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
it('| should throw error for non-string input', (): void => {
|
|
168
|
+
try {
|
|
169
|
+
DyFM_JsonErrorHelper.parseJsonWithEnhancedError(123 as any);
|
|
170
|
+
fail('Expected error to be thrown');
|
|
171
|
+
} catch (error) {
|
|
172
|
+
expect(error).toBeInstanceOf(Error);
|
|
173
|
+
expect((error as Error).message).toContain('Invalid JSON input');
|
|
174
|
+
}
|
|
175
|
+
});
|
|
176
|
+
|
|
177
|
+
it('| should use custom contextLines parameter', (): void => {
|
|
178
|
+
const jsonString = '{"name": "John", "age": }';
|
|
179
|
+
|
|
180
|
+
try {
|
|
181
|
+
DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString, undefined, 1);
|
|
182
|
+
fail('Expected error to be thrown');
|
|
183
|
+
} catch (error) {
|
|
184
|
+
expect(error).toBeInstanceOf(Error);
|
|
185
|
+
const errorMessage = (error as Error).message;
|
|
186
|
+
expect(errorMessage).toContain('JSON parsing failed');
|
|
187
|
+
}
|
|
188
|
+
});
|
|
189
|
+
|
|
190
|
+
it('| should handle reviver function', (): void => {
|
|
191
|
+
const jsonString = '{"name": "John", "age": 30}';
|
|
192
|
+
const reviver = (key: string, value: any): any => {
|
|
193
|
+
if (key === 'age') {
|
|
194
|
+
return value * 2;
|
|
195
|
+
}
|
|
196
|
+
return value;
|
|
197
|
+
};
|
|
198
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString, reviver);
|
|
199
|
+
|
|
200
|
+
expect(result).toEqual({ name: 'John', age: 60 });
|
|
201
|
+
});
|
|
202
|
+
|
|
203
|
+
it('| should provide enhanced error for multi-line JSON', (): void => {
|
|
204
|
+
const jsonString = '{\n "name": "John",\n "age": \n}';
|
|
205
|
+
|
|
206
|
+
try {
|
|
207
|
+
DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
208
|
+
fail('Expected error to be thrown');
|
|
209
|
+
} catch (error) {
|
|
210
|
+
expect(error).toBeInstanceOf(Error);
|
|
211
|
+
const errorMessage = (error as Error).message;
|
|
212
|
+
expect(errorMessage).toContain('JSON parsing failed');
|
|
213
|
+
}
|
|
214
|
+
});
|
|
215
|
+
|
|
216
|
+
it('| should handle empty string', (): void => {
|
|
217
|
+
try {
|
|
218
|
+
DyFM_JsonErrorHelper.parseJsonWithEnhancedError('');
|
|
219
|
+
fail('Expected error to be thrown');
|
|
220
|
+
} catch (error) {
|
|
221
|
+
expect(error).toBeInstanceOf(Error);
|
|
222
|
+
}
|
|
223
|
+
});
|
|
224
|
+
|
|
225
|
+
it('| should parse valid JSON array', (): void => {
|
|
226
|
+
const jsonString = '[1, 2, 3, "test"]';
|
|
227
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
228
|
+
|
|
229
|
+
expect(result).toEqual([1, 2, 3, 'test']);
|
|
230
|
+
});
|
|
231
|
+
|
|
232
|
+
it('| should parse valid JSON string', (): void => {
|
|
233
|
+
const jsonString = '"simple string"';
|
|
234
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
235
|
+
|
|
236
|
+
expect(result).toBe('simple string');
|
|
237
|
+
});
|
|
238
|
+
|
|
239
|
+
it('| should parse valid JSON number', (): void => {
|
|
240
|
+
const jsonString = '42.5';
|
|
241
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
242
|
+
|
|
243
|
+
expect(result).toBe(42.5);
|
|
244
|
+
});
|
|
245
|
+
|
|
246
|
+
it('| should parse valid JSON boolean', (): void => {
|
|
247
|
+
const jsonString = 'true';
|
|
248
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
249
|
+
|
|
250
|
+
expect(result).toBe(true);
|
|
251
|
+
});
|
|
252
|
+
|
|
253
|
+
it('| should parse valid JSON null', (): void => {
|
|
254
|
+
const jsonString = 'null';
|
|
255
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
256
|
+
|
|
257
|
+
expect(result).toBeNull();
|
|
258
|
+
});
|
|
259
|
+
|
|
260
|
+
it('| should handle position at end of string', (): void => {
|
|
261
|
+
const errorMessage = 'Unexpected end of JSON input at position 14';
|
|
262
|
+
const jsonInput = '{"name": "John"}';
|
|
263
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
264
|
+
|
|
265
|
+
expect(result).not.toBeNull();
|
|
266
|
+
if (result) {
|
|
267
|
+
expect(result.lineNumber).toBeGreaterThan(0);
|
|
268
|
+
}
|
|
269
|
+
});
|
|
270
|
+
|
|
271
|
+
it('| should handle position at start of string', (): void => {
|
|
272
|
+
const errorMessage = 'Unexpected token in JSON at position 0';
|
|
273
|
+
const jsonInput = 'invalid';
|
|
274
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
275
|
+
|
|
276
|
+
expect(result).not.toBeNull();
|
|
277
|
+
if (result) {
|
|
278
|
+
expect(result.characterPosition).toBe(0);
|
|
279
|
+
}
|
|
280
|
+
});
|
|
281
|
+
|
|
282
|
+
it('| should handle very large contextLines parameter', (): void => {
|
|
283
|
+
const errorMessage = 'Expected property name or "}" in JSON at position 10';
|
|
284
|
+
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
285
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput, 100);
|
|
286
|
+
|
|
287
|
+
expect(result).not.toBeNull();
|
|
288
|
+
if (result) {
|
|
289
|
+
// The function may return more context lines than requested due to implementation
|
|
290
|
+
// We just check that it returns a reasonable number
|
|
291
|
+
expect(result.contextLines.length).toBeGreaterThan(0);
|
|
292
|
+
expect(result.contextLines.length).toBeLessThanOrEqual(100);
|
|
293
|
+
}
|
|
294
|
+
});
|
|
295
|
+
|
|
296
|
+
it('| should handle zero contextLines parameter', (): void => {
|
|
297
|
+
const errorMessage = 'Expected property name or "}" in JSON at position 10';
|
|
298
|
+
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
299
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput, 0);
|
|
300
|
+
|
|
301
|
+
expect(result).not.toBeNull();
|
|
302
|
+
if (result) {
|
|
303
|
+
expect(result.contextLines.length).toBeGreaterThan(0);
|
|
304
|
+
}
|
|
305
|
+
});
|
|
306
|
+
|
|
307
|
+
it('| should return null when position is greater than jsonInput length', (): void => {
|
|
308
|
+
// Test case for line 82-83: position > jsonInput.length returns null
|
|
309
|
+
const errorMessage = 'Unexpected end of JSON input';
|
|
310
|
+
const jsonInput = '{"name": "John"}';
|
|
311
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput, 5);
|
|
312
|
+
expect(result).toBeNull();
|
|
313
|
+
});
|
|
314
|
+
|
|
315
|
+
it('| should handle formatJsonForBetterErrors with non-string input', (): void => {
|
|
316
|
+
// Test case for line 293-294: formatJsonForBetterErrors handles non-string input
|
|
317
|
+
const result = (DyFM_JsonErrorHelper as any).formatJsonForBetterErrors(null);
|
|
318
|
+
expect(result).toBe('');
|
|
319
|
+
});
|
|
320
|
+
|
|
321
|
+
it('| should handle formatJsonForBetterErrors with undefined input', (): void => {
|
|
322
|
+
// Test case for line 293-294: formatJsonForBetterErrors handles undefined input
|
|
323
|
+
const result = (DyFM_JsonErrorHelper as any).formatJsonForBetterErrors(undefined);
|
|
324
|
+
expect(result).toBe('');
|
|
325
|
+
});
|
|
326
|
+
|
|
327
|
+
it('| should handle formatJsonForBetterErrors with empty string', (): void => {
|
|
328
|
+
// Test case for formatJsonForBetterErrors with empty string
|
|
329
|
+
const result = (DyFM_JsonErrorHelper as any).formatJsonForBetterErrors('');
|
|
330
|
+
expect(result).toBeDefined();
|
|
331
|
+
});
|
|
332
|
+
|
|
333
|
+
it('| should handle formatJsonForBetterErrors with complex JSON', (): void => {
|
|
334
|
+
// Test case for formatJsonForBetterErrors with complex JSON formatting
|
|
335
|
+
const complexJson = '{"level1":{"level2":{"level3":"value","array":[1,2,3]},"other":"data"},"simple":"value"}';
|
|
336
|
+
const result = (DyFM_JsonErrorHelper as any).formatJsonForBetterErrors(complexJson);
|
|
337
|
+
expect(result).toBeDefined();
|
|
338
|
+
expect(result).toContain('\n');
|
|
339
|
+
});
|
|
340
|
+
|
|
341
|
+
it('| should handle extractLineInfoFromJsonError with token matching without position', (): void => {
|
|
342
|
+
// Test case for lines 60-62: token matching without position
|
|
343
|
+
const errorMessage = "Unexpected token '}'";
|
|
344
|
+
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
345
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
346
|
+
|
|
347
|
+
// Should try to find token position
|
|
348
|
+
expect(result).toBeDefined();
|
|
349
|
+
});
|
|
350
|
+
|
|
351
|
+
it('| should handle extractLineInfoFromJsonError with different error message formats', (): void => {
|
|
352
|
+
// Test various error message formats
|
|
353
|
+
const formats = [
|
|
354
|
+
'Unexpected token } in JSON at position 25',
|
|
355
|
+
'Expected property name or "}" in JSON at position 10',
|
|
356
|
+
'Unexpected end of JSON input at position 14',
|
|
357
|
+
'Unexpected token }',
|
|
358
|
+
'Expected double-quoted property name in JSON at position 5',
|
|
359
|
+
];
|
|
360
|
+
|
|
361
|
+
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
362
|
+
|
|
363
|
+
formats.forEach(errorMessage => {
|
|
364
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
365
|
+
// Some may return null, some may return line info
|
|
366
|
+
expect(result === null || (result && result.lineNumber > 0)).toBeTrue();
|
|
367
|
+
});
|
|
368
|
+
});
|
|
369
|
+
|
|
370
|
+
it('| should handle extractLineInfoFromJsonError with token match but no newlines', (): void => {
|
|
371
|
+
// Test case for line 62: token matching when jsonInput doesn't include newlines
|
|
372
|
+
const errorMessage = "Unexpected token '}'";
|
|
373
|
+
const jsonInput = '{"name": "John", "age": 30}'; // No newlines
|
|
374
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
375
|
+
|
|
376
|
+
// Should return null when no newlines and no position
|
|
377
|
+
expect(result).toBeNull();
|
|
378
|
+
});
|
|
379
|
+
|
|
380
|
+
it('| should handle extractLineInfoFromJsonError with token found at position', (): void => {
|
|
381
|
+
// Test case for lines 65-68: token found at position
|
|
382
|
+
const errorMessage = "Unexpected token '}'";
|
|
383
|
+
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
384
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
385
|
+
|
|
386
|
+
// May or may not find the token, but should handle gracefully
|
|
387
|
+
expect(result === null || (result && result.lineNumber > 0)).toBeTrue();
|
|
388
|
+
});
|
|
389
|
+
|
|
390
|
+
it('| should handle extractLineInfoFromJsonError edge cases in position extraction', (): void => {
|
|
391
|
+
// Test edge cases: position at start, middle, end
|
|
392
|
+
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
393
|
+
|
|
394
|
+
// Position at start
|
|
395
|
+
let result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError('Error at position 0', jsonInput);
|
|
396
|
+
expect(result === null || (result && result.characterPosition >= 0)).toBeTrue();
|
|
397
|
+
|
|
398
|
+
// Position in middle
|
|
399
|
+
result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError('Error at position 10', jsonInput);
|
|
400
|
+
expect(result === null || (result && result.lineNumber > 0)).toBeTrue();
|
|
401
|
+
|
|
402
|
+
// Position at end (equal to length)
|
|
403
|
+
const endPosition = jsonInput.length;
|
|
404
|
+
result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(`Error at position ${endPosition}`, jsonInput);
|
|
405
|
+
expect(result === null || (result && result.lineNumber > 0)).toBeTrue();
|
|
406
|
+
});
|
|
407
|
+
|
|
408
|
+
it('| should handle error messages with different formats', (): void => {
|
|
409
|
+
const errorMessage = 'Unexpected token } in JSON at position 25';
|
|
410
|
+
const jsonInput = '{\n "name": "John",\n "age": 30\n}';
|
|
411
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
412
|
+
|
|
413
|
+
expect(result).not.toBeNull();
|
|
414
|
+
});
|
|
415
|
+
|
|
416
|
+
it('| should handle empty error message', (): void => {
|
|
417
|
+
const errorMessage = '';
|
|
418
|
+
const jsonInput = '{"name": "John"}';
|
|
419
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
420
|
+
|
|
421
|
+
expect(result).toBeNull();
|
|
422
|
+
});
|
|
423
|
+
|
|
424
|
+
it('| should handle empty jsonInput', (): void => {
|
|
425
|
+
const errorMessage = 'Unexpected token in JSON at position 0';
|
|
426
|
+
const jsonInput = '';
|
|
427
|
+
const result = DyFM_JsonErrorHelper.extractLineInfoFromJsonError(errorMessage, jsonInput);
|
|
428
|
+
|
|
429
|
+
expect(result).not.toBeNull();
|
|
430
|
+
if (result) {
|
|
431
|
+
expect(result.contextLines).toContain('(invalid or empty input)');
|
|
432
|
+
}
|
|
433
|
+
});
|
|
434
|
+
|
|
435
|
+
it('| should handle formatJsonErrorForLogging with single line context', (): void => {
|
|
436
|
+
const lineInfo: JsonErrorLineInfo = {
|
|
437
|
+
lineNumber: 1,
|
|
438
|
+
contextLines: ['{"name": "John"}'],
|
|
439
|
+
characterPosition: 5
|
|
440
|
+
};
|
|
441
|
+
const errorMessage = 'Test error';
|
|
442
|
+
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
443
|
+
|
|
444
|
+
expect(result.some(line => line.includes('>>>'))).toBe(true);
|
|
445
|
+
expect(result.some(line => line.includes('1:'))).toBe(true);
|
|
446
|
+
});
|
|
447
|
+
|
|
448
|
+
it('| should handle formatJsonErrorForLogging with multiple context lines', (): void => {
|
|
449
|
+
const lineInfo: JsonErrorLineInfo = {
|
|
450
|
+
lineNumber: 3,
|
|
451
|
+
contextLines: ['line1', 'line2', 'line3', 'line4', 'line5'],
|
|
452
|
+
characterPosition: 5
|
|
453
|
+
};
|
|
454
|
+
const errorMessage = 'Test error';
|
|
455
|
+
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
456
|
+
|
|
457
|
+
expect(result.some(line => line.includes('>>>'))).toBe(true);
|
|
458
|
+
expect(result.some(line => line.includes('3:'))).toBe(true);
|
|
459
|
+
});
|
|
460
|
+
|
|
461
|
+
it('| should handle formatJsonErrorForLogging with empty lines in context', (): void => {
|
|
462
|
+
const lineInfo: JsonErrorLineInfo = {
|
|
463
|
+
lineNumber: 2,
|
|
464
|
+
contextLines: ['line1', '', 'line3'],
|
|
465
|
+
characterPosition: 5
|
|
466
|
+
};
|
|
467
|
+
const errorMessage = 'Test error';
|
|
468
|
+
const result = DyFM_JsonErrorHelper.formatJsonErrorForLogging(lineInfo, errorMessage);
|
|
469
|
+
|
|
470
|
+
expect(result.some(line => line.includes('(empty line)'))).toBe(true);
|
|
471
|
+
});
|
|
472
|
+
|
|
473
|
+
it('| should handle parseJsonWithEnhancedError with complex nested JSON', (): void => {
|
|
474
|
+
const jsonString = '{"level1": {"level2": {"level3": "value"}}}';
|
|
475
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
476
|
+
|
|
477
|
+
expect(result.level1.level2.level3).toBe('value');
|
|
478
|
+
});
|
|
479
|
+
|
|
480
|
+
it('| should handle parseJsonWithEnhancedError with array containing objects', (): void => {
|
|
481
|
+
const jsonString = '[{"id": 1}, {"id": 2}]';
|
|
482
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
483
|
+
|
|
484
|
+
expect(result).toEqual([{ id: 1 }, { id: 2 }]);
|
|
485
|
+
});
|
|
486
|
+
|
|
487
|
+
it('| should handle parseJsonWithEnhancedError with special characters', (): void => {
|
|
488
|
+
const jsonString = '{"message": "Hello\\nWorld\\tTab"}';
|
|
489
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
490
|
+
|
|
491
|
+
expect(result.message).toBe('Hello\nWorld\tTab');
|
|
492
|
+
});
|
|
493
|
+
|
|
494
|
+
it('| should handle parseJsonWithEnhancedError with unicode characters', (): void => {
|
|
495
|
+
const jsonString = '{"unicode": "🚀 Test ñáéíóú"}';
|
|
496
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
497
|
+
|
|
498
|
+
expect(result.unicode).toBe('🚀 Test ñáéíóú');
|
|
499
|
+
});
|
|
500
|
+
|
|
501
|
+
it('| should handle parseJsonWithEnhancedError with scientific notation', (): void => {
|
|
502
|
+
const jsonString = '{"small": 1e-10, "large": 1e10}';
|
|
503
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString);
|
|
504
|
+
|
|
505
|
+
expect(result.small).toBe(1e-10);
|
|
506
|
+
expect(result.large).toBe(1e10);
|
|
507
|
+
});
|
|
508
|
+
|
|
509
|
+
it('| should handle parseJsonWithEnhancedError with reviver that returns undefined', (): void => {
|
|
510
|
+
const jsonString = '{"keep": "value", "remove": "value"}';
|
|
511
|
+
const reviver = (key: string, value: any): any => {
|
|
512
|
+
return key === 'remove' ? undefined : value;
|
|
513
|
+
};
|
|
514
|
+
const result = DyFM_JsonErrorHelper.parseJsonWithEnhancedError(jsonString, reviver);
|
|
515
|
+
|
|
516
|
+
expect(result.keep).toBe('value');
|
|
517
|
+
expect(result.remove).toBeUndefined();
|
|
518
|
+
});
|
|
519
|
+
});
|
|
520
|
+
});
|
|
521
|
+
|