From ae3793419e98189a8976399aaefbd112a996befe Mon Sep 17 00:00:00 2001 From: Suyash Patil <127177049+suyashpatil78@users.noreply.github.com> Date: Sat, 4 May 2024 15:40:16 +0530 Subject: [PATCH] feat: adding eslint rule for converting toBe(true) to toBeTrue() etc (#2911) * feat: adding eslint rule for converting toBe(true) to toBeTrue() etc * minor * minor * feat: prefer resolveTo and rejectWith instead of returnValue(Promise.resolve()) (#2912) * feat: prefer resolveTo and rejectWith instead of returnValue(Promise.resolve()) * feat: added deepFreeze to not pollute global mock data (#2913) * feat: added deepFreeze to not pollute global mock data * feat: added deepFreeze to not pollute global mock data - Part 2 (#2914) * feat: added deepFreeze to not pollute global mock data - Part 2 * feat: added deepFreeze to not pollute global mock data - Part 3 (#2915) * feat: added deepFreeze to not pollute global mock data - Part 3 * feat: added deepFreeze to not pollute global mock data - Part 4 (#2916) * feat: added deepFreeze to not pollute global mock data - Part 4 * feat: added deepFreeze to not pollute global mock data - Part 5 (#2917) * feat: added deepFreeze to not pollute global mock data - Part 5 * feat: added deepFreeze to not pollute global mock data - Part 6 (#2918) * feat: added deepFreeze to not pollute global mock data - Part 6 * feat: added deepFreeze to not pollute global mock data - Part 7 (#2919) * feat: added deepFreeze to not pollute global mock data - Part 7 * minor * feat: added deepFreeze to not pollute global mock data - Part 8 (#2922) * feat: added deepFreeze to not pollute global mock data - Part 8 * feat: added deepFreeze to not pollute global mock data - Part 9 (#2924) * feat: added deepFreeze to not pollute global mock data - Part 9 * feat: added deepFreeze to not pollute global mock data - Part 10 (#2925) * feat: added deepFreeze to not pollute global mock data - Part 10 * feat: added deepFreeze to not pollute global mock data - Part 11 (#2927) * feat: added deepFreeze to not pollute global mock data - Part 11 * feat: added deepFreeze to not pollute global mock data - Part 12 (#2929) * feat: added deepFreeze to not pollute global mock data - Part 12 * feat: added deepFreeze to not pollute global mock data - Part 13 (#2930) * feat: added deepFreeze to not pollute global mock data - Part 13 * minor * feat: added deepFreeze to not pollute global mock data - Part 14 (#2933) * feat: added deepFreeze to not pollute global mock data - Part 14 * feat: added deepFreeze to not pollute global mock data - Part 15 (#2934) * feat: added deepFreeze to not pollute global mock data - Part 15 * test: fixing tests - part 1 (#2939) * test: fixing tests - part 1 * test: fixing tests - part 2 (#2940) * test: fixing tests - part 2 * test: fixing tests - part 3 (#2941) * test: fixing tests - part 3 * test: fixing tests - part 4 (#2943) * test: fixing tests - part 4 * test: fixing tests - part 5 (#2945) * minor --- .eslintrc.json | 42 ++- eslint-custom-rules/index.js | 2 + .../eslint-plugin-prefer-jasmine-matchers.js | 134 ++++++++ ...nt-plugin-prefer-resolve-to-reject-with.js | 52 ++++ src/app/core/mock-data/account-option.data.ts | 6 +- .../core/mock-data/acess-token-data.data.ts | 10 +- .../mock-data/action-sheet-options.data.ts | 18 +- ...dd-edit-advance-request-form-value.data.ts | 14 +- .../core/mock-data/advance-platform.data.ts | 6 +- .../mock-data/advance-request-actions.data.ts | 6 +- .../advance-request-approver.data.ts | 6 +- ...dvance-request-custom-field-values.data.ts | 10 +- .../mock-data/advance-request-file.data.ts | 10 +- .../advance-requests-custom-fields.data.ts | 10 +- .../core/mock-data/advance-requests.data.ts | 42 +-- .../core/mock-data/allowed-actions.data.ts | 6 +- .../mock-data/allowed-expense-types.data.ts | 6 +- .../allowed-per-diem-rate-options.data.ts | 6 +- src/app/core/mock-data/api-params.data.ts | 18 +- src/app/core/mock-data/api-reports.data.ts | 34 +- src/app/core/mock-data/app-version.data.ts | 6 +- src/app/core/mock-data/approval.data.ts | 10 +- src/app/core/mock-data/approver.data.ts | 42 +-- src/app/core/mock-data/auth-reponse.data.ts | 26 +- src/app/core/mock-data/auth-response.data.ts | 6 +- .../core/mock-data/bank-feed-sources.data.ts | 6 +- .../mock-data/card-aggregate-stats.data.ts | 14 +- src/app/core/mock-data/cc-transaction.data.ts | 10 +- ...i-response.ts => ccc-api-response.data.ts} | 6 +- .../mock-data/ccc-expense.details.data.ts | 14 +- .../core/mock-data/combined-options.data.ts | 14 +- .../commute-deduction-options.data.ts | 6 +- .../commute-details-response.data.ts | 14 +- .../core/mock-data/commute-details.data.ts | 6 +- .../corporate-card-expense-flattened.data.ts | 6 +- ...corporate-card-expense-unflattened.data.ts | 18 +- .../mock-data/corporate-card-expense.data.ts | 6 +- .../mock-data/corporate-card-trackers.data.ts | 34 +- ...orporate-card-transaction-response.data.ts | 18 +- ...st-center-dependent-fields-mapping.data.ts | 6 +- src/app/core/mock-data/cost-centers.data.ts | 42 +-- .../critical-policy-violation-popover.data.ts | 14 +- .../crtical-policy-violations.data.ts | 10 +- src/app/core/mock-data/currency-ip.data.ts | 10 +- src/app/core/mock-data/currency-obj.data.ts | 26 +- .../core/mock-data/currency-summary.data.ts | 6 +- src/app/core/mock-data/currency.data.ts | 22 +- src/app/core/mock-data/custom-field.data.ts | 34 +- src/app/core/mock-data/custom-input.data.ts | 22 +- .../mock-data/custom-inputs-field.data.ts | 6 +- .../core/mock-data/custom-property.data.ts | 14 +- src/app/core/mock-data/dashboard-task.data.ts | 6 +- src/app/core/mock-data/data-transform.data.ts | 18 +- .../default-txn-field-values.data.ts | 22 +- .../dependent-field-expenses.data.ts | 10 +- .../mock-data/dependent-field-mapping.data.ts | 18 +- .../mock-data/dependent-field-option.data.ts | 18 +- .../mock-data/dependent-field-value.data.ts | 10 +- .../core/mock-data/dependent-field.data.ts | 10 +- .../core/mock-data/directions-results.data.ts | 8 +- src/app/core/mock-data/duplicate-sets.data.ts | 26 +- src/app/core/mock-data/email-events.data.ts | 6 +- src/app/core/mock-data/employee.data.ts | 18 +- ...-mapping-for-verify-number-popover.data.ts | 6 +- src/app/core/mock-data/etxn-params.data.ts | 6 +- .../core/mock-data/expense-field-obj.data.ts | 22 +- src/app/core/mock-data/expense-field.data.ts | 50 +-- .../core/mock-data/expense-fields-map.data.ts | 38 +-- .../core/mock-data/expense-filters.data.ts | 74 ++--- src/app/core/mock-data/expense-policy.data.ts | 14 +- src/app/core/mock-data/expense-v2.data.ts | 10 +- src/app/core/mock-data/expense.data.ts | 126 ++++---- src/app/core/mock-data/expenses-info.data.ts | 26 +- .../core/mock-data/extended-account.data.ts | 6 +- .../extended-advance-request.data.ts | 118 +++---- .../core/mock-data/extended-advance.data.ts | 26 +- .../mock-data/extended-device-info.data.ts | 14 +- .../core/mock-data/extended-org-user.data.ts | 26 +- .../core/mock-data/extended-projects.data.ts | 38 +-- src/app/core/mock-data/file-object.data.ts | 94 +++--- src/app/core/mock-data/file-txn.data.ts | 30 +- src/app/core/mock-data/file.data.ts | 14 +- src/app/core/mock-data/filter-options.data.ts | 14 +- src/app/core/mock-data/filter-pills.data.ts | 82 ++--- src/app/core/mock-data/filter.data.ts | 10 +- ...filtered-missing-fields-violations.data.ts | 10 +- .../filtered-split-policy-violations.data.ts | 10 +- src/app/core/mock-data/form-value.data.ts | 10 +- .../formatted-policy-violation.data.ts | 18 +- .../generated-form-properties.data.ts | 22 +- ...expenses-query-params-with-filters.data.ts | 22 +- ...et-tasks-query-params-with-filters.data.ts | 18 +- .../mock-data/get-tasks-query-params.data.ts | 18 +- .../individual-expense-policy-state.data.ts | 14 +- src/app/core/mock-data/info-card-data.data.ts | 6 +- src/app/core/mock-data/ld-all-flags.data.ts | 6 +- src/app/core/mock-data/ld-client-user.data.ts | 6 +- src/app/core/mock-data/location.data.ts | 30 +- .../mock-data/matchedCCCTransaction.data.ts | 6 +- .../mock-data/matchedCCTransaction.data.ts | 14 +- .../mock-data/merge-expense-form-data.data.ts | 22 +- .../merge-expenses-custom-inputs.data.ts | 6 +- .../mock-data/merge-expenses-option.data.ts | 76 ++--- .../merge-expenses-options-data.data.ts | 175 ++++++----- .../mock-data/merge-expenses-payload.data.ts | 6 +- .../core/mock-data/mileage-location.data.ts | 22 +- src/app/core/mock-data/mileage-rate.data.ts | 42 +-- .../missing-mandatory-fields.data.ts | 10 +- .../core/mock-data/modal-controller.data.ts | 2 +- .../core/mock-data/modal-properties.data.ts | 6 +- .../core/mock-data/model-properties.data.ts | 10 +- .../mock-data/my-advances-filters.data.ts | 14 +- .../mock-data/my-reports-filterpills.data.ts | 58 ++-- .../core/mock-data/my-reports-filters.data.ts | 58 ++-- .../mock-data/my-reports-load-data.data.ts | 14 +- src/app/core/mock-data/my-reports.data.ts | 21 +- .../mock-data/notification-events.data.ts | 14 +- src/app/core/mock-data/option.data.ts | 6 +- .../mock-data/org-category-list-item.data.ts | 14 +- src/app/core/mock-data/org-category.data.ts | 146 ++++----- .../org-payment-mode-settings.data.ts | 18 +- src/app/core/mock-data/org-settings.data.ts | 110 +++---- .../core/mock-data/org-user-settings.data.ts | 54 ++-- src/app/core/mock-data/org.data.ts | 10 +- src/app/core/mock-data/outbox-queue.data.ts | 6 +- src/app/core/mock-data/parsed-receipt.data.ts | 58 ++-- src/app/core/mock-data/pdf-export.data.ts | 10 +- .../mock-data/per-diem-custom-inputs.data.ts | 10 +- .../mock-data/per-diem-form-value.data.ts | 42 +-- src/app/core/mock-data/per-diem-rates.data.ts | 10 +- .../core/mock-data/personal-card-txns.data.ts | 10 +- src/app/core/mock-data/personal-cards.data.ts | 14 +- .../mock-data/platform-api-category.data.ts | 18 +- .../platform-corporate-card-detail.data.ts | 20 +- .../mock-data/platform-corporate-card.data.ts | 30 +- .../mock-data/platform-cost-centers.data.ts | 10 +- .../mock-data/platform-mileage-rate.data.ts | 14 +- .../mock-data/platform-policy-expense.data.ts | 38 +-- .../core/mock-data/platform-report.data.ts | 31 +- .../v1/advance-request-platform.data.ts | 15 +- .../v1/expense-duplicate-sets.data.ts | 18 +- .../mock-data/platform/v1/expense.data.ts | 132 ++++---- .../platform/v1/expenses-query-params.data.ts | 14 +- .../platform/v1/expenses-response.data.ts | 6 +- .../platform/v1/expenses-stats.data.ts | 18 +- .../core/mock-data/policy-violation.data.ts | 38 +-- .../policy-violcation-comment.data.ts | 22 +- src/app/core/mock-data/popover-params.data.ts | 10 +- src/app/core/mock-data/popup.data.ts | 14 +- .../project-dependent-fields-mapping.data.ts | 6 +- .../mock-data/public-policy-expense.data.ts | 54 ++-- .../recent-local-storage-items.data.ts | 18 +- src/app/core/mock-data/recently-used.data.ts | 139 +++++---- src/app/core/mock-data/report-actions.data.ts | 6 +- .../report-auto-submission-details.data.ts | 6 +- src/app/core/mock-data/report-options.data.ts | 19 +- .../core/mock-data/report-stats-data.data.ts | 10 +- src/app/core/mock-data/report-stats.data.ts | 10 +- .../core/mock-data/report-unflattened.data.ts | 58 ++-- src/app/core/mock-data/report-v1.data.ts | 18 +- src/app/core/mock-data/report.data.ts | 34 +- .../mock-data/router-state-snapshot.data.ts | 4 +- .../core/mock-data/selected-filters.data.ts | 50 +-- .../sidemenu-allowed-actions.data.ts | 6 +- src/app/core/mock-data/sidemenu-item.data.ts | 18 +- src/app/core/mock-data/sidemenu.data.ts | 30 +- .../mock-data/snackbar-properties.data.ts | 34 +- .../mock-data/split-expense-policy.data.ts | 6 +- ...-expense-data.ts => split-expense.data.ts} | 46 +-- src/app/core/mock-data/split-payload.data.ts | 14 +- src/app/core/mock-data/splits.data.ts | 10 +- .../mock-data/static-map-properties.data.ts | 6 +- .../stats-dimension-response.data.ts | 32 +- src/app/core/mock-data/stats-response.data.ts | 14 +- src/app/core/mock-data/stats.data.ts | 26 +- src/app/core/mock-data/task-cta.data.ts | 38 +-- src/app/core/mock-data/task-filters.data.ts | 38 +-- src/app/core/mock-data/task.data.ts | 50 +-- src/app/core/mock-data/tax-group.data.ts | 10 +- src/app/core/mock-data/tax-settings.data.ts | 6 +- .../mock-data/team-reports-filters.data.ts | 46 +-- .../track-expense-properties.data.ts | 30 +- .../core/mock-data/transaction-status.data.ts | 18 +- src/app/core/mock-data/transaction.data.ts | 238 +++++++------- .../mock-data/transformed-expense.data.ts | 50 +-- ...ormed-split-expense-missing-fields.data.ts | 10 +- src/app/core/mock-data/txn-account.data.ts | 6 +- .../mock-data/txn-custom-properties.data.ts | 38 +-- src/app/core/mock-data/undo-merge.data.ts | 10 +- .../unflattened-advance-request.data.ts | 6 +- .../mock-data/unflattened-expense.data.ts | 38 +-- .../core/mock-data/unflattened-txn.data.ts | 294 +++++++++--------- .../mock-data/unformatted-transaction.data.ts | 6 +- .../core/mock-data/unique-cards-stats.data.ts | 6 +- src/app/core/mock-data/unique-cards.data.ts | 6 +- .../mock-data/user-password-status.data.ts | 6 +- ...g-for-update-mobile-number-popover.data.ts | 6 +- .../virtual-card-combined-response.data.ts | 6 +- .../virtual-card-details-response.data.ts | 11 +- .../mock-data/virtual-card-response.data.ts | 10 +- .../virtual-cards-combined-request.data.ts | 6 +- .../mock-data/virtual-select-option.data.ts | 35 ++- src/app/core/mock-data/yoodle-token.data.ts | 6 +- .../card-details-combined-response.model.ts | 2 +- .../models/card-details-response.model.ts | 2 +- .../services/advance-request.service.spec.ts | 63 ++-- src/app/core/services/advance.service.spec.ts | 4 +- .../core/services/categories.service.spec.ts | 10 +- ...porate-credit-card-expense.service.spec.ts | 2 +- .../services/custom-fields.service.spec.ts | 15 +- src/app/core/services/date.service.spec.ts | 8 +- .../services/dependent-fields.service.spec.ts | 10 +- .../services/expense-fields.service.spec.ts | 4 +- src/app/core/services/file.service.spec.ts | 5 +- .../core/services/location.service.spec.ts | 5 +- .../services/merge-expenses.service.spec.ts | 74 +++-- .../services/org-settings.service.spec.ts | 12 +- src/app/core/services/org.service.spec.ts | 18 +- ...recent-local-storage-items.service.spec.ts | 23 +- src/app/core/services/report.service.spec.ts | 31 +- src/app/core/services/status.service.spec.ts | 12 +- .../core/services/transaction.service.spec.ts | 24 +- src/app/core/services/utility.service.spec.ts | 7 +- .../services/virtual-cards.service.spec.ts | 7 +- .../test-data/accounts.service.spec.data.ts | 142 ++++----- .../core/test-data/custom-inputs.spec.data.ts | 38 +-- .../test-data/deep-link.service.spec.data.ts | 6 +- .../dependent-fields.service.spec.data.ts | 77 ++--- .../org-settings.service.spec.data.ts | 66 ++-- .../test-data/org-user.service.spec.data.ts | 50 +-- .../test-data/per-diem.service.spec.data.ts | 42 +-- src/app/core/test-data/projects.spec.data.ts | 60 ++-- .../test-data/status.service.spec.data.ts | 62 ++-- .../core/test-data/tasks.service.spec.data.ts | 38 +-- .../add-edit-expense-2.spec.ts | 23 +- .../add-edit-expense-3.spec.ts | 102 +++--- .../add-edit-expense-4.spec.ts | 40 ++- .../add-edit-expense-5.spec.ts | 15 +- .../add-edit-expense-6.spec.ts | 28 +- .../add-edit-mileage-1.spec.ts | 2 +- .../add-edit-mileage-3.spec.ts | 5 +- .../add-edit-mileage-4.spec.ts | 9 +- .../add-edit-mileage-5.spec.ts | 6 +- .../merge-expense-3.page.spec.ts | 37 +-- .../my-create-report.page.spec.ts | 5 +- .../employee-details-card.component.spec.ts | 4 +- .../fyle/my-reports/my-reports.page.spec.ts | 28 +- .../my-view-report.page.spec.ts | 26 +- .../notifications/notifications.page.spec.ts | 17 +- .../split-expense/split-expense.page.spec.ts | 34 +- .../team-reports/team-reports-1.page.spec.ts | 3 +- .../view-team-report.page.spec.ts | 89 +++--- .../setup-account/setup-account.page.spec.ts | 51 +-- .../audit-history.component.spec.ts | 10 +- .../view-comment.component.spec.ts | 25 +- .../view-comment/view-comment.component.ts | 6 +- .../expenses-card.component.spec.ts | 29 +- .../expenses-card.component.spec.ts | 25 +- .../approver-dialog.component.spec.ts | 25 +- .../fy-userlist-modal.component.spec.ts | 27 +- .../route-selector.component.spec.ts | 9 +- .../sidemenu-content.component.spec.ts | 17 +- .../virtual-select-modal.component.spec.ts | 2 +- 263 files changed, 3888 insertions(+), 3092 deletions(-) create mode 100644 eslint-custom-rules/rules/eslint-plugin-prefer-jasmine-matchers.js create mode 100644 eslint-custom-rules/rules/eslint-plugin-prefer-resolve-to-reject-with.js rename src/app/core/mock-data/{ccc-api-response.ts => ccc-api-response.data.ts} (97%) rename src/app/core/mock-data/{split-expense-data.ts => split-expense.data.ts} (84%) diff --git a/.eslintrc.json b/.eslintrc.json index 03a7afeb71..b9740a3a11 100644 --- a/.eslintrc.json +++ b/.eslintrc.json @@ -104,13 +104,47 @@ "createDefaultProgram": true }, "extends": [ - "plugin:@angular-eslint/ng-cli-compat", - "plugin:@angular-eslint/ng-cli-compat--formatting-add-on", - "plugin:@angular-eslint/template/process-inline-templates" + "plugin:@angular-eslint/ng-cli-compat" ], "rules": { "jsdoc/newline-after-description": "off", - "custom-rules/space-before-it-blocks": "error" + "@angular-eslint/component-class-suffix": "off", + "@typescript-eslint/naming-convention": "off", + "@angular-eslint/component-selector": "off", + "@angular-eslint/directive-selector": "off", + "indent": "off", + "semi": "off", + "no-underscore-dangle": "off", + "@angular-eslint/template/no-negated-async": "off", + "@typescript-eslint/prefer-for-of": "off", + "prefer-arrow/prefer-arrow-functions": "off", + "@typescript-eslint/ban-types": "off", + "@typescript-eslint/consistent-type-assertions": "off", + "@angular-eslint/no-conflicting-lifecycle": "off", + "lines-between-class-members": "off", + "@typescript-eslint/no-shadow": "off", + "complexity": "off", + "max-depth": "off", + "max-params-no-constructor/max-params-no-constructor": "off", + "max-len": "off", + "space-before-function-paren": "off", + "@typescript-eslint/quotes": "off", + "@typescript-eslint/no-unsafe-call": "off", + "@typescript-eslint/no-unsafe-member-access": "off", + "@typescript-eslint/no-unsafe-assignment": "off", + "@typescript-eslint/no-unsafe-return": "off", + "@typescript-eslint/no-unsafe-argument": "off", + "@typescript-eslint/explicit-function-return-type": "off", + "@typescript-eslint/no-unnecessary-type-assertion": "off", + "@typescript-eslint/no-unused-vars": "off", + "@typescript-eslint/no-explicit-any": "off", + "@typescript-eslint/no-empty-function": "off", + "@typescript-eslint/no-empty-interface": "off", + "@typescript-eslint/no-inferrable-types": "off", + "no-unused-expressions": "off", + "custom-rules/space-before-it-blocks": "error", + "custom-rules/prefer-jasmine-matchers": "error", + "custom-rules/prefer-resolve-to-reject-with": "error" } } ] diff --git a/eslint-custom-rules/index.js b/eslint-custom-rules/index.js index ce10d3e766..58d489f3c2 100644 --- a/eslint-custom-rules/index.js +++ b/eslint-custom-rules/index.js @@ -2,5 +2,7 @@ module.exports = { rules: { 'prefer-deep-freeze': require('./rules/eslint-plugin-prefer-deep-freeze'), 'space-before-it-blocks': require('./rules/eslint-plugin-space-before-it-blocks'), + 'prefer-jasmine-matchers': require('./rules/eslint-plugin-prefer-jasmine-matchers'), + 'prefer-resolve-to-reject-with': require('./rules/eslint-plugin-prefer-resolve-to-reject-with') }, }; \ No newline at end of file diff --git a/eslint-custom-rules/rules/eslint-plugin-prefer-jasmine-matchers.js b/eslint-custom-rules/rules/eslint-plugin-prefer-jasmine-matchers.js new file mode 100644 index 0000000000..ed97434516 --- /dev/null +++ b/eslint-custom-rules/rules/eslint-plugin-prefer-jasmine-matchers.js @@ -0,0 +1,134 @@ +// Use toBeNull() instead of toBe(null) or toEqual(null) +// Use toBeUndefined() instead of toBe(undefined) or toEqual(undefined) +// Use toBeTrue() instead of toBe(true) or toEqual(true) +// Use toBeFalse() instead of toBe(false) or toEqual(false) +// Use toBeNaN() instead of toBe(NaN) or toEqual(NaN) + +module.exports = { + meta: { + type: "suggestion", + docs: { + description: "Enforce using toBeTrue(), toBeFalse(), toBeNull(), and toBeUndefined() instead of toBe() or toEqual() with true, false, null, or undefined", + category: "Best Practices", + recommended: true, + }, + fixable: "code", + schema: [], + }, + + create: function (context) { + return { + CallExpression(node) { + const isToBe = node.callee.property && node.callee.property.name === "toBe"; + const isToEqual = node.callee.property && node.callee.property.name === "toEqual"; + + if ((isToBe || isToEqual) && node.arguments.length === 1) { + const argValue = node.arguments[0].value; + if (argValue === true) { + context.report({ + node, + message: "Prefer using toBeTrue() instead of toBe(true) or toEqual(true)", + fix: function (fixer) { + const replacementText = 'toBeTrue()'; + const sourceCode = context.getSourceCode(); + const nodeText = sourceCode.getText(node); + + // Find the correct part of the code to replace + const match = nodeText.match(/\.toBe\((true)\)|\.toEqual\((true)\)/); + if (match) { + const start = node.callee.property.range[0]; + const end = node.callee.property.range[1] + 6; // Adjust end position + return fixer.replaceTextRange([start, end], replacementText); + } + + return null; // No match found, no fix needed + } + }); + } else if (argValue === false) { + context.report({ + node, + message: "Prefer using toBeFalse() instead of toBe(false) or toEqual(false)", + fix: function (fixer) { + const replacementText = 'toBeFalse()'; + const sourceCode = context.getSourceCode(); + const nodeText = sourceCode.getText(node); + + // Find the correct part of the code to replace + const match = nodeText.match(/\.toBe\((false)\)|\.toEqual\((false)\)/); + if (match) { + const start = node.callee.property.range[0]; + const end = node.callee.property.range[1] + 7; // Adjust end position + return fixer.replaceTextRange([start, end], replacementText); + } + + return null; // No match found, no fix needed + } + }); + } else if (argValue === null) { + context.report({ + node, + message: "Prefer using toBeNull() instead of toBe(null) or toEqual(null)", + fix: function (fixer) { + const replacementText = 'toBeNull()'; + const sourceCode = context.getSourceCode(); + const nodeText = sourceCode.getText(node); + + // Find the correct part of the code to replace + const match = nodeText.match(/\.toBe\((null)\)|\.toEqual\((null)\)/); + if (match) { + const start = node.callee.property.range[0]; + const end = node.callee.property.range[1] + 6; // Adjust end position + return fixer.replaceTextRange([start, end], replacementText); + } + + return null; // No match found, no fix needed + } + }); + } else if (argValue === undefined && node.arguments[0].name === 'undefined') { + // Comparing the name of the argument to undefined since every variable is undefined by default in AST + context.report({ + node, + message: "Prefer using toBeUndefined() instead of toBe(undefined) or toEqual(undefined)", + fix: function (fixer) { + const replacementText = 'toBeUndefined()'; + const sourceCode = context.getSourceCode(); + const nodeText = sourceCode.getText(node); + + // Find the correct part of the code to replace + const match = nodeText.match(/\.toBe\((undefined)\)|\.toEqual\((undefined)\)/); + if (match) { + const start = node.callee.property.range[0]; + const end = node.callee.property.range[1] + 11; // Adjust end position + return fixer.replaceTextRange([start, end], replacementText); + } + + return null; // No match found, no fix needed + } + }); + } else if (node.arguments[0].name === 'NaN') { + // Since NaN === NaN returns false, we are comparing the name of the argument to NaN + context.report({ + node, + message: "Prefer using toBeNaN() instead of toBe(NaN) or toEqual(NaN)", + fix: function (fixer) { + const replacementText = 'toBeNaN()'; + const sourceCode = context.getSourceCode(); + const nodeText = sourceCode.getText(node); + + // Find the correct part of the code to replace + const match = nodeText.match(/\.toBe\((NaN)\)|\.toEqual\((NaN)\)/); + if (match) { + const start = node.callee.property.range[0]; + const end = node.callee.property.range[1] + 5; // Adjust end position + return fixer.replaceTextRange([start, end], replacementText); + } + + return null; // No match found, no fix needed + } + }); + } + } + } + }; + } +}; diff --git a/eslint-custom-rules/rules/eslint-plugin-prefer-resolve-to-reject-with.js b/eslint-custom-rules/rules/eslint-plugin-prefer-resolve-to-reject-with.js new file mode 100644 index 0000000000..903d01971a --- /dev/null +++ b/eslint-custom-rules/rules/eslint-plugin-prefer-resolve-to-reject-with.js @@ -0,0 +1,52 @@ +const SpyStrategyCall = `CallExpression:matches( + [callee.object.property.name=and], + [callee.object.callee.property.name=withArgs] + )`.replace(/\s+/g, ' '); + +const ReturnStrategy = `${SpyStrategyCall}[callee.property.name=returnValue]`; + +// Matches Promise.{resolve,reject}(X) +const PromiseCall = 'CallExpression[callee.object.name=Promise]'; +const SettledPromise = `${PromiseCall}[callee.property.name=/resolve|reject/]`; + +module.exports = { + meta: { + type: 'suggestion', + docs: { + description: "Enforce using resolveTo() and rejectWith() instead of Promise.resolve() and Promise.reject() in Jasmine tests", + category: "Best Practices", + recommended: true, + }, + fixable: 'code', + schema: [] + }, + + create: context => ({ + [`${ReturnStrategy} > ${SettledPromise}.arguments:first-child`] (promiseCall) { + const returnStrategyCall = promiseCall.parent; + const returnValueMethod = returnStrategyCall.callee.property; + const preferredMethod = promiseCall.callee.property.name === 'resolve' + ? 'resolveTo' : 'rejectWith'; + + context.report({ + message: `Prefer ${preferredMethod}`, + loc: { + start: returnValueMethod.loc.start, + end: returnStrategyCall.loc.end + }, + fix (fixer) { + const code = context.getSourceCode(); + return [ + // Replace Promise constructor call with its arguments + fixer.remove(promiseCall.callee), + fixer.remove(code.getTokenAfter(promiseCall.callee)), + fixer.remove(code.getLastToken(promiseCall)), + + // Replace returnValue method with resolveTo or rejectWith + fixer.replaceText(returnValueMethod, preferredMethod) + ]; + } + }) + } + }) +}; diff --git a/src/app/core/mock-data/account-option.data.ts b/src/app/core/mock-data/account-option.data.ts index f4bb8196d9..8b0f5c96f8 100644 --- a/src/app/core/mock-data/account-option.data.ts +++ b/src/app/core/mock-data/account-option.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AccountOption } from '../models/account-option.model'; import { multiplePaymentModesData } from '../test-data/accounts.service.spec.data'; -export const accountOptionData1: AccountOption[] = [ +export const accountOptionData1: AccountOption[] = deepFreeze([ { label: 'account1', value: multiplePaymentModesData[0], @@ -10,4 +12,4 @@ export const accountOptionData1: AccountOption[] = [ label: 'account2', value: multiplePaymentModesData[1], }, -]; +]); diff --git a/src/app/core/mock-data/acess-token-data.data.ts b/src/app/core/mock-data/acess-token-data.data.ts index 9b1136643f..ac71ba3981 100644 --- a/src/app/core/mock-data/acess-token-data.data.ts +++ b/src/app/core/mock-data/acess-token-data.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AccessTokenData } from '../models/access-token-data.model'; -export const apiAccessTokenRes: AccessTokenData = { +export const apiAccessTokenRes: AccessTokenData = deepFreeze({ iat: 1678349549, iss: 'FyleApp', user_id: 'usvKA4X8Ugcr', @@ -12,9 +14,9 @@ export const apiAccessTokenRes: AccessTokenData = { version: '3', cluster_domain: '"https://staging.fyle.tech"', exp: 1678353149, -}; +}); -export const apiTokenWithoutRoles: AccessTokenData = { +export const apiTokenWithoutRoles: AccessTokenData = deepFreeze({ iat: 1678349549, iss: 'FyleApp', user_id: 'usvKA4X8Ugcr', @@ -25,4 +27,4 @@ export const apiTokenWithoutRoles: AccessTokenData = { version: '3', cluster_domain: '"https://staging.fyle.tech"', exp: 1678353149, -}; +}); diff --git a/src/app/core/mock-data/action-sheet-options.data.ts b/src/app/core/mock-data/action-sheet-options.data.ts index f2fd382b5f..ccd6f747b5 100644 --- a/src/app/core/mock-data/action-sheet-options.data.ts +++ b/src/app/core/mock-data/action-sheet-options.data.ts @@ -1,4 +1,6 @@ -export const actionSheetOptionsData = [ +import deepFreeze from 'deep-freeze-strict'; + +export const actionSheetOptionsData = deepFreeze([ { text: 'Split Expense By Category', handler: () => {}, @@ -19,8 +21,8 @@ export const actionSheetOptionsData = [ text: 'Remove Card Expense', handler: () => {}, }, -]; -export const expectedActionSheetButtonRes = [ +]); +export const expectedActionSheetButtonRes = deepFreeze([ { text: 'Capture Receipt', icon: 'assets/svg/camera.svg', @@ -45,9 +47,9 @@ export const expectedActionSheetButtonRes = [ cssClass: 'capture-receipt', handler: undefined, }, -]; +]); -export const expectedActionSheetButtonsWithMileage = [ +export const expectedActionSheetButtonsWithMileage = deepFreeze([ { text: 'Capture Receipt', icon: 'assets/svg/camera.svg', @@ -66,9 +68,9 @@ export const expectedActionSheetButtonsWithMileage = [ cssClass: 'capture-receipt', handler: undefined, }, -]; +]); -export const expectedActionSheetButtonsWithPerDiem = [ +export const expectedActionSheetButtonsWithPerDiem = deepFreeze([ { text: 'Capture Receipt', icon: 'assets/svg/camera.svg', @@ -87,4 +89,4 @@ export const expectedActionSheetButtonsWithPerDiem = [ cssClass: 'capture-receipt', handler: undefined, }, -]; +]); diff --git a/src/app/core/mock-data/add-edit-advance-request-form-value.data.ts b/src/app/core/mock-data/add-edit-advance-request-form-value.data.ts index 73c0f1b26a..f71ce94c3c 100644 --- a/src/app/core/mock-data/add-edit-advance-request-form-value.data.ts +++ b/src/app/core/mock-data/add-edit-advance-request-form-value.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AddEditAdvanceRequestFormValue } from '../models/add-edit-advance-request-form-value.model'; import { recentlyUsedProjectRes } from './recently-used.data'; -export const addEditAdvanceRequestFormValueData: AddEditAdvanceRequestFormValue = { +export const addEditAdvanceRequestFormValueData: AddEditAdvanceRequestFormValue = deepFreeze({ currencyObj: { amount: 130, currency: 'USD', @@ -12,17 +14,17 @@ export const addEditAdvanceRequestFormValueData: AddEditAdvanceRequestFormValue notes: 'Test notes', project: null, customFieldValues: null, -}; +}); -export const addEditAdvanceRequestFormValueData2: AddEditAdvanceRequestFormValue = { +export const addEditAdvanceRequestFormValueData2: AddEditAdvanceRequestFormValue = deepFreeze({ currencyObj: null, purpose: null, notes: null, project: null, customFieldValues: [], -}; +}); -export const addEditAdvanceRequestFormValueData3: AddEditAdvanceRequestFormValue = { +export const addEditAdvanceRequestFormValueData3: AddEditAdvanceRequestFormValue = deepFreeze({ ...addEditAdvanceRequestFormValueData, project: recentlyUsedProjectRes[0], -}; +}); diff --git a/src/app/core/mock-data/advance-platform.data.ts b/src/app/core/mock-data/advance-platform.data.ts index 886398bd3c..05d22d3a85 100644 --- a/src/app/core/mock-data/advance-platform.data.ts +++ b/src/app/core/mock-data/advance-platform.data.ts @@ -1,8 +1,10 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CustomFieldTypes } from '../enums/platform/v1/custom-fields-type.enum'; import { AdvancesPlatform } from '../models/platform/advances-platform.model'; import { PlatformApiResponse } from '../models/platform/platform-api-response.model'; -export const advancePlatform: PlatformApiResponse = { +export const advancePlatform: PlatformApiResponse = deepFreeze({ count: 1, offset: 0, data: [ @@ -85,4 +87,4 @@ export const advancePlatform: PlatformApiResponse = { }, }, ], -}; +}); diff --git a/src/app/core/mock-data/advance-request-actions.data.ts b/src/app/core/mock-data/advance-request-actions.data.ts index 82f98b0bbc..952fd73e70 100644 --- a/src/app/core/mock-data/advance-request-actions.data.ts +++ b/src/app/core/mock-data/advance-request-actions.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AdvanceRequestActions } from '../models/advance-request-actions.model'; -export const apiAdvanceRequestAction: AdvanceRequestActions = { +export const apiAdvanceRequestAction: AdvanceRequestActions = deepFreeze({ id: 'areqoVuT5I8OOy', can_save: true, can_submit: true, @@ -13,4 +15,4 @@ export const apiAdvanceRequestAction: AdvanceRequestActions = { can_pull_back: false, can_pay: false, can_delete: true, -}; +}); diff --git a/src/app/core/mock-data/advance-request-approver.data.ts b/src/app/core/mock-data/advance-request-approver.data.ts index 501ac77543..a8c75f05e6 100644 --- a/src/app/core/mock-data/advance-request-approver.data.ts +++ b/src/app/core/mock-data/advance-request-approver.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AdvanceApprover } from '../models/approver.model'; -export const AdvanceRequestApprover: AdvanceApprover[] = [ +export const AdvanceRequestApprover: AdvanceApprover[] = deepFreeze([ { id: 8311, created_at: null, @@ -15,4 +17,4 @@ export const AdvanceRequestApprover: AdvanceApprover[] = [ approver_org_id: 'orYtMVz2qisQ', comment: null, }, -]; +]); diff --git a/src/app/core/mock-data/advance-request-custom-field-values.data.ts b/src/app/core/mock-data/advance-request-custom-field-values.data.ts index 497a2a1cbc..0f5bad44e1 100644 --- a/src/app/core/mock-data/advance-request-custom-field-values.data.ts +++ b/src/app/core/mock-data/advance-request-custom-field-values.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AdvanceRequestCustomFieldValues } from '../models/advance-request-custom-field-values.model'; -export const advanceRequestCustomFieldValuesData: AdvanceRequestCustomFieldValues[] = [ +export const advanceRequestCustomFieldValuesData: AdvanceRequestCustomFieldValues[] = deepFreeze([ { name: 'Phase', value: 'Phase 1', @@ -21,9 +23,9 @@ export const advanceRequestCustomFieldValuesData: AdvanceRequestCustomFieldValue value: 'option1', type: 'OPTION', }, -]; +]); -export const advanceRequestCustomFieldValuesData2: AdvanceRequestCustomFieldValues[] = [ +export const advanceRequestCustomFieldValuesData2: AdvanceRequestCustomFieldValues[] = deepFreeze([ { name: 'Phase', value: 'Phase 1', @@ -40,4 +42,4 @@ export const advanceRequestCustomFieldValuesData2: AdvanceRequestCustomFieldValu name: 'Checking', value: 'option1', }, -]; +]); diff --git a/src/app/core/mock-data/advance-request-file.data.ts b/src/app/core/mock-data/advance-request-file.data.ts index 5da4861d76..9e26b21fa2 100644 --- a/src/app/core/mock-data/advance-request-file.data.ts +++ b/src/app/core/mock-data/advance-request-file.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AdvanceRequestFile } from '../models/advance-request-file.model'; -export const advRequestFile: AdvanceRequestFile = { +export const advRequestFile: AdvanceRequestFile = deepFreeze({ files: [ { id: 'fi1w2IE6JeqS', @@ -92,9 +94,9 @@ export const advRequestFile: AdvanceRequestFile = { is_sent_back: false, is_pulled_back: true, }, -}; +}); -export const advRequestFile2: AdvanceRequestFile = { +export const advRequestFile2: AdvanceRequestFile = deepFreeze({ files: [ { id: 'fiK7c69UDJNb', @@ -186,4 +188,4 @@ export const advRequestFile2: AdvanceRequestFile = { is_sent_back: false, is_pulled_back: true, }, -}; +}); diff --git a/src/app/core/mock-data/advance-requests-custom-fields.data.ts b/src/app/core/mock-data/advance-requests-custom-fields.data.ts index df6750db53..17f1f58e21 100644 --- a/src/app/core/mock-data/advance-requests-custom-fields.data.ts +++ b/src/app/core/mock-data/advance-requests-custom-fields.data.ts @@ -1,5 +1,7 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AdvanceRequestsCustomFields } from '../models/advance-requests-custom-fields.model'; -export const advanceRequestCustomFieldData: AdvanceRequestsCustomFields[] = [ +export const advanceRequestCustomFieldData: AdvanceRequestsCustomFields[] = deepFreeze([ { id: 150, org_id: 'orNVthTo2Zyo', @@ -42,9 +44,9 @@ export const advanceRequestCustomFieldData: AdvanceRequestsCustomFields[] = [ last_updated_by: 'ouX8dwsbLCLv', placeholder: '123', }, -]; +]); -export const advanceRequestCustomFieldData2: AdvanceRequestsCustomFields[] = [ +export const advanceRequestCustomFieldData2: AdvanceRequestsCustomFields[] = deepFreeze([ { id: 150, org_id: 'orNVthTo2Zyo', @@ -87,4 +89,4 @@ export const advanceRequestCustomFieldData2: AdvanceRequestsCustomFields[] = [ last_updated_by: 'ouX8dwsbLCLv', placeholder: null, }, -]; +]); diff --git a/src/app/core/mock-data/advance-requests.data.ts b/src/app/core/mock-data/advance-requests.data.ts index 657c569950..ee61163241 100644 --- a/src/app/core/mock-data/advance-requests.data.ts +++ b/src/app/core/mock-data/advance-requests.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AdvanceRequests } from '../models/advance-requests.model'; -export const advanceRequests: AdvanceRequests = { +export const advanceRequests: AdvanceRequests = deepFreeze({ id: 'areqMP09oaYXBf', created_at: new Date('2023-02-23T16:24:01.335Z'), approved_at: null, @@ -73,14 +75,14 @@ export const advanceRequests: AdvanceRequests = { updated_by: null, is_sent_back: false, is_pulled_back: true, -}; +}); -export const pullBackAdvancedRequests: AdvanceRequests = { +export const pullBackAdvancedRequests: AdvanceRequests = deepFreeze({ ...advanceRequests, is_pulled_back: true, -}; +}); -export const expectedSingleErq = { +export const expectedSingleErq = deepFreeze({ id: 'areqGzKF1Tne23', created_at: '2023-02-23T02:16:15.260Z', approved_at: null, @@ -102,14 +104,14 @@ export const expectedSingleErq = { updated_by: null, is_sent_back: null, is_pulled_back: null, -}; +}); -export const advancedRequests2: AdvanceRequests = { +export const advancedRequests2: AdvanceRequests = deepFreeze({ ...advanceRequests, id: 'areq99bN9mZgu1', -}; +}); -export const draftAdvancedRequestRes: AdvanceRequests = { +export const draftAdvancedRequestRes: AdvanceRequests = deepFreeze({ id: 'areqo6m2UmDSfq', created_at: new Date('2023-02-24T12:28:18.700Z'), updated_at: new Date('2023-02-24T12:28:18.700Z'), @@ -191,9 +193,9 @@ export const draftAdvancedRequestRes: AdvanceRequests = { type: null, }, ], -}; +}); -export const draftAdvancedRequestParam = { +export const draftAdvancedRequestParam = deepFreeze({ org_user_id: 'ouX8dwsbLCLv', currency: 'USD', source: 'MOBILE', @@ -254,9 +256,9 @@ export const draftAdvancedRequestParam = { value: false, }, ], -}; +}); -export const rejectedAdvReqRes: AdvanceRequests = { +export const rejectedAdvReqRes: AdvanceRequests = deepFreeze({ id: 'areqVU0Xr5suPC', created_at: new Date('2023-02-24T12:48:00.608Z'), updated_at: new Date('2023-02-24T12:48:48.860Z'), @@ -338,9 +340,9 @@ export const rejectedAdvReqRes: AdvanceRequests = { type: 'BOOLEAN', }, ], -}; +}); -export const checkPolicyAdvReqParam: AdvanceRequests = { +export const checkPolicyAdvReqParam: AdvanceRequests = deepFreeze({ id: 'areq4YujEm52Ub', created_at: new Date('2023-02-23T19:37:01.207Z'), approved_at: null, @@ -378,9 +380,9 @@ export const checkPolicyAdvReqParam: AdvanceRequests = { updated_by: null, is_sent_back: null, is_pulled_back: true, -}; +}); -export const advanceRequests2: Partial = { +export const advanceRequests2: Partial = deepFreeze({ ...advanceRequests, currency: 'USD', amount: 130, @@ -389,11 +391,11 @@ export const advanceRequests2: Partial = { notes: 'Test notes', source: 'MOBILE', custom_field_values: null, -}; +}); -export const advanceRequests3: Partial = { +export const advanceRequests3: Partial = deepFreeze({ org_user_id: 'ouX8dwsbLCLv', currency: 'GNF', source: 'MOBILE', created_at: new Date(), -}; +}); diff --git a/src/app/core/mock-data/allowed-actions.data.ts b/src/app/core/mock-data/allowed-actions.data.ts index d9b08af00d..0c05ae1aca 100644 --- a/src/app/core/mock-data/allowed-actions.data.ts +++ b/src/app/core/mock-data/allowed-actions.data.ts @@ -1,8 +1,10 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ReportAllowedActions } from '../models/allowed-actions.model'; -export const reportAllowedActionsResponse: ReportAllowedActions = { +export const reportAllowedActionsResponse: ReportAllowedActions = deepFreeze({ allowedRouteAccess: true, approve: true, create: true, delete: true, -}; +}); diff --git a/src/app/core/mock-data/allowed-expense-types.data.ts b/src/app/core/mock-data/allowed-expense-types.data.ts index dd41359380..d60e5569fb 100644 --- a/src/app/core/mock-data/allowed-expense-types.data.ts +++ b/src/app/core/mock-data/allowed-expense-types.data.ts @@ -1,4 +1,6 @@ -export const allowedExpenseTypes: Record = { +import deepFreeze from 'deep-freeze-strict'; + +export const allowedExpenseTypes: Record = deepFreeze({ mileage: true, perDiem: true, -}; +}); diff --git a/src/app/core/mock-data/allowed-per-diem-rate-options.data.ts b/src/app/core/mock-data/allowed-per-diem-rate-options.data.ts index 5069142865..dcdbf447f7 100644 --- a/src/app/core/mock-data/allowed-per-diem-rate-options.data.ts +++ b/src/app/core/mock-data/allowed-per-diem-rate-options.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AllowedPerDiemRateOptions } from '../models/allowed-per-diem-rate-options.model'; -export const allowedPerDiemRateOptionsData1: AllowedPerDiemRateOptions[] = [ +export const allowedPerDiemRateOptionsData1: AllowedPerDiemRateOptions[] = deepFreeze([ { label: 'BulkTest2', value: { @@ -31,4 +33,4 @@ export const allowedPerDiemRateOptionsData1: AllowedPerDiemRateOptions[] = [ readableRate: 'AED 12.00 per day', }, }, -]; +]); diff --git a/src/app/core/mock-data/api-params.data.ts b/src/app/core/mock-data/api-params.data.ts index 5513cfd91c..3a7bb2cac2 100644 --- a/src/app/core/mock-data/api-params.data.ts +++ b/src/app/core/mock-data/api-params.data.ts @@ -1,37 +1,39 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ReportApiParams } from '../models/report-api-params.model'; -export const getMyReportsParam1: ReportApiParams = { +export const getMyReportsParam1: ReportApiParams = deepFreeze({ offset: 0, limit: 2, queryParams: { rp_state: 'in.(DRAFT,APPROVER_PENDING,APPROVER_INQUIRY)', }, order: undefined, -}; +}); -export const getMyReportsParam2: ReportApiParams = { +export const getMyReportsParam2: ReportApiParams = deepFreeze({ offset: 2, limit: 2, queryParams: { rp_state: 'in.(DRAFT,APPROVER_PENDING,APPROVER_INQUIRY)', }, order: undefined, -}; +}); -export const getTeamReportsParams1: ReportApiParams = { +export const getTeamReportsParams1: ReportApiParams = deepFreeze({ offset: 0, limit: 10, queryParams: { rp_state: 'in.(APPROVER_PENDING)', }, order: null, -}; +}); -export const getTeamReportsParams2: ReportApiParams = { +export const getTeamReportsParams2: ReportApiParams = deepFreeze({ offset: 0, limit: 10, queryParams: { rp_state: 'in.(APPROVER_PENDING)', }, order: 'approvalDate.asc', -}; +}); diff --git a/src/app/core/mock-data/api-reports.data.ts b/src/app/core/mock-data/api-reports.data.ts index 747f343564..b5cc2c23fb 100644 --- a/src/app/core/mock-data/api-reports.data.ts +++ b/src/app/core/mock-data/api-reports.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExtendedReport } from '../models/report.model'; import { ApiV2Response } from '../models/api-v2.model'; -export const apiReportRes: ApiV2Response = { +export const apiReportRes: ApiV2Response = deepFreeze({ count: 4, data: [ { @@ -238,9 +240,9 @@ export const apiReportRes: ApiV2Response = { limit: 4, offset: 0, url: '/v2/reports', -}; +}); -export const apiReportSingleRes: ApiV2Response = { +export const apiReportSingleRes: ApiV2Response = deepFreeze({ count: 1, data: [ { @@ -305,9 +307,9 @@ export const apiReportSingleRes: ApiV2Response = { limit: 1, offset: 0, url: '/v2/reports', -}; +}); -export const expectedReports: ApiV2Response = { +export const expectedReports: ApiV2Response = deepFreeze({ count: 4, data: [ { @@ -545,9 +547,9 @@ export const expectedReports: ApiV2Response = { limit: 4, offset: 0, url: '/v2/reports', -}; +}); -export const apiAllReportsRes1: ApiV2Response = { +export const apiAllReportsRes1: ApiV2Response = deepFreeze({ count: 2, data: [ { @@ -660,9 +662,9 @@ export const apiAllReportsRes1: ApiV2Response = { limit: 2, offset: 0, url: '/v2/reports', -}; +}); -export const apiAllReportsRes2: ApiV2Response = { +export const apiAllReportsRes2: ApiV2Response = deepFreeze({ count: 1, data: [ { @@ -723,9 +725,9 @@ export const apiAllReportsRes2: ApiV2Response = { limit: 2, offset: 2, url: '/v2/reports', -}; +}); -export const apiTeamRptCountRes: ApiV2Response = { +export const apiTeamRptCountRes: ApiV2Response = deepFreeze({ count: 25, data: [ { @@ -794,9 +796,9 @@ export const apiTeamRptCountRes: ApiV2Response = { limit: 1, offset: 0, url: '/v2/reports', -}; +}); -export const apiTeamRptSingleRes: ApiV2Response = { +export const apiTeamRptSingleRes: ApiV2Response = deepFreeze({ count: 1, data: [ { @@ -865,9 +867,9 @@ export const apiTeamRptSingleRes: ApiV2Response = { limit: 1, offset: 0, url: '/v2/reports', -}; +}); -export const apiTeamReportPaginated1: ApiV2Response = { +export const apiTeamReportPaginated1: ApiV2Response = deepFreeze({ count: 25, data: [ { @@ -994,4 +996,4 @@ export const apiTeamReportPaginated1: ApiV2Response = { limit: 10, offset: 0, url: '/v2/reports', -}; +}); diff --git a/src/app/core/mock-data/app-version.data.ts b/src/app/core/mock-data/app-version.data.ts index 6af0bb2e9e..956a69fa4e 100644 --- a/src/app/core/mock-data/app-version.data.ts +++ b/src/app/core/mock-data/app-version.data.ts @@ -1,10 +1,12 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AppVersion } from '../models/app_version.model'; -export const appVersionData1: AppVersion = { +export const appVersionData1: AppVersion = deepFreeze({ app_version: '5.50.0', created_at: new Date('2023-02-23T13:59:29.526Z'), device_platform: 'ios', id: 'mockuuid123', platform_version: '5.50.0', user_id: 'usvKA4X8Ugcr', -}; +}); diff --git a/src/app/core/mock-data/approval.data.ts b/src/app/core/mock-data/approval.data.ts index 64681f81f1..2727350b52 100644 --- a/src/app/core/mock-data/approval.data.ts +++ b/src/app/core/mock-data/approval.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ApprovalPublic } from '../models/approval-public.model'; import { Approval } from '../models/approval.model'; -export const advanceReqApprovals: Approval[] = [ +export const advanceReqApprovals: Approval[] = deepFreeze([ { id: 8314, created_at: null, @@ -16,12 +18,12 @@ export const advanceReqApprovals: Approval[] = [ approver_org_id: 'orNVthTo2Zyo', comment: null, }, -]; +]); -export const advanceReqApprovalsPublic: ApprovalPublic[] = [ +export const advanceReqApprovalsPublic: ApprovalPublic[] = deepFreeze([ { state: 'APPROVAL_PENDING', approver_email: 'john.doe@example.com', approver_name: 'John Doe', }, -]; +]); diff --git a/src/app/core/mock-data/approver.data.ts b/src/app/core/mock-data/approver.data.ts index 1878de959f..5ad3449d62 100644 --- a/src/app/core/mock-data/approver.data.ts +++ b/src/app/core/mock-data/approver.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Approver } from '../models/v1/approver.model'; -export const apiApproverRes: Approver[] = [ +export const apiApproverRes: Approver[] = deepFreeze([ { id: 43776, created_at: null, @@ -33,9 +35,9 @@ export const apiApproverRes: Approver[] = [ approver_email: 'chethan.m+0@fyle.in', comment: null, }, -]; +]); -export const apiAllApproverRes1: Approver[] = [ +export const apiAllApproverRes1: Approver[] = deepFreeze([ { id: 45435, created_at: null, @@ -68,9 +70,9 @@ export const apiAllApproverRes1: Approver[] = [ approver_email: 'aiyush.dhar@fyle.in', comment: null, }, -]; +]); -export const apiAllApproverRes2: Approver[] = [ +export const apiAllApproverRes2: Approver[] = deepFreeze([ { id: 44024, created_at: null, @@ -103,9 +105,9 @@ export const apiAllApproverRes2: Approver[] = [ approver_email: 'yash.s@fyle.in', comment: null, }, -]; +]); -export const expectedApprovers: Approver[] = [ +export const expectedApprovers: Approver[] = deepFreeze([ { id: 44024, created_at: null, @@ -138,9 +140,9 @@ export const expectedApprovers: Approver[] = [ approver_email: 'yash.s@fyle.in', comment: null, }, -]; +]); -export const approversData1: Approver[] = [ +export const approversData1: Approver[] = deepFreeze([ { id: 43239, created_at: null, @@ -189,9 +191,9 @@ export const approversData1: Approver[] = [ approver_email: 'chethan.m+90@fyle.in', comment: null, }, -]; +]); -export const approversData2: Approver[] = [ +export const approversData2: Approver[] = deepFreeze([ { id: 45435, created_at: null, @@ -256,9 +258,9 @@ export const approversData2: Approver[] = [ approver_email: 'yash.s@fyle.in', comment: null, }, -]; +]); -export const approversData3: Approver[] = [ +export const approversData3: Approver[] = deepFreeze([ { id: 43239, created_at: null, @@ -307,9 +309,9 @@ export const approversData3: Approver[] = [ approver_email: 'chethan.m+90@fyle.in', comment: null, }, -]; +]); -export const approversData4: Approver[] = [ +export const approversData4: Approver[] = deepFreeze([ { id: 43239, created_at: null, @@ -342,9 +344,9 @@ export const approversData4: Approver[] = [ approver_email: '123@fye.in', comment: null, }, -]; +]); -export const approversData5: Approver[] = [ +export const approversData5: Approver[] = deepFreeze([ { id: 43239, created_at: null, @@ -377,9 +379,9 @@ export const approversData5: Approver[] = [ approver_email: '123@fye.in', comment: null, }, -]; +]); -export const approversData6: Approver[] = [ +export const approversData6: Approver[] = deepFreeze([ { id: 43239, created_at: null, @@ -412,4 +414,4 @@ export const approversData6: Approver[] = [ approver_email: '123@fye.in', comment: null, }, -]; +]); diff --git a/src/app/core/mock-data/auth-reponse.data.ts b/src/app/core/mock-data/auth-reponse.data.ts index c324dac3aa..95ec879dda 100644 --- a/src/app/core/mock-data/auth-reponse.data.ts +++ b/src/app/core/mock-data/auth-reponse.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AuthResponse } from '../models/auth-response.model'; import { SamlResponse } from '../models/saml-response.model'; -export const apiAuthRes: AuthResponse = { +export const apiAuthRes: AuthResponse = deepFreeze({ cluster_domain: 'https://staging.fyle.tech', access_token: null, signup: false, @@ -9,18 +11,18 @@ export const apiAuthRes: AuthResponse = { redirect_url: 'https://staging1.fyle.tech/app/accounts/#/verify?org_id=orDjkSfq43i2', refresh_token: 'eyJhbGciOiJIUzI1NiJ9.eyJpYXQiOjE2Nzg3NzU4MzgsImlzcyI6IkZ5bGVBcHAiLCJvcmdfdXNlcl9pZCI6Ilwib3VIaW9KWVJGMmNyXCIiLCJjbHVzdGVyX2RvbWFpbiI6IlwiaHR0cHM6Ly9zdGFnaW5nLmZ5bGUudGVjaFwiIiwiZXhwIjoxOTk0MTM1ODM4fQ.FswsVpGpAt1sKI9TZ2Jxc_CqnV1K7iijoobmioH7X0o', -}; +}); -export const apiLogoutRes: AuthResponse = { +export const apiLogoutRes: AuthResponse = deepFreeze({ access_token: 'eyJhbGciOiJIUzI1NiJ9.eyJpYXQiOjE2Nzg3NzU4MzgsImlzcyI6IkZ5bGVBcHAiLCJ1c2VyX2lkIjoidXN1UVB6YVQwdzlDIiwib3JnX3VzZXJfaWQiOiJvdUhpb0pZUkYyY3IiLCJvcmdfaWQiOiJvckRqa1NmcTQzaTIiLCJyb2xlcyI6IltcIkZZTEVSXCJdIiwic2NvcGVzIjoiW10iLCJhbGxvd2VkX0NJRFJzIjoiW10iLCJ2ZXJzaW9uIjoiMyIsImNsdXN0ZXJfZG9tYWluIjoiXCJodHRwczovL3N0YWdpbmcuZnlsZS50ZWNoXCIiLCJleHAiOjE2Nzg3Nzk0Mzh9.RLRU6te7V8WkZ7AFwmSB865NDfRHUunL-VgLA4A5R44', signup: null, org_id: null, redirect_url: null, refresh_token: null, -}; +}); -export const authResData1: AuthResponse = { +export const authResData1: AuthResponse = deepFreeze({ cluster_domain: 'https://staging.fyle.tech', access_token: null, signup: false, @@ -28,9 +30,9 @@ export const authResData1: AuthResponse = { redirect_url: 'https://staging1.fyle.tech/app/accounts/#/verify?org_id=orNVthTo2Zyo', refresh_token: 'eyJhbGciOiJIUzI1NiJ9.eyJpYXQiOjE2Nzk5MDg3ODAsImlzcyI6IkZ5bGVBcHAiLCJvcmdfdXNlcl9pZCI6Ilwib3VYOGR3c2JMQ0x2XCIiLCJjbHVzdGVyX2RvbWFpbiI6IlwiaHR0cHM6Ly9zdGFnaW5nLmZ5bGUudGVjaFwiIiwiZXhwIjoxOTk1MjY4NzgwfQ.Ok_w8nncS6ca3_mK2PctSzMD0FluIw-PtDpn1mWn8_s', -}; +}); -export const authResData2 = { +export const authResData2 = deepFreeze({ cluster_domain: 'https://staging.fyle.tech', accessToken: 'eyJhbGciOiJIUzI1NiJ9.eyJpYXQiOjE2NzgzNDk1NDksImlzcyI6IkZ5bGVBcHAiLCJ1c2VyX2lkIjoidXN2S0E0WDhVZ2NyIiwib3JnX3VzZXJfaWQiOiJvdVg4ZHdzYkxDTHYiLCJvcmdfaWQiOiJvck5WdGhUbzJaeW8iLCJyb2xlcyI6IltcIkFETUlOXCIsXCJBUFBST1ZFUlwiLFwiRllMRVJcIixcIkhPUFwiLFwiSE9EXCIsXCJPV05FUlwiXSIsInNjb3BlcyI6IltdIiwiYWxsb3dlZF9DSURScyI6IltdIiwidmVyc2lvbiI6IjMiLCJjbHVzdGVyX2RvbWFpbiI6IlwiaHR0cHM6Ly9zdGFnaW5nLmZ5bGUudGVjaFwiIiwiZXhwIjoxNjc4MzUzMTQ5fQ.sOJKf_ndYvhFplZL-KOImnvGujGEReQ7SYq_kvay88w', @@ -39,9 +41,9 @@ export const authResData2 = { redirect_url: 'https://staging1.fyle.tech/app/accounts/#/verify?org_id=orDjkSfq43i2', refresh_token: 'eyJhbGciOiJIUzI1NiJ9.eyJpYXQiOjE2Nzg3NzU4MzgsImlzcyI6IkZ5bGVBcHAiLCJvcmdfdXNlcl9pZCI6Ilwib3VIaW9KWVJGMmNyXCIiLCJjbHVzdGVyX2RvbWFpbiI6IlwiaHR0cHM6Ly9zdGFnaW5nLmZ5bGUudGVjaFwiIiwiZXhwIjoxOTk0MTM1ODM4fQ.FswsVpGpAt1sKI9TZ2Jxc_CqnV1K7iijoobmioH7X0o', -}; +}); -export const samlResData1: SamlResponse = { +export const samlResData1: SamlResponse = deepFreeze({ error: false, response_status_code: '200', cluster_domain: 'https://staging.fyle.tech', @@ -52,9 +54,9 @@ export const samlResData1: SamlResponse = { redirect_url: 'https://staging1.fyle.tech/app/accounts/#/verify?org_id=orDjkSfq43i2', refresh_token: 'eyJhbGciOiJIUzI1NiJ9.eyJpYXQiOjE2Nzg3NzU4MzgsImlzcyI6IkZ5bGVBcHAiLCJvcmdfdXNlcl9pZCI6Ilwib3VIaW9KWVJGMmNyXCIiLCJjbHVzdGVyX2RvbWFpbiI6IlwiaHR0cHM6Ly9zdGFnaW5nLmZ5bGUudGVjaFwiIiwiZXhwIjoxOTk0MTM1ODM4fQ.FswsVpGpAt1sKI9TZ2Jxc_CqnV1K7iijoobmioH7X0o', -}; +}); -export const samlResData2: SamlResponse = { +export const samlResData2: SamlResponse = deepFreeze({ error: true, response_status_code: '500', signup: null, @@ -63,4 +65,4 @@ export const samlResData2: SamlResponse = { refresh_token: null, cluster_domain: null, access_token: null, -}; +}); diff --git a/src/app/core/mock-data/auth-response.data.ts b/src/app/core/mock-data/auth-response.data.ts index c6346d82b2..bfe02dc85f 100644 --- a/src/app/core/mock-data/auth-response.data.ts +++ b/src/app/core/mock-data/auth-response.data.ts @@ -1,10 +1,12 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AuthResponse } from '../models/auth-response.model'; -export const apiAuthResponseRes: AuthResponse = { +export const apiAuthResponseRes: AuthResponse = deepFreeze({ refresh_token: null, access_token: 'eyJhbGciOiJIUzI1NiJ9.eyJpYXQiOjE2Nzg0MzIwOTcsImlzcyI6IkZ5bGVBcHAiLCJ1c2VyX2lkIjoidXN1UVB6YVQwdzlDIiwib3JnX3VzZXJfaWQiOiJvdUhpb0pZUkYyY3IiLCJvcmdfaWQiOiJvckRqa1NmcTQzaTIiLCJyb2xlcyI6IltcIkZZTEVSXCJdIiwic2NvcGVzIjoiW10iLCJhbGxvd2VkX0NJRFJzIjoiW10iLCJ2ZXJzaW9uIjoiMyIsImNsdXN0ZXJfZG9tYWluIjoiXCJodHRwczovL3N0YWdpbmcuZnlsZS50ZWNoXCIiLCJleHAiOjE2Nzg0MzU2OTd9.wECHQUgaLPJWBRzkJVaqWH_LfmymzlhdKMzYRTOZ_l8', signup: null, redirect_url: null, org_id: null, -}; +}); diff --git a/src/app/core/mock-data/bank-feed-sources.data.ts b/src/app/core/mock-data/bank-feed-sources.data.ts index 5978cf9156..607fa49022 100644 --- a/src/app/core/mock-data/bank-feed-sources.data.ts +++ b/src/app/core/mock-data/bank-feed-sources.data.ts @@ -1,9 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + import { DataFeedSource } from '../enums/data-feed-source.enum'; -export const bankFeedSourcesData: DataFeedSource[] = [ +export const bankFeedSourcesData: DataFeedSource[] = deepFreeze([ DataFeedSource.BANK_FEED_AMEX, DataFeedSource.BANK_FEED_CDF, DataFeedSource.BANK_FEED_VCF, DataFeedSource.BANK_FEED_S3DF, DataFeedSource.BANK_FEED_HAPPAY, -]; +]); diff --git a/src/app/core/mock-data/card-aggregate-stats.data.ts b/src/app/core/mock-data/card-aggregate-stats.data.ts index 3c614c7e8d..d33ef60663 100644 --- a/src/app/core/mock-data/card-aggregate-stats.data.ts +++ b/src/app/core/mock-data/card-aggregate-stats.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CardAggregateStats } from '../models/card-aggregate-stats.model'; -export const cardAggregateStatParam: CardAggregateStats[] = [ +export const cardAggregateStatParam: CardAggregateStats[] = deepFreeze([ { aggregates: [ { @@ -79,9 +81,9 @@ export const cardAggregateStatParam: CardAggregateStats[] = [ }, ], }, -]; +]); -export const cardAggregateStatParam2: CardAggregateStats[] = [ +export const cardAggregateStatParam2: CardAggregateStats[] = deepFreeze([ { aggregates: [], key: [ @@ -151,9 +153,9 @@ export const cardAggregateStatParam2: CardAggregateStats[] = [ }, ], }, -]; +]); -export const cardAggregateStatParam3: CardAggregateStats[] = [ +export const cardAggregateStatParam3: CardAggregateStats[] = deepFreeze([ { aggregates: [ { @@ -180,4 +182,4 @@ export const cardAggregateStatParam3: CardAggregateStats[] = [ }, ], }, -]; +]); diff --git a/src/app/core/mock-data/cc-transaction.data.ts b/src/app/core/mock-data/cc-transaction.data.ts index e60c4ec581..3137836f32 100644 --- a/src/app/core/mock-data/cc-transaction.data.ts +++ b/src/app/core/mock-data/cc-transaction.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { corporateCardTransaction } from '../models/platform/v1/cc-transaction.model'; import { TransactionStatus } from '../models/platform/v1/expense.model'; -export const ccTransactionData: corporateCardTransaction = { +export const ccTransactionData: corporateCardTransaction = deepFreeze({ amount: 260.37, assignor_user: null, assignor_user_id: null, @@ -104,9 +106,9 @@ export const ccTransactionData: corporateCardTransaction = { id: 'usvMoPfCC9Xw', }, user_id: 'usvMoPfCC9Xw', -}; +}); -export const ccTransactionData1: corporateCardTransaction = { +export const ccTransactionData1: corporateCardTransaction = deepFreeze({ amount: 205.21, assignor_user: null, assignor_user_id: null, @@ -193,4 +195,4 @@ export const ccTransactionData1: corporateCardTransaction = { id: 'usvMoPfCC9Xw', }, user_id: 'usvMoPfCC9Xw', -}; +}); diff --git a/src/app/core/mock-data/ccc-api-response.ts b/src/app/core/mock-data/ccc-api-response.data.ts similarity index 97% rename from src/app/core/mock-data/ccc-api-response.ts rename to src/app/core/mock-data/ccc-api-response.data.ts index 93db1aa78e..1c7c2fb734 100644 --- a/src/app/core/mock-data/ccc-api-response.ts +++ b/src/app/core/mock-data/ccc-api-response.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ApiV2Response } from '../models/v2/api-v2-response.model'; import { CorporateCardExpense } from '../models/v2/corporate-card-expense.model'; -export const apiCardV2Transactions: ApiV2Response = { +export const apiCardV2Transactions: ApiV2Response = deepFreeze({ count: 2, data: [ { @@ -97,4 +99,4 @@ export const apiCardV2Transactions: ApiV2Response = { limit: 2, offset: 0, url: '/v2/corporate_card_transactions', -}; +}); diff --git a/src/app/core/mock-data/ccc-expense.details.data.ts b/src/app/core/mock-data/ccc-expense.details.data.ts index 7533767259..254e720f0a 100644 --- a/src/app/core/mock-data/ccc-expense.details.data.ts +++ b/src/app/core/mock-data/ccc-expense.details.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CCCDetails } from '../models/ccc-expense-details.model'; -export const expectedAssignedCCCStats: CCCDetails = { +export const expectedAssignedCCCStats: CCCDetails = deepFreeze({ totalTxns: 1090, totalAmount: 589553.832, cardDetails: [ @@ -57,9 +59,9 @@ export const expectedAssignedCCCStats: CCCDetails = { ], }, ], -}; +}); -export const mastercardCCCStats: CCCDetails = { +export const mastercardCCCStats: CCCDetails = deepFreeze({ totalTxns: 12, totalAmount: 1874.4, cardDetails: [ @@ -116,10 +118,10 @@ export const mastercardCCCStats: CCCDetails = { ], }, ], -}; +}); -export const emptyCCCStats: CCCDetails = { +export const emptyCCCStats: CCCDetails = deepFreeze({ totalTxns: 0, totalAmount: 0, cardDetails: [], -}; +}); diff --git a/src/app/core/mock-data/combined-options.data.ts b/src/app/core/mock-data/combined-options.data.ts index 4750041169..7ecdbaab5f 100644 --- a/src/app/core/mock-data/combined-options.data.ts +++ b/src/app/core/mock-data/combined-options.data.ts @@ -1,3 +1,5 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CombinedOptions } from '../models/combined-options.model'; import { optionsData10, @@ -22,7 +24,7 @@ import { optionsData9, } from './merge-expenses-options-data.data'; -export const combinedOptionsData1 = { +export const combinedOptionsData1 = deepFreeze({ amountOptionsData: optionsData3, dateOfSpendOptionsData: optionsData6, paymentModeOptionsData: optionsData7, @@ -34,15 +36,15 @@ export const combinedOptionsData1 = { taxAmountOptionsData: optionsData12, constCenterOptionsData: optionsData13, purposeOptionsData: optionsData14, -}; +}); -export const combinedOptionsData2: CombinedOptions = { +export const combinedOptionsData2: CombinedOptions = deepFreeze({ userlist: optionsData3, test: optionsData6, category2: optionsData31, -}; +}); -export const combinedOptionsData3 = { +export const combinedOptionsData3 = deepFreeze({ location1OptionsData: optionsData15, location2OptionsData: optionsData33, onwardDateOptionsData: optionsData16, @@ -53,4 +55,4 @@ export const combinedOptionsData3 = { busTravelClassOptionsData: optionsData19, distanceOptionsData: optionsData20, distanceUnitOptionsData: optionsData21, -}; +}); diff --git a/src/app/core/mock-data/commute-deduction-options.data.ts b/src/app/core/mock-data/commute-deduction-options.data.ts index caa8113bc1..dc8229f404 100644 --- a/src/app/core/mock-data/commute-deduction-options.data.ts +++ b/src/app/core/mock-data/commute-deduction-options.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CommuteDeductionOptions } from '../models/commute-deduction-options.model'; -export const commuteDeductionOptionsData1: CommuteDeductionOptions[] = [ +export const commuteDeductionOptionsData1: CommuteDeductionOptions[] = deepFreeze([ { label: 'One Way Distance', value: 'ONE_WAY', @@ -16,4 +18,4 @@ export const commuteDeductionOptionsData1: CommuteDeductionOptions[] = [ value: 'NO_DEDUCTION', distance: 0, }, -]; +]); diff --git a/src/app/core/mock-data/commute-details-response.data.ts b/src/app/core/mock-data/commute-details-response.data.ts index 7be7e6d579..4331a3ca6f 100644 --- a/src/app/core/mock-data/commute-details-response.data.ts +++ b/src/app/core/mock-data/commute-details-response.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CommuteDetailsResponse } from '../models/platform/commute-details-response.model'; import { PlatformApiResponse } from '../models/platform/platform-api-response.model'; -export const commuteDetailsResponseData: PlatformApiResponse = { +export const commuteDetailsResponseData: PlatformApiResponse = deepFreeze({ count: 1, offset: 0, data: [ @@ -31,15 +33,15 @@ export const commuteDetailsResponseData: PlatformApiResponse = { +export const commuteDetailsResponseData2: PlatformApiResponse = deepFreeze({ count: 1, offset: 0, data: [], -}; +}); -export const commuteDetailsResponseData3: PlatformApiResponse = { +export const commuteDetailsResponseData3: PlatformApiResponse = deepFreeze({ count: 1, offset: 0, data: [ @@ -55,4 +57,4 @@ export const commuteDetailsResponseData3: PlatformApiResponse = { +export const corporateCardExpenseData: ApiV2Response = deepFreeze({ count: 0, data: [], limit: 0, offset: 0, url: '/v2/corporate_card_transactions', -}; +}); diff --git a/src/app/core/mock-data/corporate-card-trackers.data.ts b/src/app/core/mock-data/corporate-card-trackers.data.ts index 630a1053fd..ef2869c592 100644 --- a/src/app/core/mock-data/corporate-card-trackers.data.ts +++ b/src/app/core/mock-data/corporate-card-trackers.data.ts @@ -1,3 +1,5 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CardNetworkType } from '../enums/card-network-type'; import { CardEnrolledProperties, @@ -6,47 +8,47 @@ import { EnrollingNonRTFCardProperties, } from '../models/tracking-properties.model'; -export const cardEnrolledProperties1: CardEnrolledProperties = { +export const cardEnrolledProperties1: CardEnrolledProperties = deepFreeze({ Source: '/enterprise/manage_corporate_cards', 'Card Network': CardNetworkType.VISA, 'Card ID': 'bacc15bbrRGWzf', -}; +}); -export const cardEnrolledProperties2: CardEnrolledProperties = { +export const cardEnrolledProperties2: CardEnrolledProperties = deepFreeze({ Source: '/enterprise/manage_corporate_cards', 'Card Network': CardNetworkType.VISA, 'Card ID': 'bacc15bbrRGWzf', -}; +}); -export const cardUnenrolledProperties: CardUnenrolledProperties = { +export const cardUnenrolledProperties: CardUnenrolledProperties = deepFreeze({ 'Card Network': CardNetworkType.VISA, 'Card ID': 'bacc15bbrRGWzf', -}; +}); -export const cardEnrollmentErrorsProperties1: CardEnrollmentErrorsProperties = { +export const cardEnrollmentErrorsProperties1: CardEnrollmentErrorsProperties = deepFreeze({ 'Card Network': CardNetworkType.VISA, Source: '/enterprise/manage_corporate_cards', 'Error Message': 'This card already exists in the system', -}; +}); -export const cardEnrollmentErrorsProperties2: CardEnrollmentErrorsProperties = { +export const cardEnrollmentErrorsProperties2: CardEnrollmentErrorsProperties = deepFreeze({ 'Card Network': CardNetworkType.VISA, Source: '/enterprise/manage_corporate_cards', 'Error Message': 'Something went wrong. Please try after some time.', -}; +}); -export const cardEnrollmentErrorsProperties3: CardEnrollmentErrorsProperties = { +export const cardEnrollmentErrorsProperties3: CardEnrollmentErrorsProperties = deepFreeze({ 'Card Network': CardNetworkType.VISA, Source: '/enterprise/manage_corporate_cards', 'Error Message': 'Invalid card number', -}; +}); -export const cardEnrollmentErrorsProperties4: CardEnrollmentErrorsProperties = { +export const cardEnrollmentErrorsProperties4: CardEnrollmentErrorsProperties = deepFreeze({ 'Card Network': CardNetworkType.VISA, Source: '/enterprise/manage_corporate_cards', 'Error Message': 'Invalid card network', -}; +}); -export const enrollingNonRTFCardProperties: EnrollingNonRTFCardProperties = { +export const enrollingNonRTFCardProperties: EnrollingNonRTFCardProperties = deepFreeze({ Source: '/enterprise/manage_corporate_cards', -}; +}); diff --git a/src/app/core/mock-data/corporate-card-transaction-response.data.ts b/src/app/core/mock-data/corporate-card-transaction-response.data.ts index feda52ce1a..d1de2c43da 100644 --- a/src/app/core/mock-data/corporate-card-transaction-response.data.ts +++ b/src/app/core/mock-data/corporate-card-transaction-response.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CorporateCardTransactionRes } from '../models/platform/v1/corporate-card-transaction-res.model'; import { TransactionStatus } from '../models/platform/v1/expense.model'; -export const ccTransactionResponseData: CorporateCardTransactionRes = { +export const ccTransactionResponseData: CorporateCardTransactionRes = deepFreeze({ data: [ { amount: 205.21, @@ -92,18 +94,18 @@ export const ccTransactionResponseData: CorporateCardTransactionRes = { user_id: 'usvMoPfCC9Xw', }, ], -}; +}); -export const ccTransactionResponseData1: CorporateCardTransactionRes = { +export const ccTransactionResponseData1: CorporateCardTransactionRes = deepFreeze({ data: [ { ...ccTransactionResponseData.data[0], id: 'btxnSte7sVQCM8', }, ], -}; +}); -export const unmatchCCCExpenseResponseData: CorporateCardTransactionRes = { +export const unmatchCCCExpenseResponseData: CorporateCardTransactionRes = deepFreeze({ data: [ { amount: 260.37, @@ -210,9 +212,9 @@ export const unmatchCCCExpenseResponseData: CorporateCardTransactionRes = { user_id: 'usvMoPfCC9Xw', }, ], -}; +}); -export const matchCCCExpenseResponseData: CorporateCardTransactionRes = { +export const matchCCCExpenseResponseData: CorporateCardTransactionRes = deepFreeze({ data: [ { amount: 260.37, @@ -266,4 +268,4 @@ export const matchCCCExpenseResponseData: CorporateCardTransactionRes = { user_id: 'usvMoPfCC9Xw', }, ], -}; +}); diff --git a/src/app/core/mock-data/cost-center-dependent-fields-mapping.data.ts b/src/app/core/mock-data/cost-center-dependent-fields-mapping.data.ts index 4cb721aab4..38fe886fb5 100644 --- a/src/app/core/mock-data/cost-center-dependent-fields-mapping.data.ts +++ b/src/app/core/mock-data/cost-center-dependent-fields-mapping.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CostCenterDependentFieldsMapping } from '../models/cost-center-dependent-fields-mapping.model'; import { dependentCustomProperties } from './custom-property.data'; -export const CostCenterDependentFieldsMappingData1: CostCenterDependentFieldsMapping = { +export const CostCenterDependentFieldsMappingData1: CostCenterDependentFieldsMapping = deepFreeze({ 13795: dependentCustomProperties, 13796: dependentCustomProperties, -}; +}); diff --git a/src/app/core/mock-data/cost-centers.data.ts b/src/app/core/mock-data/cost-centers.data.ts index 28ea8503f5..350e7ea008 100644 --- a/src/app/core/mock-data/cost-centers.data.ts +++ b/src/app/core/mock-data/cost-centers.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CostCenterOptions } from '../models/cost-centers-options.model'; import { CostCenter, CostCenters } from '../models/v1/cost-center.model'; -export const costCentersData: CostCenter[] = [ +export const costCentersData: CostCenter[] = deepFreeze([ { active: true, code: null, @@ -42,9 +44,9 @@ export const costCentersData: CostCenter[] = [ org_id: 'orNVthTo2Zyo', updated_at: new Date('2022-05-19T11:58:29.364759+00:00'), }, -]; +]); -export const costCentersData2: CostCenter[] = [ +export const costCentersData2: CostCenter[] = deepFreeze([ { active: true, code: 'code3', @@ -85,9 +87,9 @@ export const costCentersData2: CostCenter[] = [ org_id: 'orNVthTo2Zyo', updated_at: new Date('2022-09-09T10:30:25.552998+00:00'), }, -]; +]); -export const costCentersData3: CostCenter[] = [ +export const costCentersData3: CostCenter[] = deepFreeze([ { active: true, code: null, @@ -128,9 +130,9 @@ export const costCentersData3: CostCenter[] = [ org_id: 'orNVthTo2Zyo', updated_at: new Date('2022-09-09T10:30:25.552998+00:00'), }, -]; +]); -export const costCenterApiRes1: CostCenter[] = [ +export const costCenterApiRes1: CostCenter[] = deepFreeze([ { active: true, code: null, @@ -151,9 +153,9 @@ export const costCenterApiRes1: CostCenter[] = [ org_id: 'orNVthTo2Zyo', updated_at: new Date('2019-08-13T14:18:55.500829+00:00'), }, -]; +]); -export const costCenterApiRes2: CostCenter[] = [ +export const costCenterApiRes2: CostCenter[] = deepFreeze([ { active: true, code: null, @@ -174,9 +176,9 @@ export const costCenterApiRes2: CostCenter[] = [ org_id: 'orNVthTo2Zyo', updated_at: new Date('2022-05-19T11:58:29.364759+00:00'), }, -]; +]); -export const expectedCCdata: CostCenters[] = [ +export const expectedCCdata: CostCenters[] = deepFreeze([ { label: 'SMS1', value: { @@ -203,9 +205,9 @@ export const expectedCCdata: CostCenters[] = [ updated_at: new Date('2019-08-13T14:18:55.500Z'), }, }, -]; +]); -export const expectedCCdata2: CostCenters[] = [ +export const expectedCCdata2: CostCenters[] = deepFreeze([ { label: 'SMS1', value: { @@ -219,9 +221,9 @@ export const expectedCCdata2: CostCenters[] = [ updated_at: new Date('2019-06-24T15:12:05.002Z'), }, }, -]; +]); -export const expectedCCdata3: CostCenters[] = [ +export const expectedCCdata3: CostCenters[] = deepFreeze([ { label: 'SMS1', value: { @@ -274,16 +276,16 @@ export const expectedCCdata3: CostCenters[] = [ updated_at: new Date('2022-05-19T11:58:29.364759+00:00'), }, }, -]; +]); -export const costCentersOptions: CostCenterOptions[] = [ +export const costCentersOptions: CostCenterOptions[] = deepFreeze([ { label: 'cc 1', value: costCentersData[0], }, -]; +]); -export const costCenterOptions2: CostCenterOptions[] = [ +export const costCenterOptions2: CostCenterOptions[] = deepFreeze([ { label: 'SMS1', value: { @@ -336,4 +338,4 @@ export const costCenterOptions2: CostCenterOptions[] = [ updated_at: new Date('2022-05-19T11:58:29.364Z'), }, }, -]; +]); diff --git a/src/app/core/mock-data/critical-policy-violation-popover.data.ts b/src/app/core/mock-data/critical-policy-violation-popover.data.ts index c3fc906e42..b8f04b481e 100644 --- a/src/app/core/mock-data/critical-policy-violation-popover.data.ts +++ b/src/app/core/mock-data/critical-policy-violation-popover.data.ts @@ -1,4 +1,6 @@ -export const expectedCriticalPolicyViolationPopoverParams = { +import deepFreeze from 'deep-freeze-strict'; + +export const expectedCriticalPolicyViolationPopoverParams = deepFreeze({ title: '1 Critical Policy and \ 1 Draft Expenses blocking the way', @@ -6,17 +8,17 @@ export const expectedCriticalPolicyViolationPopoverParams = { $10 from being submitted. \ Also 1 other expenses are in draft states.`, reportType: 'newReport', -}; +}); -export const expectedCriticalPolicyViolationPopoverParams2 = { +export const expectedCriticalPolicyViolationPopoverParams2 = deepFreeze({ title: '1 Critical Policy Expenses blocking the way', message: `Critical policy blocking these 1 expenses worth \ $10 from being submitted.`, reportType: 'newReport', -}; +}); -export const expectedCriticalPolicyViolationPopoverParams3 = { +export const expectedCriticalPolicyViolationPopoverParams3 = deepFreeze({ title: '1 Draft Expenses blocking the way', message: '1 expenses are in draft states.', reportType: 'newReport', -}; +}); diff --git a/src/app/core/mock-data/crtical-policy-violations.data.ts b/src/app/core/mock-data/crtical-policy-violations.data.ts index 373dea6f28..8645246f0d 100644 --- a/src/app/core/mock-data/crtical-policy-violations.data.ts +++ b/src/app/core/mock-data/crtical-policy-violations.data.ts @@ -1,8 +1,10 @@ -export const criticalPolicyViolation1: string[] = [ +import deepFreeze from 'deep-freeze-strict'; + +export const criticalPolicyViolation1: string[] = deepFreeze([ 'The expense will be flagged, employee will be alerted, expense will be made unreportable and expense amount will be capped to the amount limit when expense amount in category 1 / chumma returns/1 / sd/1 / sub 123/aniruddha test / aniruddha sub/Food/Food / Travelling - Inland/Snacks/Stuff/te knklw/TEst Cateogory / 12 exceeds: INR 1000 and are fyled from Paid by Employee payment mode(s). ', -]; +]); -export const criticalPolicyViolation2: string[] = [ +export const criticalPolicyViolation2: string[] = deepFreeze([ 'The expense will be flagged, employee will be alerted, expense will be made unreportable and expense amount will be capped to the amount limit when expense amount in category 1 / chumma returns/1 / sd/1 / sub 123/aniruddha test / aniruddha sub/Food/Food / Travelling - Inland/Snacks/Stuff/te knklw/TEst Cateogory / 12 exceeds: INR 1000 and are fyled from Paid by Employee payment mode(s). ', 'Receipt needed for expenses above INR 123', -]; +]); diff --git a/src/app/core/mock-data/currency-ip.data.ts b/src/app/core/mock-data/currency-ip.data.ts index b61273444f..5ff2fca6d8 100644 --- a/src/app/core/mock-data/currency-ip.data.ts +++ b/src/app/core/mock-data/currency-ip.data.ts @@ -1,11 +1,13 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CurrencyIp } from '../models/currency-ip.model'; -export const currencyIpData: CurrencyIp = { +export const currencyIpData: CurrencyIp = deepFreeze({ ip: '49.37.243.217', currency: 'USD', -}; +}); -export const currencyIpData2: CurrencyIp = { +export const currencyIpData2: CurrencyIp = deepFreeze({ ip: '49.37.243.217', currency: null, -}; +}); diff --git a/src/app/core/mock-data/currency-obj.data.ts b/src/app/core/mock-data/currency-obj.data.ts index a9ce899dc5..32db43f486 100644 --- a/src/app/core/mock-data/currency-obj.data.ts +++ b/src/app/core/mock-data/currency-obj.data.ts @@ -1,43 +1,45 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CurrencyObj } from '../models/currency-obj.model'; -export const currencyObjData1: CurrencyObj = { +export const currencyObjData1: CurrencyObj = deepFreeze({ amount: 23, currency: 'USD', orig_amount: 23, orig_currency: 'USD', -}; +}); -export const currencyObjData2: CurrencyObj = { +export const currencyObjData2: CurrencyObj = deepFreeze({ amount: 2000, currency: 'INR', orig_amount: 2000, orig_currency: 'INR', -}; +}); -export const currencyObjData3: CurrencyObj = { +export const currencyObjData3: CurrencyObj = deepFreeze({ amount: 0.00001, currency: 'INR', orig_amount: 0.00001, orig_currency: 'INR', -}; +}); -export const currencyObjData4: CurrencyObj = { +export const currencyObjData4: CurrencyObj = deepFreeze({ orig_currency: 'USD', orig_amount: 800000, currency: 'USD', amount: 800000, -}; +}); -export const currencyObjData5: CurrencyObj = { +export const currencyObjData5: CurrencyObj = deepFreeze({ currency: 'USD', amount: 90, orig_currency: null, orig_amount: null, -}; +}); -export const currencyObjData6: CurrencyObj = { +export const currencyObjData6: CurrencyObj = deepFreeze({ currency: 'USD', amount: 10800, orig_currency: 'INR', orig_amount: 900, -}; +}); diff --git a/src/app/core/mock-data/currency-summary.data.ts b/src/app/core/mock-data/currency-summary.data.ts index f2dfe364eb..c5a5c6a88a 100644 --- a/src/app/core/mock-data/currency-summary.data.ts +++ b/src/app/core/mock-data/currency-summary.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CurrencySummary } from '../models/currency-summary.model'; -export const currencySummaryData: CurrencySummary[] = [ +export const currencySummaryData: CurrencySummary[] = deepFreeze([ { name: 'CLF', currency: 'CLF', @@ -22,4 +24,4 @@ export const currencySummaryData: CurrencySummary[] = [ origAmount: 89, count: 1, }, -]; +]); diff --git a/src/app/core/mock-data/currency.data.ts b/src/app/core/mock-data/currency.data.ts index 6f30996421..c37f0f6d6b 100644 --- a/src/app/core/mock-data/currency.data.ts +++ b/src/app/core/mock-data/currency.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Currency, CurrencyName } from '../models/currency.model'; -export const apiAllCurrencies: CurrencyName = { +export const apiAllCurrencies: CurrencyName = deepFreeze({ AED: 'United Arab Emirates Dirham', AFN: 'Afghan Afghani', ALL: 'Albanian Lek', @@ -171,9 +173,9 @@ export const apiAllCurrencies: CurrencyName = { ZMK: 'Zambian Kwacha (pre-2013)', ZMW: 'Zambian Kwacha', ZWL: 'Zimbabwean Dollar', -}; +}); -export const apiAllCurrencies2: CurrencyName = { +export const apiAllCurrencies2: CurrencyName = deepFreeze({ AED: 'United Arab Emirates Dirham', AFN: 'Afghan Afghani', ALL: 'Albanian Lek', @@ -199,9 +201,9 @@ export const apiAllCurrencies2: CurrencyName = { BTN: 'Bhutanese Ngultrum', BWP: 'Botswanan Pula', BYN: null, -}; +}); -export const selectedCurrencies: Currency[] = [ +export const selectedCurrencies: Currency[] = deepFreeze([ { shortCode: 'USD', longName: 'US Dollar', @@ -214,14 +216,14 @@ export const selectedCurrencies: Currency[] = [ shortCode: 'JPY', longName: 'JPY', }, -]; +]); -export const selectedCurrencyNames: CurrencyName = { +export const selectedCurrencyNames: CurrencyName = deepFreeze({ INR: 'Indian Rupee', USD: 'US Dollar', -}; +}); -export const selectedCurrencies2: Currency[] = [ +export const selectedCurrencies2: Currency[] = deepFreeze([ { shortCode: 'INR', longName: 'Indian Rupee', @@ -230,4 +232,4 @@ export const selectedCurrencies2: Currency[] = [ shortCode: 'USD', longName: 'US Dollar', }, -]; +]); diff --git a/src/app/core/mock-data/custom-field.data.ts b/src/app/core/mock-data/custom-field.data.ts index cfc63681e5..36c2254a12 100644 --- a/src/app/core/mock-data/custom-field.data.ts +++ b/src/app/core/mock-data/custom-field.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CustomField } from '../models/custom_field.model'; -export const customFields: CustomField[] = [ +export const customFields: CustomField[] = deepFreeze([ { id: 111, name: 'Test Number', @@ -13,18 +15,18 @@ export const customFields: CustomField[] = [ value: false, type: 'BOOLEAN', }, -]; +]); -export const customField2 = [ +export const customField2 = deepFreeze([ { id: 115, name: 'test date', value: '2023-02-23T16:24:01.335Z', type: 'DATE', }, -]; +]); -export const customFieldData1: CustomField[] = [ +export const customFieldData1: CustomField[] = deepFreeze([ { id: 111, name: 'Test Number', @@ -43,9 +45,9 @@ export const customFieldData1: CustomField[] = [ value: false, type: 'BOOLEAN', }, -]; +]); -export const customFieldData2: CustomField[] = [ +export const customFieldData2: CustomField[] = deepFreeze([ { id: 111, name: 'Test Number', @@ -70,9 +72,9 @@ export const customFieldData2: CustomField[] = [ value: 'select-1', type: 'SELECT', }, -]; +]); -export const expectedCustomField = [ +export const expectedCustomField = deepFreeze([ { id: 111, name: 'Test Number', @@ -91,9 +93,9 @@ export const expectedCustomField = [ value: false, type: 'BOOLEAN', }, -]; +]); -export const expectedCustomFieldsWoDate = [ +export const expectedCustomFieldsWoDate = deepFreeze([ { id: 111, name: 'Test Number', @@ -106,18 +108,18 @@ export const expectedCustomFieldsWoDate = [ value: false, type: 'BOOLEAN', }, -]; +]); -export const expectedCustomFieldsWithDate = [ +export const expectedCustomFieldsWithDate = deepFreeze([ { id: 115, name: 'test date', value: new Date('2023-02-23T16:24:01.335Z'), type: 'DATE', }, -]; +]); -export const expectedCustomInputFields: CustomField[] = [ +export const expectedCustomInputFields: CustomField[] = deepFreeze([ { name: 'userlist', value: 'txKJAJ1flx7n', @@ -150,4 +152,4 @@ export const expectedCustomInputFields: CustomField[] = [ name: 'select all 2', value: null, }, -]; +]); diff --git a/src/app/core/mock-data/custom-input.data.ts b/src/app/core/mock-data/custom-input.data.ts index 5c76e43cff..2428716dcd 100644 --- a/src/app/core/mock-data/custom-input.data.ts +++ b/src/app/core/mock-data/custom-input.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CustomInput } from '../models/custom-input.model'; import { TxnCustomProperties } from '../models/txn-custom-properties.model'; -export const customInputData1: Partial[] = [ +export const customInputData1: Partial[] = deepFreeze([ { id: 218266, options: [], @@ -54,9 +56,9 @@ export const customInputData1: Partial[] = [ name: 'Cost Area', value: null, }, -]; +]); -export const customInputData2: TxnCustomProperties[] = [ +export const customInputData2: TxnCustomProperties[] = deepFreeze([ { id: 218266, options: [], @@ -105,9 +107,9 @@ export const customInputData2: TxnCustomProperties[] = [ name: 'Cost Code', value: 'Wow this Works', }, -]; +]); -export const customInputsData3: Partial[] = [ +export const customInputsData3: Partial[] = deepFreeze([ { id: 211326, options: [], @@ -136,9 +138,9 @@ export const customInputsData3: Partial[] = [ name: 'Cost Code', value: 'Wow this Works', }, -]; +]); -export const customInputsData4: Partial[] = [ +export const customInputsData4: Partial[] = deepFreeze([ { id: 200227, name: 'userlist', @@ -192,9 +194,9 @@ export const customInputsData4: Partial[] = [ ], value: '2023-02-13T17:00:00.000Z', }, -]; +]); -export const expectedCustomInputs: Partial[] = [ +export const expectedCustomInputs: Partial[] = deepFreeze([ { id: 211326, options: [], @@ -223,4 +225,4 @@ export const expectedCustomInputs: Partial[] = [ name: 'Cost Code', value: 'Wow this Works', }, -]; +]); diff --git a/src/app/core/mock-data/custom-inputs-field.data.ts b/src/app/core/mock-data/custom-inputs-field.data.ts index a866af82d1..1e8e847332 100644 --- a/src/app/core/mock-data/custom-inputs-field.data.ts +++ b/src/app/core/mock-data/custom-inputs-field.data.ts @@ -1,8 +1,10 @@ +import deepFreeze from 'deep-freeze-strict'; + import { FormBuilder } from '@angular/forms'; import { CustomInputsField } from '../models/custom-inputs-field.model'; const formBuilder = new FormBuilder(); -export const customInputsFieldData1: CustomInputsField[] = [ +export const customInputsFieldData1: CustomInputsField[] = deepFreeze([ { control: formBuilder.group({ name: 'Merchant', @@ -17,7 +19,7 @@ export const customInputsFieldData1: CustomInputsField[] = [ type: 'text', value: 'Jio', }, -]; +]); // eslint-disable-next-line @typescript-eslint/no-unused-vars export const expectedCustomInputsFieldWithoutControl = customInputsFieldData1.map(({ control, ...otherProps }) => ({ diff --git a/src/app/core/mock-data/custom-property.data.ts b/src/app/core/mock-data/custom-property.data.ts index 8798c6596a..ff4a8b92ec 100644 --- a/src/app/core/mock-data/custom-property.data.ts +++ b/src/app/core/mock-data/custom-property.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CustomProperty } from '../models/custom-properties.model'; -export const customPropertiesData: CustomProperty[] = [ +export const customPropertiesData: CustomProperty[] = deepFreeze([ { name: 'userlist', value: [], @@ -33,9 +35,9 @@ export const customPropertiesData: CustomProperty[] = [ name: 'select all 2', value: '2023-02-05T09:48:18.482566+00:00', }, -]; +]); -export const dependentCustomProperties: CustomProperty[] = [ +export const dependentCustomProperties: CustomProperty[] = deepFreeze([ { name: 'CUSTOM FIELD', value: '', @@ -52,12 +54,12 @@ export const dependentCustomProperties: CustomProperty[] = [ name: 'Taj Mahaj Construction', value: null, }, -]; +]); -export const dependentCustomProperties2: CustomProperty[] = [ +export const dependentCustomProperties2: CustomProperty[] = deepFreeze([ ...dependentCustomProperties, { name: 'date property', value: new Date(), }, -]; +]); diff --git a/src/app/core/mock-data/dashboard-task.data.ts b/src/app/core/mock-data/dashboard-task.data.ts index f22258f9f3..17c1384141 100644 --- a/src/app/core/mock-data/dashboard-task.data.ts +++ b/src/app/core/mock-data/dashboard-task.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { DashboardTask } from '../models/dashboard-task.model'; import { TaskIcon } from '../models/task-icon.enum'; -export const dashboardTasksData: DashboardTask[] = [ +export const dashboardTasksData: DashboardTask[] = deepFreeze([ { icon: TaskIcon.WARNING, header: '77 Potential Duplicates', @@ -34,4 +36,4 @@ export const dashboardTasksData: DashboardTask[] = [ count: 11, ctas: [{ content: 'Show Reports', event: 5 }], }, -]; +]); diff --git a/src/app/core/mock-data/data-transform.data.ts b/src/app/core/mock-data/data-transform.data.ts index 049bd8053f..12757c0e5d 100644 --- a/src/app/core/mock-data/data-transform.data.ts +++ b/src/app/core/mock-data/data-transform.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { FlattenedAccount } from '../models/flattened-account.model'; -export const dataErtpTransformed = { +export const dataErtpTransformed = deepFreeze({ '': { search_document: "'46040':4 'a':8,14,20,26 'abhishek':32 'ajain@fyle.in':34 'business':11,17,23,29 'c/2022/10/r/37':5 'director':6 'indeed':13,19,25,31 'inr':3 'jain':33 'long':10,16,22,28 'mumbai':7 'report':2 'testing':1 'unit':12,18,24,30 'very':9,15,21,27", @@ -64,9 +66,9 @@ export const dataErtpTransformed = { email: 'ajain@fyle.in', full_name: 'Abhishek Jain', }, -}; +}); -export const apiErptReporDataParam = { +export const apiErptReporDataParam = deepFreeze({ '': { search_document: "'46040':4 'a':8,14,20,26 'abhishek':32 'ajain@fyle.in':34 'business':11,17,23,29 'c/2022/10/r/37':5 'director':6 'indeed':13,19,25,31 'inr':3 'jain':33 'long':10,16,22,28 'mumbai':7 'report':2 'testing':1 'unit':12,18,24,30 'very':9,15,21,27", @@ -130,9 +132,9 @@ export const apiErptReporDataParam = { email: 'ajain@fyle.in', full_name: 'Abhishek Jain', }, -}; +}); -export const flattenedData: FlattenedAccount = { +export const flattenedData: FlattenedAccount = deepFreeze({ acc_id: 'acct0vTdfNQrT', acc_created_at: '2019-09-19T10:19:37.764Z', acc_updated_at: '2023-03-10T11:29:40.049Z', @@ -156,9 +158,9 @@ export const flattenedData: FlattenedAccount = { orig_amount: 2500, amount: 2500, advance_id: 'aDvId123', -}; +}); -export const unflattenedData = { +export const unflattenedData = deepFreeze({ acc: { id: 'acct0vTdfNQrT', created_at: '2019-09-19T10:19:37.764Z', @@ -196,4 +198,4 @@ export const unflattenedData = { }, currency: 'INR', amount: 2500, -}; +}); diff --git a/src/app/core/mock-data/default-txn-field-values.data.ts b/src/app/core/mock-data/default-txn-field-values.data.ts index 05db2e2c77..6fa248827c 100644 --- a/src/app/core/mock-data/default-txn-field-values.data.ts +++ b/src/app/core/mock-data/default-txn-field-values.data.ts @@ -1,36 +1,38 @@ +import deepFreeze from 'deep-freeze-strict'; + import { DefaultTxnFieldValues } from '../models/v1/default-txn-field-values.model'; -export const defaultTxnFieldValuesData: Partial = { +export const defaultTxnFieldValuesData: Partial = deepFreeze({ purpose: 'test_term', tax_group_id: 'GST', -}; +}); -export const defaultTxnFieldValuesData2_1: Partial = { +export const defaultTxnFieldValuesData2_1: Partial = deepFreeze({ purpose: 'test_term', tax_group_id: 'GST', flight_journey_travel_class: { options: ['BUSINESS'], }, -}; +}); -export const defaultTxnFieldValuesData3: Partial = { +export const defaultTxnFieldValuesData3: Partial = deepFreeze({ purpose: 'test_term', tax_group_id: 'GST', vendor_id: 'vendor', billable: true, -}; +}); -export const defaultTxnFieldValuesData2: Partial = { +export const defaultTxnFieldValuesData2: Partial = deepFreeze({ purpose: 'test_term', cost_center_id: 15818, from_dt: '2023-01-01', to_dt: '2023-02-02', num_days: 32, billable: true, -}; +}); -export const defaultTxnFieldValuesData4: Partial = { +export const defaultTxnFieldValuesData4: Partial = deepFreeze({ purpose: 'test_term', cost_center_id: 15818, billable: true, -}; +}); diff --git a/src/app/core/mock-data/dependent-field-expenses.data.ts b/src/app/core/mock-data/dependent-field-expenses.data.ts index 816842979d..67509582b9 100644 --- a/src/app/core/mock-data/dependent-field-expenses.data.ts +++ b/src/app/core/mock-data/dependent-field-expenses.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Expense } from '../models/expense.model'; -export const expensesWithDependentFields: Expense[] = [ +export const expensesWithDependentFields: Expense[] = deepFreeze([ { corporate_credit_card_account_number: null, credit: false, @@ -445,9 +447,9 @@ export const expensesWithDependentFields: Expense[] = [ isCriticalPolicyViolated: false, vendorDetails: '213', }, -]; +]); -export const expensesWithSameProject: Expense[] = [ +export const expensesWithSameProject: Expense[] = deepFreeze([ { corporate_credit_card_account_number: null, credit: false, @@ -871,4 +873,4 @@ export const expensesWithSameProject: Expense[] = [ isCriticalPolicyViolated: false, vendorDetails: '213', }, -]; +]); diff --git a/src/app/core/mock-data/dependent-field-mapping.data.ts b/src/app/core/mock-data/dependent-field-mapping.data.ts index 4758c58e59..1af1e5f958 100644 --- a/src/app/core/mock-data/dependent-field-mapping.data.ts +++ b/src/app/core/mock-data/dependent-field-mapping.data.ts @@ -1,10 +1,12 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CustomProperty } from '../models/custom-properties.model'; interface dependentFieldMapping { [fieldId: number]: CustomProperty[]; } -export const dependentFieldsMappingForProject: dependentFieldMapping = { +export const dependentFieldsMappingForProject: dependentFieldMapping = deepFreeze({ 316908: [ { name: 'CF1', @@ -33,9 +35,9 @@ export const dependentFieldsMappingForProject: dependentFieldMapping = { value: null, }, ], -}; +}); -export const dependentFieldsMappingForSameProject: dependentFieldMapping = { +export const dependentFieldsMappingForSameProject: dependentFieldMapping = deepFreeze({ 316992: [ { name: 'CF1', @@ -50,13 +52,13 @@ export const dependentFieldsMappingForSameProject: dependentFieldMapping = { value: 'CF3.3', }, ], -}; +}); -export const dependentFieldsMappingForNoDependentFields: dependentFieldMapping = { +export const dependentFieldsMappingForNoDependentFields: dependentFieldMapping = deepFreeze({ 316992: [], -}; +}); -export const dependentFieldsMappingForCostCenter: dependentFieldMapping = { +export const dependentFieldsMappingForCostCenter: dependentFieldMapping = deepFreeze({ 16743: [ { name: 'Dependent Field Of Cost Center', @@ -69,4 +71,4 @@ export const dependentFieldsMappingForCostCenter: dependentFieldMapping = { value: 'Dep. Value 3', }, ], -}; +}); diff --git a/src/app/core/mock-data/dependent-field-option.data.ts b/src/app/core/mock-data/dependent-field-option.data.ts index be78746b13..5dc64c7138 100644 --- a/src/app/core/mock-data/dependent-field-option.data.ts +++ b/src/app/core/mock-data/dependent-field-option.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { DependentFieldOption } from '../models/dependent-field-option.model'; -export const dependentFieldOptions: DependentFieldOption[] = [ +export const dependentFieldOptions: DependentFieldOption[] = deepFreeze([ { label: 'Other Dep. Value 1', value: 'Other Dep. Value 1', @@ -16,9 +18,9 @@ export const dependentFieldOptions: DependentFieldOption[] = [ value: 'Other Dep. Value 3', selected: false, }, -]; +]); -export const dependentFieldOptionsWithoutSelection: DependentFieldOption[] = [ +export const dependentFieldOptionsWithoutSelection: DependentFieldOption[] = deepFreeze([ { label: 'None', value: null, @@ -39,9 +41,9 @@ export const dependentFieldOptionsWithoutSelection: DependentFieldOption[] = [ value: 'Other Dep. Value 3', selected: false, }, -]; +]); -export const dependentFieldOptionsWithSelection: DependentFieldOption[] = [ +export const dependentFieldOptionsWithSelection: DependentFieldOption[] = deepFreeze([ { label: 'None', value: null, @@ -62,9 +64,9 @@ export const dependentFieldOptionsWithSelection: DependentFieldOption[] = [ value: 'Other Dep. Value 3', selected: false, }, -]; +]); -export const dependentFieldOptionsWithSelectionNotInList: DependentFieldOption[] = [ +export const dependentFieldOptionsWithSelectionNotInList: DependentFieldOption[] = deepFreeze([ { label: 'None', value: null, @@ -90,4 +92,4 @@ export const dependentFieldOptionsWithSelectionNotInList: DependentFieldOption[] value: 'Other Dep. Value 3', selected: false, }, -]; +]); diff --git a/src/app/core/mock-data/dependent-field-value.data.ts b/src/app/core/mock-data/dependent-field-value.data.ts index 1cd76f4993..f34d68ddae 100644 --- a/src/app/core/mock-data/dependent-field-value.data.ts +++ b/src/app/core/mock-data/dependent-field-value.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PlatformDependentFieldValue } from '../models/platform/platform-dependent-field-value.model'; -export const dependentFieldValues: PlatformDependentFieldValue[] = [ +export const dependentFieldValues: PlatformDependentFieldValue[] = deepFreeze([ { created_at: '2023-03-23T07:29:25.836584+00:00', expense_field_id: 221309, @@ -34,9 +36,9 @@ export const dependentFieldValues: PlatformDependentFieldValue[] = [ parent_expense_field_value: 'Project 1', updated_at: '2023-03-23T07:29:36.441882+00:00', }, -]; +]); -export const dependentFieldOptionsForCostCode: PlatformDependentFieldValue[] = [ +export const dependentFieldOptionsForCostCode: PlatformDependentFieldValue[] = deepFreeze([ { created_at: '2023-02-23T10:50:38.058403+00:00', expense_field_id: 219199, @@ -59,4 +61,4 @@ export const dependentFieldOptionsForCostCode: PlatformDependentFieldValue[] = [ parent_expense_field_value: 'Project 1', updated_at: '2023-02-23T10:51:06.155705+00:00', }, -]; +]); diff --git a/src/app/core/mock-data/dependent-field.data.ts b/src/app/core/mock-data/dependent-field.data.ts index 4488ae944c..405fc766ca 100644 --- a/src/app/core/mock-data/dependent-field.data.ts +++ b/src/app/core/mock-data/dependent-field.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TxnCustomProperties } from '../models/txn-custom-properties.model'; -export const projectDependentFields: TxnCustomProperties[] = [ +export const projectDependentFields: TxnCustomProperties[] = deepFreeze([ { id: 218227, prefix: '', @@ -56,9 +58,9 @@ export const projectDependentFields: TxnCustomProperties[] = [ options: ['CF5.1', 'CF5.2', 'CF5.3', 'CF5.4', 'CF5.5'], parent_field_id: 218230, }, -]; +]); -export const costCenterDependentFields: TxnCustomProperties[] = [ +export const costCenterDependentFields: TxnCustomProperties[] = deepFreeze([ { id: 221308, prefix: '', @@ -70,4 +72,4 @@ export const costCenterDependentFields: TxnCustomProperties[] = [ options: [], parent_field_id: 221283, }, -]; +]); diff --git a/src/app/core/mock-data/directions-results.data.ts b/src/app/core/mock-data/directions-results.data.ts index 355b208047..ff96859c1d 100644 --- a/src/app/core/mock-data/directions-results.data.ts +++ b/src/app/core/mock-data/directions-results.data.ts @@ -1,6 +1,8 @@ -export const directionsResponse1: string = +import deepFreeze from 'deep-freeze-strict'; + +export const directionsResponse1 = 'oygtBwpx}La@LMHGPB`@AXNl@BXC\\Wd@k@Y[QEIKg@WwCKYt@Wr@Qb@Ip@]v@_@h@SIWOe@XONK@GE_@Uq@MOM@'; -export const directionsResponse2 = { +export const directionsResponse2 = deepFreeze({ message: 'No route found', -}; +}); diff --git a/src/app/core/mock-data/duplicate-sets.data.ts b/src/app/core/mock-data/duplicate-sets.data.ts index ae2bae13cd..386b49459c 100644 --- a/src/app/core/mock-data/duplicate-sets.data.ts +++ b/src/app/core/mock-data/duplicate-sets.data.ts @@ -1,29 +1,31 @@ +import deepFreeze from 'deep-freeze-strict'; + import { DuplicateSet } from '../models/v2/duplicate-sets.model'; -export const duplicateSetData1: DuplicateSet = { +export const duplicateSetData1: DuplicateSet = deepFreeze({ fields: ['field1', 'field2'], transaction_ids: ['tx5fBcPBAxLv'], -}; +}); -export const duplicateSetData2: DuplicateSet = { +export const duplicateSetData2: DuplicateSet = deepFreeze({ fields: ['field1', 'field2'], transaction_ids: ['tx5fBcPBAxLv', 'tx3nHShG60zq'], -}; +}); -export const duplicateSetData3: DuplicateSet = { +export const duplicateSetData3: DuplicateSet = deepFreeze({ fields: ['field1', 'field2'], transaction_ids: ['txcSFe6efB6R', 'txDDLtRaflUW'], -}; +}); -export const duplicateSetData4: DuplicateSet = { +export const duplicateSetData4: DuplicateSet = deepFreeze({ transaction_ids: ['tx5fBcPBAxLv'], -}; +}); -export const duplicateSetData5: DuplicateSet = { +export const duplicateSetData5: DuplicateSet = deepFreeze({ fields: ['field1', 'field2'], transaction_ids: ['txal5xGjbZ1R'], -}; +}); -export const duplicateSetData6: DuplicateSet = { +export const duplicateSetData6: DuplicateSet = deepFreeze({ transaction_ids: ['txal5xGjbZ1R'], -}; +}); diff --git a/src/app/core/mock-data/email-events.data.ts b/src/app/core/mock-data/email-events.data.ts index b52518c21a..f35062b7d0 100644 --- a/src/app/core/mock-data/email-events.data.ts +++ b/src/app/core/mock-data/email-events.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { EmailEventsObject } from '../models/email-events.model'; -export const emailEvents: EmailEventsObject = { +export const emailEvents: EmailEventsObject = deepFreeze({ features: { expensesAndReports: { textLabel: 'Expenses and Reports', @@ -165,4 +167,4 @@ export const emailEvents: EmailEventsObject = { }, }, }, -}; +}); diff --git a/src/app/core/mock-data/employee.data.ts b/src/app/core/mock-data/employee.data.ts index 326f1df1f0..53c5d98712 100644 --- a/src/app/core/mock-data/employee.data.ts +++ b/src/app/core/mock-data/employee.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Employee } from '../models/spender/employee.model'; -export const selectedOptionRes: Partial = { +export const selectedOptionRes: Partial = deepFreeze({ ou_id: 'oubQzXeZbwbS', ou_org_id: 'orNVthTo2Zyo', ou_roles: '["FYLER","APPROVER","HOD","HOP","AUDITOR","FINANCE"]', @@ -9,9 +11,9 @@ export const selectedOptionRes: Partial = { us_full_name: 'AA', us_id: 'usTdvbcxOqjs', is_selected: false, -}; +}); -export const filteredOptionsRes: Partial[] = [ +export const filteredOptionsRes: Partial[] = deepFreeze([ { ou_id: 'oubQzXeZbwbS', ou_org_id: 'orNVthTo2Zyo', @@ -72,9 +74,9 @@ export const filteredOptionsRes: Partial[] = [ us_id: 'usi3jriNhseA', is_selected: false, }, -]; +]); -export const filteredDataRes: Partial[] = [ +export const filteredDataRes: Partial[] = deepFreeze([ { us_email: 'ajain+12121212@fyle.in', is_selected: true, @@ -95,9 +97,9 @@ export const filteredDataRes: Partial[] = [ us_email: 'abcdefg@somemail.com', is_selected: true, }, -]; +]); -export const searchedUserListRes: Partial[] = [ +export const searchedUserListRes: Partial[] = deepFreeze([ { ou_id: 'oubQzXeZbwbS', ou_org_id: 'orNVthTo2Zyo', @@ -128,4 +130,4 @@ export const searchedUserListRes: Partial[] = [ us_id: 'usvKA4X8Ugcr', is_selected: false, }, -]; +]); diff --git a/src/app/core/mock-data/error-mapping-for-verify-number-popover.data.ts b/src/app/core/mock-data/error-mapping-for-verify-number-popover.data.ts index d8073d6767..ccd25689c7 100644 --- a/src/app/core/mock-data/error-mapping-for-verify-number-popover.data.ts +++ b/src/app/core/mock-data/error-mapping-for-verify-number-popover.data.ts @@ -1,3 +1,5 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ErrorType } from 'src/app/fyle/my-profile/verify-number-popover/error-type.model'; type ErrorMapping = { @@ -6,7 +8,7 @@ type ErrorMapping = { value?: number; }; -export const errorMappings: ErrorMapping[] = [ +export const errorMappings: ErrorMapping[] = deepFreeze([ { type: 'LIMIT_REACHED', error: 'You have exhausted the limit to request OTP for your mobile number. Please try again after 24 hours.', @@ -33,4 +35,4 @@ export const errorMappings: ErrorMapping[] = [ value: 1, error: 'You have 1 attempt left to verify your mobile number.', }, -]; +]); diff --git a/src/app/core/mock-data/etxn-params.data.ts b/src/app/core/mock-data/etxn-params.data.ts index d7a60488de..696ed4bb41 100644 --- a/src/app/core/mock-data/etxn-params.data.ts +++ b/src/app/core/mock-data/etxn-params.data.ts @@ -1,8 +1,10 @@ +import deepFreeze from 'deep-freeze-strict'; + import { EtxnParams } from '../models/etxn-params.model'; -export const etxnParamsData1: EtxnParams = { +export const etxnParamsData1: EtxnParams = deepFreeze({ tx_org_user_id: 'eq.out3t2X258rd', tx_state: 'in.(COMPLETE)', or: '(tx_policy_amount.is.null,tx_policy_amount.gt.0.0001)', tx_report_id: 'is.null', -}; +}); diff --git a/src/app/core/mock-data/expense-field-obj.data.ts b/src/app/core/mock-data/expense-field-obj.data.ts index f76fa2b4b5..8d93ae5764 100644 --- a/src/app/core/mock-data/expense-field-obj.data.ts +++ b/src/app/core/mock-data/expense-field-obj.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExpenseFieldsObj } from '../models/v1/expense-fields-obj.model'; -export const expenseFieldObjData: Partial = { +export const expenseFieldObjData: Partial = deepFreeze({ purpose: { id: 22, created_at: new Date('2018-01-31T23:50:27.221Z'), @@ -212,9 +214,9 @@ export const expenseFieldObjData: Partial = { ], field: 'org_category_id', }, -}; +}); -export const txnFieldData: Partial = { +export const txnFieldData: Partial = deepFreeze({ purpose: { id: 22, code: null, @@ -375,9 +377,9 @@ export const txnFieldData: Partial = { parent_field_id: null, field: 'org_category_id', }, -}; +}); -export const txnFieldsData2: Partial = { +export const txnFieldsData2: Partial = deepFreeze({ flight_journey_travel_class: { id: 2, created_at: new Date('2018-01-31T23:50:27.221Z'), @@ -425,9 +427,9 @@ export const txnFieldsData2: Partial = { code: null, roles_editable: ['FYLER', 'APPROVER', 'TRAVEL_ADMIN', 'VERIFIER', 'PAYMENT_PROCESSOR', 'FINANCE', 'ADMIN'], }, -}; +}); -export const txnFieldsData3: Partial = { +export const txnFieldsData3: Partial = deepFreeze({ billable: { id: 188990, code: null, @@ -496,9 +498,9 @@ export const txnFieldsData3: Partial = { roles_editable: ['APPROVER', 'TRAVEL_ADMIN', 'VERIFIER', 'PAYMENT_PROCESSOR', 'FINANCE', 'ADMIN', 'FYLER'], field: 'purpose', }, -}; +}); -export const txnFieldData2: Partial = { +export const txnFieldData2: Partial = deepFreeze({ purpose: { id: 22, code: null, @@ -659,4 +661,4 @@ export const txnFieldData2: Partial = { parent_field_id: null, field: 'org_category_id', }, -}; +}); diff --git a/src/app/core/mock-data/expense-field.data.ts b/src/app/core/mock-data/expense-field.data.ts index 34f57747a3..90e518a8d9 100644 --- a/src/app/core/mock-data/expense-field.data.ts +++ b/src/app/core/mock-data/expense-field.data.ts @@ -1,8 +1,10 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PlatformApiResponse } from '../models/platform/platform-api-response.model'; import { PlatformExpenseField } from '../models/platform/platform-expense-field.model'; import { ExpenseField } from '../models/v1/expense-field.model'; -export const expenseFieldResponse: ExpenseField[] = [ +export const expenseFieldResponse: ExpenseField[] = deepFreeze([ { id: 2, created_at: new Date('2018-01-31T23:50:27.221Z'), @@ -152,9 +154,9 @@ export const expenseFieldResponse: ExpenseField[] = [ code: null, roles_editable: ['FYLER', 'APPROVER', 'TRAVEL_ADMIN', 'VERIFIER', 'PAYMENT_PROCESSOR', 'FINANCE', 'ADMIN'], }, -]; +]); -export const platformExpenseFieldResponse: PlatformApiResponse = { +export const platformExpenseFieldResponse: PlatformApiResponse = deepFreeze({ count: 5, data: [ { @@ -254,9 +256,9 @@ export const platformExpenseFieldResponse: PlatformApiResponse = { +export const txnFieldsData: Partial = deepFreeze({ purpose: { id: 22, created_at: new Date(new Date('2018-01-31T23:50:27.221Z')), @@ -218,9 +220,9 @@ export const txnFieldsData: Partial = { ], field: 'org_category_id', }, -}; +}); -export const txnFieldsData2: Partial = { +export const txnFieldsData2: Partial = deepFreeze({ ...txnFieldsData, vendor_id: { code: '1234', @@ -393,9 +395,9 @@ export const txnFieldsData2: Partial = { code: null, roles_editable: ['FYLER', 'APPROVER', 'TRAVEL_ADMIN', 'VERIFIER', 'PAYMENT_PROCESSOR', 'FINANCE', 'ADMIN'], }, -}; +}); -export const txnFieldsData3: Partial = { +export const txnFieldsData3: Partial = deepFreeze({ ...txnFieldsData2, cost_center_id: { id: 3, @@ -454,9 +456,9 @@ export const txnFieldsData3: Partial = { ], field: 'cost_center_id', }, -}; +}); -export const expenseFieldsMapResponse: Partial = { +export const expenseFieldsMapResponse: Partial = deepFreeze({ purpose: [ { id: 22, @@ -676,9 +678,9 @@ export const expenseFieldsMapResponse: Partial = { field: 'org_category_id', }, ], -}; +}); -export const expenseFieldsMapResponse2: Partial = { +export const expenseFieldsMapResponse2: Partial = deepFreeze({ bus_travel_class: [ { id: 2, @@ -880,9 +882,9 @@ export const expenseFieldsMapResponse2: Partial = { roles_editable: ['FYLER', 'APPROVER', 'TRAVEL_ADMIN', 'VERIFIER', 'PAYMENT_PROCESSOR', 'FINANCE', 'ADMIN'], }, ], -}; +}); -export const expenseFieldsMapResponse3 = { +export const expenseFieldsMapResponse3 = deepFreeze({ distance: [ { id: 6, @@ -930,9 +932,9 @@ export const expenseFieldsMapResponse3 = { roles_editable: ['FYLER', 'APPROVER', 'TRAVEL_ADMIN', 'VERIFIER', 'PAYMENT_PROCESSOR', 'FINANCE', 'ADMIN'], }, ], -}; +}); -export const expenseFieldsMapResponse4 = { +export const expenseFieldsMapResponse4 = deepFreeze({ ...expenseFieldsMapResponse, ...expenseFieldsMapResponse2, project_id: [ @@ -959,9 +961,9 @@ export const expenseFieldsMapResponse4 = { input_type: 'input', }, ], -}; +}); -export const txnFieldsMap2: Partial = { +export const txnFieldsMap2: Partial = deepFreeze({ purpose: { id: 22, created_at: new Date('2018-01-31T23:50:27.221Z'), @@ -1173,9 +1175,9 @@ export const txnFieldsMap2: Partial = { ], field: 'org_category_id', }, -}; +}); -export const txnFieldsFlightData: Partial = { +export const txnFieldsFlightData: Partial = deepFreeze({ ...txnFieldsData2, flight_journey_travel_class: { id: 2, @@ -1224,4 +1226,4 @@ export const txnFieldsFlightData: Partial = { code: null, roles_editable: ['FYLER', 'APPROVER', 'TRAVEL_ADMIN', 'VERIFIER', 'PAYMENT_PROCESSOR', 'FINANCE', 'ADMIN'], }, -}; +}); diff --git a/src/app/core/mock-data/expense-filters.data.ts b/src/app/core/mock-data/expense-filters.data.ts index 643bbc5732..922d5e712a 100644 --- a/src/app/core/mock-data/expense-filters.data.ts +++ b/src/app/core/mock-data/expense-filters.data.ts @@ -1,9 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + import { DateFilters } from 'src/app/shared/components/fy-filters/date-filters.enum'; import { ExpenseType } from '../enums/expense-type.enum'; import { FilterState } from '../enums/filter-state.enum'; import { ExpenseFilters } from '../models/expense-filters.model'; -export const expenseFiltersData1: Partial = { +export const expenseFiltersData1: Partial = deepFreeze({ state: ['DRAFT', 'READY_TO_REPORT'], date: DateFilters.thisWeek, receiptsAttached: 'YES', @@ -12,9 +14,9 @@ export const expenseFiltersData1: Partial = { sortDir: 'asc', cardNumbers: ['1234', '5678'], splitExpense: 'YES', -}; +}); -export const expenseFiltersDataWoCards: Partial = { +export const expenseFiltersDataWoCards: Partial = deepFreeze({ state: ['DRAFT', 'READY_TO_REPORT'], date: DateFilters.thisWeek, receiptsAttached: 'YES', @@ -22,9 +24,9 @@ export const expenseFiltersDataWoCards: Partial = { sortParam: 'category->name', sortDir: 'asc', splitExpense: 'YES', -}; +}); -export const expenseFiltersData1Old: Partial = { +export const expenseFiltersData1Old: Partial = deepFreeze({ state: ['DRAFT', 'READY_TO_REPORT'], date: DateFilters.thisWeek, receiptsAttached: 'YES', @@ -33,17 +35,17 @@ export const expenseFiltersData1Old: Partial = { sortDir: 'asc', cardNumbers: ['1234', '5678'], splitExpense: 'YES', -}; +}); -export const expenseFiltersData2: Partial = { +export const expenseFiltersData2: Partial = deepFreeze({ date: DateFilters.thisWeek, receiptsAttached: 'YES', sortParam: 'category->name', sortDir: 'asc', splitExpense: 'YES', -}; +}); -export const expenseFiltersData3: Partial = { +export const expenseFiltersData3: Partial = deepFreeze({ state: 'custom', date: 'Last Month', customDateStart: new Date('2023-01-04'), @@ -52,43 +54,43 @@ export const expenseFiltersData3: Partial = { type: ['Mileage'], cardNumbers: ['1234', '2389'], splitExpense: 'Yes', -}; +}); -export const expenseFiltersData4: Partial = { +export const expenseFiltersData4: Partial = deepFreeze({ ...expenseFiltersData3, customDateStart: undefined, customDateEnd: undefined, -}; +}); -export const expenseFiltersData5: Partial = { +export const expenseFiltersData5: Partial = deepFreeze({ receiptsAttached: 'YES', sortParam: 'amount', sortDir: 'desc', splitExpense: 'YES', -}; +}); -export const expenseFiltersData5Old: Partial = { +export const expenseFiltersData5Old: Partial = deepFreeze({ receiptsAttached: 'YES', sortParam: 'tx_amount', sortDir: 'desc', splitExpense: 'YES', -}; +}); -export const expenseFiltersData6: Partial = { +export const expenseFiltersData6: Partial = deepFreeze({ receiptsAttached: 'YES', sortParam: 'spent_at', sortDir: 'asc', splitExpense: 'YES', -}; +}); -export const expenseFiltersData7: Partial = { +export const expenseFiltersData7: Partial = deepFreeze({ receiptsAttached: 'YES', sortParam: 'tx_txn_dt', sortDir: 'asc', splitExpense: 'YES', -}; +}); -export const expenseFiltersDataWCustom: Partial = { +export const expenseFiltersDataWCustom: Partial = deepFreeze({ state: 'custom', date: DateFilters.custom, customDateStart: new Date('2023-01-04'), @@ -97,9 +99,9 @@ export const expenseFiltersDataWCustom: Partial = { type: [ExpenseType.MILEAGE, ExpenseType.PER_DIEM, 'RegularExpenses'], cardNumbers: ['1234', '2389'], splitExpense: 'Yes', -}; +}); -export const expenseFiltersDataWithCustomStart: Partial = { +export const expenseFiltersDataWithCustomStart: Partial = deepFreeze({ state: 'custom', date: DateFilters.custom, customDateStart: new Date('2023-01-04'), @@ -107,9 +109,9 @@ export const expenseFiltersDataWithCustomStart: Partial = { type: ['Mileage'], cardNumbers: ['1234', '2389'], splitExpense: 'Yes', -}; +}); -export const expenseFiltersDataWithCustomEnd: Partial = { +export const expenseFiltersDataWithCustomEnd: Partial = deepFreeze({ state: 'custom', date: DateFilters.custom, customDateEnd: new Date('2023-01-10'), @@ -117,9 +119,9 @@ export const expenseFiltersDataWithCustomEnd: Partial = { type: ['Mileage'], cardNumbers: ['1234', '2389'], splitExpense: 'Yes', -}; +}); -export const expenseFiltersDataWoReceipts: Partial = { +export const expenseFiltersDataWoReceipts: Partial = deepFreeze({ state: 'custom', date: DateFilters.custom, customDateEnd: new Date('2023-01-10'), @@ -127,9 +129,9 @@ export const expenseFiltersDataWoReceipts: Partial = { type: ['Mileage'], cardNumbers: ['1234', '2389'], splitExpense: 'Yes', -}; +}); -export const expenseFiltersDataWoSplit: Partial = { +export const expenseFiltersDataWoSplit: Partial = deepFreeze({ state: 'custom', date: DateFilters.custom, customDateEnd: new Date('2023-01-10'), @@ -137,9 +139,9 @@ export const expenseFiltersDataWoSplit: Partial = { type: ['Mileage'], cardNumbers: ['1234', '2389'], splitExpense: 'NO', -}; +}); -export const expenseFiltersDataAllStates: Partial = { +export const expenseFiltersDataAllStates: Partial = deepFreeze({ state: [FilterState.DRAFT, FilterState.CANNOT_REPORT, FilterState.POLICY_VIOLATED, FilterState.READY_TO_REPORT], date: DateFilters.thisWeek, customDateStart: new Date('2023-01-04'), @@ -150,9 +152,9 @@ export const expenseFiltersDataAllStates: Partial = { sortDir: 'asc', cardNumbers: ['1234', '5678'], splitExpense: 'YES', -}; +}); -export const expenseFiltersDataMonth: Partial = { +export const expenseFiltersDataMonth: Partial = deepFreeze({ state: [FilterState.DRAFT, FilterState.CANNOT_REPORT, FilterState.POLICY_VIOLATED, FilterState.READY_TO_REPORT], date: DateFilters.thisMonth, customDateStart: new Date('2023-01-04'), @@ -163,9 +165,9 @@ export const expenseFiltersDataMonth: Partial = { sortDir: 'asc', cardNumbers: ['1234', '5678'], splitExpense: 'YES', -}; +}); -export const expenseFiltersDataLastMonth: Partial = { +export const expenseFiltersDataLastMonth: Partial = deepFreeze({ state: [FilterState.DRAFT], date: DateFilters.lastMonth, customDateStart: new Date('2023-01-04'), @@ -176,4 +178,4 @@ export const expenseFiltersDataLastMonth: Partial = { sortDir: 'asc', cardNumbers: ['1234', '5678'], splitExpense: 'YES', -}; +}); diff --git a/src/app/core/mock-data/expense-policy.data.ts b/src/app/core/mock-data/expense-policy.data.ts index 5433a39c70..33b7c04d78 100644 --- a/src/app/core/mock-data/expense-policy.data.ts +++ b/src/app/core/mock-data/expense-policy.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExpensePolicy } from '../models/platform/platform-expense-policy.model'; -export const expensePolicyData: ExpensePolicy = { +export const expensePolicyData: ExpensePolicy = deepFreeze({ data: { final_desired_state: { add_approver_user_ids: [], @@ -13,13 +15,13 @@ export const expensePolicyData: ExpensePolicy = { }, individual_desired_states: [], }, -}; +}); -export const expensePolicyDataWoData: ExpensePolicy = { +export const expensePolicyDataWoData: ExpensePolicy = deepFreeze({ data: null, -}; +}); -export const splitExpPolicyData: ExpensePolicy = { +export const splitExpPolicyData: ExpensePolicy = deepFreeze({ data: { final_desired_state: { add_approver_user_ids: [], @@ -32,4 +34,4 @@ export const splitExpPolicyData: ExpensePolicy = { }, individual_desired_states: [], }, -}; +}); diff --git a/src/app/core/mock-data/expense-v2.data.ts b/src/app/core/mock-data/expense-v2.data.ts index 7b662e1c14..5e711ac3ce 100644 --- a/src/app/core/mock-data/expense-v2.data.ts +++ b/src/app/core/mock-data/expense-v2.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Expense } from '../models/expense.model'; import { ApiV2Response } from '../models/v2/api-v2-response.model'; -export const expenseV2Data: ApiV2Response = { +export const expenseV2Data: ApiV2Response = deepFreeze({ count: 1145, data: [ { @@ -205,9 +207,9 @@ export const expenseV2Data: ApiV2Response = { limit: 1, offset: 0, url: '/v2/expenses', -}; +}); -export const expenseV2DataMultiple: ApiV2Response = { +export const expenseV2DataMultiple: ApiV2Response = deepFreeze({ count: 2, data: [ { @@ -624,4 +626,4 @@ export const expenseV2DataMultiple: ApiV2Response = { limit: 2, offset: 0, url: '/v2/expenses', -}; +}); diff --git a/src/app/core/mock-data/expense.data.ts b/src/app/core/mock-data/expense.data.ts index 1ee51fb177..e9af5fbd03 100644 --- a/src/app/core/mock-data/expense.data.ts +++ b/src/app/core/mock-data/expense.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Expense } from '../models/expense.model'; import { ApiV2Response } from '../models/v2/api-v2-response.model'; -export const apiExpenseRes: Expense[] = [ +export const apiExpenseRes: Expense[] = deepFreeze([ { tx_risk_state: null, tx_is_duplicate_expense: null, @@ -130,9 +132,9 @@ export const apiExpenseRes: Expense[] = [ ], tx_is_implicit_merge_blocked: false, }, -]; +]); -export const expenseData1: Expense = { +export const expenseData1: Expense = deepFreeze({ tx_categoryDisplayName: 'Groceries', tx_risk_state: null, tx_is_duplicate_expense: null, @@ -257,9 +259,9 @@ export const expenseData1: Expense = { }, ], tx_is_implicit_merge_blocked: false, -}; +}); -export const expenseData2: Expense = { +export const expenseData2: Expense = deepFreeze({ tx_risk_state: null, tx_is_duplicate_expense: null, tx_duplicates: null, @@ -382,9 +384,9 @@ export const expenseData2: Expense = { }, ], tx_is_implicit_merge_blocked: false, -}; +}); -export const etxncData: ApiV2Response = { +export const etxncData: ApiV2Response = deepFreeze({ limit: 1, offset: 0, count: 1, @@ -596,9 +598,9 @@ export const etxncData: ApiV2Response = { us_full_name: 'Abhishek Jain', }, ], -}; +}); -export const etxncListData: ApiV2Response = { +export const etxncListData: ApiV2Response = deepFreeze({ count: 2, data: [ { @@ -1026,9 +1028,9 @@ export const etxncListData: ApiV2Response = { limit: 2, offset: 0, url: '/v2/expenses', -}; +}); -export const expenseDataWithDateString = { +export const expenseDataWithDateString = deepFreeze({ tx_categoryDisplayName: 'Groceries', tx_risk_state: null, tx_is_duplicate_expense: null, @@ -1153,9 +1155,9 @@ export const expenseDataWithDateString = { }, ], tx_is_implicit_merge_blocked: false, -}; +}); -export const etxnData: Expense = { +export const etxnData: Expense = deepFreeze({ tx_risk_state: null, tx_is_duplicate_expense: null, tx_duplicates: [ @@ -1294,9 +1296,9 @@ export const etxnData: Expense = { ], tx_is_implicit_merge_blocked: false, tx_categoryDisplayName: 'Ani test 1 / sub1', -}; +}); -export const expenseList: Expense[] = [ +export const expenseList: Expense[] = deepFreeze([ { _search_document: "'1024.0':1 '1024.00':2 'a':13,19,25,31 'abhishek':37 'ajain@fyle.in':39 'ani':40,42 'business':16,22,28,34 'card':8 'complete':4 'description':5 'director':11 'e/2022/02/t/874':10 'indeed':18,24,30,36 'inr':3 'is':6 'j3duuf':45 'jain':38 'long':15,21,27,33 'mumbai':12 'project':47 'staging':46 'test':41,43 'transaction':9 'unit':17,23,29,35 'vendor':44 'very':14,20,26,32 'yuv3hw':7", @@ -1519,9 +1521,9 @@ export const expenseList: Expense[] = [ us_email: 'ajain@fyle.in', us_full_name: 'Abhishek Jain', }, -]; +]); -export const expenseList2: Expense[] = [ +export const expenseList2: Expense[] = deepFreeze([ { _search_document: "'1024.0':1 '1024.00':2 'a':13,19,25,31 'abhishek':37 'ajain@fyle.in':39 'ani':40,42 'business':16,22,28,34 'card':8 'complete':4 'description':5 'director':11 'e/2022/02/t/874':10 'indeed':18,24,30,36 'inr':3 'is':6 'j3duuf':45 'jain':38 'long':15,21,27,33 'mumbai':12 'project':47 'staging':46 'test':41,43 'transaction':9 'unit':17,23,29,35 'vendor':44 'very':14,20,26,32 'yuv3hw':7", @@ -1848,9 +1850,9 @@ export const expenseList2: Expense[] = [ ], tx_is_implicit_merge_blocked: false, }, -]; +]); -export const mileageExpenseWithoutDistance: Expense = { +export const mileageExpenseWithoutDistance: Expense = deepFreeze({ _search_document: "'0':1 '0.00':2 'a':10,16,22,28 'abhishek':34 'ajain@fyle.in':36 'business':13,19,25,31 'complete':4 'director':8 'duowigw':38 'e/2023/01/t/111':7 'indeed':15,21,27,33 'inr':3 'jain':35 'long':12,18,24,30 'mileage':37,39 'mumbai':9 'project':41 'staging':40 'term':6 'test':5 'unit':14,20,26,32 'very':11,17,23,29", corporate_credit_card_account_number: null, @@ -2051,9 +2053,9 @@ export const mileageExpenseWithoutDistance: Expense = { isPolicyViolated: true, isCriticalPolicyViolated: true, vendorDetails: '0 KM', -}; +}); -export const mileageExpenseWithDistance: Expense = { +export const mileageExpenseWithDistance: Expense = deepFreeze({ _search_document: "'0':1 '0.00':2 'a':10,16,22,28 'abhishek':34 'ajain@fyle.in':36 'business':13,19,25,31 'complete':4 'director':8 'duowigw':38 'e/2023/01/t/111':7 'indeed':15,21,27,33 'inr':3 'jain':35 'long':12,18,24,30 'mileage':37,39 'mumbai':9 'project':41 'staging':40 'term':6 'test':5 'unit':14,20,26,32 'very':11,17,23,29", corporate_credit_card_account_number: null, @@ -2254,9 +2256,9 @@ export const mileageExpenseWithDistance: Expense = { isPolicyViolated: true, isCriticalPolicyViolated: true, vendorDetails: '0 KM', -}; +}); -export const perDiemExpenseSingleNumDays: Expense = { +export const perDiemExpenseSingleNumDays: Expense = deepFreeze({ _search_document: null, corporate_credit_card_account_number: null, credit: false, @@ -2456,9 +2458,9 @@ export const perDiemExpenseSingleNumDays: Expense = { isPolicyViolated: false, isCriticalPolicyViolated: false, vendorDetails: null, -}; +}); -export const perDiemExpenseMultipleNumDays: Expense = { +export const perDiemExpenseMultipleNumDays: Expense = deepFreeze({ _search_document: null, corporate_credit_card_account_number: null, credit: false, @@ -2658,9 +2660,9 @@ export const perDiemExpenseMultipleNumDays: Expense = { isPolicyViolated: false, isCriticalPolicyViolated: false, vendorDetails: null, -}; +}); -export const expenseData3 = { +export const expenseData3 = deepFreeze({ tx_risk_state: null, tx_is_duplicate_expense: null, tx_duplicates: null, @@ -2792,9 +2794,9 @@ export const expenseData3 = { }, ], tx_is_implicit_merge_blocked: false, -}; +}); -export const expenseList3: Expense[] = [ +export const expenseList3: Expense[] = deepFreeze([ { _search_document: "'1024.0':1 '1024.00':2 'a':13,19,25,31 'abhishek':37 'ajain@fyle.in':39 'ani':40,42 'business':16,22,28,34 'card':8 'complete':4 'description':5 'director':11 'e/2022/02/t/874':10 'indeed':18,24,30,36 'inr':3 'is':6 'j3duuf':45 'jain':38 'long':15,21,27,33 'mumbai':12 'project':47 'staging':46 'test':41,43 'transaction':9 'unit':17,23,29,35 'vendor':44 'very':14,20,26,32 'yuv3hw':7", @@ -3121,9 +3123,9 @@ export const expenseList3: Expense[] = [ ], tx_is_implicit_merge_blocked: false, }, -]; +]); -export const expenseList4: Expense[] = [ +export const expenseList4: Expense[] = deepFreeze([ { _search_document: "'1':38 '89':1 '89.00':2 'a':11,17,23,29 'abcdfeiapcalp':39,40,41,42,43 'abhishek':35 'ajain@fyle.in':37 'approver':4 'aus':46 'business':14,20,26,32 'director':9 'e/2023/01/t/120':8 'indeed':16,22,28,34 'inr':3 'jain':36 'long':13,19,25,31 'mumbai':10 'nilesh':45 'others':44 'pending':5 'project':49 'staging':48 'term':7 'test':6 'unit':15,21,27,33 'vendor':47 'very':12,18,24,30", @@ -3736,9 +3738,9 @@ export const expenseList4: Expense[] = [ isCriticalPolicyViolated: false, vendorDetails: '2 Days', }, -]; +]); -export const splitExpData: Expense[] = [ +export const splitExpData: Expense[] = deepFreeze([ { tx_risk_state: null, tx_is_duplicate_expense: null, @@ -4063,8 +4065,8 @@ export const splitExpData: Expense[] = [ tx_is_implicit_merge_blocked: false, tx_categoryDisplayName: 'Food / Travelling - Inland', }, -]; -export const splitExpData2: Expense[] = [ +]); +export const splitExpData2: Expense[] = deepFreeze([ { tx_risk_state: null, tx_is_duplicate_expense: null, @@ -4373,9 +4375,9 @@ export const splitExpData2: Expense[] = [ tx_is_implicit_merge_blocked: false, tx_categoryDisplayName: '00', }, -]; +]); -export const advanceExpensesList: Expense[] = [ +export const advanceExpensesList: Expense[] = deepFreeze([ { tx_risk_state: null, tx_is_duplicate_expense: null, @@ -4504,9 +4506,9 @@ export const advanceExpensesList: Expense[] = [ ], tx_is_implicit_merge_blocked: false, }, -]; +]); -export const mergeExpenseData1: Expense[] = [ +export const mergeExpenseData1: Expense[] = deepFreeze([ { _search_document: "'1':1 '1.00':2 'a':10,16,22,28 'abhishek':34 'ajain@fyle.in':36 'australian':39 'business':13,19,25,31 'complete':4 'director':8 'e/2023/03/t/133':7 'indeed':15,21,27,33 'inr':3 'jain':35 'long':12,18,24,30 'mumbai':9 'office':41 'others':37,38 'project':43 'staging':42 'taxation':40 'term':6 'test':5 'unit':14,20,26,32 'very':11,17,23,29", @@ -4992,9 +4994,9 @@ export const mergeExpenseData1: Expense[] = [ isCriticalPolicyViolated: false, vendorDetails: 'Angular', }, -]; +]); -export const expensesDataWithCC: Expense[] = [ +export const expensesDataWithCC: Expense[] = deepFreeze([ { _search_document: "'1':1,37 '1.00':2 'a':10,16,22,28 'abcdfeiapcalp':38,39,40,41,42 'abhishek':34 'ajain@fyle.in':36 'as':45 'business':13,19,25,31 'complete':4 'director':8 'e/2023/03/t/537':7 'indeed':15,21,27,33 'inr':3 'jain':35 'long':12,18,24,30 'mumbai':9 'nilesh':44 'others':43 'project':48 'staging':47 'term':6 'test':5 'unit':14,20,26,32 'vendor':46 'very':11,17,23,29", @@ -5495,9 +5497,9 @@ export const expensesDataWithCC: Expense[] = [ isCriticalPolicyViolated: false, vendorDetails: 'Nilesh As Vendor', }, -]; +]); -export const newExpenseViewReport: Expense[] = [ +export const newExpenseViewReport: Expense[] = deepFreeze([ { ...expenseData1, tx_report_id: 'rpkkdCNBFsJ2', tx_txn_dt: new Date('2023-01-24T17:00:00.000Z') }, { ...expenseData2, @@ -5506,9 +5508,9 @@ export const newExpenseViewReport: Expense[] = [ tx_id: 'txz2vohKxBXu', }, { ...expenseData3, tx_report_id: 'rpkkdCNBFsJ2' }, -]; +]); -export const expectedFormattedTransaction: Partial[] = [ +export const expectedFormattedTransaction: Partial[] = deepFreeze([ { tx_created_at: new Date('2023-02-08T06:47:48.414Z'), tx_updated_at: new Date('2023-02-08T06:47:48.414Z'), @@ -5580,14 +5582,14 @@ export const expectedFormattedTransaction: Partial[] = [ tx_policy_amount: null, tx_locations: [], }, -]; +]); -export const policyExpense2: Expense = { +export const policyExpense2: Expense = deepFreeze({ ...apiExpenseRes[0], tx_policy_amount: 0, -}; +}); -export const selectedExpenses: Expense[] = [ +export const selectedExpenses: Expense[] = deepFreeze([ { ...expenseList[0], isSelected: true, @@ -5600,9 +5602,9 @@ export const selectedExpenses: Expense[] = [ tx_skip_reimbursement: false, tx_txn_dt: new Date('2023-01-23T17:00:00'), }, -]; +]); -export const selectedExpense1: Expense = { +export const selectedExpense1: Expense = deepFreeze({ _search_document: "'-102717':57 '1':42 '111':9 '20210809':56 '5':53 '899':1 '899.00':2 'a':15,21,27,33 'abcdfeiapcalp':43,44,45,46,47 'abhishek':39 'ajain@fyle.in':41 'ana':12 'approver':4 'aus':55 'board':50 'business':18,24,30,36 'director':13 'e/2023/01/t/89':8 'equalization':52 'honecomb':54 'indeed':20,26,32,38 'inr':3,10 'jain':40 'long':17,23,29,35 'mumbai':14 'of':51 'others':11,48 'pending':5 'project':59 'staging':58 'state':49 'term':7 'test':6 'unit':19,25,31,37 'very':16,22,28,34", corporate_credit_card_account_number: null, @@ -5807,19 +5809,19 @@ export const selectedExpense1: Expense = { us_email: 'ajain@fyle.in', us_full_name: 'Abhishek Jain', isSelected: true, -}; +}); -export const policyExpense3: Expense = { +export const policyExpense3: Expense = deepFreeze({ ...apiExpenseRes[0], tx_policy_amount: 0.0000001, -}; +}); -export const expenseListwithoutID: Expense[] = [ +export const expenseListwithoutID: Expense[] = deepFreeze([ { ...expenseList4[0], tx_id: null }, { ...expenseList4[1], tx_id: null }, -]; +]); -export const splitExpTransformedData: Partial[] = [ +export const splitExpTransformedData: Partial[] = deepFreeze([ { tx_id: 'txal5xGjbZ1R', tx_txn_dt: new Date('2024-01-31T06:30:00.000Z'), @@ -5920,9 +5922,9 @@ export const splitExpTransformedData: Partial[] = [ source_account_id: 'acc7F6bwRa52p', source_account_type: 'PERSONAL_CORPORATE_CREDIT_CARD_ACCOUNT', }, -]; +]); -export const splitExpTransformedData1: Partial[] = [ +export const splitExpTransformedData1: Partial[] = deepFreeze([ { tx_id: 'txQNInZMIHgZ', tx_txn_dt: new Date('2024-01-31T06:30:00.000Z'), @@ -6023,11 +6025,11 @@ export const splitExpTransformedData1: Partial[] = [ source_account_id: 'acc7F6bwRa52p', source_account_type: 'PERSONAL_CORPORATE_CREDIT_CARD_ACCOUNT', }, -]; +]); export const transformedPlatformedExpense: Partial = splitExpTransformedData[0]; -export const transformedPlatformedExpense1: Partial[] = [ +export const transformedPlatformedExpense1: Partial[] = deepFreeze([ { tx_id: 'txZA0Oj6TV9c', tx_txn_dt: new Date('2024-01-31T11:30:00.000Z'), @@ -6126,4 +6128,4 @@ export const transformedPlatformedExpense1: Partial[] = [ source_account_id: 'acc7F6bwRa52p', source_account_type: 'PERSONAL_CORPORATE_CREDIT_CARD_ACCOUNT', }, -]; +]); diff --git a/src/app/core/mock-data/expenses-info.data.ts b/src/app/core/mock-data/expenses-info.data.ts index 57e78bb9e9..ce64bd15c0 100644 --- a/src/app/core/mock-data/expenses-info.data.ts +++ b/src/app/core/mock-data/expenses-info.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExpensesInfo } from '../services/expenses-info.model'; import { apiExpenseRes } from './expense.data'; -export const expensesInfo: ExpensesInfo = { +export const expensesInfo: ExpensesInfo = deepFreeze({ isReportedAndAbove: false, isAdvancePresent: true, defaultExpenses: [ @@ -255,15 +257,15 @@ export const expensesInfo: ExpensesInfo = { vendorDetails: 'Angular', }, ], -}; +}); -export const expenseInfoWithoutDefaultExpense: ExpensesInfo = { +export const expenseInfoWithoutDefaultExpense: ExpensesInfo = deepFreeze({ isReportedAndAbove: false, isAdvancePresent: false, defaultExpenses: null, -}; +}); -export const expensesInfoWithReportedExpense: ExpensesInfo = { +export const expensesInfoWithReportedExpense: ExpensesInfo = deepFreeze({ isReportedAndAbove: true, isAdvancePresent: true, defaultExpenses: [ @@ -272,15 +274,15 @@ export const expensesInfoWithReportedExpense: ExpensesInfo = { ...expensesInfo.defaultExpenses[0], }, ], -}; +}); -export const expensesInfoWithReportedExpenseAndNoAdvance: ExpensesInfo = { +export const expensesInfoWithReportedExpenseAndNoAdvance: ExpensesInfo = deepFreeze({ isReportedAndAbove: true, isAdvancePresent: false, defaultExpenses: [apiExpenseRes[0], apiExpenseRes[0]], -}; +}); -export const expensesInfoWithMultipleAdvanceExpenses: ExpensesInfo = { +export const expensesInfoWithMultipleAdvanceExpenses: ExpensesInfo = deepFreeze({ isReportedAndAbove: false, isAdvancePresent: true, defaultExpenses: [ @@ -534,9 +536,9 @@ export const expensesInfoWithMultipleAdvanceExpenses: ExpensesInfo = { vendorDetails: 'Angular', }, ], -}; +}); -export const expensesInfoData1: ExpensesInfo = { +export const expensesInfoData1: ExpensesInfo = deepFreeze({ isReportedAndAbove: false, isAdvancePresent: true, defaultExpenses: [ @@ -1019,4 +1021,4 @@ export const expensesInfoData1: ExpensesInfo = { vendorDetails: 'Nilesh As Vendor', }, ], -}; +}); diff --git a/src/app/core/mock-data/extended-account.data.ts b/src/app/core/mock-data/extended-account.data.ts index 788ec8b042..d5971b9b9c 100644 --- a/src/app/core/mock-data/extended-account.data.ts +++ b/src/app/core/mock-data/extended-account.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExtendedAccount } from '../models/extended-account.model'; -export const extendedAccountData1: ExtendedAccount[] = [ +export const extendedAccountData1: ExtendedAccount[] = deepFreeze([ { acc: null, ou: { @@ -23,4 +25,4 @@ export const extendedAccountData1: ExtendedAccount[] = [ currency: null, amount: null, }, -]; +]); diff --git a/src/app/core/mock-data/extended-advance-request.data.ts b/src/app/core/mock-data/extended-advance-request.data.ts index ec6281ac0b..625c8e901a 100644 --- a/src/app/core/mock-data/extended-advance-request.data.ts +++ b/src/app/core/mock-data/extended-advance-request.data.ts @@ -1,9 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + import { cloneDeep } from 'lodash'; import { ApiV2Response } from '../models/api-v2.model'; import { ExtendedAdvanceRequestPublic } from '../models/extended-advance-request-public.model'; import { ExtendedAdvanceRequest } from '../models/extended_advance_request.model'; -export const singleExtendedAdvReqRes: ApiV2Response = { +export const singleExtendedAdvReqRes: ApiV2Response = deepFreeze({ count: 1, data: [ { @@ -78,9 +80,9 @@ export const singleExtendedAdvReqRes: ApiV2Response = { limit: 1, offset: 0, url: '/v2/advance_requests', -}; +}); -export const extendedAdvReqDraft: ExtendedAdvanceRequest = { +export const extendedAdvReqDraft: ExtendedAdvanceRequest = deepFreeze({ _search_document: "'54':1 'a':7,13,19,25 'abhishek':31 'ajain@fyle.in':33 'ar/2023/01/r/4':3 'business':10,16,22,28 'director':5 'fd':4 'indeed':12,18,24,30 'jain':32 'long':9,15,21,27 'mumbai':6 'tggg':2 'unit':11,17,23,29 'very':8,14,20,26", advance_request_approvals: null, @@ -139,58 +141,58 @@ export const extendedAdvReqDraft: ExtendedAdvanceRequest = { project_name: null, us_email: 'ajain@fyle.in', us_full_name: 'Abhishek Jain', -}; +}); -export const extendedAdvReqInquiry: ExtendedAdvanceRequest = { +export const extendedAdvReqInquiry: ExtendedAdvanceRequest = deepFreeze({ ...extendedAdvReqDraft, areq_state: 'INQUIRY', -}; +}); -export const extendedAdvReqSubmitted: ExtendedAdvanceRequest = { +export const extendedAdvReqSubmitted: ExtendedAdvanceRequest = deepFreeze({ ...extendedAdvReqDraft, areq_state: 'SUBMITTED', -}; +}); -export const extendedAdvReqPaid: ExtendedAdvanceRequest = { +export const extendedAdvReqPaid: ExtendedAdvanceRequest = deepFreeze({ ...extendedAdvReqDraft, areq_state: 'PAID', -}; +}); -export const extendedAdvReqApproved: ExtendedAdvanceRequest = { +export const extendedAdvReqApproved: ExtendedAdvanceRequest = deepFreeze({ ...extendedAdvReqDraft, areq_state: 'APPROVED', -}; +}); -export const extendedAdvReqRejected: ExtendedAdvanceRequest = { +export const extendedAdvReqRejected: ExtendedAdvanceRequest = deepFreeze({ ...extendedAdvReqDraft, areq_state: 'REJECTED', -}; +}); -export const extendedAdvReqPulledBack: ExtendedAdvanceRequest = { +export const extendedAdvReqPulledBack: ExtendedAdvanceRequest = deepFreeze({ ...extendedAdvReqDraft, areq_is_pulled_back: true, -}; +}); -export const extendedAdvReqSentBack: ExtendedAdvanceRequest = { +export const extendedAdvReqSentBack: ExtendedAdvanceRequest = deepFreeze({ ...extendedAdvReqDraft, areq_is_sent_back: true, -}; +}); -export const extendedAdvReqWithoutDates = { +export const extendedAdvReqWithoutDates = deepFreeze({ ...extendedAdvReqDraft, areq_created_at: '2023-01-16T06:22:47.058Z', areq_updated_at: '2023-01-16T06:22:47.058Z', areq_approved_at: '2023-01-16T06:22:47.058Z', -}; +}); -export const extendedAdvReqWithDates = { +export const extendedAdvReqWithDates = deepFreeze({ ...extendedAdvReqDraft, areq_created_at: new Date('2023-01-16T06:22:47.058Z'), areq_updated_at: new Date('2023-01-16T06:22:47.058Z'), areq_approved_at: new Date('2023-01-16T06:22:47.058Z'), -}; +}); -export const withoutDatesAdv = { +export const withoutDatesAdv = deepFreeze({ _search_document: "'54':1 'a':7,13,19,25 'abhishek':31 'ajain@fyle.in':33 'ar/2023/01/r/4':3 'business':10,16,22,28 'director':5 'fd':4 'indeed':12,18,24,30 'jain':32 'long':9,15,21,27 'mumbai':6 'tggg':2 'unit':11,17,23,29 'very':8,14,20,26", advance_request_approvals: null, @@ -247,9 +249,9 @@ export const withoutDatesAdv = { project_name: null, us_email: 'ajain@fyle.in', us_full_name: 'Abhishek Jain', -}; +}); -export const singleErqRes: ExtendedAdvanceRequestPublic = { +export const singleErqRes: ExtendedAdvanceRequestPublic = deepFreeze({ areq_advance_request_number: 'A/2020/10/T/95', areq_advance_id: 'advjrgwlk2Q', areq_amount: 47.99, @@ -283,9 +285,9 @@ export const singleErqRes: ExtendedAdvanceRequestPublic = { areq_is_sent_back: false, project_name: 'Fast and Furious', project_code: 'C1234', -}; +}); -export const singleErqUnflattened = { +export const singleErqUnflattened = deepFreeze({ areq: { id: 'areqGzKF1Tne23', created_at: new Date('2023-02-23T13:16:15.260Z'), @@ -344,9 +346,9 @@ export const singleErqUnflattened = { new: { state: 'APPROVAL_PENDING', }, -}; +}); -export const teamAdvanceCountRes: ApiV2Response = { +export const teamAdvanceCountRes: ApiV2Response = deepFreeze({ count: 43, data: [ { @@ -421,9 +423,9 @@ export const teamAdvanceCountRes: ApiV2Response = { limit: 1, offset: 0, url: '/v2/advance_requests', -}; +}); -export const allAdvanceRequestsRes: ApiV2Response = { +export const allAdvanceRequestsRes: ApiV2Response = deepFreeze({ count: 107, data: [ { @@ -550,9 +552,9 @@ export const allAdvanceRequestsRes: ApiV2Response = { limit: 10, offset: 0, url: '/v2/advance_requests', -}; +}); -export const publicAdvanceRequestRes: ApiV2Response = { +export const publicAdvanceRequestRes: ApiV2Response = deepFreeze({ count: 1, data: [ { @@ -586,9 +588,9 @@ export const publicAdvanceRequestRes: ApiV2Response = { +export const publicAdvanceRequestResSentBack: ApiV2Response = deepFreeze({ count: 1, data: [ { @@ -600,9 +602,9 @@ export const publicAdvanceRequestResSentBack: ApiV2Response = { +export const publicAdvanceRequestResPulledBack: ApiV2Response = deepFreeze({ count: 1, data: [ { @@ -614,14 +616,14 @@ export const publicAdvanceRequestResPulledBack: ApiV2Response = { +export const publicAdvanceRequestRes2: ApiV2Response = deepFreeze({ ...publicAdvanceRequestRes, count: 250, -}; +}); -export const publicAdvanceRequestRes3: ExtendedAdvanceRequestPublic = { +export const publicAdvanceRequestRes3: ExtendedAdvanceRequestPublic = deepFreeze({ ...publicAdvanceRequestRes.data[0], type: 'request', currency: 'USD', @@ -630,9 +632,9 @@ export const publicAdvanceRequestRes3: ExtendedAdvanceRequestPublic = { purpose: 'onsite client meeting', state: 'DRAFT', areq_is_pulled_back: true, -}; +}); -export const publicAdvanceRequestRes4: ExtendedAdvanceRequestPublic = { +export const publicAdvanceRequestRes4: ExtendedAdvanceRequestPublic = deepFreeze({ ...publicAdvanceRequestRes.data[0], type: 'request', currency: 'USD', @@ -641,9 +643,9 @@ export const publicAdvanceRequestRes4: ExtendedAdvanceRequestPublic = { purpose: 'onsite client meeting', state: 'DRAFT', areq_is_sent_back: true, -}; +}); -export const publicAdvanceRequestRes5: ApiV2Response = { +export const publicAdvanceRequestRes5: ApiV2Response = deepFreeze({ count: 1, data: [ { @@ -677,9 +679,9 @@ export const publicAdvanceRequestRes5: ApiV2Response = { +export const allTeamAdvanceRequestsRes: ApiV2Response = deepFreeze({ count: 43, data: [ { @@ -831,27 +833,27 @@ export const allTeamAdvanceRequestsRes: ApiV2Response = limit: 10, offset: 0, url: '/v2/advance_requests', -}; +}); -export const myAdvanceRequestsData2: ApiV2Response = { +export const myAdvanceRequestsData2: ApiV2Response = deepFreeze({ ...allTeamAdvanceRequestsRes, count: 11, -}; +}); -export const myAdvanceRequestsData3: ExtendedAdvanceRequest = { +export const myAdvanceRequestsData3: ExtendedAdvanceRequest = deepFreeze({ ...singleExtendedAdvReqRes.data[0], areq_state: 'DRAFT', areq_is_sent_back: true, -}; +}); -export const myAdvanceRequestsData4: ExtendedAdvanceRequest = { +export const myAdvanceRequestsData4: ExtendedAdvanceRequest = deepFreeze({ ...singleExtendedAdvReqRes.data[0], areq_state: 'DRAFT', areq_is_sent_back: false, areq_is_pulled_back: false, -}; +}); -export const myAdvanceRequestData5: ExtendedAdvanceRequest = { +export const myAdvanceRequestData5: ExtendedAdvanceRequest = deepFreeze({ ...singleExtendedAdvReqRes.data[0], type: 'request', currency: 'USD', @@ -859,4 +861,4 @@ export const myAdvanceRequestData5: ExtendedAdvanceRequest = { created_at: new Date('2022-05-27T08:33:32.879009'), purpose: '213', state: 'APPROVAL_PENDING', -}; +}); diff --git a/src/app/core/mock-data/extended-advance.data.ts b/src/app/core/mock-data/extended-advance.data.ts index b2d3644bc2..6408074d19 100644 --- a/src/app/core/mock-data/extended-advance.data.ts +++ b/src/app/core/mock-data/extended-advance.data.ts @@ -1,10 +1,12 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExtendedAdvance } from '../models/extended_advance.model'; import { ApiV2Response } from '../models/api-v2.model'; import { PlatformApiResponse } from '../models/platform/platform-api-response.model'; import { AdvancesPlatform } from '../models/platform/advances-platform.model'; import { CustomFieldTypes } from '../enums/platform/v1/custom-fields-type.enum'; -export const singleExtendedAdvancesData: ApiV2Response = { +export const singleExtendedAdvancesData: ApiV2Response = deepFreeze({ count: 1, data: [ { @@ -38,21 +40,21 @@ export const singleExtendedAdvancesData: ApiV2Response = { }, ], offset: 0, -}; +}); -export const extendedAdvWithDates = { +export const extendedAdvWithDates = deepFreeze({ ...singleExtendedAdvancesData, adv_created_at: new Date('2019-10-31T04:36:01.927Z'), adv_issued_at: new Date('2019-10-31T04:35:10.391Z'), -}; +}); -export const extendedAdvWithoutDates = { +export const extendedAdvWithoutDates = deepFreeze({ ...singleExtendedAdvancesData, adv_created_at: '2019-10-31T04:36:01.927Z', adv_issued_at: '2019-10-31T04:35:10.391Z', -}; +}); -export const singleExtendedAdvancesData2: ApiV2Response = { +export const singleExtendedAdvancesData2: ApiV2Response = deepFreeze({ count: 11, data: [ { @@ -87,9 +89,9 @@ export const singleExtendedAdvancesData2: ApiV2Response = { limit: 1, offset: 0, url: '/v2/advances', -}; +}); -export const singleExtendedAdvancesData3: ExtendedAdvance = { +export const singleExtendedAdvancesData3: ExtendedAdvance = deepFreeze({ ...singleExtendedAdvancesData.data[0], type: 'advance', amount: 5044, @@ -98,9 +100,9 @@ export const singleExtendedAdvancesData3: ExtendedAdvance = { currency: 'INR', orig_currency: null, purpose: 'testing', -}; +}); -export const platformAdvanceData: PlatformApiResponse = { +export const platformAdvanceData: PlatformApiResponse = deepFreeze({ count: 11, offset: 200, data: [ @@ -174,4 +176,4 @@ export const platformAdvanceData: PlatformApiResponse = { user_id: 'usvKA4X8Ugcr', }, ], -}; +}); diff --git a/src/app/core/mock-data/extended-device-info.data.ts b/src/app/core/mock-data/extended-device-info.data.ts index 2b11c74d90..be7289594b 100644 --- a/src/app/core/mock-data/extended-device-info.data.ts +++ b/src/app/core/mock-data/extended-device-info.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExtendedDeviceInfo } from '../models/extended-device-info.model'; -export const extendedDeviceInfoMockData: ExtendedDeviceInfo = { +export const extendedDeviceInfoMockData: ExtendedDeviceInfo = deepFreeze({ uuid: 'mockuuid123', appVersion: '5.50.0', liveUpdateAppVersion: '5.50.0', @@ -11,9 +13,9 @@ export const extendedDeviceInfoMockData: ExtendedDeviceInfo = { manufacturer: 'Apple', isVirtual: false, webViewVersion: 'mockwebviewversion123', -}; +}); -export const extendedDeviceInfoMockData2: ExtendedDeviceInfo = { +export const extendedDeviceInfoMockData2: ExtendedDeviceInfo = deepFreeze({ uuid: 'mockuuid124', appVersion: '5.52.0', liveUpdateAppVersion: '5.52.0', @@ -24,9 +26,9 @@ export const extendedDeviceInfoMockData2: ExtendedDeviceInfo = { manufacturer: 'Samsung', isVirtual: false, webViewVersion: 'mockwebviewversion124', -}; +}); -export const extendedDeviceInfoMockDataWoApp: ExtendedDeviceInfo = { +export const extendedDeviceInfoMockDataWoApp: ExtendedDeviceInfo = deepFreeze({ uuid: 'mockuuid124', appVersion: null, liveUpdateAppVersion: '5.52.0', @@ -37,4 +39,4 @@ export const extendedDeviceInfoMockDataWoApp: ExtendedDeviceInfo = { manufacturer: 'Samsung', isVirtual: false, webViewVersion: 'mockwebviewversion124', -}; +}); diff --git a/src/app/core/mock-data/extended-org-user.data.ts b/src/app/core/mock-data/extended-org-user.data.ts index de92d5cd36..23c0c41c69 100644 --- a/src/app/core/mock-data/extended-org-user.data.ts +++ b/src/app/core/mock-data/extended-org-user.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { EouApiResponse } from '../models/eou-api-response.model'; import { ExtendedOrgUser } from '../models/extended-org-user.model'; -export const apiEouRes: ExtendedOrgUser = { +export const apiEouRes: ExtendedOrgUser = deepFreeze({ ou: { id: 'ouX8dwsbLCLv', created_at: new Date('2018-02-01T02:32:25.267Z'), @@ -102,9 +104,9 @@ export const apiEouRes: ExtendedOrgUser = { customer_id: 'dwcJzfwZCgwkdfG', bank_account_added: true, }, -}; +}); -export const eouRes2: ExtendedOrgUser = { +export const eouRes2: ExtendedOrgUser = deepFreeze({ ou: { id: 'ouX8dwsbLCLv', created_at: new Date('2018-02-01T02:32:25.267Z'), @@ -184,9 +186,9 @@ export const eouRes2: ExtendedOrgUser = { customer_id: 'dwcJzfwZCgwkdfG', bank_account_added: true, }, -}; +}); -export const eouRes3: ExtendedOrgUser = { +export const eouRes3: ExtendedOrgUser = deepFreeze({ ou: { id: 'ouX8dwsbLCLv', created_at: new Date('2018-02-01T02:32:25.267Z'), @@ -301,9 +303,9 @@ export const eouRes3: ExtendedOrgUser = { customer_id: 'dwcJzfwZCgwkdfG', bank_account_added: true, }, -}; +}); -export const eouFlattended: EouApiResponse = { +export const eouFlattended: EouApiResponse = deepFreeze({ ou_id: 'ouX8dwsbLCLv', ou_created_at: new Date('2018-02-01T02:32:25.267Z'), ou_org_id: 'orNVthTo2Zyo', @@ -398,20 +400,20 @@ export const eouFlattended: EouApiResponse = { dwolla_customer_id: 'dwcJzfwZCgwkdfG', dwolla_bank_account_added: true, ou_cost_center_ids: [13792, 13793, 13794, 14018, 13795, 13995, 9493, 9494, 13785, 13787, 13788, 13789, 13790, 13791], -}; +}); -export const eouWithNoAttempts: ExtendedOrgUser = { +export const eouWithNoAttempts: ExtendedOrgUser = deepFreeze({ ...apiEouRes, ou: { ...apiEouRes.ou, mobile_verification_attempts_left: 0, }, -}; +}); -export const eouWithPendingDetails: ExtendedOrgUser = { +export const eouWithPendingDetails: ExtendedOrgUser = deepFreeze({ ...apiEouRes, ou: { ...apiEouRes.ou, status: 'PENDING_DETAILS', }, -}; +}); diff --git a/src/app/core/mock-data/extended-projects.data.ts b/src/app/core/mock-data/extended-projects.data.ts index 48f3b6290e..5f22649cd9 100644 --- a/src/app/core/mock-data/extended-projects.data.ts +++ b/src/app/core/mock-data/extended-projects.data.ts @@ -1,4 +1,6 @@ -export const projects = [ +import deepFreeze from 'deep-freeze-strict'; + +export const projects = deepFreeze([ { ap1_email: null, ap1_full_name: null, @@ -37,9 +39,9 @@ export const projects = [ projectv2_name: 'Abercrombie International Group', sub_project_name: null, }, -]; +]); -export const labelledProjects = [ +export const labelledProjects = deepFreeze([ { label: 'project1', value: { @@ -84,9 +86,9 @@ export const labelledProjects = [ sub_project_name: null, }, }, -]; +]); -export const expectedLabelledProjects = [ +export const expectedLabelledProjects = deepFreeze([ { label: 'project1', value: { @@ -131,9 +133,9 @@ export const expectedLabelledProjects = [ sub_project_name: null, }, }, -]; +]); -export const singleProjects1 = { +export const singleProjects1 = deepFreeze({ ap1_email: 'john.d@fyle.in', ap1_full_name: 'John Doe', ap2_email: 'james.d@fyle.in', @@ -151,9 +153,9 @@ export const singleProjects1 = { project_updated_at: new Date('2023-02-22T04:58:55.727Z'), projectv2_name: 'Abercrombie International Group', sub_project_name: null, -}; +}); -export const singleProject2 = { +export const singleProject2 = deepFreeze({ ap1_email: null, ap1_full_name: null, ap2_email: null, @@ -171,9 +173,9 @@ export const singleProject2 = { project_updated_at: new Date('2021-07-08T10:28:27.686886'), projectv2_name: 'Customer Mapped Project', sub_project_name: null, -}; +}); -export const expectedProjects = [ +export const expectedProjects = deepFreeze([ { label: 'None', value: null, @@ -222,9 +224,9 @@ export const expectedProjects = [ sub_project_name: null, }, }, -]; +]); -export const expectedProjects2 = [ +export const expectedProjects2 = deepFreeze([ { label: 'None', value: null, @@ -297,9 +299,9 @@ export const expectedProjects2 = [ sub_project_name: null, }, }, -]; +]); -export const expectedProjects3 = [ +export const expectedProjects3 = deepFreeze([ { label: 'None', value: null, @@ -349,9 +351,9 @@ export const expectedProjects3 = [ sub_project_name: null, }, }, -]; +]); -export const expectedProjects4 = [ +export const expectedProjects4 = deepFreeze([ { label: 'project1', value: { @@ -374,4 +376,4 @@ export const expectedProjects4 = [ sub_project_name: null, }, }, -]; +]); diff --git a/src/app/core/mock-data/file-object.data.ts b/src/app/core/mock-data/file-object.data.ts index c59d2fa16e..d8404cb070 100644 --- a/src/app/core/mock-data/file-object.data.ts +++ b/src/app/core/mock-data/file-object.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { FileObject } from '../models/file-obj.model'; -export const fileObjectData: FileObject = { +export const fileObjectData: FileObject = deepFreeze({ id: 'fiHPZUiichAS', org_user_id: 'ouX8dwsbLCLv', created_at: new Date('2023-02-01T12:27:28.522Z'), @@ -14,9 +16,9 @@ export const fileObjectData: FileObject = { receipt_coordinates: null, email_meta_data: null, fyle_sub_url: '/api/files/fiHPZUiichAS/download', -}; +}); -export const fileObjectData1: FileObject[] = [ +export const fileObjectData1: FileObject[] = deepFreeze([ { id: 'fi6PQ6z4w6ET', org_user_id: 'ouX8dwsbLCLv', @@ -32,9 +34,9 @@ export const fileObjectData1: FileObject[] = [ email_meta_data: null, fyle_sub_url: '/api/files/fi6PQ6z4w6ET/download', }, -]; +]); -export const fileObjectData2: FileObject = { +export const fileObjectData2: FileObject = deepFreeze({ id: 'fi6PQ6z4w6ET', org_user_id: 'ouX8dwsbLCLv', created_at: new Date('2023-02-08T06:47:44.340Z'), @@ -48,9 +50,9 @@ export const fileObjectData2: FileObject = { receipt_coordinates: null, email_meta_data: null, fyle_sub_url: '/api/files/fi6PQ6z4w6ET/download', -}; +}); -export const fileObjectData3: FileObject = { +export const fileObjectData3: FileObject = deepFreeze({ id: 'finwabtsAZRy', org_user_id: 'ouX8dwsbLCLv', created_at: new Date('2023-02-23T13:16:15.227Z'), @@ -64,9 +66,9 @@ export const fileObjectData3: FileObject = { receipt_coordinates: null, email_meta_data: null, fyle_sub_url: '/api/files/finwabtsAZRy/download', -}; +}); -export const fileObjectData5: FileObject = { +export const fileObjectData5: FileObject = deepFreeze({ name: '000.png', receipt_coordinates: { x: 100, @@ -76,16 +78,16 @@ export const fileObjectData5: FileObject = { }, id: 'fiHPZUiichAS', purpose: '', -}; +}); -export const fileUrlMockData: FileObject[] = [ +export const fileUrlMockData: FileObject[] = deepFreeze([ { id: 'fiwJ0nQTBpYH', url: 'mock-url-1', }, -]; +]); -export const fileObjectAdv: FileObject[] = [ +export const fileObjectAdv: FileObject[] = deepFreeze([ { id: 'fiSSsy2Bf4Se', org_user_id: 'ouCI4UQ2G0K1', @@ -106,9 +108,9 @@ export const fileObjectAdv: FileObject[] = [ thumbnail: 'https://fyle-storage-mumbai-3.s3.amazonaws.com/2023-02-23/orrjqbDbeP9p/receipts/fiSSsy2Bf4Se.000.jpeg?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Date=20230223T151537Z&X-Amz-SignedHeaders=host&X-Amz-Expires=604800&X-Amz-Credential=AKIA54Z3LIXTX6CFH4VG%2F20230223%2Fap-south-1%2Fs3%2Faws4_request&X-Amz-Signature=d79c2711892e7cb3f072e223b7b416408c252da38e7df0995e3d256cd8509fee', }, -]; +]); -export const fileObjectAdv1: FileObject = { +export const fileObjectAdv1: FileObject = deepFreeze({ ...fileObjectAdv[0], name: '000.pdf', file_type: 'pdf', @@ -116,9 +118,9 @@ export const fileObjectAdv1: FileObject = { type: 'pdf', thumbnail: 'https://fyle-storage-mumbai-3.s3.amazonaws.com/2023-02-23/orrjqbDbeP9p/receipts/fiSSsy2Bf4Se.000.pdf?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Date=20230223T151537Z&X-Amz-SignedHeaders=host&X-Amz-Expires=604800&X-Amz-Credential=AKIA54Z3LIXTX6CFH4VG%2F20230223%2Fap-south-1%2Fs3%2Faws4_request&X-Amz-Signature=d79c2711892e7cb3f072e223b7b416408c252da38e7df0995e3d256cd8509fee', -}; +}); -export const fileObjectData4: FileObject = { +export const fileObjectData4: FileObject = deepFreeze({ id: 'fiXpfkKFhf6w', org_user_id: 'ouCI4UQ2G0K1', created_at: new Date('2023-02-23T16:22:03.264Z'), @@ -132,9 +134,9 @@ export const fileObjectData4: FileObject = { receipt_coordinates: null, email_meta_data: null, fyle_sub_url: '/api/files/fiXpfkKFhf6w/download', -}; +}); -export const splitExpFileObj: FileObject[] = [ +export const splitExpFileObj: FileObject[] = deepFreeze([ { id: 'fijCeF0G0jTl', org_user_id: 'ouX8dwsbLCLv', @@ -150,9 +152,9 @@ export const splitExpFileObj: FileObject[] = [ email_meta_data: null, fyle_sub_url: '/api/files/fijCeF0G0jTl/download', }, -]; +]); -export const splitExpFile2: FileObject = { +export const splitExpFile2: FileObject = deepFreeze({ id: 'fiebA5W5GLhr', org_user_id: 'ouX8dwsbLCLv', created_at: new Date('2023-03-02T14:13:19.604Z'), @@ -166,9 +168,9 @@ export const splitExpFile2: FileObject = { receipt_coordinates: null, email_meta_data: null, fyle_sub_url: '/api/files/fiebA5W5GLhr/download', -}; +}); -export const splitExpFile3: FileObject = { +export const splitExpFile3: FileObject = deepFreeze({ id: 'figgpRkIApZE', org_user_id: 'ouX8dwsbLCLv', created_at: new Date('2023-03-02T14:13:19.587Z'), @@ -182,9 +184,9 @@ export const splitExpFile3: FileObject = { receipt_coordinates: null, email_meta_data: null, fyle_sub_url: '/api/files/figgpRkIApZE/download', -}; +}); -export const fileObject4: FileObject[] = [ +export const fileObject4: FileObject[] = deepFreeze([ { id: 'fiV1gXpyCcbU', org_user_id: 'ouX8dwsbLCLv', @@ -200,9 +202,9 @@ export const fileObject4: FileObject[] = [ email_meta_data: null, fyle_sub_url: '/api/files/fiV1gXpyCcbU/download', }, -]; +]); -export const fileObject5: FileObject[] = [ +export const fileObject5: FileObject[] = deepFreeze([ { id: 'fixUymqiLnvc', org_user_id: 'ouX8dwsbLCLv', @@ -218,9 +220,9 @@ export const fileObject5: FileObject[] = [ email_meta_data: null, fyle_sub_url: '/api/files/fixUymqiLnvc/download', }, -]; +]); -export const fileObject6: FileObject[] = [ +export const fileObject6: FileObject[] = deepFreeze([ { id: 'fiI9e9ZytdXM', org_user_id: 'ou5tyO64Eg0L', @@ -236,9 +238,9 @@ export const fileObject6: FileObject[] = [ email_meta_data: null, fyle_sub_url: '/api/files/fiI9e9ZytdXM/download', }, -]; +]); -export const fileObject7: FileObject[] = [ +export const fileObject7: FileObject[] = deepFreeze([ { id: 'ficaDEJBVhjm', org_user_id: 'ou5tyO64Eg0L', @@ -269,9 +271,9 @@ export const fileObject7: FileObject[] = [ email_meta_data: null, fyle_sub_url: '/api/files/firDjjutGXfT/download', }, -]; +]); -export const fileObject8: FileObject[] = [ +export const fileObject8: FileObject[] = deepFreeze([ { id: 'fizBwnXhyZTp', org_user_id: 'ou5tyO64Eg0L', @@ -287,9 +289,9 @@ export const fileObject8: FileObject[] = [ email_meta_data: null, fyle_sub_url: '/api/files/fizBwnXhyZTp/download', }, -]; +]); -export const expectedFileData1 = [ +export const expectedFileData1 = deepFreeze([ { id: 'fiV1gXpyCcbU', org_user_id: 'ouX8dwsbLCLv', @@ -308,9 +310,9 @@ export const expectedFileData1 = [ type: 'jpeg', thumbnail: 'thumbnail', }, -]; +]); -export const advanceRequestFileUrlData: FileObject[] = [ +export const advanceRequestFileUrlData: FileObject[] = deepFreeze([ { ...fileObjectAdv1, }, @@ -319,17 +321,17 @@ export const advanceRequestFileUrlData: FileObject[] = [ type: 'jpeg', id: null, }, -]; +]); -export const expectedFileData2: FileObject[] = [ +export const expectedFileData2: FileObject[] = deepFreeze([ { type: 'pdf', url: '2023-02-08/orNVthTo2Zyo/receipts/fi6PQ6z4w6ET.000.pdf', thumbnail: '2023-02-08/orNVthTo2Zyo/receipts/fi6PQ6z4w6ET.000.pdf', }, -]; +]); -export const advanceRequestFileUrlData2: FileObject[] = [ +export const advanceRequestFileUrlData2: FileObject[] = deepFreeze([ { ...fileObjectAdv1, id: null, @@ -339,9 +341,9 @@ export const advanceRequestFileUrlData2: FileObject[] = [ type: 'image', id: null, }, -]; +]); -export const fileObject9: FileObject[] = [ +export const fileObject9: FileObject[] = deepFreeze([ { id: 'fiV1gXpyCcbU', org_user_id: 'ouX8dwsbLCLv', @@ -357,13 +359,13 @@ export const fileObject9: FileObject[] = [ email_meta_data: null, fyle_sub_url: '/api/files/fiV1gXpyCcbU/download', }, -]; +]); -export const fileObject10: FileObject[] = [ +export const fileObject10: FileObject[] = deepFreeze([ { ...fileObjectAdv1, url: 'mockdownloadurl.png', type: 'pdf', thumbnail: 'src/assets/images/pdf-receipt-placeholder.png', }, -]; +]); diff --git a/src/app/core/mock-data/file-txn.data.ts b/src/app/core/mock-data/file-txn.data.ts index 5dbe3fbb0d..6b2d1eb228 100644 --- a/src/app/core/mock-data/file-txn.data.ts +++ b/src/app/core/mock-data/file-txn.data.ts @@ -1,3 +1,5 @@ +import deepFreeze from 'deep-freeze-strict'; + import { FileTransaction } from '../models/file-txn.model'; import { splitExpenseTxn1, @@ -7,7 +9,7 @@ import { splitExpenseTxn2_3, } from './transaction.data'; -export const fileTxns: FileTransaction = { +export const fileTxns: FileTransaction = deepFreeze({ txns: [ { created_at: new Date('2023-03-02T14:13:16.734Z'), @@ -233,9 +235,9 @@ export const fileTxns: FileTransaction = { content: 'some content here', }, ], -}; +}); -export const fileTxns2: FileTransaction = { +export const fileTxns2: FileTransaction = deepFreeze({ txns: [ { created_at: new Date('2023-06-16T05:37:30.878Z'), @@ -409,9 +411,9 @@ export const fileTxns2: FileTransaction = { content: 'someData', }, ], -}; +}); -export const fileTxns3: FileTransaction = { +export const fileTxns3: FileTransaction = deepFreeze({ txns: [splitExpenseTxn1, { ...splitExpenseTxn1_1, id: 'tx12SqYytrm' }], files: [ { @@ -420,13 +422,13 @@ export const fileTxns3: FileTransaction = { content: 'someData', }, ], -}; +}); -export const fileTxns4: FileTransaction = { +export const fileTxns4: FileTransaction = deepFreeze({ txns: [splitExpenseTxn1, { ...splitExpenseTxn1_1, id: 'tx12SqYytrm' }], -}; +}); -export const fileTxns5: FileTransaction = { +export const fileTxns5: FileTransaction = deepFreeze({ txns: [ splitExpenseTxn2, { ...splitExpenseTxn2_2, id: 'tx78mWdbfw1N' }, @@ -439,9 +441,9 @@ export const fileTxns5: FileTransaction = { content: 'someContent', }, ], -}; +}); -export const fileTxns6: FileTransaction = { +export const fileTxns6: FileTransaction = deepFreeze({ txns: [ splitExpenseTxn2, { ...splitExpenseTxn2_2, id: 'tx78mWdbfw1N' }, @@ -454,9 +456,9 @@ export const fileTxns6: FileTransaction = { content: 'someData', }, ], -}; +}); -export const fileTxns7: FileTransaction = { +export const fileTxns7: FileTransaction = deepFreeze({ txns: [ { created_at: new Date('2023-06-22T04:13:28.899Z'), @@ -635,4 +637,4 @@ export const fileTxns7: FileTransaction = { locations: [], }, ], -}; +}); diff --git a/src/app/core/mock-data/file.data.ts b/src/app/core/mock-data/file.data.ts index 0aad6c231e..65ee47177d 100644 --- a/src/app/core/mock-data/file.data.ts +++ b/src/app/core/mock-data/file.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { File } from '../models/file.model'; -export const fileData1: File[] = [ +export const fileData1: File[] = deepFreeze([ { id: 'fi1w2IE6JeqS', org_user_id: 'ouX8dwsbLCLv', @@ -16,9 +18,9 @@ export const fileData1: File[] = [ email_meta_data: null, fyle_sub_url: '/api/files/fi1w2IE6JeqS/download', }, -]; +]); -export const fileData2: File[] = [ +export const fileData2: File[] = deepFreeze([ { id: 'fiK7c69UDJNb', org_user_id: 'ouX8dwsbLCLv', @@ -34,9 +36,9 @@ export const fileData2: File[] = [ email_meta_data: null, fyle_sub_url: '/api/files/fiK7c69UDJNb/download', }, -]; +]); -export const fileData3: File[] = [ +export const fileData3: File[] = deepFreeze([ { id: 'fiV1gXpyCcbU', org_user_id: 'ouX8dwsbLCLv', @@ -52,4 +54,4 @@ export const fileData3: File[] = [ email_meta_data: null, fyle_sub_url: '/api/files/fiV1gXpyCcbU/download', }, -]; +]); diff --git a/src/app/core/mock-data/filter-options.data.ts b/src/app/core/mock-data/filter-options.data.ts index 3b063fe49d..baa3cd67b9 100644 --- a/src/app/core/mock-data/filter-options.data.ts +++ b/src/app/core/mock-data/filter-options.data.ts @@ -1,3 +1,5 @@ +import deepFreeze from 'deep-freeze-strict'; + import { FilterOptionType } from 'src/app/shared/components/fy-filters/filter-option-type.enum'; import { FilterOptions } from 'src/app/shared/components/fy-filters/filter-options.interface'; import { AdvancesStates } from '../models/advances-states.model'; @@ -5,7 +7,7 @@ import { SortingValue } from '../models/sorting-value.model'; import { DateFilters } from 'src/app/shared/components/fy-filters/date-filters.enum'; import { ExpenseType } from '../enums/expense-type.enum'; -export const filterOptions: FilterOptions[] = [ +export const filterOptions: FilterOptions[] = deepFreeze([ { name: 'State', optionType: FilterOptionType.multiselect, @@ -51,9 +53,9 @@ export const filterOptions: FilterOptions[] = [ }, ], }, -]; +]); -export const filterOptions2: FilterOptions[] = [ +export const filterOptions2: FilterOptions[] = deepFreeze([ { name: 'Type', optionType: FilterOptionType.multiselect, @@ -178,9 +180,9 @@ export const filterOptions2: FilterOptions[] = [ }, ], }, -]; +]); -export const filterOptions3: FilterOptions[] = [ +export const filterOptions3: FilterOptions[] = deepFreeze([ { name: 'Type', optionType: FilterOptionType.multiselect, @@ -305,4 +307,4 @@ export const filterOptions3: FilterOptions[] = [ }, ], }, -]; +]); diff --git a/src/app/core/mock-data/filter-pills.data.ts b/src/app/core/mock-data/filter-pills.data.ts index 0c8bb1c1ea..bd95e42849 100644 --- a/src/app/core/mock-data/filter-pills.data.ts +++ b/src/app/core/mock-data/filter-pills.data.ts @@ -1,22 +1,24 @@ +import deepFreeze from 'deep-freeze-strict'; + import { FilterPill } from 'src/app/shared/components/fy-filter-pills/filter-pill.interface'; -export const creditTxnFilterPill: FilterPill[] = [ +export const creditTxnFilterPill: FilterPill[] = deepFreeze([ { label: 'Transactions Type', type: 'string', value: 'Credit', }, -]; +]); -export const debitTxnFilterPill: FilterPill[] = [ +export const debitTxnFilterPill: FilterPill[] = deepFreeze([ { label: 'Transactions Type', type: 'string', value: 'Debit', }, -]; +]); -export const allFilterPills: FilterPill[] = [ +export const allFilterPills: FilterPill[] = deepFreeze([ { label: 'Created On', type: 'date', @@ -32,9 +34,9 @@ export const allFilterPills: FilterPill[] = [ type: 'string', value: 'Debit', }, -]; +]); -export const taskFiltersPills: FilterPill[] = [ +export const taskFiltersPills: FilterPill[] = deepFreeze([ { label: 'Expenses', type: 'Expenses', @@ -50,8 +52,8 @@ export const taskFiltersPills: FilterPill[] = [ type: 'Advances', value: 'Sent Back', }, -]; -export const expectedFilterPill1: FilterPill[] = [ +]); +export const expectedFilterPill1: FilterPill[] = deepFreeze([ { label: 'Type', type: 'state', @@ -82,9 +84,9 @@ export const expectedFilterPill1: FilterPill[] = [ type: 'splitExpense', value: 'yes', }, -]; +]); -export const expectedFilterPill2: FilterPill[] = [ +export const expectedFilterPill2: FilterPill[] = deepFreeze([ { label: 'Receipts Attached', type: 'receiptsAttached', @@ -100,103 +102,103 @@ export const expectedFilterPill2: FilterPill[] = [ type: 'splitExpense', value: 'yes', }, -]; +]); -export const stateFilterPill: FilterPill = { +export const stateFilterPill: FilterPill = deepFreeze({ label: 'Type', type: 'state', value: 'Incomplete, Complete', -}; +}); -export const receiptsAttachedFilterPill: FilterPill = { +export const receiptsAttachedFilterPill: FilterPill = deepFreeze({ label: 'Receipts Attached', type: 'receiptsAttached', value: 'yes', -}; +}); -export const dateFilterPill: FilterPill[] = [ +export const dateFilterPill: FilterPill[] = deepFreeze([ { label: 'Date', type: 'date', value: 'this Week', }, -]; +]); -export const typeFilterPill: FilterPill = { +export const typeFilterPill: FilterPill = deepFreeze({ label: 'Expense Type', type: 'type', value: 'Per Diem, Mileage', -}; +}); -export const sortFilterPill: FilterPill = { +export const sortFilterPill: FilterPill = deepFreeze({ label: 'Sort By', type: 'sort', value: 'category - a to z', -}; +}); -export const cardFilterPill: FilterPill = { +export const cardFilterPill: FilterPill = deepFreeze({ label: 'Cards', type: 'cardNumbers', value: '****1234, ****5678', -}; +}); -export const splitExpenseFilterPill: FilterPill = { +export const splitExpenseFilterPill: FilterPill = deepFreeze({ label: 'Split Expense', type: 'splitExpense', value: 'yes', -}; +}); -export const filterTypeMappings: FilterPill[] = [ +export const filterTypeMappings: FilterPill[] = deepFreeze([ stateFilterPill, receiptsAttachedFilterPill, typeFilterPill, dateFilterPill[0], sortFilterPill, splitExpenseFilterPill, -]; +]); -export const sortByDescFilterPill: FilterPill[] = [ +export const sortByDescFilterPill: FilterPill[] = deepFreeze([ { label: 'Sort By', type: 'sort', value: 'amount - high to low', }, -]; +]); -export const sortByAscFilterPill: FilterPill[] = [ +export const sortByAscFilterPill: FilterPill[] = deepFreeze([ { label: 'Sort By', type: 'sort', value: 'amount - low to high', }, -]; +]); -export const sortByDateAscFilterPill: FilterPill[] = [ +export const sortByDateAscFilterPill: FilterPill[] = deepFreeze([ { label: 'Sort By', type: 'sort', value: 'date - old to new', }, -]; +]); -export const sortByDateDescFilterPill: FilterPill[] = [ +export const sortByDateDescFilterPill: FilterPill[] = deepFreeze([ { label: 'Sort By', type: 'sort', value: 'date - new to old', }, -]; +]); -export const expectedDateFilterPill = [ +export const expectedDateFilterPill = deepFreeze([ { label: 'Date', type: 'date', value: '2023-01-21 to 2023-01-31', }, -]; +]); -export const stateFilterPill2: FilterPill = { +export const stateFilterPill2: FilterPill = deepFreeze({ label: 'Type', type: 'state', value: 'Incomplete, Complete, approved', -}; +}); diff --git a/src/app/core/mock-data/filter.data.ts b/src/app/core/mock-data/filter.data.ts index bb9f3c4d17..fef05aebd8 100644 --- a/src/app/core/mock-data/filter.data.ts +++ b/src/app/core/mock-data/filter.data.ts @@ -1,3 +1,5 @@ +import deepFreeze from 'deep-freeze-strict'; + import { FilterOptionType } from 'src/app/shared/components/fy-filters/filter-option-type.enum'; import { FilterOptions } from 'src/app/shared/components/fy-filters/filter-options.interface'; @@ -16,7 +18,7 @@ type Filter = Partial<{ transactionType: string; }>; -export const filterData1: Filter = { +export const filterData1: Filter = deepFreeze({ createdOn: { name: 'custom', customDateStart: new Date('2023-02-20T00:00:00.000Z'), @@ -28,9 +30,9 @@ export const filterData1: Filter = { customDateEnd: new Date('2023-02-24T00:00:00.000Z'), }, transactionType: 'Debit', -}; +}); -export const filterOptions1 = [ +export const filterOptions1 = deepFreeze([ { name: 'Type', optionType: FilterOptionType.multiselect, @@ -99,4 +101,4 @@ export const filterOptions1 = [ }, ], } as FilterOptions, -]; +]); diff --git a/src/app/core/mock-data/filtered-missing-fields-violations.data.ts b/src/app/core/mock-data/filtered-missing-fields-violations.data.ts index 1fb776caa1..73b5494714 100644 --- a/src/app/core/mock-data/filtered-missing-fields-violations.data.ts +++ b/src/app/core/mock-data/filtered-missing-fields-violations.data.ts @@ -1,18 +1,20 @@ +import deepFreeze from 'deep-freeze-strict'; + import { FilteredMissingFieldsViolations } from '../models/filtered-missing-fields-violations.model'; -export const filteredMissingFieldsViolationsData: FilteredMissingFieldsViolations = { +export const filteredMissingFieldsViolationsData: FilteredMissingFieldsViolations = deepFreeze({ isMissingFields: false, type: 'category', name: 'food', currency: 'USD', amount: 67.8, isExpanded: false, -}; +}); -export const filteredMissingFieldsViolationsData2: FilteredMissingFieldsViolations = { +export const filteredMissingFieldsViolationsData2: FilteredMissingFieldsViolations = deepFreeze({ isMissingFields: true, type: 'category', name: 'Food', currency: 'INR', amount: 122, -}; +}); diff --git a/src/app/core/mock-data/filtered-split-policy-violations.data.ts b/src/app/core/mock-data/filtered-split-policy-violations.data.ts index af87020ca3..2284bb03f5 100644 --- a/src/app/core/mock-data/filtered-split-policy-violations.data.ts +++ b/src/app/core/mock-data/filtered-split-policy-violations.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { FilteredSplitPolicyViolations } from '../models/filtered-split-policy-violations.model'; -export const filteredSplitPolicyViolationsData: FilteredSplitPolicyViolations = { +export const filteredSplitPolicyViolationsData: FilteredSplitPolicyViolations = deepFreeze({ rules: ['rule1', 'rule2', 'rule3'], action: { final_desired_state: { @@ -20,9 +22,9 @@ export const filteredSplitPolicyViolationsData: FilteredSplitPolicyViolations = amount: 45, isCriticalPolicyViolation: false, isExpanded: false, -}; +}); -export const filteredSplitPolicyViolationsData2: FilteredSplitPolicyViolations = { +export const filteredSplitPolicyViolationsData2: FilteredSplitPolicyViolations = deepFreeze({ action: { final_desired_state: { add_approver_user_ids: [], @@ -63,4 +65,4 @@ export const filteredSplitPolicyViolationsData2: FilteredSplitPolicyViolations = currency: 'INR', amount: 240000, isCriticalPolicyViolation: true, -}; +}); diff --git a/src/app/core/mock-data/form-value.data.ts b/src/app/core/mock-data/form-value.data.ts index 54af6e8e99..3a2d432f83 100644 --- a/src/app/core/mock-data/form-value.data.ts +++ b/src/app/core/mock-data/form-value.data.ts @@ -1,3 +1,5 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CommuteDeduction } from '../enums/commute-deduction.enum'; import { paymentModeDataPersonal } from '../test-data/accounts.service.spec.data'; import { expectedProjectsResponse } from '../test-data/projects.spec.data'; @@ -6,7 +8,7 @@ import { locationData1, locationData2 } from './location.data'; import { unfilteredMileageRatesData } from './mileage-rate.data'; import { orgCategoryData } from './org-category.data'; -export const formValue1 = { +export const formValue1 = deepFreeze({ mileage_rate_name: unfilteredMileageRatesData[0], route: { mileageLocations: [locationData1, locationData2], @@ -20,9 +22,9 @@ export const formValue1 = { purpose: 'travel', costCenter: costCentersData[0], commuteDeduction: CommuteDeduction.ONE_WAY, -}; +}); -export const formValue2 = { +export const formValue2 = deepFreeze({ mileage_rate_name: null, route: { mileageLocations: null, @@ -35,4 +37,4 @@ export const formValue2 = { project: expectedProjectsResponse[0], purpose: 'travel', costCenter: costCentersData[0], -}; +}); diff --git a/src/app/core/mock-data/formatted-policy-violation.data.ts b/src/app/core/mock-data/formatted-policy-violation.data.ts index 1e02d96e1a..aea5561bbc 100644 --- a/src/app/core/mock-data/formatted-policy-violation.data.ts +++ b/src/app/core/mock-data/formatted-policy-violation.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { FormattedPolicyViolation } from '../models/formatted-policy-violation.model'; -export const formattedPolicyViolation1: FormattedPolicyViolation = { +export const formattedPolicyViolation1: FormattedPolicyViolation = deepFreeze({ rules: [ 'The expense will be flagged, employee will be alerted, expense will be made unreportable and expense amount will be capped to the amount limit when expense amount in category 1 / chumma returns/1 / sd/1 / sub 123/aniruddha test / aniruddha sub/Food/Food / Travelling - Inland/Snacks/Stuff/te knklw/TEst Cateogory / 12 exceeds: INR 1000 and are fyled from Paid by Employee payment mode(s). ', ], @@ -42,9 +44,9 @@ export const formattedPolicyViolation1: FormattedPolicyViolation = { amount: 240000, isCriticalPolicyViolation: true, isExpanded: false, -}; +}); -export const formattedPolicyViolation2: FormattedPolicyViolation = { +export const formattedPolicyViolation2: FormattedPolicyViolation = deepFreeze({ rules: [ 'The expense will be flagged, employee will be alerted, expense will be made unreportable and expense amount will be capped to the amount limit when expense amount in category 1 / chumma returns/1 / sd/1 / sub 123/aniruddha test / aniruddha sub/Food/Food / Travelling - Inland/Snacks/Stuff/te knklw/TEst Cateogory / 12 exceeds: INR 1000 and are fyled from Paid by Employee payment mode(s). ', ], @@ -98,14 +100,14 @@ export const formattedPolicyViolation2: FormattedPolicyViolation = { amount: 160000, isCriticalPolicyViolation: true, isExpanded: false, -}; +}); -export const formattedTxnViolations = { +export const formattedTxnViolations = deepFreeze({ txc2KIogxUAy: formattedPolicyViolation1, txgfkvuYteta: formattedPolicyViolation2, -}; +}); -export const formattedTxnViolations2 = { +export const formattedTxnViolations2 = deepFreeze({ txc2KIogxUAy: { ...formattedPolicyViolation1, isCriticalPolicyViolation: false }, txgfkvuYteta: { ...formattedPolicyViolation2, isCriticalPolicyViolation: false }, -}; +}); diff --git a/src/app/core/mock-data/generated-form-properties.data.ts b/src/app/core/mock-data/generated-form-properties.data.ts index f94bf9045a..11e3c217d9 100644 --- a/src/app/core/mock-data/generated-form-properties.data.ts +++ b/src/app/core/mock-data/generated-form-properties.data.ts @@ -1,8 +1,10 @@ +import deepFreeze from 'deep-freeze-strict'; + import { GeneratedFormProperties } from '../models/generated-form-properties.model'; import { dependentCustomProperties } from './custom-property.data'; import { optionsData15, optionsData33 } from './merge-expenses-options-data.data'; -export const generatedFormPropertiesData1: GeneratedFormProperties = { +export const generatedFormPropertiesData1: GeneratedFormProperties = deepFreeze({ source_account_id: '1234', billable: true, currency: 'INR', @@ -37,9 +39,9 @@ export const generatedFormPropertiesData1: GeneratedFormProperties = { distance: 100, distance_unit: 'KM', locations: [optionsData15.value, optionsData33.value], -}; +}); -export const generatedFormPropertiesData2: GeneratedFormProperties = { +export const generatedFormPropertiesData2: GeneratedFormProperties = deepFreeze({ source_account_id: 'accDDeaVIs6p6', billable: undefined, currency: 'USD', @@ -76,9 +78,9 @@ export const generatedFormPropertiesData2: GeneratedFormProperties = { distance: undefined, distance_unit: undefined, locations: [optionsData15.options[0].value, optionsData33.options[0].value], -}; +}); -export const generatedFormPropertiesData3: GeneratedFormProperties = { +export const generatedFormPropertiesData3: GeneratedFormProperties = deepFreeze({ source_account_id: 'accDDeaVIs6p6', billable: undefined, currency: 'USD', @@ -113,16 +115,16 @@ export const generatedFormPropertiesData3: GeneratedFormProperties = { distance: undefined, distance_unit: undefined, locations: [optionsData15.options[0].value, optionsData33.options[0].value], -}; +}); -export const generatedFormPropertiesData4: GeneratedFormProperties = { +export const generatedFormPropertiesData4: GeneratedFormProperties = deepFreeze({ ...generatedFormPropertiesData3, source_account_id: undefined, currency: undefined, amount: undefined, -}; +}); -export const generatedFormPropertiesData5: GeneratedFormProperties = { +export const generatedFormPropertiesData5: GeneratedFormProperties = deepFreeze({ source_account_id: 'accDDeaVIs6p6', billable: undefined, currency: 'USD', @@ -148,4 +150,4 @@ export const generatedFormPropertiesData5: GeneratedFormProperties = { distance: undefined, distance_unit: undefined, locations: [optionsData15.options[0].value, optionsData33.options[0].value], -}; +}); diff --git a/src/app/core/mock-data/get-expenses-query-params-with-filters.data.ts b/src/app/core/mock-data/get-expenses-query-params-with-filters.data.ts index 6f0402ffe7..873efc6470 100644 --- a/src/app/core/mock-data/get-expenses-query-params-with-filters.data.ts +++ b/src/app/core/mock-data/get-expenses-query-params-with-filters.data.ts @@ -1,47 +1,49 @@ +import deepFreeze from 'deep-freeze-strict'; + import { GetExpensesQueryParamsWithFilters } from '../models/get-expenses-query-params-with-filters.model'; import { GetExpenseQueryParam } from '../models/platform/v1/get-expenses-query.model'; -export const expectedCurrentParams: Partial = { +export const expectedCurrentParams: Partial = deepFreeze({ sortDir: 'asc', queryParams: { corporate_credit_card_account_number: 'in.(789)', and: '(tx_txn_dt.gte.March,tx_txn_dt.lt.April)', or: ['(tx_is_split_expense.eq.true)'], }, -}; +}); -export const expectedCurrentParamsWoFilterState: Partial = { +export const expectedCurrentParamsWoFilterState: Partial = deepFreeze({ sortDir: 'asc', queryParams: { or: ['(is_split.eq.true)'], 'matched_corporate_card_transactions->0->corporate_card_number': 'in.(789)', and: '(spent_at.gte.March,spent_at.lt.April)', }, -}; +}); -export const expectedCurrentParamsDraftState: Partial = { +export const expectedCurrentParamsDraftState: Partial = deepFreeze({ sortDir: 'asc', queryParams: { or: ['(is_split.eq.true)'], 'matched_corporate_card_transactions->0->corporate_card_number': 'in.(789)', and: '(spent_at.gte.March,spent_at.lt.April)', }, -}; +}); -export const expectedCurrentParamsCannotReportState: Partial = { +export const expectedCurrentParamsCannotReportState: Partial = deepFreeze({ sortDir: 'asc', queryParams: { or: ['(is_split.eq.true)'], 'matched_corporate_card_transactions->0->corporate_card_number': 'in.(789)', and: '(spent_at.gte.March,spent_at.lt.April)', }, -}; +}); -export const expectedCurrentParamsWithDraftCannotReportState: Partial = { +export const expectedCurrentParamsWithDraftCannotReportState: Partial = deepFreeze({ sortDir: 'asc', queryParams: { or: ['(is_split.eq.true)'], 'matched_corporate_card_transactions->0->corporate_card_number': 'in.(789)', and: '(spent_at.gte.March,spent_at.lt.April)', }, -}; +}); diff --git a/src/app/core/mock-data/get-tasks-query-params-with-filters.data.ts b/src/app/core/mock-data/get-tasks-query-params-with-filters.data.ts index e87cc1ca99..2f3294279d 100644 --- a/src/app/core/mock-data/get-tasks-query-params-with-filters.data.ts +++ b/src/app/core/mock-data/get-tasks-query-params-with-filters.data.ts @@ -1,21 +1,23 @@ +import deepFreeze from 'deep-freeze-strict'; + import { GetTasksQueryParamsWithFilters } from '../models/get-tasks-query-params-with-filters.model'; -export const tasksQueryParamsWithFiltersData: Partial = { +export const tasksQueryParamsWithFiltersData: Partial = deepFreeze({ pageNumber: 1, sortDir: 'asc', searchString: 'example', queryParams: { rp_state: 'in.(APPROVER_PENDING)', }, -}; +}); -export const tasksQueryParamsWithFiltersData2: Partial = { +export const tasksQueryParamsWithFiltersData2: Partial = deepFreeze({ pageNumber: 1, sortDir: 'asc', sortParam: 'approvalDate', -}; +}); -export const tasksQueryParamsWithFiltersData3: Partial = { +export const tasksQueryParamsWithFiltersData3: Partial = deepFreeze({ pageNumber: 1, sortDir: 'desc', searchString: 'example', @@ -24,13 +26,13 @@ export const tasksQueryParamsWithFiltersData3: Partial = { +export const tasksQueryParamsParams: Partial = deepFreeze({ rp_approval_state: 'in.(APPROVAL_PENDING)', rp_state: 'in.(APPROVER_PENDING)', sequential_approval_turn: 'in.(true)', -}; +}); -export const teamReportsQueryParams: Partial = { +export const teamReportsQueryParams: Partial = deepFreeze({ or: [], and: '(rp_submitted_at.gte.2023-01-01T00:00:00.000Z,rp_submitted_at.lt.2023-01-04T00:00:00.000Z)', -}; +}); -export const teamReportsQueryParams2: Partial = { +export const teamReportsQueryParams2: Partial = deepFreeze({ or: [], and: '(rp_submitted_at.gte.2023-01-01T00:00:00.000Z)', -}; +}); -export const teamReportsQueryParams3: Partial = { +export const teamReportsQueryParams3: Partial = deepFreeze({ or: [], and: '(rp_submitted_at.lt.2023-01-04T00:00:00.000Z)', -}; +}); diff --git a/src/app/core/mock-data/individual-expense-policy-state.data.ts b/src/app/core/mock-data/individual-expense-policy-state.data.ts index d48e2f14dd..bc051ba573 100644 --- a/src/app/core/mock-data/individual-expense-policy-state.data.ts +++ b/src/app/core/mock-data/individual-expense-policy-state.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { IndividualExpensePolicyState } from '../models/platform/platform-individual-expense-policy-state.model'; -export const individualExpPolicyStateData1: IndividualExpensePolicyState = { +export const individualExpPolicyStateData1: IndividualExpensePolicyState = deepFreeze({ add_approver_user_ids: [], amount: 0, expense_policy_rule: { @@ -15,9 +17,9 @@ export const individualExpPolicyStateData1: IndividualExpensePolicyState = { 'expense could not be added to a report or submitted', ], run_status: 'VIOLATED_ACTION_SUCCESS', -}; +}); -export const individualExpPolicyStateData2: IndividualExpensePolicyState[] = [ +export const individualExpPolicyStateData2: IndividualExpensePolicyState[] = deepFreeze([ { add_approver_user_ids: [], amount: 0, @@ -46,9 +48,9 @@ export const individualExpPolicyStateData2: IndividualExpensePolicyState[] = [ run_result: ['expense will be flagged for verification and approval'], run_status: 'VIOLATED_ACTION_SUCCESS', }, -]; +]); -export const individualExpPolicyStateData3: IndividualExpensePolicyState[] = [ +export const individualExpPolicyStateData3: IndividualExpensePolicyState[] = deepFreeze([ { add_approver_user_ids: [], amount: null, @@ -75,4 +77,4 @@ export const individualExpPolicyStateData3: IndividualExpensePolicyState[] = [ run_result: ['expense will be flagged for verification and approval'], run_status: 'VIOLATED_ACTION_SUCCESS', }, -]; +]); diff --git a/src/app/core/mock-data/info-card-data.data.ts b/src/app/core/mock-data/info-card-data.data.ts index ac7992a223..bd4ead084c 100644 --- a/src/app/core/mock-data/info-card-data.data.ts +++ b/src/app/core/mock-data/info-card-data.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { InfoCardData } from '../models/info-card-data.model'; -export const allInfoCardsData: InfoCardData[] = [ +export const allInfoCardsData: InfoCardData[] = deepFreeze([ { title: 'Message Receipts', content: 'Message your receipts to Fyle at (302) 440-2921.', @@ -15,4 +17,4 @@ export const allInfoCardsData: InfoCardData[] = [ toastMessageContent: 'Email Copied Successfully', isShown: true, }, -]; +]); diff --git a/src/app/core/mock-data/ld-all-flags.data.ts b/src/app/core/mock-data/ld-all-flags.data.ts index 7229de77e5..491d2ed07c 100644 --- a/src/app/core/mock-data/ld-all-flags.data.ts +++ b/src/app/core/mock-data/ld-all-flags.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import * as LDClient from 'launchdarkly-js-client-sdk'; -export const ldAllFlagsRes: LDClient.LDFlagValue = { +export const ldAllFlagsRes: LDClient.LDFlagValue = deepFreeze({ approve_report_and_next_enabled: true, automate_report_submission_enabled: true, automate_reports_weekly: true, @@ -20,4 +22,4 @@ export const ldAllFlagsRes: LDClient.LDFlagValue = { payment_mode_configurations: true, remove_offline_forms: true, upload_receipt_first_flow: false, -}; +}); diff --git a/src/app/core/mock-data/ld-client-user.data.ts b/src/app/core/mock-data/ld-client-user.data.ts index 499cceecb5..3520794209 100644 --- a/src/app/core/mock-data/ld-client-user.data.ts +++ b/src/app/core/mock-data/ld-client-user.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import * as LDClient from 'launchdarkly-js-client-sdk'; -export const lDUser: LDClient.LDUser = { +export const lDUser: LDClient.LDUser = deepFreeze({ key: 'usvKA4X8Ugcr', custom: { org_id: 'orNVthTo2Zyo', @@ -9,4 +11,4 @@ export const lDUser: LDClient.LDUser = { org_created_at: '2018-01-31T23:50:27.216Z', asset: 'MOBILE - WEB', }, -}; +}); diff --git a/src/app/core/mock-data/location.data.ts b/src/app/core/mock-data/location.data.ts index e92bf619f9..c2cfd1c1df 100644 --- a/src/app/core/mock-data/location.data.ts +++ b/src/app/core/mock-data/location.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Position } from '@capacitor/geolocation'; import { Location } from '../models/location.model'; import { PredictedLocation } from '../models/predicted-location.model'; -export const locationData1: Location = { +export const locationData1: Location = deepFreeze({ city: 'Kolkata', state: 'West Bengal', country: 'India', @@ -9,9 +11,9 @@ export const locationData1: Location = { latitude: 22.4986357, longitude: 88.3453906, display: 'Tollygunge, Kolkata, West Bengal, India', -}; +}); -export const locationData2: Location = { +export const locationData2: Location = deepFreeze({ city: 'Kolkata', state: 'West Bengal', country: 'India', @@ -19,9 +21,9 @@ export const locationData2: Location = { latitude: 22.5851477, longitude: 88.34680530000001, display: 'Howrah Bridge, Kolkata, West Bengal, India', -}; +}); -export const locationData3: Location = { +export const locationData3: Location = deepFreeze({ city: 'Kolkata', state: 'West Bengal', country: 'India', @@ -29,9 +31,9 @@ export const locationData3: Location = { latitude: 22.5474164, longitude: 88.3598025, display: 'Park Street, Mullick Bazar, Beniapukur, Kolkata, West Bengal, India', -}; +}); -export const locationData4: Location = { +export const locationData4: Location = deepFreeze({ city: 'Thane', state: 'Maharashtra', country: 'India', @@ -39,9 +41,9 @@ export const locationData4: Location = { latitude: 19.2183307, longitude: 72.9780897, display: 'Thane, Maharashtra, India', -}; +}); -export const predictedLocation1: PredictedLocation[] = [ +export const predictedLocation1: PredictedLocation[] = deepFreeze([ { description: 'Bengaluru, Karnataka, India', matched_substrings: [ @@ -158,9 +160,9 @@ export const predictedLocation1: PredictedLocation[] = [ ], types: ['locality', 'political', 'geocode'], }, -]; +]); -export const coordinatesData1: Position = { +export const coordinatesData1: Position = deepFreeze({ timestamp: Date.now(), coords: { latitude: 10.12, @@ -171,9 +173,9 @@ export const coordinatesData1: Position = { speed: 0.099, heading: 0, }, -}; +}); -export const coordinatesData2: Position = { +export const coordinatesData2: Position = deepFreeze({ timestamp: Date.now(), coords: { latitude: 19.0748, @@ -184,4 +186,4 @@ export const coordinatesData2: Position = { speed: 0.099, heading: 0, }, -}; +}); diff --git a/src/app/core/mock-data/matchedCCCTransaction.data.ts b/src/app/core/mock-data/matchedCCCTransaction.data.ts index c5da5a2621..39a9827b55 100644 --- a/src/app/core/mock-data/matchedCCCTransaction.data.ts +++ b/src/app/core/mock-data/matchedCCCTransaction.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { MatchedCCCTransaction } from '../models/matchedCCCTransaction.model'; -export const matchedCCCTransactionData1: MatchedCCCTransaction = { +export const matchedCCCTransactionData1: MatchedCCCTransaction = deepFreeze({ amount: -680.62, balance_transfer_id: null, card_or_account_number: '9880', @@ -18,4 +20,4 @@ export const matchedCCCTransactionData1: MatchedCCCTransaction = { txn_dt: '2019-07-13T00:00:00.000Z', updated_at: '2023-07-17T13:24:47.274Z', vendor: 'HOTEL MARRIOT', -}; +}); diff --git a/src/app/core/mock-data/matchedCCTransaction.data.ts b/src/app/core/mock-data/matchedCCTransaction.data.ts index 8706805b22..3825691038 100644 --- a/src/app/core/mock-data/matchedCCTransaction.data.ts +++ b/src/app/core/mock-data/matchedCCTransaction.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { MatchedCCCTransaction } from '../models/matchedCCCTransaction.model'; import { TransactionStatus } from '../models/platform/v1/expense.model'; -export const matchedCCTransactionData: Partial = { +export const matchedCCTransactionData: Partial = deepFreeze({ id: 'btxnSte7sVQCM8', group_id: 'btxnSte7sVQCM8', amount: 260.37, @@ -15,9 +17,9 @@ export const matchedCCTransactionData: Partial = { orig_currency: null, status: TransactionStatus.PENDING, displayObject: 'Jul 3, 2018 - test description260.37', -}; +}); -export const matchedCCTransactionData2: Partial = { +export const matchedCCTransactionData2: Partial = deepFreeze({ id: 'btxnBdS2Kpvzhy', group_id: 'btxnBdS2Kpvzhy', amount: 205.21, @@ -31,9 +33,9 @@ export const matchedCCTransactionData2: Partial = { orig_currency: null, status: TransactionStatus.PENDING, displayObject: 'Jun 6, 2018 - test description205.21', -}; +}); -export const matchedCCTransactionData3: Partial = { +export const matchedCCTransactionData3: Partial = deepFreeze({ id: 'btxnBdS2Kpvzhy', group_id: 'btxnBdS2Kpvzhy', created_at: '2024-01-23T12:17:34.473632+00:00', @@ -50,4 +52,4 @@ export const matchedCCTransactionData3: Partial = { orig_amount: null, orig_currency: null, status: undefined, -}; +}); diff --git a/src/app/core/mock-data/merge-expense-form-data.data.ts b/src/app/core/mock-data/merge-expense-form-data.data.ts index 8657bb73bf..e6580d83c2 100644 --- a/src/app/core/mock-data/merge-expense-form-data.data.ts +++ b/src/app/core/mock-data/merge-expense-form-data.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { optionsData15, optionsData33 } from './merge-expenses-options-data.data'; -export const mergeExpenseFormData1 = { +export const mergeExpenseFormData1 = deepFreeze({ genericFields: { paymentMode: 'CORPORATE_CARD', amount: 'tx3nHShG60zq', @@ -23,9 +25,9 @@ export const mergeExpenseFormData1 = { location_1: optionsData15.options[0].value, location_2: optionsData33.options[0].value, }, -}; +}); -export const mergeExpenseFormData2 = { +export const mergeExpenseFormData2 = deepFreeze({ genericFields: { paymentMode: 'CORPORATE_CARD', amount: 'tx3nHShG60zq', @@ -47,9 +49,9 @@ export const mergeExpenseFormData2 = { categoryDependent: { location_1: optionsData15.options[0].value, }, -}; +}); -export const mergeExpenseFormData3 = { +export const mergeExpenseFormData3 = deepFreeze({ genericFields: { paymentMode: 'CORPORATE_CARD', amount: 'tx3nHShG60zq', @@ -69,9 +71,9 @@ export const mergeExpenseFormData3 = { ], }, categoryDependent: {}, -}; +}); -export const mergeExpenseFormData4 = { +export const mergeExpenseFormData4 = deepFreeze({ genericFields: { paymentMode: 'CORPORATE_CARD', amount: 'tx3nHShG60zq', @@ -92,9 +94,9 @@ export const mergeExpenseFormData4 = { location_1: optionsData15.options[0].value, location_2: optionsData33.options[0].value, }, -}; +}); -export const mergeExpenseFormData5 = { +export const mergeExpenseFormData5 = deepFreeze({ genericFields: { paymentMode: 'CORPORATE_CARD', amount: 'tx3nHShG6035', @@ -115,4 +117,4 @@ export const mergeExpenseFormData5 = { location_1: optionsData15.options[0].value, location_2: optionsData33.options[0].value, }, -}; +}); diff --git a/src/app/core/mock-data/merge-expenses-custom-inputs.data.ts b/src/app/core/mock-data/merge-expenses-custom-inputs.data.ts index f87fbc2165..5b6afc2447 100644 --- a/src/app/core/mock-data/merge-expenses-custom-inputs.data.ts +++ b/src/app/core/mock-data/merge-expenses-custom-inputs.data.ts @@ -1,4 +1,6 @@ -export const mergeExpenesesCustomInputsData = [ +import deepFreeze from 'deep-freeze-strict'; + +export const mergeExpenesesCustomInputsData = deepFreeze([ [ { name: 'status', @@ -13,4 +15,4 @@ export const mergeExpenesesCustomInputsData = [ value: null, }, ], -]; +]); diff --git a/src/app/core/mock-data/merge-expenses-option.data.ts b/src/app/core/mock-data/merge-expenses-option.data.ts index 8f87461a19..9d3e34e996 100644 --- a/src/app/core/mock-data/merge-expenses-option.data.ts +++ b/src/app/core/mock-data/merge-expenses-option.data.ts @@ -1,46 +1,48 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AccountType } from '../enums/account-type.enum'; import { MergeExpensesOption } from '../models/merge-expenses-option.model'; -export const billableOptions1: MergeExpensesOption = { +export const billableOptions1: MergeExpensesOption = deepFreeze({ label: 'Yes', value: true, -}; +}); -export const billableOptions2: MergeExpensesOption = { +export const billableOptions2: MergeExpensesOption = deepFreeze({ label: 'No', value: false, -}; +}); -export const paymentModeOptions1: MergeExpensesOption = { +export const paymentModeOptions1: MergeExpensesOption = deepFreeze({ label: 'Personal Card/Cash', value: AccountType.PERSONAL, -}; +}); -export const paymentModeOptions2: MergeExpensesOption = { +export const paymentModeOptions2: MergeExpensesOption = deepFreeze({ label: 'Advance', value: AccountType.ADVANCE, -}; +}); -export const paymentModeOptions3: MergeExpensesOption = { +export const paymentModeOptions3: MergeExpensesOption = deepFreeze({ label: 'Corporate Card', value: AccountType.CCC, -}; +}); -export const sameOptions: MergeExpensesOption[] = [billableOptions1, billableOptions1]; +export const sameOptions: MergeExpensesOption[] = deepFreeze([billableOptions1, billableOptions1]); -export const mergeExpensesOptionsData: MergeExpensesOption[] = [ +export const mergeExpensesOptionsData: MergeExpensesOption[] = deepFreeze([ { label: 'Receipt From Expense 1 ', value: 'tx3nHShG60zq', }, -]; +]); -export const projectOptionsData: MergeExpensesOption = { +export const projectOptionsData: MergeExpensesOption = deepFreeze({ label: 'Staging Project', value: 3943, -}; +}); -export const categoryOptionsData: MergeExpensesOption[] = [ +export const categoryOptionsData: MergeExpensesOption[] = deepFreeze([ { label: 'Food / Travelling - Inland', value: 201952, @@ -49,9 +51,9 @@ export const categoryOptionsData: MergeExpensesOption[] = [ label: 'Unspecified', value: 16582, }, -]; +]); -export const mergeExpensesOptionData1: MergeExpensesOption[] = [ +export const mergeExpensesOptionData1: MergeExpensesOption[] = deepFreeze([ { label: 'Mar 13 ₹1.00 Nilesh As Vendor - Staging Project', value: 'txKJAJ1flx7n', @@ -60,9 +62,9 @@ export const mergeExpensesOptionData1: MergeExpensesOption[] = [ label: 'Mar 08 ₹1.00 Nilesh As Vendor - Staging Project', value: 'txz2vohKxBXu', }, -]; +]); -export const mergeExpensesOptionData2: MergeExpensesOption[] = [ +export const mergeExpensesOptionData2: MergeExpensesOption[] = deepFreeze([ { label: ' Nilesh As Vendor - Staging Project', value: 'txKJAJ1flx7n', @@ -71,9 +73,9 @@ export const mergeExpensesOptionData2: MergeExpensesOption[] = [ label: ' Nilesh As Vendor - Staging Project', value: 'txz2vohKxBXu', }, -]; +]); -export const mergeExpensesOptionData3: MergeExpensesOption[] = [ +export const mergeExpensesOptionData3: MergeExpensesOption[] = deepFreeze([ { label: 'Staging Project', value: '3943', @@ -82,9 +84,9 @@ export const mergeExpensesOptionData3: MergeExpensesOption[] = [ label: 'Staging Project', value: '3943', }, -]; +]); -export const mergeExpensesOptionData4: MergeExpensesOption[] = [ +export const mergeExpensesOptionData4: MergeExpensesOption[] = deepFreeze([ { label: 'Food', value: 201952, @@ -93,9 +95,9 @@ export const mergeExpensesOptionData4: MergeExpensesOption[] = [ label: 'Hotel', value: 16582, }, -]; +]); -export const mergeExpensesOptionData5: MergeExpensesOption[] = [ +export const mergeExpensesOptionData5: MergeExpensesOption[] = deepFreeze([ { label: 'GST', value: 'tgXEJA6YUoZ1', @@ -104,9 +106,9 @@ export const mergeExpensesOptionData5: MergeExpensesOption[] = [ label: 'GST', value: 'tgXEJA6YUoZ1', }, -]; +]); -export const mergeExpensesOptionData6: MergeExpensesOption[] = [ +export const mergeExpensesOptionData6: MergeExpensesOption[] = deepFreeze([ { label: 'ECONOMY', value: 'ECONOMY', @@ -115,9 +117,9 @@ export const mergeExpensesOptionData6: MergeExpensesOption[] = [ label: 'BUSINESS', value: 'BUSINESS', }, -]; +]); -export const mergeExpensesOptionData7: MergeExpensesOption[] = [ +export const mergeExpensesOptionData7: MergeExpensesOption[] = deepFreeze([ { label: 'SLEEPER', value: 'SLEEPER', @@ -126,9 +128,9 @@ export const mergeExpensesOptionData7: MergeExpensesOption[] = [ label: 'SLEEPER', value: 'SLEEPER', }, -]; +]); -export const mergeExpensesOptionData8: MergeExpensesOption[] = [ +export const mergeExpensesOptionData8: MergeExpensesOption[] = deepFreeze([ { label: 'AC', value: 'AC', @@ -137,9 +139,9 @@ export const mergeExpensesOptionData8: MergeExpensesOption[] = [ label: 'AC', value: 'AC', }, -]; +]); -export const mergeExpensesOptionData9: MergeExpensesOption[] = [ +export const mergeExpensesOptionData9: MergeExpensesOption[] = deepFreeze([ { label: '25', value: 25, @@ -148,9 +150,9 @@ export const mergeExpensesOptionData9: MergeExpensesOption[] = [ label: '30', value: 30, }, -]; +]); -export const mergeExpensesOptionData10: MergeExpensesOption[] = [ +export const mergeExpensesOptionData10: MergeExpensesOption[] = deepFreeze([ { label: 'KM', value: 'KM', @@ -159,4 +161,4 @@ export const mergeExpensesOptionData10: MergeExpensesOption[] = [ label: 'MILES', value: 'MILES', }, -]; +]); diff --git a/src/app/core/mock-data/merge-expenses-options-data.data.ts b/src/app/core/mock-data/merge-expenses-options-data.data.ts index 5dd3bd5df8..829fc1665d 100644 --- a/src/app/core/mock-data/merge-expenses-options-data.data.ts +++ b/src/app/core/mock-data/merge-expenses-options-data.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { MergeExpensesOptionsData } from '../models/merge-expenses-options-data.model'; import { Destination } from '../models/destination.model'; -export const optionsData2: MergeExpensesOptionsData = { +export const optionsData2: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'No', @@ -9,9 +11,9 @@ export const optionsData2: MergeExpensesOptionsData = { }, ], areSameValues: false, -}; +}); -export const optionsData3: MergeExpensesOptionsData = { +export const optionsData3: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'INR 1', @@ -23,9 +25,9 @@ export const optionsData3: MergeExpensesOptionsData = { }, ], areSameValues: true, -}; +}); -export const optionsData4: MergeExpensesOptionsData = { +export const optionsData4: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'USD 1 (INR 1)', @@ -37,9 +39,9 @@ export const optionsData4: MergeExpensesOptionsData = { }, ], areSameValues: true, -}; +}); -export const optionsData5: MergeExpensesOptionsData = { +export const optionsData5: MergeExpensesOptionsData = deepFreeze({ options: [ { label: '0', @@ -51,9 +53,9 @@ export const optionsData5: MergeExpensesOptionsData = { }, ], areSameValues: true, -}; +}); -export const optionsData6: MergeExpensesOptionsData = { +export const optionsData6: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'Mar 13, 2023', @@ -65,9 +67,9 @@ export const optionsData6: MergeExpensesOptionsData = { }, ], areSameValues: false, -}; +}); -export const optionsData7: MergeExpensesOptionsData = { +export const optionsData7: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'Corporate Card', @@ -79,9 +81,9 @@ export const optionsData7: MergeExpensesOptionsData = { }, ], areSameValues: false, -}; +}); -export const optionsData8: MergeExpensesOptionsData = { +export const optionsData8: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'Nilesh As Vendor', @@ -93,9 +95,9 @@ export const optionsData8: MergeExpensesOptionsData = { }, ], areSameValues: true, -}; +}); -export const optionsData9: MergeExpensesOptionsData = { +export const optionsData9: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'Staging Project', @@ -107,9 +109,9 @@ export const optionsData9: MergeExpensesOptionsData = { }, ], areSameValues: true, -}; +}); -export const optionsData10: MergeExpensesOptionsData = { +export const optionsData10: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'Food', @@ -121,9 +123,9 @@ export const optionsData10: MergeExpensesOptionsData = { }, ], areSameValues: false, -}; +}); -export const optionsData11: MergeExpensesOptionsData = { +export const optionsData11: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'GST', @@ -135,9 +137,9 @@ export const optionsData11: MergeExpensesOptionsData = { }, ], areSameValues: true, -}; +}); -export const optionsData12: MergeExpensesOptionsData = { +export const optionsData12: MergeExpensesOptionsData = deepFreeze({ options: [ { label: '0.01', @@ -149,9 +151,9 @@ export const optionsData12: MergeExpensesOptionsData = { }, ], areSameValues: true, -}; +}); -export const optionsData13: MergeExpensesOptionsData = { +export const optionsData13: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'Cost Center 1', @@ -163,9 +165,9 @@ export const optionsData13: MergeExpensesOptionsData = { }, ], areSameValues: false, -}; +}); -export const optionsData14: MergeExpensesOptionsData = { +export const optionsData14: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'Outing', @@ -177,9 +179,9 @@ export const optionsData14: MergeExpensesOptionsData = { }, ], areSameValues: false, -}; +}); -export const optionsData15: MergeExpensesOptionsData = { +export const optionsData15: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'Kalyan Station Rd, Bhanunagar KalyanWest, Bhoiwada, Kalyan, Maharashtra 421301, India', @@ -196,9 +198,9 @@ export const optionsData15: MergeExpensesOptionsData = { }, ], areSameValues: false, -}; +}); -export const optionsData16: MergeExpensesOptionsData = { +export const optionsData16: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'Mar 13, 2023', @@ -210,9 +212,9 @@ export const optionsData16: MergeExpensesOptionsData = { }, ], areSameValues: false, -}; +}); -export const optionsData17: MergeExpensesOptionsData = { +export const optionsData17: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'ECONOMY', @@ -224,9 +226,9 @@ export const optionsData17: MergeExpensesOptionsData = { }, ], areSameValues: false, -}; +}); -export const optionsData18: MergeExpensesOptionsData = { +export const optionsData18: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'SLEEPER', @@ -238,9 +240,9 @@ export const optionsData18: MergeExpensesOptionsData = { }, ], areSameValues: true, -}; +}); -export const optionsData19: MergeExpensesOptionsData = { +export const optionsData19: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'AC', @@ -252,9 +254,9 @@ export const optionsData19: MergeExpensesOptionsData = { }, ], areSameValues: true, -}; +}); -export const optionsData20: MergeExpensesOptionsData = { +export const optionsData20: MergeExpensesOptionsData = deepFreeze({ options: [ { label: '25', @@ -266,9 +268,9 @@ export const optionsData20: MergeExpensesOptionsData = { }, ], areSameValues: false, -}; +}); -export const optionsData21: MergeExpensesOptionsData = { +export const optionsData21: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'KM', @@ -280,9 +282,9 @@ export const optionsData21: MergeExpensesOptionsData = { }, ], areSameValues: false, -}; +}); -export const optionsData22: MergeExpensesOptionsData[] = [ +export const optionsData22: MergeExpensesOptionsData[] = deepFreeze([ { options: [ { @@ -302,9 +304,9 @@ export const optionsData22: MergeExpensesOptionsData[] = [ id: 200229, name: 'date field', }, -]; +]); -export const optionsData23: MergeExpensesOptionsData[] = [ +export const optionsData23: MergeExpensesOptionsData[] = deepFreeze([ { options: [ { @@ -329,9 +331,9 @@ export const optionsData23: MergeExpensesOptionsData[] = [ }, ], }, -]; +]); -export const optionsData24: MergeExpensesOptionsData[] = [ +export const optionsData24: MergeExpensesOptionsData[] = deepFreeze([ { options: [ { @@ -351,9 +353,9 @@ export const optionsData24: MergeExpensesOptionsData[] = [ id: 200211, name: 'text field', }, -]; +]); -export const optionsData25: MergeExpensesOptionsData[] = [ +export const optionsData25: MergeExpensesOptionsData[] = deepFreeze([ { options: [ { @@ -378,9 +380,9 @@ export const optionsData25: MergeExpensesOptionsData[] = [ id: 200211, name: 'text field', }, -]; +]); -export const optionsData26: MergeExpensesOptionsData[] = [ +export const optionsData26: MergeExpensesOptionsData[] = deepFreeze([ { options: null, areSameValues: false, @@ -388,9 +390,9 @@ export const optionsData26: MergeExpensesOptionsData[] = [ id: 200212, name: 'numberfield', }, -]; +]); -export const optionsData27: MergeExpensesOptionsData[] = [ +export const optionsData27: MergeExpensesOptionsData[] = deepFreeze([ { options: [], areSameValues: false, @@ -405,9 +407,9 @@ export const optionsData27: MergeExpensesOptionsData[] = [ id: 200213, name: 'customcategory', }, -]; +]); -export const optionsData28: MergeExpensesOptionsData[] = [ +export const optionsData28: MergeExpensesOptionsData[] = deepFreeze([ { options: [ { @@ -424,9 +426,9 @@ export const optionsData28: MergeExpensesOptionsData[] = [ id: 200213, name: 'customcategory', }, -]; +]); -export const optionsData29: MergeExpensesOptionsData[] = [ +export const optionsData29: MergeExpensesOptionsData[] = deepFreeze([ { options: [], areSameValues: false, @@ -441,9 +443,9 @@ export const optionsData29: MergeExpensesOptionsData[] = [ id: 200215, name: 'customNumber', }, -]; +]); -export const optionsData30: MergeExpensesOptionsData[] = [ +export const optionsData30: MergeExpensesOptionsData[] = deepFreeze([ { options: [ { @@ -460,9 +462,9 @@ export const optionsData30: MergeExpensesOptionsData[] = [ id: 200215, name: 'customNumber', }, -]; +]); -export const optionsData31: MergeExpensesOptionsData = { +export const optionsData31: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'No', @@ -474,9 +476,9 @@ export const optionsData31: MergeExpensesOptionsData = { }, ], areSameValues: true, -}; +}); -export const optionsData32: MergeExpensesOptionsData[] = [ +export const optionsData32: MergeExpensesOptionsData[] = deepFreeze([ { id: 200227, name: 'userlist', @@ -530,9 +532,9 @@ export const optionsData32: MergeExpensesOptionsData[] = [ ], value: '2023-02-13T17:00:00.000Z', }, -]; +]); -export const optionsData33: MergeExpensesOptionsData = { +export const optionsData33: MergeExpensesOptionsData = deepFreeze({ options: [ { label: 'Kalyan Station Rd, Bhanunagar KalyanWest, Bhoiwada, Kalyan, Maharashtra 421301, India', @@ -550,27 +552,28 @@ export const optionsData33: MergeExpensesOptionsData = { }, ], areSameValues: false, -}; +}); -export const optionsDataMergeExpenses: MergeExpensesOptionsData | string[]>[] = [ - { - name: 'status', - value: '', - options: [], - }, - { - name: 'Multi Type', - value: ['Multi 1'], - options: [ - { - label: 'Multi 1', - value: ['Multi 1'], - }, - ], - }, - { - name: 'name', - value: null, - options: [], - }, -]; +export const optionsDataMergeExpenses: MergeExpensesOptionsData | string[]>[] = + deepFreeze([ + { + name: 'status', + value: '', + options: [], + }, + { + name: 'Multi Type', + value: ['Multi 1'], + options: [ + { + label: 'Multi 1', + value: ['Multi 1'], + }, + ], + }, + { + name: 'name', + value: null, + options: [], + }, + ]); diff --git a/src/app/core/mock-data/merge-expenses-payload.data.ts b/src/app/core/mock-data/merge-expenses-payload.data.ts index 17f64b42c2..dc2f4c9063 100644 --- a/src/app/core/mock-data/merge-expenses-payload.data.ts +++ b/src/app/core/mock-data/merge-expenses-payload.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { MergeExpensesPayload } from '../models/merge-expenses-payload.model'; -export const mergeExpensesPayload: MergeExpensesPayload = { +export const mergeExpensesPayload: MergeExpensesPayload = deepFreeze({ source_txn_ids: ['txKj4PEIUAXw'], target_txn_id: 'txVNpvgTPW4Z', target_txn_fields: { @@ -49,4 +51,4 @@ export const mergeExpensesPayload: MergeExpensesPayload = { ], locations: [], }, -}; +}); diff --git a/src/app/core/mock-data/mileage-location.data.ts b/src/app/core/mock-data/mileage-location.data.ts index 3566b40170..fcbb5e6b99 100644 --- a/src/app/core/mock-data/mileage-location.data.ts +++ b/src/app/core/mock-data/mileage-location.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { MileageLocation } from 'src/app/shared/components/route-visualizer/mileage-locations.interface'; -export const mileageLocationData1: MileageLocation[] = [ +export const mileageLocationData1: MileageLocation[] = deepFreeze([ { city: 'Kolkata', state: 'West Bengal', @@ -19,9 +21,9 @@ export const mileageLocationData1: MileageLocation[] = [ latitude: 22.532432, longitude: 88.3445775, }, -]; +]); -export const mileageLocationData2: MileageLocation[] = [ +export const mileageLocationData2: MileageLocation[] = deepFreeze([ { city: 'Kolkata', state: 'West Bengal', @@ -40,9 +42,9 @@ export const mileageLocationData2: MileageLocation[] = [ latitude: 22.532432, longitude: 0, }, -]; +]); -export const mileageLocationData3: MileageLocation[] = [ +export const mileageLocationData3: MileageLocation[] = deepFreeze([ { city: 'Kolkata', state: 'West Bengal', @@ -70,9 +72,9 @@ export const mileageLocationData3: MileageLocation[] = [ latitude: 22.549094, longitude: 88.357311, }, -]; +]); -export const mileageLocationData4: MileageLocation[] = [ +export const mileageLocationData4: MileageLocation[] = deepFreeze([ { city: 'Kolkata', state: 'West Bengal', @@ -82,9 +84,9 @@ export const mileageLocationData4: MileageLocation[] = [ latitude: 22.4860708, longitude: 88.3506995, }, -]; +]); -export const mileageLocationData5: MileageLocation[] = [ +export const mileageLocationData5: MileageLocation[] = deepFreeze([ { city: 'Kolkata', state: 'West Bengal', @@ -95,4 +97,4 @@ export const mileageLocationData5: MileageLocation[] = [ longitude: 88.3506995, }, null, -]; +]); diff --git a/src/app/core/mock-data/mileage-rate.data.ts b/src/app/core/mock-data/mileage-rate.data.ts index afb92776fe..f7124ea280 100644 --- a/src/app/core/mock-data/mileage-rate.data.ts +++ b/src/app/core/mock-data/mileage-rate.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { MileageRatesOptions } from '../models/mileage-rates-options.data'; import { PlatformMileageRates } from '../models/platform/platform-mileage-rates.model'; -export const unfilteredMileageRatesData: PlatformMileageRates[] = [ +export const unfilteredMileageRatesData: PlatformMileageRates[] = deepFreeze([ { code: null, created_at: new Date('2017-04-06T04:52:07.825000+00:00'), @@ -69,9 +71,9 @@ export const unfilteredMileageRatesData: PlatformMileageRates[] = [ vehicle_type: 'Type 1', readableRate: '₹18.00/mile', }, -]; +]); -export const filterEnabledMileageRatesData: PlatformMileageRates[] = [ +export const filterEnabledMileageRatesData: PlatformMileageRates[] = deepFreeze([ { code: null, created_at: new Date('2017-04-06T04:52:07.825000+00:00'), @@ -121,9 +123,9 @@ export const filterEnabledMileageRatesData: PlatformMileageRates[] = [ vehicle_type: 'electric_car', readableRate: '₹122.00/mile', }, -]; +]); -export const nullMileageRateData: PlatformMileageRates[] = [ +export const nullMileageRateData: PlatformMileageRates[] = deepFreeze([ { code: null, created_at: new Date('2017-04-06T04:52:07.825000+00:00'), @@ -173,9 +175,9 @@ export const nullMileageRateData: PlatformMileageRates[] = [ vehicle_type: 'electric_car', readableRate: '₹122.00/mile', }, -]; +]); -export const platformMileageRatesData1: PlatformMileageRates[] = [ +export const platformMileageRatesData1: PlatformMileageRates[] = deepFreeze([ { code: null, created_at: new Date('2017-04-06T04:52:07.825000+00:00'), @@ -207,9 +209,9 @@ export const platformMileageRatesData1: PlatformMileageRates[] = [ vehicle_type: 'IRS testing', readableRate: '₹102.26/mile', }, -]; +]); -export const platformMileageRatesData2: PlatformMileageRates[] = [ +export const platformMileageRatesData2: PlatformMileageRates[] = deepFreeze([ { code: null, created_at: new Date('2017-04-06T04:52:07.825000+00:00'), @@ -246,9 +248,9 @@ export const platformMileageRatesData2: PlatformMileageRates[] = [ vehicle_type: 'Type 1', readableRate: '₹18.00/mile', }, -]; +]); -export const mileageRateApiRes1: PlatformMileageRates[] = [ +export const mileageRateApiRes1: PlatformMileageRates[] = deepFreeze([ { code: null, created_at: new Date('2017-04-06T04:52:07.825000+00:00'), @@ -280,9 +282,9 @@ export const mileageRateApiRes1: PlatformMileageRates[] = [ vehicle_type: 'IRS testing', readableRate: '₹102.26/mile', }, -]; +]); -export const mileageRateApiRes2: PlatformMileageRates[] = [ +export const mileageRateApiRes2: PlatformMileageRates[] = deepFreeze([ { code: null, created_at: new Date('2017-04-06T04:52:07.825000+00:00'), @@ -319,9 +321,9 @@ export const mileageRateApiRes2: PlatformMileageRates[] = [ vehicle_type: 'Type 1', readableRate: '₹18.00/mile', }, -]; +]); -export const mileageRateOptions: MileageRatesOptions[] = [ +export const mileageRateOptions: MileageRatesOptions[] = deepFreeze([ { label: 'Electric Car ($10/mi)', value: { @@ -364,9 +366,9 @@ export const mileageRateOptions: MileageRatesOptions[] = [ readableRate: '$10/mi', }, }, -]; +]); -export const unfilteredMileageRatesData2: PlatformMileageRates[] = [ +export const unfilteredMileageRatesData2: PlatformMileageRates[] = deepFreeze([ { code: null, created_at: new Date('2017-04-06T04:52:07.825000+00:00'), @@ -434,9 +436,9 @@ export const unfilteredMileageRatesData2: PlatformMileageRates[] = [ vehicle_type: 'Type 1', readableRate: '₹18.00/mile', }, -]; +]); -export const expectedMileageData: PlatformMileageRates[] = [ +export const expectedMileageData: PlatformMileageRates[] = deepFreeze([ { code: null, created_at: new Date('2017-04-06T04:52:07.825000+00:00'), @@ -504,4 +506,4 @@ export const expectedMileageData: PlatformMileageRates[] = [ vehicle_type: 'Type 1', readableRate: '₹18.00/mile', }, -]; +]); diff --git a/src/app/core/mock-data/missing-mandatory-fields.data.ts b/src/app/core/mock-data/missing-mandatory-fields.data.ts index 19ed030d90..81daee8206 100644 --- a/src/app/core/mock-data/missing-mandatory-fields.data.ts +++ b/src/app/core/mock-data/missing-mandatory-fields.data.ts @@ -1,15 +1,17 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PlatformMissingMandatoryFields } from '../models/platform/platform-missing-mandatory-fields.model'; -export const missingMandatoryFieldsData1: PlatformMissingMandatoryFields = { +export const missingMandatoryFieldsData1: PlatformMissingMandatoryFields = deepFreeze({ missing_amount: false, missing_currency: false, missing_receipt: true, missing_expense_field_ids: [], -}; +}); -export const missingMandatoryFieldsData2: PlatformMissingMandatoryFields = { +export const missingMandatoryFieldsData2: PlatformMissingMandatoryFields = deepFreeze({ missing_amount: false, missing_currency: false, missing_receipt: false, missing_expense_field_ids: [], -}; +}); diff --git a/src/app/core/mock-data/modal-controller.data.ts b/src/app/core/mock-data/modal-controller.data.ts index 39af7d0c6c..c68e7edc5e 100644 --- a/src/app/core/mock-data/modal-controller.data.ts +++ b/src/app/core/mock-data/modal-controller.data.ts @@ -1,3 +1,4 @@ +/* eslint-disable custom-rules/prefer-deep-freeze */ import { FyFiltersComponent } from 'src/app/shared/components/fy-filters/fy-filters.component'; import { filterOptions1 } from './filter.data'; import { selectedFilters1, selectedFilters4, taskSelectedFiltersData } from './selected-filters.data'; @@ -12,7 +13,6 @@ import { FilterOptions } from 'src/app/shared/components/fy-filters/filter-optio import { DateFilters } from 'src/app/shared/components/fy-filters/date-filters.enum'; import { FyAddToReportModalComponent } from 'src/app/shared/components/fy-add-to-report/fy-add-to-report-modal/fy-add-to-report-modal.component'; import { reportOptionsData } from './report-options.data'; -import { expectedErpt } from './report-unflattened.data'; import { expectedReportsPaginated } from './platform-report.data'; import { FyInputPopoverComponent } from 'src/app/shared/components/fy-input-popover/fy-input-popover.component'; import { CaptureReceiptComponent } from 'src/app/shared/components/capture-receipt/capture-receipt.component'; diff --git a/src/app/core/mock-data/modal-properties.data.ts b/src/app/core/mock-data/modal-properties.data.ts index f530430f25..70a27c0464 100644 --- a/src/app/core/mock-data/modal-properties.data.ts +++ b/src/app/core/mock-data/modal-properties.data.ts @@ -1,4 +1,6 @@ -export const properties = { +import deepFreeze from 'deep-freeze-strict'; + +export const properties = deepFreeze({ cssClass: 'fy-modal', showBackdrop: true, canDismiss: true, @@ -7,4 +9,4 @@ export const properties = { initialBreakpoint: 1, breakpoints: [0, 1], handle: false, -}; +}); diff --git a/src/app/core/mock-data/model-properties.data.ts b/src/app/core/mock-data/model-properties.data.ts index 8b768c47a5..6b1288a440 100644 --- a/src/app/core/mock-data/model-properties.data.ts +++ b/src/app/core/mock-data/model-properties.data.ts @@ -1,4 +1,6 @@ -export const fyModalProperties = { +import deepFreeze from 'deep-freeze-strict'; + +export const fyModalProperties = deepFreeze({ cssClass: 'fy-modal', showBackdrop: true, canDismiss: true, @@ -7,9 +9,9 @@ export const fyModalProperties = { initialBreakpoint: 1, breakpoints: [0, 1], handle: false, -}; +}); -export const shareReportModalProperties = { +export const shareReportModalProperties = deepFreeze({ cssClass: 'share-report-modal', showBackdrop: true, canDismiss: true, @@ -18,4 +20,4 @@ export const shareReportModalProperties = { initialBreakpoint: 1, breakpoints: [0, 1], handle: false, -}; +}); diff --git a/src/app/core/mock-data/my-advances-filters.data.ts b/src/app/core/mock-data/my-advances-filters.data.ts index aa16954a79..efed60a3ef 100644 --- a/src/app/core/mock-data/my-advances-filters.data.ts +++ b/src/app/core/mock-data/my-advances-filters.data.ts @@ -1,20 +1,22 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AdvancesStates } from '../models/advances-states.model'; import { MyAdvancesFilters } from '../models/my-advances-filters.model'; import { SortingDirection } from '../models/sorting-direction.model'; import { SortingParam } from '../models/sorting-param.model'; -export const myAdvancesFiltersData: Partial = { +export const myAdvancesFiltersData: Partial = deepFreeze({ state: [AdvancesStates.cancelled, AdvancesStates.paid], -}; +}); -export const myAdvancesFiltersData2: Partial = { +export const myAdvancesFiltersData2: Partial = deepFreeze({ ...myAdvancesFiltersData, sortDir: SortingDirection.ascending, sortParam: SortingParam.project, -}; +}); -export const draftSentBackFiltersData: Partial = { +export const draftSentBackFiltersData: Partial = deepFreeze({ state: [AdvancesStates.sentBack, AdvancesStates.draft], sortDir: SortingDirection.ascending, sortParam: SortingParam.project, -}; +}); diff --git a/src/app/core/mock-data/my-reports-filterpills.data.ts b/src/app/core/mock-data/my-reports-filterpills.data.ts index c41e393d34..233fecfbaf 100644 --- a/src/app/core/mock-data/my-reports-filterpills.data.ts +++ b/src/app/core/mock-data/my-reports-filterpills.data.ts @@ -1,111 +1,113 @@ -export const expectedFilterPill1 = [ +import deepFreeze from 'deep-freeze-strict'; + +export const expectedFilterPill1 = deepFreeze([ { label: 'State', type: 'state', value: 'approved, reported', }, -]; +]); -export const expectedFilterPill2 = [ +export const expectedFilterPill2 = deepFreeze([ { label: 'Date', type: 'date', value: '2023-01-21 to 2023-01-31', }, -]; +]); -export const expectedFilterPill3 = [ +export const expectedFilterPill3 = deepFreeze([ { label: 'Date', type: 'date', value: '>= 2023-01-21', }, -]; +]); -export const expectedFilterPill4 = [ +export const expectedFilterPill4 = deepFreeze([ { label: 'Date', type: 'date', value: '<= 2023-01-31', }, -]; +]); -export const expectedFilterPill5 = [ +export const expectedFilterPill5 = deepFreeze([ { label: 'Date', type: 'date', value: 'this Week', }, -]; +]); -export const expectedFilterPill6 = [ +export const expectedFilterPill6 = deepFreeze([ { label: 'Date', type: 'date', value: 'this Month', }, -]; +]); -export const expectedFilterPill7 = [ +export const expectedFilterPill7 = deepFreeze([ { label: 'Date', type: 'date', value: 'All', }, -]; +]); -export const expectedFilterPill8 = [ +export const expectedFilterPill8 = deepFreeze([ { label: 'Date', type: 'date', value: 'Last Month', }, -]; +]); -export const expectedFilterPill9 = [ +export const expectedFilterPill9 = deepFreeze([ { label: 'Sort By', type: 'sort', value: 'date - old to new', }, -]; +]); -export const expectedFilterPill10 = [ +export const expectedFilterPill10 = deepFreeze([ { label: 'Sort By', type: 'sort', value: 'date - new to old', }, -]; +]); -export const expectedFilterPill11 = [ +export const expectedFilterPill11 = deepFreeze([ { label: 'Sort By', type: 'sort', value: 'amount - high to low', }, -]; +]); -export const expectedFilterPill12 = [ +export const expectedFilterPill12 = deepFreeze([ { label: 'Sort By', type: 'sort', value: 'amount - low to high', }, -]; +]); -export const expectedFilterPill13 = [ +export const expectedFilterPill13 = deepFreeze([ { label: 'Sort By', type: 'sort', value: 'Name - a to z', }, -]; +]); -export const expectedFilterPill14 = [ +export const expectedFilterPill14 = deepFreeze([ { label: 'Sort By', type: 'sort', value: 'Name - z to a', }, -]; +]); diff --git a/src/app/core/mock-data/my-reports-filters.data.ts b/src/app/core/mock-data/my-reports-filters.data.ts index 018fb09d41..b0a565c7c9 100644 --- a/src/app/core/mock-data/my-reports-filters.data.ts +++ b/src/app/core/mock-data/my-reports-filters.data.ts @@ -1,87 +1,89 @@ +import deepFreeze from 'deep-freeze-strict'; + import { DateFilters } from 'src/app/shared/components/fy-filters/date-filters.enum'; -export const filter1 = { +export const filter1 = deepFreeze({ state: 'approved', date: 'last_week', customDateStart: new Date('2023-01-01'), customDateEnd: new Date('2023-01-07'), sortParam: 'rp_created_at', sortDir: 'asc', -}; +}); -export const filter2 = { +export const filter2 = deepFreeze({ date: DateFilters.custom, customDateStart: new Date('2023-01-21'), customDateEnd: new Date('2023-01-31'), -}; +}); -export const filter3 = { +export const filter3 = deepFreeze({ state: ['active', 'completed'], date: DateFilters.thisWeek, sortParam: 'rp_created_at', sortDir: 'asc', -}; +}); -export const filter4 = { +export const filter4 = deepFreeze({ date: DateFilters.custom, customDateStart: new Date('2022-01-01'), customDateEnd: new Date('2022-01-31'), -}; +}); -export const filter5 = { +export const filter5 = deepFreeze({ date: DateFilters.custom, customDateStart: new Date('2022-01-01'), customDateEnd: null, -}; +}); -export const filter6 = { +export const filter6 = deepFreeze({ date: DateFilters.custom, customDateStart: null, customDateEnd: new Date('2022-01-31'), -}; +}); -export const filter7 = { +export const filter7 = deepFreeze({ date: DateFilters.thisWeek, customDateStart: new Date(), customDateEnd: new Date(), -}; +}); -export const filter8 = { +export const filter8 = deepFreeze({ date: DateFilters.thisMonth, customDateStart: null, customDateEnd: null, -}; +}); -export const filter9 = { +export const filter9 = deepFreeze({ date: DateFilters.thisWeek, customDateStart: null, customDateEnd: null, -}; +}); -export const filter10 = { +export const filter10 = deepFreeze({ date: DateFilters.lastMonth, customDateStart: null, customDateEnd: null, -}; +}); -export const filter11 = { +export const filter11 = deepFreeze({ date: null, customDateStart: null, customDateEnd: null, -}; +}); -export const filter12 = { +export const filter12 = deepFreeze({ date: DateFilters.all, customDateStart: new Date('2023-02-21T00:00:00.000Z'), customDateEnd: new Date('2023-02-23T00:00:00.000Z'), -}; +}); -export const filter13 = { +export const filter13 = deepFreeze({ state: ['DRAFT', 'APPROVER_PENDING', 'APPROVER_INQUIRY', 'APPROVED', 'PAYMENT_PENDING', 'PAYMENT_PROCESSING', 'PAID'], -}; +}); -export const filter14 = { +export const filter14 = deepFreeze({ sortDir: 'desc', sortParam: 'rp_created_at', rp_state: 'APPROVED', -}; +}); diff --git a/src/app/core/mock-data/my-reports-load-data.data.ts b/src/app/core/mock-data/my-reports-load-data.data.ts index 6405ecc24c..394047a206 100644 --- a/src/app/core/mock-data/my-reports-load-data.data.ts +++ b/src/app/core/mock-data/my-reports-load-data.data.ts @@ -1,18 +1,20 @@ -export const loadData1 = { +import deepFreeze from 'deep-freeze-strict'; + +export const loadData1 = deepFreeze({ pageNumber: 1, searchString: 'example', sortParam: 'approvalDate', sortDir: 'desc', -}; +}); -export const loadData2 = { +export const loadData2 = deepFreeze({ pageNumber: 1, searchString: 'example', sortDir: 'desc', -}; +}); -export const loadData3 = { +export const loadData3 = deepFreeze({ pageNumber: 1, searchString: 'example', sortDir: 'desc', -}; +}); diff --git a/src/app/core/mock-data/my-reports.data.ts b/src/app/core/mock-data/my-reports.data.ts index 05ad15450f..a9f40a77e8 100644 --- a/src/app/core/mock-data/my-reports.data.ts +++ b/src/app/core/mock-data/my-reports.data.ts @@ -1,3 +1,5 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Observable, of } from 'rxjs'; import { FyDeleteDialogComponent } from 'src/app/shared/components/fy-delete-dialog/fy-delete-dialog.component'; import { DateFilters } from 'src/app/shared/components/fy-filters/date-filters.enum'; @@ -6,7 +8,7 @@ import { FilterOptions } from 'src/app/shared/components/fy-filters/filter-optio import { FyFiltersComponent } from 'src/app/shared/components/fy-filters/fy-filters.component'; import { PopupAlertComponent } from 'src/app/shared/components/popup-alert/popup-alert.component'; -export const generatedFiltersStateDateSortParams = [ +export const generatedFiltersStateDateSortParams = deepFreeze([ { name: 'State', value: 'approved', @@ -23,9 +25,9 @@ export const generatedFiltersStateDateSortParams = [ name: 'Sort By', value: 'dateOldToNew', }, -]; +]); -export const generatedFiltersStateDate = [ +export const generatedFiltersStateDate = deepFreeze([ { name: 'State', value: 'draft', @@ -38,9 +40,9 @@ export const generatedFiltersStateDate = [ endDate: undefined, }, }, -]; +]); -export const expectedGenerateFilterPillsData = [ +export const expectedGenerateFilterPillsData = deepFreeze([ { label: 'State', type: 'state', @@ -56,9 +58,9 @@ export const expectedGenerateFilterPillsData = [ type: 'sort', value: 'date - old to new', }, -]; +]); -export const openFiltersOptions = [ +export const openFiltersOptions = deepFreeze([ { name: 'State', optionType: FilterOptionType.multiselect, @@ -197,8 +199,9 @@ export const openFiltersOptions = [ }, ], } as FilterOptions, -]; +]); +// eslint-disable-next-line custom-rules/prefer-deep-freeze export const filterPopoverParams = { component: FyFiltersComponent, componentProps: { @@ -211,6 +214,7 @@ export const filterPopoverParams = { cssClass: 'dialog-popover', }; +// eslint-disable-next-line custom-rules/prefer-deep-freeze export const popoverControllerParams = { component: PopupAlertComponent, componentProps: { @@ -226,6 +230,7 @@ export const popoverControllerParams = { const mockDeleteMethod = (): Observable => of(); +// eslint-disable-next-line custom-rules/prefer-deep-freeze export const deletePopoverParamsRes = { component: FyDeleteDialogComponent, cssClass: 'delete-dialog', diff --git a/src/app/core/mock-data/notification-events.data.ts b/src/app/core/mock-data/notification-events.data.ts index 85d0b635ee..98b1cab9b5 100644 --- a/src/app/core/mock-data/notification-events.data.ts +++ b/src/app/core/mock-data/notification-events.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { NotificationEvents } from '../models/notification-events.model'; -export const notificationEventsData: NotificationEvents = { +export const notificationEventsData: NotificationEvents = deepFreeze({ features: { expensesAndReports: { textLabel: 'Expenses and Reports', @@ -193,9 +195,9 @@ export const notificationEventsData: NotificationEvents = { eventType: 'eadvance_requests_rejected', }, ], -}; +}); -export const notificationEventsData2: NotificationEvents = { +export const notificationEventsData2: NotificationEvents = deepFreeze({ features: { expensesAndReports: { textLabel: 'Expenses and Reports', @@ -388,9 +390,9 @@ export const notificationEventsData2: NotificationEvents = { eventType: 'eadvance_requests_rejected', }, ], -}; +}); -export const notificationEventsData3: NotificationEvents = { +export const notificationEventsData3: NotificationEvents = deepFreeze({ features: { expensesAndReports: { textLabel: 'Expenses and Reports', @@ -583,4 +585,4 @@ export const notificationEventsData3: NotificationEvents = { eventType: 'eadvance_requests_rejected', }, ], -}; +}); diff --git a/src/app/core/mock-data/option.data.ts b/src/app/core/mock-data/option.data.ts index fc33e40597..dd17f97b43 100644 --- a/src/app/core/mock-data/option.data.ts +++ b/src/app/core/mock-data/option.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Option } from '../models/option.model'; -export const optionData1: Option[] = [ +export const optionData1: Option[] = deepFreeze([ { label: 'report 1', value: { @@ -132,4 +134,4 @@ export const optionData1: Option[] = [ user_id: 'usvKA4X8Ugcr', }, }, -]; +]); diff --git a/src/app/core/mock-data/org-category-list-item.data.ts b/src/app/core/mock-data/org-category-list-item.data.ts index fa63efc841..c628c2e05f 100644 --- a/src/app/core/mock-data/org-category-list-item.data.ts +++ b/src/app/core/mock-data/org-category-list-item.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { OrgCategoryListItem } from '../models/v1/org-category.model'; import { expectedOrgCategoriesPaginated } from './org-category.data'; -export const categorieListRes: OrgCategoryListItem[] = [ +export const categorieListRes: OrgCategoryListItem[] = deepFreeze([ { label: 'Accounts Payable - Employees', value: expectedOrgCategoriesPaginated[0], @@ -18,9 +20,9 @@ export const categorieListRes: OrgCategoryListItem[] = [ label: 'samp category', value: expectedOrgCategoriesPaginated[3], }, -]; +]); -export const recentUsedCategoriesRes: OrgCategoryListItem[] = [ +export const recentUsedCategoriesRes: OrgCategoryListItem[] = deepFreeze([ { label: 'Office Supplies', value: { @@ -66,9 +68,9 @@ export const recentUsedCategoriesRes: OrgCategoryListItem[] = [ updated_at: new Date('2022-11-23T13:11:51.771676+00:00'), }, }, -]; +]); -export const orgCategoryListItemData1 = [ +export const orgCategoryListItemData1 = deepFreeze([ { label: 'Business', value: { @@ -129,4 +131,4 @@ export const orgCategoryListItemData1 = [ updated_at: new Date('2023-01-09T16:54:09.929Z'), }, }, -]; +]); diff --git a/src/app/core/mock-data/org-category.data.ts b/src/app/core/mock-data/org-category.data.ts index e2cfd0545d..b683f921ab 100644 --- a/src/app/core/mock-data/org-category.data.ts +++ b/src/app/core/mock-data/org-category.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PlatformCategory } from '../models/platform/platform-category.model'; import { OrgCategory } from '../models/v1/org-category.model'; -export const orgCategoryData: OrgCategory = { +export const orgCategoryData: OrgCategory = deepFreeze({ code: null, created_at: new Date('2018-01-31T23:50:27.235056+00:00'), displayName: 'Food', @@ -12,9 +14,9 @@ export const orgCategoryData: OrgCategory = { org_id: 'orNVthTo2Zyo', sub_category: 'Food', updated_at: new Date('2022-05-05T17:45:42.092507+00:00'), -}; +}); -export const mileagePerDiemPlatformCategoryData: PlatformCategory[] = [ +export const mileagePerDiemPlatformCategoryData: PlatformCategory[] = deepFreeze([ { code: null, created_at: new Date('2018-01-31T23:50:27.235056+00:00'), @@ -39,9 +41,9 @@ export const mileagePerDiemPlatformCategoryData: PlatformCategory[] = [ sub_category: 'Per Diem', updated_at: new Date('2022-05-05T17:45:42.092507+00:00'), }, -]; +]); -export const transformedOrgCategories: OrgCategory[] = [ +export const transformedOrgCategories: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -90,9 +92,9 @@ export const transformedOrgCategories: OrgCategory[] = [ sub_category: 'samp category', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const sortedCategory: OrgCategory[] = [ +export const sortedCategory: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -141,9 +143,9 @@ export const sortedCategory: OrgCategory[] = [ sub_category: 'samp category', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const sortedOrgCategories: OrgCategory[] = [ +export const sortedOrgCategories: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -192,9 +194,9 @@ export const sortedOrgCategories: OrgCategory[] = [ sub_category: 'samp category', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const filterOrgCategoryParam: OrgCategory[] = [ +export const filterOrgCategoryParam: OrgCategory[] = deepFreeze([ { code: '43', created_at: new Date('2023-01-09T16:54:09.929Z'), @@ -219,9 +221,9 @@ export const filterOrgCategoryParam: OrgCategory[] = [ sub_category: 'Marketing outreach', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const expectedFilterOrgCategory: OrgCategory[] = [ +export const expectedFilterOrgCategory: OrgCategory[] = deepFreeze([ { code: '42', created_at: new Date('2023-01-09T16:54:09.929Z'), @@ -234,9 +236,9 @@ export const expectedFilterOrgCategory: OrgCategory[] = [ sub_category: 'Marketing outreach', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const expectedAllOrgCategories: OrgCategory[] = [ +export const expectedAllOrgCategories: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -285,9 +287,9 @@ export const expectedAllOrgCategories: OrgCategory[] = [ sub_category: 'samp category', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const orgCategoryWoDisplayName: OrgCategory[] = [ +export const orgCategoryWoDisplayName: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -312,9 +314,9 @@ export const orgCategoryWoDisplayName: OrgCategory[] = [ sub_category: 'samp category', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const orgCategoryWithDisplayName: OrgCategory[] = [ +export const orgCategoryWithDisplayName: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -339,9 +341,9 @@ export const orgCategoryWithDisplayName: OrgCategory[] = [ sub_category: 'samp category', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const orgCategoryPaginated1: OrgCategory[] = [ +export const orgCategoryPaginated1: OrgCategory[] = deepFreeze([ { code: '20300', created_at: new Date('2021-03-14T06:07:39.652664+00:00'), @@ -366,9 +368,9 @@ export const orgCategoryPaginated1: OrgCategory[] = [ sub_category: 'Capitalized Software Costs', updated_at: new Date('2022-05-05T17:45:11.742874+00:00'), }, -]; +]); -export const orgCategoryPaginated2: OrgCategory[] = [ +export const orgCategoryPaginated2: OrgCategory[] = deepFreeze([ { code: '51708', created_at: new Date('2021-03-14T06:07:39.652664+00:00'), @@ -393,9 +395,9 @@ export const orgCategoryPaginated2: OrgCategory[] = [ sub_category: 'samp category', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const expectedOrgCategoriesPaginated: OrgCategory[] = [ +export const expectedOrgCategoriesPaginated: OrgCategory[] = deepFreeze([ { code: '20300', created_at: new Date('2021-03-14T06:07:39.652Z'), @@ -444,9 +446,9 @@ export const expectedOrgCategoriesPaginated: OrgCategory[] = [ sub_category: 'samp category', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const orgCategoryData1: OrgCategory[] = [ +export const orgCategoryData1: OrgCategory[] = deepFreeze([ { ...expectedOrgCategoriesPaginated[0] }, { ...expectedOrgCategoriesPaginated[1] }, { @@ -473,9 +475,9 @@ export const orgCategoryData1: OrgCategory[] = [ sub_category: 'Food', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const expectedTransformedCategories: OrgCategory[] = [ +export const expectedTransformedCategories: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -524,9 +526,9 @@ export const expectedTransformedCategories: OrgCategory[] = [ sub_category: 'Marketing outreach', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const unsortedCategories1: OrgCategory[] = [ +export const unsortedCategories1: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -647,9 +649,9 @@ export const unsortedCategories1: OrgCategory[] = [ sub_category: 'Induction', updated_at: new Date('2022-11-23T13:11:51.771676+00:00'), }, -]; +]); -export const sortedCategories1: OrgCategory[] = [ +export const sortedCategories1: OrgCategory[] = deepFreeze([ { code: null, created_at: new Date('2022-02-07T10:36:23.916Z'), @@ -770,9 +772,9 @@ export const sortedCategories1: OrgCategory[] = [ sub_category: 'Pager', updated_at: new Date('2022-05-05T17:47:06.951Z'), }, -]; +]); -export const transformedOrgCategoryById: OrgCategory[] = [ +export const transformedOrgCategoryById: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -809,9 +811,9 @@ export const transformedOrgCategoryById: OrgCategory[] = [ sub_category: 'samp category', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const displayOrgCategoryById: OrgCategory[] = [ +export const displayOrgCategoryById: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -848,9 +850,9 @@ export const displayOrgCategoryById: OrgCategory[] = [ sub_category: 'samp category', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const expectedOrgCategoryById: OrgCategory = { +export const expectedOrgCategoryById: OrgCategory = deepFreeze({ code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), displayName: 'Business', @@ -861,9 +863,9 @@ export const expectedOrgCategoryById: OrgCategory = { org_id: 'orrjqbDbeP9p', sub_category: 'Business', updated_at: new Date('2022-07-01T05:51:31.800Z'), -}; +}); -export const transformedOrgCategoriesByName: OrgCategory[] = [ +export const transformedOrgCategoriesByName: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -900,9 +902,9 @@ export const transformedOrgCategoriesByName: OrgCategory[] = [ sub_category: 'Marketing outreach', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const displayOrgCategoriesByName: OrgCategory[] = [ +export const displayOrgCategoriesByName: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -939,9 +941,9 @@ export const displayOrgCategoriesByName: OrgCategory[] = [ sub_category: 'Marketing outreach', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const expectedOrgCategoryByName: OrgCategory = { +export const expectedOrgCategoryByName: OrgCategory = deepFreeze({ code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), displayName: 'Business', @@ -952,18 +954,18 @@ export const expectedOrgCategoryByName: OrgCategory = { org_id: 'orrjqbDbeP9p', sub_category: 'Business', updated_at: new Date('2022-07-01T05:51:31.800Z'), -}; +}); -export const filteredCategoriesData = [ +export const filteredCategoriesData = deepFreeze([ { value: orgCategoryData, }, { value: transformedOrgCategories[0], }, -]; +]); -export const expectedAutoFillCategory: OrgCategory = { +export const expectedAutoFillCategory: OrgCategory = deepFreeze({ code: null, created_at: new Date('2018-01-31T23:50:27.235Z'), displayName: 'Food', @@ -974,9 +976,9 @@ export const expectedAutoFillCategory: OrgCategory = { org_id: 'orNVthTo2Zyo', sub_category: 'Food', updated_at: new Date('2022-05-05T17:45:42.092Z'), -}; +}); -export const expectedAutoFillCategory2: OrgCategory = { +export const expectedAutoFillCategory2: OrgCategory = deepFreeze({ code: null, created_at: new Date('2020-03-04T09:51:01.619Z'), displayName: 'Office supplies', @@ -987,9 +989,9 @@ export const expectedAutoFillCategory2: OrgCategory = { org_id: 'orNVthTo2Zyo', sub_category: 'Office supplies', updated_at: new Date('2022-11-23T13:11:51.771Z'), -}; +}); -export const TaxiCategory: OrgCategory = { +export const TaxiCategory: OrgCategory = deepFreeze({ code: null, created_at: new Date('2020-03-04T09:51:01.619Z'), displayName: 'Office supplies', @@ -1000,9 +1002,9 @@ export const TaxiCategory: OrgCategory = { org_id: 'orNVthTo2Zyo', sub_category: 'TRAVEL', updated_at: new Date('2022-11-23T13:11:51.771Z'), -}; +}); -export const expectedAutoFillCategory3: OrgCategory = { +export const expectedAutoFillCategory3: OrgCategory = deepFreeze({ code: null, created_at: new Date('2018-01-31T23:50:27.235Z'), displayName: 'Food', @@ -1013,9 +1015,9 @@ export const expectedAutoFillCategory3: OrgCategory = { org_id: 'orNVthTo2Zyo', sub_category: 'Food', updated_at: new Date('2022-05-05T17:45:42.092Z'), -}; +}); -export const perDiemCategory: OrgCategory = { +export const perDiemCategory: OrgCategory = deepFreeze({ code: null, created_at: new Date('2018-07-27T08:52:38.938006+00:00'), displayName: 'Per Diem', @@ -1026,9 +1028,9 @@ export const perDiemCategory: OrgCategory = { org_id: 'orrb8EW1zZsy', sub_category: 'Per Diem', updated_at: new Date('2022-09-13T17:16:56.232081+00:00'), -}; +}); -export const mileageCategories: OrgCategory[] = [ +export const mileageCategories: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -1065,9 +1067,9 @@ export const mileageCategories: OrgCategory[] = [ sub_category: 'Marketing outreach', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const mileageCategories2: OrgCategory[] = [ +export const mileageCategories2: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -1104,9 +1106,9 @@ export const mileageCategories2: OrgCategory[] = [ sub_category: 'Marketing outreach', updated_at: new Date('2023-01-09T16:54:09.929Z'), }, -]; +]); -export const mileageCategories3: OrgCategory[] = [ +export const mileageCategories3: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -1131,9 +1133,9 @@ export const mileageCategories3: OrgCategory[] = [ sub_category: null, updated_at: new Date('2022-05-05T17:47:06.951Z'), }, -]; +]); -export const expectedMileageCategoriesData: OrgCategory[] = [ +export const expectedMileageCategoriesData: OrgCategory[] = deepFreeze([ { code: '98', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -1146,9 +1148,9 @@ export const expectedMileageCategoriesData: OrgCategory[] = [ sub_category: null, updated_at: new Date('2022-05-05T17:47:06.951Z'), }, -]; +]); -export const expectedOrgCategoryByName2: OrgCategory = { +export const expectedOrgCategoryByName2: OrgCategory = deepFreeze({ code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), displayName: 'Business', @@ -1159,9 +1161,9 @@ export const expectedOrgCategoryByName2: OrgCategory = { org_id: 'orrjqbDbeP9p', sub_category: 'Business', updated_at: new Date('2022-07-01T05:51:31.800Z'), -}; +}); -export const unspecifiedCategory: OrgCategory = { +export const unspecifiedCategory: OrgCategory = deepFreeze({ code: null, created_at: new Date('2018-01-31T23:50:27.235056+00:00'), displayName: 'Unspecified', @@ -1172,9 +1174,9 @@ export const unspecifiedCategory: OrgCategory = { org_id: 'orNVthTo2Zyo', sub_category: 'Unspecified', updated_at: new Date('2022-05-05T17:45:42.092507+00:00'), -}; +}); -export const mileageCategoryWithoutId: OrgCategory[] = [ +export const mileageCategoryWithoutId: OrgCategory[] = deepFreeze([ { code: '93', created_at: new Date('2021-05-18T11:40:38.576Z'), @@ -1187,4 +1189,4 @@ export const mileageCategoryWithoutId: OrgCategory[] = [ sub_category: 'Business', updated_at: new Date('2022-07-01T05:51:31.800Z'), }, -]; +]); diff --git a/src/app/core/mock-data/org-payment-mode-settings.data.ts b/src/app/core/mock-data/org-payment-mode-settings.data.ts index 2aa6e61558..cb655233d5 100644 --- a/src/app/core/mock-data/org-payment-mode-settings.data.ts +++ b/src/app/core/mock-data/org-payment-mode-settings.data.ts @@ -1,32 +1,34 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AllowedPaymentModes } from '../models/allowed-payment-modes.enum'; import { PaymentmodeSettings } from '../models/org-settings.model'; -export const cccOnlyPaymentModeSettingsParam: PaymentmodeSettings = { +export const cccOnlyPaymentModeSettingsParam: PaymentmodeSettings = deepFreeze({ allowed: true, enabled: true, payment_modes_order: [AllowedPaymentModes.PERSONAL_CORPORATE_CREDIT_CARD_ACCOUNT], -}; +}); -export const reimbursableOnlyPaymentModeSettingsParam: PaymentmodeSettings = { +export const reimbursableOnlyPaymentModeSettingsParam: PaymentmodeSettings = deepFreeze({ allowed: true, enabled: true, payment_modes_order: [AllowedPaymentModes.PERSONAL_ACCOUNT], -}; +}); -export const cccAndReimbursablePaymentModeSettingsParam: PaymentmodeSettings = { +export const cccAndReimbursablePaymentModeSettingsParam: PaymentmodeSettings = deepFreeze({ allowed: true, enabled: true, payment_modes_order: [ AllowedPaymentModes.PERSONAL_ACCOUNT, AllowedPaymentModes.PERSONAL_CORPORATE_CREDIT_CARD_ACCOUNT, ], -}; +}); -export const cccAndPaidByCompanyPaymentModeSettingsParam: PaymentmodeSettings = { +export const cccAndPaidByCompanyPaymentModeSettingsParam: PaymentmodeSettings = deepFreeze({ allowed: true, enabled: true, payment_modes_order: [ AllowedPaymentModes.PERSONAL_CORPORATE_CREDIT_CARD_ACCOUNT, AllowedPaymentModes.COMPANY_ACCOUNT, ], -}; +}); diff --git a/src/app/core/mock-data/org-settings.data.ts b/src/app/core/mock-data/org-settings.data.ts index d811139faa..e0aa03b761 100644 --- a/src/app/core/mock-data/org-settings.data.ts +++ b/src/app/core/mock-data/org-settings.data.ts @@ -1,8 +1,10 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AllowedPaymentModes } from '../models/allowed-payment-modes.enum'; import { EmailEvents, OrgSettings, TaxSettings } from '../models/org-settings.model'; import { orgSettingsData } from '../test-data/accounts.service.spec.data'; -export const orgSettingsRes: OrgSettings = { +export const orgSettingsRes: OrgSettings = deepFreeze({ org_id: 'orrjqbDbeP9p', mileage: { allowed: true, @@ -407,9 +409,9 @@ export const orgSettingsRes: OrgSettings = { enabled: true, virtual_card_settings_enabled: true, }, -}; +}); -export const orgSettingsParams2: OrgSettings = { +export const orgSettingsParams2: OrgSettings = deepFreeze({ org_id: 'orrjqbDbeP9p', mileage: { allowed: true, @@ -814,9 +816,9 @@ export const orgSettingsParams2: OrgSettings = { enabled: true, virtual_card_settings_enabled: true, }, -}; +}); -export const orgSettingsParamWoCCC: OrgSettings = { +export const orgSettingsParamWoCCC: OrgSettings = deepFreeze({ org_id: 'orrjqbDbeP9p', mileage: { allowed: true, @@ -1199,35 +1201,35 @@ export const orgSettingsParamWoCCC: OrgSettings = { enabled: true, virtual_card_settings_enabled: true, }, -}; +}); -export const orgSettingsCCCDisabled: OrgSettings = { +export const orgSettingsCCCDisabled: OrgSettings = deepFreeze({ ...orgSettingsData, corporate_credit_card_settings: { ...orgSettingsData.corporate_credit_card_settings, allowed: false, enabled: false, }, -}; +}); -export const orgSettingsCCCEnabled: OrgSettings = { +export const orgSettingsCCCEnabled: OrgSettings = deepFreeze({ ...orgSettingsData, corporate_credit_card_settings: { ...orgSettingsData.corporate_credit_card_settings, allowed: true, enabled: true, }, -}; +}); -export const orgSettingsParamsWithSimplifiedReport: OrgSettings = { +export const orgSettingsParamsWithSimplifiedReport: OrgSettings = deepFreeze({ ...orgSettingsRes, simplified_report_closure_settings: { allowed: true, enabled: true, }, -}; +}); -export const taxSettingsData: TaxSettings = { +export const taxSettingsData: TaxSettings = deepFreeze({ allowed: true, enabled: true, name: null, @@ -1254,14 +1256,14 @@ export const taxSettingsData: TaxSettings = { }, }, ], -}; +}); -export const taxSettingsData2: TaxSettings = { +export const taxSettingsData2: TaxSettings = deepFreeze({ ...taxSettingsData, enabled: false, -}; +}); -export const orgSettingsWoTax: OrgSettings = { +export const orgSettingsWoTax: OrgSettings = deepFreeze({ ...orgSettingsData, tax_settings: { ...orgSettingsData.tax_settings, enabled: false }, advances: null, @@ -1275,9 +1277,9 @@ export const orgSettingsWoTax: OrgSettings = { advance_requests: { enabled: true, }, -}; +}); -export const orgSettingsWoTaxAndRtf: OrgSettings = { +export const orgSettingsWoTaxAndRtf: OrgSettings = deepFreeze({ ...orgSettingsWoTax, visa_enrollment_settings: { allowed: true, @@ -1287,22 +1289,22 @@ export const orgSettingsWoTaxAndRtf: OrgSettings = { allowed: true, enabled: false, }, -}; +}); -export const orgSettingsCCCDisabled2: OrgSettings = { +export const orgSettingsCCCDisabled2: OrgSettings = deepFreeze({ ...orgSettingsRes, corporate_credit_card_settings: null, -}; +}); -export const orgSettingsCCCDisabled3: OrgSettings = { +export const orgSettingsCCCDisabled3: OrgSettings = deepFreeze({ ...orgSettingsRes, corporate_credit_card_settings: { allowed: true, enabled: null, }, -}; +}); -export const orgSettingsRTFDisabled: OrgSettings = { +export const orgSettingsRTFDisabled: OrgSettings = deepFreeze({ ...orgSettingsRes, mastercard_enrollment_settings: { allowed: false, @@ -1312,45 +1314,45 @@ export const orgSettingsRTFDisabled: OrgSettings = { allowed: false, enabled: false, }, -}; +}); -export const orgSettingsWithProjectAndAutofill: OrgSettings = { +export const orgSettingsWithProjectAndAutofill: OrgSettings = deepFreeze({ ...orgSettingsRes, org_expense_form_autofills: { allowed: true, enabled: true, }, -}; +}); -export const orgSettingsWithExpenseFormAutofill: OrgSettings = { +export const orgSettingsWithExpenseFormAutofill: OrgSettings = deepFreeze({ ...orgSettingsParams2, org_expense_form_autofills: { allowed: true, enabled: true, }, -}; +}); -export const orgSettingsProjectDisabled: OrgSettings = { +export const orgSettingsProjectDisabled: OrgSettings = deepFreeze({ ...orgSettingsRes, projects: { allowed: false, enabled: false, }, -}; +}); -export const orgSettingsWoAdvance: OrgSettings = { +export const orgSettingsWoAdvance: OrgSettings = deepFreeze({ ...orgSettingsRes, advances: null, -}; +}); -export const orgSettingsCCDisabled: OrgSettings = { +export const orgSettingsCCDisabled: OrgSettings = deepFreeze({ ...orgSettingsRes, cost_centers: { enabled: false, }, -}; +}); -export const orgSettingsOrgAutofill: OrgSettings = { +export const orgSettingsOrgAutofill: OrgSettings = deepFreeze({ ...orgSettingsRes, org_expense_form_autofills: { enabled: true, @@ -1358,55 +1360,55 @@ export const orgSettingsOrgAutofill: OrgSettings = { }, advanced_projects: null, projects: null, -}; +}); -export const orgSettingsWoProjects: OrgSettings = { +export const orgSettingsWoProjects: OrgSettings = deepFreeze({ ...orgSettingsRes, advanced_projects: null, projects: null, -}; +}); -export const orgSettingsWoMileage: OrgSettings = { +export const orgSettingsWoMileage: OrgSettings = deepFreeze({ ...orgSettingsParams2, mileage: null, -}; +}); -export const orgSettingsWithUnsubscribeEvent: OrgSettings = { +export const orgSettingsWithUnsubscribeEvent: OrgSettings = deepFreeze({ ...orgSettingsRes, admin_email_settings: { ...orgSettingsRes.admin_email_settings, unsubscribed_events: [EmailEvents.DELEGATOR_SUBSCRIPTION, EmailEvents.EADVANCES_CREATED], }, -}; +}); -export const orgSettingsWithV2ExpensesPage: OrgSettings = { +export const orgSettingsWithV2ExpensesPage: OrgSettings = deepFreeze({ ...orgSettingsRes, mobile_app_my_expenses_beta_enabled: true, -}; +}); -export const orgSettingsWoV2ExpensesPage: OrgSettings = { +export const orgSettingsWoV2ExpensesPage: OrgSettings = deepFreeze({ ...orgSettingsRes, mobile_app_my_expenses_beta_enabled: false, -}; +}); -export const orgSettingsPendingRestrictions: OrgSettings = { +export const orgSettingsPendingRestrictions: OrgSettings = deepFreeze({ ...orgSettingsRes, corporate_credit_card_settings: { enabled: true }, pending_cct_expense_restriction: { enabled: true }, -}; +}); -export const orgSettingsWithCommuteDeductionsEnabled: OrgSettings = { +export const orgSettingsWithCommuteDeductionsEnabled: OrgSettings = deepFreeze({ ...orgSettingsRes, commute_deduction_settings: { enabled: true, allowed: true, }, -}; +}); -export const orgSettingsWithCommuteDeductionsDisabled: OrgSettings = { +export const orgSettingsWithCommuteDeductionsDisabled: OrgSettings = deepFreeze({ ...orgSettingsRes, commute_deduction_settings: { enabled: false, allowed: false, }, -}; +}); diff --git a/src/app/core/mock-data/org-user-settings.data.ts b/src/app/core/mock-data/org-user-settings.data.ts index 605d165484..8e9d4f3042 100644 --- a/src/app/core/mock-data/org-user-settings.data.ts +++ b/src/app/core/mock-data/org-user-settings.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AccountType } from '../enums/account-type.enum'; import { OrgUserSettings } from '../models/org_user_settings.model'; -export const orgUserSettingsData: OrgUserSettings = { +export const orgUserSettingsData: OrgUserSettings = deepFreeze({ id: 'ousS9MgDNQ6NB', created_at: new Date('2018-02-01T02:32:25.275Z'), updated_at: new Date('2023-01-23T09:47:32.266Z'), @@ -158,27 +160,27 @@ export const orgUserSettingsData: OrgUserSettings = { enabled: true, allowed_payment_modes: [AccountType.PERSONAL, AccountType.CCC, AccountType.COMPANY], }, -}; +}); -export const orgUserSettingsWoPaymentModes: OrgUserSettings = { +export const orgUserSettingsWoPaymentModes: OrgUserSettings = deepFreeze({ ...orgUserSettingsData, payment_mode_settings: { allowed: false, enabled: false, allowed_payment_modes: [AccountType.PERSONAL, AccountType.CCC, AccountType.COMPANY], }, -}; +}); -export const orgUserSettingsWoPayModesCompany: OrgUserSettings = { +export const orgUserSettingsWoPayModesCompany: OrgUserSettings = deepFreeze({ ...orgUserSettingsWoPaymentModes, preferences: { default_project_id: 3943, default_vehicle_type: 'four_wheeler', default_payment_mode: 'COMPANY_ACCOUNT', }, -}; +}); -export const orgUserSettingsData2: OrgUserSettings = { +export const orgUserSettingsData2: OrgUserSettings = deepFreeze({ id: 'ousS9MgDNQ6NB', created_at: new Date('2018-02-01T02:32:25.275Z'), updated_at: new Date('2023-02-03T14:01:22.940Z'), @@ -335,9 +337,9 @@ export const orgUserSettingsData2: OrgUserSettings = { enabled: true, allowed_payment_modes: [AccountType.PERSONAL, AccountType.CCC, AccountType.COMPANY], }, -}; +}); -export const orgUserSettingsData3: OrgUserSettings = { +export const orgUserSettingsData3: OrgUserSettings = deepFreeze({ id: 'ousS9MgDNQ6NB', created_at: new Date('2018-02-01T02:32:25.275Z'), updated_at: new Date('2023-02-08T10:04:47.852Z'), @@ -494,9 +496,9 @@ export const orgUserSettingsData3: OrgUserSettings = { enabled: true, allowed_payment_modes: [AccountType.PERSONAL, AccountType.CCC, AccountType.COMPANY], }, -}; +}); -export const orgUserSettingsDataWoCCIDs: OrgUserSettings = { +export const orgUserSettingsDataWoCCIDs: OrgUserSettings = deepFreeze({ id: 'ousS9MgDNQ6NB', created_at: new Date('2018-02-01T02:32:25.275Z'), updated_at: new Date('2023-01-23T09:47:32.266Z'), @@ -653,60 +655,60 @@ export const orgUserSettingsDataWoCCIDs: OrgUserSettings = { enabled: true, allowed_payment_modes: [AccountType.PERSONAL, AccountType.CCC, AccountType.COMPANY], }, -}; +}); -export const orgUserSettingsWithCurrency: OrgUserSettings = { +export const orgUserSettingsWithCurrency: OrgUserSettings = deepFreeze({ ...orgUserSettingsData, currency_settings: { enabled: true, preferred_currency: 'USD', }, -}; +}); -export const orgUserSettingsWoDefaultProject: OrgUserSettings = { +export const orgUserSettingsWoDefaultProject: OrgUserSettings = deepFreeze({ ...orgUserSettingsData, preferences: { ...orgUserSettingsData.preferences, default_project_id: null, }, -}; +}); -export const orgUserSettingsWoInstaFyle: OrgUserSettings = { +export const orgUserSettingsWoInstaFyle: OrgUserSettings = deepFreeze({ ...orgUserSettingsData, insta_fyle_settings: { ...orgUserSettingsData.insta_fyle_settings, allowed: true, }, -}; +}); -export const orgUserSettingsWoProjects: OrgUserSettings = { +export const orgUserSettingsWoProjects: OrgUserSettings = deepFreeze({ ...orgUserSettingsData, project_ids: null, -}; +}); -export const notificationDelegateeSettings1: OrgUserSettings = { +export const notificationDelegateeSettings1: OrgUserSettings = deepFreeze({ ...orgUserSettingsData, notification_settings: { ...orgUserSettingsData.notification_settings, notify_delegatee: true, notify_user: false, }, -}; +}); -export const notificationDelegateeSettings2: OrgUserSettings = { +export const notificationDelegateeSettings2: OrgUserSettings = deepFreeze({ ...orgUserSettingsData, notification_settings: { ...orgUserSettingsData.notification_settings, notify_delegatee: false, notify_user: true, }, -}; +}); -export const notificationDelegateeSettings3: OrgUserSettings = { +export const notificationDelegateeSettings3: OrgUserSettings = deepFreeze({ ...orgUserSettingsData, notification_settings: { ...orgUserSettingsData.notification_settings, notify_delegatee: true, notify_user: true, }, -}; +}); diff --git a/src/app/core/mock-data/org.data.ts b/src/app/core/mock-data/org.data.ts index 04778403d1..6ab8790159 100644 --- a/src/app/core/mock-data/org.data.ts +++ b/src/app/core/mock-data/org.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Org } from '../models/org.model'; -export const orgData1: Org[] = [ +export const orgData1: Org[] = deepFreeze([ { id: 'orNVthTo2Zyo', created_at: new Date('2018-01-31T23:50:27.216Z'), @@ -21,9 +23,9 @@ export const orgData1: Org[] = [ lite: false, dwolla_customers_metadata_id: 'dcmbDcwO330Wn', }, -]; +]); -export const orgData2 = [ +export const orgData2 = deepFreeze([ { id: 'orNVthTo2Zyo', created_at: new Date('2018-01-31T23:50:27.216Z'), @@ -64,4 +66,4 @@ export const orgData2 = [ lite: false, dwolla_customers_metadata_id: 'dcmbDcwO440Xn', }, -]; +]); diff --git a/src/app/core/mock-data/outbox-queue.data.ts b/src/app/core/mock-data/outbox-queue.data.ts index ea30392884..bd1747ea17 100644 --- a/src/app/core/mock-data/outbox-queue.data.ts +++ b/src/app/core/mock-data/outbox-queue.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { OutboxQueue } from '../models/outbox-queue.model'; import { expectedUnflattendedTxnData3 } from './unflattened-txn.data'; -export const outboxQueueData1: OutboxQueue[] = [ +export const outboxQueueData1: OutboxQueue[] = deepFreeze([ { transaction: expectedUnflattendedTxnData3.tx, dataUrls: [ @@ -17,4 +19,4 @@ export const outboxQueueData1: OutboxQueue[] = [ applyMagic: true, fileUploadCompleted: true, }, -]; +]); diff --git a/src/app/core/mock-data/parsed-receipt.data.ts b/src/app/core/mock-data/parsed-receipt.data.ts index f8b11164a6..fda8fc4af1 100644 --- a/src/app/core/mock-data/parsed-receipt.data.ts +++ b/src/app/core/mock-data/parsed-receipt.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { InstaFyleResponse } from '../models/insta-fyle-data.model'; import { ParsedReceipt } from '../models/parsed_receipt.model'; -export const parsedReceiptData1: ParsedReceipt = { +export const parsedReceiptData1: ParsedReceipt = deepFreeze({ data: { category: 'SYSTEM', currency: 'USD', @@ -10,9 +12,9 @@ export const parsedReceiptData1: ParsedReceipt = { invoice_dt: new Date('2023-02-24T12:03:57.680Z'), vendor_name: 'vendor', }, -}; +}); -export const parsedReceiptData: ParsedReceipt = { +export const parsedReceiptData: ParsedReceipt = deepFreeze({ data: { category: 'SYSTEM', currency: 'USD', @@ -21,9 +23,9 @@ export const parsedReceiptData: ParsedReceipt = { invoice_dt: new Date('2023-02-24T12:03:57.680Z'), vendor_name: 'vendor', }, -}; +}); -export const parsedReceiptData2: ParsedReceipt = { +export const parsedReceiptData2: ParsedReceipt = deepFreeze({ data: { category: 'SYSTEM', currency: 'USD', @@ -32,9 +34,9 @@ export const parsedReceiptData2: ParsedReceipt = { invoice_dt: new Date('2023-02-24T12:03:57.680Z'), vendor_name: 'vendor', }, -}; +}); -export const expectedInstaFyleData1: InstaFyleResponse = { +export const expectedInstaFyleData1: InstaFyleResponse = deepFreeze({ thumbnail: 'data-url', type: 'image', url: 'data-url', @@ -47,9 +49,9 @@ export const expectedInstaFyleData1: InstaFyleResponse = { vendor_name: 'vendor', }, exchangeRate: 82, -}; +}); -export const instaFyleData1: InstaFyleResponse = { +export const instaFyleData1: InstaFyleResponse = deepFreeze({ thumbnail: 'data-url', type: 'image', url: 'data-url', @@ -62,9 +64,9 @@ export const instaFyleData1: InstaFyleResponse = { vendor_name: 'vendor', }, exchangeRate: 82, -}; +}); -export const extractedData: ParsedReceipt = { +export const extractedData: ParsedReceipt = deepFreeze({ data: { category: 'SYSTEM', currency: 'USD', @@ -74,9 +76,9 @@ export const extractedData: ParsedReceipt = { vendor_name: 'vendor', }, exchangeRate: 82, -}; +}); -export const expectedInstaFyleData2: InstaFyleResponse = { +export const expectedInstaFyleData2: InstaFyleResponse = deepFreeze({ thumbnail: 'data-url', type: 'image', url: 'data-url', @@ -88,9 +90,9 @@ export const expectedInstaFyleData2: InstaFyleResponse = { invoice_dt: new Date('2023-02-24T12:03:57.680Z'), vendor_name: 'vendor', }, -}; +}); -export const instaFyleData2: InstaFyleResponse = { +export const instaFyleData2: InstaFyleResponse = deepFreeze({ thumbnail: 'data-url', type: 'image', url: 'data-url', @@ -103,9 +105,9 @@ export const instaFyleData2: InstaFyleResponse = { vendor_name: 'vendor', }, exchangeRate: 82, -}; +}); -export const parsedInfo1: ParsedReceipt = { +export const parsedInfo1: ParsedReceipt = deepFreeze({ data: { category: 'SYSTEM', currency: 'USD', @@ -115,9 +117,9 @@ export const parsedInfo1: ParsedReceipt = { vendor_name: 'vendor', }, exchangeRate: 82, -}; +}); -export const parsedInfo2: ParsedReceipt = { +export const parsedInfo2: ParsedReceipt = deepFreeze({ data: { category: 'SYSTEM', currency: 'USD', @@ -127,9 +129,9 @@ export const parsedInfo2: ParsedReceipt = { vendor_name: 'vendor', }, exchangeRate: 82, -}; +}); -export const parsedReceiptDataWoDate: ParsedReceipt = { +export const parsedReceiptDataWoDate: ParsedReceipt = deepFreeze({ data: { category: 'SYSTEM', currency: 'USD', @@ -138,9 +140,9 @@ export const parsedReceiptDataWoDate: ParsedReceipt = { invoice_dt: new Date('2023-02-24T12:03:57.680Z'), vendor_name: 'vendor', }, -}; +}); -export const instaFyleData3 = { +export const instaFyleData3 = deepFreeze({ thumbnail: 'data-url', type: 'image', url: 'data-url', @@ -153,16 +155,16 @@ export const instaFyleData3 = { vendor_name: 'vendor', }, exchangeRate: null, -}; +}); -export const instaFyleData4 = { +export const instaFyleData4 = deepFreeze({ thumbnail: 'data-url', type: 'image', url: 'data-url', parsedResponse: null, -}; +}); -export const instaFyleData5 = { +export const instaFyleData5 = deepFreeze({ thumbnail: 'data-url', type: 'image', url: 'data-url', @@ -175,4 +177,4 @@ export const instaFyleData5 = { vendor_name: 'vendor', }, exchangeRate: null, -}; +}); diff --git a/src/app/core/mock-data/pdf-export.data.ts b/src/app/core/mock-data/pdf-export.data.ts index e0dbb66fb2..7aa2665fb5 100644 --- a/src/app/core/mock-data/pdf-export.data.ts +++ b/src/app/core/mock-data/pdf-export.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PdfExport } from '../models/pdf-exports.model'; -export const pdfExportData1: PdfExport[] = [ +export const pdfExportData1: PdfExport[] = deepFreeze([ { id: 'ldz3kKCK1ehw', sent_by: 'arjun.m@fyle.in', @@ -53,9 +55,9 @@ export const pdfExportData1: PdfExport[] = [ column_mappings: null, batch_size: null, }, -]; +]); -export const pdfExportData2: PdfExport[] = [ +export const pdfExportData2: PdfExport[] = deepFreeze([ { id: 'ldz3kKCK1ehw', sent_by: 'arjun.m@fyle.in', @@ -134,4 +136,4 @@ export const pdfExportData2: PdfExport[] = [ column_mappings: null, batch_size: null, }, -]; +]); diff --git a/src/app/core/mock-data/per-diem-custom-inputs.data.ts b/src/app/core/mock-data/per-diem-custom-inputs.data.ts index 990e6f17e9..66e32d8144 100644 --- a/src/app/core/mock-data/per-diem-custom-inputs.data.ts +++ b/src/app/core/mock-data/per-diem-custom-inputs.data.ts @@ -1,9 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + import { FormBuilder } from '@angular/forms'; import { TxnCustomProperties } from '../models/txn-custom-properties.model'; import { PerDiemCustomInputs } from '../models/per-diem-custom-inputs.model'; const formBuilder = new FormBuilder(); -export const perDiemCustomInputsData1 = [ +export const perDiemCustomInputsData1 = deepFreeze([ { id: 200227, mandatory: false, @@ -92,7 +94,7 @@ export const perDiemCustomInputsData1 = [ value: '2023-02-13', }), }, -]; +]); // eslint-disable-next-line @typescript-eslint/no-unused-vars export const expectedExpenseFieldWithoutControl = perDiemCustomInputsData1.map(({ control, ...otherProps }) => ({ @@ -103,7 +105,7 @@ export const expectedControlValues = perDiemCustomInputsData1.map( ({ control }: { control: { value: string | string[] } }) => control.value ); -export const perDiemCustomInputsData2: PerDiemCustomInputs[] = [ +export const perDiemCustomInputsData2: PerDiemCustomInputs[] = deepFreeze([ { id: 318297, mandatory: true, @@ -132,4 +134,4 @@ export const perDiemCustomInputsData2: PerDiemCustomInputs[] = [ value: '', }), }, -]; +]); diff --git a/src/app/core/mock-data/per-diem-form-value.data.ts b/src/app/core/mock-data/per-diem-form-value.data.ts index 667163af65..1b2cf86f74 100644 --- a/src/app/core/mock-data/per-diem-form-value.data.ts +++ b/src/app/core/mock-data/per-diem-form-value.data.ts @@ -1,3 +1,5 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PerDiemFormValue } from '../models/per-diem-form-value.model'; import { multiplePaymentModesData } from '../test-data/accounts.service.spec.data'; import { costCentersData2, expectedCCdata3 } from './cost-centers.data'; @@ -7,7 +9,7 @@ import { orgCategoryData1 } from './org-category.data'; import { perDiemRatesData1 } from './per-diem-rates.data'; import { expectedReportsPaginated } from './platform-report.data'; -export const perDiemFormValuesData1: Partial = { +export const perDiemFormValuesData1: Partial = deepFreeze({ paymentMode: multiplePaymentModesData[0], sub_category: undefined, per_diem_rate: null, @@ -22,14 +24,14 @@ export const perDiemFormValuesData1: Partial = { custom_inputs: [], project_dependent_fields: [], cost_center_dependent_fields: [], -}; +}); -export const perDiemFormValuesData2: Partial = { +export const perDiemFormValuesData2: Partial = deepFreeze({ ...perDiemFormValuesData1, project: null, -}; +}); -export const perDiemFormValuesData3: Partial = { +export const perDiemFormValuesData3: Partial = deepFreeze({ ...perDiemFormValuesData1, per_diem_rate: { active: true, @@ -43,31 +45,31 @@ export const perDiemFormValuesData3: Partial = { full_name: 'BulkTest2 (50 USD per day)', readableRate: '$50.00 per day', }, -}; +}); -export const perDiemFormValuesData4: Partial = { +export const perDiemFormValuesData4: Partial = deepFreeze({ ...perDiemFormValuesData1, report: expectedReportsPaginated[0], -}; +}); -export const perDiemFormValuesData5: Partial = { +export const perDiemFormValuesData5: Partial = deepFreeze({ ...perDiemFormValuesData1, report: expectedReportsPaginated[0], -}; +}); -export const perDiemFormValuesData6: Partial = { +export const perDiemFormValuesData6: Partial = deepFreeze({ ...perDiemFormValuesData1, costCenter: expectedCCdata3[0].value, -}; +}); -export const perDiemFormValuesData7: Partial = { +export const perDiemFormValuesData7: Partial = deepFreeze({ ...perDiemFormValuesData1, to_dt: '2023-08-03', from_dt: '2023-08-01', num_days: 3, -}; +}); -export const perDiemFormValuesData8: PerDiemFormValue = { +export const perDiemFormValuesData8: PerDiemFormValue = deepFreeze({ currencyObj: currencyObjData6, paymentMode: multiplePaymentModesData[0], sub_category: orgCategoryData1[0], @@ -95,9 +97,9 @@ export const perDiemFormValuesData8: PerDiemFormValue = { }, ], cost_center_dependent_fields: [], -}; +}); -export const perDiemFormValuesData9: PerDiemFormValue = { +export const perDiemFormValuesData9: PerDiemFormValue = deepFreeze({ currencyObj: currencyObjData6, paymentMode: multiplePaymentModesData[0], sub_category: undefined, @@ -113,9 +115,9 @@ export const perDiemFormValuesData9: PerDiemFormValue = { custom_inputs: [], project_dependent_fields: [], cost_center_dependent_fields: [], -}; +}); -export const perDiemFormValuesData10: PerDiemFormValue = { +export const perDiemFormValuesData10: PerDiemFormValue = deepFreeze({ ...perDiemFormValuesData8, custom_inputs: [ { @@ -143,4 +145,4 @@ export const perDiemFormValuesData10: PerDiemFormValue = { displayValue: null, }, ], -}; +}); diff --git a/src/app/core/mock-data/per-diem-rates.data.ts b/src/app/core/mock-data/per-diem-rates.data.ts index 2f704a7433..ed6b63fb08 100644 --- a/src/app/core/mock-data/per-diem-rates.data.ts +++ b/src/app/core/mock-data/per-diem-rates.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PerDiemRates } from '../models/v1/per-diem-rates.model'; -export const perDiemRatesData1: PerDiemRates = { +export const perDiemRatesData1: PerDiemRates = deepFreeze({ active: true, created_at: new Date('2023-08-21'), currency: 'USD', @@ -11,12 +13,12 @@ export const perDiemRatesData1: PerDiemRates = { rate: 30, readableRate: '$30.00 per day', updated_at: new Date('2023-08-21'), -}; +}); -export const perDiemRatesData2: PerDiemRates = { +export const perDiemRatesData2: PerDiemRates = deepFreeze({ ...perDiemRatesData1, currency: 'INR', full_name: 'Rate 1 (300 INR per day)', rate: 300, readableRate: '₹300.00 per day', -}; +}); diff --git a/src/app/core/mock-data/personal-card-txns.data.ts b/src/app/core/mock-data/personal-card-txns.data.ts index 95ccebf049..63caa7936d 100644 --- a/src/app/core/mock-data/personal-card-txns.data.ts +++ b/src/app/core/mock-data/personal-card-txns.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PersonalCardTxn } from '../models/personal_card_txn.model'; import { ApiV2Response } from '../models/v2/api-v2-response.model'; -export const apiPersonalCardTxnsRes: ApiV2Response = { +export const apiPersonalCardTxnsRes: ApiV2Response = deepFreeze({ count: 1, data: [ { @@ -33,9 +35,9 @@ export const apiPersonalCardTxnsRes: ApiV2Response = { limit: 1, offset: 0, url: '/v2/personal_bank_transactions', -}; +}); -export const matchedPersonalCardTxn: PersonalCardTxn = { +export const matchedPersonalCardTxn: PersonalCardTxn = deepFreeze({ _search_document: "'200':1 '200.00':2 'card':5 'debit':4,18 'huskyteambkstore':11 'purchase':6 'usd':3 'wa':16 'xx':8 'xx/xx':7 'xxp':9 'xxx':13,14 'xxx-xxx-xxxx':12 'xxxx':15 'xxxxuw':10 'xxxxx':17", ba_account_number: 'xxxx2345', @@ -76,4 +78,4 @@ export const matchedPersonalCardTxn: PersonalCardTxn = { vendor_name: 'Office & Shipping', }, ], -}; +}); diff --git a/src/app/core/mock-data/personal-cards.data.ts b/src/app/core/mock-data/personal-cards.data.ts index 30fc6a9823..197d84c54d 100644 --- a/src/app/core/mock-data/personal-cards.data.ts +++ b/src/app/core/mock-data/personal-cards.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ApiV2Response } from '../models/api-v2.model'; import { PersonalCard } from '../models/personal_card.model'; -export const apiLinkedAccRes: ApiV2Response = { +export const apiLinkedAccRes: ApiV2Response = deepFreeze({ count: 11, data: [ { @@ -46,9 +48,9 @@ export const apiLinkedAccRes: ApiV2Response = { limit: 11, offset: 0, url: '/v2/personal_bank_accounts', -}; +}); -export const deletePersonalCardRes: PersonalCard = { +export const deletePersonalCardRes: PersonalCard = deepFreeze({ account_number: 'xxxx9806', account_type: 'CREDIT', bank_name: 'Dag Site yodlee', @@ -66,9 +68,9 @@ export const deletePersonalCardRes: PersonalCard = { unclassified_count: 0, update_credentials: false, updated_at: new Date('2022-05-31T07:40:58.190907'), -}; +}); -export const linkedAccountsRes: PersonalCard[] = [ +export const linkedAccountsRes: PersonalCard[] = deepFreeze([ { account_number: 'xxxx4227', account_type: 'CHECKING', @@ -107,4 +109,4 @@ export const linkedAccountsRes: PersonalCard[] = [ update_credentials: false, updated_at: new Date('2023-01-12T15:57:47.178727'), }, -]; +]); diff --git a/src/app/core/mock-data/platform-api-category.data.ts b/src/app/core/mock-data/platform-api-category.data.ts index 0ebbfb1110..4695428d5f 100644 --- a/src/app/core/mock-data/platform-api-category.data.ts +++ b/src/app/core/mock-data/platform-api-category.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ApiV2Response } from '../models/api-v2.model'; import { PlatformCategory } from '../models/platform/platform-category.model'; -export const platformApiCategoryRes: ApiV2Response = { +export const platformApiCategoryRes: ApiV2Response = deepFreeze({ count: 318, data: [ { @@ -19,9 +21,9 @@ export const platformApiCategoryRes: ApiV2Response = { }, ], offset: 0, -}; +}); -export const platformApiAllCategories: ApiV2Response = { +export const platformApiAllCategories: ApiV2Response = deepFreeze({ count: 4, data: [ { @@ -78,9 +80,9 @@ export const platformApiAllCategories: ApiV2Response = { }, ], offset: 0, -}; +}); -export const platformApiCategoryById: ApiV2Response = { +export const platformApiCategoryById: ApiV2Response = deepFreeze({ count: 3, data: [ { @@ -124,9 +126,9 @@ export const platformApiCategoryById: ApiV2Response = { }, ], offset: 0, -}; +}); -export const platformApiCategoriesByName: ApiV2Response = { +export const platformApiCategoriesByName: ApiV2Response = deepFreeze({ count: 3, data: [ { @@ -170,4 +172,4 @@ export const platformApiCategoriesByName: ApiV2Response = { }, ], offset: 0, -}; +}); diff --git a/src/app/core/mock-data/platform-corporate-card-detail.data.ts b/src/app/core/mock-data/platform-corporate-card-detail.data.ts index 178e606498..b62377a1c3 100644 --- a/src/app/core/mock-data/platform-corporate-card-detail.data.ts +++ b/src/app/core/mock-data/platform-corporate-card-detail.data.ts @@ -1,8 +1,10 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PlatformCorporateCardDetail } from '../models/platform-corporate-card-detail.model'; import { mastercardRTFCard, statementUploadedCard, virtualCard, visaRTFCard } from './platform-corporate-card.data'; import { virtualCardCombinedResponse } from './virtual-card-combined-response.data'; -export const virtualCardDetails: PlatformCorporateCardDetail[] = [ +export const virtualCardDetails: PlatformCorporateCardDetail[] = deepFreeze([ { card: virtualCard, stats: { @@ -14,9 +16,9 @@ export const virtualCardDetails: PlatformCorporateCardDetail[] = [ totalAmountValue: 0, }, }, -]; +]); -export const cardDetailsRes: PlatformCorporateCardDetail[] = [ +export const cardDetailsRes: PlatformCorporateCardDetail[] = deepFreeze([ { card: visaRTFCard, stats: { @@ -51,9 +53,9 @@ export const cardDetailsRes: PlatformCorporateCardDetail[] = [ }, }, virtualCardDetails[0], -]; +]); -export const statementUploadedCardDetail: PlatformCorporateCardDetail[] = [ +export const statementUploadedCardDetail: PlatformCorporateCardDetail[] = deepFreeze([ { card: statementUploadedCard, stats: { @@ -65,11 +67,11 @@ export const statementUploadedCardDetail: PlatformCorporateCardDetail[] = [ totalAmountValue: 1874.4, }, }, -]; +]); -export const virtualCardDetailsCombined: PlatformCorporateCardDetail[] = [ +export const virtualCardDetailsCombined: PlatformCorporateCardDetail[] = deepFreeze([ { ...virtualCardDetails[0], - virtualCardDetail: virtualCardCombinedResponse['vc1234'], + virtualCardDetail: virtualCardCombinedResponse.vc1234, }, -]; +]); diff --git a/src/app/core/mock-data/platform-corporate-card.data.ts b/src/app/core/mock-data/platform-corporate-card.data.ts index 399a85d87c..e34e8a02df 100644 --- a/src/app/core/mock-data/platform-corporate-card.data.ts +++ b/src/app/core/mock-data/platform-corporate-card.data.ts @@ -1,8 +1,10 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CardStatus } from '../enums/card-status.enum'; import { DataFeedSource } from '../enums/data-feed-source.enum'; import { PlatformCorporateCard } from '../models/platform/platform-corporate-card.model'; -export const mastercardRTFCard: PlatformCorporateCard = { +export const mastercardRTFCard: PlatformCorporateCard = deepFreeze({ assignor_user_id: 'usvKA4X8Ugcr', bank_name: 'MASTERCARD_BANK', card_number: '555555******5555', @@ -23,9 +25,9 @@ export const mastercardRTFCard: PlatformCorporateCard = { updated_at: '2023-03-03T07:16:46.376082+00:00', user_id: 'usvKA4X8Ugcr', verification_status: 'NOT_VERIFIED', -}; +}); -export const visaRTFCard: PlatformCorporateCard = { +export const visaRTFCard: PlatformCorporateCard = deepFreeze({ assignor_user_id: 'usvKA4X8Ugcr', bank_name: 'VISA_BANK', card_number: '455555******5555', @@ -46,9 +48,9 @@ export const visaRTFCard: PlatformCorporateCard = { updated_at: '2023-03-03T07:16:46.376082+00:00', user_id: 'usvKA4X8Ugcr', verification_status: 'NOT_VERIFIED', -}; +}); -export const statementUploadedCard: PlatformCorporateCard = { +export const statementUploadedCard: PlatformCorporateCard = deepFreeze({ assignor_user_id: 'usvKA4X8Ugcr', bank_name: 'MASTERCARD_BANK', card_number: '5555', @@ -69,9 +71,9 @@ export const statementUploadedCard: PlatformCorporateCard = { updated_at: '2023-03-03T07:16:46.376082+00:00', user_id: 'usvKA4X8Ugcr', verification_status: 'NOT_VERIFIED', -}; +}); -export const virtualCard: PlatformCorporateCard = { +export const virtualCard: PlatformCorporateCard = deepFreeze({ assignor_user_id: 'usvKA4X8Ugcr', bank_name: 'American Express', card_number: '5555', @@ -94,9 +96,9 @@ export const virtualCard: PlatformCorporateCard = { verification_status: 'NOT_VERIFIED', virtual_card_id: 'vc1234', virtual_card_state: CardStatus.PREACTIVE, -}; +}); -export const bankFeedCard: PlatformCorporateCard = { +export const bankFeedCard: PlatformCorporateCard = deepFreeze({ assignor_user_id: 'usvKA4X8Ugcr', bank_name: 'MASTERCARD_BANK', card_number: '555555******5555', @@ -117,9 +119,9 @@ export const bankFeedCard: PlatformCorporateCard = { updated_at: '2023-03-03T07:16:46.376082+00:00', user_id: 'usvKA4X8Ugcr', verification_status: 'NOT_VERIFIED', -}; +}); -export const yodleeCard: PlatformCorporateCard = { +export const yodleeCard: PlatformCorporateCard = deepFreeze({ assignor_user_id: 'usvKA4X8Ugcr', bank_name: 'MASTERCARD_BANK', card_number: '555555******5555', @@ -140,9 +142,9 @@ export const yodleeCard: PlatformCorporateCard = { updated_at: '2023-03-03T07:16:46.376082+00:00', user_id: 'usvKA4X8Ugcr', verification_status: 'NOT_VERIFIED', -}; +}); -export const amexFeedCard: PlatformCorporateCard = { +export const amexFeedCard: PlatformCorporateCard = deepFreeze({ assignor_user_id: 'usvKA4X8Ugcr', bank_name: 'AMEX_BANK', card_number: '**********81000', @@ -163,4 +165,4 @@ export const amexFeedCard: PlatformCorporateCard = { updated_at: '2023-03-03T07:16:46.376082+00:00', user_id: 'usvKA4X8Ugcr', verification_status: 'NOT_VERIFIED', -}; +}); diff --git a/src/app/core/mock-data/platform-cost-centers.data.ts b/src/app/core/mock-data/platform-cost-centers.data.ts index 11d6828cd8..0697d744de 100644 --- a/src/app/core/mock-data/platform-cost-centers.data.ts +++ b/src/app/core/mock-data/platform-cost-centers.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PlatformCostCenter } from '../models/platform/platform-cost-center.model'; import { PlatformApiResponse } from '../models/platform/platform-api-response.model'; -export const platformCostCenterSingleRes: PlatformApiResponse = { +export const platformCostCenterSingleRes: PlatformApiResponse = deepFreeze({ count: 1, data: [ { @@ -16,9 +18,9 @@ export const platformCostCenterSingleRes: PlatformApiResponse = { +export const platformCostCenterMultipleRes: PlatformApiResponse = deepFreeze({ count: 4, data: [ { @@ -63,4 +65,4 @@ export const platformCostCenterMultipleRes: PlatformApiResponse = { +export const platformMileageRates: PlatformApiResponse = deepFreeze({ count: 4, data: [ { @@ -73,9 +75,9 @@ export const platformMileageRates: PlatformApiResponse = { }, ], offset: 0, -}; +}); -export const platformMileageRatesSingleData: PlatformApiResponse = { +export const platformMileageRatesSingleData: PlatformApiResponse = deepFreeze({ count: 1, data: [ { @@ -92,9 +94,9 @@ export const platformMileageRatesSingleData: PlatformApiResponse = { +export const expensePolicyStatesData: PlatformApiResponse = deepFreeze({ count: 1, data: [ { @@ -263,15 +265,15 @@ export const expensePolicyStatesData: PlatformApiResponse = }, ], offset: 0, -}; +}); -export const emptyApiResponse: PlatformApiResponse = { +export const emptyApiResponse: PlatformApiResponse = deepFreeze({ count: 0, data: [], offset: 0, -}; +}); -export const ApproverExpensePolicyStatesData: PlatformApiResponse = { +export const ApproverExpensePolicyStatesData: PlatformApiResponse = deepFreeze({ count: 1, data: [ { @@ -290,9 +292,9 @@ export const ApproverExpensePolicyStatesData: PlatformApiResponse = { +export const platformReportCountData: PlatformApiResponse = deepFreeze({ count: 4, data: [platformReportData], offset: 0, -}; +}); -export const allReportsPaginated1: PlatformApiResponse = { +export const allReportsPaginated1: PlatformApiResponse = deepFreeze({ count: 4, data: [ { @@ -204,9 +206,9 @@ export const allReportsPaginated1: PlatformApiResponse = { }, ], offset: 0, -}; +}); -export const allReportsPaginated2: PlatformApiResponse = { +export const allReportsPaginated2: PlatformApiResponse = deepFreeze({ count: 4, data: [ { @@ -335,10 +337,13 @@ export const allReportsPaginated2: PlatformApiResponse = { }, ], offset: 2, -}; +}); -export const expectedSingleReport: Report[] = [allReportsPaginated1.data[0]]; +export const expectedSingleReport: Report[] = deepFreeze([allReportsPaginated1.data[0]]); -export const expectedReportsSinglePage: Report[] = [...allReportsPaginated1.data]; +export const expectedReportsSinglePage: Report[] = deepFreeze([...allReportsPaginated1.data]); -export const expectedReportsPaginated: Report[] = [...allReportsPaginated1.data, ...allReportsPaginated2.data]; +export const expectedReportsPaginated: Report[] = deepFreeze([ + ...allReportsPaginated1.data, + ...allReportsPaginated2.data, +]); diff --git a/src/app/core/mock-data/platform/v1/advance-request-platform.data.ts b/src/app/core/mock-data/platform/v1/advance-request-platform.data.ts index 2d8a713e27..d7629a5d0c 100644 --- a/src/app/core/mock-data/platform/v1/advance-request-platform.data.ts +++ b/src/app/core/mock-data/platform/v1/advance-request-platform.data.ts @@ -1,10 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + import { cloneDeep } from 'lodash'; import { CustomFieldTypes } from 'src/app/core/enums/platform/v1/custom-fields-type.enum'; -import { AdvanceRequestState } from 'src/app/core/models/advance-request-state.model'; import { AdvanceRequestPlatform } from 'src/app/core/models/platform/advance-request-platform.model'; import { PlatformApiResponse } from 'src/app/core/models/platform/platform-api-response.model'; -export const advanceRequestPlatform: PlatformApiResponse = { +export const advanceRequestPlatform: PlatformApiResponse = deepFreeze({ count: 1, offset: 0, data: [ @@ -87,9 +88,9 @@ export const advanceRequestPlatform: PlatformApiResponse ], }, ], -}; +}); -export const advanceRequestPlatformPulledBack: PlatformApiResponse = { +export const advanceRequestPlatformPulledBack: PlatformApiResponse = deepFreeze({ count: 1, offset: 0, data: [ @@ -99,9 +100,9 @@ export const advanceRequestPlatformPulledBack: PlatformApiResponse = { +export const advanceRequestPlatformSentBack: PlatformApiResponse = deepFreeze({ count: 1, offset: 0, data: [ @@ -111,4 +112,4 @@ export const advanceRequestPlatformSentBack: PlatformApiResponse; -const mileageCategory: Category = { +const mileageCategory: Category = deepFreeze({ code: null, display_name: 'mileage display', id: 267841, name: 'Mileage', sub_category: 'Others', system_category: 'Mileage', -}; +}); -const perDiemCategory = { +const perDiemCategory = deepFreeze({ code: null, display_name: 'Per Diem display', id: 267841, name: 'Per Diem', sub_category: 'Others', system_category: 'Per Diem', -}; +}); -export const mileageExpenseWithDistance: Expense = { +export const mileageExpenseWithDistance: Expense = deepFreeze({ ...expenseData, distance: 25, distance_unit: MileageUnitEnum.KM, category: mileageCategory, -}; +}); -export const mileageExpenseWithoutDistance: Expense = { +export const mileageExpenseWithoutDistance: Expense = deepFreeze({ ...expenseData, distance: 0, distance_unit: MileageUnitEnum.KM, category: mileageCategory, -}; +}); -export const perDiemExpenseWithSingleNumDays: Expense = { +export const perDiemExpenseWithSingleNumDays: Expense = deepFreeze({ ...expenseData, category: perDiemCategory, per_diem_num_days: 1, -}; +}); -export const perDiemExpenseWithMultipleNumDays: Expense = { +export const perDiemExpenseWithMultipleNumDays: Expense = deepFreeze({ ...expenseData, category: perDiemCategory, per_diem_num_days: 3, -}; +}); -export const apiExpenses1: Expense[] = [ +export const apiExpenses1: Expense[] = deepFreeze([ { accounting_export_summary: {}, @@ -1715,25 +1717,25 @@ export const apiExpenses1: Expense[] = [ user_id: 'usuQPzaT0w9C', verifier_comments: [], }, -]; +]); -export const perDiemExpenseWithSingleNumDays2: Expense = { +export const perDiemExpenseWithSingleNumDays2: Expense = deepFreeze({ ...perDiemExpenseWithSingleNumDays, category: { ...perDiemExpenseWithSingleNumDays.category, name: 'Per Diem', }, -}; +}); -export const mileageExpenseWithDistance2: Expense = { +export const mileageExpenseWithDistance2: Expense = deepFreeze({ ...mileageExpenseWithDistance, category: { ...mileageExpenseWithDistance.category, name: 'Mileage', }, -}; +}); -export const readyToReportExpensesData: Expense[] = [ +export const readyToReportExpensesData: Expense[] = deepFreeze([ { ...expenseData, amount: 50, @@ -1744,9 +1746,9 @@ export const readyToReportExpensesData: Expense[] = [ amount: 100, id: 'txWjW9qT2Vf1', }, -]; +]); -export const readyToReportExpensesData2: Expense[] = [ +export const readyToReportExpensesData2: Expense[] = deepFreeze([ { ...expenseData, amount: 100, @@ -1759,19 +1761,19 @@ export const readyToReportExpensesData2: Expense[] = [ is_reimbursable: true, id: 'txWjW9qT2Vf1', }, -]; +]); -export const nonReimbursableExpense: Expense = { +export const nonReimbursableExpense: Expense = deepFreeze({ ...expenseData, is_reimbursable: false, -}; +}); -export const draftExpense: Expense = { +export const draftExpense: Expense = deepFreeze({ ...expenseData, state: ExpenseState.DRAFT, -}; +}); -export const splitExpensesData: Expense[] = [ +export const splitExpensesData: Expense[] = deepFreeze([ { accounting_export_summary: {}, added_to_report_at: null, @@ -2068,11 +2070,11 @@ export const splitExpensesData: Expense[] = [ verifications: [], verifier_comments: [], }, -]; +]); -export const apiExpenses2: Expense[] = [splitExpensesData[0]]; +export const apiExpenses2: Expense[] = deepFreeze([splitExpensesData[0]]); -export const apiExpenses3: Expense[] = [ +export const apiExpenses3: Expense[] = deepFreeze([ { accounting_export_summary: {}, added_to_report_at: null, @@ -2369,9 +2371,9 @@ export const apiExpenses3: Expense[] = [ verifications: [], verifier_comments: [], }, -]; +]); -export const platformExpenseData: Expense = { +export const platformExpenseData: Expense = deepFreeze({ accounting_export_summary: {}, added_to_report_at: null, admin_amount: null, @@ -2535,9 +2537,9 @@ export const platformExpenseData: Expense = { }, user_id: 'usvMoPfCC9Xw', verifier_comments: ['Amount changed due to following reason(s) : No policy violation explanation provided'], -}; +}); -export const platformExpenseDataWithSubCategory: Expense = { +export const platformExpenseDataWithSubCategory: Expense = deepFreeze({ accounting_export_summary: {}, added_to_report_at: null, id: 'txD5hIQgLuR5', @@ -2755,19 +2757,19 @@ export const platformExpenseDataWithSubCategory: Expense = { user_id: 'usvMoPfCC9Xw', verifications: [], verifier_comments: [], -}; +}); -export const platformExpenseDataWithReportId: Expense = { +export const platformExpenseDataWithReportId: Expense = deepFreeze({ ...platformExpenseDataWithSubCategory, report_id: 'rpbNc3kn5baq', -}; +}); -export const platformExpenseDataWithReportId2: Expense = { +export const platformExpenseDataWithReportId2: Expense = deepFreeze({ ...platformExpenseDataWithSubCategory, report_id: 'rplD17WeBlha', -}; +}); -export const platformExpenseWithExtractedData: Expense = { +export const platformExpenseWithExtractedData: Expense = deepFreeze({ accounting_export_summary: {}, added_to_report_at: null, admin_amount: null, @@ -2959,9 +2961,9 @@ export const platformExpenseWithExtractedData: Expense = { user_id: 'usvMoPfCC9Xw', verifications: [], verifier_comments: [], -}; +}); -export const platformExpenseWithExtractedData2: Expense = { +export const platformExpenseWithExtractedData2: Expense = deepFreeze({ ...platformExpenseWithExtractedData, category: { code: null, @@ -2979,9 +2981,9 @@ export const platformExpenseWithExtractedData2: Expense = { invoice_dt: null, vendor_name: 'SWIGGY', }, -}; +}); -export const platformExpenseWithMatchCCC: Expense = { +export const platformExpenseWithMatchCCC: Expense = deepFreeze({ accounting_export_summary: {}, added_to_report_at: null, admin_amount: null, @@ -3139,26 +3141,26 @@ export const platformExpenseWithMatchCCC: Expense = { user_id: 'usvMoPfCC9Xw', verifications: [], verifier_comments: [], -}; +}); -export const platformExpenseWithMatchCCC2: Expense = { +export const platformExpenseWithMatchCCC2: Expense = deepFreeze({ ...platformExpenseWithMatchCCC, matched_corporate_card_transaction_ids: [], matched_corporate_card_transactions: [], -}; +}); -export const mileageCategoryPlatformExpenseData: Expense = { +export const mileageCategoryPlatformExpenseData: Expense = deepFreeze({ ...platformExpenseData, category: { ...platformExpenseData.category, name: 'MILEAGE' }, -}; +}); -export const perDiemCategoryPlatformExpenseData: Expense = { +export const perDiemCategoryPlatformExpenseData: Expense = deepFreeze({ ...platformExpenseData, category: { ...platformExpenseData.category, name: 'PER DIEM' }, -}; +}); -export const expensesList: Expense[] = [ +export const expensesList: Expense[] = deepFreeze([ { ...platformExpenseData, }, -]; +]); diff --git a/src/app/core/mock-data/platform/v1/expenses-query-params.data.ts b/src/app/core/mock-data/platform/v1/expenses-query-params.data.ts index 40e0d70692..02ad78504b 100644 --- a/src/app/core/mock-data/platform/v1/expenses-query-params.data.ts +++ b/src/app/core/mock-data/platform/v1/expenses-query-params.data.ts @@ -1,23 +1,25 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExpensesQueryParams } from 'src/app/core/models/platform/v1/expenses-query-params.model'; -export const getExpensesQueryParams: ExpensesQueryParams = { +export const getExpensesQueryParams: ExpensesQueryParams = deepFreeze({ report_id: 'eq.txOJVaaPxo9O', -}; +}); -export const allExpensesQueryParams: ExpensesQueryParams = { +export const allExpensesQueryParams: ExpensesQueryParams = deepFreeze({ queryParams: { employee_id: 'eq.out3t2X258rd', state: ['in.(COMPLETE)'], or: ['(policy_amount.is.null,policy_amount.gt.0.0001)'], report_id: ['is.null'], }, -}; +}); -export const unreportedExpensesQueryParams: ExpensesQueryParams = { +export const unreportedExpensesQueryParams: ExpensesQueryParams = deepFreeze({ queryParams: { state: 'in.(COMPLETE)', or: '(policy_amount.is.null,policy_amount.gt.0.0001)', report_id: 'is.null', and: '(or(matched_corporate_card_transactions.eq.[],matched_corporate_card_transactions->0->status.neq.PENDING))', }, -}; +}); diff --git a/src/app/core/mock-data/platform/v1/expenses-response.data.ts b/src/app/core/mock-data/platform/v1/expenses-response.data.ts index 1910619b58..4efbbcf16b 100644 --- a/src/app/core/mock-data/platform/v1/expenses-response.data.ts +++ b/src/app/core/mock-data/platform/v1/expenses-response.data.ts @@ -1,9 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PlatformApiResponse } from 'src/app/core/models/platform/platform-api-response.model'; import { expenseData } from './expense.data'; import { Expense } from 'src/app/core/models/platform/v1/expense.model'; -export const expensesResponse: PlatformApiResponse = { +export const expensesResponse: PlatformApiResponse = deepFreeze({ count: 1, data: [expenseData], offset: 0, -}; +}); diff --git a/src/app/core/mock-data/platform/v1/expenses-stats.data.ts b/src/app/core/mock-data/platform/v1/expenses-stats.data.ts index ee6a3c4010..94153ebc25 100644 --- a/src/app/core/mock-data/platform/v1/expenses-stats.data.ts +++ b/src/app/core/mock-data/platform/v1/expenses-stats.data.ts @@ -1,27 +1,29 @@ -export const completeStats = { +import deepFreeze from 'deep-freeze-strict'; + +export const completeStats = deepFreeze({ data: { count: 3, total_amount: 30, }, -}; +}); -export const emptyStats = { +export const emptyStats = deepFreeze({ data: { count: 0, total_amount: 0, }, -}; +}); -export const incompleteStats = { +export const incompleteStats = deepFreeze({ data: { count: 339, total_amount: 76234.4729069240282984, }, -}; +}); -export const completeStats1 = { +export const completeStats1 = deepFreeze({ data: { count: 4, total_amount: 3494, }, -}; +}); diff --git a/src/app/core/mock-data/policy-violation.data.ts b/src/app/core/mock-data/policy-violation.data.ts index 115af74d77..a17d78e82d 100644 --- a/src/app/core/mock-data/policy-violation.data.ts +++ b/src/app/core/mock-data/policy-violation.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PolicyViolation } from '../models/policy-violation.model'; import { PolicyViolationTxn } from '../models/policy-violation-txn.model'; -export const policyViolation1: PolicyViolation = { +export const policyViolation1: PolicyViolation = deepFreeze({ data: { final_desired_state: { add_approver_user_ids: [], @@ -13,9 +15,9 @@ export const policyViolation1: PolicyViolation = { }, individual_desired_states: [], }, -}; +}); -export const splitPolicyExp2: PolicyViolation = { +export const splitPolicyExp2: PolicyViolation = deepFreeze({ data: { final_desired_state: { add_approver_user_ids: [], @@ -32,9 +34,9 @@ export const splitPolicyExp2: PolicyViolation = { currency: 'USD', name: 'Food', type: 'category', -}; +}); -export const splitPolicyExp3: PolicyViolation = { +export const splitPolicyExp3: PolicyViolation = deepFreeze({ data: { final_desired_state: { add_approver_user_ids: [], @@ -51,14 +53,14 @@ export const splitPolicyExp3: PolicyViolation = { currency: 'USD', name: 'Food / Travelling - Inland', type: 'category', -}; +}); -export const policyVoilationData2: PolicyViolationTxn = { +export const policyVoilationData2: PolicyViolationTxn = deepFreeze({ txVHydZVrGYC: splitPolicyExp2, tx4QhcvNHpuh: splitPolicyExp3, -}; +}); -export const splitPolicyExp4: PolicyViolation = { +export const splitPolicyExp4: PolicyViolation = deepFreeze({ data: { final_desired_state: { add_approver_user_ids: [], @@ -95,9 +97,9 @@ export const splitPolicyExp4: PolicyViolation = { currency: 'INR', name: '1 / chumma returns', type: 'category', -}; +}); -export const splitPolicyExp5: PolicyViolation = { +export const splitPolicyExp5: PolicyViolation = deepFreeze({ data: { final_desired_state: { add_approver_user_ids: [], @@ -146,19 +148,19 @@ export const splitPolicyExp5: PolicyViolation = { currency: 'INR', name: '1 / sd', type: 'category', -}; +}); -export const policyViolationData3: PolicyViolationTxn = { +export const policyViolationData3: PolicyViolationTxn = deepFreeze({ txc2KIogxUAy: splitPolicyExp4, txgfkvuYteta: splitPolicyExp5, -}; +}); -export const policyViolationData4: PolicyViolationTxn = { +export const policyViolationData4: PolicyViolationTxn = deepFreeze({ txSEM4DtjyKR: splitPolicyExp4, txNyI8ot5CuJ: splitPolicyExp5, -}; +}); -export const policyViolationData5: PolicyViolation = { +export const policyViolationData5: PolicyViolation = deepFreeze({ amount: 122, currency: 'INR', name: 'Food', @@ -175,4 +177,4 @@ export const policyViolationData5: PolicyViolation = { run_summary: [], }, }, -}; +}); diff --git a/src/app/core/mock-data/policy-violcation-comment.data.ts b/src/app/core/mock-data/policy-violcation-comment.data.ts index e72023bd00..571c9d9d72 100644 --- a/src/app/core/mock-data/policy-violcation-comment.data.ts +++ b/src/app/core/mock-data/policy-violcation-comment.data.ts @@ -1,46 +1,48 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PolicyViolationComment } from '../models/policy-violation-comment.model'; -export const violationComment1: PolicyViolationComment = { +export const violationComment1: PolicyViolationComment = deepFreeze({ objectType: 'reports', txnId: 'rpkpSa8guCuR', comment: { comment: 'a comment', }, notify: false, -}; +}); -export const violationComment2: PolicyViolationComment = { +export const violationComment2: PolicyViolationComment = deepFreeze({ objectType: 'transactions', txnId: 'txxkBruL0EO9', comment: { comment: 'Policy violation explanation: another comment', }, notify: true, -}; +}); -export const violationComment3: PolicyViolationComment = { +export const violationComment3: PolicyViolationComment = deepFreeze({ objectType: 'transactions', txnId: 'txNVtsqF8Siq', comment: { comment: 'No policy violation explanation provided', }, notify: true, -}; +}); -export const violationComment4: PolicyViolationComment = { +export const violationComment4: PolicyViolationComment = deepFreeze({ objectType: 'transactions', txnId: 'txeqxj49dgh', comment: { comment: 'Policy violation explanation: test comment 1', }, notify: true, -}; +}); -export const violationComment5: PolicyViolationComment = { +export const violationComment5: PolicyViolationComment = deepFreeze({ objectType: 'transactions', txnId: 'txeqxj89ddf', comment: { comment: 'No policy violation explanation provided', }, notify: true, -}; +}); diff --git a/src/app/core/mock-data/popover-params.data.ts b/src/app/core/mock-data/popover-params.data.ts index 40a7190042..9a6b6f8075 100644 --- a/src/app/core/mock-data/popover-params.data.ts +++ b/src/app/core/mock-data/popover-params.data.ts @@ -1,13 +1,15 @@ -export const getMarkDismissModalParamsData1 = { +import deepFreeze from 'deep-freeze-strict'; + +export const getMarkDismissModalParamsData1 = deepFreeze({ header: 'Dismiss this expense?', body: "This corporate card expense will be dismissed and you won't be able to edit it.\nDo you wish to proceed?", ctaText: 'Yes', ctaLoadingText: 'Dismissing', -}; +}); -export const getMarkDismissModalParamsData2 = { +export const getMarkDismissModalParamsData2 = deepFreeze({ header: 'Mark Expense as Personal', body: "This corporate card expense will be marked as personal and you won't be able to edit it.\nDo you wish to proceed?", ctaText: 'Yes', ctaLoadingText: 'Marking', -}; +}); diff --git a/src/app/core/mock-data/popup.data.ts b/src/app/core/mock-data/popup.data.ts index d7ed61d21e..9af71dd11a 100644 --- a/src/app/core/mock-data/popup.data.ts +++ b/src/app/core/mock-data/popup.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { PopupConfig } from 'src/app/shared/components/fy-popup/popup.model'; -export const popupConfigData: PopupConfig = { +export const popupConfigData: PopupConfig = deepFreeze({ header: 'Delete Report?', message: `

@@ -13,20 +15,20 @@ export const popupConfigData: PopupConfig = { primaryCta: { text: 'Delete', }, -}; +}); -export const popupConfigData2: PopupConfig = { +export const popupConfigData2: PopupConfig = deepFreeze({ header: 'Cannot Delete Report', message: 'Report cannot be deleted', primaryCta: { text: 'Close', }, -}; +}); -export const popupConfigData3: PopupConfig = { +export const popupConfigData3: PopupConfig = deepFreeze({ header: 'Confirm', message: 'Are you sure you want to delete this Advance Request', primaryCta: { text: 'Delete Advance Request', }, -}; +}); diff --git a/src/app/core/mock-data/project-dependent-fields-mapping.data.ts b/src/app/core/mock-data/project-dependent-fields-mapping.data.ts index c1d347e901..f11592cfd4 100644 --- a/src/app/core/mock-data/project-dependent-fields-mapping.data.ts +++ b/src/app/core/mock-data/project-dependent-fields-mapping.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ProjectDependentFieldsMapping } from '../models/project-dependent-fields-mapping.model'; import { dependentCustomProperties } from './custom-property.data'; -export const projectDependentFieldsMappingData1: ProjectDependentFieldsMapping = { +export const projectDependentFieldsMappingData1: ProjectDependentFieldsMapping = deepFreeze({ 3943: dependentCustomProperties, 3944: dependentCustomProperties, -}; +}); diff --git a/src/app/core/mock-data/public-policy-expense.data.ts b/src/app/core/mock-data/public-policy-expense.data.ts index 964a3dbb1d..395622aee8 100644 --- a/src/app/core/mock-data/public-policy-expense.data.ts +++ b/src/app/core/mock-data/public-policy-expense.data.ts @@ -1,9 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExpensePolicy } from '../models/platform/platform-expense-policy.model'; import { PolicyViolation } from '../models/policy-violation.model'; import { PublicPolicyExpense } from '../models/public-policy-expense.model'; import { optionsData15 } from './merge-expenses-options-data.data'; -export const publicPolicyExpenseData1: PublicPolicyExpense = { +export const publicPolicyExpenseData1: PublicPolicyExpense = deepFreeze({ skip_reimbursement: false, source: 'MOBILE', state: 'COMPLETE', @@ -121,39 +123,39 @@ export const publicPolicyExpenseData1: PublicPolicyExpense = { user_reason_for_duplicate_expenses: '', vendor: 'Uber', vendor_id: 0, -}; +}); -export const publicPolicyExpenseData2: PublicPolicyExpense = { +export const publicPolicyExpenseData2: PublicPolicyExpense = deepFreeze({ ...publicPolicyExpenseData1, fyle_category: 'airlines', -}; +}); -export const publicPolicyExpenseData3: PublicPolicyExpense = { +export const publicPolicyExpenseData3: PublicPolicyExpense = deepFreeze({ ...publicPolicyExpenseData1, fyle_category: 'bus', -}; +}); -export const publicPolicyExpenseData4: PublicPolicyExpense = { +export const publicPolicyExpenseData4: PublicPolicyExpense = deepFreeze({ ...publicPolicyExpenseData1, fyle_category: 'train', -}; +}); -export const publicPolicyExpenseData5: PublicPolicyExpense = { +export const publicPolicyExpenseData5: PublicPolicyExpense = deepFreeze({ ...publicPolicyExpenseData1, skip_reimbursement: null, -}; +}); -export const publicPolicyExpenseData6: PublicPolicyExpense = { +export const publicPolicyExpenseData6: PublicPolicyExpense = deepFreeze({ ...publicPolicyExpenseData1, locations: null, -}; +}); -export const publicPolicyExpenseData7: PublicPolicyExpense = { +export const publicPolicyExpenseData7: PublicPolicyExpense = deepFreeze({ ...publicPolicyExpenseData1, fyle_category: null, -}; +}); -export const expensePolicyData: ExpensePolicy = { +export const expensePolicyData: ExpensePolicy = deepFreeze({ data: { final_desired_state: { add_approver_user_ids: [], @@ -192,9 +194,9 @@ export const expensePolicyData: ExpensePolicy = { }, ], }, -}; +}); -export const policyViolationData: PolicyViolation = { +export const policyViolationData: PolicyViolation = deepFreeze({ data: { individual_desired_states: [ { @@ -238,13 +240,13 @@ export const policyViolationData: PolicyViolation = { currency: 'INR', name: 'Policy Violation 1', type: 'Expense Policy', -}; +}); -export const violations: { [id: string]: PolicyViolation } = { +export const violations: { [id: string]: PolicyViolation } = deepFreeze({ txVTmNOp5JEa: policyViolationData, -}; +}); -export const splitPolicyExp: PublicPolicyExpense = { +export const splitPolicyExp: PublicPolicyExpense = deepFreeze({ ...publicPolicyExpenseData1, id: 'txqhb1IwrujH', org_user_id: 'ouX8dwsbLCLv', @@ -252,9 +254,9 @@ export const splitPolicyExp: PublicPolicyExpense = { txn_dt: new Date('2023-02-15T06:30:00.000Z'), amount: 20.4, user_amount: 20.4, -}; +}); -export const splitTransactionData1: PublicPolicyExpense = { +export const splitTransactionData1: PublicPolicyExpense = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -356,9 +358,9 @@ export const splitTransactionData1: PublicPolicyExpense = { proposed_exchange_rate: 0, status_id: '', updated_at: undefined, -}; +}); -export const publicPolicyExpenseDataFromTxn: PublicPolicyExpense = { +export const publicPolicyExpenseDataFromTxn: PublicPolicyExpense = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -486,4 +488,4 @@ export const publicPolicyExpenseDataFromTxn: PublicPolicyExpense = { proposed_exchange_rate: 0, status_id: '', updated_at: undefined, -}; +}); diff --git a/src/app/core/mock-data/recent-local-storage-items.data.ts b/src/app/core/mock-data/recent-local-storage-items.data.ts index 6ec24628e7..77672f6d8b 100644 --- a/src/app/core/mock-data/recent-local-storage-items.data.ts +++ b/src/app/core/mock-data/recent-local-storage-items.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { RecentLocalStorageItems } from '../models/recent-local-storage-items.model'; -export const recentLocalStorageItemsRes: RecentLocalStorageItems[] = [ +export const recentLocalStorageItemsRes: RecentLocalStorageItems[] = deepFreeze([ { label: '12232', value: { @@ -18,9 +20,9 @@ export const recentLocalStorageItemsRes: RecentLocalStorageItems[] = [ selected: false, custom: false, }, -]; +]); -export const recentItemsRes: RecentLocalStorageItems[] = [ +export const recentItemsRes: RecentLocalStorageItems[] = deepFreeze([ { label: 'New New Mileage', value: { @@ -55,9 +57,9 @@ export const recentItemsRes: RecentLocalStorageItems[] = [ selected: false, custom: false, }, -]; +]); -export const itemsRes: RecentLocalStorageItems = { +export const itemsRes: RecentLocalStorageItems = deepFreeze({ label: 'New New Mileage', value: { code: null, @@ -73,11 +75,11 @@ export const itemsRes: RecentLocalStorageItems = { }, selected: false, custom: false, -}; +}); export const propertyRes = 'label'; -export const postRecentItemsRes: RecentLocalStorageItems[] = [ +export const postRecentItemsRes: RecentLocalStorageItems[] = deepFreeze([ { label: 'New New Mileage', value: { @@ -129,4 +131,4 @@ export const postRecentItemsRes: RecentLocalStorageItems[] = [ selected: false, custom: false, }, -]; +]); diff --git a/src/app/core/mock-data/recently-used.data.ts b/src/app/core/mock-data/recently-used.data.ts index 680adf7925..80cbb21cf7 100644 --- a/src/app/core/mock-data/recently-used.data.ts +++ b/src/app/core/mock-data/recently-used.data.ts @@ -1,9 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + import { RecentlyUsed } from '../models/v1/recently_used.model'; import { ExtendedProject } from '../models/v2/extended-project.model'; import { Currency, CurrencyName } from '../models/currency.model'; import { CostCenter } from '../models/v1/cost-center.model'; -export const recentlyUsedRes: RecentlyUsed = { +export const recentlyUsedRes: RecentlyUsed = deepFreeze({ recent_project_ids: [168826, 247943, 247946], recent_org_category_ids: [89469, 129111, 16576], recent_cost_center_ids: [6671, 6725, 89, 2406], @@ -24,9 +26,9 @@ export const recentlyUsedRes: RecentlyUsed = { '16/10, 16/10, Mariyamman Kovil St, Vagai Nagar, Ramanathapuram, Tamil Nadu 623504, India', 'mg road race', ], -}; +}); -export const recentlyUsedProjectRes: ExtendedProject[] = [ +export const recentlyUsedProjectRes: ExtendedProject[] = deepFreeze([ { ap1_email: 'john.d@fyle.in', ap1_full_name: 'John Doe', @@ -85,9 +87,9 @@ export const recentlyUsedProjectRes: ExtendedProject[] = [ projectv2_name: 'AcuVision Eye Centre', sub_project_name: null, }, -]; +]); -export const recentCurrencyRes: Currency[] = [ +export const recentCurrencyRes: Currency[] = deepFreeze([ { shortCode: 'ARS', longName: 'Argentine Peso', @@ -104,94 +106,95 @@ export const recentCurrencyRes: Currency[] = [ shortCode: 'CLP', longName: 'Chilean Peso', }, -]; +]); -export const currencies: CurrencyName = { +export const currencies: CurrencyName = deepFreeze({ ARS: 'Argentine Peso', INR: 'Indian Rupee', EUR: 'Euro', CLP: 'Chilean Peso', -}; +}); -export const recentlyUsedResWithoutCurr = { +export const recentlyUsedResWithoutCurr = deepFreeze({ ...recentlyUsedRes, recent_currencies: [], -}; +}); -export const recentlyUsedResWithoutCostCenterId = { +export const recentlyUsedResWithoutCostCenterId = deepFreeze({ ...recentlyUsedRes, recent_cost_center_ids: [], -}; +}); -export const recentlyUsedCategoryWithoutId = { +export const recentlyUsedCategoryWithoutId = deepFreeze({ ...recentlyUsedRes, recent_org_category_ids: [], -}; +}); -export const costCentersResWithNonMatchingIds = { +export const costCentersResWithNonMatchingIds = deepFreeze({ ...recentlyUsedRes, recent_cost_center_ids: [2456, 2457, 3457, 3458], -}; +}); -export const recentlyUsedCostCentersRes: Partial<{ label: string; value: CostCenter; selected?: boolean }[]> = [ - { - label: 'Cost center 1', - value: { - active: true, - code: '92344', - created_at: new Date('2020-10-27T17:07:55.516633+00:00'), - description: 'This is the description for cost center 1', - id: 6671, - name: 'Cost center 1', - org_id: 'orNVthTo2Zyo', - updated_at: new Date('2020-10-27T17:08:13.441319+00:00'), +export const recentlyUsedCostCentersRes: Partial<{ label: string; value: CostCenter; selected?: boolean }[]> = + deepFreeze([ + { + label: 'Cost center 1', + value: { + active: true, + code: '92344', + created_at: new Date('2020-10-27T17:07:55.516633+00:00'), + description: 'This is the description for cost center 1', + id: 6671, + name: 'Cost center 1', + org_id: 'orNVthTo2Zyo', + updated_at: new Date('2020-10-27T17:08:13.441319+00:00'), + }, }, - }, - { - label: 'Cost center 2', - value: { - active: true, - code: 'A very long cost center code', - created_at: new Date('2020-12-08T03:11:07.653324+00:00'), - description: 'This is the description for cost center 2', - id: 6725, - name: 'Cost center 2', - org_id: 'orNVthTo2Zyo', - updated_at: new Date('2022-07-14T13:13:56.757449+00:00'), + { + label: 'Cost center 2', + value: { + active: true, + code: 'A very long cost center code', + created_at: new Date('2020-12-08T03:11:07.653324+00:00'), + description: 'This is the description for cost center 2', + id: 6725, + name: 'Cost center 2', + org_id: 'orNVthTo2Zyo', + updated_at: new Date('2022-07-14T13:13:56.757449+00:00'), + }, }, - }, - { - label: 'Cost center 3', - value: { - active: true, - code: 'Administrion', - created_at: new Date('2019-02-01T06:59:07.889634+00:00'), - description: 'This is the description for cost center 3', - id: 89, - name: 'Cost center 3', - org_id: 'orNVthTo2Zyo', - updated_at: new Date('2019-08-28T10:11:41.004307+00:00'), + { + label: 'Cost center 3', + value: { + active: true, + code: 'Administrion', + created_at: new Date('2019-02-01T06:59:07.889634+00:00'), + description: 'This is the description for cost center 3', + id: 89, + name: 'Cost center 3', + org_id: 'orNVthTo2Zyo', + updated_at: new Date('2019-08-28T10:11:41.004307+00:00'), + }, }, - }, - { - label: 'Cost center 4', - value: { - active: true, - code: 'code1', - created_at: new Date('2019-06-24T08:25:08.307285+00:00'), - description: 'This is the description for cost center 4', - id: 2406, - name: 'Cost center 4', - org_id: 'orNVthTo2Zyo', - updated_at: new Date('2022-09-08T19:17:19.671789+00:00'), + { + label: 'Cost center 4', + value: { + active: true, + code: 'code1', + created_at: new Date('2019-06-24T08:25:08.307285+00:00'), + description: 'This is the description for cost center 4', + id: 2406, + name: 'Cost center 4', + org_id: 'orNVthTo2Zyo', + updated_at: new Date('2022-09-08T19:17:19.671789+00:00'), + }, }, - }, -]; + ]); export const recentlyUsedMileages: Pick< RecentlyUsed, 'recent_start_locations' | 'recent_end_locations' | 'recent_locations' -> = { +> = deepFreeze({ recent_start_locations: [ 'MG Road, Halasuru, Yellappa Chetty Layout, Sivanchetti Gardens, Bengaluru, Karnataka, India', 'MG Road, Yellappa Chetty Layout, Sivanchetti Gardens, Halasuru, Karnataka, India', @@ -207,4 +210,4 @@ export const recentlyUsedMileages: Pick< '16/10, 16/10, Mariyamman Kovil St, Vagai Nagar, Ramanathapuram, Tamil Nadu 623504, India', 'mg road race', ], -}; +}); diff --git a/src/app/core/mock-data/report-actions.data.ts b/src/app/core/mock-data/report-actions.data.ts index f57c7f2aab..6f265172db 100644 --- a/src/app/core/mock-data/report-actions.data.ts +++ b/src/app/core/mock-data/report-actions.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ReportActions } from '../models/report-actions.model'; -export const apiReportActions: ReportActions = { +export const apiReportActions: ReportActions = deepFreeze({ id: 'rpxtbiLXQZUm', can_resubmit: false, can_approve: false, @@ -13,4 +15,4 @@ export const apiReportActions: ReportActions = { can_payment_pending: false, can_undo_payment_pending: false, can_inquire: true, -}; +}); diff --git a/src/app/core/mock-data/report-auto-submission-details.data.ts b/src/app/core/mock-data/report-auto-submission-details.data.ts index 246a2ad574..c30eddc032 100644 --- a/src/app/core/mock-data/report-auto-submission-details.data.ts +++ b/src/app/core/mock-data/report-auto-submission-details.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ReportAutoSubmissionDetails } from '../models/report-auto-submission-details.model'; -export const apiReportAutoSubmissionDetails: ReportAutoSubmissionDetails = { +export const apiReportAutoSubmissionDetails: ReportAutoSubmissionDetails = deepFreeze({ data: { next_at: new Date('2023-02-01T00:00:00.000000'), }, -}; +}); diff --git a/src/app/core/mock-data/report-options.data.ts b/src/app/core/mock-data/report-options.data.ts index 7ab871b442..86e3045be4 100644 --- a/src/app/core/mock-data/report-options.data.ts +++ b/src/app/core/mock-data/report-options.data.ts @@ -1,8 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ReportOptions } from '../models/report-options.model'; -import { expectedErpt, expectedUnflattenedReports } from './report-unflattened.data'; import { expectedReportsPaginated } from './platform-report.data'; // TODO: update the spec file for fy-add-to-report component to use these mock data in next pr -hp -export const reportOptionsData: ReportOptions[] = [ +export const reportOptionsData: ReportOptions[] = deepFreeze([ { label: 'report1', value: expectedReportsPaginated[0], @@ -11,16 +12,16 @@ export const reportOptionsData: ReportOptions[] = [ label: 'report2', value: expectedReportsPaginated[1], }, -]; +]); -export const reportOptionsData2: ReportOptions[] = [ +export const reportOptionsData2: ReportOptions[] = deepFreeze([ { label: 'report1', value: expectedReportsPaginated[0], }, -]; +]); -export const reportOptionsData3: ReportOptions[] = [ +export const reportOptionsData3: ReportOptions[] = deepFreeze([ { label: '#8: Jan 2023', value: expectedReportsPaginated[0], @@ -37,9 +38,9 @@ export const reportOptionsData3: ReportOptions[] = [ label: '#4: Jan 2023', value: expectedReportsPaginated[3], }, -]; +]); -export const reportOptionsData4 = [ +export const reportOptionsData4 = deepFreeze([ { label: '#8: Jan 2023', value: { @@ -284,4 +285,4 @@ export const reportOptionsData4 = [ }, }, }, -]; +]); diff --git a/src/app/core/mock-data/report-stats-data.data.ts b/src/app/core/mock-data/report-stats-data.data.ts index 18f49e6ed9..5c82bf5e1c 100644 --- a/src/app/core/mock-data/report-stats-data.data.ts +++ b/src/app/core/mock-data/report-stats-data.data.ts @@ -1,15 +1,17 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ReportStatsData } from '../models/report-stats-data.model'; import { expectedReportStats } from './report-stats.data'; -export const reportStatsData1: ReportStatsData = { +export const reportStatsData1: ReportStatsData = deepFreeze({ reportStats: expectedReportStats, simplifyReportsSettings: { enabled: true }, homeCurrency: 'INR', currencySymbol: '₹', isNonReimbursableOrg: false, -}; +}); -export const reportStatsData2: ReportStatsData = { +export const reportStatsData2: ReportStatsData = deepFreeze({ ...reportStatsData1, simplifyReportsSettings: { enabled: undefined }, -}; +}); diff --git a/src/app/core/mock-data/report-stats.data.ts b/src/app/core/mock-data/report-stats.data.ts index fccb6d9720..a0654d6f89 100644 --- a/src/app/core/mock-data/report-stats.data.ts +++ b/src/app/core/mock-data/report-stats.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ReportStats } from '../models/report-stats.model'; -export const expectedReportStats: ReportStats = { +export const expectedReportStats: ReportStats = deepFreeze({ draft: { count: 6, sum: 93165.91, @@ -21,9 +23,9 @@ export const expectedReportStats: ReportStats = { count: 7, sum: 5012.12, }, -}; +}); -export const expectedEmptyReportStats: ReportStats = { +export const expectedEmptyReportStats: ReportStats = deepFreeze({ draft: { sum: 0, count: 0, @@ -44,4 +46,4 @@ export const expectedEmptyReportStats: ReportStats = { sum: 0, count: 0, }, -}; +}); diff --git a/src/app/core/mock-data/report-unflattened.data.ts b/src/app/core/mock-data/report-unflattened.data.ts index 782e2b1c2d..48d7826eb1 100644 --- a/src/app/core/mock-data/report-unflattened.data.ts +++ b/src/app/core/mock-data/report-unflattened.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { UnflattenedReport } from '../models/report-unflattened.model'; -export const expectedErpt: UnflattenedReport[] = [ +export const expectedErpt: UnflattenedReport[] = deepFreeze([ { rp: { id: 'rprAfNrce73O', @@ -233,9 +235,9 @@ export const expectedErpt: UnflattenedReport[] = [ email: 'ajain@fyle.in', }, }, -]; +]); -export const expectedErptPlatform: UnflattenedReport[] = [ +export const expectedErptPlatform: UnflattenedReport[] = deepFreeze([ { rp: { id: 'rpIfg2VWQKGJ', @@ -326,9 +328,9 @@ export const expectedErptPlatform: UnflattenedReport[] = [ email: 'devendra.r@fyle.in', }, }, -]; +]); -export const expectedSingleErpt: UnflattenedReport = { +export const expectedSingleErpt: UnflattenedReport = deepFreeze({ rp: { id: 'rprAfNrce73O', org_user_id: 'ouX8dwsbLCLv', @@ -385,9 +387,9 @@ export const expectedSingleErpt: UnflattenedReport = { full_name: 'Abhishek Jain', email: 'ajain@fyle.in', }, -}; +}); -export const extendedReportParam: UnflattenedReport[] = [ +export const extendedReportParam: UnflattenedReport[] = deepFreeze([ { rp: { id: 'rp5eUkeNm9wB', @@ -612,9 +614,9 @@ export const extendedReportParam: UnflattenedReport[] = [ email: 'ajain@fyle.in', }, }, -]; +]); -export const expectedUnflattenedReports: UnflattenedReport[] = [ +export const expectedUnflattenedReports: UnflattenedReport[] = deepFreeze([ { rp: { id: 'rp5eUkeNm9wB', @@ -839,9 +841,9 @@ export const expectedUnflattenedReports: UnflattenedReport[] = [ email: 'ajain@fyle.in', }, }, -]; +]); -export const unflattenedErptc: UnflattenedReport = { +export const unflattenedErptc: UnflattenedReport = deepFreeze({ rp: { id: 'rprAfNrce73O', org_user_id: 'ouX8dwsbLCLv', @@ -898,9 +900,9 @@ export const unflattenedErptc: UnflattenedReport = { full_name: 'Abhishek Jain', email: 'ajain@fyle.in', }, -}; +}); -export const unflattenedErptcArrayItem1: UnflattenedReport = { +export const unflattenedErptcArrayItem1: UnflattenedReport = deepFreeze({ rp: { id: 'rprAfNrce73O', org_user_id: 'ouX8dwsbLCLv', @@ -957,9 +959,9 @@ export const unflattenedErptcArrayItem1: UnflattenedReport = { full_name: 'Abhishek Jain', email: 'ajain@fyle.in', }, -}; +}); -export const unflattenedErptcArrayItem2: UnflattenedReport = { +export const unflattenedErptcArrayItem2: UnflattenedReport = deepFreeze({ rp: { id: 'rpLMyvYSXgJy', org_user_id: 'ouX8dwsbLCLv', @@ -1016,9 +1018,9 @@ export const unflattenedErptcArrayItem2: UnflattenedReport = { full_name: 'Abhishek Jain', email: 'ajain@fyle.in', }, -}; +}); -export const unflattenedErptcArrayItem3: UnflattenedReport = { +export const unflattenedErptcArrayItem3: UnflattenedReport = deepFreeze({ rp: { id: 'rpxtbiLXQZUm', org_user_id: 'ouX8dwsbLCLv', @@ -1075,9 +1077,9 @@ export const unflattenedErptcArrayItem3: UnflattenedReport = { full_name: 'Abhishek Jain', email: 'ajain@fyle.in', }, -}; +}); -export const unflattenedErptcArrayItem4: UnflattenedReport = { +export const unflattenedErptcArrayItem4: UnflattenedReport = deepFreeze({ rp: { id: 'rpSGcIEwzxDd', org_user_id: 'ouX8dwsbLCLv', @@ -1134,9 +1136,9 @@ export const unflattenedErptcArrayItem4: UnflattenedReport = { full_name: 'Abhishek Jain', email: 'ajain@fyle.in', }, -}; +}); -export const singleERptcFixDatesMock: UnflattenedReport = { +export const singleERptcFixDatesMock: UnflattenedReport = deepFreeze({ rp: { id: 'rprAfNrce73O', org_user_id: 'ouX8dwsbLCLv', @@ -1193,9 +1195,9 @@ export const singleERptcFixDatesMock: UnflattenedReport = { full_name: 'Abhishek Jain', email: 'ajain@fyle.in', }, -}; +}); -export const addApproverERpts: UnflattenedReport[] = [ +export const addApproverERpts: UnflattenedReport[] = deepFreeze([ { rp: { id: 'rp35DK02IvMP', @@ -1456,9 +1458,9 @@ export const addApproverERpts: UnflattenedReport[] = [ email: 'ajain@fyle.in', }, }, -]; +]); -export const expectedAddedApproverERpts: UnflattenedReport[] = [ +export const expectedAddedApproverERpts: UnflattenedReport[] = deepFreeze([ { rp: { id: 'rp35DK02IvMP', @@ -1623,9 +1625,9 @@ export const expectedAddedApproverERpts: UnflattenedReport[] = [ email: 'ajain@fyle.in', }, }, -]; +]); -export const draftReportPerDiemData: UnflattenedReport[] = [ +export const draftReportPerDiemData: UnflattenedReport[] = deepFreeze([ { rp: { id: 'rp35DK02IvMP', @@ -1700,4 +1702,4 @@ export const draftReportPerDiemData: UnflattenedReport[] = [ email: 'ajain@fyle.in', }, }, -]; +]); diff --git a/src/app/core/mock-data/report-v1.data.ts b/src/app/core/mock-data/report-v1.data.ts index 40d9cfb82c..b5e1772e27 100644 --- a/src/app/core/mock-data/report-v1.data.ts +++ b/src/app/core/mock-data/report-v1.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ReportV1 } from '../models/report-v1.model'; -export const reportUnflattenedData: ReportV1 = { +export const reportUnflattenedData: ReportV1 = deepFreeze({ created_at: new Date('2023-01-19T16:25:46.804Z'), updated_at: new Date('2023-01-19T16:25:46.804Z'), last_updated_by: { @@ -49,9 +51,9 @@ export const reportUnflattenedData: ReportV1 = { location4: null, location5: null, type: 'EXPENSE', -}; +}); -export const reportUnflattenedData2: ReportV1 = { +export const reportUnflattenedData2: ReportV1 = deepFreeze({ created_at: new Date('2023-01-21T07:45:18.869Z'), updated_at: new Date('2023-01-21T07:45:18.869Z'), last_updated_by: { @@ -100,9 +102,9 @@ export const reportUnflattenedData2: ReportV1 = { location4: null, location5: null, type: 'EXPENSE', -}; +}); -export const apiEmptyReportRes: ReportV1 = { +export const apiEmptyReportRes: ReportV1 = deepFreeze({ created_at: null, updated_at: null, last_updated_by: null, @@ -139,9 +141,9 @@ export const apiEmptyReportRes: ReportV1 = { location4: null, location5: null, type: null, -}; +}); -export const apiReportUpdatedDetails: ReportV1 = { +export const apiReportUpdatedDetails: ReportV1 = deepFreeze({ created_at: new Date('2022-10-31T13:54:46.317Z'), updated_at: new Date('2023-01-23T10:53:52.220Z'), last_updated_by: { @@ -190,4 +192,4 @@ export const apiReportUpdatedDetails: ReportV1 = { location4: null, location5: null, type: 'EXPENSE', -}; +}); diff --git a/src/app/core/mock-data/report.data.ts b/src/app/core/mock-data/report.data.ts index 4a5e0b2401..03b15643ae 100644 --- a/src/app/core/mock-data/report.data.ts +++ b/src/app/core/mock-data/report.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExtendedReport } from '../models/report.model'; -export const apiExtendedReportRes: ExtendedReport[] = [ +export const apiExtendedReportRes: ExtendedReport[] = deepFreeze([ { rp_id: 'rprAfNrce73O', rp_org_user_id: 'ouX8dwsbLCLv', @@ -209,9 +211,9 @@ export const apiExtendedReportRes: ExtendedReport[] = [ rp_risk_state_expense_count: null, rp_risk_state: null, }, -]; +]); -export const expectedAllReports: ExtendedReport[] = [ +export const expectedAllReports: ExtendedReport[] = deepFreeze([ { _search_document: "'0':5 '2023':3 '4':1 'a':8 'abhishek':10 'ajain@fyle.in':12 'bangalore':9 'c/2023/02/r/5':6 'feb':2 'inr':4 'jain':11 'lion':7", @@ -318,9 +320,9 @@ export const expectedAllReports: ExtendedReport[] = [ us_email: 'ajain@fyle.in', us_full_name: 'Abhishek Jain', }, -]; +]); -export const expectedPaginatedReports: ExtendedReport[] = [ +export const expectedPaginatedReports: ExtendedReport[] = deepFreeze([ { _search_document: "'0':5 '2023':3 '4':1 'a':8 'abhishek':10 'ajain@fyle.in':12 'bangalore':9 'c/2023/02/r/5':6 'feb':2 'inr':4 'jain':11 'lion':7", @@ -481,9 +483,9 @@ export const expectedPaginatedReports: ExtendedReport[] = [ us_email: 'ajain@fyle.in', us_full_name: 'Abhishek Jain', }, -]; +]); -export const reportParam: ExtendedReport = { +export const reportParam: ExtendedReport = deepFreeze({ _search_document: "'46040':4 'a':8,14,20,26 'abhishek':32 'ajain@fyle.in':34 'business':11,17,23,29 'c/2022/10/r/37':5 'director':6 'indeed':13,19,25,31 'inr':3 'jain':33 'long':10,16,22,28 'mumbai':7 'report':2 'testing':1 'unit':12,18,24,30 'very':9,15,21,27", approved_by: null, @@ -533,9 +535,9 @@ export const reportParam: ExtendedReport = { sequential_approval_turn: false, us_email: 'ajain@fyle.in', us_full_name: 'Abhishek Jain', -}; +}); -export const expectedReportSingleResponse: ExtendedReport = { +export const expectedReportSingleResponse: ExtendedReport = deepFreeze({ _search_document: "'145':5 'a':8 'abhishek':10 'ajain@fyle.in':12 'bangalore':9 'c/2023/01/r/31':6 'columns':3 'inr':4 'jain':11 'lion':7 'manage':2 'test':1", approved_by: ['out3t2X258rd'], @@ -592,9 +594,9 @@ export const expectedReportSingleResponse: ExtendedReport = { sequential_approval_turn: false, us_email: 'ajain@fyle.in', us_full_name: 'Abhishek Jain', -}; +}); -export const apiErptcReportsRes: ExtendedReport[] = [ +export const apiErptcReportsRes: ExtendedReport[] = deepFreeze([ { rp_id: 'rpfClhA1lglE', rp_org_user_id: 'ouCI4UQ2G0K1', @@ -799,9 +801,9 @@ export const apiErptcReportsRes: ExtendedReport[] = [ rp_risk_state_expense_count: null, rp_risk_state: null, }, -]; +]); -export const newReportParam = { +export const newReportParam = deepFreeze({ _search_document: "'46040':4 'a':8,14,20,26 'abhishek':32 'ajain@fyle.in':34 'business':11,17,23,29 'c/2022/10/r/37':5 'director':6 'indeed':13,19,25,31 'inr':3 'jain':33 'long':10,16,22,28 'mumbai':7 'report':2 'testing':1 'unit':12,18,24,30 'very':9,15,21,27", approved_by: null, @@ -851,9 +853,9 @@ export const newReportParam = { sequential_approval_turn: false, us_email: 'ajain@fyle.in', us_full_name: 'Abhishek Jain', -}; +}); -export const reportData1: ExtendedReport = { +export const reportData1: ExtendedReport = deepFreeze({ _search_document: "'0':7 '2023':3 '3':1 'a':11,17,23,29 'abhishek':35 'ajain@fyle.in':37 'business':14,20,26,32 'c/2023/07/r/17':8 'director':9 'expense':5 'indeed':16,22,28,34 'inr':6 'jain':36 'jul':2 'long':13,19,25,31 'mumbai':10 'office':4 'unit':15,21,27,33 'very':12,18,24,30", approved_by: null, @@ -906,4 +908,4 @@ export const reportData1: ExtendedReport = { sequential_approval_turn: false, us_email: 'ajain@fyle.in', us_full_name: 'Abhishek Jain', -}; +}); diff --git a/src/app/core/mock-data/router-state-snapshot.data.ts b/src/app/core/mock-data/router-state-snapshot.data.ts index ec90f79b8e..de07d66d87 100644 --- a/src/app/core/mock-data/router-state-snapshot.data.ts +++ b/src/app/core/mock-data/router-state-snapshot.data.ts @@ -1 +1,3 @@ -export const routerStateSnapshotData = { url: '/test', root: null }; +import deepFreeze from 'deep-freeze-strict'; + +export const routerStateSnapshotData = deepFreeze({ url: '/test', root: null }); diff --git a/src/app/core/mock-data/selected-filters.data.ts b/src/app/core/mock-data/selected-filters.data.ts index 26f5531513..74102f3fcb 100644 --- a/src/app/core/mock-data/selected-filters.data.ts +++ b/src/app/core/mock-data/selected-filters.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { SelectedFilters } from 'src/app/shared/components/fy-filters/selected-filters.interface'; -export const selectedFilters1: SelectedFilters[] = [ +export const selectedFilters1: SelectedFilters[] = deepFreeze([ { name: 'Created On', value: 'custom', @@ -29,9 +31,9 @@ export const selectedFilters1: SelectedFilters[] = [ name: 'Receipts Attached', value: 'custom', }, -]; +]); -export const selectedFilters2: SelectedFilters[] = [ +export const selectedFilters2: SelectedFilters[] = deepFreeze([ { name: 'Updated On', value: 'custom', @@ -52,9 +54,9 @@ export const selectedFilters2: SelectedFilters[] = [ name: 'Transactions Type', value: 'Debit', }, -]; +]); -export const selectedFilters3 = [ +export const selectedFilters3 = deepFreeze([ { name: 'State', value: 'Approved' }, { name: 'Date', @@ -62,23 +64,23 @@ export const selectedFilters3 = [ associatedData: { startDate: new Date('2023-04-01'), endDate: new Date('2023-04-04') }, }, { name: 'Sort By', value: 'dateNewToOld' }, -]; +]); -export const selectedFilters4 = [ +export const selectedFilters4 = deepFreeze([ { name: 'State', value: 'Approved' }, { name: 'Date', value: 'Last 7 Days', associatedData: undefined }, { name: 'Sort By', value: 'dateNewToOld' }, -]; +]); -export const selectedFilters5 = [ +export const selectedFilters5 = deepFreeze([ { name: 'Date', value: 'Last Month', associatedData: { startDate: new Date('2023-01-04'), endDate: new Date('2023-01-10') }, }, -]; +]); -export const taskSelectedFiltersData: SelectedFilters[] = [ +export const taskSelectedFiltersData: SelectedFilters[] = deepFreeze([ { name: 'Expenses', value: ['DRAFT'], @@ -91,9 +93,9 @@ export const taskSelectedFiltersData: SelectedFilters[] = [ name: 'Advances', value: ['SENT_BACK'], }, -]; +]); -export const selectedFilters6: SelectedFilters[] = [ +export const selectedFilters6: SelectedFilters[] = deepFreeze([ { name: 'State', value: 'DRAFT', @@ -106,14 +108,14 @@ export const selectedFilters6: SelectedFilters[] = [ endDate: new Date('2023-02-02'), }, }, -]; +]); -export const selectedFiltersParams: SelectedFilters = { +export const selectedFiltersParams: SelectedFilters = deepFreeze({ name: 'Sort By', value: 'dateNewToOld', -}; +}); -export const selectedFiltersParams2: SelectedFilters[] = [ +export const selectedFiltersParams2: SelectedFilters[] = deepFreeze([ { name: 'State', value: 'DRAFT', @@ -131,9 +133,9 @@ export const selectedFiltersParams2: SelectedFilters[] = [ endDate: new Date('2023-02-02'), }, }, -]; +]); -export const selectedFilters7: SelectedFilters[] = [ +export const selectedFilters7: SelectedFilters[] = deepFreeze([ ...selectedFilters5, { name: 'Type', @@ -156,9 +158,9 @@ export const selectedFilters7: SelectedFilters[] = [ name: 'Split Expense', value: 'Yes', }, -]; +]); -export const selectedFilters8: SelectedFilters[] = [ +export const selectedFilters8: SelectedFilters[] = deepFreeze([ { name: 'Date', value: 'Last Month', @@ -184,9 +186,9 @@ export const selectedFilters8: SelectedFilters[] = [ name: 'Split Expense', value: 'Yes', }, -]; +]); -export const selectedFilters9: SelectedFilters[] = [ +export const selectedFilters9: SelectedFilters[] = deepFreeze([ { name: 'Type', value: ['DRAFT', 'READY_TO_REPORT'], @@ -215,4 +217,4 @@ export const selectedFilters9: SelectedFilters[] = [ name: 'Split Expense', value: 'YES', }, -]; +]); diff --git a/src/app/core/mock-data/sidemenu-allowed-actions.data.ts b/src/app/core/mock-data/sidemenu-allowed-actions.data.ts index 5d4778bf33..ac7ac269d1 100644 --- a/src/app/core/mock-data/sidemenu-allowed-actions.data.ts +++ b/src/app/core/mock-data/sidemenu-allowed-actions.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { SidemenuAllowedActions } from '../models/sidemenu-allowed-actions.model'; -export const sidemenuAllowedActions: SidemenuAllowedActions = { +export const sidemenuAllowedActions: SidemenuAllowedActions = deepFreeze({ allowedReportsActions: { allowedRouteAccess: true, approve: true, @@ -12,4 +14,4 @@ export const sidemenuAllowedActions: SidemenuAllowedActions = { approve: true, delete: true, }, -}; +}); diff --git a/src/app/core/mock-data/sidemenu-item.data.ts b/src/app/core/mock-data/sidemenu-item.data.ts index 1b2e0383f2..ba10186cdf 100644 --- a/src/app/core/mock-data/sidemenu-item.data.ts +++ b/src/app/core/mock-data/sidemenu-item.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { SidemenuItem } from '../models/sidemenu-item.model'; -export const sidemenuItemData1: SidemenuItem = { +export const sidemenuItemData1: SidemenuItem = deepFreeze({ title: 'Dashboard', isVisible: true, icon: 'dashboard', @@ -9,9 +11,9 @@ export const sidemenuItemData1: SidemenuItem = { isDropdownOpen: false, dropdownOptions: [], openLiveChat: false, -}; +}); -export const sidemenuItemData2: SidemenuItem = { +export const sidemenuItemData2: SidemenuItem = deepFreeze({ title: 'Team', isVisible: true, icon: 'user-three', @@ -31,17 +33,17 @@ export const sidemenuItemData2: SidemenuItem = { ], route: [], openLiveChat: false, -}; +}); -export const sidemenuItemData3: Partial = { +export const sidemenuItemData3: Partial = deepFreeze({ title: 'Live Chat', isVisible: true, icon: 'chat', openLiveChat: true, disabled: false, -}; +}); -export const sidemenuItemData4: Partial = { +export const sidemenuItemData4: Partial = deepFreeze({ title: 'Switch Organization', isVisible: true, icon: 'swap', @@ -55,4 +57,4 @@ export const sidemenuItemData4: Partial = { }, ], disabled: false, -}; +}); diff --git a/src/app/core/mock-data/sidemenu.data.ts b/src/app/core/mock-data/sidemenu.data.ts index 49f39cfa36..ba038cc626 100644 --- a/src/app/core/mock-data/sidemenu.data.ts +++ b/src/app/core/mock-data/sidemenu.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { SidemenuItem } from '../models/sidemenu-item.model'; -export const sidemenuData1 = [ +export const sidemenuData1 = deepFreeze([ { title: 'Dashboard', isVisible: true, @@ -19,9 +21,9 @@ export const sidemenuData1 = [ icon: 'gear', route: ['/', 'enterprise', 'my_profile'], }, -]; +]); -export const PrimaryOptionsRes1: Partial[] = [ +export const PrimaryOptionsRes1: Partial[] = deepFreeze([ { title: 'Dashboard', isVisible: true, @@ -55,17 +57,17 @@ export const PrimaryOptionsRes1: Partial[] = [ route: ['/', 'enterprise', 'my_advances'], disabled: false, }, -]; +]); -export const UpdatedOptionsRes: Partial = { +export const UpdatedOptionsRes: Partial = deepFreeze({ title: 'Personal Cards', isVisible: true, route: ['/', 'enterprise', 'personal_cards'], icon: 'card', disabled: false, -}; +}); -export const PrimaryOptionsRes2: Partial[] = [ +export const PrimaryOptionsRes2: Partial[] = deepFreeze([ { title: 'Team', isVisible: true, @@ -85,9 +87,9 @@ export const PrimaryOptionsRes2: Partial[] = [ }, ], }, -]; +]); -export const getPrimarySidemenuOptionsRes1 = [ +export const getPrimarySidemenuOptionsRes1 = deepFreeze([ { title: 'Dashboard', isVisible: true, @@ -122,9 +124,9 @@ export const getPrimarySidemenuOptionsRes1 = [ icon: 'user-three', disabled: false, }, -]; +]); -export const getSecondarySidemenuOptionsRes1 = [ +export const getSecondarySidemenuOptionsRes1 = deepFreeze([ { title: 'Delegated Accounts', isVisible: true, @@ -152,9 +154,9 @@ export const getSecondarySidemenuOptionsRes1 = [ route: ['/', 'enterprise', 'help'], disabled: false, }, -]; +]); -export const setSideMenuRes: Partial[] = [ +export const setSideMenuRes: Partial[] = deepFreeze([ { title: 'Dashboard', isVisible: true, @@ -215,4 +217,4 @@ export const setSideMenuRes: Partial[] = [ route: ['/', 'enterprise', 'help'], disabled: false, }, -]; +]); diff --git a/src/app/core/mock-data/snackbar-properties.data.ts b/src/app/core/mock-data/snackbar-properties.data.ts index b37453a4a9..6f2aa3c0e4 100644 --- a/src/app/core/mock-data/snackbar-properties.data.ts +++ b/src/app/core/mock-data/snackbar-properties.data.ts @@ -1,73 +1,75 @@ +import deepFreeze from 'deep-freeze-strict'; + import { SnackbarProperties } from '../models/snackbar-properties.model'; -export const snackbarPropertiesRes = { +export const snackbarPropertiesRes = deepFreeze({ data: { icon: 'warning-fill', showCloseButton: true, message: 'Please select one or more expenses to be reported', }, duration: 3000, -}; +}); -export const snackbarPropertiesRes2 = { +export const snackbarPropertiesRes2 = deepFreeze({ data: { icon: 'success', showCloseButton: true, message: 'Expense added to report successfully', }, duration: 3000, -}; +}); -export const snackbarPropertiesRes3 = { +export const snackbarPropertiesRes3 = deepFreeze({ data: { icon: 'success', showCloseButton: true, message: '1 expense has been deleted', }, duration: 3000, -}; +}); -export const snackbarPropertiesRes4 = { +export const snackbarPropertiesRes4 = deepFreeze({ data: { icon: 'warning-fill', showCloseButton: true, message: 'We could not delete the expenses. Please try again', }, duration: 3000, -}; +}); -export const snackbarPropertiesRes5 = { +export const snackbarPropertiesRes5 = deepFreeze({ data: { icon: 'success', showCloseButton: true, message: 'Expenses merged Successfully', }, duration: 3000, -}; +}); -export const snackbarPropertiesRes6: SnackbarProperties = { +export const snackbarPropertiesRes6: SnackbarProperties = deepFreeze({ data: { icon: 'success', showCloseButton: true, message: '1 Transaction successfully hidden!', }, duration: 3000, -}; +}); -export const snackbarPropertiesRes7: SnackbarProperties = { +export const snackbarPropertiesRes7: SnackbarProperties = deepFreeze({ data: { icon: 'success', showCloseButton: true, message: '2 Transactions successfully hidden!', }, duration: 3000, -}; +}); -export const dismissExpenseSnackbarProps: SnackbarProperties = { +export const dismissExpenseSnackbarProps: SnackbarProperties = deepFreeze({ data: { icon: 'success', showCloseButton: true, message: 'Expense dismissed', }, duration: 3000, -}; +}); diff --git a/src/app/core/mock-data/split-expense-policy.data.ts b/src/app/core/mock-data/split-expense-policy.data.ts index 126069dbc0..8e2e46c8f9 100644 --- a/src/app/core/mock-data/split-expense-policy.data.ts +++ b/src/app/core/mock-data/split-expense-policy.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { SplitExpensePolicy } from '../models/platform/v1/split-expense-policy.model'; -export const splitPolicyExp1: SplitExpensePolicy = { +export const splitPolicyExp1: SplitExpensePolicy = deepFreeze({ data: [ { individual_desired_states: [], @@ -15,4 +17,4 @@ export const splitPolicyExp1: SplitExpensePolicy = { }, }, ], -}; +}); diff --git a/src/app/core/mock-data/split-expense-data.ts b/src/app/core/mock-data/split-expense.data.ts similarity index 84% rename from src/app/core/mock-data/split-expense-data.ts rename to src/app/core/mock-data/split-expense.data.ts index 5f1feb4ebb..0da1b90d37 100644 --- a/src/app/core/mock-data/split-expense-data.ts +++ b/src/app/core/mock-data/split-expense.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import * as dayjs from 'dayjs'; import { SplitExpense } from '../models/split-expense.model'; -export const splitExpense1: SplitExpense = { +export const splitExpense1: SplitExpense = deepFreeze({ amount: 15000, currency: 'INR', percentage: 60, @@ -25,9 +27,9 @@ export const splitExpense1: SplitExpense = { projectv2_name: '3M', sub_project_name: null, }, -}; +}); -export const splitExpense2: SplitExpense = { +export const splitExpense2: SplitExpense = deepFreeze({ amount: 2160, currency: 'INR', percentage: 60, @@ -44,48 +46,48 @@ export const splitExpense2: SplitExpense = { sub_category: '1', updated_at: '2023-04-17T12:55:49.475665+00:00', }, -}; +}); -export const splitExpense3 = { +export const splitExpense3 = deepFreeze({ amount: 2000, currency: 'INR', percentage: 50, txn_dt: '2023-02-08', category: '', -}; +}); -export const splitExpense4 = { +export const splitExpense4 = deepFreeze({ amount: 2000, currency: 'INR', percentage: 50, txn_dt: dayjs(new Date()).format('YYYY-MM-DD'), category: '', -}; +}); -export const splitExpense5 = { +export const splitExpense5 = deepFreeze({ amount: 2000, currency: 'INR', percentage: 50, txn_dt: '2023-02-08', project: '', -}; +}); -export const splitExpense6 = { +export const splitExpense6 = deepFreeze({ amount: 2000, currency: 'INR', percentage: 50, txn_dt: '2023-02-08', cost_center: '', -}; +}); -export const splitExpense7 = { +export const splitExpense7 = deepFreeze({ ...splitExpense3, amount: null, currency: null, percentage: null, -}; +}); -export const splitExpenseDataWithProject: SplitExpense = { +export const splitExpenseDataWithProject: SplitExpense = deepFreeze({ amount: 120, currency: 'INR', percentage: 60, @@ -130,14 +132,14 @@ export const splitExpenseDataWithProject: SplitExpense = { sub_project_name: 'Sub 103', }, txn_dt: '2023-08-10', -}; +}); -export const splitExpenseDataWithProject2: SplitExpense = { +export const splitExpenseDataWithProject2: SplitExpense = deepFreeze({ ...splitExpenseDataWithProject, project: undefined, -}; +}); -export const splitExpenseDataWithCostCenter: SplitExpense = { +export const splitExpenseDataWithCostCenter: SplitExpense = deepFreeze({ ...splitExpenseDataWithProject, project: undefined, cost_center: { @@ -150,9 +152,9 @@ export const splitExpenseDataWithCostCenter: SplitExpense = { org_id: 'orOTDe765hQp', updated_at: '2023-01-04T04:00:32.338131+00:00', }, -}; +}); -export const splitExpenseDataWithCostCenter2: SplitExpense = { +export const splitExpenseDataWithCostCenter2: SplitExpense = deepFreeze({ ...splitExpenseDataWithCostCenter, cost_center: undefined, -}; +}); diff --git a/src/app/core/mock-data/split-payload.data.ts b/src/app/core/mock-data/split-payload.data.ts index 1794d84182..ee18786929 100644 --- a/src/app/core/mock-data/split-payload.data.ts +++ b/src/app/core/mock-data/split-payload.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { SplitPayload } from '../models/platform/v1/split-payload.model'; import { splitsData1 } from './splits.data'; -export const splitPayloadData1: SplitPayload = { +export const splitPayloadData1: SplitPayload = deepFreeze({ id: 'sdfd2391', claim_amount: 1900, splits: [ @@ -47,9 +49,9 @@ export const splitPayloadData1: SplitPayload = { value: 'string1', }, ], -}; +}); -export const splitPayloadData2: SplitPayload = { +export const splitPayloadData2: SplitPayload = deepFreeze({ is_reimbursable: true, source: 'MOBILE', spent_at: new Date('Mon Feb 13 2023 22:30:00 GMT+0530 (India Standard Time)'), @@ -95,10 +97,10 @@ export const splitPayloadData2: SplitPayload = { splits: splitsData1, travel_classes: [], report_id: 'rp0AGAoeQfQX', -}; +}); -export const splitPayloadData3: SplitPayload = { +export const splitPayloadData3: SplitPayload = deepFreeze({ ...splitPayloadData2, category_id: 16569, is_reimbursable: null, -}; +}); diff --git a/src/app/core/mock-data/splits.data.ts b/src/app/core/mock-data/splits.data.ts index 0dca1ec6fb..06f13e1b98 100644 --- a/src/app/core/mock-data/splits.data.ts +++ b/src/app/core/mock-data/splits.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Splits } from '../models/platform/v1/splits.model'; -export const splitsData1: Splits[] = [ +export const splitsData1: Splits[] = deepFreeze([ { claim_amount: 56.6, spent_at: new Date(), @@ -12,9 +14,9 @@ export const splitsData1: Splits[] = [ purpose: 'split test 1', custom_fields: [], }, -]; +]); -export const splitData2: Splits[] = [ +export const splitData2: Splits[] = deepFreeze([ { claim_amount: null, spent_at: new Date('Tue Jan 31 2023 22:30:00 GMT+0530 (India Standard Time)'), @@ -53,4 +55,4 @@ export const splitData2: Splits[] = [ ], claim_amount: null, }, -]; +]); diff --git a/src/app/core/mock-data/static-map-properties.data.ts b/src/app/core/mock-data/static-map-properties.data.ts index 4161abd0e6..96ff4eab9e 100644 --- a/src/app/core/mock-data/static-map-properties.data.ts +++ b/src/app/core/mock-data/static-map-properties.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { StaticMapProperties } from '../models/static-map-properties.interface'; -export const staticMapPropertiesData: StaticMapProperties = { +export const staticMapPropertiesData: StaticMapProperties = deepFreeze({ zoom: 18, routeColor: '0x00BFFF', markers: [ @@ -34,4 +36,4 @@ export const staticMapPropertiesData: StaticMapProperties = { width: window.innerWidth, height: 266, resolutionScale: 2, -}; +}); diff --git a/src/app/core/mock-data/stats-dimension-response.data.ts b/src/app/core/mock-data/stats-dimension-response.data.ts index 0495023096..87df5d8622 100644 --- a/src/app/core/mock-data/stats-dimension-response.data.ts +++ b/src/app/core/mock-data/stats-dimension-response.data.ts @@ -1,8 +1,8 @@ -import { PlatformApiResponse } from '../models/platform/platform-api-response.model'; +import deepFreeze from 'deep-freeze-strict'; + import { StatsDimensionResponse } from '../models/stats-dimension-response.model'; -import { ApiV2Response } from '../models/v2/api-v2-response.model'; -export const apiTxnUnreportedStatsRes: StatsDimensionResponse[] = [ +export const apiTxnUnreportedStatsRes: StatsDimensionResponse[] = deepFreeze([ { aggregates: [ { @@ -17,17 +17,17 @@ export const apiTxnUnreportedStatsRes: StatsDimensionResponse[] = [ dimensions: [], name: 'scalar_stat', }, -]; +]); -export const apiTxnUnreportedStatsEmptyRes: StatsDimensionResponse[] = [ +export const apiTxnUnreportedStatsEmptyRes: StatsDimensionResponse[] = deepFreeze([ { aggregates: [], dimensions: [], name: 'scalar_stat', }, -]; +]); -export const apiTxnIncompleteStatsRes: StatsDimensionResponse[] = [ +export const apiTxnIncompleteStatsRes: StatsDimensionResponse[] = deepFreeze([ { aggregates: [ { @@ -42,30 +42,30 @@ export const apiTxnIncompleteStatsRes: StatsDimensionResponse[] = [ dimensions: [], name: 'scalar_stat', }, -]; +]); -export const apiTxnIncompleteStatsEmptyRes: StatsDimensionResponse[] = [ +export const apiTxnIncompleteStatsEmptyRes: StatsDimensionResponse[] = deepFreeze([ { aggregates: [], dimensions: [], name: 'scalar_stat', }, -]; +]); -export const apiUnreportedParams: Partial = { +export const apiUnreportedParams: Partial = deepFreeze({ scalar: true, tx_state: 'in.(COMPLETE)', or: '(tx_policy_amount.is.null,tx_policy_amount.gt.0.0001)', tx_report_id: 'is.null', -}; +}); -export const apiIncompleteParams: Partial = { +export const apiIncompleteParams: Partial = deepFreeze({ scalar: true, tx_state: 'in.(DRAFT)', tx_report_id: 'is.null', -}; +}); -export const expectedReportRawStats: StatsDimensionResponse[] = [ +export const expectedReportRawStats: StatsDimensionResponse[] = deepFreeze([ { aggregates: [ { @@ -80,4 +80,4 @@ export const expectedReportRawStats: StatsDimensionResponse[] = [ dimensions: [], name: 'scalar_stat', }, -]; +]); diff --git a/src/app/core/mock-data/stats-response.data.ts b/src/app/core/mock-data/stats-response.data.ts index b35eddd255..64232096de 100644 --- a/src/app/core/mock-data/stats-response.data.ts +++ b/src/app/core/mock-data/stats-response.data.ts @@ -1,3 +1,5 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Datum, StatsResponse } from '../models/v2/stats-response.model'; // type StatsResponse = { // data: { @@ -317,7 +319,7 @@ export const txnStats = new StatsResponse({ url: '/v2/expenses/stats', }); -export const transactionDatum1: Datum[] = [ +export const transactionDatum1: Datum[] = deepFreeze([ { name: '', dimensions: [], @@ -360,9 +362,9 @@ export const transactionDatum1: Datum[] = [ }, ], }, -]; +]); -export const transactionDatum2: Datum[] = [ +export const transactionDatum2: Datum[] = deepFreeze([ { name: '', dimensions: [], @@ -396,9 +398,9 @@ export const transactionDatum2: Datum[] = [ }, ], }, -]; +]); -export const transactionDatum3: Datum[] = [ +export const transactionDatum3: Datum[] = deepFreeze([ { name: '', dimensions: [], @@ -413,4 +415,4 @@ export const transactionDatum3: Datum[] = [ }, ], }, -]; +]); diff --git a/src/app/core/mock-data/stats.data.ts b/src/app/core/mock-data/stats.data.ts index b9cc6a454a..c2b5f3e323 100644 --- a/src/app/core/mock-data/stats.data.ts +++ b/src/app/core/mock-data/stats.data.ts @@ -1,31 +1,33 @@ +import deepFreeze from 'deep-freeze-strict'; + import { Stats } from '../models/stats.model'; -export const expectedUnreportedExpStats: Stats = { +export const expectedUnreportedExpStats: Stats = deepFreeze({ count: 6, sum: 16748.73, -}; +}); -export const expectedIncompleteExpStats: Stats = { +export const expectedIncompleteExpStats: Stats = deepFreeze({ count: 1130, sum: 1148487.57555147, -}; +}); -export const expectedEmptyStats: Stats = { +export const expectedEmptyStats: Stats = deepFreeze({ count: undefined, sum: undefined, -}; +}); -export const expectedUnreportedExpStats2: Stats = { +export const expectedUnreportedExpStats2: Stats = deepFreeze({ count: 3, sum: 30, -}; +}); -export const expectedIncompleteExpStats2: Stats = { +export const expectedIncompleteExpStats2: Stats = deepFreeze({ count: 339, sum: 76234.47290692403, -}; +}); -export const emptyStatsAgg: Stats = { +export const emptyStatsAgg: Stats = deepFreeze({ count: 0, sum: 0, -}; +}); diff --git a/src/app/core/mock-data/task-cta.data.ts b/src/app/core/mock-data/task-cta.data.ts index 02e009bf41..13d61add33 100644 --- a/src/app/core/mock-data/task-cta.data.ts +++ b/src/app/core/mock-data/task-cta.data.ts @@ -1,47 +1,49 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TaskCta } from '../models/task-cta.model'; import { TASKEVENT } from '../models/task-event.enum'; -export const taskCtaData: TaskCta = { +export const taskCtaData: TaskCta = deepFreeze({ event: TASKEVENT.expensesAddToReport, content: 'Add To Report', -}; +}); -export const taskCtaData2: TaskCta = { +export const taskCtaData2: TaskCta = deepFreeze({ event: TASKEVENT.openDraftReports, content: 'Draft Reports', -}; +}); -export const taskCtaData3: TaskCta = { +export const taskCtaData3: TaskCta = deepFreeze({ event: TASKEVENT.openSentBackReport, content: 'Sent Back Report', -}; +}); -export const taskCtaData4: TaskCta = { +export const taskCtaData4: TaskCta = deepFreeze({ event: TASKEVENT.reviewExpenses, content: 'Review Expenses', -}; +}); -export const taskCtaData5: TaskCta = { +export const taskCtaData5: TaskCta = deepFreeze({ event: TASKEVENT.openTeamReport, content: 'Team Reports', -}; +}); -export const taskCtaData6: TaskCta = { +export const taskCtaData6: TaskCta = deepFreeze({ event: TASKEVENT.openPotentialDuplicates, content: 'Potential Duplicates', -}; +}); -export const taskCtaData7: TaskCta = { +export const taskCtaData7: TaskCta = deepFreeze({ event: TASKEVENT.openSentBackAdvance, content: 'Sent Back Advances', -}; +}); -export const taskCtaData8: TaskCta = { +export const taskCtaData8: TaskCta = deepFreeze({ event: TASKEVENT.expensesCreateNewReport, content: 'Create New Report', -}; +}); -export const taskCtaData9: TaskCta = { +export const taskCtaData9: TaskCta = deepFreeze({ event: TASKEVENT.mobileNumberVerification, content: 'Verify Mobile Number', -}; +}); diff --git a/src/app/core/mock-data/task-filters.data.ts b/src/app/core/mock-data/task-filters.data.ts index 2e221d17ae..68fd8ffff2 100644 --- a/src/app/core/mock-data/task-filters.data.ts +++ b/src/app/core/mock-data/task-filters.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TaskFilters } from '../models/task-filters.model'; -export const taskFiltersData: TaskFilters = { +export const taskFiltersData: TaskFilters = deepFreeze({ sentBackReports: true, draftReports: false, draftExpenses: true, @@ -8,9 +10,9 @@ export const taskFiltersData: TaskFilters = { potentialDuplicates: false, teamReports: false, sentBackAdvances: false, -}; +}); -export const taskFiltersData2: TaskFilters = { +export const taskFiltersData2: TaskFilters = deepFreeze({ sentBackReports: false, draftReports: false, draftExpenses: false, @@ -18,9 +20,9 @@ export const taskFiltersData2: TaskFilters = { potentialDuplicates: false, teamReports: false, sentBackAdvances: false, -}; +}); -export const taskFiltersParams: TaskFilters = { +export const taskFiltersParams: TaskFilters = deepFreeze({ sentBackReports: true, draftReports: false, draftExpenses: false, @@ -28,9 +30,9 @@ export const taskFiltersParams: TaskFilters = { potentialDuplicates: false, teamReports: false, sentBackAdvances: false, -}; +}); -export const taskFiltersParams2: TaskFilters = { +export const taskFiltersParams2: TaskFilters = deepFreeze({ sentBackReports: false, draftReports: false, draftExpenses: true, @@ -38,9 +40,9 @@ export const taskFiltersParams2: TaskFilters = { potentialDuplicates: false, teamReports: false, sentBackAdvances: false, -}; +}); -export const taskFiltersParams3: TaskFilters = { +export const taskFiltersParams3: TaskFilters = deepFreeze({ sentBackReports: true, draftReports: false, draftExpenses: true, @@ -48,27 +50,27 @@ export const taskFiltersParams3: TaskFilters = { potentialDuplicates: false, teamReports: false, sentBackAdvances: false, -}; +}); -export const taskFiltersParams4: TaskFilters = { +export const taskFiltersParams4: TaskFilters = deepFreeze({ ...taskFiltersData2, unreportedExpenses: true, draftExpenses: true, potentialDuplicates: true, -}; +}); -export const taskFiltersParams5: TaskFilters = { +export const taskFiltersParams5: TaskFilters = deepFreeze({ ...taskFiltersData2, draftReports: true, sentBackReports: true, -}; +}); -export const taskFiltersParams6: TaskFilters = { +export const taskFiltersParams6: TaskFilters = deepFreeze({ ...taskFiltersData2, teamReports: true, -}; +}); -export const taskFiltersParams7: TaskFilters = { +export const taskFiltersParams7: TaskFilters = deepFreeze({ ...taskFiltersData2, sentBackAdvances: true, -}; +}); diff --git a/src/app/core/mock-data/task.data.ts b/src/app/core/mock-data/task.data.ts index b438cb0595..41f5e32fdd 100644 --- a/src/app/core/mock-data/task.data.ts +++ b/src/app/core/mock-data/task.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TASKEVENT } from '../models/task-event.enum'; import { TaskIcon } from '../models/task-icon.enum'; -export const draftExpenseTaskSample = { +export const draftExpenseTaskSample = deepFreeze({ amount: '132.57B', count: 161, header: 'Incomplete expenses', @@ -13,9 +15,9 @@ export const draftExpenseTaskSample = { event: TASKEVENT.reviewExpenses, }, ], -}; +}); -export const draftExpenseTaskSample2 = { +export const draftExpenseTaskSample2 = deepFreeze({ amount: '132.57B', count: 339, header: 'Incomplete expenses', @@ -27,9 +29,9 @@ export const draftExpenseTaskSample2 = { event: TASKEVENT.reviewExpenses, }, ], -}; +}); -export const potentailDuplicateTaskSample = { +export const potentailDuplicateTaskSample = deepFreeze({ hideAmount: true, count: 13, header: '34 Potential Duplicates', @@ -41,9 +43,9 @@ export const potentailDuplicateTaskSample = { event: TASKEVENT.openPotentialDuplicates, }, ], -}; +}); -export const teamReportTaskSample = { +export const teamReportTaskSample = deepFreeze({ amount: '733.48K', count: 2, header: 'Reports to be approved', @@ -55,9 +57,9 @@ export const teamReportTaskSample = { event: TASKEVENT.openTeamReport, }, ], -}; +}); -export const sentBackReportTaskSample = { +export const sentBackReportTaskSample = deepFreeze({ amount: '44.53', count: 1, header: 'Report sent back!', @@ -69,9 +71,9 @@ export const sentBackReportTaskSample = { event: TASKEVENT.openSentBackReport, }, ], -}; +}); -export const unreportedExpenseTaskSample = { +export const unreportedExpenseTaskSample = deepFreeze({ amount: '142.26K', count: 13, header: 'Expenses are ready to report', @@ -83,9 +85,9 @@ export const unreportedExpenseTaskSample = { event: TASKEVENT.expensesAddToReport, }, ], -}; +}); -export const unreportedExpenseTaskSample2 = { +export const unreportedExpenseTaskSample2 = deepFreeze({ amount: '142.26K', count: 3, header: 'Expenses are ready to report', @@ -97,9 +99,9 @@ export const unreportedExpenseTaskSample2 = { event: TASKEVENT.expensesAddToReport, }, ], -}; +}); -export const unsubmittedReportTaskSample = { +export const unsubmittedReportTaskSample = deepFreeze({ amount: '0.00', count: 2, header: 'Unsubmitted reports', @@ -111,9 +113,9 @@ export const unsubmittedReportTaskSample = { event: TASKEVENT.openDraftReports, }, ], -}; +}); -export const sentBackAdvanceTaskSample = { +export const sentBackAdvanceTaskSample = deepFreeze({ amount: '123.37M', count: 5, header: 'Advances sent back!', @@ -125,9 +127,9 @@ export const sentBackAdvanceTaskSample = { event: TASKEVENT.openSentBackAdvance, }, ], -}; +}); -export const addMobileNumberTask = { +export const addMobileNumberTask = deepFreeze({ hideAmount: true, header: 'Add Mobile Number', subheader: 'Add and verify your mobile number to text the receipts directly', @@ -138,9 +140,9 @@ export const addMobileNumberTask = { event: TASKEVENT.mobileNumberVerification, }, ], -}; +}); -export const verifyMobileNumberTask = { +export const verifyMobileNumberTask = deepFreeze({ hideAmount: true, header: 'Verify Mobile Number', subheader: 'Verify your mobile number to text the receipts directly', @@ -151,9 +153,9 @@ export const verifyMobileNumberTask = { event: TASKEVENT.mobileNumberVerification, }, ], -}; +}); -export const commuteDeductionTask = { +export const commuteDeductionTask = deepFreeze({ hideAmount: true, header: 'Add Commute Details', subheader: 'Add your Home and Work locations to easily deduct commute distance from your mileage expenses', @@ -164,4 +166,4 @@ export const commuteDeductionTask = { event: TASKEVENT.commuteDetails, }, ], -}; +}); diff --git a/src/app/core/mock-data/tax-group.data.ts b/src/app/core/mock-data/tax-group.data.ts index 13c2f7b687..6408f0b7aa 100644 --- a/src/app/core/mock-data/tax-group.data.ts +++ b/src/app/core/mock-data/tax-group.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TaxGroup } from '../models/tax-group.model'; -export const taxGroupData: TaxGroup[] = [ +export const taxGroupData: TaxGroup[] = deepFreeze([ { id: 'tgXEJA6YUoZ1', name: 'GST', @@ -19,9 +21,9 @@ export const taxGroupData: TaxGroup[] = [ org_id: 'orwruogwnngg', is_enabled: true, }, -]; +]); -export const expectedTaxGroupData: { label: string; value: TaxGroup }[] = [ +export const expectedTaxGroupData: { label: string; value: TaxGroup }[] = deepFreeze([ { label: 'GST', value: { @@ -46,4 +48,4 @@ export const expectedTaxGroupData: { label: string; value: TaxGroup }[] = [ is_enabled: true, }, }, -]; +]); diff --git a/src/app/core/mock-data/tax-settings.data.ts b/src/app/core/mock-data/tax-settings.data.ts index 10de6ff13d..d2b635b6c3 100644 --- a/src/app/core/mock-data/tax-settings.data.ts +++ b/src/app/core/mock-data/tax-settings.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TaxSettings } from '../models/org-settings.model'; -export const taxSettingsData: TaxSettings = { +export const taxSettingsData: TaxSettings = deepFreeze({ allowed: true, enabled: true, name: null, @@ -27,4 +29,4 @@ export const taxSettingsData: TaxSettings = { }, }, ], -}; +}); diff --git a/src/app/core/mock-data/team-reports-filters.data.ts b/src/app/core/mock-data/team-reports-filters.data.ts index 8bd1eb2e61..bdda30d475 100644 --- a/src/app/core/mock-data/team-reports-filters.data.ts +++ b/src/app/core/mock-data/team-reports-filters.data.ts @@ -1,63 +1,65 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TeamReportsFilters } from '../models/team-reports-filters.model'; -export const teamReportsFiltersData: Partial = { +export const teamReportsFiltersData: Partial = deepFreeze({ sortDir: 'desc', sortParam: 'rp_created_at', date: 'custom', -}; +}); -export const teamReportsFiltersData2: Partial = { +export const teamReportsFiltersData2: Partial = deepFreeze({ sortDir: 'desc', state: 'DRAFT', sortParam: 'rp_created_at', date: 'custom', customDateStart: new Date('2023-01-01'), customDateEnd: new Date('2023-02-02'), -}; +}); -export const teamReportsFiltersParams: Partial = { +export const teamReportsFiltersParams: Partial = deepFreeze({ sortParam: 'rp_purpose', sortDir: 'asc', -}; +}); -export const teamReportsFiltersParams2: Partial = { +export const teamReportsFiltersParams2: Partial = deepFreeze({ sortParam: 'rp_purpose', sortDir: 'desc', -}; +}); -export const teamReportsFiltersData3: Partial = { +export const teamReportsFiltersData3: Partial = deepFreeze({ state: 'DRAFT', date: 'custom', customDateStart: new Date('2023-01-01'), customDateEnd: new Date('2023-02-02'), -}; +}); -export const teamReportsFiltersData4: Partial = { +export const teamReportsFiltersData4: Partial = deepFreeze({ state: 'DRAFT', date: 'custom', customDateStart: undefined, customDateEnd: undefined, -}; +}); -export const teamReportsFiltersParams3: Partial = { +export const teamReportsFiltersParams3: Partial = deepFreeze({ state: ['DRAFT', 'PAID', 'CANCELLED'], -}; +}); -export const teamReportsFiltersParams4: Partial = { +export const teamReportsFiltersParams4: Partial = deepFreeze({ sortParam: 'rp_submitted_at', sortDir: 'asc', -}; +}); -export const teamReportsFiltersParams5: Partial = { +export const teamReportsFiltersParams5: Partial = deepFreeze({ sortParam: 'rp_amount', sortDir: 'desc', -}; +}); -export const teamReportsFiltersParams6: Partial = { +export const teamReportsFiltersParams6: Partial = deepFreeze({ sortParam: 'rp_purpose', sortDir: 'asc', -}; +}); -export const teamReportsFiltersParams7: Partial = { +export const teamReportsFiltersParams7: Partial = deepFreeze({ date: 'thisWeek', -}; +}); diff --git a/src/app/core/mock-data/track-expense-properties.data.ts b/src/app/core/mock-data/track-expense-properties.data.ts index 9fe56d7e65..abccf4ded3 100644 --- a/src/app/core/mock-data/track-expense-properties.data.ts +++ b/src/app/core/mock-data/track-expense-properties.data.ts @@ -1,3 +1,5 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExpenseProperties } from '../models/tracking-properties.model'; import { expectedUnflattendedTxnData4, @@ -6,7 +8,7 @@ import { unflattenedTxnWithTrackData, } from './unflattened-txn.data'; -export const createExpenseProperties: ExpenseProperties = { +export const createExpenseProperties: ExpenseProperties = deepFreeze({ Type: 'Receipt', Amount: expectedUnflattendedTxnData4.tx.amount, Currency: expectedUnflattendedTxnData4.tx.currency, @@ -17,9 +19,9 @@ export const createExpenseProperties: ExpenseProperties = { Used_Autofilled_CostCenter: true, Used_Autofilled_Currency: true, Instafyle: false, -}; +}); -export const createExpenseProperties2: ExpenseProperties = { +export const createExpenseProperties2: ExpenseProperties = deepFreeze({ Type: 'Receipt', Amount: trackAddExpenseWoCurrency.tx.amount, Currency: trackAddExpenseWoCurrency.tx.currency, @@ -30,9 +32,9 @@ export const createExpenseProperties2: ExpenseProperties = { Used_Autofilled_CostCenter: true, Used_Autofilled_Currency: true, Instafyle: false, -}; +}); -export const editExpenseProperties1: ExpenseProperties = { +export const editExpenseProperties1: ExpenseProperties = deepFreeze({ Type: 'Mileage', Amount: unflattenedTxnWithTrackData.tx.amount, Currency: unflattenedTxnWithTrackData.tx.currency, @@ -42,9 +44,9 @@ export const editExpenseProperties1: ExpenseProperties = { Used_Autofilled_CostCenter: true, Used_Autofilled_VehicleType: true, Used_Autofilled_StartLocation: true, -}; +}); -export const createExpenseProperties3: ExpenseProperties = { +export const createExpenseProperties3: ExpenseProperties = deepFreeze({ Type: 'Receipt', Amount: 344, Currency: 'INR', @@ -52,9 +54,9 @@ export const createExpenseProperties3: ExpenseProperties = { Time_Spent: '180 secs', Used_Autofilled_Project: true, Used_Autofilled_CostCenter: true, -}; +}); -export const createExpenseProperties4: ExpenseProperties = { +export const createExpenseProperties4: ExpenseProperties = deepFreeze({ Type: 'Mileage', Amount: expenseTrackCreate.tx.amount, Currency: expenseTrackCreate.tx.currency, @@ -64,14 +66,14 @@ export const createExpenseProperties4: ExpenseProperties = { Used_Autofilled_CostCenter: true, Used_Autofilled_VehicleType: true, Used_Autofilled_StartLocation: true, -}; +}); -export const editExpenseProperties: ExpenseProperties = { +export const editExpenseProperties: ExpenseProperties = deepFreeze({ ...createExpenseProperties3, Type: 'Per Diem', -}; +}); -export const editExpensePropertiesPlatform: ExpenseProperties = { +export const editExpensePropertiesPlatform: ExpenseProperties = deepFreeze({ Type: 'Per Diem', Amount: 2263.68, Currency: 'USD', @@ -79,4 +81,4 @@ export const editExpensePropertiesPlatform: ExpenseProperties = { Time_Spent: '180 secs', Used_Autofilled_Project: null, Used_Autofilled_CostCenter: null, -}; +}); diff --git a/src/app/core/mock-data/transaction-status.data.ts b/src/app/core/mock-data/transaction-status.data.ts index 67693ec1c8..cc135cff28 100644 --- a/src/app/core/mock-data/transaction-status.data.ts +++ b/src/app/core/mock-data/transaction-status.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TransactionStatus } from '../models/transaction-status.model'; -export const txnStatusData: TransactionStatus = { +export const txnStatusData: TransactionStatus = deepFreeze({ id: 'stjIdPp8BX8O', created_at: new Date('2022-11-17T06:07:38.590Z'), org_user_id: 'ouX8dwsbLCLv', @@ -10,9 +12,9 @@ export const txnStatusData: TransactionStatus = { transaction_id: null, report_id: 'rpkpSa8guCuR', advance_request_id: null, -}; +}); -export const expenseStatusData: TransactionStatus = { +export const expenseStatusData: TransactionStatus = deepFreeze({ advance_request_id: null, comment: 'A comment', created_at: new Date('2024-02-11T16:43:25.675Z'), @@ -22,9 +24,9 @@ export const expenseStatusData: TransactionStatus = { report_id: null, state: null, transaction_id: 'txNWAit6pFgw', -}; +}); -export const txnStatusData1: TransactionStatus = { +export const txnStatusData1: TransactionStatus = deepFreeze({ id: 'stjIdPp7BX81', created_at: new Date('2022-11-17T06:07:38.590Z'), org_user_id: 'ouX8dwsbLCLv', @@ -34,9 +36,9 @@ export const txnStatusData1: TransactionStatus = { transaction_id: 'txxkBruL0EO9', report_id: null, advance_request_id: null, -}; +}); -export const txnStatusData2: TransactionStatus = { +export const txnStatusData2: TransactionStatus = deepFreeze({ id: 'stjIdPp7BX81', created_at: new Date('2022-11-17T06:07:38.590Z'), org_user_id: 'ouX8dwsbLCLv', @@ -46,4 +48,4 @@ export const txnStatusData2: TransactionStatus = { transaction_id: 'txNVtsqF8Siq', report_id: null, advance_request_id: null, -}; +}); diff --git a/src/app/core/mock-data/transaction.data.ts b/src/app/core/mock-data/transaction.data.ts index 1933336e12..32a6dfd4f0 100644 --- a/src/app/core/mock-data/transaction.data.ts +++ b/src/app/core/mock-data/transaction.data.ts @@ -1,9 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TransactionStatus } from '../models/platform/v1/expense.model'; import { Transaction } from '../models/v1/transaction.model'; import { optionsData15, optionsData33 } from './merge-expenses-options-data.data'; import { expectedTxnCustomProperties, txnCustomPropertiesData } from './txn-custom-properties.data'; -export const txnList: Transaction[] = [ +export const txnList: Transaction[] = deepFreeze([ { created_at: new Date('2023-01-31T04:03:12.575Z'), updated_at: new Date('2023-01-31T04:03:12.575Z'), @@ -172,9 +174,9 @@ export const txnList: Transaction[] = [ policy_amount: null, locations: [], }, -]; +]); -export const txnData: Transaction = { +export const txnData: Transaction = deepFreeze({ source: 'MOBILE_DASHCAM_BULK', txn_dt: new Date('2023-02-08T17:00:00.000Z'), currency: 'INR', @@ -184,9 +186,9 @@ export const txnData: Transaction = { custom_attributes: null, source_account_id: 'acc5APeygFjRd', skip_reimbursement: false, -}; +}); -export const txnData2: Transaction = { +export const txnData2: Transaction = deepFreeze({ created_at: new Date('2023-02-08T06:47:48.414Z'), updated_at: new Date('2023-02-08T06:47:48.414Z'), id: 'txNVtsqF8Siq', @@ -260,9 +262,9 @@ export const txnData2: Transaction = { physical_bill_at: null, policy_amount: null, locations: [], -}; +}); -export const upsertTxnParam: Transaction = { +export const upsertTxnParam: Transaction = deepFreeze({ skip_reimbursement: false, source: 'MOBILE', txn_dt: new Date('2023-02-13T17:00:00.000Z'), @@ -395,9 +397,9 @@ export const upsertTxnParam: Transaction = { admin_amount: null, custom_attributes: null, id: 'txT5J30Rsnbd', -}; +}); -export const txnData4: Transaction = { +export const txnData4: Transaction = deepFreeze({ created_at: new Date('2023-02-13T07:26:41.582Z'), updated_at: new Date('2023-02-13T07:26:44.188Z'), id: 'txT5J30Rsnbd', @@ -504,9 +506,9 @@ export const txnData4: Transaction = { physical_bill_at: null, policy_amount: null, locations: [], -}; +}); -export const txnDataPayload: Transaction = { +export const txnDataPayload: Transaction = deepFreeze({ skip_reimbursement: false, source: 'MOBILE', txn_dt: new Date('2023-02-13T17:00:00.000Z'), @@ -556,9 +558,9 @@ export const txnDataPayload: Transaction = { user_amount: null, admin_amount: null, custom_attributes: null, -}; +}); -export const splitPurposeTxn: Transaction = { +export const splitPurposeTxn: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -674,9 +676,9 @@ export const splitPurposeTxn: Transaction = { is_implicit_merge_blocked: false, categoryDisplayName: 'Unspecified', custom_attributes: null, -}; +}); -export const sourceSplitTxn: Transaction = { +export const sourceSplitTxn: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -784,9 +786,9 @@ export const sourceSplitTxn: Transaction = { ], is_implicit_merge_blocked: false, categoryDisplayName: '1 / ABCDFEIAPCALP ABCDFEIAPCALP ABCDFEIAPCALP ABCDFEIAPCALP ABCDFEIAPCALP', -}; +}); -export const splitTxn: Transaction = { +export const splitTxn: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -892,9 +894,9 @@ export const splitTxn: Transaction = { ], is_implicit_merge_blocked: false, categoryDisplayName: '1 / ABCDFEIAPCALP ABCDFEIAPCALP ABCDFEIAPCALP ABCDFEIAPCALP ABCDFEIAPCALP', -}; +}); -export const sourceTxn2: Transaction = { +export const sourceTxn2: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -1002,9 +1004,9 @@ export const sourceTxn2: Transaction = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'Others', -}; +}); -export const splitTxns: Transaction[] = [ +export const splitTxns: Transaction[] = deepFreeze([ { risk_state: null, is_duplicate_expense: null, @@ -1221,9 +1223,9 @@ export const splitTxns: Transaction[] = [ is_implicit_merge_blocked: false, categoryDisplayName: 'Others', }, -]; +]); -export const createSourceTxn: Transaction = { +export const createSourceTxn: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -1410,9 +1412,9 @@ export const createSourceTxn: Transaction = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'Food / Travelling - Inland', -}; +}); -export const createSourceTxn2: Transaction = { +export const createSourceTxn2: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -1513,9 +1515,9 @@ export const createSourceTxn2: Transaction = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'Food / Travelling - Inland', -}; +}); -export const splitTxn2: Transaction[] = [ +export const splitTxn2: Transaction[] = deepFreeze([ { risk_state: null, is_duplicate_expense: null, @@ -1888,9 +1890,9 @@ export const splitTxn2: Transaction[] = [ is_implicit_merge_blocked: false, categoryDisplayName: 'Food / Travelling - Inland', }, -]; +]); -export const txnParam1: Transaction = { +export const txnParam1: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -2077,9 +2079,9 @@ export const txnParam1: Transaction = { is_implicit_merge_blocked: false, categoryDisplayName: 'Food / Travelling - Inland', custom_attributes: null, -}; +}); -export const txnParam2: Transaction = { +export const txnParam2: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -2266,9 +2268,9 @@ export const txnParam2: Transaction = { is_implicit_merge_blocked: false, categoryDisplayName: 'Food / Travelling - Inland', custom_attributes: null, -}; +}); -export const txnData5: Transaction = { +export const txnData5: Transaction = deepFreeze({ ...txnData, orig_currency: 'USD', orig_amount: 200, @@ -2293,17 +2295,17 @@ export const txnData5: Transaction = { value: [], }, ], -}; +}); -export const expectedTxnParams: Transaction = { +export const expectedTxnParams: Transaction = deepFreeze({ ...txnData5, split_group_id: 'txOJVaaPxo9O', split_group_user_amount: 100, orig_amount: 100, amount: 1000, -}; +}); -export const expectedTxnParams2: Transaction = { +export const expectedTxnParams2: Transaction = deepFreeze({ ...txnData5, orig_amount: 100, amount: 1000, @@ -2311,9 +2313,9 @@ export const expectedTxnParams2: Transaction = { split_group_user_amount: 100, cost_center_id: 13795, org_category_id: 123032, -}; +}); -export const expectedTxnParams3: Transaction = { +export const expectedTxnParams3: Transaction = deepFreeze({ ...txnData5, orig_currency: undefined, split_group_user_amount: 100, @@ -2321,9 +2323,9 @@ export const expectedTxnParams3: Transaction = { amount: null, cost_center_id: null, org_category_id: 117013, -}; +}); -export const expectedTxnParams4: Transaction = { +export const expectedTxnParams4: Transaction = deepFreeze({ ...txnData5, orig_currency: undefined, split_group_user_amount: 100, @@ -2331,16 +2333,16 @@ export const expectedTxnParams4: Transaction = { amount: null, cost_center_id: 13795, org_category_id: 123032, -}; +}); -export const expectedTxnParams5: Transaction = { +export const expectedTxnParams5: Transaction = deepFreeze({ ...txnData5, source: 'MOBILE_SPLIT', orig_amount: null, amount: 0, -}; +}); -export const splitExpenseTxn1: Transaction = { +export const splitExpenseTxn1: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -2431,9 +2433,9 @@ export const splitExpenseTxn1: Transaction = { custom_properties: [], is_implicit_merge_blocked: false, categoryDisplayName: 'Bus', -}; +}); -export const splitExpenseTxn1_1: Transaction = { +export const splitExpenseTxn1_1: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -2524,9 +2526,9 @@ export const splitExpenseTxn1_1: Transaction = { custom_properties: [], is_implicit_merge_blocked: false, categoryDisplayName: 'Bus', -}; +}); -export const txnAmount1: Transaction = { +export const txnAmount1: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -2618,9 +2620,9 @@ export const txnAmount1: Transaction = { custom_properties: [], is_implicit_merge_blocked: false, categoryDisplayName: 'Bus', -}; +}); -export const splitExpenseTxn2: Transaction = { +export const splitExpenseTxn2: Transaction = deepFreeze({ skip_reimbursement: false, source: 'MOBILE', id: 'txmsakgYZeCV', @@ -2641,9 +2643,9 @@ export const splitExpenseTxn2: Transaction = { fyle_category: 'Entertainment', admin_amount: 0, user_amount: 0, -}; +}); -export const splitExpenseTxn2_2: Transaction = { +export const splitExpenseTxn2_2: Transaction = deepFreeze({ skip_reimbursement: false, source: 'MOBILE', state: 'COMPLETE', @@ -2664,9 +2666,9 @@ export const splitExpenseTxn2_2: Transaction = { fyle_category: 'Entertainment', admin_amount: 0, user_amount: 0, -}; +}); -export const splitExpenseTxn2_3: Transaction = { +export const splitExpenseTxn2_3: Transaction = deepFreeze({ skip_reimbursement: false, source: 'MOBILE', id: 'txmsakgYZeCV', @@ -2687,9 +2689,9 @@ export const splitExpenseTxn2_3: Transaction = { fyle_category: 'Entertainment', admin_amount: 0, user_amount: 0, -}; +}); -export const txnAmount2: Transaction = { +export const txnAmount2: Transaction = deepFreeze({ skip_reimbursement: false, source: 'MOBILE_CAMERA', txn_dt: new Date('2023-06-15T18:30:00.000Z'), @@ -2708,9 +2710,9 @@ export const txnAmount2: Transaction = { fyle_category: 'Entertainment', admin_amount: 0, user_amount: 0, -}; +}); -export const splitExpenseTxn3: Transaction[] = [ +export const splitExpenseTxn3: Transaction[] = deepFreeze([ { risk_state: null, is_duplicate_expense: null, @@ -2957,9 +2959,9 @@ export const splitExpenseTxn3: Transaction[] = [ is_implicit_merge_blocked: false, categoryDisplayName: '1 / Entertainment', }, -]; +]); -export const amtTxn3: Transaction = { +export const amtTxn3: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -3084,9 +3086,9 @@ export const amtTxn3: Transaction = { ], is_implicit_merge_blocked: false, categoryDisplayName: '1 / Entertainment', -}; +}); -export const editExpTxn = { +export const editExpTxn = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -3190,9 +3192,9 @@ export const editExpTxn = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'Software', -}; +}); -export const editExpTxn2 = { +export const editExpTxn2 = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -3299,9 +3301,9 @@ export const editExpTxn2 = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'ani test', -}; +}); -export const editExpTxn3 = { +export const editExpTxn3 = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -3408,9 +3410,9 @@ export const editExpTxn3 = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'ani test', -}; +}); -export const editExpTxn4 = { +export const editExpTxn4 = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -3518,9 +3520,9 @@ export const editExpTxn4 = { is_implicit_merge_blocked: false, categoryDisplayName: 'ani test', tx_policy_amount: 0, -}; +}); -export const editExpTxn5 = { +export const editExpTxn5 = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -3628,9 +3630,9 @@ export const editExpTxn5 = { is_implicit_merge_blocked: false, categoryDisplayName: 'ani test', tx_policy_amount: 0, -}; +}); -export const personalCardTxn: Transaction = { +export const personalCardTxn: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -3749,9 +3751,9 @@ export const personalCardTxn: Transaction = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'Software', -}; +}); -export const modifiedTxnData4: Transaction = { +export const modifiedTxnData4: Transaction = deepFreeze({ ...txnData4, from_dt: new Date('2023-08-04'), to_dt: new Date('2023-08-07'), @@ -3763,26 +3765,26 @@ export const modifiedTxnData4: Transaction = { org_category_id: 184692, txn_dt: new Date('Fri Aug 04 2023 05:30:00 GMT+0530 (India Standard Time)'), custom_properties: txnCustomPropertiesData, -}; +}); -export const modifiedTxnData5: Transaction = { +export const modifiedTxnData5: Transaction = deepFreeze({ ...modifiedTxnData4, project_id: 384582, -}; +}); -export const modifiedTxnData6: Transaction = { +export const modifiedTxnData6: Transaction = deepFreeze({ ...modifiedTxnData4, cost_center_id: 384582, project_id: undefined, -}; +}); -export const modifiedTxnData7: Transaction = { +export const modifiedTxnData7: Transaction = deepFreeze({ ...modifiedTxnData4, cost_center_id: undefined, project_id: undefined, -}; +}); -export const txnData6: Transaction = { +export const txnData6: Transaction = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -3882,9 +3884,9 @@ export const txnData6: Transaction = { proposed_exchange_rate: 0, status_id: '', updated_at: undefined, -}; +}); -export const perDiemTransaction: Partial = { +export const perDiemTransaction: Partial = deepFreeze({ source_account_id: 'accWUsrRlinFb', billable: true, org_category_id: 129140, @@ -3907,9 +3909,9 @@ export const perDiemTransaction: Partial = { cost_center_name: 'Test3', cost_center_code: 'code3', user_reason_for_duplicate_expenses: null, -}; +}); -export const editUnflattenedTransaction: Partial = { +export const editUnflattenedTransaction: Partial = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -4012,9 +4014,9 @@ export const editUnflattenedTransaction: Partial = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'Software / Subscriptions', -}; +}); -export const editUnflattenedTransactionPlatform: Partial = { +export const editUnflattenedTransactionPlatform: Partial = deepFreeze({ id: 'txD5hIQgLuR5', created_at: new Date('2024-02-09T01:20:13.098Z'), txn_dt: new Date('2024-02-09T06:00:00.000Z'), @@ -4099,19 +4101,19 @@ export const editUnflattenedTransactionPlatform: Partial = { project_code: null, physical_bill: null, physical_bill_at: null, -}; +}); -export const editUnflattenedTransactionPlatform2: Partial = { +export const editUnflattenedTransactionPlatform2: Partial = deepFreeze({ ...editUnflattenedTransactionPlatform, report_id: 'rpbNc3kn5baq', -}; +}); -export const editUnflattenedTransactionPlatform3: Partial = { +export const editUnflattenedTransactionPlatform3: Partial = deepFreeze({ ...editUnflattenedTransactionPlatform, report_id: 'rplD17WeBlha', -}; +}); -export const editUnflattenedTransactionWithMatchCCCPlatform: Partial = { +export const editUnflattenedTransactionWithMatchCCCPlatform: Partial = deepFreeze({ id: 'txmF3wgfj0Bs', created_at: new Date('2024-01-23T01:19:49.370Z'), txn_dt: new Date('2018-07-03T13:00:00.000Z'), @@ -4184,9 +4186,9 @@ export const editUnflattenedTransactionWithMatchCCCPlatform: Partial = { +export const editTransaction2: Partial = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -4289,9 +4291,9 @@ export const editTransaction2: Partial = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'Software / Subscriptions', -}; +}); -export const editTransaction3: Partial = { +export const editTransaction3: Partial = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -4420,9 +4422,9 @@ export const editTransaction3: Partial = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'ani test', -}; +}); -export const editTransaction4: Partial = { +export const editTransaction4: Partial = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -4551,9 +4553,9 @@ export const editTransaction4: Partial = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'ani test', -}; +}); -export const editTransaction5: Partial = { +export const editTransaction5: Partial = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -4656,9 +4658,9 @@ export const editTransaction5: Partial = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'Software / Subscriptions', -}; +}); -export const editTransaction6: Partial = { +export const editTransaction6: Partial = deepFreeze({ risk_state: null, is_duplicate_expense: null, duplicates: null, @@ -4787,43 +4789,43 @@ export const editTransaction6: Partial = { ], is_implicit_merge_blocked: false, categoryDisplayName: 'ani test', -}; +}); -export const txnData7: Transaction = { +export const txnData7: Transaction = deepFreeze({ ...txnData5, orig_amount: 100, amount: 1000, split_group_id: 'txOJVaaPxo9O', split_group_user_amount: 100, -}; +}); -export const txnData8: Transaction = { +export const txnData8: Transaction = deepFreeze({ ...txnData7, cost_center_id: 13795, org_category_id: 123032, -}; +}); -export const txnData9: Transaction = { +export const txnData9: Transaction = deepFreeze({ ...txnData5, amount: null, orig_currency: undefined, -}; +}); -export const txnData10: Transaction = { +export const txnData10: Transaction = deepFreeze({ ...txnData9, cost_center_id: 13795, org_category_id: 123032, -}; +}); -export const txnData11: Transaction = { +export const txnData11: Transaction = deepFreeze({ ...txnData5, source: 'MOBILE_SPLIT', orig_amount: null, amount: 0, -}; +}); -export const txnData12: Transaction = { +export const txnData12: Transaction = deepFreeze({ ...txnData11, cost_center_id: 13795, org_category_id: 123032, -}; +}); diff --git a/src/app/core/mock-data/transformed-expense.data.ts b/src/app/core/mock-data/transformed-expense.data.ts index f9ed386f80..21308e8801 100644 --- a/src/app/core/mock-data/transformed-expense.data.ts +++ b/src/app/core/mock-data/transformed-expense.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TransactionStatus } from '../models/platform/v1/expense.model'; import { UnflattenedTransaction } from '../models/unflattened-transaction.model'; -export const transformedExpenseData: Partial = { +export const transformedExpenseData: Partial = deepFreeze({ tx: { id: 'txvslh8aQMbu', created_at: new Date('2023-12-05T17:20:43.158Z'), @@ -75,9 +77,9 @@ export const transformedExpenseData: Partial = { id: 'ou6cE4dCLH8d', org_id: 'orNbIQloYtfa', }, -}; +}); -export const transformedExpenseDataWithSubCategory: Partial = { +export const transformedExpenseDataWithSubCategory: Partial = deepFreeze({ tx: { id: 'txD5hIQgLuR5', created_at: new Date('2024-02-09T01:20:13.098Z'), @@ -172,25 +174,25 @@ export const transformedExpenseDataWithSubCategory: Partial = { +export const transformedExpenseDataWithReportId: Partial = deepFreeze({ ...transformedExpenseDataWithSubCategory, tx: { ...transformedExpenseDataWithSubCategory.tx, report_id: 'rpbNc3kn5baq', }, -}; +}); -export const transformedExpenseDataWithReportId2: Partial = { +export const transformedExpenseDataWithReportId2: Partial = deepFreeze({ ...transformedExpenseDataWithSubCategory, tx: { ...transformedExpenseDataWithSubCategory.tx, report_id: 'rplD17WeBlha', }, -}; +}); -export const transformedExpenseWithExtractedData: Partial = { +export const transformedExpenseWithExtractedData: Partial = deepFreeze({ tx: { id: 'txO6d6eiB4JF', created_at: new Date('2024-02-11T17:27:43.416Z'), @@ -290,9 +292,9 @@ export const transformedExpenseWithExtractedData: Partial = { +export const transformedExpenseWithExtractedData2: Partial = deepFreeze({ ...transformedExpenseWithExtractedData, tx: { ...transformedExpenseWithExtractedData.tx, @@ -309,9 +311,9 @@ export const transformedExpenseWithExtractedData2: Partial = { +export const transformedExpenseWithMatchCCCData: Partial = deepFreeze({ tx: { id: 'txmF3wgfj0Bs', created_at: new Date('2024-01-23T01:19:49.370Z'), @@ -392,9 +394,9 @@ export const transformedExpenseWithMatchCCCData: Partial id: 'ouokfwl9OEdl', org_id: 'oroLKHBYQVvj', }, -}; +}); -export const transformedExpenseWithMatchCCCData2: Partial = { +export const transformedExpenseWithMatchCCCData2: Partial = deepFreeze({ ...transformedExpenseWithMatchCCCData, tx: { ...transformedExpenseWithMatchCCCData.tx, @@ -402,9 +404,9 @@ export const transformedExpenseWithMatchCCCData2: Partial = { +export const transformedExpenseWithMatchCCCData3: Partial = deepFreeze({ ...transformedExpenseWithMatchCCCData, tx: { ...transformedExpenseWithMatchCCCData.tx, @@ -428,9 +430,9 @@ export const transformedExpenseWithMatchCCCData3: Partial = { +export const transformedExpenseWithMatchCCCData4: Partial = deepFreeze({ tx: { id: 'txmF3wgfj0Bs', created_at: new Date('2024-01-23T01:19:49.370Z'), @@ -496,14 +498,14 @@ export const transformedExpenseWithMatchCCCData4: Partial = { +export const mileageCategoryTransformedExpenseData: Partial = deepFreeze({ ...transformedExpenseData, tx: { ...transformedExpenseData.tx, org_category: 'MILEAGE' }, -}; +}); -export const perDiemCategoryTransformedExpenseData: Partial = { +export const perDiemCategoryTransformedExpenseData: Partial = deepFreeze({ ...transformedExpenseData, tx: { ...transformedExpenseData.tx, org_category: 'PER DIEM' }, -}; +}); diff --git a/src/app/core/mock-data/transformed-split-expense-missing-fields.data.ts b/src/app/core/mock-data/transformed-split-expense-missing-fields.data.ts index 5eeabfbb18..cf676b1300 100644 --- a/src/app/core/mock-data/transformed-split-expense-missing-fields.data.ts +++ b/src/app/core/mock-data/transformed-split-expense-missing-fields.data.ts @@ -1,16 +1,18 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TransformedSplitExpenseMissingFields } from '../models/transformed-split-expense-missing-fields.model'; -export const transformedSplitExpenseMissingFieldsData: Partial = { +export const transformedSplitExpenseMissingFieldsData: Partial = deepFreeze({ amount: 67, currency: 'USD', name: 'food', type: 'category', -}; +}); -export const transformedSplitExpenseMissingFieldsData2: Partial = { +export const transformedSplitExpenseMissingFieldsData2: Partial = deepFreeze({ amount: 122, currency: 'INR', name: 'Food', type: 'category', data: { missing_amount: false, missing_receipt: false, missing_currency: false, missing_expense_field_ids: [] }, -}; +}); diff --git a/src/app/core/mock-data/txn-account.data.ts b/src/app/core/mock-data/txn-account.data.ts index 901a71b6d0..af804b85a5 100644 --- a/src/app/core/mock-data/txn-account.data.ts +++ b/src/app/core/mock-data/txn-account.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TransactionAccount } from '../models/transaction-account.model'; -export const txnAccountData: TransactionAccount = { +export const txnAccountData: TransactionAccount = deepFreeze({ source_account_id: 'acc5APeygFjRd', skip_reimbursement: false, -}; +}); diff --git a/src/app/core/mock-data/txn-custom-properties.data.ts b/src/app/core/mock-data/txn-custom-properties.data.ts index 1d80867906..8bf77ade39 100644 --- a/src/app/core/mock-data/txn-custom-properties.data.ts +++ b/src/app/core/mock-data/txn-custom-properties.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { TxnCustomProperties } from '../models/txn-custom-properties.model'; -export const txnCustomPropertiesData: TxnCustomProperties[] = [ +export const txnCustomPropertiesData: TxnCustomProperties[] = deepFreeze([ { id: 200227, mandatory: false, @@ -103,9 +105,9 @@ export const txnCustomPropertiesData: TxnCustomProperties[] = [ type: 'DATE', value: '2023-02-13T17:00:00.000Z', }, -]; +]); -export const txnCustomPropertiesData2: TxnCustomProperties[] = [ +export const txnCustomPropertiesData2: TxnCustomProperties[] = deepFreeze([ { id: 200227, mandatory: false, @@ -208,9 +210,9 @@ export const txnCustomPropertiesData2: TxnCustomProperties[] = [ type: 'DATE', value: '2023-02-13T17:00:00.000Z', }, -]; +]); -export const txnCustomPropertiesData3: TxnCustomProperties[] = [ +export const txnCustomPropertiesData3: TxnCustomProperties[] = deepFreeze([ { id: 213300, prefix: '', @@ -286,9 +288,9 @@ export const txnCustomPropertiesData3: TxnCustomProperties[] = [ options: undefined, parent_field_id: null, }, -]; +]); -export const txnCustomPropertiesData4: TxnCustomProperties[] = [ +export const txnCustomPropertiesData4: TxnCustomProperties[] = deepFreeze([ { id: 200227, prefix: '', @@ -377,9 +379,9 @@ export const txnCustomPropertiesData4: TxnCustomProperties[] = [ options: [], parent_field_id: null, }, -]; +]); -export const expectedTxnCustomProperties: TxnCustomProperties[] = [ +export const expectedTxnCustomProperties: TxnCustomProperties[] = deepFreeze([ { id: 200227, mandatory: false, @@ -433,9 +435,9 @@ export const expectedTxnCustomProperties: TxnCustomProperties[] = [ type: 'DATE', value: new Date('2023-02-13T17:00:00.000Z'), }, -]; +]); -export const TxnCustomProperties3: TxnCustomProperties[] = [ +export const TxnCustomProperties3: TxnCustomProperties[] = deepFreeze([ { id: 200227, mandatory: false, @@ -456,9 +458,9 @@ export const TxnCustomProperties3: TxnCustomProperties[] = [ type: 'DATE', value: '2023-02-13T17:00:00.000Z', }, -]; +]); -export const txnCustomProperties4: TxnCustomProperties[] = [ +export const txnCustomProperties4: TxnCustomProperties[] = deepFreeze([ { id: 318297, mandatory: true, @@ -532,9 +534,9 @@ export const txnCustomProperties4: TxnCustomProperties[] = [ type: 'DATE', value: new Date('2023-02-13T17:00:00.000Z'), }, -]; +]); -export const txnCustomPropertiesData6: TxnCustomProperties[] = [ +export const txnCustomPropertiesData6: TxnCustomProperties[] = deepFreeze([ { id: 200227, mandatory: false, @@ -637,9 +639,9 @@ export const txnCustomPropertiesData6: TxnCustomProperties[] = [ type: 'DATE', value: '2023-02-13T17:00:00.000Z', }, -]; +]); -export const txnCustomPropertiesData5: TxnCustomProperties[] = [ +export const txnCustomPropertiesData5: TxnCustomProperties[] = deepFreeze([ { id: 318297, mandatory: true, @@ -713,4 +715,4 @@ export const txnCustomPropertiesData5: TxnCustomProperties[] = [ type: 'DATE', value: new Date('2023-02-13T17:00:00.000Z'), }, -]; +]); diff --git a/src/app/core/mock-data/undo-merge.data.ts b/src/app/core/mock-data/undo-merge.data.ts index d7b15996da..81141300ab 100644 --- a/src/app/core/mock-data/undo-merge.data.ts +++ b/src/app/core/mock-data/undo-merge.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { UndoMerge } from '../models/undo-merge.model'; import { txnList } from './transaction.data'; -export const UndoMergeData: UndoMerge = { +export const UndoMergeData: UndoMerge = deepFreeze({ user_created_expense: { created_at: new Date('2022-02-17T14:12:49.079Z'), updated_at: new Date('2022-06-12T11:37:06.592Z'), @@ -152,9 +154,9 @@ export const UndoMergeData: UndoMerge = { policy_amount: null, locations: [], }, -}; +}); -export const UndoMergeData2: UndoMerge = { +export const UndoMergeData2: UndoMerge = deepFreeze({ user_created_expense: txnList[0], auto_created_expense: txnList[1], -}; +}); diff --git a/src/app/core/mock-data/unflattened-advance-request.data.ts b/src/app/core/mock-data/unflattened-advance-request.data.ts index 5a40adfad3..aa9508beb5 100644 --- a/src/app/core/mock-data/unflattened-advance-request.data.ts +++ b/src/app/core/mock-data/unflattened-advance-request.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { UnflattenedAdvanceRequest } from '../models/unflattened-advance-request.model'; -export const unflattenedAdvanceRequestData: UnflattenedAdvanceRequest = { +export const unflattenedAdvanceRequestData: UnflattenedAdvanceRequest = deepFreeze({ areq: { id: 'areqLFKMxUSAlQ', created_at: new Date('2023-10-03T09:20:22.112Z'), @@ -69,4 +71,4 @@ export const unflattenedAdvanceRequestData: UnflattenedAdvanceRequest = { new: { state: 'APPROVAL_PENDING', }, -}; +}); diff --git a/src/app/core/mock-data/unflattened-expense.data.ts b/src/app/core/mock-data/unflattened-expense.data.ts index 0e6610a666..882c69dad7 100644 --- a/src/app/core/mock-data/unflattened-expense.data.ts +++ b/src/app/core/mock-data/unflattened-expense.data.ts @@ -1,9 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExpenseSource } from '../models/expense-source.enum'; import { ExpenseState } from '../models/expense-state.enum'; import { PublicPolicyExpense } from '../models/public-policy-expense.model'; import { UnflattenedTransaction } from '../models/unflattened-transaction.model'; -export const unflattenExp1: { tx: PublicPolicyExpense } = { +export const unflattenExp1: { tx: PublicPolicyExpense } = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -111,9 +113,9 @@ export const unflattenExp1: { tx: PublicPolicyExpense } = { status_id: '', updated_at: undefined, }, -}; +}); -export const unflattenExp2: { tx: PublicPolicyExpense } = { +export const unflattenExp2: { tx: PublicPolicyExpense } = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -225,9 +227,9 @@ export const unflattenExp2: { tx: PublicPolicyExpense } = { status_id: '', updated_at: undefined, }, -}; +}); -export const unflattenedTxn: UnflattenedTransaction = { +export const unflattenedTxn: UnflattenedTransaction = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -352,9 +354,9 @@ export const unflattenedTxn: UnflattenedTransaction = { is: { test_call: false, }, -}; +}); -export const unflattenedExpData = { +export const unflattenedExpData = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -523,9 +525,9 @@ export const unflattenedExpData = { test_call: null, }, dataUrls: [], -}; +}); -export const draftUnflattendedTxn = { +export const draftUnflattendedTxn = deepFreeze({ ...unflattenedExpData, tx: { ...unflattenedExpData.tx, @@ -535,9 +537,9 @@ export const draftUnflattendedTxn = { org_category_id: null, fyle_category: 'UNSPECIFIED', }, -}; +}); -export const draftUnflattendedTxn2: UnflattenedTransaction = { +export const draftUnflattendedTxn2: UnflattenedTransaction = deepFreeze({ ...unflattenedExpData, tx: { ...unflattenedExpData.tx, @@ -547,9 +549,9 @@ export const draftUnflattendedTxn2: UnflattenedTransaction = { org_category_id: null, fyle_category: null, }, -}; +}); -export const draftUnflattendedTxn3 = { +export const draftUnflattendedTxn3 = deepFreeze({ ...unflattenedExpData, tx: { ...unflattenedExpData.tx, @@ -559,9 +561,9 @@ export const draftUnflattendedTxn3 = { org_category_id: null, fyle_category: 'UNSPECIFIED', }, -}; +}); -export const draftUnflattendedTxn4: UnflattenedTransaction = { +export const draftUnflattendedTxn4: UnflattenedTransaction = deepFreeze({ ...unflattenedExpData, tx: { ...unflattenedExpData.tx, @@ -571,9 +573,9 @@ export const draftUnflattendedTxn4: UnflattenedTransaction = { org_category_id: 212690, fyle_category: null, }, -}; +}); -export const unflattenedTxnDataPerDiem = { +export const unflattenedTxnDataPerDiem = deepFreeze({ tx: { // TODO: Enum for state and source skip_reimbursement: false, @@ -593,4 +595,4 @@ export const unflattenedTxnDataPerDiem = { custom_properties: [], org_user_id: 'ouX8dwsbLCLv', }, -}; +}); diff --git a/src/app/core/mock-data/unflattened-txn.data.ts b/src/app/core/mock-data/unflattened-txn.data.ts index 10ce3de82c..29c0ba7168 100644 --- a/src/app/core/mock-data/unflattened-txn.data.ts +++ b/src/app/core/mock-data/unflattened-txn.data.ts @@ -1,9 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CommuteDeduction } from '../enums/commute-deduction.enum'; import { UnflattenedTransaction } from '../models/unflattened-transaction.model'; import { optionsData15, optionsData33 } from './merge-expenses-options-data.data'; import { personalCardTxn } from './transaction.data'; -export const unflattenedTxnData: UnflattenedTransaction = { +export const unflattenedTxnData: UnflattenedTransaction = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -151,9 +153,9 @@ export const unflattenedTxnData: UnflattenedTransaction = { is: { test_call: null, }, -}; +}); -export const unflattenedTxnDataWithSubCategory: UnflattenedTransaction = { +export const unflattenedTxnDataWithSubCategory: UnflattenedTransaction = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -301,9 +303,9 @@ export const unflattenedTxnDataWithSubCategory: UnflattenedTransaction = { is: { test_call: null, }, -}; +}); -export const unflattenedTxnWithExtractedData: UnflattenedTransaction = { +export const unflattenedTxnWithExtractedData: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -322,9 +324,9 @@ export const unflattenedTxnWithExtractedData: UnflattenedTransaction = { invoice_dt: new Date('2023-02-24T12:03:57.680Z'), }, }, -}; +}); -export const expectedUnflattendedTxnData1: UnflattenedTransaction = { +export const expectedUnflattendedTxnData1: UnflattenedTransaction = deepFreeze({ tx: { risk_state: null, txn_dt: new Date('2023-01-24T11:30:00.000Z'), @@ -472,9 +474,9 @@ export const expectedUnflattendedTxnData1: UnflattenedTransaction = { is: { test_call: null, }, -}; +}); -export const expectedUnflattendedTxnData2 = { +export const expectedUnflattendedTxnData2 = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -593,18 +595,18 @@ export const expectedUnflattendedTxnData2 = { joining_dt: new Date('2017-07-25T00:00:00.000Z'), }, dataUrls: [], -}; +}); -export const unflattenedTxnData2: UnflattenedTransaction = { +export const unflattenedTxnData2: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, amount: 100, user_amount: 100, }, -}; +}); -export const expectedUnflattendedTxnData3: UnflattenedTransaction = { +export const expectedUnflattendedTxnData3: UnflattenedTransaction = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -761,9 +763,9 @@ export const expectedUnflattendedTxnData3: UnflattenedTransaction = { is: { test_call: false, }, -}; +}); -export const expectedUnflattendedTxnData4: UnflattenedTransaction = { +export const expectedUnflattendedTxnData4: UnflattenedTransaction = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -914,9 +916,9 @@ export const expectedUnflattendedTxnData4: UnflattenedTransaction = { is: { test_call: false, }, -}; +}); -export const expectedUnflattendedTxnData5 = { +export const expectedUnflattendedTxnData5 = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -1051,9 +1053,9 @@ export const expectedUnflattendedTxnData5 = { joining_dt: new Date('2017-07-25T00:00:00.000Z'), }, dataUrls: [], -}; +}); -export const unflattenedTxnDataWithoutCategoryData: UnflattenedTransaction = { +export const unflattenedTxnDataWithoutCategoryData: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -1061,9 +1063,9 @@ export const unflattenedTxnDataWithoutCategoryData: UnflattenedTransaction = { org_category_id: null, fyle_category: 'unspecified', }, -}; +}); -export const expWithCriticalViolation: { etxn: UnflattenedTransaction; comment: string } = { +export const expWithCriticalViolation: { etxn: UnflattenedTransaction; comment: string } = deepFreeze({ etxn: { tx: { risk_state: null, @@ -1235,9 +1237,9 @@ export const expWithCriticalViolation: { etxn: UnflattenedTransaction; comment: dataUrls: [], }, comment: null, -}; +}); -export const unflattenedPaidExp: UnflattenedTransaction = { +export const unflattenedPaidExp: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -1245,9 +1247,9 @@ export const unflattenedPaidExp: UnflattenedTransaction = { fyle_category: 'TRAVEL', org_category_id: 12345, }, -}; +}); -export const unflattenedDraftExp: UnflattenedTransaction = { +export const unflattenedDraftExp: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -1255,9 +1257,9 @@ export const unflattenedDraftExp: UnflattenedTransaction = { fyle_category: 'unspecified', org_category_id: 12345, }, -}; +}); -export const unflattenedDraftExp2: UnflattenedTransaction = { +export const unflattenedDraftExp2: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -1266,18 +1268,18 @@ export const unflattenedDraftExp2: UnflattenedTransaction = { fyle_category: 'unspecified', org_category_id: null, }, -}; +}); -export const unflattenedPaidExp2: UnflattenedTransaction = { +export const unflattenedPaidExp2: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, state: 'PAID', fyle_category: 'TRAVEL', }, -}; +}); -export const expectedExpenseObservable: Partial = { +export const expectedExpenseObservable: Partial = deepFreeze({ tx: { skip_reimbursement: false, source: 'MOBILE', @@ -1311,9 +1313,9 @@ export const expectedExpenseObservable: Partial = { thumbnail: 'data-url', }, ], -}; +}); -export const expectedExpenseObservable2 = { +export const expectedExpenseObservable2 = deepFreeze({ tx: { skip_reimbursement: false, source: 'MOBILE', @@ -1330,9 +1332,9 @@ export const expectedExpenseObservable2 = { project_id: 3943, }, dataUrls: [], -}; +}); -export const expectedExpenseObservable3: Partial = { +export const expectedExpenseObservable3: Partial = deepFreeze({ tx: { skip_reimbursement: false, source: 'MOBILE', @@ -1366,9 +1368,9 @@ export const expectedExpenseObservable3: Partial = { thumbnail: 'data-url', }, ], -}; +}); -export const expectedExpenseObservable4: Partial = { +export const expectedExpenseObservable4: Partial = deepFreeze({ tx: { source: 'MOBILE', currency: 'INR', @@ -1400,9 +1402,9 @@ export const expectedExpenseObservable4: Partial = { thumbnail: 'data-url', }, ], -}; +}); -export const expectedExpenseObservable5: Partial = { +export const expectedExpenseObservable5: Partial = deepFreeze({ tx: { source: 'MOBILE', currency: 'USD', @@ -1433,9 +1435,9 @@ export const expectedExpenseObservable5: Partial = { thumbnail: 'data-url', }, ], -}; +}); -export const unflattenedTxnDataWithoutCategoryData2: UnflattenedTransaction = { +export const unflattenedTxnDataWithoutCategoryData2: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -1450,17 +1452,17 @@ export const unflattenedTxnDataWithoutCategoryData2: UnflattenedTransaction = { org_category_id: 12345, fyle_category: 'unspecified', }, -}; +}); -export const unflattenedTransactionDataPersonalCard: UnflattenedTransaction = { +export const unflattenedTransactionDataPersonalCard: UnflattenedTransaction = deepFreeze({ ...expectedUnflattendedTxnData3, tx: { ...personalCardTxn, locations: null, }, -}; +}); -export const newUnflattenedTxn = { +export const newUnflattenedTxn = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -1623,9 +1625,9 @@ export const newUnflattenedTxn = { test_call: null, }, dataUrls: [], -}; +}); -export const unflattenedTxnDataWithReportID = { +export const unflattenedTxnDataWithReportID = deepFreeze({ ...expectedUnflattendedTxnData2, tx: { ...expectedUnflattendedTxnData2.tx, @@ -1651,9 +1653,9 @@ export const unflattenedTxnDataWithReportID = { is: { test_call: false, }, -}; +}); -export const unflattenedTxnDataWithReportID2 = { +export const unflattenedTxnDataWithReportID2 = deepFreeze({ ...expectedUnflattendedTxnData2, tx: { ...expectedUnflattendedTxnData2.tx, @@ -1679,9 +1681,9 @@ export const unflattenedTxnDataWithReportID2 = { is: { test_call: false, }, -}; +}); -export const unflattenedTxnDataWithViolationUserReview = { +export const unflattenedTxnDataWithViolationUserReview = deepFreeze({ ...expectedUnflattendedTxnData2, tx: { ...expectedUnflattendedTxnData2.tx, @@ -1708,18 +1710,18 @@ export const unflattenedTxnDataWithViolationUserReview = { is: { test_call: false, }, -}; +}); -export const unflattenedExpenseWithCCCGroupId = { +export const unflattenedExpenseWithCCCGroupId = deepFreeze({ ...unflattenedTxnDataWithViolationUserReview, tx: { ...expectedUnflattendedTxnData2.tx, corporate_credit_card_expense_group_id: 'ccceWauzF1A3oS', report_id: null, }, -}; +}); -export const unflattenedExpenseWithCCCGroupId2 = { +export const unflattenedExpenseWithCCCGroupId2 = deepFreeze({ ...unflattenedTxnDataWithViolationUserReview, tx: { ...expectedUnflattendedTxnData2.tx, @@ -1728,47 +1730,47 @@ export const unflattenedExpenseWithCCCGroupId2 = { report_id: null, policy_amount: -100, }, -}; +}); -export const txnWithCCCGroupID = { +export const txnWithCCCGroupID = deepFreeze({ ...unflattenedTxnData.tx, corporate_credit_card_expense_group_id: 'ccceWauzF1A3oS', report_id: null, -}; +}); -export const unflattenedExpWoProject = { +export const unflattenedExpWoProject = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, project_id: null, }, -}; +}); -export const unflattenedExpWithReport = { +export const unflattenedExpWithReport = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, report_id: 'rprAfNrce73O', }, -}; +}); -export const unflattenedExpWithCostCenter = { +export const unflattenedExpWithCostCenter = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, cost_center_id: 2411, }, -}; +}); -export const unflattenedExpWoCostCenter = { +export const unflattenedExpWoCostCenter = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, cost_center_id: null, }, -}; +}); -export const unflattenedExp2 = { +export const unflattenedExp2 = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -1787,9 +1789,9 @@ export const unflattenedExp2 = { thumbnail: 'data-url', }, ], -}; +}); -export const unflattenedExpWithCCCExpn: UnflattenedTransaction = { +export const unflattenedExpWithCCCExpn: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -1810,26 +1812,26 @@ export const unflattenedExpWithCCCExpn: UnflattenedTransaction = { thumbnail: 'data-url', }, ], -}; +}); -export const unflattenedExpWithCCCExpn1: UnflattenedTransaction = { +export const unflattenedExpWithCCCExpn1: UnflattenedTransaction = deepFreeze({ ...unflattenedExpWithCCCExpn, tx: { ...unflattenedExpWithCCCExpn.tx, split_group_id: 'tx6I9xcOZFU6', }, -}; +}); -export const unflattenedExpWithoutCCExpnSync: UnflattenedTransaction = { +export const unflattenedExpWithoutCCExpnSync: UnflattenedTransaction = deepFreeze({ ...unflattenedExpWithCCCExpn, tx: { ...unflattenedExpWithCCCExpn.tx, matched_corporate_card_transactions: [], split_group_id: 'tx6I9xcOZFU6', }, -}; +}); -export const trackCreateExpData: UnflattenedTransaction = { +export const trackCreateExpData: UnflattenedTransaction = deepFreeze({ ...unflattenedExp2, tx: { ...unflattenedExp2.tx, @@ -1839,9 +1841,9 @@ export const trackCreateExpData: UnflattenedTransaction = { currency: 'USD', orig_currency: 'USD', }, -}; +}); -export const trackCreateExpDataWoCurrency: UnflattenedTransaction = { +export const trackCreateExpDataWoCurrency: UnflattenedTransaction = deepFreeze({ ...unflattenedExp2, tx: { ...unflattenedExp2.tx, @@ -1851,9 +1853,9 @@ export const trackCreateExpDataWoCurrency: UnflattenedTransaction = { currency: null, orig_currency: 'USD', }, -}; +}); -export const trackAddExpenseWoCurrency: Partial = { +export const trackAddExpenseWoCurrency: Partial = deepFreeze({ ...expectedUnflattendedTxnData4, tx: { ...expectedUnflattendedTxnData4.tx, @@ -1886,9 +1888,9 @@ export const trackAddExpenseWoCurrency: Partial = { test_call: false, }, dataUrls: null, -}; +}); -export const newExpFromFg: Partial = { +export const newExpFromFg: Partial = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -2039,9 +2041,9 @@ export const newExpFromFg: Partial = { joining_dt: new Date('2017-07-25T00:00:00.000Z'), }, dataUrls: [], -}; +}); -export const newExpFromFg2: Partial = { +export const newExpFromFg2: Partial = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -2193,9 +2195,9 @@ export const newExpFromFg2: Partial = { joining_dt: new Date('2017-07-25T00:00:00.000Z'), }, dataUrls: [], -}; +}); -export const newExpFromFg3: Partial = { +export const newExpFromFg3: Partial = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -2330,9 +2332,9 @@ export const newExpFromFg3: Partial = { joining_dt: new Date('2017-07-25T00:00:00.000Z'), }, dataUrls: [], -}; +}); -export const newExpFromFg4: Partial = { +export const newExpFromFg4: Partial = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -2467,9 +2469,9 @@ export const newExpFromFg4: Partial = { joining_dt: new Date('2017-07-25T00:00:00.000Z'), }, dataUrls: [], -}; +}); -export const newExpFromFgPlatform: Partial = { +export const newExpFromFgPlatform: Partial = deepFreeze({ tx: { id: 'txD5hIQgLuR5', created_at: new Date('2024-02-09T01:20:13.098Z'), @@ -2581,14 +2583,14 @@ export const newExpFromFgPlatform: Partial = { org_id: 'orNbIQloYtfa', }, dataUrls: [], -}; +}); -export const expWithSplitGroupID: Partial = { +export const expWithSplitGroupID: Partial = deepFreeze({ ...unflattenedTxnData, tx: null, -}; +}); -export const unflattenedTxnWithExtractedData2: UnflattenedTransaction = { +export const unflattenedTxnWithExtractedData2: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -2607,9 +2609,9 @@ export const unflattenedTxnWithExtractedData2: UnflattenedTransaction = { invoice_dt: new Date('2023-02-24T12:03:57.680Z'), }, }, -}; +}); -export const unflattenedDraftExp3: UnflattenedTransaction = { +export const unflattenedDraftExp3: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -2618,9 +2620,9 @@ export const unflattenedDraftExp3: UnflattenedTransaction = { fyle_category: null, org_category_id: null, }, -}; +}); -export const checkSplitExpData1: UnflattenedTransaction = { +export const checkSplitExpData1: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -2631,9 +2633,9 @@ export const checkSplitExpData1: UnflattenedTransaction = { org_category_id: null, split_group_id: 'tx3qHxFNgRcZ', }, -}; +}); -export const checkSplitExpData2: UnflattenedTransaction = { +export const checkSplitExpData2: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -2641,9 +2643,9 @@ export const checkSplitExpData2: UnflattenedTransaction = { state: 'COMPLETE', split_group_id: null, }, -}; +}); -export const checkDebitCCCExpenseData1: UnflattenedTransaction = { +export const checkDebitCCCExpenseData1: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -2652,9 +2654,9 @@ export const checkDebitCCCExpenseData1: UnflattenedTransaction = { amount: 100, corporate_credit_card_expense_group_id: 'tx3qHxFNgRcZ', }, -}; +}); -export const checkDebitCCCExpenseData2: UnflattenedTransaction = { +export const checkDebitCCCExpenseData2: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -2663,9 +2665,9 @@ export const checkDebitCCCExpenseData2: UnflattenedTransaction = { amount: -1, corporate_credit_card_expense_group_id: 'tx3qHxFNgRcZ', }, -}; +}); -export const setupFormExpenseWoCurrency: UnflattenedTransaction = { +export const setupFormExpenseWoCurrency: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData, @@ -2688,9 +2690,9 @@ export const setupFormExpenseWoCurrency: UnflattenedTransaction = { }, ], }, -}; +}); -export const setupFormExpenseWoCurrency2: UnflattenedTransaction = { +export const setupFormExpenseWoCurrency2: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -2712,9 +2714,9 @@ export const setupFormExpenseWoCurrency2: UnflattenedTransaction = { }, ], }, -}; +}); -export const setupFormExpenseWoCurrency3: UnflattenedTransaction = { +export const setupFormExpenseWoCurrency3: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -2727,9 +2729,9 @@ export const setupFormExpenseWoCurrency3: UnflattenedTransaction = { locations: [], project_id: null, }, -}; +}); -export const expectedPersonalTxn: UnflattenedTransaction = { +export const expectedPersonalTxn: UnflattenedTransaction = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -2878,9 +2880,9 @@ export const expectedPersonalTxn: UnflattenedTransaction = { }, us: undefined, rp: undefined, -}; +}); -export const newExpenseMileageData1: Partial = { +export const newExpenseMileageData1: Partial = deepFreeze({ tx: { skip_reimbursement: false, source: 'MOBILE', @@ -2904,9 +2906,9 @@ export const newExpenseMileageData1: Partial = { locations: [], custom_properties: [], }, -}; +}); -export const newExpenseMileageData2: Partial = { +export const newExpenseMileageData2: Partial = deepFreeze({ tx: { skip_reimbursement: false, source: 'MOBILE', @@ -2940,42 +2942,42 @@ export const newExpenseMileageData2: Partial = { ], custom_properties: [], }, -}; -export const mileageCategoryUnflattenedExpense: UnflattenedTransaction = { +}); +export const mileageCategoryUnflattenedExpense: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, org_category: 'MILEAGE' }, -}; +}); -export const perDiemCategoryUnflattenedExpense: UnflattenedTransaction = { +export const perDiemCategoryUnflattenedExpense: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, org_category: 'PER DIEM' }, -}; +}); -export const unflattenedTxnWithSourceID: UnflattenedTransaction = { +export const unflattenedTxnWithSourceID: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, source_account_id: 'acc6mK6CEesGL', }, -}; +}); -export const unflattenedTxnWithSourceID2: UnflattenedTransaction = { +export const unflattenedTxnWithSourceID2: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, source_account_id: 'acc6mK6CEesXL', }, -}; +}); -export const unflattendedTxnWithPolicyAmount: UnflattenedTransaction = { +export const unflattendedTxnWithPolicyAmount: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, policy_amount: 100, }, -}; +}); -export const unflattenedTxnWithTrackData: UnflattenedTransaction = { +export const unflattenedTxnWithTrackData: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -2988,17 +2990,17 @@ export const unflattenedTxnWithTrackData: UnflattenedTransaction = { }, ], }, -}; +}); -export const unflattenedTxnDataWithReportID2UserReview: UnflattenedTransaction = { +export const unflattenedTxnDataWithReportID2UserReview: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnDataWithReportID2, tx: { ...unflattenedTxnDataWithReportID2.tx, user_review_needed: true, }, -}; +}); -export const expenseTrackCreate: UnflattenedTransaction = { +export const expenseTrackCreate: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, @@ -3011,9 +3013,9 @@ export const expenseTrackCreate: UnflattenedTransaction = { }, ], }, -}; +}); -export const unflattenedTxnWithReportID3: UnflattenedTransaction = { +export const unflattenedTxnWithReportID3: UnflattenedTransaction = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -3161,9 +3163,9 @@ export const unflattenedTxnWithReportID3: UnflattenedTransaction = { is: { test_call: null, }, -}; +}); -export const newMileageExpFromForm: Partial = { +export const newMileageExpFromForm: Partial = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -3374,9 +3376,9 @@ export const newMileageExpFromForm: Partial = { sub_department: null, joining_dt: new Date('2017-07-25T00:00:00.000Z'), }, -}; +}); -export const newMileageExpFromForm2: Partial = { +export const newMileageExpFromForm2: Partial = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -3494,9 +3496,9 @@ export const newMileageExpFromForm2: Partial = { sub_department: null, joining_dt: new Date('2017-07-25T00:00:00.000Z'), }, -}; +}); -export const unflattenedTxnWithCategory: UnflattenedTransaction = { +export const unflattenedTxnWithCategory: UnflattenedTransaction = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -3644,17 +3646,17 @@ export const unflattenedTxnWithCategory: UnflattenedTransaction = { is: { test_call: null, }, -}; +}); -export const unflattenedTxnWithCC: UnflattenedTransaction = { +export const unflattenedTxnWithCC: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, cost_center_id: 2411, }, -}; +}); -export const newMileageExpFromForm3: UnflattenedTransaction = { +export const newMileageExpFromForm3: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnWithReportID3, tx: { ...unflattenedTxnWithReportID3.tx, @@ -3689,12 +3691,12 @@ export const newMileageExpFromForm3: UnflattenedTransaction = { }, ], }, -}; +}); -export const unflattenedMileageDataWithPolicyAmount: UnflattenedTransaction = { +export const unflattenedMileageDataWithPolicyAmount: UnflattenedTransaction = deepFreeze({ ...unflattenedTxnData, tx: { ...unflattenedTxnData.tx, policy_amount: 100, }, -}; +}); diff --git a/src/app/core/mock-data/unformatted-transaction.data.ts b/src/app/core/mock-data/unformatted-transaction.data.ts index acc34453b3..6007315d68 100644 --- a/src/app/core/mock-data/unformatted-transaction.data.ts +++ b/src/app/core/mock-data/unformatted-transaction.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { UnformattedTransaction } from '../models/unformatted-transaction.model'; -export const unformattedTxnData: Partial[] = [ +export const unformattedTxnData: Partial[] = deepFreeze([ { created_at: new Date('2023-02-08T06:47:48.414Z'), updated_at: new Date('2023-02-08T06:47:48.414Z'), @@ -72,4 +74,4 @@ export const unformattedTxnData: Partial[] = [ policy_amount: null, locations: [], }, -]; +]); diff --git a/src/app/core/mock-data/unique-cards-stats.data.ts b/src/app/core/mock-data/unique-cards-stats.data.ts index a6b89d9266..908100c6bb 100644 --- a/src/app/core/mock-data/unique-cards-stats.data.ts +++ b/src/app/core/mock-data/unique-cards-stats.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { UniqueCardStats } from '../models/unique-cards-stats.model'; -export const expectedUniqueCardStats: UniqueCardStats[] = [ +export const expectedUniqueCardStats: UniqueCardStats[] = deepFreeze([ { cardNumber: '8698', cardName: 'DAMNA', @@ -21,4 +23,4 @@ export const expectedUniqueCardStats: UniqueCardStats[] = [ totalTxnsCount: 5, totalAmountValue: 371.87, }, -]; +]); diff --git a/src/app/core/mock-data/unique-cards.data.ts b/src/app/core/mock-data/unique-cards.data.ts index 6752ce732b..2f142290d0 100644 --- a/src/app/core/mock-data/unique-cards.data.ts +++ b/src/app/core/mock-data/unique-cards.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { UniqueCards } from '../models/unique-cards.model'; -export const uniqueCardsParam: UniqueCards[] = [ +export const uniqueCardsParam: UniqueCards[] = deepFreeze([ { cardNumber: '8698', cardName: 'DAMNA', @@ -13,4 +15,4 @@ export const uniqueCardsParam: UniqueCards[] = [ cardNumber: '869', cardName: 'PEX BANK', }, -]; +]); diff --git a/src/app/core/mock-data/user-password-status.data.ts b/src/app/core/mock-data/user-password-status.data.ts index e369cc916e..5fa27fcb22 100644 --- a/src/app/core/mock-data/user-password-status.data.ts +++ b/src/app/core/mock-data/user-password-status.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { UserPasswordStatus } from '../models/user-password-status.model'; -export const userPasswordStatus: UserPasswordStatus = { +export const userPasswordStatus: UserPasswordStatus = deepFreeze({ is_password_required: true, is_password_set: true, -}; +}); diff --git a/src/app/core/mock-data/value-error-mapping-for-update-mobile-number-popover.data.ts b/src/app/core/mock-data/value-error-mapping-for-update-mobile-number-popover.data.ts index f084afaa8d..5e1e2e5ebb 100644 --- a/src/app/core/mock-data/value-error-mapping-for-update-mobile-number-popover.data.ts +++ b/src/app/core/mock-data/value-error-mapping-for-update-mobile-number-popover.data.ts @@ -1,9 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + interface ValueErrorMapping { value: string | null; error: string | null; } -export const valueErrorMapping: ValueErrorMapping[] = [ +export const valueErrorMapping: ValueErrorMapping[] = deepFreeze([ { value: null, error: 'Please enter a Mobile Number', @@ -24,4 +26,4 @@ export const valueErrorMapping: ValueErrorMapping[] = [ value: '+918080913866', error: null, }, -]; +]); diff --git a/src/app/core/mock-data/virtual-card-combined-response.data.ts b/src/app/core/mock-data/virtual-card-combined-response.data.ts index 399601946d..70f8fe44aa 100644 --- a/src/app/core/mock-data/virtual-card-combined-response.data.ts +++ b/src/app/core/mock-data/virtual-card-combined-response.data.ts @@ -1,4 +1,6 @@ -export const virtualCardCombinedResponse = { +import deepFreeze from 'deep-freeze-strict'; + +export const virtualCardCombinedResponse = deepFreeze({ vc1234: { full_card_number: '123451234512345', cvv: '1234', @@ -6,4 +8,4 @@ export const virtualCardCombinedResponse = { nick_name: 'Nickname', current_amount: 1000, }, -}; +}); diff --git a/src/app/core/mock-data/virtual-card-details-response.data.ts b/src/app/core/mock-data/virtual-card-details-response.data.ts index 3fb3d94845..ffc8199fa3 100644 --- a/src/app/core/mock-data/virtual-card-details-response.data.ts +++ b/src/app/core/mock-data/virtual-card-details-response.data.ts @@ -1,17 +1,18 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CardDetailsAmountResponse } from '../models/card-details-amount-response'; import { CardDetailsResponse } from '../models/card-details-response.model'; -export const virtualCardDetailsResponse: { data: CardDetailsResponse } = { +export const virtualCardDetailsResponse: { data: CardDetailsResponse } = deepFreeze({ data: { full_card_number: '123412341234123', cvv: '123', - // @ts-ignore expiry_date: '2029-01-01T00:00:00+00:00', }, -}; +}); -export const virtualCardCurrentAmountResponse: { data: CardDetailsAmountResponse } = { +export const virtualCardCurrentAmountResponse: { data: CardDetailsAmountResponse } = deepFreeze({ data: { current_amount: 1000, }, -}; +}); diff --git a/src/app/core/mock-data/virtual-card-response.data.ts b/src/app/core/mock-data/virtual-card-response.data.ts index e86f1a2cbb..826b6775da 100644 --- a/src/app/core/mock-data/virtual-card-response.data.ts +++ b/src/app/core/mock-data/virtual-card-response.data.ts @@ -1,8 +1,10 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CardStatus } from '../enums/card-status.enum'; import { PlatformApiResponse } from '../models/platform/platform-api-response.model'; import { VirtualCard } from '../models/virtual-card.model'; -export const virtualCardResponse: PlatformApiResponse = { +export const virtualCardResponse: PlatformApiResponse = deepFreeze({ count: 1, data: [ { @@ -22,10 +24,10 @@ export const virtualCardResponse: PlatformApiResponse = { }, ], offset: 0, -}; +}); -export const virtualCardUndefinedResponse: PlatformApiResponse = { +export const virtualCardUndefinedResponse: PlatformApiResponse = deepFreeze({ count: 0, data: undefined, offset: 0, -}; +}); diff --git a/src/app/core/mock-data/virtual-cards-combined-request.data.ts b/src/app/core/mock-data/virtual-cards-combined-request.data.ts index a46cd99eea..a14c69f73d 100644 --- a/src/app/core/mock-data/virtual-cards-combined-request.data.ts +++ b/src/app/core/mock-data/virtual-cards-combined-request.data.ts @@ -1,4 +1,6 @@ -export const virtualCardCombinedRequest = { +import deepFreeze from 'deep-freeze-strict'; + +export const virtualCardCombinedRequest = deepFreeze({ virtualCardIds: ['vcgNQmrZvGhL'], includeCurrentAmount: true, -}; +}); diff --git a/src/app/core/mock-data/virtual-select-option.data.ts b/src/app/core/mock-data/virtual-select-option.data.ts index 3f170655f8..9f1a522976 100644 --- a/src/app/core/mock-data/virtual-select-option.data.ts +++ b/src/app/core/mock-data/virtual-select-option.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { VirtualSelectOption } from 'src/app/shared/components/virtual-select/virtual-select-modal/virtual-select-option.interface'; -export const virtualSelectOptionData: VirtualSelectOption = { +export const virtualSelectOptionData: VirtualSelectOption = deepFreeze({ label: 'Airlines', value: { code: null, @@ -15,9 +17,9 @@ export const virtualSelectOptionData: VirtualSelectOption = { updated_at: '2023-07-20T09:58:39.922648+00:00', }, selected: false, -}; +}); -export const virtualSelectOptionData2: VirtualSelectOption = { +export const virtualSelectOptionData2: VirtualSelectOption = deepFreeze({ label: 'Mail', value: { code: null, @@ -32,9 +34,9 @@ export const virtualSelectOptionData2: VirtualSelectOption = { updated_at: '2023-07-20T09:58:39.922648+00:00', }, selected: false, -}; +}); -export const virtualSelectOptionData3: VirtualSelectOption = { +export const virtualSelectOptionData3: VirtualSelectOption = deepFreeze({ label: 'Train', value: { code: null, @@ -49,30 +51,33 @@ export const virtualSelectOptionData3: VirtualSelectOption = { updated_at: '2023-07-20T09:58:39.922648+00:00', }, selected: false, -}; +}); -export const virtualSelectOptionData4: VirtualSelectOption[] = [virtualSelectOptionData, virtualSelectOptionData2]; +export const virtualSelectOptionData4: VirtualSelectOption[] = deepFreeze([ + virtualSelectOptionData, + virtualSelectOptionData2, +]); -export const virtualSelectOptionData5: VirtualSelectOption[] = [ +export const virtualSelectOptionData5: VirtualSelectOption[] = deepFreeze([ { ...virtualSelectOptionData2 }, virtualSelectOptionData3, -]; +]); -export const expectedVirtualSelectOptionData: VirtualSelectOption[] = [ +export const expectedVirtualSelectOptionData: VirtualSelectOption[] = deepFreeze([ { label: 'None', value: null }, virtualSelectOptionData2, -]; +]); -export const expectedSelectableOptionsData: VirtualSelectOption[] = [ +export const expectedSelectableOptionsData: VirtualSelectOption[] = deepFreeze([ { ...virtualSelectOptionData2, isRecentlyUsed: true }, { ...virtualSelectOptionData3, isRecentlyUsed: true }, virtualSelectOptionData, virtualSelectOptionData2, -]; +]); -export const expectedFilteredOptionsData: VirtualSelectOption[] = [ +export const expectedFilteredOptionsData: VirtualSelectOption[] = deepFreeze([ { label: 'None', value: null }, virtualSelectOptionData, virtualSelectOptionData2, { label: 'Train', value: virtualSelectOptionData3, selected: true }, -]; +]); diff --git a/src/app/core/mock-data/yoodle-token.data.ts b/src/app/core/mock-data/yoodle-token.data.ts index ed7a39489c..a9511d07c1 100644 --- a/src/app/core/mock-data/yoodle-token.data.ts +++ b/src/app/core/mock-data/yoodle-token.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { YodleeAccessToken } from '../models/yoodle-token.model'; -export const apiToken: YodleeAccessToken = { +export const apiToken: YodleeAccessToken = deepFreeze({ access_token: 'bMWGrqpBH4ZEamNIh1VKSOvJBzvG', fast_link_url: 'https://fl4.preprod.yodlee.com/authenticate/development-448/fastlink/?channelAppName=tieredpreprod', -}; +}); diff --git a/src/app/core/models/card-details-combined-response.model.ts b/src/app/core/models/card-details-combined-response.model.ts index a17609c26d..6ea57d5d49 100644 --- a/src/app/core/models/card-details-combined-response.model.ts +++ b/src/app/core/models/card-details-combined-response.model.ts @@ -1,7 +1,7 @@ export interface CardDetailsCombinedResponse { full_card_number: string; cvv: string; - expiry_date: Date; + expiry_date: Date | string; nick_name?: string; current_amount?: number; } diff --git a/src/app/core/models/card-details-response.model.ts b/src/app/core/models/card-details-response.model.ts index 8975bd1321..67f0c7f150 100644 --- a/src/app/core/models/card-details-response.model.ts +++ b/src/app/core/models/card-details-response.model.ts @@ -1,5 +1,5 @@ export interface CardDetailsResponse { full_card_number: string; cvv: string; - expiry_date: Date; + expiry_date: Date | string; } diff --git a/src/app/core/services/advance-request.service.spec.ts b/src/app/core/services/advance-request.service.spec.ts index 502907c65c..1a81496382 100644 --- a/src/app/core/services/advance-request.service.spec.ts +++ b/src/app/core/services/advance-request.service.spec.ts @@ -461,16 +461,16 @@ describe('AdvanceRequestService', () => { describe('fixDates():', () => { it('should convert string values to dates', () => { + const mockAdvanceReqData = cloneDeep(extendedAdvReqWithoutDates); //@ts-ignore - expect(advanceRequestService.fixDates(extendedAdvReqWithoutDates)).toEqual(extendedAdvReqWithDates); + expect(advanceRequestService.fixDates(mockAdvanceReqData)).toEqual(extendedAdvReqWithDates); }); }); it('fixDatesForPlatformFields(): should convert string values to dates', () => { + const mockAdvanceReqData = cloneDeep(advanceRequestPlatform.data[0]); //@ts-ignore - expect(advanceRequestService.fixDatesForPlatformFields(advanceRequestPlatform.data[0])).toEqual( - advanceRequestPlatform.data[0] - ); + expect(advanceRequestService.fixDatesForPlatformFields(mockAdvanceReqData)).toEqual(advanceRequestPlatform.data[0]); }); it('getEReq(): should get advance request', (done) => { @@ -532,10 +532,11 @@ describe('AdvanceRequestService', () => { fileService.post.and.returnValue(of(fileObjectData3)); spyOn(advanceRequestService, 'submit').and.returnValue(of(advanceRequests)); - advanceRequestService.createAdvReqWithFilesAndSubmit(advanceRequests, of(fileData1)).subscribe((res) => { + const mockFileObject = cloneDeep(fileData1); + advanceRequestService.createAdvReqWithFilesAndSubmit(advanceRequests, of(mockFileObject)).subscribe((res) => { expect(res).toEqual(advRequestFile); expect(advanceRequestService.submit).toHaveBeenCalledOnceWith(advanceRequests); - expect(fileService.post).toHaveBeenCalledOnceWith(fileData1[0]); + expect(fileService.post).toHaveBeenCalledOnceWith(mockFileObject[0]); done(); }); }); @@ -556,10 +557,11 @@ describe('AdvanceRequestService', () => { fileService.post.and.returnValue(of(fileObjectData4)); spyOn(advanceRequestService, 'saveDraft').and.returnValue(of(advancedRequests2)); - advanceRequestService.saveDraftAdvReqWithFiles(advancedRequests2, of(fileData2)).subscribe((res) => { + const mockFileObject = cloneDeep(fileData2); + advanceRequestService.saveDraftAdvReqWithFiles(advancedRequests2, of(mockFileObject)).subscribe((res) => { expect(res).toEqual(advRequestFile2); expect(advanceRequestService.saveDraft).toHaveBeenCalledOnceWith(advancedRequests2); - expect(fileService.post).toHaveBeenCalledOnceWith(fileData2[0]); + expect(fileService.post).toHaveBeenCalledOnceWith(mockFileObject[0]); done(); }); }); @@ -592,11 +594,15 @@ describe('AdvanceRequestService', () => { describe('modifyAdvanceRequestCustomFields():', () => { it('should modify advance request custom fields', () => { - expect(advanceRequestService.modifyAdvanceRequestCustomFields(customFields)).toEqual(expectedCustomFieldsWoDate); + const mockCustomFields = cloneDeep(customFields); + expect(advanceRequestService.modifyAdvanceRequestCustomFields(mockCustomFields)).toEqual( + expectedCustomFieldsWoDate + ); }); it('should modify custom fields with date value', () => { - expect(advanceRequestService.modifyAdvanceRequestCustomFields(customField2)).toEqual( + const mockCustomFields = cloneDeep(customField2); + expect(advanceRequestService.modifyAdvanceRequestCustomFields(mockCustomFields)).toEqual( expectedCustomFieldsWithDate ); }); @@ -728,6 +734,7 @@ describe('AdvanceRequestService', () => { done(); }); }); + it('should get all advance request with default params', (done) => { spenderService.get.and.returnValue(of(advanceRequestPlatform)); @@ -747,8 +754,9 @@ describe('AdvanceRequestService', () => { describe('getMyadvanceRequests():', () => { it('should get all advance request', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); - apiv2Service.get.and.returnValue(of(allAdvanceRequestsRes)); + authService.getEou.and.resolveTo(apiEouRes); + const mockApiV2Res = cloneDeep(allAdvanceRequestsRes); + apiv2Service.get.and.returnValue(of(mockApiV2Res)); const param = { offset: 0, @@ -760,7 +768,7 @@ describe('AdvanceRequestService', () => { }; advanceRequestService.getMyadvanceRequests(param).subscribe((res) => { - expect(res).toEqual(allAdvanceRequestsRes); + expect(res).toEqual(mockApiV2Res); expect(apiv2Service.get).toHaveBeenCalledOnceWith('/advance_requests', { params: { offset: param.offset, @@ -773,12 +781,14 @@ describe('AdvanceRequestService', () => { done(); }); }); + it('should get all advance request with default params', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); - apiv2Service.get.and.returnValue(of(allAdvanceRequestsRes)); + authService.getEou.and.resolveTo(apiEouRes); + const mockApiV2Res = cloneDeep(allAdvanceRequestsRes); + apiv2Service.get.and.returnValue(of(mockApiV2Res)); advanceRequestService.getMyadvanceRequests().subscribe((res) => { - expect(res).toEqual(allAdvanceRequestsRes); + expect(res).toEqual(mockApiV2Res); expect(apiv2Service.get).toHaveBeenCalledOnceWith('/advance_requests', { params: { offset: 0, @@ -827,8 +837,9 @@ describe('AdvanceRequestService', () => { describe('getTeamAdvanceRequests():', () => { it('should get all team advance requests | APPROVAL PENDING AND APPROVED', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); - apiv2Service.get.and.returnValue(of(allTeamAdvanceRequestsRes)); + authService.getEou.and.resolveTo(apiEouRes); + const mockApiV2Res = cloneDeep(allTeamAdvanceRequestsRes); + apiv2Service.get.and.returnValue(of(mockApiV2Res)); const params = { offset: 0, @@ -849,7 +860,7 @@ describe('AdvanceRequestService', () => { }; advanceRequestService.getTeamAdvanceRequests(params).subscribe((res) => { - expect(res).toEqual(allTeamAdvanceRequestsRes); + expect(res).toEqual(mockApiV2Res); expect(apiv2Service.get).toHaveBeenCalledOnceWith('/advance_requests', { params: { offset: params.offset, @@ -866,8 +877,9 @@ describe('AdvanceRequestService', () => { }); it('should get all team advance requests | APPROVAL PENDING', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); - apiv2Service.get.and.returnValue(of(allTeamAdvanceRequestsRes)); + authService.getEou.and.resolveTo(apiEouRes); + const mockApiV2Res = cloneDeep(allTeamAdvanceRequestsRes); + apiv2Service.get.and.returnValue(of(mockApiV2Res)); const params = { offset: 0, @@ -888,7 +900,7 @@ describe('AdvanceRequestService', () => { }; advanceRequestService.getTeamAdvanceRequests(params).subscribe((res) => { - expect(res).toEqual(allTeamAdvanceRequestsRes); + expect(res).toEqual(mockApiV2Res); expect(apiv2Service.get).toHaveBeenCalledOnceWith('/advance_requests', { params: { offset: params.offset, @@ -905,8 +917,9 @@ describe('AdvanceRequestService', () => { }); it('should get all team advance requests | APPROVED', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); - apiv2Service.get.and.returnValue(of(allTeamAdvanceRequestsRes)); + authService.getEou.and.resolveTo(apiEouRes); + const mockApiV2Res = cloneDeep(allTeamAdvanceRequestsRes); + apiv2Service.get.and.returnValue(of(mockApiV2Res)); const params = { offset: 0, @@ -927,7 +940,7 @@ describe('AdvanceRequestService', () => { }; advanceRequestService.getTeamAdvanceRequests(params).subscribe((res) => { - expect(res).toEqual(allTeamAdvanceRequestsRes); + expect(res).toEqual(mockApiV2Res); expect(apiv2Service.get).toHaveBeenCalledOnceWith('/advance_requests', { params: { offset: params.offset, diff --git a/src/app/core/services/advance.service.spec.ts b/src/app/core/services/advance.service.spec.ts index 9928262776..0c2fc4fc66 100644 --- a/src/app/core/services/advance.service.spec.ts +++ b/src/app/core/services/advance.service.spec.ts @@ -9,6 +9,7 @@ import { apiEouRes } from '../mock-data/extended-org-user.data'; import { of } from 'rxjs'; import { SpenderService } from './platform/v1/spender/spender.service'; import { advancePlatform } from '../mock-data/advance-platform.data'; +import { cloneDeep } from 'lodash'; describe('AdvanceService', () => { let advanceService: AdvanceService; @@ -59,8 +60,9 @@ describe('AdvanceService', () => { }); it('fixDates(): should convert string values to dates', () => { + const mockExtendedAdvData = cloneDeep(extendedAdvWithoutDates); //@ts-ignore - expect(advanceService.fixDates(extendedAdvWithoutDates)).toEqual(extendedAdvWithDates); + expect(advanceService.fixDates(mockExtendedAdvData)).toEqual(extendedAdvWithDates); }); describe('getSpenderAdvances():', () => { diff --git a/src/app/core/services/categories.service.spec.ts b/src/app/core/services/categories.service.spec.ts index cf2350a90d..29365f7a00 100644 --- a/src/app/core/services/categories.service.spec.ts +++ b/src/app/core/services/categories.service.spec.ts @@ -31,6 +31,7 @@ import { displayOrgCategoriesByName, expectedOrgCategoryByName, } from '../mock-data/org-category.data'; +import { cloneDeep } from 'lodash'; describe('CategoriesService', () => { let categoriesService: CategoriesService; @@ -133,7 +134,8 @@ describe('CategoriesService', () => { }); it('addDisplayName(): should modify display name', () => { - expect(categoriesService.addDisplayName(orgCategoryWoDisplayName)).toEqual(orgCategoryWithDisplayName); + const mockCategory = cloneDeep(orgCategoryWoDisplayName); + expect(categoriesService.addDisplayName(mockCategory)).toEqual(orgCategoryWithDisplayName); }); it('filterByOrgCategoryId(): should filter a category by ID', () => { @@ -146,11 +148,13 @@ describe('CategoriesService', () => { describe('sortCategories():', () => { it('should sort categories', () => { - expect(categoriesService.sortCategories(transformedOrgCategories)).toEqual(sortedCategory); + const mockCategories = cloneDeep(transformedOrgCategories); + expect(categoriesService.sortCategories(mockCategories)).toEqual(sortedCategory); }); it('should sort categories when categories and sub-categories are same', () => { - expect(categoriesService.sortCategories(unsortedCategories1)).toEqual(sortedCategories1); + const mockCategories = cloneDeep(unsortedCategories1); + expect(categoriesService.sortCategories(mockCategories)).toEqual(sortedCategories1); }); }); diff --git a/src/app/core/services/corporate-credit-card-expense.service.spec.ts b/src/app/core/services/corporate-credit-card-expense.service.spec.ts index 0e631cbfbe..b6b41c6128 100644 --- a/src/app/core/services/corporate-credit-card-expense.service.spec.ts +++ b/src/app/core/services/corporate-credit-card-expense.service.spec.ts @@ -6,7 +6,7 @@ import { SpenderPlatformV1ApiService } from './spender-platform-v1-api.service'; import { AuthService } from './auth.service'; import { CorporateCreditCardExpenseService } from './corporate-credit-card-expense.service'; import { DataTransformService } from './data-transform.service'; -import { apiCardV2Transactions } from '../mock-data/ccc-api-response'; +import { apiCardV2Transactions } from '../mock-data/ccc-api-response.data'; import { expectedECccResponse } from '../mock-data/corporate-card-expense-unflattened.data'; import { uniqueCardsParam } from '../mock-data/unique-cards.data'; import { cardAggregateStatParam } from '../mock-data/card-aggregate-stats.data'; diff --git a/src/app/core/services/custom-fields.service.spec.ts b/src/app/core/services/custom-fields.service.spec.ts index e44f62bbdd..2e9db98db7 100644 --- a/src/app/core/services/custom-fields.service.spec.ts +++ b/src/app/core/services/custom-fields.service.spec.ts @@ -9,6 +9,7 @@ import { import { customInputData, platformApiResponse } from '../test-data/custom-inputs.spec.data'; import { CustomFieldsService } from './custom-fields.service'; +import { cloneDeep } from 'lodash'; describe('CustomFieldsService', () => { let customFieldsService: CustomFieldsService; @@ -41,22 +42,26 @@ describe('CustomFieldsService', () => { describe('setDefaultValue():', () => { it('should set default value to false for boolean type', () => { - const result = customFieldsService.setDefaultValue(txnCustomPropertiesData3[0], 'BOOLEAN'); - expect(result.value).toBe(false); + const mockTxnCustomProperties = cloneDeep(txnCustomPropertiesData3[0]); + const result = customFieldsService.setDefaultValue(mockTxnCustomProperties, 'BOOLEAN'); + expect(result.value).toBeFalse(); }); it('should set default value to empty string for select type', () => { - const result = customFieldsService.setDefaultValue(txnCustomPropertiesData3[1], 'SELECT'); + const mockTxnCustomProperties = cloneDeep(txnCustomPropertiesData3[1]); + const result = customFieldsService.setDefaultValue(mockTxnCustomProperties, 'SELECT'); expect(result.value).toBe(''); }); it('should set default value to empty string for multi select type', () => { - const result = customFieldsService.setDefaultValue(txnCustomPropertiesData[2], 'MULTI_SELECT'); + const mockTxnCustomProperties = cloneDeep(txnCustomPropertiesData3[2]); + const result = customFieldsService.setDefaultValue(mockTxnCustomProperties, 'MULTI_SELECT'); expect(result.value).toBe(''); }); it('should set default value to empty string for user select type', () => { - const result = customFieldsService.setDefaultValue(txnCustomPropertiesData[0], 'USER_LIST'); + const mockTxnCustomProperties = cloneDeep(txnCustomPropertiesData[0]); + const result = customFieldsService.setDefaultValue(mockTxnCustomProperties, 'USER_LIST'); expect(result.value).toEqual([]); }); }); diff --git a/src/app/core/services/date.service.spec.ts b/src/app/core/services/date.service.spec.ts index b01cce04d3..cf2961e769 100644 --- a/src/app/core/services/date.service.spec.ts +++ b/src/app/core/services/date.service.spec.ts @@ -24,11 +24,11 @@ describe('DateService', () => { }); it('firstOfThisMonth(): get the first day of the month', () => { - expect(dateService.firstOfThisMonth()).toEqual(new Date(year, month, 1)); + expect(dateService.firstOfThisMonth().toDateString()).toEqual(new Date(year, month, 1).toDateString()); }); it('lastOfThisMonth(): get the last day of the month', () => { - expect(dateService.lastOfThisMonth()).toEqual(new Date(year, month + 1, 0, 23, 59)); + expect(dateService.lastOfThisMonth().toDateString()).toEqual(new Date(year, month + 1, 0, 23, 59).toDateString()); }); it('isValidDate(): check if date is valid', () => { @@ -60,11 +60,11 @@ describe('DateService', () => { }); it('firstOfLastMonth(): should get the first of last month', () => { - expect(dateService.firstOfLastMonth()).toEqual(new Date(year, month - 1, 1)); + expect(dateService.firstOfLastMonth().toDateString()).toEqual(new Date(year, month - 1, 1).toDateString()); }); it('lastOfLastMonth(): should get the last of last month', () => { - expect(dateService.lastOfLastMonth()).toEqual(new Date(year, month, 0, 23, 59)); + expect(dateService.lastOfLastMonth().toDateString()).toEqual(new Date(year, month, 0, 23, 59).toDateString()); }); it("getLastMonthRange(): should get last month's range", () => { diff --git a/src/app/core/services/dependent-fields.service.spec.ts b/src/app/core/services/dependent-fields.service.spec.ts index 9befd32cf5..df87cd6712 100644 --- a/src/app/core/services/dependent-fields.service.spec.ts +++ b/src/app/core/services/dependent-fields.service.spec.ts @@ -16,6 +16,7 @@ import { import { DependentFieldsService } from './dependent-fields.service'; import { SpenderPlatformV1ApiService } from './spender-platform-v1-api.service'; import { CustomInputsService } from './custom-inputs.service'; +import { cloneDeep } from 'lodash'; describe('DependentFieldsService', () => { let dependentFieldsService: DependentFieldsService; @@ -82,7 +83,8 @@ describe('DependentFieldsService', () => { describe('getDependentFieldsForBaseField(): ', () => { it('should return the dependent expense fields for the parent field', () => { const parentFieldId = 219175; - customInputsService.getAll.and.returnValue(of(customExpenseFields)); + const mockCustomExpenseFields = cloneDeep(customExpenseFields); + customInputsService.getAll.and.returnValue(of(mockCustomExpenseFields)); dependentFieldsService.getDependentFieldsForBaseField(parentFieldId).subscribe((res) => { expect(res).toEqual(dependentExpenseFields); @@ -93,11 +95,13 @@ describe('DependentFieldsService', () => { describe('getDependentFieldValuesForBaseField(): ', () => { it('should return the dependent field values for parent field and txn custom properties', () => { const parentFieldId = 219175; - customInputsService.getAll.and.returnValue(of(customExpenseFields)); + const mockCustomExpenseFields = cloneDeep(customExpenseFields); + customInputsService.getAll.and.returnValue(of(mockCustomExpenseFields)); spyOn(dependentFieldsService, 'getDependentFieldsForBaseField').and.returnValue(of(dependentExpenseFields)); + const mockTxnCustomProperties = cloneDeep(txnCustomProperties); dependentFieldsService - .getDependentFieldValuesForBaseField(txnCustomProperties, parentFieldId) + .getDependentFieldValuesForBaseField(mockTxnCustomProperties, parentFieldId) .subscribe((res) => { expect(res).toEqual(dependentFieldValues); }); diff --git a/src/app/core/services/expense-fields.service.spec.ts b/src/app/core/services/expense-fields.service.spec.ts index bdd8c9cc81..dece8e2e40 100644 --- a/src/app/core/services/expense-fields.service.spec.ts +++ b/src/app/core/services/expense-fields.service.spec.ts @@ -19,6 +19,7 @@ import { SpenderPlatformV1ApiService } from './spender-platform-v1-api.service'; import { AuthService } from './auth.service'; import { ExpenseFieldsService } from './expense-fields.service'; +import { cloneDeep } from 'lodash'; describe('ExpenseFieldsService', () => { let expenseFieldsService: ExpenseFieldsService; @@ -84,8 +85,9 @@ describe('ExpenseFieldsService', () => { it('filterbyCategory(): should filter expense fields by category', (done) => { const fields = ['purpose', 'txn_dt', 'vendor_id', 'org_category_id']; + const mockExpenseFieldsMapResponse = cloneDeep(expenseFieldsMapResponse); expenseFieldsService - .filterByOrgCategoryId(expenseFieldsMapResponse, fields, orgCategoryData) + .filterByOrgCategoryId(mockExpenseFieldsMapResponse, fields, orgCategoryData) .subscribe((expenseFields) => { expect(expenseFields).toEqual(expenseFieldObjData); done(); diff --git a/src/app/core/services/file.service.spec.ts b/src/app/core/services/file.service.spec.ts index 551911ecf4..7e6eadb746 100644 --- a/src/app/core/services/file.service.spec.ts +++ b/src/app/core/services/file.service.spec.ts @@ -5,6 +5,7 @@ import { ApiService } from './api.service'; import { DateService } from './date.service'; import { FileService } from './file.service'; +import { cloneDeep } from 'lodash'; describe('FileService', () => { let fileService: FileService; @@ -118,7 +119,7 @@ describe('FileService', () => { describe('setFileType():', () => { it('should set the file type', () => { spyOn(fileService, 'getFileExtension').and.returnValue('jpeg'); - const file = fileObjectAdv[0]; + const file = cloneDeep(fileObjectAdv[0]); const fileWithFileType = fileService.setFileType(file); expect(fileWithFileType.file_type).toEqual('image'); expect(fileService.getFileExtension).toHaveBeenCalledOnceWith(file.name); @@ -126,7 +127,7 @@ describe('FileService', () => { it('should set the file pdf type', () => { spyOn(fileService, 'getFileExtension').and.returnValue('pdf'); - const file = fileObjectAdv1; + const file = cloneDeep(fileObjectAdv1); const fileWithFileType = fileService.setFileType(file); expect(fileWithFileType.file_type).toEqual('pdf'); expect(fileService.getFileExtension).toHaveBeenCalledOnceWith(file.name); diff --git a/src/app/core/services/location.service.spec.ts b/src/app/core/services/location.service.spec.ts index fee47c6bcd..74bdd84cf3 100644 --- a/src/app/core/services/location.service.spec.ts +++ b/src/app/core/services/location.service.spec.ts @@ -4,6 +4,7 @@ import { of, delay } from 'rxjs'; import { LocationService } from './location.service'; import { locationData1, locationData2, locationData4, predictedLocation1 } from '../mock-data/location.data'; import { HttpParams } from '@angular/common/http'; +import { cloneDeep } from 'lodash'; describe('LocationService', () => { let locationService: LocationService; @@ -101,7 +102,7 @@ describe('LocationService', () => { it('should return location details with display name if displayName is provided', () => { const placeId = 'pLcId123'; const displayName = 'Tollygunge, Kolkata, West Bengal, India'; - const locationDetails = locationData1; + const locationDetails = cloneDeep(locationData1); locationService.getGeocode(placeId, displayName).subscribe((result) => { expect(result).toEqual(locationDetails); }); @@ -114,7 +115,7 @@ describe('LocationService', () => { it('should not add the displayName to locationDetails when displayName is not provided', () => { const placeId = '12345'; const displayName = ''; - const locationDetails = locationData4; + const locationDetails = cloneDeep(locationData4); locationService.getGeocode(placeId, displayName).subscribe((result) => { expect(result).toEqual(locationDetails); }); diff --git a/src/app/core/services/merge-expenses.service.spec.ts b/src/app/core/services/merge-expenses.service.spec.ts index b71ad8c355..38f2b9a759 100644 --- a/src/app/core/services/merge-expenses.service.spec.ts +++ b/src/app/core/services/merge-expenses.service.spec.ts @@ -96,6 +96,7 @@ import { customInputData } from '../test-data/custom-inputs.spec.data'; import * as dayjs from 'dayjs'; import { expectedOrgCategoryByName2, orgCategoryData1 } from '../mock-data/org-category.data'; import { taxGroupData } from '../mock-data/tax-group.data'; +import { cloneDeep } from 'lodash'; describe('MergeExpensesService', () => { let mergeExpensesService: MergeExpensesService; @@ -371,19 +372,20 @@ describe('MergeExpensesService', () => { }); it('getAttachements(): should return the attachments', (done) => { - fileService.findByTransactionId.and.returnValue(of(fileObject5)); + const mockFileObject = cloneDeep(fileObject5); + fileService.findByTransactionId.and.returnValue(of(mockFileObject)); fileService.downloadUrl.and.returnValue(of('mock-url')); fileService.getReceiptsDetails.and.returnValue({ - thumbnail: fileObject5[0].thumbnail, - type: fileObject5[0].type, + thumbnail: mockFileObject[0].thumbnail, + type: mockFileObject[0].type, }); const transactionId = 'txz2vohKxBXu'; mergeExpensesService.getAttachements(transactionId).subscribe((res) => { - expect(res).toEqual(fileObject5); + expect(res).toEqual(mockFileObject); expect(fileService.findByTransactionId).toHaveBeenCalledOnceWith(transactionId); - expect(fileService.downloadUrl).toHaveBeenCalledOnceWith(fileObject5[0].id); - expect(fileService.getReceiptsDetails).toHaveBeenCalledOnceWith(fileObject5[0].name, 'mock-url'); + expect(fileService.downloadUrl).toHaveBeenCalledOnceWith(mockFileObject[0].id); + expect(fileService.getReceiptsDetails).toHaveBeenCalledOnceWith(mockFileObject[0].name, 'mock-url'); done(); }); }); @@ -405,17 +407,19 @@ describe('MergeExpensesService', () => { describe('formatProjectOptions():', () => { it('should return the project options', (done) => { projectService.getAllActive.and.returnValue(of(projectsV1Data)); + const mockProjectOptions = cloneDeep(projectOptionsData); // @ts-ignore - mergeExpensesService.formatProjectOptions(projectOptionsData).subscribe((res) => { - expect(res).toEqual(projectOptionsData); + mergeExpensesService.formatProjectOptions(mockProjectOptions).subscribe((res) => { + expect(res).toEqual(mockProjectOptions); done(); }); }); it('should return the project options with label as project name if id matches with option', (done) => { projectService.getAllActive.and.returnValue(of(projectsV1Data)); + const mockProjectOptions = cloneDeep(projectOptionsData); // @ts-ignore - mergeExpensesService.formatProjectOptions({ ...projectOptionsData, value: 257528 }).subscribe((res) => { + mergeExpensesService.formatProjectOptions({ ...mockProjectOptions, value: 257528 }).subscribe((res) => { expect(res).toEqual({ label: 'Customer Mapped Project', value: 257528 }); done(); }); @@ -838,7 +842,7 @@ describe('MergeExpensesService', () => { categoriesService.getAll.and.returnValue(of(orgCategoryData1)); const categoryId = '201951'; mergeExpensesService.getCategoryName(categoryId).subscribe((res) => { - expect(res).toEqual(undefined); + expect(res).toBeUndefined(); expect(categoriesService.getAll).toHaveBeenCalledTimes(1); }); }); @@ -847,7 +851,7 @@ describe('MergeExpensesService', () => { categoriesService.getAll.and.returnValue(of([expectedOrgCategoryByName2])); const categoryId = '201951'; mergeExpensesService.getCategoryName(categoryId).subscribe((res) => { - expect(res).toEqual(undefined); + expect(res).toBeUndefined(); expect(categoriesService.getAll).toHaveBeenCalledTimes(1); }); }); @@ -901,8 +905,9 @@ describe('MergeExpensesService', () => { describe('formatTaxGroupOption():', () => { it('formatTaxGroupOption(): should return the formatted tax group option', (done) => { taxGroupService.get.and.returnValue(of(taxGroupData)); + const mockOptions = cloneDeep(optionsData11.options[0]); // @ts-ignore - mergeExpensesService.formatTaxGroupOption(optionsData11.options[0]).subscribe((res) => { + mergeExpensesService.formatTaxGroupOption(mockOptions).subscribe((res) => { expect(res).toEqual(mergeExpensesOptionData5[0]); expect(taxGroupService.get).toHaveBeenCalledTimes(1); done(); @@ -928,71 +933,78 @@ describe('MergeExpensesService', () => { it('should return the formatted custom input options by type with valid date', () => { dateService.isValidDate.and.returnValues(false, true); spyOn(mergeExpensesService, 'setFormattedDate').and.returnValue('Mar 10, 2021'); + const mockOptions = cloneDeep(optionsData22); // @ts-ignore - const res = mergeExpensesService.formatCustomInputOptionsByType(optionsData22); + const res = mergeExpensesService.formatCustomInputOptionsByType(mockOptions); expect(res).toEqual(optionsData23); - expect(dateService.isValidDate).toHaveBeenCalledWith(optionsData22[1].value); + expect(dateService.isValidDate).toHaveBeenCalledWith(mockOptions[1].value as Date); }); it('should return the formatted custom input options by type without date', () => { dateService.isValidDate.and.returnValues(false, false); + const mockOptions = cloneDeep(optionsData24); // @ts-ignore - const res = mergeExpensesService.formatCustomInputOptionsByType(optionsData24); + const res = mergeExpensesService.formatCustomInputOptionsByType(mockOptions); expect(res).toEqual(optionsData25); }); it('should return the formatted custom input options by type with repeated string options', () => { dateService.isValidDate.and.returnValues(false, false); + const mockOptions = cloneDeep(optionsData27); // @ts-ignore - const res = mergeExpensesService.formatCustomInputOptionsByType(optionsData27); + const res = mergeExpensesService.formatCustomInputOptionsByType(mockOptions); expect(res).toEqual(optionsData28); }); it('should return the formatted custom input options by type with repeated number options', () => { dateService.isValidDate.and.returnValues(false, false); + const mockOptions = cloneDeep(optionsData29); // @ts-ignore - const res = mergeExpensesService.formatCustomInputOptionsByType(optionsData29); + const res = mergeExpensesService.formatCustomInputOptionsByType(mockOptions); expect(res).toEqual(optionsData30); }); it('should return the formatted custom input options by type with repeated select options', () => { dateService.isValidDate.and.returnValues(false, false); + const mockOptions = cloneDeep(optionsData22); // @ts-ignore - const res = mergeExpensesService.formatCustomInputOptionsByType([optionsData22[0], optionsData22[0]]); - expect(res).toEqual([optionsData22[0]]); + const res = mergeExpensesService.formatCustomInputOptionsByType([mockOptions[0], mockOptions[0]]); + expect(res).toEqual([mockOptions[0]]); }); }); describe('formatCustomInputOptions():', () => { it('should return the formatted custom input options', () => { + const mockOptions = cloneDeep(optionsData22); // @ts-ignore - spyOn(mergeExpensesService, 'formatCustomInputOptionsByType').and.returnValue([optionsData22[0]]); + spyOn(mergeExpensesService, 'formatCustomInputOptionsByType').and.returnValue([mockOptions[0]]); // @ts-ignore - const res = mergeExpensesService.formatCustomInputOptions(optionsData22); + const res = mergeExpensesService.formatCustomInputOptions(mockOptions); const expectedRes = { // eslint-disable-next-line quote-props - userlist: optionsData22[0], + userlist: mockOptions[0], }; expect(res).toEqual(expectedRes); // @ts-ignore - expect(mergeExpensesService.formatCustomInputOptionsByType).toHaveBeenCalledWith(optionsData22); + expect(mergeExpensesService.formatCustomInputOptionsByType).toHaveBeenCalledWith(mockOptions); }); it('should return the formatted custom input options without options', () => { + const mockOptions = cloneDeep(optionsData26); // @ts-ignore - spyOn(mergeExpensesService, 'formatCustomInputOptionsByType').and.returnValue([optionsData26[0]]); + spyOn(mergeExpensesService, 'formatCustomInputOptionsByType').and.returnValue([mockOptions[0]]); // @ts-ignore - const res = mergeExpensesService.formatCustomInputOptions(optionsData26); + const res = mergeExpensesService.formatCustomInputOptions(mockOptions); const expectedRes = { // eslint-disable-next-line quote-props numberfield: { options: [], - ...optionsData26[0], + ...mockOptions[0], }, }; expect(res).toEqual(expectedRes); // @ts-ignore - expect(mergeExpensesService.formatCustomInputOptionsByType).toHaveBeenCalledWith(optionsData26); + expect(mergeExpensesService.formatCustomInputOptionsByType).toHaveBeenCalledWith(mockOptions); }); }); @@ -1008,9 +1020,10 @@ describe('MergeExpensesService', () => { }); it('should return the formatted category option', (done) => { + const mockOptions = cloneDeep(mergeExpensesOptionData4[0]); // @ts-ignore - mergeExpensesService.formatCategoryOption(mergeExpensesOptionData4[0]).subscribe((res) => { - expect(res).toEqual(mergeExpensesOptionData4[0]); + mergeExpensesService.formatCategoryOption(mockOptions).subscribe((res) => { + expect(res).toEqual(mockOptions); expect(categoriesService.getAll).toHaveBeenCalledTimes(1); expect(categoriesService.filterRequired).toHaveBeenCalledOnceWith(orgCategoryData1); done(); @@ -1018,8 +1031,9 @@ describe('MergeExpensesService', () => { }); it('should return the formatted category option with label as Unspecified if id does not matches with options', (done) => { + const mockOptions = cloneDeep({ ...mergeExpensesOptionData4[0], value: 201951 }); // @ts-ignore - mergeExpensesService.formatCategoryOption({ ...mergeExpensesOptionData4[0], value: 201951 }).subscribe((res) => { + mergeExpensesService.formatCategoryOption(mockOptions).subscribe((res) => { expect(res).toEqual({ label: 'Unspecified', value: 201951, diff --git a/src/app/core/services/org-settings.service.spec.ts b/src/app/core/services/org-settings.service.spec.ts index ee72ec870c..efc7e942f5 100644 --- a/src/app/core/services/org-settings.service.spec.ts +++ b/src/app/core/services/org-settings.service.spec.ts @@ -26,6 +26,7 @@ import { } from '../test-data/org-settings.service.spec.data'; import { OrgSettingsService } from './org-settings.service'; +import { cloneDeep } from 'lodash'; const getApiData: OrgSettings = orgSettingsGetData; const postApiData: OrgSettingsResponse = orgSettingsPostData; @@ -68,7 +69,8 @@ describe('OrgSettingsService', () => { }); it('should be able to get the org settings properly', (done) => { - apiService.get.and.returnValue(of(postApiData)); + const mockApiResponse = cloneDeep(postApiData); + apiService.get.and.returnValue(of(mockApiResponse)); orgSettingsService.get().subscribe((res) => { expect(res).toEqual(getApiData); done(); @@ -84,9 +86,8 @@ describe('OrgSettingsService', () => { }); it('should be able to get incoming tally account object', () => { - expect(orgSettingsService.getIncomingAccountingObject(outgoingTallyAccountObject)).toEqual( - incomingTallyAccountObject - ); + const mockAccountingObject = cloneDeep(outgoingTallyAccountObject); + expect(orgSettingsService.getIncomingAccountingObject(mockAccountingObject)).toEqual(incomingTallyAccountObject); }); it('should be able to set outgoing tally account object', () => { @@ -96,7 +97,8 @@ describe('OrgSettingsService', () => { }); it('should be able to get incoming quick books account object', () => { - expect(orgSettingsService.getIncomingAccountingObject(outgoingQuickbooksAccountObject)).toEqual( + const mockAccountingObject = cloneDeep(outgoingQuickbooksAccountObject); + expect(orgSettingsService.getIncomingAccountingObject(mockAccountingObject)).toEqual( incomingQuickBooksAccountObject ); }); diff --git a/src/app/core/services/org.service.spec.ts b/src/app/core/services/org.service.spec.ts index 75ba3cb592..f457707502 100644 --- a/src/app/core/services/org.service.spec.ts +++ b/src/app/core/services/org.service.spec.ts @@ -8,6 +8,7 @@ import { ApiService } from './api.service'; import { AuthService } from './auth.service'; import { OrgService } from './org.service'; import { TrackingService } from './tracking.service'; +import { cloneDeep } from 'lodash'; describe('OrgService', () => { let orgService: OrgService; @@ -112,17 +113,19 @@ describe('OrgService', () => { describe('suggestOrgCurrency():', () => { it('should suggest org currency', (done) => { - apiService.get.and.returnValue(of(currencyIpData)); + const mockCurrencyIpData = cloneDeep(currencyIpData); + apiService.get.and.returnValue(of(mockCurrencyIpData)); orgService.suggestOrgCurrency().subscribe((res) => { - expect(res).toEqual(currencyIpData.currency); + expect(res).toEqual(mockCurrencyIpData.currency); expect(apiService.get).toHaveBeenCalledOnceWith('/currency/ip'); done(); }); }); it('should return `USD` if api does not return currency', (done) => { - apiService.get.and.returnValue(of(currencyIpData2)); + const mockCurrencyIpData = cloneDeep(currencyIpData2); + apiService.get.and.returnValue(of(mockCurrencyIpData)); orgService.suggestOrgCurrency().subscribe((res) => { expect(res).toEqual('USD'); @@ -134,14 +137,15 @@ describe('OrgService', () => { it('setCurrencyBasedOnIp(): should set currency based on ip', (done) => { spyOn(orgService, 'suggestOrgCurrency').and.returnValue(of(currencyIpData.currency)); - spyOn(orgService, 'getCurrentOrg').and.returnValue(of(orgData1[0])); - spyOn(orgService, 'updateOrg').and.returnValue(of(orgData1[0])); + const mockOrgData = cloneDeep(orgData1[0]); + spyOn(orgService, 'getCurrentOrg').and.returnValue(of(mockOrgData)); + spyOn(orgService, 'updateOrg').and.returnValue(of(mockOrgData)); orgService.setCurrencyBasedOnIp().subscribe((res) => { - expect(res).toEqual(orgData1[0]); + expect(res).toEqual(mockOrgData); expect(orgService.suggestOrgCurrency).toHaveBeenCalledTimes(1); expect(orgService.getCurrentOrg).toHaveBeenCalledTimes(1); - expect(orgService.updateOrg).toHaveBeenCalledOnceWith(orgData1[0]); + expect(orgService.updateOrg).toHaveBeenCalledOnceWith(mockOrgData); done(); }); }); diff --git a/src/app/core/services/recent-local-storage-items.service.spec.ts b/src/app/core/services/recent-local-storage-items.service.spec.ts index ae6f6d1f98..bff4c7fb2c 100644 --- a/src/app/core/services/recent-local-storage-items.service.spec.ts +++ b/src/app/core/services/recent-local-storage-items.service.spec.ts @@ -9,6 +9,7 @@ import { postRecentItemsRes, } from '../mock-data/recent-local-storage-items.data'; import * as dayjs from 'dayjs'; +import { cloneDeep } from 'lodash'; describe('RecentLocalStorageItemsService', () => { let recentLocalStorageItemsService: RecentLocalStorageItemsService; @@ -71,7 +72,7 @@ describe('RecentLocalStorageItemsService', () => { updatedAt: dayjs().toISOString(), recentItems, }; - storageService.get.and.returnValue(Promise.resolve(cache)); + storageService.get.and.resolveTo(cache); const result = await recentLocalStorageItemsService.get(cacheName); expect(storageService.get).toHaveBeenCalledOnceWith(cacheName); @@ -84,7 +85,7 @@ describe('RecentLocalStorageItemsService', () => { updatedAt: dayjs().diff(5, 'minute').toString(), recentItems: recentLocalStorageItemsRes, }; - storageService.get.and.returnValue(Promise.resolve(outdatedCache)); + storageService.get.and.resolveTo(outdatedCache); const result = await recentLocalStorageItemsService.get(cacheName); expect(storageService.get).toHaveBeenCalledOnceWith(cacheName); expect(result).toEqual([]); @@ -115,40 +116,42 @@ describe('RecentLocalStorageItemsService', () => { describe('post():', () => { it('should maintain and update a cache of recent items in the local storage', async () => { const cacheName = 'mileageSubCategoryName'; - const recentItems = postRecentItemsRes; + const mockPostRecentItemsRes = cloneDeep(postRecentItemsRes); + const recentItems = mockPostRecentItemsRes; const cache = { recentItems, updatedAt: jasmine.any(Date), }; const indexOfItemSpy = spyOn(recentLocalStorageItemsService, 'indexOfItem'); - const getSpy = spyOn(recentLocalStorageItemsService, 'get').and.returnValue(Promise.resolve(postRecentItemsRes)); + const getSpy = spyOn(recentLocalStorageItemsService, 'get').and.resolveTo(mockPostRecentItemsRes); await recentLocalStorageItemsService.post(cacheName, itemsRes, propertyRes); - storageService.set.and.returnValue(Promise.resolve()); + storageService.set.and.resolveTo(); expect(indexOfItemSpy).toHaveBeenCalledOnceWith(recentItems, itemsRes, propertyRes); expect(getSpy).toHaveBeenCalledOnceWith(cacheName); recentLocalStorageItemsService.post(cacheName, itemsRes, propertyRes).then((res) => { - expect(res).toEqual(postRecentItemsRes); + expect(res).toEqual(mockPostRecentItemsRes); }); expect(storageService.set).toHaveBeenCalledOnceWith(cacheName, cache); }); it('should find the index of an item without the property argument', async () => { const cacheName = 'mileageSubCategoryName'; - const recentItems = postRecentItemsRes; + const mockPostRecentItemsRes = cloneDeep(postRecentItemsRes); + const recentItems = mockPostRecentItemsRes; const cache = { recentItems, updatedAt: jasmine.any(Date), }; - const getSpy = spyOn(recentLocalStorageItemsService, 'get').and.returnValue(Promise.resolve(postRecentItemsRes)); + const getSpy = spyOn(recentLocalStorageItemsService, 'get').and.resolveTo(mockPostRecentItemsRes); await recentLocalStorageItemsService.post(cacheName, itemsRes); - storageService.set.and.returnValue(Promise.resolve()); + storageService.set.and.resolveTo(); expect(getSpy).toHaveBeenCalledOnceWith(cacheName); recentLocalStorageItemsService.post(cacheName, itemsRes).then((res) => { - expect(res).toEqual(postRecentItemsRes); + expect(res).toEqual(mockPostRecentItemsRes); }); expect(storageService.set).toHaveBeenCalledOnceWith(cacheName, cache); }); diff --git a/src/app/core/services/report.service.spec.ts b/src/app/core/services/report.service.spec.ts index a6960cd6fc..ba2be279b8 100644 --- a/src/app/core/services/report.service.spec.ts +++ b/src/app/core/services/report.service.spec.ts @@ -73,6 +73,7 @@ import { dataErtpTransformed, apiErptReporDataParam } from '../mock-data/data-tr import { platformReportData } from '../mock-data/platform-report.data'; import { ApproverPlatformApiService } from './approver-platform-api.service'; import { HttpClientTestingModule } from '@angular/common/http/testing'; +import { cloneDeep } from 'lodash'; describe('ReportService', () => { let reportService: ReportService; @@ -269,7 +270,7 @@ describe('ReportService', () => { describe('getMyReports()', () => { it('should get reports from API as specified by params', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); + authService.getEou.and.resolveTo(apiEouRes); apiv2Service.get.and.returnValue(of(apiReportRes)); spyOn(dateService, 'fixDates').and.returnValues( apiReportRes.data[0], @@ -303,7 +304,7 @@ describe('ReportService', () => { }); it('should get reports from API when no order is specified', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); + authService.getEou.and.resolveTo(apiEouRes); apiv2Service.get.and.returnValue(of(apiReportRes)); spyOn(dateService, 'fixDates').and.returnValues( apiReportRes.data[0], @@ -366,7 +367,8 @@ describe('ReportService', () => { it('getERpt(): should get an extended report', (done) => { apiService.get.and.returnValue(of(apiExtendedReportRes[0])); - dataTransformService.unflatten.and.returnValue(unflattenedErptc); + const mockUnflattenedErptc = cloneDeep(unflattenedErptc); + dataTransformService.unflatten.and.returnValue(mockUnflattenedErptc); spyOn(dateService, 'fixDates').and.returnValue(singleERptcFixDatesMock); spyOn(dateService, 'getLocalDate').and.returnValue(new Date('2023-01-21T07:29:01.958Z')); @@ -399,7 +401,7 @@ describe('ReportService', () => { }); it('getReport(): should get the report from API as per report ID given', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); + authService.getEou.and.resolveTo(apiEouRes); spyOn(reportService, 'getMyReports').and.returnValue(of(apiReportSingleRes)); const reportID = 'rpfClhA1lglE'; @@ -437,7 +439,7 @@ describe('ReportService', () => { describe('getTeamReports()', () => { it('should get all team reports', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); + authService.getEou.and.resolveTo(apiEouRes); apiv2Service.get.and.returnValue(of(apiTeamReportPaginated1)); spyOn(dateService, 'fixDates').and.returnValues(apiTeamReportPaginated1.data[0], apiTeamReportPaginated1.data[1]); @@ -467,7 +469,7 @@ describe('ReportService', () => { }); it('should get all team reports when order is not specified', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); + authService.getEou.and.resolveTo(apiEouRes); apiv2Service.get.and.returnValue(of(apiTeamReportPaginated1)); spyOn(dateService, 'fixDates').and.returnValues(apiTeamReportPaginated1.data[0], apiTeamReportPaginated1.data[1]); @@ -613,7 +615,8 @@ describe('ReportService', () => { describe('getReportAutoSubmissionDetails():', () => { it('should get submission details', (done) => { - spenderPlatformV1ApiService.post.and.returnValue(of(apiReportAutoSubmissionDetails)); + const mockApiReportAutoSubmissionDetails = cloneDeep(apiReportAutoSubmissionDetails); + spenderPlatformV1ApiService.post.and.returnValue(of(mockApiReportAutoSubmissionDetails)); reportService.getReportAutoSubmissionDetails().subscribe((res) => { expect(res).toEqual({ @@ -871,7 +874,7 @@ describe('ReportService', () => { it('should get extended reports count', (done) => { networkService.isOnline.and.returnValue(of(true)); apiService.get.and.returnValue(of({ count: 4 })); - storageService.set.and.returnValue(Promise.resolve(null)); + storageService.set.and.resolveTo(null); const apiParam = ['DRAFT', 'APPROVER_PENDING', 'APPROVER_INQUIRY']; @@ -887,7 +890,7 @@ describe('ReportService', () => { it('should return count when device is offline and use storage to give count', (done) => { networkService.isOnline.and.returnValue(of(false)); - storageService.get.and.returnValue(Promise.resolve({ count: 4 })); + storageService.get.and.resolveTo({ count: 4 }); reportService.getPaginatedERptcCount({}).subscribe((res) => { expect(res).toEqual({ count: 4 }); @@ -1026,7 +1029,9 @@ describe('ReportService', () => { }); it('addApprovers(): add approvers to reports', () => { - const res = reportService.addApprovers(addApproverERpts, approversData1); + const mockApproverData = cloneDeep(approversData1); + const mockERpts = cloneDeep(addApproverERpts); + const res = reportService.addApprovers(mockERpts, mockApproverData); expect(res).toEqual(expectedAddedApproverERpts); }); @@ -1057,7 +1062,7 @@ describe('ReportService', () => { describe('getReportStatsData()', () => { it('should get report stats data', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); + authService.getEou.and.resolveTo(apiEouRes); apiv2Service.get.and.returnValue(of(apiReportStatsRawRes)); const params = { @@ -1079,7 +1084,7 @@ describe('ReportService', () => { }); it('should get report stats data when default stats has been set to false', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); + authService.getEou.and.resolveTo(apiEouRes); apiv2Service.get.and.returnValue(of(new StatsResponse(apiReportStatsRawRes))); const params = { @@ -1101,7 +1106,7 @@ describe('ReportService', () => { }); it('getReportStats(): should get report stats', (done) => { - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); + authService.getEou.and.resolveTo(apiEouRes); apiv2Service.get.and.returnValue(of(new StatsResponse(apiReportStatsRes))); reportService.getReportStats(apiReportStatParams).subscribe((res) => { diff --git a/src/app/core/services/status.service.spec.ts b/src/app/core/services/status.service.spec.ts index cd8c87ac73..aaa84be579 100644 --- a/src/app/core/services/status.service.spec.ts +++ b/src/app/core/services/status.service.spec.ts @@ -8,6 +8,7 @@ import { getApiResponse, updateReponseWithFlattenedEStatus, } from '../test-data/status.service.spec.data'; +import { cloneDeep } from 'lodash'; describe('StatusService', () => { let statusService: StatusService; @@ -37,7 +38,8 @@ describe('StatusService', () => { }); it('should find all estatuses', (done) => { - apiService.get.and.returnValue(of(getApiResponse)); + const mockGetApiResponse = cloneDeep(getApiResponse); + apiService.get.and.returnValue(of(mockGetApiResponse)); statusService.find(type, id).subscribe((res) => { expect(res).toEqual(getEstatusApiResponse); @@ -49,18 +51,20 @@ describe('StatusService', () => { apiService.get.and.returnValue(of(null)); statusService.find(type, id).subscribe((res) => { - expect(res).toEqual(undefined); + expect(res).toBeUndefined(); done(); }); }); it('should use status map and update the comments accordingly by adding statuses', () => { - const result = statusService.createStatusMap(apiCommentsResponse, 'reports'); + const mockApiCommentsResponse = cloneDeep(apiCommentsResponse); + const result = statusService.createStatusMap(mockApiCommentsResponse, 'reports'); expect(result).toEqual(updateReponseWithFlattenedEStatus); }); it('should find and return the latest comment', (done) => { - apiService.get.and.returnValue(of(getApiResponse)); + const mockGetApiResponse = cloneDeep(getApiResponse); + apiService.get.and.returnValue(of(mockGetApiResponse)); const result = statusService.findLatestComment(id, type, 'POLICY'); result.subscribe((res) => { diff --git a/src/app/core/services/transaction.service.spec.ts b/src/app/core/services/transaction.service.spec.ts index 92c60e12f2..06308a10f4 100644 --- a/src/app/core/services/transaction.service.spec.ts +++ b/src/app/core/services/transaction.service.spec.ts @@ -58,6 +58,7 @@ import { matchCCCExpenseResponseData, unmatchCCCExpenseResponseData, } from '../mock-data/corporate-card-transaction-response.data'; +import { cloneDeep } from 'lodash'; describe('TransactionService', () => { let transactionService: TransactionService; @@ -249,7 +250,7 @@ describe('TransactionService', () => { it('getDefaultVehicleType(): should get default vehicle type', (done) => { const defaultVehicleType = 'two_wheeler'; - storageService.get.and.returnValue(Promise.resolve(defaultVehicleType)); + storageService.get.and.resolveTo(defaultVehicleType); transactionService.getDefaultVehicleType().subscribe((res) => { expect(res).toEqual(defaultVehicleType); expect(storageService.get).toHaveBeenCalledTimes(1); @@ -317,6 +318,7 @@ describe('TransactionService', () => { beforeEach(() => { spyOn(lodash, 'cloneDeep').and.returnValue(params); }); + it('should return receipt attached params if receipt attached is YES', () => { const filters = { receiptsAttached: 'YES' }; const receiptsAttachedParams = { or: [], tx_num_files: 'gt.0' }; @@ -412,8 +414,9 @@ describe('TransactionService', () => { }); it('fixDates(): should fix dates', () => { + const mockExpenseData = cloneDeep(expenseDataWithDateString); // @ts-ignore - expect(transactionService.fixDates(expenseDataWithDateString)).toEqual(expenseData1); + expect(transactionService.fixDates(mockExpenseData)).toEqual(expenseData1); }); it('getPaymentModeforEtxn(): should return payment mode for etxn', () => { @@ -858,7 +861,7 @@ describe('TransactionService', () => { }); it('getMyExpenses(): should return my expenses with order', (done) => { - authService.getEou.and.returnValue(Promise.resolve(eouRes2)); + authService.getEou.and.resolveTo(eouRes2); apiV2Service.get.and.returnValue(of(expenseV2Data)); dateService.fixDatesV2.and.returnValue(expenseV2Data.data[0]); @@ -891,7 +894,7 @@ describe('TransactionService', () => { }); it('getMyExpenses(): should return my expenses without order using default date order', (done) => { - authService.getEou.and.returnValue(Promise.resolve(eouRes2)); + authService.getEou.and.resolveTo(eouRes2); apiV2Service.get.and.returnValue(of(expenseV2Data)); dateService.fixDatesV2.and.returnValue(expenseV2Data.data[0]); @@ -1201,7 +1204,7 @@ describe('TransactionService', () => { spyOn(transactionService, 'getIsCriticalPolicyViolated').and.returnValue(false); spyOn(transactionService, 'getIsDraft').and.returnValue(false); - expect(transactionService.getReportableExpenses(null)).toEqual(undefined); + expect(transactionService.getReportableExpenses(null)).toBeUndefined(); expect(transactionService.getIsCriticalPolicyViolated).not.toHaveBeenCalled(); expect(transactionService.getIsDraft).not.toHaveBeenCalled(); }); @@ -1231,10 +1234,11 @@ describe('TransactionService', () => { orgUserSettingsService.get.and.returnValue(of(orgUserSettingsData2)); spenderPlatformV1ApiService.post.and.returnValue(of(expensePolicyData)); - transactionService.checkPolicy(platformPolicyExpenseData1).subscribe((res) => { + const mockPlatformExpense = cloneDeep(platformPolicyExpenseData1); + transactionService.checkPolicy(mockPlatformExpense).subscribe((res) => { expect(res).toEqual(expensePolicyData); expect(spenderPlatformV1ApiService.post).toHaveBeenCalledOnceWith('/expenses/check_policies', { - data: platformPolicyExpenseData1, + data: mockPlatformExpense, }); expect(orgUserSettingsService.get).toHaveBeenCalledTimes(1); done(); @@ -1245,7 +1249,8 @@ describe('TransactionService', () => { spyOn(transactionService, 'upsert').and.returnValue(of(txnData2)); fileService.post.and.returnValue(of(fileObjectData2)); - transactionService.createTxnWithFiles(txnData, of(fileObjectData1)).subscribe((res) => { + const mockFileObject = cloneDeep(fileObjectData1); + transactionService.createTxnWithFiles(txnData, of(mockFileObject)).subscribe((res) => { expect(res).toEqual(txnData2); expect(transactionService.upsert).toHaveBeenCalledOnceWith(txnData); expect(fileService.post).toHaveBeenCalledOnceWith(fileObjectData2); @@ -1262,7 +1267,8 @@ describe('TransactionService', () => { apiService.post.and.returnValue(of(txnData4)); utilityService.discardRedundantCharacters.and.returnValue(txnDataPayload); - transactionService.upsert(upsertTxnParam).subscribe((res) => { + const mockUpsertTxnParam = cloneDeep(upsertTxnParam); + transactionService.upsert(mockUpsertTxnParam).subscribe((res) => { expect(res).toEqual(txnData4); expect(apiService.post).toHaveBeenCalledOnceWith('/transactions', txnDataPayload); expect(orgUserSettingsService.get).toHaveBeenCalledTimes(1); diff --git a/src/app/core/services/utility.service.spec.ts b/src/app/core/services/utility.service.spec.ts index 3900d3fa30..459a591973 100644 --- a/src/app/core/services/utility.service.spec.ts +++ b/src/app/core/services/utility.service.spec.ts @@ -12,6 +12,7 @@ import { SortingDirection } from '../models/sorting-direction.model'; import { SortingParam } from '../models/sorting-param.model'; import { UtilityService } from './utility.service'; +import { cloneDeep } from 'lodash'; describe('UtilityService', () => { let utilityService: UtilityService; @@ -36,12 +37,14 @@ describe('UtilityService', () => { describe('refineNestedObject():', () => { it('should return the nested object when the custom field type is number, string etc', () => { - expect(utilityService.refineNestedObject(customFieldData1)).toEqual(customFieldData1); + const mockCustomField = cloneDeep(customFieldData1); + expect(utilityService.refineNestedObject(mockCustomField)).toEqual(customFieldData1); }); it('should return the nested object when the custom field type is select', () => { spyOn(utilityService, 'discardNullChar').and.returnValue('select-1'); - expect(utilityService.refineNestedObject(customFieldData2)).toEqual(customFieldData2); + const mockCustomFieldData = cloneDeep(customFieldData2); + expect(utilityService.refineNestedObject(mockCustomFieldData)).toEqual(customFieldData2); expect(utilityService.discardNullChar).toHaveBeenCalledOnceWith('select-1'); }); }); diff --git a/src/app/core/services/virtual-cards.service.spec.ts b/src/app/core/services/virtual-cards.service.spec.ts index 92f1512845..d84591a7e0 100644 --- a/src/app/core/services/virtual-cards.service.spec.ts +++ b/src/app/core/services/virtual-cards.service.spec.ts @@ -13,6 +13,7 @@ import { virtualCardResponse, virtualCardUndefinedResponse } from '../mock-data/ import { VirtualCardsCombinedRequest } from '../models/virtual-cards-combined-request.model'; import { cardDetailsRes } from '../mock-data/platform-corporate-card-detail.data'; import { virtualCardCombinedRequest } from '../mock-data/virtual-cards-combined-request.data'; +import { cloneDeep } from 'lodash'; describe('VirtualCardsService', () => { let virtualCardsService: VirtualCardsService; @@ -48,9 +49,9 @@ describe('VirtualCardsService', () => { const virtualCardsRequest: VirtualCardsRequest = { id: 'vc1234', }; - const expectedResponse: { data: CardDetailsResponse } = virtualCardDetailsResponse; + const expectedResponse: { data: CardDetailsResponse } = cloneDeep(virtualCardDetailsResponse); expectedResponse.data.expiry_date = new Date(expectedResponse.data.expiry_date); - spenderPlatformV1ApiService.post.and.returnValue(of(virtualCardDetailsResponse)); + spenderPlatformV1ApiService.post.and.returnValue(of(expectedResponse)); virtualCardsService.getCardDetails(virtualCardsRequest).subscribe((res) => { expect(res).toEqual(expectedResponse.data); @@ -108,7 +109,7 @@ describe('VirtualCardsService', () => { spenderPlatformV1ApiService.get.and.returnValue(of(virtualCardUndefinedResponse)); virtualCardsService.getVirtualCard(virtualCardsRequest).subscribe((res) => { - expect(res).toEqual(undefined); + expect(res).toBeUndefined(); done(); }); }); diff --git a/src/app/core/test-data/accounts.service.spec.data.ts b/src/app/core/test-data/accounts.service.spec.data.ts index c7bc8d4711..1cf0bed068 100644 --- a/src/app/core/test-data/accounts.service.spec.data.ts +++ b/src/app/core/test-data/accounts.service.spec.data.ts @@ -1,4 +1,6 @@ /* eslint-disable id-blacklist */ +import deepFreeze from 'deep-freeze-strict'; + import { AccountType } from '../enums/account-type.enum'; import { ExpenseType } from '../enums/expense-type.enum'; import { unflattenedTxn } from '../mock-data/unflattened-expense.data'; @@ -7,7 +9,7 @@ import { ExtendedAccount } from '../models/extended-account.model'; import { OrgSettings } from '../models/org-settings.model'; import { UnflattenedTransaction } from '../models/unflattened-transaction.model'; -export const account1Data = { +export const account1Data = deepFreeze({ acc_id: 'accfziaxbGFVW', acc_created_at: new Date('2018-10-08T07:04:42.753Z'), acc_updated_at: new Date('2022-04-27T08:57:52.221Z'), @@ -31,9 +33,9 @@ export const account1Data = { orig_amount: null, amount: null, advance_id: null, -}; +}); -export const unflattenedAccount1Data = { +export const unflattenedAccount1Data = deepFreeze({ acc: { id: 'accfziaxbGFVW', created_at: new Date('2018-10-08T07:04:42.753Z'), @@ -60,9 +62,9 @@ export const unflattenedAccount1Data = { orig: { currency: null, amount: null }, currency: null, amount: null, -}; +}); -export const account2Data = { +export const account2Data = deepFreeze({ acc_id: 'acct0IxPgGvLa', acc_created_at: new Date('2018-11-05T18:35:59.912Z'), acc_updated_at: new Date('2021-09-29T19:35:23.965Z'), @@ -86,9 +88,9 @@ export const account2Data = { orig_amount: null, amount: 800000, advance_id: 'advT96eCXZtCo', -}; +}); -export const unflattenedAccount2Data = { +export const unflattenedAccount2Data = deepFreeze({ acc: { id: 'acc6mK6CEesGL', created_at: new Date('2018-11-15T06:25:00.402Z'), @@ -126,9 +128,9 @@ export const unflattenedAccount2Data = { }, currency: 'USD', amount: 23213, -}; +}); -export const unflattenedAccount3Data = { +export const unflattenedAccount3Data = deepFreeze({ acc: { id: 'acct0IxPgGvLa', created_at: new Date('2018-11-05T18:35:59.912Z'), @@ -148,9 +150,9 @@ export const unflattenedAccount3Data = { orig: { currency: 'USD', amount: 500 }, currency: 'USD', amount: 800000, -}; +}); -export const unflattenedAccount4Data = { +export const unflattenedAccount4Data = deepFreeze({ acc: { id: 'acct0IxPgGvLa', created_at: new Date('2018-11-05T18:35:59.912Z'), @@ -170,9 +172,9 @@ export const unflattenedAccount4Data = { orig: null, currency: 'USD', amount: 800000, -}; +}); -export const unflattenedTransactionPersonal: UnflattenedTransaction = { +export const unflattenedTransactionPersonal: UnflattenedTransaction = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -339,9 +341,9 @@ export const unflattenedTransactionPersonal: UnflattenedTransaction = { is: { test_call: null, }, -}; +}); -export const paymentModeDataPersonal = { +export const paymentModeDataPersonal = deepFreeze({ acc: { id: 'accZ1IWjhjLyu4', created_at: new Date('2019-01-11T16:41:56.485Z'), @@ -379,9 +381,9 @@ export const paymentModeDataPersonal = { }, currency: null, amount: null, -}; +}); -export const paymentModeDataPersonal2 = { +export const paymentModeDataPersonal2 = deepFreeze({ acc: { id: 'accZ1IWjhjLyu4', created_at: new Date('2019-01-11T16:41:56.485Z'), @@ -419,9 +421,9 @@ export const paymentModeDataPersonal2 = { }, currency: null, amount: null, -}; +}); -export const unflattenedTransactionCCC: UnflattenedTransaction = { +export const unflattenedTransactionCCC: UnflattenedTransaction = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -588,9 +590,9 @@ export const unflattenedTransactionCCC: UnflattenedTransaction = { is: { test_call: null, }, -}; +}); -export const paymentModeDataCCC = { +export const paymentModeDataCCC = deepFreeze({ acc: { id: 'accZ1IWjhjLv4', created_at: new Date('2019-01-11T16:41:56.485Z'), @@ -628,9 +630,9 @@ export const paymentModeDataCCC = { }, currency: null, amount: null, -}; +}); -export const paymentModesData = [ +export const paymentModesData = deepFreeze([ { label: 'Personal Card/Cash', value: { @@ -757,9 +759,9 @@ export const paymentModesData = [ amount: null, }, }, -]; +]); -export const unflattenedTxnWithoutSourceAccountIdData = { +export const unflattenedTxnWithoutSourceAccountIdData = deepFreeze({ tx: { risk_state: null, is_duplicate_expense: null, @@ -927,9 +929,9 @@ export const unflattenedTxnWithoutSourceAccountIdData = { is: { test_call: null, }, -}; +}); -export const paymentModeDataCCCWithoutAccountProperty = { +export const paymentModeDataCCCWithoutAccountProperty = deepFreeze({ acc: { id: 'accZ1IWjhjLv4', created_at: new Date('2019-01-11T16:41:56.485Z'), @@ -965,9 +967,9 @@ export const paymentModeDataCCCWithoutAccountProperty = { }, currency: null, amount: null, -}; +}); -export const paymentModeDataAdvance = { +export const paymentModeDataAdvance = deepFreeze({ acc: { id: 'acc6mK6CEesGL', created_at: new Date('2018-11-15T06:25:00.402Z'), @@ -1005,9 +1007,9 @@ export const paymentModeDataAdvance = { }, currency: 'USD', amount: 23213, -}; +}); -export const paymentModeDataMultipleAdvance = { +export const paymentModeDataMultipleAdvance = deepFreeze({ acc: { id: 'acct0IxPgGvLa', created_at: new Date('2018-11-05T18:35:59.912Z'), @@ -1029,9 +1031,9 @@ export const paymentModeDataMultipleAdvance = { orig: { currency: 'USD', amount: 500 }, currency: 'USD', amount: 800000, -}; +}); -export const paymentModeDataMultipleAdvWithoutOrigAmt = { +export const paymentModeDataMultipleAdvWithoutOrigAmt = deepFreeze({ acc: { id: 'acct0IxPgGvLa', created_at: new Date('2018-11-05T18:35:59.912Z'), @@ -1053,9 +1055,9 @@ export const paymentModeDataMultipleAdvWithoutOrigAmt = { orig: null, currency: 'USD', amount: 800000, -}; +}); -export const multiplePaymentModesData: ExtendedAccount[] = [ +export const multiplePaymentModesData: ExtendedAccount[] = deepFreeze([ { acc: { id: 'accWUsrRlinFb', @@ -1167,9 +1169,9 @@ export const multiplePaymentModesData: ExtendedAccount[] = [ currency: 'USD', amount: 23213, }, -]; +]); -export const multiplePaymentModesWithoutAdvData: ExtendedAccount[] = [ +export const multiplePaymentModesWithoutAdvData: ExtendedAccount[] = deepFreeze([ { acc: { id: 'accWUsrRlinFb', @@ -1244,9 +1246,9 @@ export const multiplePaymentModesWithoutAdvData: ExtendedAccount[] = [ currency: null, amount: null, }, -]; +]); -export const multiplePaymentModesWithoutPersonalAccData: ExtendedAccount[] = [ +export const multiplePaymentModesWithoutPersonalAccData: ExtendedAccount[] = deepFreeze([ { acc: { id: 'accWUsrRlinFb', @@ -1321,9 +1323,9 @@ export const multiplePaymentModesWithoutPersonalAccData: ExtendedAccount[] = [ currency: null, amount: null, }, -]; +]); -export const multiplePaymentModesWithCompanyAccData: ExtendedAccount[] = [ +export const multiplePaymentModesWithCompanyAccData: ExtendedAccount[] = deepFreeze([ { acc: { id: 'accYoo40xd0C1', @@ -1441,9 +1443,9 @@ export const multiplePaymentModesWithCompanyAccData: ExtendedAccount[] = [ currency: null, amount: null, }, -]; +]); -export const multiplePaymentModesWithoutCCCAccData: ExtendedAccount[] = [ +export const multiplePaymentModesWithoutCCCAccData: ExtendedAccount[] = deepFreeze([ { acc: { id: 'accWUsrRlinFb', @@ -1522,9 +1524,9 @@ export const multiplePaymentModesWithoutCCCAccData: ExtendedAccount[] = [ currency: null, amount: null, }, -]; +]); -export const multiplePaymentModesIncPersonalAccData: ExtendedAccount[] = [ +export const multiplePaymentModesIncPersonalAccData: ExtendedAccount[] = deepFreeze([ { acc: { id: 'accWUsrRlinFb', @@ -1603,9 +1605,9 @@ export const multiplePaymentModesIncPersonalAccData: ExtendedAccount[] = [ currency: null, amount: null, }, -]; +]); -export const multipleAdvAccountsData: ExtendedAccount[] = [ +export const multipleAdvAccountsData: ExtendedAccount[] = deepFreeze([ { acc: { id: 'accWUsrRlinFb', @@ -1684,9 +1686,9 @@ export const multipleAdvAccountsData: ExtendedAccount[] = [ currency: 'USD', amount: 23213, }, -]; +]); -export const etxnObjData = { +export const etxnObjData = deepFreeze({ tx: { skip_reimbursement: false, source: 'MOBILE', @@ -1701,9 +1703,9 @@ export const etxnObjData = { org_user_id: 'ouvyOFOSx5bh', }, dataUrls: [], -}; +}); -export const etxnObjWithSourceData = { +export const etxnObjWithSourceData = deepFreeze({ tx: { skip_reimbursement: true, source: 'MOBILE', @@ -1722,9 +1724,9 @@ export const etxnObjWithSourceData = { account_type: AccountType.PERSONAL, account_id: 'accZ1IWjhjLv4', }, -}; +}); -export const etxnObjWithAdvSourceData = { +export const etxnObjWithAdvSourceData = deepFreeze({ tx: { skip_reimbursement: true, source: 'MOBILE', @@ -1743,9 +1745,9 @@ export const etxnObjWithAdvSourceData = { account_type: AccountType.ADVANCE, account_id: 'accYoo40xd0C1', }, -}; +}); -export const orgSettingsData: OrgSettings = { +export const orgSettingsData: OrgSettings = deepFreeze({ org_id: 'orrb8EW1zZsy', mileage: { allowed: true, @@ -2139,9 +2141,9 @@ export const orgSettingsData: OrgSettings = { enabled: true, virtual_card_settings_enabled: true, }, -}; +}); -export const orgSettingsAdvDisabledData: OrgSettings = { +export const orgSettingsAdvDisabledData: OrgSettings = deepFreeze({ org_id: 'orrb8EW1zZsy', mileage: { allowed: true, @@ -2535,9 +2537,9 @@ export const orgSettingsAdvDisabledData: OrgSettings = { enabled: true, virtual_card_settings_enabled: true, }, -}; +}); -export const paymentModesResData = [ +export const paymentModesResData = deepFreeze([ { label: 'Corporate Card', value: { @@ -2706,9 +2708,9 @@ export const paymentModesResData = [ amount: 23213, }, }, -]; +]); -export const paymentModesAccountsData = [ +export const paymentModesAccountsData = deepFreeze([ { acc: { id: 'accWUsrRlinFb', @@ -2820,9 +2822,9 @@ export const paymentModesAccountsData = [ currency: 'USD', amount: 23213, }, -]; +]); -export const accountsData: ExtendedAccount[] = [ +export const accountsData: ExtendedAccount[] = deepFreeze([ { acc: { id: 'acc5APeygFjRd', @@ -2934,26 +2936,26 @@ export const accountsData: ExtendedAccount[] = [ currency: 'INR', amount: 499, }, -]; +]); -export const orgSettingsDataWithoutAdvPro = { +export const orgSettingsDataWithoutAdvPro = deepFreeze({ ...orgSettingsData, advanced_projects: { allowed: true, enabled: true, enable_individual_projects: true, }, -}; +}); -export const orgSettingsWithoutAutofill: OrgSettings = { +export const orgSettingsWithoutAutofill: OrgSettings = deepFreeze({ ...orgSettingsData, org_expense_form_autofills: { allowed: false, enabled: false, }, -}; +}); -export const paymentModesConfig = { +export const paymentModesConfig = deepFreeze({ etxn: unflattenedTxn, orgSettings: { ...orgSettingsData, @@ -2965,4 +2967,4 @@ export const paymentModesConfig = { }, expenseType: ExpenseType.MILEAGE, isPaymentModeConfigurationsEnabled: true, -}; +}); diff --git a/src/app/core/test-data/custom-inputs.spec.data.ts b/src/app/core/test-data/custom-inputs.spec.data.ts index 71f0ca8e8b..ce48677190 100644 --- a/src/app/core/test-data/custom-inputs.spec.data.ts +++ b/src/app/core/test-data/custom-inputs.spec.data.ts @@ -1,7 +1,9 @@ +import deepFreeze from 'deep-freeze-strict'; + import { CustomProperty } from '../models/custom-properties.model'; import { ExpenseField } from '../models/v1/expense-field.model'; -export const platformApiResponse = { +export const platformApiResponse = deepFreeze({ count: 6, data: [ { @@ -168,9 +170,9 @@ export const platformApiResponse = { }, ], offset: 0, -}; +}); -export const authRespone = { +export const authRespone = deepFreeze({ ou: { id: 'ouX8dwsbLCLv', created_at: new Date('2018-02-01T02:32:25.267Z'), @@ -332,9 +334,9 @@ export const authRespone = { customer_id: 'dwcJzfwZCgwkdfG', bank_account_added: true, }, -}; +}); -export const filterTestData: ExpenseField[] = [ +export const filterTestData: ExpenseField[] = deepFreeze([ { id: 200226, created_at: new Date('2022-02-25T05:44:36.169Z'), @@ -1185,9 +1187,9 @@ export const filterTestData: ExpenseField[] = [ 'AUDITOR', ], }, -]; +]); -export const responseAfterAppliedFilter: ExpenseField[] = [ +export const responseAfterAppliedFilter: ExpenseField[] = deepFreeze([ { id: 200227, created_at: new Date('2022-02-25T05:44:59.645Z'), @@ -1836,9 +1838,9 @@ export const responseAfterAppliedFilter: ExpenseField[] = [ 'AUDITOR', ], }, -]; +]); -export const customProperties: CustomProperty[] = [ +export const customProperties: CustomProperty[] = deepFreeze([ { name: 'USer List CF', value: [], @@ -1863,9 +1865,9 @@ export const customProperties: CustomProperty = { +export const dependentFieldValuesApiResponse: PlatformApiResponse = deepFreeze({ count: 2, data: [ { @@ -49,16 +51,16 @@ export const dependentFieldValuesApiResponse: PlatformApiResponse = { - count: 1, - data: [ - { - created_at: '2023-02-23T10:50:56.756648+00:00', - expense_field_id: 219199, - expense_field_value: 'Cost Code 2', - id: 8, - is_enabled: true, - org_id: 'orN6GkZNaD8b', - parent_expense_field_id: 219175, - parent_expense_field_value: 'Project 1', - updated_at: '2023-02-23T10:51:06.155705+00:00', - }, - ], - offset: 0, -}; +export const dependentFieldValuesApiResponseForSearchQuery: PlatformApiResponse = + deepFreeze({ + count: 1, + data: [ + { + created_at: '2023-02-23T10:50:56.756648+00:00', + expense_field_id: 219199, + expense_field_value: 'Cost Code 2', + id: 8, + is_enabled: true, + org_id: 'orN6GkZNaD8b', + parent_expense_field_id: 219175, + parent_expense_field_value: 'Project 1', + updated_at: '2023-02-23T10:51:06.155705+00:00', + }, + ], + offset: 0, + }); -export const customExpenseFields: ExpenseField[] = [ +export const customExpenseFields: ExpenseField[] = deepFreeze([ { id: 219199, code: null, @@ -185,9 +188,9 @@ export const customExpenseFields: ExpenseField[] = [ updated_at: new Date('2023-03-17T12:29:13.566689+00:00'), parent_field_id: null, }, -]; +]); -export const dependentExpenseFields: ExpenseField[] = [ +export const dependentExpenseFields: ExpenseField[] = deepFreeze([ { id: 219199, code: null, @@ -226,9 +229,9 @@ export const dependentExpenseFields: ExpenseField[] = [ updated_at: new Date('2023-02-23T10:45:53.853907+00:00'), parent_field_id: 219199, }, -]; +]); -export const txnCustomProperties: CustomProperty[] = [ +export const txnCustomProperties: CustomProperty[] = deepFreeze([ { name: 'CUSTOM FIELD', value: 'qwwq', @@ -241,9 +244,9 @@ export const txnCustomProperties: CustomProperty[] = [ name: 'Cost Area', value: null, }, -]; +]); -export const dependentFieldValues: CustomProperty[] = [ +export const dependentFieldValues: CustomProperty[] = deepFreeze([ { name: 'Cost Code', value: 'Wow this Works', @@ -252,9 +255,9 @@ export const dependentFieldValues: CustomProperty[] = [ name: 'Cost Area', value: '-', }, -]; +]); -export const txnCustomProperties2: CustomProperty[] = [ +export const txnCustomProperties2: CustomProperty[] = deepFreeze([ { name: 'CUSTOM FIELD', value: 'custom field', @@ -263,4 +266,4 @@ export const txnCustomProperties2: CustomProperty[] = [ name: 'Cost Code', value: 'Wow this Works', }, -]; +]); diff --git a/src/app/core/test-data/org-settings.service.spec.data.ts b/src/app/core/test-data/org-settings.service.spec.data.ts index 5e790afea4..2150e1d4c2 100644 --- a/src/app/core/test-data/org-settings.service.spec.data.ts +++ b/src/app/core/test-data/org-settings.service.spec.data.ts @@ -1,3 +1,5 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AllowedPaymentModes } from '../models/allowed-payment-modes.enum'; import { AccountingExportSettings, @@ -6,7 +8,7 @@ import { OrgSettingsResponse, } from '../models/org-settings.model'; -export const orgSettingsGetData: OrgSettings = { +export const orgSettingsGetData: OrgSettings = deepFreeze({ org_id: 'orNVthTo2Zyo', mileage: { allowed: true, @@ -442,9 +444,9 @@ export const orgSettingsGetData: OrgSettings = { enabled: true, }, pending_cct_expense_restriction: { enabled: true, allowed: true }, -}; +}); -export const orgSettingsPostData: OrgSettingsResponse = { +export const orgSettingsPostData: OrgSettingsResponse = deepFreeze({ org_id: 'orNVthTo2Zyo', project_settings: { allowed: true, @@ -876,23 +878,23 @@ export const orgSettingsPostData: OrgSettingsResponse = { enabled: true, }, pending_cct_expense_restriction: { enabled: true, allowed: true }, -}; +}); -export const orgSettingsAmexFeedDataRequest: OrgSettingsResponse = { +export const orgSettingsAmexFeedDataRequest: OrgSettingsResponse = deepFreeze({ ...orgSettingsPostData, amex_feed_enrollment_settings: null, -}; +}); -export const orgSettingsAmexFeedDataResponse: OrgSettingsResponse = { +export const orgSettingsAmexFeedDataResponse: OrgSettingsResponse = deepFreeze({ ...orgSettingsGetData, amex_feed_enrollment_settings: { allowed: undefined, enabled: undefined, virtual_card_settings_enabled: undefined, }, -}; +}); -export const outgoingTallyAccountObj: AccountingExportSettings = { +export const outgoingTallyAccountObj: AccountingExportSettings = deepFreeze({ allowed: undefined, tally_settings: { enabled: true, @@ -910,9 +912,9 @@ export const outgoingTallyAccountObj: AccountingExportSettings = { blocked_payment_types: [], }, integration_exports_enabled: true, -}; +}); -export const incomingTallyAccoutingObj: IncomingAccountObject = { +export const incomingTallyAccoutingObj: IncomingAccountObject = deepFreeze({ enabled: true, type: 'TALLY', settings: { @@ -931,9 +933,9 @@ export const incomingTallyAccoutingObj: IncomingAccountObject = { blocked_payment_types: [], }, integration_exports_enabled: true, -}; +}); -export const outgoingQuickbooksAccountObj: AccountingExportSettings = { +export const outgoingQuickbooksAccountObj: AccountingExportSettings = deepFreeze({ allowed: undefined, quick_books_settings: { enabled: true, @@ -949,9 +951,9 @@ export const outgoingQuickbooksAccountObj: AccountingExportSettings = { separate_org_user_advance_ledger: true, }, integration_exports_enabled: true, -}; +}); -export const incomingQuickbooksAccoutingObj: IncomingAccountObject = { +export const incomingQuickbooksAccoutingObj: IncomingAccountObject = deepFreeze({ enabled: true, type: 'QUICKBOOKS', settings: { @@ -968,9 +970,9 @@ export const incomingQuickbooksAccoutingObj: IncomingAccountObject = { separate_org_user_advance_ledger: true, }, integration_exports_enabled: true, -}; +}); -export const outgoingAccountSettingsObj: AccountingExportSettings = { +export const outgoingAccountSettingsObj: AccountingExportSettings = deepFreeze({ allowed: undefined, accounting_settings: { enabled: true, @@ -983,9 +985,9 @@ export const outgoingAccountSettingsObj: AccountingExportSettings = { collapse_expenses: true, }, integration_exports_enabled: true, -}; +}); -export const incomingAccountSettingsObj: IncomingAccountObject = { +export const incomingAccountSettingsObj: IncomingAccountObject = deepFreeze({ enabled: true, type: null, settings: { @@ -999,42 +1001,42 @@ export const incomingAccountSettingsObj: IncomingAccountObject = { collapse_expenses: true, }, integration_exports_enabled: true, -}; +}); -export const incomingAccountingObj: IncomingAccountObject = { +export const incomingAccountingObj: IncomingAccountObject = deepFreeze({ enabled: false, type: null, settings: null, integration_exports_enabled: undefined, -}; +}); -export const incomingTallyAccountingObjWithoutSettings: IncomingAccountObject = { +export const incomingTallyAccountingObjWithoutSettings: IncomingAccountObject = deepFreeze({ enabled: false, type: 'TALLY', settings: null, integration_exports_enabled: false, -}; +}); -export const incomingQuickbooksAccountingObjWithoutSettings: IncomingAccountObject = { +export const incomingQuickbooksAccountingObjWithoutSettings: IncomingAccountObject = deepFreeze({ enabled: false, type: 'QUICKBOOKS', settings: null, integration_exports_enabled: false, -}; +}); -export const outgoingAccountingTallyObjWithoutSettings: AccountingExportSettings = { +export const outgoingAccountingTallyObjWithoutSettings: AccountingExportSettings = deepFreeze({ allowed: undefined, integration_exports_enabled: false, tally_settings: {}, -}; +}); -export const outgoingAccountingQuickbooksObjWithoutSettings: AccountingExportSettings = { +export const outgoingAccountingQuickbooksObjWithoutSettings: AccountingExportSettings = deepFreeze({ allowed: undefined, integration_exports_enabled: false, quick_books_settings: {}, -}; +}); -export const orgSettingsData: OrgSettings = { +export const orgSettingsData: OrgSettings = deepFreeze({ org_id: 'orNVthTo2Zyo', mileage: { allowed: true, @@ -1436,4 +1438,4 @@ export const orgSettingsData: OrgSettings = { enabled: true, virtual_card_settings_enabled: true, }, -}; +}); diff --git a/src/app/core/test-data/org-user.service.spec.data.ts b/src/app/core/test-data/org-user.service.spec.data.ts index 3f189ec3c9..93e27242a5 100644 --- a/src/app/core/test-data/org-user.service.spec.data.ts +++ b/src/app/core/test-data/org-user.service.spec.data.ts @@ -1,8 +1,10 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AccessTokenData } from '../models/access-token-data.model'; import { EouApiResponse } from '../models/eou-api-response.model'; import { ExtendedOrgUser } from '../models/extended-org-user.model'; -export const currentEouRes: ExtendedOrgUser = { +export const currentEouRes: ExtendedOrgUser = deepFreeze({ ou: { id: 'ouX8dwsbLCLv', created_at: new Date('2018-02-01T02:32:25.267Z'), @@ -86,9 +88,9 @@ export const currentEouRes: ExtendedOrgUser = { customer_id: 'dwcJzfwZCgwkdfG', bank_account_added: true, }, -}; +}); -export const currentEouUnflatted: EouApiResponse = { +export const currentEouUnflatted: EouApiResponse = deepFreeze({ ou_id: 'ouX8dwsbLCLv', ou_created_at: new Date('2018-02-01T02:32:25.267Z'), ou_org_id: 'orNVthTo2Zyo', @@ -166,9 +168,9 @@ export const currentEouUnflatted: EouApiResponse = { dwolla_customer_id: 'dwcJzfwZCgwkdfG', dwolla_bank_account_added: true, ou_cost_center_ids: [13792, 13793, 13794], -}; +}); -export const employeesRes = { +export const employeesRes = deepFreeze({ count: 95, data: [ { @@ -195,9 +197,9 @@ export const employeesRes = { limit: 5, offset: 0, url: '/v2/spender_employees', -}; +}); -export const employeesParamsRes = { +export const employeesParamsRes = deepFreeze({ count: 929, data: [ { @@ -233,9 +235,9 @@ export const employeesParamsRes = { limit: 20, offset: 0, url: '/v2/spender_employees', -}; +}); -export const eouListWithDisabledUser = [ +export const eouListWithDisabledUser = deepFreeze([ { ou: { id: 'ouwszMqKW1JR', @@ -395,9 +397,9 @@ export const eouListWithDisabledUser = [ bank_account_added: null, }, }, -]; +]); -export const switchToDelegatorParams = { +export const switchToDelegatorParams = deepFreeze({ id: 'ou5qrPJbGfWM', created_at: new Date('2019-06-20T07:33:45.690Z'), org_id: 'orNVthTo2Zyo', @@ -447,9 +449,9 @@ export const switchToDelegatorParams = { default_cost_center_name: null, default_cost_center_code: null, cost_center_ids: [13696, 14018, 13701], -}; +}); -export const extendedOrgUserResponse = { +export const extendedOrgUserResponse = deepFreeze({ ou: { id: 'ou5qrPJbGfWM', created_at: new Date('2019-06-20T07:33:45.690Z'), @@ -533,15 +535,15 @@ export const extendedOrgUserResponse = { customer_id: 'dwcMdzMqqWLD9Ds', bank_account_added: null, }, -}; +}); -export const postUserParam = { +export const postUserParam = deepFreeze({ full_name: 'Dimple', email: 'dimple.kh+321@fyle.in', password: 'Test@1234523456', -}; +}); -export const postUserResponse = { +export const postUserResponse = deepFreeze({ created_at: new Date('2023-01-05T08:44:47.180Z'), email: 'dimple.kh+321@fyle.in', email_verified_at: new Date('2023-01-05T08:46:21.970Z'), @@ -549,9 +551,9 @@ export const postUserResponse = { id: 'usXHGWJ1UXMP', onboarded: false, password: 'Test@1234523456', -}; +}); -export const postOrgUser = { +export const postOrgUser = deepFreeze({ id: 'ou5tyO64Eg0L', created_at: new Date('2021-11-17T02:54:07.855Z'), updated_at: new Date('2023-01-05T08:57:31.543Z'), @@ -583,9 +585,9 @@ export const postOrgUser = { dwolla_customers_metadata_id: null, bank_account_type: null, bank_routing_number: null, -}; +}); -export const accessTokenData: AccessTokenData = { +export const accessTokenData: AccessTokenData = deepFreeze({ allowed_CIDRs: '[]', cluster_domain: '"https://staging.fyle.tech"', exp: 1672915952, @@ -597,9 +599,9 @@ export const accessTokenData: AccessTokenData = { scopes: '[]', user_id: 'usMjLibmye7s', version: '3', -}; +}); -export const accessTokenWithProxyOrgUserId: AccessTokenData = { +export const accessTokenWithProxyOrgUserId: AccessTokenData = deepFreeze({ allowed_CIDRs: '[]', cluster_domain: '"https://staging.fyle.tech"', exp: 1672915952, @@ -612,4 +614,4 @@ export const accessTokenWithProxyOrgUserId: AccessTokenData = { scopes: '[]', user_id: 'usMjLibmye7s', version: '3', -}; +}); diff --git a/src/app/core/test-data/per-diem.service.spec.data.ts b/src/app/core/test-data/per-diem.service.spec.data.ts index 067e490574..14d02449d9 100644 --- a/src/app/core/test-data/per-diem.service.spec.data.ts +++ b/src/app/core/test-data/per-diem.service.spec.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { AccountType } from '../enums/account-type.enum'; -export const apiPerDiemByID = { +export const apiPerDiemByID = deepFreeze({ count: 1, data: [ { @@ -17,9 +19,9 @@ export const apiPerDiemByID = { }, ], offset: 0, -}; +}); -export const expectPerDiemByID = { +export const expectPerDiemByID = deepFreeze({ active: false, created_at: new Date('2018-10-25T09:40:40.729Z'), currency: 'INR', @@ -28,9 +30,9 @@ export const expectPerDiemByID = { org_id: 'orrjqbDbeP9p', rate: 140, updated_at: new Date('2022-08-11T09:50:26.804Z'), -}; +}); -export const apiPerDiemSingleResponse = { +export const apiPerDiemSingleResponse = deepFreeze({ count: 4, data: [ { @@ -47,9 +49,9 @@ export const apiPerDiemSingleResponse = { }, ], offset: 0, -}; +}); -export const expectedPerDiems = [ +export const expectedPerDiems = deepFreeze([ { active: true, created_at: new Date('2018-10-08T06:37:01.337Z'), @@ -90,9 +92,9 @@ export const expectedPerDiems = [ rate: 3, updated_at: new Date('2023-01-10T07:18:10.082Z'), }, -]; +]); -export const apiPerDiem = { +export const apiPerDiem = deepFreeze({ count: 4, data: [ { @@ -145,9 +147,9 @@ export const apiPerDiem = { }, ], offset: 0, -}; +}); -export const apiPerDiemFirst = { +export const apiPerDiemFirst = deepFreeze({ count: 4, data: [ { @@ -176,9 +178,9 @@ export const apiPerDiemFirst = { }, ], offset: 0, -}; +}); -export const apiPerDiemSecond = { +export const apiPerDiemSecond = deepFreeze({ count: 4, data: [ { @@ -207,9 +209,9 @@ export const apiPerDiemSecond = { }, ], offset: 2, -}; +}); -export const allPerDiemRatesParam = [ +export const allPerDiemRatesParam = deepFreeze([ { active: true, created_at: '2020-08-12T16:09:14.551376+00:00', @@ -246,9 +248,9 @@ export const allPerDiemRatesParam = [ full_name: 'aaaa (12 AED per day)', readableRate: 'AED 12.00 per day', }, -]; +]); -export const apiOrgUserSettings = { +export const apiOrgUserSettings = deepFreeze({ id: 'ous7cvGj3iOsi', created_at: new Date('2019-10-10T06:33:08.192Z'), updated_at: new Date('2022-12-07T10:37:57.155Z'), @@ -392,9 +394,9 @@ export const apiOrgUserSettings = { enabled: true, allowed_payment_modes: [AccountType.PERSONAL], }, -}; +}); -export const allowedPerDiem = [ +export const allowedPerDiem = deepFreeze([ { active: true, created_at: '2020-08-12T16:09:14.551Z', @@ -419,4 +421,4 @@ export const allowedPerDiem = [ full_name: 'aaaa (12 AED per day)', readableRate: 'AED 12.00 per day', }, -]; +]); diff --git a/src/app/core/test-data/projects.spec.data.ts b/src/app/core/test-data/projects.spec.data.ts index 83c9fd8f96..2955b44f1c 100644 --- a/src/app/core/test-data/projects.spec.data.ts +++ b/src/app/core/test-data/projects.spec.data.ts @@ -1,9 +1,11 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ProjectParams } from '../models/project-params.model'; import { ProjectV1 } from '../models/v1/extended-project.model'; import { OrgCategory, OrgCategoryListItem } from '../models/v1/org-category.model'; import { ExtendedProject } from '../models/v2/extended-project.model'; -export const apiResponseActiveOnly = [ +export const apiResponseActiveOnly = deepFreeze([ { id: 257528, created_at: new Date('2021-05-12T10:28:40.834Z'), @@ -46,9 +48,9 @@ export const apiResponseActiveOnly = [ approver2_id: null, org_category_ids: null, }, -]; +]); -export const expectedReponseActiveOnly = [ +export const expectedReponseActiveOnly = deepFreeze([ { id: 257528, created_at: new Date('2021-05-12T10:28:40.834Z'), @@ -91,9 +93,9 @@ export const expectedReponseActiveOnly = [ approver2_id: null, org_category_ids: null, }, -]; +]); -export const apiV2ResponseMultiple = { +export const apiV2ResponseMultiple = deepFreeze({ count: 2, data: [ { @@ -138,9 +140,9 @@ export const apiV2ResponseMultiple = { limit: 4, offset: 0, url: '/v2/projects', -}; +}); -export const apiV2ResponseSingle = { +export const apiV2ResponseSingle = deepFreeze({ count: 1, data: [ { @@ -166,9 +168,9 @@ export const apiV2ResponseSingle = { limit: 1, offset: 0, url: '/v2/projects', -}; +}); -export const testActiveCategoryList: OrgCategory[] = [ +export const testActiveCategoryList: OrgCategory[] = deepFreeze([ { code: '4060340', created_at: new Date('2018-01-31T23:50:27.215171+00:00'), @@ -205,9 +207,9 @@ export const testActiveCategoryList: OrgCategory[] = [ sub_category: 'Cell phone', updated_at: new Date('2022-05-05T17:46:15.434494+00:00'), }, -]; +]); -export const testActiveCategoryListOptions: OrgCategoryListItem[] = [ +export const testActiveCategoryListOptions: OrgCategoryListItem[] = deepFreeze([ { label: 'Snacks', value: { @@ -253,9 +255,9 @@ export const testActiveCategoryListOptions: OrgCategoryListItem[] = [ updated_at: new Date('2022-05-05T17:46:15.434494+00:00'), }, }, -]; +]); -export const allowedActiveCategories: OrgCategory[] = [ +export const allowedActiveCategories: OrgCategory[] = deepFreeze([ { code: '4060340', created_at: new Date('2018-01-31T23:50:27.215171+00:00'), @@ -280,9 +282,9 @@ export const allowedActiveCategories: OrgCategory[] = [ sub_category: 'Induction', updated_at: new Date('2022-07-05T07:52:00.417939+00:00'), }, -]; +]); -export const allowedActiveCategoriesListOptions: OrgCategoryListItem[] = [ +export const allowedActiveCategoriesListOptions: OrgCategoryListItem[] = deepFreeze([ { label: 'Snacks', value: { @@ -313,9 +315,9 @@ export const allowedActiveCategoriesListOptions: OrgCategoryListItem[] = [ updated_at: new Date('2022-07-05T07:52:00.417939+00:00'), }, }, -]; +]); -export const expectedProjectsResponse: ExtendedProject[] = [ +export const expectedProjectsResponse: ExtendedProject[] = deepFreeze([ { ap1_email: null, ap1_full_name: null, @@ -354,9 +356,9 @@ export const expectedProjectsResponse: ExtendedProject[] = [ projectv2_name: 'Fyle Engineering', sub_project_name: null, }, -]; +]); -export const testProjectParams: ProjectParams = { +export const testProjectParams: ProjectParams = deepFreeze({ orgId: 'orNVthTo2Zyo', active: true, sortDirection: 'asc', @@ -366,9 +368,9 @@ export const testProjectParams: ProjectParams = { offset: 0, limit: 10, searchNameText: 'search', -}; +}); -export const testProjectV2: ExtendedProject = { +export const testProjectV2: ExtendedProject = deepFreeze({ ap1_email: null, ap1_full_name: null, ap2_email: null, @@ -386,11 +388,11 @@ export const testProjectV2: ExtendedProject = { project_updated_at: new Date('2022-11-23T08:55:29.400Z'), projectv2_name: 'Staging Project', sub_project_name: null, -}; +}); -export const testCategoryIds = ['145429', '140530', '145458', '122269']; +export const testCategoryIds = deepFreeze(['145429', '140530', '145458', '122269']); -export const params = { +export const params = deepFreeze({ project_org_id: 'eq.orNVthTo2Zyo', order: 'project_name.asc', limit: 10, @@ -399,9 +401,9 @@ export const params = { project_org_category_ids: 'ov.{,122269,122270,122271,122272,122273}', project_id: 'in.(3943,305792,148971,247936)', project_name: 'ilike.%search%', -}; +}); -export const projectsV1Data: ProjectV1[] = [ +export const projectsV1Data: ProjectV1[] = deepFreeze([ { created_at: new Date('2021-05-12T10:28:40.834844'), updated_at: new Date('2021-07-08T10:28:27.686886'), @@ -412,9 +414,9 @@ export const projectsV1Data: ProjectV1[] = [ updated_at: new Date('2021-07-08T10:28:27.686886'), ...apiResponseActiveOnly[1], }, -]; +]); -export const projectsV1Data2: ProjectV1[] = [ +export const projectsV1Data2: ProjectV1[] = deepFreeze([ { created_at: new Date('2021-05-12T10:28:40.834844'), updated_at: new Date('2021-07-08T10:28:27.686886'), @@ -422,4 +424,4 @@ export const projectsV1Data2: ProjectV1[] = [ name: 'Staging Project', ...apiResponseActiveOnly[0], }, -]; +]); diff --git a/src/app/core/test-data/status.service.spec.data.ts b/src/app/core/test-data/status.service.spec.data.ts index 79b77c275c..0ca5836a36 100644 --- a/src/app/core/test-data/status.service.spec.data.ts +++ b/src/app/core/test-data/status.service.spec.data.ts @@ -1,6 +1,8 @@ +import deepFreeze from 'deep-freeze-strict'; + import { ExtendedStatus } from '../models/extended_status.model'; -export const getApiResponse = [ +export const getApiResponse = deepFreeze([ { st_id: 'st7ak7UoeTDH', st_created_at: '2022-09-23T15:33:52.696Z', @@ -84,9 +86,9 @@ export const getApiResponse = [ us_full_name: null, us_email: null, }, -]; +]); -export const getEstatusApiResponse: ExtendedStatus[] = [ +export const getEstatusApiResponse: ExtendedStatus[] = deepFreeze([ { st_id: 'st7ak7UoeTDH', st_created_at: new Date('2022-09-23T15:33:52.696Z'), @@ -170,9 +172,9 @@ export const getEstatusApiResponse: ExtendedStatus[] = [ us_full_name: null, us_email: null, }, -]; +]); -export const apiCommentsResponse: ExtendedStatus[] = [ +export const apiCommentsResponse: ExtendedStatus[] = deepFreeze([ { st_id: 'stB3NqJuL3eE', st_created_at: new Date('2022-10-28T05:54:01.537Z'), @@ -702,9 +704,9 @@ export const apiCommentsResponse: ExtendedStatus[] = [ isSelfComment: false, isOthersComment: true, }, -]; +]); -export const updateReponseWithFlattenedEStatus: ExtendedStatus[] = [ +export const updateReponseWithFlattenedEStatus: ExtendedStatus[] = deepFreeze([ { st_id: 'stB3NqJuL3eE', st_created_at: new Date('2022-10-28T05:54:01.537Z'), @@ -1366,9 +1368,9 @@ export const updateReponseWithFlattenedEStatus: ExtendedStatus[] = [ icon: 'edit', }, }, -]; +]); -export const estatusData1: ExtendedStatus[] = [ +export const estatusData1: ExtendedStatus[] = deepFreeze([ { st_id: 'st7ak7UoeTDH', st_created_at: new Date('2022-09-23T15:33:52.696Z'), @@ -1437,9 +1439,9 @@ export const estatusData1: ExtendedStatus[] = [ icon: 'food', }, }, -]; +]); -export const expectedEstatusData1: ExtendedStatus[] = [ +export const expectedEstatusData1: ExtendedStatus[] = deepFreeze([ { st_id: 'st7ak7UoeTDH', st_created_at: new Date('2022-09-23T15:33:52.696Z'), @@ -1511,9 +1513,9 @@ export const expectedEstatusData1: ExtendedStatus[] = [ }, has_details: false, }, -]; +]); -export const updatedProjectKeyEstData: ExtendedStatus[] = [ +export const updatedProjectKeyEstData: ExtendedStatus[] = deepFreeze([ { st_id: 'st7ak7UoeTDH', st_created_at: new Date('2022-09-23T15:33:52.696Z'), @@ -1585,9 +1587,9 @@ export const updatedProjectKeyEstData: ExtendedStatus[] = [ }, has_details: false, }, -]; +]); -export const estatusSample = [ +export const estatusSample = deepFreeze([ { st_id: 'st1YBfc0c0t6', st_created_at: new Date('2022-11-07T10:56:01.991Z'), @@ -1704,9 +1706,9 @@ export const estatusSample = [ }, has_details: true, }, -]; +]); -export const eStatusWithProjectName = [ +export const eStatusWithProjectName = deepFreeze([ { st_id: 'sty8xyVwn2sK', st_created_at: new Date('2022-11-07T10:58:24.975Z'), @@ -1730,9 +1732,9 @@ export const eStatusWithProjectName = [ icon: 'radio-circle-outline', }, }, -]; +]); -export const eStatusWithProjectName2 = [ +export const eStatusWithProjectName2 = deepFreeze([ { st_id: 'sty8xyVwn2sK', st_created_at: new Date('2022-11-07T10:58:24.975Z'), @@ -1757,9 +1759,9 @@ export const eStatusWithProjectName2 = [ icon: 'radio-circle-outline', }, }, -]; +]); -export const eStatusWithReimbursible = [ +export const eStatusWithReimbursible = deepFreeze([ { st_id: 'stJ0lgtMHZW9', st_created_at: '2023-04-10T09:13:26.285Z', @@ -1795,9 +1797,9 @@ export const eStatusWithReimbursible = [ }, has_details: true, }, -]; +]); -export const newEstatusData1: ExtendedStatus[] = [ +export const newEstatusData1: ExtendedStatus[] = deepFreeze([ { st_id: 'st7ak7UoeTDH', st_created_at: new Date('2022-09-23T15:33:52.696Z'), @@ -1867,9 +1869,9 @@ export const newEstatusData1: ExtendedStatus[] = [ us_full_name: null, us_email: null, }, -]; +]); -export const expectedNewStatusData: ExtendedStatus[] = [ +export const expectedNewStatusData: ExtendedStatus[] = deepFreeze([ { st_id: 'stIwoMKmTqeM', st_created_at: new Date('2022-09-21T15:33:50.409Z'), @@ -1953,9 +1955,9 @@ export const expectedNewStatusData: ExtendedStatus[] = [ isOthersComment: true, show_dt: false, }, -]; +]); -export const systemComments1: ExtendedStatus[] = [ +export const systemComments1: ExtendedStatus[] = deepFreeze([ { st_id: 'stIwoMKmTqeM', st_created_at: new Date('2022-09-21T15:33:50.409Z'), @@ -2022,9 +2024,9 @@ export const systemComments1: ExtendedStatus[] = [ isOthersComment: true, show_dt: true, }, -]; +]); -export const systemCommentsWithSt: ExtendedStatus[] = [ +export const systemCommentsWithSt: ExtendedStatus[] = deepFreeze([ { st_id: 'stIwoMKmTqeM', st_created_at: new Date('2022-09-21T15:33:50.409Z'), @@ -2100,4 +2102,4 @@ export const systemCommentsWithSt: ExtendedStatus[] = [ icon: 'flag-fill', }, }, -]; +]); diff --git a/src/app/core/test-data/tasks.service.spec.data.ts b/src/app/core/test-data/tasks.service.spec.data.ts index a8b59de734..3c2d4a34e8 100644 --- a/src/app/core/test-data/tasks.service.spec.data.ts +++ b/src/app/core/test-data/tasks.service.spec.data.ts @@ -1,4 +1,6 @@ -export const potentialDuplicatesApiResponse = [ +import deepFreeze from 'deep-freeze-strict'; + +export const potentialDuplicatesApiResponse = deepFreeze([ { transaction_ids: ['tx3I0ccSGlhg', 'txvAmVCGZUZi'], fields: ['amount', 'currency', 'txn_dt'] }, { transaction_ids: ['tx3rq5G9gzgf', 'txS1cDov9iZn'], fields: ['amount', 'currency', 'txn_dt'] }, { transaction_ids: ['tx6KauIKfjdJ', 'txT0ZmCrVOiD'], fields: ['amount', 'currency', 'txn_dt'] }, @@ -18,9 +20,9 @@ export const potentialDuplicatesApiResponse = [ { transaction_ids: ['txjh5iDt7xXO', 'txkJsHIF6a9X'], fields: ['amount', 'currency', 'txn_dt'] }, { transaction_ids: ['txT0ZmCrVOiD', 'txws78AoalC9'], fields: ['amount', 'currency', 'txn_dt'] }, { transaction_ids: ['txT0ZmCrVOiD', 'txzjWIcqYxa9'], fields: ['amount', 'currency', 'txn_dt'] }, -]; +]); -export const extendedOrgUserResponse = { +export const extendedOrgUserResponse = deepFreeze({ ou: { id: 'out3t2X258rd', created_at: new Date('2019-02-04T10:26:36.877Z'), @@ -167,9 +169,9 @@ export const extendedOrgUserResponse = { customer_id: 'dwc8ZDUdZeUHhrI', bank_account_added: true, }, -}; +}); -export const teamReportResponse = [ +export const teamReportResponse = deepFreeze([ { aggregates: [ { @@ -184,9 +186,9 @@ export const teamReportResponse = [ dimensions: [], name: 'scalar_stat', }, -]; +]); -export const sentBackResponse = [ +export const sentBackResponse = deepFreeze([ { aggregates: [ { @@ -201,9 +203,9 @@ export const sentBackResponse = [ dimensions: [], name: 'scalar_stat', }, -]; +]); -export const unsubmittedReportsResponse = [ +export const unsubmittedReportsResponse = deepFreeze([ { aggregates: [ { @@ -218,9 +220,9 @@ export const unsubmittedReportsResponse = [ dimensions: [], name: 'scalar_stat', }, -]; +]); -export const allExtendedReportsResponse = [ +export const allExtendedReportsResponse = deepFreeze([ { _search_document: "'1':1 '2022':3 '44.53':5 'aiyush':9 'aiyush.dhar@fyle.in':10 'c/2022/11/r/2':6 'indiax':8 'inr':4 'oct':2 'se':7", @@ -444,9 +446,9 @@ export const allExtendedReportsResponse = [ us_email: 'aiyush.dhar@fyle.in', us_full_name: 'Aiyush', }, -]; +]); -export const unreportedExpensesResponse = [ +export const unreportedExpensesResponse = deepFreeze([ { aggregates: [ { @@ -461,9 +463,9 @@ export const unreportedExpensesResponse = [ dimensions: [], name: 'scalar_stat', }, -]; +]); -export const incompleteExpensesResponse = [ +export const incompleteExpensesResponse = deepFreeze([ { aggregates: [ { @@ -478,9 +480,9 @@ export const incompleteExpensesResponse = [ dimensions: [], name: 'scalar_stat', }, -]; +]); -export const sentBackAdvancesResponse = { +export const sentBackAdvancesResponse = deepFreeze({ count: 5, total_amount: 123370000, -}; +}); diff --git a/src/app/fyle/add-edit-expense/add-edit-expense-2.spec.ts b/src/app/fyle/add-edit-expense/add-edit-expense-2.spec.ts index 4b156191a4..8d125e2a47 100644 --- a/src/app/fyle/add-edit-expense/add-edit-expense-2.spec.ts +++ b/src/app/fyle/add-edit-expense/add-edit-expense-2.spec.ts @@ -471,16 +471,17 @@ export function TestCases2(getTestBed) { describe('getEditExpenseObservable(): ', () => { it('should get editable expense observable if the txn is in DRAFT state', (done) => { expensesService.getExpenseById.and.returnValue(of(platformExpenseWithExtractedData)); - transactionService.transformExpense.and.returnValue(transformedExpenseWithExtractedData); + const mockTransformedExpense = cloneDeep(transformedExpenseWithExtractedData); + transactionService.transformExpense.and.returnValue(mockTransformedExpense); categoriesService.getCategoryByName.and.returnValue(of(orgCategoryData)); dateService.getUTCDate.and.returnValue(new Date('2023-01-24T11:30:00.000Z')); component.getEditExpenseObservable().subscribe((res) => { - expect(res).toEqual(transformedExpenseWithExtractedData); + expect(res).toEqual(mockTransformedExpense); expect(expensesService.getExpenseById).toHaveBeenCalledOnceWith(activatedRoute.snapshot.params.id); expect(transactionService.transformExpense).toHaveBeenCalledOnceWith(platformExpenseWithExtractedData); expect(categoriesService.getCategoryByName).toHaveBeenCalledOnceWith( - transformedExpenseWithExtractedData.tx.extracted_data.category + mockTransformedExpense.tx.extracted_data.category ); expect(dateService.getUTCDate).not.toHaveBeenCalled(); expect(component.isIncompleteExpense).toBeTrue(); @@ -490,10 +491,11 @@ export function TestCases2(getTestBed) { it('should return txn if state is not DRAFT', (done) => { expensesService.getExpenseById.and.returnValue(of(platformExpenseData)); - transactionService.transformExpense.and.returnValue(transformedExpenseData); + const mockTransformedExpense = cloneDeep(transformedExpenseData); + transactionService.transformExpense.and.returnValue(mockTransformedExpense); component.getEditExpenseObservable().subscribe((res) => { - expect(res).toEqual(transformedExpenseData); + expect(res).toEqual(mockTransformedExpense); expect(expensesService.getExpenseById).toHaveBeenCalledOnceWith(activatedRoute.snapshot.params.id); expect(transactionService.transformExpense).toHaveBeenCalledOnceWith(platformExpenseData); done(); @@ -502,11 +504,12 @@ export function TestCases2(getTestBed) { it('should return txn when the expense or the extracted data does not contain any category', (done) => { expensesService.getExpenseById.and.returnValue(of(platformExpenseWithExtractedData2)); - transactionService.transformExpense.and.returnValue(transformedExpenseWithExtractedData2); + const mockTransformedExpense = cloneDeep(transformedExpenseWithExtractedData2); + transactionService.transformExpense.and.returnValue(mockTransformedExpense); dateService.getUTCDate.and.returnValue(new Date('2023-01-24T11:30:00.000Z')); component.getEditExpenseObservable().subscribe((res) => { - expect(res).toEqual(transformedExpenseWithExtractedData2); + expect(res).toEqual(mockTransformedExpense); expect(expensesService.getExpenseById).toHaveBeenCalledTimes(1); expect(transactionService.transformExpense).toHaveBeenCalledOnceWith(platformExpenseWithExtractedData2); expect(dateService.getUTCDate).not.toHaveBeenCalled(); @@ -1151,7 +1154,8 @@ export function TestCases2(getTestBed) { describe('getParsedReceipt():', () => { it('should get parsed receipt', fakeAsync(() => { - transactionOutboxService.parseReceipt.and.resolveTo(parsedReceiptData1); + const mockParsedReceiptData = cloneDeep(parsedReceiptData1); + transactionOutboxService.parseReceipt.and.resolveTo(mockParsedReceiptData); currencyService.getHomeCurrency.and.returnValue(of('INR')); currencyService.getExchangeRate.and.returnValue(of(82)); @@ -1171,7 +1175,8 @@ export function TestCases2(getTestBed) { })); it('should get parsed receipt without date', fakeAsync(() => { - transactionOutboxService.parseReceipt.and.resolveTo(parsedReceiptData2); + const mockParsedReceiptData = cloneDeep(parsedReceiptData2); + transactionOutboxService.parseReceipt.and.resolveTo(mockParsedReceiptData); currencyService.getHomeCurrency.and.returnValue(of('INR')); currencyService.getExchangeRate.and.returnValue(of(82)); diff --git a/src/app/fyle/add-edit-expense/add-edit-expense-3.spec.ts b/src/app/fyle/add-edit-expense/add-edit-expense-3.spec.ts index c9b599147f..74ffc29fc4 100644 --- a/src/app/fyle/add-edit-expense/add-edit-expense-3.spec.ts +++ b/src/app/fyle/add-edit-expense/add-edit-expense-3.spec.ts @@ -289,12 +289,12 @@ export function TestCases3(getTestBed) { expect(component.getParsedReceipt).toHaveBeenCalledOnceWith('url1', 'pdf'); expect(currencyService.getHomeCurrency).toHaveBeenCalledTimes(1); - expect(component.inpageExtractedData).toEqual(null); + expect(component.inpageExtractedData).toBeNull(); expect(component.fg.controls.currencyObj.value).toEqual({ amount: null, currency: 'USD', }); - expect(component.fg.controls.category.value).toEqual(null); + expect(component.fg.controls.category.value).toBeNull(); expect(component.fg.controls.dateOfSpend.value).toEqual(new Date('2023-02-24T12:03:57.680Z')); expect(component.fg.controls.vendor_id.value).toEqual('vendor_name'); }); @@ -328,7 +328,7 @@ export function TestCases3(getTestBed) { currency: 'USD', }); expect(component.fg.controls.dateOfSpend.value).toEqual(new Date('2023-02-24T12:03:57.680Z')); - expect(component.fg.controls.category.value).toEqual(null); + expect(component.fg.controls.category.value).toBeNull(); expect(component.fg.controls.vendor_id.value).toEqual('vendor_name'); }); }); @@ -374,8 +374,8 @@ export function TestCases3(getTestBed) { }); expect(result).toEqual(orgCategoryData); - expect(component.recentCategories).toEqual(undefined); - expect(component.presetCategoryId).toEqual(undefined); + expect(component.recentCategories).toBeUndefined(); + expect(component.presetCategoryId).toBeUndefined(); }); it('return auto fill category if recent categories is not present and expense category is empty', () => { @@ -405,7 +405,8 @@ export function TestCases3(getTestBed) { describe('getExpenseAttachments():', () => { it('should return file observables in edit mode', (done) => { - fileService.findByTransactionId.and.returnValue(of(fileObject4)); + const mockFileObject = cloneDeep(fileObject4); + fileService.findByTransactionId.and.returnValue(of(mockFileObject)); fileService.downloadUrl.and.returnValue(of('url')); spyOn(component, 'getReceiptDetails').and.returnValue({ type: 'jpeg', @@ -416,25 +417,27 @@ export function TestCases3(getTestBed) { expect(res).toEqual(expectedFileData1); expect(fileService.findByTransactionId).toHaveBeenCalledOnceWith('tx1vdITUXIzf'); expect(fileService.downloadUrl).toHaveBeenCalledOnceWith('fiV1gXpyCcbU'); - expect(component.getReceiptDetails).toHaveBeenCalledOnceWith(fileObject4[0]); + expect(component.getReceiptDetails).toHaveBeenCalledOnceWith(mockFileObject[0]); done(); }); }); it('should return new expense file objects in add mode', (done) => { - component.newExpenseDataUrls = fileObject4; + const mockFileObject = cloneDeep(fileObject4); + component.newExpenseDataUrls = mockFileObject; component.getExpenseAttachments('add').subscribe((res) => { - expect(res).toEqual(fileObject4); + expect(res).toEqual(mockFileObject); done(); }); }); it('should return new expense file objects of type pdf in add mode', (done) => { - component.newExpenseDataUrls = [fileObjectAdv1]; + const mockExpenseDataUrls = cloneDeep(fileObjectAdv1); + component.newExpenseDataUrls = [mockExpenseDataUrls]; component.getExpenseAttachments('add').subscribe((res) => { - expect(res).toEqual([fileObjectAdv1]); + expect(res).toEqual([mockExpenseDataUrls]); done(); }); }); @@ -478,8 +481,11 @@ export function TestCases3(getTestBed) { component.inpageExtractedData = extractedData.data; fixture.detectChanges(); + const mockCustomFieldData1 = cloneDeep(expectedCustomField[0]); + const mockCustomFieldData2 = cloneDeep(expectedCustomField[2]); + const mockEtxn = cloneDeep(unflattenedExpData); component - .generateEtxnFromFg(of(unflattenedExpData), of([expectedCustomField[0], expectedCustomField[2]])) + .generateEtxnFromFg(of(mockEtxn), of([mockCustomFieldData1, mockCustomFieldData2])) .subscribe((res) => { expect(res).toEqual(newExpFromFg); expect(component.getExpenseAttachments).toHaveBeenCalledOnceWith(component.mode, unflattenedExpData.tx.id); @@ -551,7 +557,8 @@ export function TestCases3(getTestBed) { }); fixture.detectChanges(); - component.generateEtxnFromFg(of(unflattenedTxnData2), of(customFieldData2), true).subscribe((res) => { + const mockCustomFieldData1 = cloneDeep(customFieldData2); + component.generateEtxnFromFg(of(unflattenedTxnData2), of(mockCustomFieldData1), true).subscribe((res) => { expect(res).toEqual(newExpFromFg2); expect(component.getExpenseAttachments).toHaveBeenCalledOnceWith(component.mode, 'tx3qHxFNgRcZ'); expect(dateService.getUTCDate).toHaveBeenCalledOnceWith(new Date('2023-02-23T16:24:01.335Z')); @@ -619,8 +626,9 @@ export function TestCases3(getTestBed) { component.newExpenseDataUrls = []; fixture.detectChanges(); + const mockCustomFields = cloneDeep(customFieldData1); component - .generateEtxnFromFg(of(cloneDeep(draftUnflattendedTxn)), of(customFieldData1), false) + .generateEtxnFromFg(of(cloneDeep(draftUnflattendedTxn)), of(mockCustomFields), false) .subscribe((res) => { expect(res).toEqual(newExpFromFg3); expect(component.getExpenseAttachments).toHaveBeenCalledOnceWith(component.mode, null); @@ -685,40 +693,37 @@ export function TestCases3(getTestBed) { currency: 'USD', }); - component - .generateEtxnFromFg(of(cloneDeep(draftUnflattendedTxn)), of(customFieldData1), false) - .subscribe((res) => { - expect(res).toEqual(newExpFromFg4); - expect(component.getExpenseAttachments).toHaveBeenCalledOnceWith( - component.mode, - draftUnflattendedTxn.tx.id - ); - expect(component.getSourceAccID).toHaveBeenCalledTimes(1); - expect(component.getBillable).toHaveBeenCalledTimes(1); - expect(component.getSkipRemibursement).toHaveBeenCalledTimes(1); - expect(component.getTxnDate).toHaveBeenCalledTimes(1); - expect(component.getCurrency).toHaveBeenCalledTimes(1); - expect(component.getOriginalCurrency).toHaveBeenCalledTimes(1); - expect(component.getOriginalAmount).toHaveBeenCalledTimes(1); - expect(component.getProjectID).toHaveBeenCalledTimes(1); - expect(component.getTaxAmount).toHaveBeenCalledTimes(1); - expect(component.getTaxGroupID).toHaveBeenCalledTimes(1); - expect(component.getOrgCategoryID).toHaveBeenCalledTimes(1); - expect(component.getFyleCategory).toHaveBeenCalledTimes(1); - expect(component.getDisplayName).toHaveBeenCalledTimes(1); - expect(component.getPurpose).toHaveBeenCalledTimes(1); - expect(component.getFromDt).toHaveBeenCalledTimes(1); - expect(component.getToDt).toHaveBeenCalledTimes(1); - expect(component.getFlightJourneyClass).toHaveBeenCalledTimes(1); - expect(component.getFlightReturnClass).toHaveBeenCalledTimes(1); - expect(component.getTrainTravelClass).toHaveBeenCalledTimes(1); - expect(component.getBusTravelClass).toHaveBeenCalledTimes(1); - expect(component.getDistance).toHaveBeenCalledTimes(1); - expect(component.getDistanceUnit).toHaveBeenCalledTimes(1); - expect(component.getBreakfastProvided).toHaveBeenCalledTimes(1); - expect(component.getAmount).toHaveBeenCalledTimes(1); - done(); - }); + const mockCustomFields = cloneDeep(customFieldData1); + const mockEtxn = cloneDeep(draftUnflattendedTxn); + component.generateEtxnFromFg(of(cloneDeep(mockEtxn)), of(mockCustomFields), false).subscribe((res) => { + expect(res).toEqual(newExpFromFg4); + expect(component.getExpenseAttachments).toHaveBeenCalledOnceWith(component.mode, draftUnflattendedTxn.tx.id); + expect(component.getSourceAccID).toHaveBeenCalledTimes(1); + expect(component.getBillable).toHaveBeenCalledTimes(1); + expect(component.getSkipRemibursement).toHaveBeenCalledTimes(1); + expect(component.getTxnDate).toHaveBeenCalledTimes(1); + expect(component.getCurrency).toHaveBeenCalledTimes(1); + expect(component.getOriginalCurrency).toHaveBeenCalledTimes(1); + expect(component.getOriginalAmount).toHaveBeenCalledTimes(1); + expect(component.getProjectID).toHaveBeenCalledTimes(1); + expect(component.getTaxAmount).toHaveBeenCalledTimes(1); + expect(component.getTaxGroupID).toHaveBeenCalledTimes(1); + expect(component.getOrgCategoryID).toHaveBeenCalledTimes(1); + expect(component.getFyleCategory).toHaveBeenCalledTimes(1); + expect(component.getDisplayName).toHaveBeenCalledTimes(1); + expect(component.getPurpose).toHaveBeenCalledTimes(1); + expect(component.getFromDt).toHaveBeenCalledTimes(1); + expect(component.getToDt).toHaveBeenCalledTimes(1); + expect(component.getFlightJourneyClass).toHaveBeenCalledTimes(1); + expect(component.getFlightReturnClass).toHaveBeenCalledTimes(1); + expect(component.getTrainTravelClass).toHaveBeenCalledTimes(1); + expect(component.getBusTravelClass).toHaveBeenCalledTimes(1); + expect(component.getDistance).toHaveBeenCalledTimes(1); + expect(component.getDistanceUnit).toHaveBeenCalledTimes(1); + expect(component.getBreakfastProvided).toHaveBeenCalledTimes(1); + expect(component.getAmount).toHaveBeenCalledTimes(1); + done(); + }); }); }); @@ -1174,6 +1179,7 @@ export function TestCases3(getTestBed) { beforeEach(() => { categoriesService.getCategoryByName.and.returnValue(of(expectedOrgCategoryByName2)); }); + it('should get new expense observable', (done) => { orgSettingsService.get.and.returnValue(of(orgSettingsData)); authService.getEou.and.resolveTo(apiEouRes); diff --git a/src/app/fyle/add-edit-expense/add-edit-expense-4.spec.ts b/src/app/fyle/add-edit-expense/add-edit-expense-4.spec.ts index 3b8c9b4b07..332717cbee 100644 --- a/src/app/fyle/add-edit-expense/add-edit-expense-4.spec.ts +++ b/src/app/fyle/add-edit-expense/add-edit-expense-4.spec.ts @@ -100,6 +100,7 @@ import { transformedExpenseWithMatchCCCData2, } from 'src/app/core/mock-data/transformed-expense.data'; import { SpenderReportsService } from 'src/app/core/services/platform/v1/spender/reports.service'; +import { cloneDeep } from 'lodash'; export function TestCases4(getTestBed) { return describe('AddEditExpensePage-4', () => { @@ -438,7 +439,8 @@ export function TestCases4(getTestBed) { describe('addExpense():', () => { it('should add an expense', (done) => { spyOn(component, 'getCustomFields').and.returnValue(of(txnCustomProperties)); - spyOn(component, 'generateEtxnFromFg').and.returnValue(of(expectedUnflattendedTxnData3)); + const mockEtxn = cloneDeep(expectedUnflattendedTxnData3); + spyOn(component, 'generateEtxnFromFg').and.returnValue(of(mockEtxn)); spyOn(component, 'trackAddExpense'); component.isConnected$ = of(true); spyOn(component, 'checkPolicyViolation').and.returnValue(of(expensePolicyDataWoData)); @@ -472,12 +474,11 @@ export function TestCases4(getTestBed) { component.isConnected$ = of(false); spyOn(component, 'trackAddExpense'); component.fg.controls.report.setValue(expectedReportsPaginated[0]); - spyOn(component, 'generateEtxnFromFg').and.returnValue( - of({ - ...unflattenedTxnData, - dataUrls: [{ url: '2023-02-08/orNVthTo2Zyo/receipts/fi6PQ6z4w6ET.000.pdf', type: 'application/pdf' }], - }) - ); + const mockEtxn = cloneDeep({ + ...unflattenedTxnData, + dataUrls: [{ url: '2023-02-08/orNVthTo2Zyo/receipts/fi6PQ6z4w6ET.000.pdf', type: 'application/pdf' }], + }); + spyOn(component, 'generateEtxnFromFg').and.returnValue(of(mockEtxn)); authService.getEou.and.resolveTo(apiEouRes); transactionOutboxService.addEntry.and.resolveTo(); component.selectedCCCTransaction = expectedECccResponse[0].ccce; @@ -491,7 +492,7 @@ export function TestCases4(getTestBed) { expect(component.generateEtxnFromFg).toHaveBeenCalledTimes(2); expect(authService.getEou).toHaveBeenCalledTimes(1); expect(transactionOutboxService.addEntry).toHaveBeenCalledOnceWith( - unflattenedTxnData.tx, + mockEtxn.tx, [{ url: '2023-02-08/orNVthTo2Zyo/receipts/fi6PQ6z4w6ET.000.pdf', type: 'pdf' }], [], 'rprAfNrce73O' @@ -503,15 +504,14 @@ export function TestCases4(getTestBed) { it('should add expense with critical policy violation', (done) => { spyOn(component, 'getCustomFields').and.returnValue(of(txnCustomProperties)); spyOn(component, 'trackAddExpense'); - spyOn(component, 'generateEtxnFromFg').and.returnValue(of(expectedUnflattendedTxnData3)); + const mockEtxn = cloneDeep(expectedUnflattendedTxnData3); + spyOn(component, 'generateEtxnFromFg').and.returnValue(of(mockEtxn)); component.isConnected$ = of(true); spyOn(component, 'checkPolicyViolation').and.returnValue(of(expensePolicyData)); policyService.getCriticalPolicyRules.and.returnValue([ 'The expense will be flagged when the total amount of all expenses in category Others in a month exceeds: INR 3000.', ]); - spyOn(component, 'criticalPolicyViolationErrorHandler').and.returnValue( - of({ etxn: expectedUnflattendedTxnData3, comment: null }) - ); + spyOn(component, 'criticalPolicyViolationErrorHandler').and.returnValue(of({ etxn: mockEtxn, comment: null })); authService.getEou.and.resolveTo(apiEouRes); spyOn(component, 'trackCreateExpense'); transactionOutboxService.addEntry.and.resolveTo(); @@ -530,7 +530,7 @@ export function TestCases4(getTestBed) { policyViolations: [ 'The expense will be flagged when the total amount of all expenses in category Others in a month exceeds: INR 3000.', ], - etxn: expectedUnflattendedTxnData3, + etxn: mockEtxn, }, jasmine.any(Observable) ); @@ -549,7 +549,8 @@ export function TestCases4(getTestBed) { it('should add expense with policy violations', (done) => { spyOn(component, 'getCustomFields').and.returnValue(of(txnCustomProperties)); spyOn(component, 'trackAddExpense'); - spyOn(component, 'generateEtxnFromFg').and.returnValue(of(expectedUnflattendedTxnData4)); + const mockEtxn = cloneDeep(expectedUnflattendedTxnData4); + spyOn(component, 'generateEtxnFromFg').and.returnValue(of(mockEtxn)); component.isConnected$ = of(true); spyOn(component, 'checkPolicyViolation').and.returnValue(of(expensePolicyData)); policyService.getCriticalPolicyRules.and.returnValue([]); @@ -558,7 +559,7 @@ export function TestCases4(getTestBed) { ]); spyOn(component, 'policyViolationErrorHandler').and.returnValue( of({ - etxn: expectedUnflattendedTxnData4, + etxn: mockEtxn, comment: 'continue', }) ); @@ -580,18 +581,13 @@ export function TestCases4(getTestBed) { 'The expense will be flagged when the total amount of all expenses in category Others in a month exceeds: INR 3000.', ], policyAction: expensePolicyData.data.final_desired_state, - etxn: expectedUnflattendedTxnData4, + etxn: mockEtxn, }, jasmine.any(Observable) ); expect(authService.getEou).toHaveBeenCalledOnceWith(); expect(component.trackCreateExpense).toHaveBeenCalledOnceWith(expectedUnflattendedTxnData4, false); - expect(transactionOutboxService.addEntry).toHaveBeenCalledOnceWith( - expectedUnflattendedTxnData4.tx, - [], - ['continue'], - undefined - ); + expect(transactionOutboxService.addEntry).toHaveBeenCalledOnceWith(mockEtxn.tx, [], ['continue'], undefined); done(); }); }); diff --git a/src/app/fyle/add-edit-expense/add-edit-expense-5.spec.ts b/src/app/fyle/add-edit-expense/add-edit-expense-5.spec.ts index 8985b70b1f..43b334785b 100644 --- a/src/app/fyle/add-edit-expense/add-edit-expense-5.spec.ts +++ b/src/app/fyle/add-edit-expense/add-edit-expense-5.spec.ts @@ -108,6 +108,7 @@ import { txnFieldsData2, txnFieldsFlightData } from 'src/app/core/mock-data/expe import { apiExpenses2, expenseData, splitExpensesData } from 'src/app/core/mock-data/platform/v1/expense.data'; import { ExpensesService } from 'src/app/core/services/platform/v1/spender/expenses.service'; import { matchedCCTransactionData } from 'src/app/core/mock-data/matchedCCTransaction.data'; +import { cloneDeep } from 'lodash'; export function TestCases5(getTestBed) { return describe('AddEditExpensePage-5', () => { @@ -1343,7 +1344,8 @@ export function TestCases5(getTestBed) { spyOn(component, 'getNewExpenseObservable').and.returnValue(of(expectedExpenseObservable)); spyOn(component, 'getEditExpenseObservable').and.returnValue(of(expectedUnflattendedTxnData1)); expensesService.getExpenseById.and.returnValue(of(expenseData)); - fileService.findByTransactionId.and.returnValue(of(expectedFileData1)); + const mockFileObject = cloneDeep(expectedFileData1); + fileService.findByTransactionId.and.returnValue(of(mockFileObject)); fileService.downloadUrl.and.returnValue(of('url')); spyOn(component, 'getReceiptDetails').and.returnValue({ type: 'jpeg', @@ -1465,12 +1467,12 @@ export function TestCases5(getTestBed) { expect(expensesService.getExpenseById).toHaveBeenCalledOnceWith('txyeiYbLDSOy'); component.attachments$.subscribe((res) => { - expect(res).toEqual(expectedFileData1); + expect(res).toEqual(mockFileObject); }); expect(fileService.findByTransactionId).toHaveBeenCalledOnceWith('tx3qHxFNgRcZ'); expect(fileService.downloadUrl).toHaveBeenCalledOnceWith('fiV1gXpyCcbU'); - expect(component.getReceiptDetails).toHaveBeenCalledOnceWith(expectedFileData1[0]); + expect(component.getReceiptDetails).toHaveBeenCalledOnceWith(mockFileObject[0]); component.flightJourneyTravelClassOptions$.subscribe((res) => { expect(res).toBeUndefined(); @@ -1632,7 +1634,8 @@ export function TestCases5(getTestBed) { expensesService.getSplitExpenses.and.returnValue(of(splitExpensesData)); transactionService.transformRawExpense.and.returnValue(splitExpTransformedData[0]); transactionService.transformRawExpense.and.returnValue(splitExpTransformedData[1]); - fileService.findByTransactionId.and.returnValue(of(expectedFileData1)); + const mockFileObject = cloneDeep(expectedFileData1); + fileService.findByTransactionId.and.returnValue(of(mockFileObject)); fileService.downloadUrl.and.returnValue(of('url')); activatedRoute.snapshot.params.activeIndex = JSON.stringify(1); activatedRoute.snapshot.params.txnIds = JSON.stringify(['id_1', 'id_2']); @@ -1749,12 +1752,12 @@ export function TestCases5(getTestBed) { expect(expensesService.getExpenseById).not.toHaveBeenCalled(); component.attachments$.subscribe((res) => { - expect(res).toEqual(expectedFileData1); + expect(res).toEqual(mockFileObject); }); expect(fileService.findByTransactionId).toHaveBeenCalledOnceWith(undefined); expect(fileService.downloadUrl).toHaveBeenCalledOnceWith('fiV1gXpyCcbU'); - expect(component.getReceiptDetails).toHaveBeenCalledOnceWith(expectedFileData1[0]); + expect(component.getReceiptDetails).toHaveBeenCalledOnceWith(mockFileObject[0]); component.flightJourneyTravelClassOptions$.subscribe((res) => { expect(res).toBeUndefined(); diff --git a/src/app/fyle/add-edit-expense/add-edit-expense-6.spec.ts b/src/app/fyle/add-edit-expense/add-edit-expense-6.spec.ts index 3732552bb5..24e6c0e921 100644 --- a/src/app/fyle/add-edit-expense/add-edit-expense-6.spec.ts +++ b/src/app/fyle/add-edit-expense/add-edit-expense-6.spec.ts @@ -81,6 +81,7 @@ import { import { matchedCCTransactionData, matchedCCTransactionData2 } from 'src/app/core/mock-data/matchedCCTransaction.data'; import { ccTransactionData, ccTransactionData1 } from 'src/app/core/mock-data/cc-transaction.data'; import { ccTransactionResponseData } from 'src/app/core/mock-data/corporate-card-transaction-response.data'; +import { cloneDeep } from 'lodash'; export function TestCases6(getTestBed) { describe('AddEditExpensePage-6', () => { @@ -365,7 +366,8 @@ export function TestCases6(getTestBed) { describe('updateFormForExpenseFields():', () => { it('should update form with expense fields values', () => { component.etxn$ = of(unflattenedExpWithCCCExpn); - component.taxGroups$ = of(taxGroupData); + const mockTaxGroupData = cloneDeep(taxGroupData); + component.taxGroups$ = of(mockTaxGroupData); expenseFieldsService.getDefaultTxnFieldValues.and.returnValue(defaultTxnFieldValuesData3); fixture.detectChanges(); @@ -375,7 +377,8 @@ export function TestCases6(getTestBed) { it('should update form with expense fields values with billable fields', () => { component.etxn$ = of(unflattenedExpWithCCCExpn); - component.taxGroups$ = of(taxGroupData); + const mockTaxGroupData = cloneDeep(taxGroupData); + component.taxGroups$ = of(mockTaxGroupData); expenseFieldsService.getDefaultTxnFieldValues.and.returnValue(defaultTxnFieldValuesData3); component.fg.controls.project.setValue(expectedProjectsResponse[0]); component.fg.controls.billable.setValue(null); @@ -391,7 +394,8 @@ export function TestCases6(getTestBed) { describe('setupExpenseFields():', () => { it('should setup expense fields', () => { - spyOn(component, 'generateTxnFieldsMap').and.returnValue(of(txnFieldsData2)); + const mockTxnFields = cloneDeep(txnFieldsData2); + spyOn(component, 'generateTxnFieldsMap').and.returnValue(of(mockTxnFields)); orgSettingsService.get.and.returnValue(of(orgSettingsData)); component.isIndividualProjectsEnabled$ = of(true); component.individualProjectIds$ = of([]); @@ -411,7 +415,8 @@ export function TestCases6(getTestBed) { }); it('should setup expense fields for offline mode and cost centers enabled', () => { - spyOn(component, 'generateTxnFieldsMap').and.returnValue(of(txnFieldsData3)); + const mockTxnFields = cloneDeep(txnFieldsData3); + spyOn(component, 'generateTxnFieldsMap').and.returnValue(of(mockTxnFields)); orgSettingsService.get.and.returnValue(of(orgSettingsData)); component.isIndividualProjectsEnabled$ = of(true); component.individualProjectIds$ = of([]); @@ -428,7 +433,8 @@ export function TestCases6(getTestBed) { }); it('should setup expense fields if cost centers are empty', () => { - spyOn(component, 'generateTxnFieldsMap').and.returnValue(of(txnFieldsData3)); + const mockTxnFields = cloneDeep(txnFieldsData3); + spyOn(component, 'generateTxnFieldsMap').and.returnValue(of(mockTxnFields)); orgSettingsService.get.and.returnValue(of(orgSettingsData)); component.isIndividualProjectsEnabled$ = of(true); component.individualProjectIds$ = of([123]); @@ -499,7 +505,8 @@ export function TestCases6(getTestBed) { it('should handle CCC expenses if expenses have matched_corporate_card_transaction synced', () => { const date = new Date('2018-07-03T13:00:00.000Z'); jasmine.clock().mockDate(date); - component.handleCCCExpenses(transformedExpenseWithMatchCCCData, null); + const mockEtxn = cloneDeep(transformedExpenseWithMatchCCCData); + component.handleCCCExpenses(mockEtxn, null); expect(component.cardNumber).toEqual('7620'); expect(component.matchedCCCTransaction).toEqual(matchedCCTransactionData); }); @@ -507,8 +514,10 @@ export function TestCases6(getTestBed) { it('should handle CCC expenses if expense does not have matched_corporate_card_transaction synced', () => { const date = new Date('2018-07-03T13:00:00.000Z'); jasmine.clock().mockDate(date); - corporateCreditCardExpenseService.transformCCTransaction.and.returnValue(matchedCCTransactionData); - component.handleCCCExpenses(transformedExpenseWithMatchCCCData4, ccTransactionData); + const mockTransformedCCCTxn = cloneDeep(matchedCCTransactionData); + corporateCreditCardExpenseService.transformCCTransaction.and.returnValue(mockTransformedCCCTxn); + const mockEtxn = cloneDeep(transformedExpenseWithMatchCCCData4); + component.handleCCCExpenses(mockEtxn, ccTransactionData); expect(corporateCreditCardExpenseService.transformCCTransaction).toHaveBeenCalledOnceWith(ccTransactionData); expect(component.cardNumber).toEqual('7620'); expect(component.matchedCCCTransaction).toEqual(matchedCCTransactionData); @@ -517,7 +526,8 @@ export function TestCases6(getTestBed) { it('should show card digits and vendor description', () => { const date = new Date('2018-06-06T08:30:00.000Z'); jasmine.clock().mockDate(date); - component.handleCCCExpenses(transformedExpenseWithMatchCCCData3, null); + const mockEtxn = cloneDeep(transformedExpenseWithMatchCCCData3); + component.handleCCCExpenses(mockEtxn, null); expect(component.cardNumber).toEqual('9891'); expect(component.matchedCCCTransaction).toEqual(matchedCCTransactionData2); }); diff --git a/src/app/fyle/add-edit-mileage/add-edit-mileage-1.spec.ts b/src/app/fyle/add-edit-mileage/add-edit-mileage-1.spec.ts index 4af092b537..3df2e2eb22 100644 --- a/src/app/fyle/add-edit-mileage/add-edit-mileage-1.spec.ts +++ b/src/app/fyle/add-edit-mileage/add-edit-mileage-1.spec.ts @@ -925,7 +925,7 @@ export function TestCases1(getTestBed) { it('should return an error object when the date is after the upper bound of the valid range', () => { const tomorrow = new Date(); - tomorrow.setDate(tomorrow.getDate() + 2); + tomorrow.setDate(tomorrow.getDate() + 3); const control = new FormControl(tomorrow.toDateString()); const result = component.customDateValidator(control); expect(result).toEqual({ invalidDateSelection: true }); diff --git a/src/app/fyle/add-edit-mileage/add-edit-mileage-3.spec.ts b/src/app/fyle/add-edit-mileage/add-edit-mileage-3.spec.ts index facb7a6823..af4d2bbf63 100644 --- a/src/app/fyle/add-edit-mileage/add-edit-mileage-3.spec.ts +++ b/src/app/fyle/add-edit-mileage/add-edit-mileage-3.spec.ts @@ -536,10 +536,11 @@ export function TestCases3(getTestBed) { mileageCategories: [mileageCategories2[1]], }) ); - expenseFieldsService.filterByOrgCategoryId.and.returnValue(of(txnFieldsData)); + const mockTxnFields = cloneDeep(txnFieldsData); + expenseFieldsService.filterByOrgCategoryId.and.returnValue(of(mockTxnFields)); component.getTransactionFields().subscribe((res) => { - expect(res).toEqual(txnFieldsData); + expect(res).toEqual(mockTxnFields); expect(expenseFieldsService.getAllMap).toHaveBeenCalledTimes(1); expect(component.getMileageCategories).toHaveBeenCalledTimes(1); expect(expenseFieldsService.filterByOrgCategoryId).toHaveBeenCalledOnceWith( diff --git a/src/app/fyle/add-edit-mileage/add-edit-mileage-4.spec.ts b/src/app/fyle/add-edit-mileage/add-edit-mileage-4.spec.ts index 02b5a25a37..aa789297f4 100644 --- a/src/app/fyle/add-edit-mileage/add-edit-mileage-4.spec.ts +++ b/src/app/fyle/add-edit-mileage/add-edit-mileage-4.spec.ts @@ -276,7 +276,8 @@ export function TestCases4(getTestBed) { custom_inputs: customPropertiesData as CustomInput[], }); spyOn(component, 'checkMileageCategories').and.returnValue(of(orgCategoryData)); - customFieldsService.standardizeCustomFields.and.returnValue(txnCustomPropertiesData); + const mockTxnCustomProperties = cloneDeep(txnCustomPropertiesData); + customFieldsService.standardizeCustomFields.and.returnValue(mockTxnCustomProperties); fixture.detectChanges(); component.getCustomInputs().subscribe((res) => { @@ -293,7 +294,8 @@ export function TestCases4(getTestBed) { it('should get custom inputs if no previous custom inputs are assigned', (done) => { spyOn(component, 'checkMileageCategories').and.returnValue(of(orgCategoryData)); - customFieldsService.standardizeCustomFields.and.returnValue(txnCustomPropertiesData3); + const mockTxnCustomProperties = cloneDeep(txnCustomPropertiesData3); + customFieldsService.standardizeCustomFields.and.returnValue(mockTxnCustomProperties); spyOn(component, 'getFormValues').and.returnValue({ custom_inputs: null, }); @@ -693,9 +695,10 @@ export function TestCases4(getTestBed) { component.commuteDetails = commuteDetailsData; component.fg.patchValue({ commuteDeduction: CommuteDeduction.ONE_WAY }); fixture.detectChanges(); + const mockTxnCustomProperties = cloneDeep(txnCustomProperties4); component - .generateEtxnFromFg(of(unflattenedTxnWithReportID3), of(txnCustomProperties4), of(10)) + .generateEtxnFromFg(of(unflattenedTxnWithReportID3), of(mockTxnCustomProperties), of(10)) .subscribe((res) => { expect(res).toEqual(newMileageExpFromForm); expect(component.getFormValues).toHaveBeenCalledTimes(1); diff --git a/src/app/fyle/add-edit-mileage/add-edit-mileage-5.spec.ts b/src/app/fyle/add-edit-mileage/add-edit-mileage-5.spec.ts index e78f69365f..61acb73b43 100644 --- a/src/app/fyle/add-edit-mileage/add-edit-mileage-5.spec.ts +++ b/src/app/fyle/add-edit-mileage/add-edit-mileage-5.spec.ts @@ -257,7 +257,8 @@ export function TestCases5(getTestBed) { spyOn(component, 'getProjects').and.returnValue(of(expectedProjectsResponse[0])); spyOn(component, 'getReports').and.returnValue(of(expectedReportsPaginated[0])); spyOn(component, 'getSelectedCostCenters').and.returnValue(of(costCentersData[0])); - spyOn(component, 'getMileageByVehicleType').and.returnValue(unfilteredMileageRatesData[0]); + const mockMileageRates = cloneDeep(unfilteredMileageRatesData[0]); + spyOn(component, 'getMileageByVehicleType').and.returnValue(mockMileageRates); } function setupMocks() { @@ -768,7 +769,8 @@ export function TestCases5(getTestBed) { const mockOrgSettings = cloneDeep(orgSettingsRes); mockOrgSettings.commute_deduction_settings = { allowed: true, enabled: true }; orgSettingsService.get.and.returnValue(of(mockOrgSettings)); - employeesService.getCommuteDetails.and.returnValue(of(commuteDetailsResponseData)); + const mockCommuteDetailsResponse = cloneDeep(commuteDetailsResponseData); + employeesService.getCommuteDetails.and.returnValue(of(mockCommuteDetailsResponse)); mileageService.getCommuteDeductionOptions.and.returnValue(commuteDeductionOptionsData1); mileageService.isCommuteDeductionEnabled.and.returnValue(true); spyOn(component, 'updateDistanceOnDeductionChange'); diff --git a/src/app/fyle/merge-expense/merge-expense-3.page.spec.ts b/src/app/fyle/merge-expense/merge-expense-3.page.spec.ts index a5ad55cf92..0f5a83108d 100644 --- a/src/app/fyle/merge-expense/merge-expense-3.page.spec.ts +++ b/src/app/fyle/merge-expense/merge-expense-3.page.spec.ts @@ -72,7 +72,7 @@ import { responseAfterAppliedFilter } from 'src/app/core/test-data/custom-inputs import { expenseFieldsMapResponse, expenseFieldsMapResponse4 } from 'src/app/core/mock-data/expense-fields-map.data'; import { dependentFieldsMappingForProject } from 'src/app/core/mock-data/dependent-field-mapping.data'; import { expectedCustomInputFields } from 'src/app/core/mock-data/custom-field.data'; -import { apiCardV2Transactions } from 'src/app/core/mock-data/ccc-api-response'; +import { apiCardV2Transactions } from 'src/app/core/mock-data/ccc-api-response.data'; import { expenseInfoWithoutDefaultExpense, expensesInfo } from 'src/app/core/mock-data/expenses-info.data'; import { customInputData1, customInputsData4 } from 'src/app/core/mock-data/custom-input.data'; import { mergeExpenesesCustomInputsData } from 'src/app/core/mock-data/merge-expenses-custom-inputs.data'; @@ -302,7 +302,8 @@ export function TestCases3(getTestBed) { }); it('should return customInput options correctly', () => { - const customInputOptions = component.generateCustomInputOptions(mergeExpenesesCustomInputsData); + const mockMergeExpensesCustomInputsData = cloneDeep(mergeExpenesesCustomInputsData); + const customInputOptions = component.generateCustomInputOptions(mockMergeExpensesCustomInputsData); expect(mergeExpensesService.formatCustomInputOptions).toHaveBeenCalledOnceWith(optionsDataMergeExpenses); expect(customInputOptions).toEqual({ @@ -334,7 +335,7 @@ export function TestCases3(getTestBed) { it('should set disableFormElements to true if isApprovedAndAbove length is greater than zero', () => { component.setAdvanceOrApprovedAndAbove(expensesInfo); - expect(component.disableFormElements).toEqual(true); + expect(component.disableFormElements).toBeTrue(); }); it('should set disableFormElements to false if isApprovedAndAbove length is zero and isAdvancePresent is false', () => { @@ -342,13 +343,13 @@ export function TestCases3(getTestBed) { const mockExpenseInfo = cloneDeep(expensesInfo); mockExpenseInfo.isAdvancePresent = false; component.setAdvanceOrApprovedAndAbove(mockExpenseInfo); - expect(component.disableFormElements).toEqual(false); + expect(component.disableFormElements).toBeFalse(); }); it('should set disableFormElements to true if expensesInfo.isAdvancePresent is true', () => { mergeExpensesService.isApprovedAndAbove.and.returnValue([]); component.setAdvanceOrApprovedAndAbove(expensesInfo); - expect(component.disableFormElements).toEqual(true); + expect(component.disableFormElements).toBeTrue(); }); }); @@ -361,21 +362,21 @@ export function TestCases3(getTestBed) { it('should call mergeExpensesService.isReportedPresent() once and set isReportedExpensePresent to true if isReported length is greater than zero', () => { component.setIsReported(expensesInfo); expect(mergeExpensesService.isReportedPresent).toHaveBeenCalledOnceWith(expenseList2); - expect(component.isReportedExpensePresent).toEqual(true); + expect(component.isReportedExpensePresent).toBeTrue(); }); it('should set isReportedExpensePresent to false if isReported length is zero', () => { mergeExpensesService.isReportedPresent.and.returnValue([]); component.setIsReported(expensesInfo); - expect(component.isReportedExpensePresent).toEqual(false); + expect(component.isReportedExpensePresent).toBeFalse(); }); it('should set disableFormElements and showReceiptSelection to true if isReportedExpensePresent and expensesInfo.isAdvancePresent is true', () => { component.disableFormElements = false; component.showReceiptSelection = false; component.setIsReported(expensesInfo); - expect(component.disableFormElements).toEqual(true); - expect(component.showReceiptSelection).toEqual(true); + expect(component.disableFormElements).toBeTrue(); + expect(component.showReceiptSelection).toBeTrue(); }); it('should not modify disableFormElements and showReceiptSelection if isReportedExpensePresent is false', () => { @@ -383,8 +384,8 @@ export function TestCases3(getTestBed) { component.showReceiptSelection = false; mergeExpensesService.isReportedPresent.and.returnValue([]); component.setIsReported(expensesInfo); - expect(component.disableFormElements).toEqual(false); - expect(component.showReceiptSelection).toEqual(false); + expect(component.disableFormElements).toBeFalse(); + expect(component.showReceiptSelection).toBeFalse(); }); it('should not modify disableFormElements and showReceiptSelection if expensesInfo.isAdvancePresent is false', () => { @@ -393,8 +394,8 @@ export function TestCases3(getTestBed) { const mockExpenseInfo = cloneDeep(expensesInfo); mockExpenseInfo.isAdvancePresent = false; component.setIsReported(mockExpenseInfo); - expect(component.disableFormElements).toEqual(false); - expect(component.showReceiptSelection).toEqual(false); + expect(component.disableFormElements).toBeFalse(); + expect(component.showReceiptSelection).toBeFalse(); }); }); @@ -423,7 +424,7 @@ export function TestCases3(getTestBed) { component.setInitialExpenseToKeepDetails(expensesInfo, true); expect(mergeExpensesService.isReportedOrAbove).toHaveBeenCalledOnceWith(expensesInfo); expect(component.setIsReported).toHaveBeenCalledOnceWith(expensesInfo); - expect(component.disableExpenseToKeep).toEqual(true); + expect(component.disableExpenseToKeep).toBeTrue(); expect(component.expenseToKeepInfoText).toEqual( 'You are required to keep the expense that has already been submitted.' ); @@ -441,8 +442,8 @@ export function TestCases3(getTestBed) { expect(mergeExpensesService.isMoreThanOneAdvancePresent).toHaveBeenCalledOnceWith(expensesInfo, true); expect(component.setIsReported).not.toHaveBeenCalled(); - expect(component.disableExpenseToKeep).toEqual(false); - expect(component.showReceiptSelection).toEqual(true); + expect(component.disableExpenseToKeep).toBeFalse(); + expect(component.showReceiptSelection).toBeTrue(); expect(component.expenseToKeepInfoText).toEqual( 'You cannot make changes to an expense paid from ‘advance’. Edit each expense separately if you wish to make any changes.' ); @@ -460,8 +461,8 @@ export function TestCases3(getTestBed) { expect(mergeExpensesService.isAdvancePresent).toHaveBeenCalledOnceWith(expensesInfo); expect(component.setIsReported).not.toHaveBeenCalled(); - expect(component.disableExpenseToKeep).toEqual(true); - expect(component.showReceiptSelection).toEqual(false); + expect(component.disableExpenseToKeep).toBeTrue(); + expect(component.showReceiptSelection).toBeFalse(); expect(component.expenseToKeepInfoText).toEqual( 'You are required to keep the expense paid from ‘advance’. Edit each expense separately if you wish to make any changes.' ); diff --git a/src/app/fyle/my-create-report/my-create-report.page.spec.ts b/src/app/fyle/my-create-report/my-create-report.page.spec.ts index 90d3999c9b..e965d77d56 100644 --- a/src/app/fyle/my-create-report/my-create-report.page.spec.ts +++ b/src/app/fyle/my-create-report/my-create-report.page.spec.ts @@ -375,9 +375,10 @@ describe('MyCreateReportPage', () => { it('toggleTransaction(): should toggle selected transaction to unselected', () => { spyOn(component, 'getReportTitle'); - component.toggleTransaction(selectedExpense1); + const mockSelectedExpense = cloneDeep(selectedExpense1); + component.toggleTransaction(mockSelectedExpense); - expect(selectedExpense1.isSelected).toBeFalse(); + expect(mockSelectedExpense.isSelected).toBeFalse(); expect(component.getReportTitle).toHaveBeenCalledTimes(1); }); diff --git a/src/app/fyle/my-profile/employee-details-card/employee-details-card.component.spec.ts b/src/app/fyle/my-profile/employee-details-card/employee-details-card.component.spec.ts index 450ebd62a8..55d6269fb4 100644 --- a/src/app/fyle/my-profile/employee-details-card/employee-details-card.component.spec.ts +++ b/src/app/fyle/my-profile/employee-details-card/employee-details-card.component.spec.ts @@ -6,6 +6,7 @@ import { apiEouRes } from 'src/app/core/mock-data/extended-org-user.data'; import { getTextContent } from 'src/app/core/dom-helpers'; import { getElementBySelector } from 'src/app/core/dom-helpers'; import { click } from 'src/app/core/dom-helpers'; +import { cloneDeep } from 'lodash'; describe('EmployeeDetailsCardComponent', () => { let component: EmployeeDetailsCardComponent; @@ -20,7 +21,8 @@ describe('EmployeeDetailsCardComponent', () => { fixture = TestBed.createComponent(EmployeeDetailsCardComponent); component = fixture.componentInstance; - component.eou = apiEouRes; + const mockApiEouRes = cloneDeep(apiEouRes); + component.eou = mockApiEouRes; fixture.detectChanges(); })); diff --git a/src/app/fyle/my-reports/my-reports.page.spec.ts b/src/app/fyle/my-reports/my-reports.page.spec.ts index 89afdd819f..558b18df87 100644 --- a/src/app/fyle/my-reports/my-reports.page.spec.ts +++ b/src/app/fyle/my-reports/my-reports.page.spec.ts @@ -1237,7 +1237,8 @@ describe('MyReportsPage', () => { }; const expectedAndQuery = `(rp_created_at.gte.${thisMonthRange.from.toISOString()},rp_created_at.lt.${thisMonthRange.to.toISOString()})`; dateService.getThisMonthRange.and.returnValue(thisMonthRange); - component.filters = filter8; + const mockFilter = cloneDeep(filter8); + component.filters = mockFilter; component.generateDateParams(newQueryParams); @@ -1254,7 +1255,8 @@ describe('MyReportsPage', () => { }; const expectedAndQuery = `(rp_created_at.gte.${thisWeekRange.from.toISOString()},rp_created_at.lt.${thisWeekRange.to.toISOString()})`; dateService.getThisWeekRange.and.returnValue(thisWeekRange); - component.filters = filter9; + const mockFilter = cloneDeep(filter9); + component.filters = mockFilter; component.generateDateParams(newQueryParams); @@ -1271,7 +1273,8 @@ describe('MyReportsPage', () => { }; const expectedAndQuery = `(rp_created_at.gte.${lastMonthRange.from.toISOString()},rp_created_at.lt.${lastMonthRange.to.toISOString()})`; dateService.getLastMonthRange.and.returnValue(lastMonthRange); - component.filters = filter10; + const mockFilter = cloneDeep(filter10); + component.filters = mockFilter; component.generateDateParams(newQueryParams); @@ -1282,7 +1285,8 @@ describe('MyReportsPage', () => { it('should not generate date params when date filter is not set', () => { spyOn(component, 'generateCustomDateParams'); const newQueryParams: { or: string[]; and?: string } = { or: [] }; - component.filters = filter11; + const mockFilter = cloneDeep(filter11); + component.filters = mockFilter; component.generateDateParams(newQueryParams); @@ -1292,7 +1296,8 @@ describe('MyReportsPage', () => { it('should convert customDateStart and customDateEnd string to date', () => { spyOn(component, 'generateCustomDateParams'); - component.filters = filter12; + const mockFilter = cloneDeep(filter12); + component.filters = mockFilter; const newQueryParams: { or: string[]; and?: string } = { or: [] }; component.generateDateParams(newQueryParams); @@ -1448,7 +1453,7 @@ describe('MyReportsPage', () => { 'present', 'onWillDismiss', ]); - popoverController.create.and.returnValue(Promise.resolve(cannotDeleteReportPopOverSpy)); + popoverController.create.and.resolveTo(cannotDeleteReportPopOverSpy); const mockErpt = cloneDeep({ ...apiExtendedReportRes[0], rp_state: 'APPROVED' }); component.onDeleteReportClick(mockErpt); @@ -1460,7 +1465,7 @@ describe('MyReportsPage', () => { it('should call the deleteReport and do a refresh if rp_state consist any of DRAFT, APPROVER_PENDING, APPROVER_INQUIRY', fakeAsync(() => { const deleteReportPopoverSpy = jasmine.createSpyObj('deleteReportPopover', ['present', 'onDidDismiss']); deleteReportPopoverSpy.onDidDismiss.and.resolveTo({ data: { status: 'success' } }); - popoverController.create.and.returnValue(Promise.resolve(deleteReportPopoverSpy)); + popoverController.create.and.resolveTo(deleteReportPopoverSpy); spyOn(component, 'doRefresh'); spyOn(component, 'getDeleteReportPopoverParams').and.returnValue(deletePopoverParamsRes); reportService.delete.and.returnValue(of(null)); @@ -1526,7 +1531,7 @@ describe('MyReportsPage', () => { expect(component.simpleSearchText).toEqual(''); expect(inputElement.value).toEqual(''); expect(dispatchEventSpy).toHaveBeenCalledOnceWith(new Event('keyup')); - expect(component.isSearchBarFocused).toEqual(true); + expect(component.isSearchBarFocused).toBeTrue(); }); it('should clear the search text, input value, dispatch keyup event, and toggle search bar focus when called from onSimpleSearchCancel', () => { @@ -1542,7 +1547,7 @@ describe('MyReportsPage', () => { expect(component.simpleSearchText).toEqual(''); expect(inputElement.value).toEqual(''); expect(dispatchEventSpy).toHaveBeenCalledOnceWith(new Event('keyup')); - expect(component.isSearchBarFocused).toEqual(false); + expect(component.isSearchBarFocused).toBeFalse(); }); }); @@ -1562,7 +1567,7 @@ describe('MyReportsPage', () => { inputElement.dispatchEvent(new Event('focus')); - expect(component.isSearchBarFocused).toEqual(true); + expect(component.isSearchBarFocused).toBeTrue(); }); it('onFilterPillsClearAll(): should call clearFilters', () => { @@ -1937,6 +1942,7 @@ describe('MyReportsPage', () => { beforeEach(() => { spyOn(component, 'convertSelectedSortFitlersToFilters'); }); + it('should convert selected filters to corresponding Filters object', () => { const selectedFilters = selectedFilters3; @@ -2408,7 +2414,7 @@ describe('MyReportsPage', () => { ]); spyOn(component, 'generateSelectedFilters').and.returnValue([{ name: 'state', value: 'PENDING' }]); filterPopoverSpy.onWillDismiss.and.resolveTo({ data: selectedFilters1 }); - modalController.create.and.returnValue(Promise.resolve(filterPopoverSpy)); + modalController.create.and.resolveTo(filterPopoverSpy); component.openFilters('State'); tick(200); diff --git a/src/app/fyle/my-view-report/my-view-report.page.spec.ts b/src/app/fyle/my-view-report/my-view-report.page.spec.ts index 6b1120699b..5483771a80 100644 --- a/src/app/fyle/my-view-report/my-view-report.page.spec.ts +++ b/src/app/fyle/my-view-report/my-view-report.page.spec.ts @@ -308,7 +308,8 @@ describe('MyViewReportPage', () => { loaderService.showLoader.and.resolveTo(); reportService.getReport.and.returnValue(of(erpt)); authService.getEou.and.resolveTo(apiEouRes); - statusService.find.and.returnValue(of(newEstatusData1)); + const mockStatusData = cloneDeep(newEstatusData1); + statusService.find.and.returnValue(of(mockStatusData)); statusService.createStatusMap.and.returnValue(systemCommentsWithSt); reportService.getApproversByReportId.and.returnValue(of(approversData1)); expensesService.getReportExpenses.and.returnValue(of(expenseResponseData2)); @@ -401,7 +402,8 @@ describe('MyViewReportPage', () => { loaderService.showLoader.and.resolveTo(); reportService.getReport.and.returnValue(of(null)); authService.getEou.and.resolveTo(apiEouRes); - statusService.find.and.returnValue(of(newEstatusData1)); + const mockStatusData = cloneDeep(newEstatusData1); + statusService.find.and.returnValue(of(mockStatusData)); statusService.createStatusMap.and.returnValue(systemCommentsWithSt); reportService.getApproversByReportId.and.returnValue(of(approversData1)); expensesService.getReportExpenses.and.returnValue(of(expenseResponseData2)); @@ -486,13 +488,14 @@ describe('MyViewReportPage', () => { }); it('updateReportName(): should update report name', () => { - component.erpt$ = of(newReportParam); + const mockErpt = cloneDeep(newReportParam); + component.erpt$ = of(mockErpt); fixture.detectChanges(); reportService.updateReportPurpose.and.returnValue(of(platformReportData)); spyOn(component.loadReportDetails$, 'next'); component.updateReportName('#3: Jul 2023 - Office expense'); - expect(reportService.updateReportPurpose).toHaveBeenCalledOnceWith(newReportParam); + expect(reportService.updateReportPurpose).toHaveBeenCalledOnceWith(mockErpt); expect(component.loadReportDetails$.next).toHaveBeenCalledTimes(1); }); @@ -507,7 +510,7 @@ describe('MyViewReportPage', () => { const editReportNamePopoverSpy = jasmine.createSpyObj('editReportNamePopover', ['present', 'onWillDismiss']); editReportNamePopoverSpy.onWillDismiss.and.resolveTo({ data: { reportName: 'new name' } }); - popoverController.create.and.returnValue(Promise.resolve(editReportNamePopoverSpy)); + popoverController.create.and.resolveTo(editReportNamePopoverSpy); const editReportButton = getElementBySelector(fixture, '.view-reports--card-header__icon') as HTMLElement; click(editReportButton); @@ -533,7 +536,7 @@ describe('MyViewReportPage', () => { const editReportNamePopoverSpy = jasmine.createSpyObj('editReportNamePopover', ['present', 'onWillDismiss']); editReportNamePopoverSpy.onWillDismiss.and.resolveTo(); - popoverController.create.and.returnValue(Promise.resolve(editReportNamePopoverSpy)); + popoverController.create.and.resolveTo(editReportNamePopoverSpy); const editReportButton = getElementBySelector(fixture, '.view-reports--card-header__icon') as HTMLElement; click(editReportButton); @@ -590,7 +593,7 @@ describe('MyViewReportPage', () => { const deleteReportPopoverSpy = jasmine.createSpyObj('deleteReportPopover', ['present', 'onDidDismiss']); deleteReportPopoverSpy.onDidDismiss.and.resolveTo({ data: { status: 'success' } }); - popoverController.create.and.returnValue(Promise.resolve(deleteReportPopoverSpy)); + popoverController.create.and.resolveTo(deleteReportPopoverSpy); component.deleteReportPopup(expectedAllReports[0]); tick(2000); @@ -700,6 +703,7 @@ describe('MyViewReportPage', () => { }, ]); }); + it('should go to edit expense page if canEdit is true', () => { component.canEdit$ = of(true); component.erpt$ = of(expectedAllReports[0]); @@ -828,7 +832,7 @@ describe('MyViewReportPage', () => { email: 'aj@fyle.com', }, }); - modalController.create.and.returnValue(Promise.resolve(shareReportModalSpy)); + modalController.create.and.resolveTo(shareReportModalSpy); reportService.downloadSummaryPdfUrl.and.returnValue(of(null)); matSnackBar.openFromComponent.and.callThrough(); modalProperties.getModalDefaultProperties.and.returnValue(shareReportModalProperties); @@ -863,7 +867,7 @@ describe('MyViewReportPage', () => { const viewInfoModalSpy = jasmine.createSpyObj('viewInfoModal', ['onWillDismiss', 'present']); viewInfoModalSpy.onWillDismiss.and.resolveTo(); - modalController.create.and.returnValue(Promise.resolve(viewInfoModalSpy)); + modalController.create.and.resolveTo(viewInfoModalSpy); modalProperties.getModalDefaultProperties.and.returnValue(fyModalProperties); await component.openViewReportInfoModal(); @@ -964,7 +968,7 @@ describe('MyViewReportPage', () => { }, }); - modalController.create.and.returnValue(Promise.resolve(addExpensesToReportModalSpy)); + modalController.create.and.resolveTo(addExpensesToReportModalSpy); modalProperties.getModalDefaultProperties.and.returnValue(fyModalProperties); spyOn(component, 'addExpensesToReport').and.returnValue(null); @@ -997,7 +1001,7 @@ describe('MyViewReportPage', () => { ]); addExpensesToReportModalSpy.onWillDismiss.and.resolveTo(null); - modalController.create.and.returnValue(Promise.resolve(addExpensesToReportModalSpy)); + modalController.create.and.resolveTo(addExpensesToReportModalSpy); modalProperties.getModalDefaultProperties.and.returnValue(fyModalProperties); spyOn(component, 'addExpensesToReport').and.returnValue(null); diff --git a/src/app/fyle/notifications/notifications.page.spec.ts b/src/app/fyle/notifications/notifications.page.spec.ts index 8a3f6810d9..5170b97d74 100644 --- a/src/app/fyle/notifications/notifications.page.spec.ts +++ b/src/app/fyle/notifications/notifications.page.spec.ts @@ -182,7 +182,8 @@ describe('NotificationsPage', () => { it('removeAdminUnsbscribedEvents(): should remove admin unsubscribe events', fakeAsync(() => { component.orgSettings$ = of(orgSettingsWithUnsubscribeEvent); component.orgSettings = orgSettingsWithUnsubscribeEvent; - component.notificationEvents = cloneDeep(notificationEventsData2); + const mockNotificationEvents = cloneDeep(notificationEventsData2); + component.notificationEvents = cloneDeep(mockNotificationEvents); component.removeAdminUnsbscribedEvents(); tick(500); @@ -191,17 +192,19 @@ describe('NotificationsPage', () => { })); it('updateAdvanceRequestFeatures(): should update advance request features', () => { - component.notificationEvents = notificationEventsData; + const mockNotificationEvents = cloneDeep(notificationEventsData); + component.notificationEvents = mockNotificationEvents; component.orgSettings$ = of(orgSettingsData); component.updateAdvanceRequestFeatures(); - expect(Object.keys(notificationEventsData.features).includes('advances')).toBeFalse(); + expect(Object.keys(mockNotificationEvents.features).includes('advances')).toBeFalse(); }); describe('updateDelegateeNotifyPreference():', () => { it('should set settings to notify delegatee', () => { - component.orgUserSettings = orgUserSettingsData; + const mockOrgUserSettings = cloneDeep(orgUserSettingsData); + component.orgUserSettings = mockOrgUserSettings; component.updateDelegateeNotifyPreference({ value: 'Notify my delegate', @@ -212,7 +215,8 @@ describe('NotificationsPage', () => { }); it('should set settings to notify delegatee and user', () => { - component.orgUserSettings = orgUserSettingsData; + const mockOrgUserSettings = cloneDeep(orgUserSettingsData); + component.orgUserSettings = mockOrgUserSettings; component.updateDelegateeNotifyPreference({ value: 'Notify me and my delegate', @@ -223,7 +227,8 @@ describe('NotificationsPage', () => { }); it('should set settings to notify user', () => { - component.orgUserSettings = orgUserSettingsData; + const mockOrgUserSettings = cloneDeep(orgUserSettingsData); + component.orgUserSettings = mockOrgUserSettings; component.updateDelegateeNotifyPreference({ value: 'Notify me only', diff --git a/src/app/fyle/split-expense/split-expense.page.spec.ts b/src/app/fyle/split-expense/split-expense.page.spec.ts index 7ca3c71530..97067e7893 100644 --- a/src/app/fyle/split-expense/split-expense.page.spec.ts +++ b/src/app/fyle/split-expense/split-expense.page.spec.ts @@ -109,7 +109,7 @@ import { splitExpenseDataWithCostCenter2, splitExpenseDataWithProject, splitExpenseDataWithProject2, -} from 'src/app/core/mock-data/split-expense-data'; +} from 'src/app/core/mock-data/split-expense.data'; import { LaunchDarklyService } from 'src/app/core/services/launch-darkly.service'; import { ProjectsService } from 'src/app/core/services/projects.service'; import { orgUserSettingsData } from 'src/app/core/mock-data/org-user-settings.data'; @@ -605,12 +605,14 @@ describe('SplitExpensePage', () => { describe('uploadNewFiles(): ', () => { it('should upload new files when the type is an image', (done) => { + const mockFileObjectAdv = cloneDeep(fileObjectData5); const mockFileObject = { - ...fileObjectData5, + ...mockFileObjectAdv, name: '000.jpeg', }; - const files = fileObjectAdv; - const dataUrl = fileObjectAdv[0].url; + const mockFile = cloneDeep(fileObjectAdv); + const files = mockFile; + const dataUrl = mockFile[0].url; const attachmentType = 'image'; transactionsOutboxService.fileUpload.and.resolveTo(mockFileObject); @@ -622,12 +624,13 @@ describe('SplitExpensePage', () => { }); it('should upload new files when the type is a png', (done) => { + const mockFileObjectAdv = cloneDeep(fileObjectAdv); const mockFile = { - ...fileObjectAdv[0], + ...mockFileObjectAdv[0], type: 'png', }; const files = [mockFile]; - const dataUrl = fileObjectAdv[0].url; + const dataUrl = mockFileObjectAdv[0].url; const attachmentType = 'image'; transactionsOutboxService.fileUpload.and.resolveTo(fileObjectData5); @@ -639,12 +642,13 @@ describe('SplitExpensePage', () => { }); it('should upload new files when the type is a pdf', (done) => { - const files = [fileObjectAdv1]; + const files = [cloneDeep(fileObjectAdv1)]; + const mockFileObjectAdv = cloneDeep(fileObjectData5); const mockFileObject = { - ...fileObjectData5, + ...mockFileObjectAdv, name: '000.pdf', }; - const dataUrl = fileObjectAdv1.url; + const dataUrl = files[0].url; const attachmentType = 'pdf'; transactionsOutboxService.fileUpload.and.resolveTo(mockFileObject); component.uploadNewFiles(files).subscribe((result) => { @@ -1499,8 +1503,6 @@ describe('SplitExpensePage', () => { const txnDateRes = component.setTransactionDate(mockSplitExpenseForm, '-05:00:00'); expect(txnDateRes).toEqual(mockUTCDate); - const today = new Date(); - expect(dateService.getUTCDate).toHaveBeenCalledOnceWith(today); expect(timezoneService.convertToUtc).toHaveBeenCalledOnceWith(mockDate, '-05:00:00'); }); }); @@ -2073,12 +2075,10 @@ describe('SplitExpensePage', () => { component.unspecifiedCategory = unspecifiedCategory; component.expenseFields = expenseFieldResponse; const splitEtxns = cloneDeep(txnList); - spyOn(component, 'showSplitExpensePolicyViolationsAndMissingFields').and.returnValue( - Promise.resolve({ - action: 'continue', - comments: { '0': 'test comment' }, - }) - ); + spyOn(component, 'showSplitExpensePolicyViolationsAndMissingFields').and.resolveTo({ + action: 'continue', + comments: { '0': 'test comment' }, + }); policyService.checkIfViolationsExist.and.returnValue(true); splitExpenseService.checkIfMissingFieldsExist.and.returnValue(true); splitExpenseService.handlePolicyAndMissingFieldsCheck.and.returnValue( diff --git a/src/app/fyle/team-reports/team-reports-1.page.spec.ts b/src/app/fyle/team-reports/team-reports-1.page.spec.ts index 60b551bf90..69f3d241e9 100644 --- a/src/app/fyle/team-reports/team-reports-1.page.spec.ts +++ b/src/app/fyle/team-reports/team-reports-1.page.spec.ts @@ -104,7 +104,8 @@ export function TestCases1(getTestBed) { reportService.getTeamReports.and.returnValue(of(paginatedPipeValue)); reportService.getTeamReportsCount.and.returnValue(of(20)); mockAddNewFiltersToParams = spyOn(component, 'addNewFiltersToParams'); - mockAddNewFiltersToParams.and.returnValue(tasksQueryParamsWithFiltersData); + const mockTasksQuery = cloneDeep(tasksQueryParamsWithFiltersData); + mockAddNewFiltersToParams.and.returnValue(mockTasksQuery); spyOn(component, 'generateFilterPills').and.returnValue(creditTxnFilterPill); spyOn(component, 'clearFilters'); }); diff --git a/src/app/fyle/view-team-report/view-team-report.page.spec.ts b/src/app/fyle/view-team-report/view-team-report.page.spec.ts index 454df1552d..0772b9eb9f 100644 --- a/src/app/fyle/view-team-report/view-team-report.page.spec.ts +++ b/src/app/fyle/view-team-report/view-team-report.page.spec.ts @@ -240,9 +240,9 @@ describe('ViewTeamReportPageV2', () => { }); it('loadReports(): should load reports', (done) => { - loaderService.showLoader.and.returnValue(Promise.resolve()); + loaderService.showLoader.and.resolveTo(); reportService.getReport.and.returnValue(of(expectedAllReports[0])); - loaderService.hideLoader.and.returnValue(Promise.resolve()); + loaderService.hideLoader.and.resolveTo(); component .loadReports() @@ -304,17 +304,19 @@ describe('ViewTeamReportPageV2', () => { spyOn(component, 'getApprovalSettings').and.returnValue(true); spyOn(component, 'getReportClosureSettings').and.returnValue(true); spyOn(component, 'isUserActiveInCurrentSeqApprovalQueue').and.returnValue(null); - loaderService.showLoader.and.returnValue(Promise.resolve()); + loaderService.showLoader.and.resolveTo(); spyOn(component, 'loadReports').and.returnValue(of(expectedAllReports[0])); - loaderService.hideLoader.and.returnValue(Promise.resolve()); - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); - statusService.find.and.returnValue(of(newEstatusData1)); + loaderService.hideLoader.and.resolveTo(); + authService.getEou.and.resolveTo(apiEouRes); + const mockStatus = cloneDeep(newEstatusData1); + statusService.find.and.returnValue(of(mockStatus)); orgSettingsService.get.and.returnValue(of(orgSettingsData)); statusService.createStatusMap.and.returnValue(systemCommentsWithSt); reportService.getTeamReport.and.returnValue(of(expectedAllReports[0])); + const mockPdfExportData = cloneDeep(pdfExportData1); reportService.getExports.and.returnValue( of({ - results: pdfExportData1, + results: mockPdfExportData, }) ); reportService.getApproversByReportId.and.returnValue(of(approversData1)); @@ -415,17 +417,19 @@ describe('ViewTeamReportPageV2', () => { spyOn(component, 'getApprovalSettings').and.returnValue(false); spyOn(component, 'getReportClosureSettings').and.returnValue(true); spyOn(component, 'isUserActiveInCurrentSeqApprovalQueue').and.returnValue(null); - loaderService.showLoader.and.returnValue(Promise.resolve()); + loaderService.showLoader.and.resolveTo(); spyOn(component, 'loadReports').and.returnValue(of(expectedAllReports[0])); - loaderService.hideLoader.and.returnValue(Promise.resolve()); - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); - statusService.find.and.returnValue(of(newEstatusData1)); + loaderService.hideLoader.and.resolveTo(); + authService.getEou.and.resolveTo(apiEouRes); + const mockStatus = cloneDeep(newEstatusData1); + statusService.find.and.returnValue(of(mockStatus)); orgSettingsService.get.and.returnValue(of(orgSettingsData)); statusService.createStatusMap.and.returnValue(systemCommentsWithSt); reportService.getTeamReport.and.returnValue(of(expectedAllReports[0])); + const mockPdfExportData = cloneDeep(pdfExportData2); reportService.getExports.and.returnValue( of({ - results: pdfExportData2, + results: mockPdfExportData, }) ); reportService.getApproversByReportId.and.returnValue(of(approversData1)); @@ -570,10 +574,10 @@ describe('ViewTeamReportPageV2', () => { }); it('deleteReport(): should delete report', async () => { - popupService.showPopup.and.returnValue(Promise.resolve('primary')); - loaderService.showLoader.and.returnValue(Promise.resolve()); + popupService.showPopup.and.resolveTo('primary'); + loaderService.showLoader.and.resolveTo(); reportService.delete.and.returnValue(of(undefined)); - loaderService.hideLoader.and.returnValue(Promise.resolve()); + loaderService.hideLoader.and.resolveTo(); await component.deleteReport(); @@ -601,15 +605,13 @@ describe('ViewTeamReportPageV2', () => { it('should open the modal and approve the report', async () => { humanizeCurrency.transform.and.callThrough(); const popoverSpy = jasmine.createSpyObj('popover', ['present', 'onWillDismiss']); - popoverSpy.onWillDismiss.and.returnValue( - Promise.resolve({ - data: { - action: 'approve', - }, - }) - ); + popoverSpy.onWillDismiss.and.resolveTo({ + data: { + action: 'approve', + }, + }); - popoverController.create.and.returnValue(Promise.resolve(popoverSpy)); + popoverController.create.and.resolveTo(popoverSpy); reportService.approve.and.returnValue(of(undefined)); refinerService.startSurvey.and.returnValue(null); @@ -745,14 +747,12 @@ describe('ViewTeamReportPageV2', () => { it('shareReport(): should open share report modal', async () => { const popoverSpy = jasmine.createSpyObj('popover', ['present', 'onWillDismiss']); - popoverSpy.onWillDismiss.and.returnValue( - Promise.resolve({ - data: { - email: 'ajn@fyle.in', - }, - }) - ); - popoverController.create.and.returnValue(Promise.resolve(popoverSpy)); + popoverSpy.onWillDismiss.and.resolveTo({ + data: { + email: 'ajn@fyle.in', + }, + }); + popoverController.create.and.resolveTo(popoverSpy); reportService.downloadSummaryPdfUrl.and.returnValue(of({ report_url: 'encodedcontent' })); @@ -780,15 +780,13 @@ describe('ViewTeamReportPageV2', () => { duration: 3000, }; const popoverSpy = jasmine.createSpyObj('popover', ['present', 'onWillDismiss']); - popoverSpy.onWillDismiss.and.returnValue( - Promise.resolve({ - data: { - comment: 'comment', - }, - }) - ); + popoverSpy.onWillDismiss.and.resolveTo({ + data: { + comment: 'comment', + }, + }); - popoverController.create.and.returnValue(Promise.resolve(popoverSpy)); + popoverController.create.and.resolveTo(popoverSpy); reportService.inquire.and.returnValue(of(undefined)); snackbarProperties.setSnackbarProperties.and.returnValue(properties); @@ -823,7 +821,7 @@ describe('ViewTeamReportPageV2', () => { it('openViewReportInfoModal(): should open report info modal', async () => { const viewInfoModalSpy = jasmine.createSpyObj('viewInfoModal', ['onWillDismiss', 'present']); - viewInfoModalSpy.onWillDismiss.and.returnValue(Promise.resolve()); + viewInfoModalSpy.onWillDismiss.and.resolveTo(); const properties = { cssClass: 'fy-modal', @@ -836,7 +834,7 @@ describe('ViewTeamReportPageV2', () => { handle: false, }; - modalController.create.and.returnValue(Promise.resolve(viewInfoModalSpy)); + modalController.create.and.resolveTo(viewInfoModalSpy); modalProperties.getModalDefaultProperties.and.returnValue(properties); await component.openViewReportInfoModal(); @@ -981,13 +979,14 @@ describe('ViewTeamReportPageV2', () => { }); it('updateReportName(): should update report name', () => { - component.erpt$ = of(newReportParam); + const mockErpt = cloneDeep(newReportParam); + component.erpt$ = of(mockErpt); fixture.detectChanges(); reportService.approverUpdateReportPurpose.and.returnValue(of(platformReportData)); spyOn(component.loadReportDetails$, 'next'); component.updateReportName('#3: Jul 2023 - Office expense'); - expect(reportService.approverUpdateReportPurpose).toHaveBeenCalledOnceWith(newReportParam); + expect(reportService.approverUpdateReportPurpose).toHaveBeenCalledOnceWith(mockErpt); expect(component.loadReportDetails$.next).toHaveBeenCalledTimes(1); }); @@ -1000,7 +999,7 @@ describe('ViewTeamReportPageV2', () => { it('should edit report name', fakeAsync(() => { const editReportNamePopoverSpy = jasmine.createSpyObj('editReportNamePopover', ['present', 'onWillDismiss']); editReportNamePopoverSpy.onWillDismiss.and.resolveTo({ data: { reportName: 'new name' } }); - popoverController.create.and.returnValue(Promise.resolve(editReportNamePopoverSpy)); + popoverController.create.and.resolveTo(editReportNamePopoverSpy); component.editReportName(); tick(100); @@ -1018,7 +1017,7 @@ describe('ViewTeamReportPageV2', () => { it('should not edit report name if data does not contain name', fakeAsync(() => { const editReportNamePopoverSpy = jasmine.createSpyObj('editReportNamePopover', ['present', 'onWillDismiss']); editReportNamePopoverSpy.onWillDismiss.and.resolveTo(); - popoverController.create.and.returnValue(Promise.resolve(editReportNamePopoverSpy)); + popoverController.create.and.resolveTo(editReportNamePopoverSpy); component.editReportName(); tick(100); diff --git a/src/app/post-verification/setup-account/setup-account.page.spec.ts b/src/app/post-verification/setup-account/setup-account.page.spec.ts index 71e83a29bc..7f4b8b8fe2 100644 --- a/src/app/post-verification/setup-account/setup-account.page.spec.ts +++ b/src/app/post-verification/setup-account/setup-account.page.spec.ts @@ -96,7 +96,7 @@ describe('SetupAccountPage', () => { networkService.connectivityWatcher.and.returnValue(new EventEmitter()); networkService.isOnline.and.returnValue(of(true)); - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); + authService.getEou.and.resolveTo(apiEouRes); orgService.getCurrentOrg.and.returnValue(of(orgData1[0])); orgSettingsService.get.and.returnValue(of(orgSettingsRes)); orgService.setCurrencyBasedOnIp.and.returnValue(of(orgData1[0])); @@ -115,14 +115,14 @@ describe('SetupAccountPage', () => { component.setupNetworkWatcher(); component.isConnected$.pipe(take(1)).subscribe((connectionStatus) => { - expect(connectionStatus).toEqual(true); + expect(connectionStatus).toBeTrue(); }); })); it('openCurrenySelectionModal(): should open the currency select modal', fakeAsync(() => { const modalSpy = jasmine.createSpyObj('Modal', ['present', 'onWillDismiss']); - modalController.create.and.returnValue(Promise.resolve(modalSpy)); - modalSpy.onWillDismiss.and.returnValue(Promise.resolve({ data: { currency: { shortCode: 'USD' } } })); + modalController.create.and.resolveTo(modalSpy); + modalSpy.onWillDismiss.and.resolveTo({ data: { currency: { shortCode: 'USD' } } }); component.openCurrenySelectionModal(); fixture.detectChanges(); @@ -136,7 +136,8 @@ describe('SetupAccountPage', () => { it('postUser(): should update the password of the user', fakeAsync(() => { orgUserService.postUser.and.returnValue(of(postUserResponse)); - component.eou$ = of(currentEouRes); + const mockEou = cloneDeep(currentEouRes); + component.eou$ = of(mockEou); component.fg.controls.password.setValue('qwerty@123456'); const updatedEou = { id: 'usvKA4X8Ugcr', @@ -149,7 +150,7 @@ describe('SetupAccountPage', () => { }; component.postUser().subscribe(() => { expect(orgUserService.postUser).toHaveBeenCalledOnceWith(updatedEou); - expect(currentEouRes.us).toEqual(updatedEou); + expect(mockEou.us).toEqual(updatedEou); }); })); @@ -173,20 +174,22 @@ describe('SetupAccountPage', () => { describe('saveGuessedMileage():', () => { it('should set the desired mileage value if the org currency is USD', fakeAsync(() => { - orgSettingsService.get.and.returnValue(of(orgSettingsRes)); + const mockOrgSettings = cloneDeep(orgSettingsRes); + orgSettingsService.get.and.returnValue(of(mockOrgSettings)); component.org$ = of(orgData1[0]); orgSettingsService.post.and.returnValue(of(orgSettingsPostData)); component.saveGuessedMileage().subscribe(() => { - expect(orgSettingsRes.mileage.four_wheeler).toBe(0.58); - expect(orgSettingsRes.mileage.unit).toBe('MILES'); - expect(orgSettingsRes.mileage.enabled).toBe(true); - expect(orgSettingsRes.mileage.two_wheeler).toBe(0.58); + expect(mockOrgSettings.mileage.four_wheeler).toBe(0.58); + expect(mockOrgSettings.mileage.unit).toBe('MILES'); + expect(mockOrgSettings.mileage.enabled).toBeTrue(); + expect(mockOrgSettings.mileage.two_wheeler).toBe(0.58); }); - expect(orgSettingsService.post).toHaveBeenCalledOnceWith(orgSettingsRes); + expect(orgSettingsService.post).toHaveBeenCalledOnceWith(mockOrgSettings); })); it('should set the desired mileage value if the org currency is not USD', fakeAsync(() => { - orgSettingsService.get.and.returnValue(of(orgSettingsRes)); + const mockOrgSettings = cloneDeep(orgSettingsRes); + orgSettingsService.get.and.returnValue(of(mockOrgSettings)); const orgData12 = { ...orgData1[0], currency: 'INR', @@ -195,13 +198,13 @@ describe('SetupAccountPage', () => { orgSettingsService.post.and.returnValue(of(orgSettingsPostData)); component.saveGuessedMileage().subscribe(() => { fixture.detectChanges(); - expect(orgSettingsRes.mileage.four_wheeler).toBe(8.0); - expect(orgSettingsRes.mileage.unit).toBe('KM'); - expect(orgSettingsRes.mileage.enabled).toBe(true); - expect(orgSettingsRes.mileage.two_wheeler).toBe(6.0); + expect(mockOrgSettings.mileage.four_wheeler).toBe(8.0); + expect(mockOrgSettings.mileage.unit).toBe('KM'); + expect(mockOrgSettings.mileage.enabled).toBeTrue(); + expect(mockOrgSettings.mileage.two_wheeler).toBe(6.0); }); tick(500); - expect(orgSettingsService.post).toHaveBeenCalledOnceWith(orgSettingsRes); + expect(orgSettingsService.post).toHaveBeenCalledOnceWith(mockOrgSettings); })); }); @@ -211,8 +214,8 @@ describe('SetupAccountPage', () => { spyOn(component, 'postUser').and.returnValue(of(postUserResponse)); spyOn(component, 'postOrg').and.returnValue(of(orgData1[0])); spyOn(component, 'saveGuessedMileage').and.returnValue(of(orgSettingsRes)); - loaderService.showLoader.and.returnValue(Promise.resolve()); - loaderService.hideLoader.and.returnValue(Promise.resolve()); + loaderService.showLoader.and.resolveTo(); + loaderService.hideLoader.and.resolveTo(); authService.refreshEou.and.returnValue(of(eouRes3)); component.fg.setValue({ companyName: 'Acme Inc.', @@ -223,7 +226,7 @@ describe('SetupAccountPage', () => { fixture.detectChanges(); tick(500); expect(component.fg.markAllAsTouched).toHaveBeenCalledTimes(1); - expect(component.fg.valid).toBe(true); + expect(component.fg.valid).toBeTrue(); expect(loaderService.showLoader).toHaveBeenCalledTimes(1); expect(component.postUser).toHaveBeenCalledTimes(1); expect(component.postOrg).toHaveBeenCalledTimes(1); @@ -244,13 +247,13 @@ describe('SetupAccountPage', () => { }); const toastSpy = jasmine.createSpyObj('HTMLIonToastElement', ['present']); - toastSpy.present.and.returnValue(Promise.resolve()); - toastController.create.and.returnValue(Promise.resolve(toastSpy)); + toastSpy.present.and.resolveTo(); + toastController.create.and.resolveTo(toastSpy); component.saveData(); fixture.detectChanges(); tick(500); expect(component.fg.markAllAsTouched).toHaveBeenCalledTimes(1); - expect(component.fg.valid).toBe(false); + expect(component.fg.valid).toBeFalse(); expect(toastController.create).toHaveBeenCalledOnceWith({ message: 'Please fill all required fields to proceed', color: 'danger', diff --git a/src/app/shared/components/comments-history/audit-history/audit-history.component.spec.ts b/src/app/shared/components/comments-history/audit-history/audit-history.component.spec.ts index 793bc009c2..666d0d97ac 100644 --- a/src/app/shared/components/comments-history/audit-history/audit-history.component.spec.ts +++ b/src/app/shared/components/comments-history/audit-history/audit-history.component.spec.ts @@ -15,6 +15,7 @@ import { } from 'src/app/core/test-data/status.service.spec.data'; import { SnakeCaseToSpaceCase } from 'src/app/shared/pipes/snake-case-to-space-case.pipe'; import { getAllElementsBySelector, getElementBySelector, getTextContent } from 'src/app/core/dom-helpers'; +import { cloneDeep } from 'lodash'; describe('AuditHistoryComponent', () => { let component: AuditHistoryComponent; @@ -37,7 +38,8 @@ describe('AuditHistoryComponent', () => { component = fixture.componentInstance; expenseFieldsService = TestBed.inject(ExpenseFieldsService) as jasmine.SpyObj; expenseFieldsService.getAllEnabled.and.returnValue(of(transformedResponse2)); - component.estatuses = estatusSample; + const mockEstatuses = cloneDeep(estatusSample); + component.estatuses = mockEstatuses; spyOn(component, 'hasDetails').and.callThrough(); spyOn(component, 'getAndUpdateProjectName').and.callThrough(); spyOn(component, 'setReimbursable').and.callThrough(); @@ -66,7 +68,7 @@ describe('AuditHistoryComponent', () => { }); it('updateProjectNameKey(): should update project name', () => { - component.estatuses = eStatusWithProjectName; + component.estatuses = cloneDeep(eStatusWithProjectName); fixture.detectChanges(); component.updateProjectNameKey(); @@ -75,7 +77,7 @@ describe('AuditHistoryComponent', () => { }); it('updateProjectNameKey(): should update project name if it already exists', () => { - component.estatuses = eStatusWithProjectName2; + component.estatuses = cloneDeep(eStatusWithProjectName2); fixture.detectChanges(); component.updateProjectNameKey(); @@ -96,7 +98,7 @@ describe('AuditHistoryComponent', () => { }); it('setReimbursable(): should set re-imbursable', () => { - component.estatuses = eStatusWithReimbursible; + component.estatuses = cloneDeep(eStatusWithReimbursible); fixture.detectChanges(); component.setReimbursable(); diff --git a/src/app/shared/components/comments-history/view-comment/view-comment.component.spec.ts b/src/app/shared/components/comments-history/view-comment/view-comment.component.spec.ts index 83c95ff2af..50362b72ab 100644 --- a/src/app/shared/components/comments-history/view-comment/view-comment.component.spec.ts +++ b/src/app/shared/components/comments-history/view-comment/view-comment.component.spec.ts @@ -20,6 +20,7 @@ import { getEstatusApiResponse, updateReponseWithFlattenedEStatus, } from 'src/app/core/test-data/status.service.spec.data'; +import { cloneDeep } from 'lodash'; describe('ViewCommentComponent', () => { let component: ViewCommentComponent; @@ -60,17 +61,18 @@ describe('ViewCommentComponent', () => { ], }).compileComponents(); - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); - statusService.find.and.returnValue(of(apiCommentsResponse)); - statusService.createStatusMap.and.returnValue(updateReponseWithFlattenedEStatus); + authService.getEou.and.resolveTo(apiEouRes); + const mockCommentResponse = cloneDeep(apiCommentsResponse); + statusService.find.and.returnValue(of(mockCommentResponse)); + const mockStatusMap = cloneDeep(updateReponseWithFlattenedEStatus); + statusService.createStatusMap.and.returnValue(mockStatusMap); fixture = TestBed.createComponent(ViewCommentComponent); component = fixture.componentInstance; - component.estatuses$ = of(apiCommentsResponse); + component.estatuses$ = of(mockCommentResponse); component.objectType = 'transactions'; component.objectId = 'tx1oTNwgRdRq'; component.newComment = 'This is a new comment'; - fixture.detectChanges(); })); it('should create', () => { @@ -82,6 +84,7 @@ describe('ViewCommentComponent', () => { const data = { comment: newComment }; component.newComment = newComment; statusService.post.and.returnValue(of(null)); + fixture.detectChanges(); const focusSpy = spyOn(component.commentInput.nativeElement, 'focus'); component.addComment(); @@ -95,8 +98,8 @@ describe('ViewCommentComponent', () => { describe('closeCommentModal():', () => { it('should close the modal if the comment is discarded', fakeAsync(() => { const popOverSpy = jasmine.createSpyObj('HTMLIonPopoverElement', ['present', 'onWillDismiss']); - popoverController.create.and.returnValue(Promise.resolve(popOverSpy)); - popOverSpy.onWillDismiss.and.returnValue(Promise.resolve({ data: { action: 'discard' } })); + popoverController.create.and.resolveTo(popOverSpy); + popOverSpy.onWillDismiss.and.resolveTo({ data: { action: 'discard' } }); component.closeCommentModal(); tick(500); expect(popoverController.create).toHaveBeenCalledOnceWith({ @@ -124,7 +127,7 @@ describe('ViewCommentComponent', () => { component.newComment = null; component.isCommentAdded = true; component.closeCommentModal(); - modalController.dismiss.and.returnValue(Promise.resolve({ data: { updated: true } } as any)); + modalController.dismiss.and.resolveTo({ data: { updated: true } } as any); expect(modalController.dismiss).toHaveBeenCalled(); expect(trackingService.addComment).toHaveBeenCalledTimes(1); }); @@ -133,7 +136,7 @@ describe('ViewCommentComponent', () => { component.newComment = null; component.isCommentAdded = false; component.closeCommentModal(); - modalController.dismiss.and.returnValue(Promise.resolve(Promise.resolve({ data: { updated: false } } as any))); + modalController.dismiss.and.resolveTo({ data: { updated: false } } as any); expect(modalController.dismiss).toHaveBeenCalled(); expect(trackingService.viewComment).toHaveBeenCalledTimes(1); }); @@ -213,8 +216,9 @@ describe('ViewCommentComponent', () => { st_org_user_id: 'POLICY', })); + spyOn(component, 'setContentScrollToBottom'); const totalCommentsCount = 33; - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); + authService.getEou.and.resolveTo(apiEouRes); statusService.find.and.returnValue(of(updatedApiCommentsResponse)); statusService.createStatusMap.and.returnValue(updateReponseWithFlattenedEStatus); component.ngOnInit(); @@ -236,6 +240,7 @@ describe('ViewCommentComponent', () => { })); it('should set type correctly for a given objectType', fakeAsync(() => { + spyOn(component, 'setContentScrollToBottom'); component.objectType = 'Expenses'; component.ngOnInit(); tick(500); diff --git a/src/app/shared/components/comments-history/view-comment/view-comment.component.ts b/src/app/shared/components/comments-history/view-comment/view-comment.component.ts index 7a43d405f2..44d45ba278 100644 --- a/src/app/shared/components/comments-history/view-comment/view-comment.component.ts +++ b/src/app/shared/components/comments-history/view-comment/view-comment.component.ts @@ -60,6 +60,10 @@ export class ViewCommentComponent implements OnInit { public platform: Platform ) {} + setContentScrollToBottom(): void { + this.content.scrollToBottom(500); + } + addComment() { if (this.newComment) { const data = { @@ -170,7 +174,7 @@ export class ViewCommentComponent implements OnInit { map((res) => res.sort((a, b) => a.st_created_at.valueOf() - b.st_created_at.valueOf())), finalize(() => { setTimeout(() => { - this.content.scrollToBottom(500); + this.setContentScrollToBottom(); }, 500); }) ) diff --git a/src/app/shared/components/expenses-card-v2/expenses-card.component.spec.ts b/src/app/shared/components/expenses-card-v2/expenses-card.component.spec.ts index 554478303e..668f73f16c 100644 --- a/src/app/shared/components/expenses-card-v2/expenses-card.component.spec.ts +++ b/src/app/shared/components/expenses-card-v2/expenses-card.component.spec.ts @@ -275,7 +275,7 @@ describe('ExpensesCardComponent', () => { }; component.getReceipt(); fixture.detectChanges(); - expect(component.isReceiptPresent).toBe(true); + expect(component.isReceiptPresent).toBeTrue(); }); }); @@ -629,10 +629,11 @@ describe('ExpensesCardComponent', () => { }); it('matchReceiptWithEtxn(): match the receipt with the transactions', () => { - component.matchReceiptWithEtxn(fileObjectData); + const mockFileObject = cloneDeep(fileObjectData); + component.matchReceiptWithEtxn(mockFileObject); expect(component.expense.file_ids).toBeDefined(); - expect(component.expense.file_ids).toContain(fileObjectData.id); - expect(fileObjectData.transaction_id).toBe(component.expense.id); + expect(component.expense.file_ids).toContain(mockFileObject.id); + expect(mockFileObject.transaction_id).toBe(component.expense.id); }); describe('canAddAttchment():', () => { @@ -679,7 +680,7 @@ describe('ExpensesCardComponent', () => { }; fileService.getAttachmentType.and.returnValue(attachmentType); - transactionsOutboxService.fileUpload.and.returnValue(Promise.resolve(fileObj)); + transactionsOutboxService.fileUpload.and.resolveTo(fileObj); fileService.post.and.returnValue(of(fileObjectData)); spyOn(component, 'matchReceiptWithEtxn').and.callThrough(); @@ -700,7 +701,7 @@ describe('ExpensesCardComponent', () => { it('should add attachment when file is selected', fakeAsync(() => { const dataUrl = '...'; const mockFile = new File(['file contents'], 'test.png', { type: 'image/png' }); - fileService.readFile.and.returnValue(Promise.resolve(dataUrl)); + fileService.readFile.and.resolveTo(dataUrl); const mockNativeElement = { files: [mockFile], }; @@ -735,7 +736,7 @@ describe('ExpensesCardComponent', () => { it('showSizeLimitExceededPopover', fakeAsync(() => { const popOverSpy = jasmine.createSpyObj('HTMLIonPopoverElement', ['present']); - popoverController.create.and.returnValue(Promise.resolve(popOverSpy)); + popoverController.create.and.resolveTo(popOverSpy); component.showSizeLimitExceededPopover(); tick(500); @@ -794,8 +795,8 @@ describe('ExpensesCardComponent', () => { }; spyOn(component, 'canAddAttachment').and.returnValue(true); const popOverSpy = jasmine.createSpyObj('HTMLIonPopoverElement', ['present', 'onWillDismiss']); - popoverController.create.and.returnValue(Promise.resolve(popOverSpy)); - popOverSpy.onWillDismiss.and.returnValue(Promise.resolve(receiptDetails)); + popoverController.create.and.resolveTo(popOverSpy); + popOverSpy.onWillDismiss.and.resolveTo(receiptDetails); component.addAttachments(event as any); fixture.detectChanges(); @@ -833,11 +834,11 @@ describe('ExpensesCardComponent', () => { spyOn(component, 'attachReceipt'); spyOn(component, 'canAddAttachment').and.returnValue(true); const popOverSpy = jasmine.createSpyObj('HTMLIonPopoverElement', ['present', 'onWillDismiss']); - popoverController.create.and.returnValue(Promise.resolve(popOverSpy)); - popOverSpy.onWillDismiss.and.returnValue(Promise.resolve(dataRes)); + popoverController.create.and.resolveTo(popOverSpy); + popOverSpy.onWillDismiss.and.resolveTo(dataRes); const captureReceiptModalSpy = jasmine.createSpyObj('HTMLIonModalElement', ['present', 'onWillDismiss']); - modalController.create.and.returnValue(Promise.resolve(captureReceiptModalSpy)); - captureReceiptModalSpy.onWillDismiss.and.returnValue(Promise.resolve(dataRes)); + modalController.create.and.resolveTo(captureReceiptModalSpy); + captureReceiptModalSpy.onWillDismiss.and.resolveTo(dataRes); fileService.getImageTypeFromDataUrl.and.returnValue('png'); component.addAttachments(event as any); @@ -878,7 +879,7 @@ describe('ExpensesCardComponent', () => { component.setupNetworkWatcher(); component.isConnected$.pipe(take(1)).subscribe((connectionStatus) => { - expect(connectionStatus).toEqual(true); + expect(connectionStatus).toBeTrue(); }); })); diff --git a/src/app/shared/components/expenses-card/expenses-card.component.spec.ts b/src/app/shared/components/expenses-card/expenses-card.component.spec.ts index 65dbc23f1e..4c890152c8 100644 --- a/src/app/shared/components/expenses-card/expenses-card.component.spec.ts +++ b/src/app/shared/components/expenses-card/expenses-card.component.spec.ts @@ -602,10 +602,11 @@ describe('ExpensesCardComponent', () => { }); it('matchReceiptWithEtxn(): match the receipt with the transactions', () => { - component.matchReceiptWithEtxn(fileObjectData); + const mockFileObj = cloneDeep(fileObjectData); + component.matchReceiptWithEtxn(mockFileObj); expect(component.expense.tx_file_ids).toBeDefined(); - expect(component.expense.tx_file_ids).toContain(fileObjectData.id); - expect(fileObjectData.transaction_id).toBe(component.expense.tx_id); + expect(component.expense.tx_file_ids).toContain(mockFileObj.id); + expect(mockFileObj.transaction_id).toBe(component.expense.tx_id); }); describe('canAddAttchment():', () => { @@ -652,7 +653,7 @@ describe('ExpensesCardComponent', () => { }; fileService.getAttachmentType.and.returnValue(attachmentType); - transactionsOutboxService.fileUpload.and.returnValue(Promise.resolve(fileObj)); + transactionsOutboxService.fileUpload.and.resolveTo(fileObj); fileService.post.and.returnValue(of(fileObjectData)); spyOn(component, 'matchReceiptWithEtxn').and.callThrough(); @@ -672,7 +673,7 @@ describe('ExpensesCardComponent', () => { it('onFileUpload(): should add attachment when file is selected', fakeAsync(() => { const dataUrl = '...'; const mockFile = new File(['file contents'], 'test.png', { type: 'image/png' }); - fileService.readFile.and.returnValue(Promise.resolve(dataUrl)); + fileService.readFile.and.resolveTo(dataUrl); const mockNativeElement = { files: [mockFile], }; @@ -731,8 +732,8 @@ describe('ExpensesCardComponent', () => { }; spyOn(component, 'canAddAttachment').and.returnValue(true); const popOverSpy = jasmine.createSpyObj('HTMLIonPopoverElement', ['present', 'onWillDismiss']); - popoverController.create.and.returnValue(Promise.resolve(popOverSpy)); - popOverSpy.onWillDismiss.and.returnValue(Promise.resolve(receiptDetails)); + popoverController.create.and.resolveTo(popOverSpy); + popOverSpy.onWillDismiss.and.resolveTo(receiptDetails); component.addAttachments(event as any); fixture.detectChanges(); @@ -770,11 +771,11 @@ describe('ExpensesCardComponent', () => { spyOn(component, 'attachReceipt'); spyOn(component, 'canAddAttachment').and.returnValue(true); const popOverSpy = jasmine.createSpyObj('HTMLIonPopoverElement', ['present', 'onWillDismiss']); - popoverController.create.and.returnValue(Promise.resolve(popOverSpy)); - popOverSpy.onWillDismiss.and.returnValue(Promise.resolve(dataRes)); + popoverController.create.and.resolveTo(popOverSpy); + popOverSpy.onWillDismiss.and.resolveTo(dataRes); const captureReceiptModalSpy = jasmine.createSpyObj('HTMLIonModalElement', ['present', 'onWillDismiss']); - modalController.create.and.returnValue(Promise.resolve(captureReceiptModalSpy)); - captureReceiptModalSpy.onWillDismiss.and.returnValue(Promise.resolve(dataRes)); + modalController.create.and.resolveTo(captureReceiptModalSpy); + captureReceiptModalSpy.onWillDismiss.and.resolveTo(dataRes); fileService.getImageTypeFromDataUrl.and.returnValue('png'); component.addAttachments(event as any); @@ -815,7 +816,7 @@ describe('ExpensesCardComponent', () => { component.setupNetworkWatcher(); component.isConnected$.pipe(take(1)).subscribe((connectionStatus) => { - expect(connectionStatus).toEqual(true); + expect(connectionStatus).toBeTrue(); }); })); diff --git a/src/app/shared/components/fy-approver/add-approvers-popover/approver-dialog/approver-dialog.component.spec.ts b/src/app/shared/components/fy-approver/add-approvers-popover/approver-dialog/approver-dialog.component.spec.ts index 874627d7d6..3494038d7d 100644 --- a/src/app/shared/components/fy-approver/add-approvers-popover/approver-dialog/approver-dialog.component.spec.ts +++ b/src/app/shared/components/fy-approver/add-approvers-popover/approver-dialog/approver-dialog.component.spec.ts @@ -12,6 +12,7 @@ import { of } from 'rxjs'; import { employeesParamsRes } from 'src/app/core/test-data/org-user.service.spec.data'; import { MatCheckboxModule } from '@angular/material/checkbox'; import { click, getAllElementsBySelector, getElementBySelector, getTextContent } from 'src/app/core/dom-helpers'; +import { cloneDeep } from 'lodash'; describe('ApproverDialogComponent', () => { let component: ApproverDialogComponent; @@ -91,13 +92,14 @@ describe('ApproverDialogComponent', () => { orgUserService = TestBed.inject(OrgUserService) as jasmine.SpyObj; loaderService = TestBed.inject(LoaderService) as jasmine.SpyObj; - component.initialApproverList = approvers; + component.initialApproverList = cloneDeep(approvers); component.approverEmailsList = ['jay.b@fyle.in', 'ajain@fyle.in']; - orgUserService.getEmployeesBySearch.and.returnValue(of(employeesParamsRes.data)); - loaderService.showLoader.and.returnValue(Promise.resolve(null)); - loaderService.hideLoader.and.returnValue(Promise.resolve(null)); + const employeesData = cloneDeep(employeesParamsRes.data); + orgUserService.getEmployeesBySearch.and.returnValue(of(employeesData)); + loaderService.showLoader.and.resolveTo(null); + loaderService.hideLoader.and.resolveTo(null); fixture.detectChanges(); })); @@ -162,7 +164,7 @@ describe('ApproverDialogComponent', () => { expect(component.getSelectedApproversDict).toHaveBeenCalledTimes(1); expect(component.selectedApproversList.length).toEqual(3); - expect(component.areApproversAdded).toEqual(false); + expect(component.areApproversAdded).toBeFalse(); }); it('should remove an unchecked approver', () => { @@ -191,7 +193,7 @@ describe('ApproverDialogComponent', () => { expect(component.getSelectedApproversDict).toHaveBeenCalledTimes(1); expect(component.selectedApproversList.length).toEqual(0); - expect(component.areApproversAdded).toEqual(true); + expect(component.areApproversAdded).toBeTrue(); }); }); @@ -211,8 +213,8 @@ describe('ApproverDialogComponent', () => { describe('getDefaultUsersList():', () => { it(' should get default user list', fakeAsync(() => { orgUserService.getEmployeesBySearch.and.returnValue(of(employeesParamsRes.data)); - loaderService.showLoader.and.returnValue(Promise.resolve(null)); - loaderService.hideLoader.and.returnValue(Promise.resolve(null)); + loaderService.showLoader.and.resolveTo(null); + loaderService.hideLoader.and.resolveTo(null); const params = { order: 'us_full_name.asc,us_email.asc,ou_id', @@ -229,8 +231,8 @@ describe('ApproverDialogComponent', () => { it('if approver email list is empty', () => { component.approverEmailsList = []; orgUserService.getEmployeesBySearch.and.returnValue(of(employeesParamsRes.data)); - loaderService.showLoader.and.returnValue(Promise.resolve(null)); - loaderService.hideLoader.and.returnValue(Promise.resolve(null)); + loaderService.showLoader.and.resolveTo(null); + loaderService.hideLoader.and.resolveTo(null); fixture.detectChanges(); const params = { @@ -247,7 +249,8 @@ describe('ApproverDialogComponent', () => { }); it('getSearchedUsersList(): get users list from search text', (done) => { - orgUserService.getEmployeesBySearch.and.returnValue(of(employeesParamsRes.data)); + const employeesData = cloneDeep(employeesParamsRes.data); + orgUserService.getEmployeesBySearch.and.returnValue(of(employeesData)); component.getSearchedUsersList('text').subscribe((res) => { expect(res).toEqual([ diff --git a/src/app/shared/components/fy-userlist/fy-userlist-modal/fy-userlist-modal.component.spec.ts b/src/app/shared/components/fy-userlist/fy-userlist-modal/fy-userlist-modal.component.spec.ts index 65ef7f4c97..147cac8a64 100644 --- a/src/app/shared/components/fy-userlist/fy-userlist-modal/fy-userlist-modal.component.spec.ts +++ b/src/app/shared/components/fy-userlist/fy-userlist-modal/fy-userlist-modal.component.spec.ts @@ -21,6 +21,7 @@ import { MatCheckboxModule } from '@angular/material/checkbox'; import { getElementBySelector } from 'src/app/core/dom-helpers'; import { Employee } from 'src/app/core/models/spender/employee.model'; import { By } from '@angular/platform-browser'; +import { cloneDeep } from 'lodash'; describe('FyUserlistModalComponent', () => { let component: FyUserlistModalComponent; @@ -59,18 +60,19 @@ describe('FyUserlistModalComponent', () => { orgUserService = TestBed.inject(OrgUserService) as jasmine.SpyObj; loaderService = TestBed.inject(LoaderService) as jasmine.SpyObj; - orgUserService.getEmployeesBySearch.and.returnValue(of(employeesParamsRes.data)); + const employeesData = cloneDeep(employeesRes.data); + orgUserService.getEmployeesBySearch.and.returnValue(of(employeesData)); fixture = TestBed.createComponent(FyUserlistModalComponent); component = fixture.componentInstance; component.value = 'test value'; - component.currentSelections = [ + component.currentSelections = cloneDeep([ 'ajain+12+12+1@fyle.in', 'ajain+12121212@fyle.in', 'aaaaaaa@aaaabbbb.com', 'aaaaasdjskjd@sdsd.com', 'kawaljeet.ravi22@gmail.com', 'abcdefg@somemail.com', - ]; + ]); fixture.detectChanges(); })); @@ -191,7 +193,8 @@ describe('FyUserlistModalComponent', () => { 'in.(ajain+12+12+1@fyle.in,ajain+12121212@fyle.in,aaaaaaa@aaaabbbb.com,aaaaasdjskjd@sdsd.com,kawaljeet.ravi22@gmail.com,abcdefg@somemail.com)', }; - orgUserService.getEmployeesBySearch.and.returnValue(of(employeesParamsRes.data)); + const employeesData = cloneDeep(employeesParamsRes.data); + orgUserService.getEmployeesBySearch.and.returnValue(of(employeesData)); component.getDefaultUsersList().subscribe((res) => { fixture.detectChanges(); expect(res).toEqual(searchedUserListRes); @@ -213,12 +216,13 @@ describe('FyUserlistModalComponent', () => { }); it('getSearchedUsersList(): should get the searched user list', fakeAsync(() => { - const params: any = { + const params = { limit: 20, order: 'us_full_name.asc,us_email.asc,ou_id', or: '(us_email.ilike.*ajain+12+12+1@fyle.in*,us_full_name.ilike.*ajain+12+12+1@fyle.in*)', }; - orgUserService.getEmployeesBySearch.and.returnValue(of(employeesParamsRes.data)); + const employeesData = cloneDeep(employeesParamsRes.data); + orgUserService.getEmployeesBySearch.and.returnValue(of(employeesData)); component.getSearchedUsersList('ajain+12+12+1@fyle.in').subscribe((res) => { fixture.detectChanges(); expect(res).toEqual(searchedUserListRes); @@ -295,24 +299,27 @@ describe('FyUserlistModalComponent', () => { describe('getUsersList():', () => { it('should return searched user list if searchText is provided', fakeAsync(() => { const searchText = 'ajain'; - const getSearchedUsersListSpy = spyOn(component, 'getSearchedUsersList').and.returnValue(of(searchedUserListRes)); + const mockUsersList = cloneDeep(searchedUserListRes); + const getSearchedUsersListSpy = spyOn(component, 'getSearchedUsersList').and.returnValue(of(mockUsersList)); const result$ = component.getUsersList(searchText); fixture.detectChanges(); expect(component.isLoading).toBeTrue(); expect(getSearchedUsersListSpy).toHaveBeenCalledOnceWith(searchText); result$.subscribe((res) => { - expect(res).toEqual(searchedUserListRes); + expect(res).toEqual(mockUsersList); }); tick(500); })); it('should return default users list if searchText is not provided', fakeAsync(() => { - const getDefaultUserListSpy = spyOn(component, 'getDefaultUsersList').and.returnValue(of(searchedUserListRes)); + const mockUsersList = cloneDeep(searchedUserListRes); + spyOn(component, 'getSearchedUsersList').and.returnValue(of([])); + const getDefaultUserListSpy = spyOn(component, 'getDefaultUsersList').and.returnValue(of(mockUsersList)); const result$ = component.getUsersList(''); fixture.detectChanges(); result$.subscribe((res) => { expect(component.isLoading).toBeTrue(); - expect(res).toEqual(searchedUserListRes); + expect(res).toEqual(mockUsersList); expect(getDefaultUserListSpy).toHaveBeenCalledTimes(1); }); tick(500); diff --git a/src/app/shared/components/route-selector/route-selector.component.spec.ts b/src/app/shared/components/route-selector/route-selector.component.spec.ts index 851a46d397..c76bc2f508 100644 --- a/src/app/shared/components/route-selector/route-selector.component.spec.ts +++ b/src/app/shared/components/route-selector/route-selector.component.spec.ts @@ -14,6 +14,7 @@ import { MatIconTestingModule } from '@angular/material/icon/testing'; import { MatIconModule } from '@angular/material/icon'; import { click, getElementBySelector, getTextContent } from 'src/app/core/dom-helpers'; import { By } from '@angular/platform-browser'; +import { cloneDeep } from 'lodash'; describe('RouteSelectorComponent', () => { let component: RouteSelectorComponent; @@ -44,7 +45,8 @@ describe('RouteSelectorComponent', () => { component = fixture.componentInstance; fb = TestBed.inject(FormBuilder) as jasmine.SpyObj; modalController = TestBed.inject(ModalController) as jasmine.SpyObj; - component.mileageConfig = orgSettingsRes.mileage; + const mockOrgSettings = cloneDeep(orgSettingsRes); + component.mileageConfig = mockOrgSettings.mileage; component.formInitialized = true; component.onChangeSub = of(null).subscribe(); component.form = fb.group({ @@ -92,7 +94,7 @@ describe('RouteSelectorComponent', () => { }); expect(component.mileageLocations.length).toEqual(mileageLocationData1.length); expect(component.form.controls.distance.value).toEqual(20.0); - expect(component.form.controls.roundTrip.value).toEqual(true); + expect(component.form.controls.roundTrip.value).toBeTrue(); }); it('writeValue(): should write value to the form group', () => { @@ -261,7 +263,8 @@ describe('RouteSelectorComponent', () => { describe('onTxnFieldsChange():', () => { beforeEach(() => { spyOn(component, 'ngOnChanges'); - component.txnFields = expenseFieldsMapResponse3; + const mockExpenseFieldsMapResponse = cloneDeep(expenseFieldsMapResponse3); + component.txnFields = mockExpenseFieldsMapResponse; }); it('should update form validators', () => { diff --git a/src/app/shared/components/sidemenu/sidemenu-content/sidemenu-content.component.spec.ts b/src/app/shared/components/sidemenu/sidemenu-content/sidemenu-content.component.spec.ts index c92db1adcb..08ff944861 100644 --- a/src/app/shared/components/sidemenu/sidemenu-content/sidemenu-content.component.spec.ts +++ b/src/app/shared/components/sidemenu/sidemenu-content/sidemenu-content.component.spec.ts @@ -14,6 +14,7 @@ import { sidemenuItemData4, } from 'src/app/core/mock-data/sidemenu-item.data'; import { globalCacheBusterNotifier } from 'ts-cacheable'; +import { cloneDeep } from 'lodash'; describe('SidemenuContentComponent', () => { let component: SidemenuContentComponent; @@ -68,23 +69,25 @@ describe('SidemenuContentComponent', () => { describe('goToRoute():', () => { it('should call trackingService.menuItemClicked with correct argument', () => { - component.goToRoute(sidemenuItemData1); + const mockSideMenuItemData = cloneDeep(sidemenuItemData1); + component.goToRoute(mockSideMenuItemData); fixture.detectChanges(); - expect(trackingService.menuItemClicked).toHaveBeenCalledOnceWith({ option: sidemenuItemData1.title }); + expect(trackingService.menuItemClicked).toHaveBeenCalledOnceWith({ option: mockSideMenuItemData.title }); }); it('should toggle isDropdownOpen property when sidemenu item has dropdown options', () => { - component.goToRoute(sidemenuItemData2); + const mockSideMenuItemData = cloneDeep(sidemenuItemData2); + component.goToRoute(mockSideMenuItemData); fixture.detectChanges(); - expect(sidemenuItemData2.isDropdownOpen).toBe(true); // initial click should open dropdown - component.goToRoute(sidemenuItemData2); + expect(mockSideMenuItemData.isDropdownOpen).toBeTrue(); // initial click should open dropdown + component.goToRoute(mockSideMenuItemData); fixture.detectChanges(); - expect(sidemenuItemData2.isDropdownOpen).toBe(false); // second click should close dropdown + expect(mockSideMenuItemData.isDropdownOpen).toBeFalse(); // second click should close dropdown }); it('should close the menucontroller when sidemenu item does not have dropdown options', () => { component.goToRoute(sidemenuItemData1); - expect(sidemenuItemData2.isDropdownOpen).toBe(false); + expect(sidemenuItemData2.isDropdownOpen).toBeFalse(); expect(menuController.close).toHaveBeenCalledTimes(1); }); diff --git a/src/app/shared/components/virtual-select/virtual-select-modal/virtual-select-modal.component.spec.ts b/src/app/shared/components/virtual-select/virtual-select-modal/virtual-select-modal.component.spec.ts index a529b49459..d5f808a238 100644 --- a/src/app/shared/components/virtual-select/virtual-select-modal/virtual-select-modal.component.spec.ts +++ b/src/app/shared/components/virtual-select/virtual-select-modal/virtual-select-modal.component.spec.ts @@ -197,7 +197,7 @@ describe('VirtualSelectModalComponent', () => { it('onElementSelect(): should call recentlocalstorage service and dismiss the modal', () => { component.cacheName = 'cache1'; - const option = virtualSelectOptionData4[1]; + const option = cloneDeep(virtualSelectOptionData4[1]); component.onElementSelect(option); expect(recentLocalStorageItemsService.post).toHaveBeenCalledOnceWith('cache1', option, 'label'); expect(modalController.dismiss).toHaveBeenCalledOnceWith(option);