@accounter/server 0.0.9-alpha-20251210173721-a5bb944d9abd3f354daf897072b78bea4d8269c9 → 0.0.9-alpha-20251210174843-5565e7453eaaa611b548e0b47b3e32c6bd978732
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +21 -5
- package/dist/server/src/__tests__/helpers/db-setup.d.ts +0 -1
- package/dist/server/src/__tests__/helpers/db-setup.js +0 -2
- package/dist/server/src/__tests__/helpers/db-setup.js.map +1 -1
- package/dist/server/src/__tests__/helpers/seed-helpers.business.test.js +23 -31
- package/dist/server/src/__tests__/helpers/seed-helpers.business.test.js.map +1 -1
- package/dist/server/src/__tests__/helpers/seed-helpers.concurrent.test.js +8 -8
- package/dist/server/src/__tests__/helpers/seed-helpers.concurrent.test.js.map +1 -1
- package/dist/server/src/__tests__/helpers/seed-helpers.financial-entity.test.js +41 -50
- package/dist/server/src/__tests__/helpers/seed-helpers.financial-entity.test.js.map +1 -1
- package/dist/server/src/__tests__/helpers/seed-helpers.tax-category.test.js +23 -31
- package/dist/server/src/__tests__/helpers/seed-helpers.tax-category.test.js.map +1 -1
- package/dist/server/src/__tests__/helpers/test-db-config.js +1 -1
- package/dist/server/src/__tests__/helpers/test-db-config.js.map +1 -1
- package/dist/server/src/__tests__/seed-admin-context.integration.test.js +128 -131
- package/dist/server/src/__tests__/seed-admin-context.integration.test.js.map +1 -1
- package/dist/server/src/modules/accountant-approval/resolvers/accountant-approval.resolver.js +2 -2
- package/dist/server/src/modules/accountant-approval/resolvers/accountant-approval.resolver.js.map +1 -1
- package/dist/server/src/modules/admin-context/providers/admin-context.provider.d.ts +1 -1
- package/dist/server/src/modules/admin-context/providers/admin-context.provider.js +1 -1
- package/dist/server/src/modules/admin-context/providers/admin-context.provider.js.map +1 -1
- package/dist/server/src/modules/admin-context/resolvers/admin-context.resolvers.js +1 -1
- package/dist/server/src/modules/admin-context/resolvers/admin-context.resolvers.js.map +1 -1
- package/dist/server/src/modules/app-providers/gmail-listener/gmail-service.provider.d.ts +3 -3
- package/dist/server/src/modules/app-providers/gmail-listener/gmail-service.provider.js +5 -5
- package/dist/server/src/modules/app-providers/gmail-listener/gmail-service.provider.js.map +1 -1
- package/dist/server/src/modules/bank-deposits/providers/bank-deposit-transactions.provider.d.ts +2 -2
- package/dist/server/src/modules/bank-deposits/providers/bank-deposit-transactions.provider.js +3 -3
- package/dist/server/src/modules/bank-deposits/providers/bank-deposit-transactions.provider.js.map +1 -1
- package/dist/server/src/modules/bank-deposits/resolvers/bank-deposit-transactions.resolver.js +1 -1
- package/dist/server/src/modules/bank-deposits/resolvers/bank-deposit-transactions.resolver.js.map +1 -1
- package/dist/server/src/modules/business-trips/helpers/business-trip-report.helper.js +4 -4
- package/dist/server/src/modules/business-trips/helpers/business-trip-report.helper.js.map +1 -1
- package/dist/server/src/modules/business-trips/helpers/business-trips-expenses.helper.d.ts +1 -1
- package/dist/server/src/modules/business-trips/helpers/business-trips-expenses.helper.js +5 -5
- package/dist/server/src/modules/business-trips/helpers/business-trips-expenses.helper.js.map +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-attendees.provider.d.ts +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-attendees.provider.js +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-attendees.provider.js.map +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-employee-payments.provider.d.ts +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-employee-payments.provider.js +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-employee-payments.provider.js.map +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-accommodations.provider.d.ts +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-accommodations.provider.js +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-accommodations.provider.js.map +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-car-rental.provider.d.ts +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-car-rental.provider.js +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-car-rental.provider.js.map +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-flights.provider.d.ts +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-flights.provider.js +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-flights.provider.js.map +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-other.provider.d.ts +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-other.provider.js +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-other.provider.js.map +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-transactions-match.provider.d.ts +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-transactions-match.provider.js +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-transactions-match.provider.js.map +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-travel-and-subsistence.provider.d.ts +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-travel-and-subsistence.provider.js +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses-travel-and-subsistence.provider.js.map +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses.provider.d.ts +3 -3
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses.provider.js +2 -2
- package/dist/server/src/modules/business-trips/providers/business-trips-expenses.provider.js.map +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-tax-variables.provider.d.ts +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-tax-variables.provider.js +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips-tax-variables.provider.js.map +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips.provider.d.ts +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips.provider.js +1 -1
- package/dist/server/src/modules/business-trips/providers/business-trips.provider.js.map +1 -1
- package/dist/server/src/modules/business-trips/resolvers/business-trip-attendees.resolver.js.map +1 -1
- package/dist/server/src/modules/business-trips/resolvers/business-trips-expenses.resolver.js +1 -1
- package/dist/server/src/modules/business-trips/resolvers/business-trips-expenses.resolver.js.map +1 -1
- package/dist/server/src/modules/business-trips/resolvers/business-trips.resolver.js +2 -2
- package/dist/server/src/modules/business-trips/resolvers/business-trips.resolver.js.map +1 -1
- package/dist/server/src/modules/business-trips/resolvers/common.js +6 -6
- package/dist/server/src/modules/business-trips/resolvers/common.js.map +1 -1
- package/dist/server/src/modules/business-trips/resolvers/credit-shareholders-business-trip-travel-and-subsistence.resolver.js +2 -2
- package/dist/server/src/modules/business-trips/resolvers/credit-shareholders-business-trip-travel-and-subsistence.resolver.js.map +1 -1
- package/dist/server/src/modules/charges/helpers/batch-update-charges.js +2 -2
- package/dist/server/src/modules/charges/helpers/batch-update-charges.js.map +1 -1
- package/dist/server/src/modules/charges/helpers/charge-type.js +1 -1
- package/dist/server/src/modules/charges/helpers/charge-type.js.map +1 -1
- package/dist/server/src/modules/charges/helpers/common.helper.js +9 -9
- package/dist/server/src/modules/charges/helpers/common.helper.js.map +1 -1
- package/dist/server/src/modules/charges/helpers/delete-charges.helper.js +2 -2
- package/dist/server/src/modules/charges/helpers/delete-charges.helper.js.map +1 -1
- package/dist/server/src/modules/charges/helpers/financial-charge.helper.js +2 -2
- package/dist/server/src/modules/charges/helpers/financial-charge.helper.js.map +1 -1
- package/dist/server/src/modules/charges/helpers/validate.helper.js +5 -5
- package/dist/server/src/modules/charges/helpers/validate.helper.js.map +1 -1
- package/dist/server/src/modules/charges/providers/charge-spread.provider.d.ts +1 -1
- package/dist/server/src/modules/charges/providers/charge-spread.provider.js +1 -1
- package/dist/server/src/modules/charges/providers/charge-spread.provider.js.map +1 -1
- package/dist/server/src/modules/charges/providers/charges.provider.d.ts +1 -1
- package/dist/server/src/modules/charges/providers/charges.provider.js +1 -1
- package/dist/server/src/modules/charges/providers/charges.provider.js.map +1 -1
- package/dist/server/src/modules/charges/resolvers/charge-suggestions/charge-suggestions.resolver.js +7 -7
- package/dist/server/src/modules/charges/resolvers/charge-suggestions/charge-suggestions.resolver.js.map +1 -1
- package/dist/server/src/modules/charges/resolvers/charge-suggestions/conversion-suggeestions.resolver.js +1 -1
- package/dist/server/src/modules/charges/resolvers/charge-suggestions/conversion-suggeestions.resolver.js.map +1 -1
- package/dist/server/src/modules/charges/resolvers/charges.resolver.js +11 -11
- package/dist/server/src/modules/charges/resolvers/charges.resolver.js.map +1 -1
- package/dist/server/src/modules/charges/resolvers/common.js +1 -1
- package/dist/server/src/modules/charges/resolvers/common.js.map +1 -1
- package/dist/server/src/modules/charges/resolvers/financial-charges.resolver.js +3 -3
- package/dist/server/src/modules/charges/resolvers/financial-charges.resolver.js.map +1 -1
- package/dist/server/src/modules/charges-matcher/__tests__/auto-match-integration.test.js +4 -4
- package/dist/server/src/modules/charges-matcher/__tests__/auto-match-integration.test.js.map +1 -1
- package/dist/server/src/modules/charges-matcher/__tests__/single-match-integration.test.js +3 -3
- package/dist/server/src/modules/charges-matcher/__tests__/single-match-integration.test.js.map +1 -1
- package/dist/server/src/modules/charges-matcher/providers/charges-matcher.provider.js +3 -3
- package/dist/server/src/modules/charges-matcher/providers/charges-matcher.provider.js.map +1 -1
- package/dist/server/src/modules/charges-matcher/providers/document-aggregator.d.ts +1 -1
- package/dist/server/src/modules/charges-matcher/providers/match-scorer.provider.d.ts +1 -1
- package/dist/server/src/modules/charges-matcher/providers/transaction-aggregator.d.ts +1 -1
- package/dist/server/src/modules/charges-matcher/resolvers/index.js +1 -1
- package/dist/server/src/modules/charges-matcher/resolvers/index.js.map +1 -1
- package/dist/server/src/modules/charges-matcher/types.d.ts +3 -3
- package/dist/server/src/modules/charges-matcher/types.js.map +1 -1
- package/dist/server/src/modules/charts/resolvers/charts.resolver.js +3 -3
- package/dist/server/src/modules/charts/resolvers/charts.resolver.js.map +1 -1
- package/dist/server/src/modules/common/resolvers/gmail-listener.resolver.js +2 -2
- package/dist/server/src/modules/common/resolvers/gmail-listener.resolver.js.map +1 -1
- package/dist/server/src/modules/contracts/providers/contracts.provider.d.ts +2 -2
- package/dist/server/src/modules/contracts/providers/contracts.provider.js +2 -2
- package/dist/server/src/modules/contracts/providers/contracts.provider.js.map +1 -1
- package/dist/server/src/modules/contracts/resolvers/contracts.resolver.js +2 -2
- package/dist/server/src/modules/contracts/resolvers/contracts.resolver.js.map +1 -1
- package/dist/server/src/modules/corn-jobs/providers/corn-jobs.provider.d.ts +1 -1
- package/dist/server/src/modules/corn-jobs/providers/corn-jobs.provider.js +1 -1
- package/dist/server/src/modules/corn-jobs/providers/corn-jobs.provider.js.map +1 -1
- package/dist/server/src/modules/corn-jobs/resolvers/corn-jobs.resolver.js +1 -1
- package/dist/server/src/modules/corn-jobs/resolvers/corn-jobs.resolver.js.map +1 -1
- package/dist/server/src/modules/corporate-taxes/providers/corporate-taxes.provider.d.ts +1 -1
- package/dist/server/src/modules/corporate-taxes/providers/corporate-taxes.provider.js +1 -1
- package/dist/server/src/modules/corporate-taxes/providers/corporate-taxes.provider.js.map +1 -1
- package/dist/server/src/modules/countries/providers/countries.provider.d.ts +1 -1
- package/dist/server/src/modules/countries/providers/countries.provider.js +1 -1
- package/dist/server/src/modules/countries/providers/countries.provider.js.map +1 -1
- package/dist/server/src/modules/deel/helpers/deel.helper.d.ts +2 -2
- package/dist/server/src/modules/deel/helpers/deel.helper.js +5 -5
- package/dist/server/src/modules/deel/helpers/deel.helper.js.map +1 -1
- package/dist/server/src/modules/deel/providers/deel-contracts.provider.d.ts +1 -1
- package/dist/server/src/modules/deel/providers/deel-contracts.provider.js +1 -1
- package/dist/server/src/modules/deel/providers/deel-contracts.provider.js.map +1 -1
- package/dist/server/src/modules/deel/providers/deel-invoices.provider.d.ts +1 -1
- package/dist/server/src/modules/deel/providers/deel-invoices.provider.js +1 -1
- package/dist/server/src/modules/deel/providers/deel-invoices.provider.js.map +1 -1
- package/dist/server/src/modules/deel/resolvers/deel.resolvers.js +4 -4
- package/dist/server/src/modules/deel/resolvers/deel.resolvers.js.map +1 -1
- package/dist/server/src/modules/depreciation/providers/depreciation-categories.provider.d.ts +1 -1
- package/dist/server/src/modules/depreciation/providers/depreciation-categories.provider.js +1 -1
- package/dist/server/src/modules/depreciation/providers/depreciation-categories.provider.js.map +1 -1
- package/dist/server/src/modules/depreciation/providers/depreciation.provider.d.ts +1 -1
- package/dist/server/src/modules/depreciation/providers/depreciation.provider.js +1 -1
- package/dist/server/src/modules/depreciation/providers/depreciation.provider.js.map +1 -1
- package/dist/server/src/modules/depreciation/resolvers/depreciation.resolver.js +2 -2
- package/dist/server/src/modules/depreciation/resolvers/depreciation.resolver.js.map +1 -1
- package/dist/server/src/modules/dividends/providers/dividends.provider.d.ts +1 -1
- package/dist/server/src/modules/dividends/providers/dividends.provider.js +1 -1
- package/dist/server/src/modules/dividends/providers/dividends.provider.js.map +1 -1
- package/dist/server/src/modules/documents/helpers/upload.helper.js +2 -2
- package/dist/server/src/modules/documents/helpers/upload.helper.js.map +1 -1
- package/dist/server/src/modules/documents/helpers/validate-document.helper.js +1 -1
- package/dist/server/src/modules/documents/helpers/validate-document.helper.js.map +1 -1
- package/dist/server/src/modules/documents/providers/documents.provider.d.ts +1 -1
- package/dist/server/src/modules/documents/providers/documents.provider.js +1 -1
- package/dist/server/src/modules/documents/providers/documents.provider.js.map +1 -1
- package/dist/server/src/modules/documents/providers/issued-documents.provider.d.ts +1 -1
- package/dist/server/src/modules/documents/providers/issued-documents.provider.js +1 -1
- package/dist/server/src/modules/documents/providers/issued-documents.provider.js.map +1 -1
- package/dist/server/src/modules/documents/resolvers/document-suggestions.resolver.js +4 -4
- package/dist/server/src/modules/documents/resolvers/document-suggestions.resolver.js.map +1 -1
- package/dist/server/src/modules/documents/resolvers/documents.resolver.js +5 -5
- package/dist/server/src/modules/documents/resolvers/documents.resolver.js.map +1 -1
- package/dist/server/src/modules/exchange-rates/helpers/exchange.helper.d.ts +1 -1
- package/dist/server/src/modules/exchange-rates/helpers/exchange.helper.js.map +1 -1
- package/dist/server/src/modules/exchange-rates/providers/crypto-exchange.provider.d.ts +2 -2
- package/dist/server/src/modules/exchange-rates/providers/crypto-exchange.provider.js +2 -2
- package/dist/server/src/modules/exchange-rates/providers/crypto-exchange.provider.js.map +1 -1
- package/dist/server/src/modules/exchange-rates/providers/fiat-exchange.provider.d.ts +1 -1
- package/dist/server/src/modules/exchange-rates/providers/fiat-exchange.provider.js +1 -1
- package/dist/server/src/modules/exchange-rates/providers/fiat-exchange.provider.js.map +1 -1
- package/dist/server/src/modules/exchange-rates/resolvers/common.js +1 -1
- package/dist/server/src/modules/exchange-rates/resolvers/common.js.map +1 -1
- package/dist/server/src/modules/exchange-rates/resolvers/exchange.resolver.js +2 -2
- package/dist/server/src/modules/exchange-rates/resolvers/exchange.resolver.js.map +1 -1
- package/dist/server/src/modules/financial-accounts/providers/financial-accounts.provider.d.ts +1 -1
- package/dist/server/src/modules/financial-accounts/providers/financial-accounts.provider.js +1 -1
- package/dist/server/src/modules/financial-accounts/providers/financial-accounts.provider.js.map +1 -1
- package/dist/server/src/modules/financial-accounts/providers/financial-bank-accounts.provider.d.ts +1 -1
- package/dist/server/src/modules/financial-accounts/providers/financial-bank-accounts.provider.js +1 -1
- package/dist/server/src/modules/financial-accounts/providers/financial-bank-accounts.provider.js.map +1 -1
- package/dist/server/src/modules/financial-accounts/resolvers/common.js +2 -2
- package/dist/server/src/modules/financial-accounts/resolvers/common.js.map +1 -1
- package/dist/server/src/modules/financial-entities/helpers/business-transactions.helper.d.ts +1 -1
- package/dist/server/src/modules/financial-entities/helpers/business-transactions.helper.js.map +1 -1
- package/dist/server/src/modules/financial-entities/helpers/businesses.helper.js +1 -1
- package/dist/server/src/modules/financial-entities/helpers/businesses.helper.js.map +1 -1
- package/dist/server/src/modules/financial-entities/providers/admin-businesses.provider.d.ts +1 -1
- package/dist/server/src/modules/financial-entities/providers/admin-businesses.provider.js +1 -1
- package/dist/server/src/modules/financial-entities/providers/admin-businesses.provider.js.map +1 -1
- package/dist/server/src/modules/financial-entities/providers/businesses-operation.provider.d.ts +7 -7
- package/dist/server/src/modules/financial-entities/providers/businesses-operation.provider.js +7 -7
- package/dist/server/src/modules/financial-entities/providers/businesses-operation.provider.js.map +1 -1
- package/dist/server/src/modules/financial-entities/providers/businesses.provider.d.ts +1 -1
- package/dist/server/src/modules/financial-entities/providers/businesses.provider.js +2 -2
- package/dist/server/src/modules/financial-entities/providers/businesses.provider.js.map +1 -1
- package/dist/server/src/modules/financial-entities/providers/clients.provider.d.ts +1 -1
- package/dist/server/src/modules/financial-entities/providers/clients.provider.js +1 -1
- package/dist/server/src/modules/financial-entities/providers/clients.provider.js.map +1 -1
- package/dist/server/src/modules/financial-entities/providers/financial-entities.provider.d.ts +1 -1
- package/dist/server/src/modules/financial-entities/providers/financial-entities.provider.js +1 -1
- package/dist/server/src/modules/financial-entities/providers/financial-entities.provider.js.map +1 -1
- package/dist/server/src/modules/financial-entities/providers/tax-categories.provider.d.ts +1 -1
- package/dist/server/src/modules/financial-entities/providers/tax-categories.provider.js +1 -1
- package/dist/server/src/modules/financial-entities/providers/tax-categories.provider.js.map +1 -1
- package/dist/server/src/modules/financial-entities/resolvers/business-transactions-sum-from-ledger-records.resolver.js +4 -4
- package/dist/server/src/modules/financial-entities/resolvers/business-transactions-sum-from-ledger-records.resolver.js.map +1 -1
- package/dist/server/src/modules/financial-entities/resolvers/business-transactions.resolver.js +2 -2
- package/dist/server/src/modules/financial-entities/resolvers/business-transactions.resolver.js.map +1 -1
- package/dist/server/src/modules/financial-entities/resolvers/businesses.resolver.js +5 -5
- package/dist/server/src/modules/financial-entities/resolvers/businesses.resolver.js.map +1 -1
- package/dist/server/src/modules/financial-entities/resolvers/clients.resolvers.js +2 -2
- package/dist/server/src/modules/financial-entities/resolvers/clients.resolvers.js.map +1 -1
- package/dist/server/src/modules/financial-entities/resolvers/common.js +2 -2
- package/dist/server/src/modules/financial-entities/resolvers/common.js.map +1 -1
- package/dist/server/src/modules/financial-entities/resolvers/tax-categories.resolver.js +1 -1
- package/dist/server/src/modules/financial-entities/resolvers/tax-categories.resolver.js.map +1 -1
- package/dist/server/src/modules/green-invoice/helpers/contract-to-draft.helper.d.ts +1 -1
- package/dist/server/src/modules/green-invoice/helpers/contract-to-draft.helper.js +4 -4
- package/dist/server/src/modules/green-invoice/helpers/contract-to-draft.helper.js.map +1 -1
- package/dist/server/src/modules/green-invoice/helpers/green-invoice-clients.helper.js +4 -4
- package/dist/server/src/modules/green-invoice/helpers/green-invoice-clients.helper.js.map +1 -1
- package/dist/server/src/modules/green-invoice/helpers/green-invoice.helper.d.ts +3 -3
- package/dist/server/src/modules/green-invoice/helpers/green-invoice.helper.js +8 -8
- package/dist/server/src/modules/green-invoice/helpers/green-invoice.helper.js.map +1 -1
- package/dist/server/src/modules/green-invoice/helpers/issue-document.helper.d.ts +2 -2
- package/dist/server/src/modules/green-invoice/helpers/issue-document.helper.js +6 -6
- package/dist/server/src/modules/green-invoice/helpers/issue-document.helper.js.map +1 -1
- package/dist/server/src/modules/green-invoice/resolvers/green-invoice.resolvers.js +12 -12
- package/dist/server/src/modules/green-invoice/resolvers/green-invoice.resolvers.js.map +1 -1
- package/dist/server/src/modules/ledger/helpers/common-charge-ledger.helper.d.ts +2 -2
- package/dist/server/src/modules/ledger/helpers/common-charge-ledger.helper.js +4 -4
- package/dist/server/src/modules/ledger/helpers/common-charge-ledger.helper.js.map +1 -1
- package/dist/server/src/modules/ledger/helpers/cross-year-ledger.helper.d.ts +1 -1
- package/dist/server/src/modules/ledger/helpers/cross-year-ledger.helper.js +3 -3
- package/dist/server/src/modules/ledger/helpers/cross-year-ledger.helper.js.map +1 -1
- package/dist/server/src/modules/ledger/helpers/dividend-ledger.helper.d.ts +1 -1
- package/dist/server/src/modules/ledger/helpers/fee-transactions.d.ts +2 -2
- package/dist/server/src/modules/ledger/helpers/fee-transactions.js +2 -2
- package/dist/server/src/modules/ledger/helpers/fee-transactions.js.map +1 -1
- package/dist/server/src/modules/ledger/helpers/ledger-by-charge-type.helper.d.ts +1 -1
- package/dist/server/src/modules/ledger/helpers/ledger-by-charge-type.helper.js +2 -2
- package/dist/server/src/modules/ledger/helpers/ledger-by-charge-type.helper.js.map +1 -1
- package/dist/server/src/modules/ledger/helpers/ledger-lock.d.ts +1 -1
- package/dist/server/src/modules/ledger/helpers/ledger-lock.js +1 -1
- package/dist/server/src/modules/ledger/helpers/ledger-lock.js.map +1 -1
- package/dist/server/src/modules/ledger/helpers/misc-expenses-ledger.helper.d.ts +1 -1
- package/dist/server/src/modules/ledger/helpers/misc-expenses-ledger.helper.js +2 -2
- package/dist/server/src/modules/ledger/helpers/misc-expenses-ledger.helper.js.map +1 -1
- package/dist/server/src/modules/ledger/helpers/monthly-vat-ledger-generation.helper.d.ts +1 -1
- package/dist/server/src/modules/ledger/helpers/recovery-reserve.helper.js +3 -3
- package/dist/server/src/modules/ledger/helpers/recovery-reserve.helper.js.map +1 -1
- package/dist/server/src/modules/ledger/helpers/salary-charge-ledger.helper.d.ts +2 -2
- package/dist/server/src/modules/ledger/helpers/utils.helper.d.ts +3 -3
- package/dist/server/src/modules/ledger/helpers/utils.helper.js +3 -3
- package/dist/server/src/modules/ledger/helpers/utils.helper.js.map +1 -1
- package/dist/server/src/modules/ledger/helpers/vacation-reserve.helper.js +2 -2
- package/dist/server/src/modules/ledger/helpers/vacation-reserve.helper.js.map +1 -1
- package/dist/server/src/modules/ledger/providers/balance-cancellation.provider.d.ts +1 -1
- package/dist/server/src/modules/ledger/providers/balance-cancellation.provider.js +1 -1
- package/dist/server/src/modules/ledger/providers/balance-cancellation.provider.js.map +1 -1
- package/dist/server/src/modules/ledger/providers/ledger.provider.d.ts +1 -1
- package/dist/server/src/modules/ledger/providers/ledger.provider.js +1 -1
- package/dist/server/src/modules/ledger/providers/ledger.provider.js.map +1 -1
- package/dist/server/src/modules/ledger/providers/unbalanced-businesses.provider.d.ts +1 -1
- package/dist/server/src/modules/ledger/providers/unbalanced-businesses.provider.js +1 -1
- package/dist/server/src/modules/ledger/providers/unbalanced-businesses.provider.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/bank-deposit-ledger-generation.resolver.js +10 -10
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/bank-deposit-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/business-trip-ledger-generation.resolver.js +16 -16
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/business-trip-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/common-ledger-generation.resolver.js +9 -9
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/common-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/conversion-ledger-generation.resolver.js +3 -3
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/conversion-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/dividend-ledger-generation.resolver.js +7 -7
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/dividend-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/balance-ledger-generation.resolver.js +3 -3
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/balance-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/bank-deposits-revaluation-ledger-generation.resolver.js +4 -4
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/bank-deposits-revaluation-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/depreciation-expenses-ledger-generation.resolver.js +3 -3
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/depreciation-expenses-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/recovery-reserve-ledger-generation.resolver.js +3 -3
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/recovery-reserve-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/revaluation-ledger-generation.resolver.js +5 -5
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/revaluation-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/tax-expenses-ledger-generation.resolver.js +6 -6
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/tax-expenses-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/vacation-reserve-ledger-generation.resolver.js +3 -3
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/vacation-reserve-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation.resolver.js +2 -2
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/foreign-securities-ledger-generation.resolver.js +7 -7
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/foreign-securities-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/internal-transfer-ledger-generation.resolver.js +4 -4
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/internal-transfer-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/monthly-vat-ledger-generation.resolver.js +7 -7
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/monthly-vat-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/salary-ledger-generation.resolver.js +11 -11
- package/dist/server/src/modules/ledger/resolvers/ledger-generation/salary-ledger-generation.resolver.js.map +1 -1
- package/dist/server/src/modules/ledger/resolvers/ledger.resolver.js +2 -2
- package/dist/server/src/modules/ledger/resolvers/ledger.resolver.js.map +1 -1
- package/dist/server/src/modules/misc-expenses/providers/misc-expenses.provider.d.ts +1 -1
- package/dist/server/src/modules/misc-expenses/providers/misc-expenses.provider.js +1 -1
- package/dist/server/src/modules/misc-expenses/providers/misc-expenses.provider.js.map +1 -1
- package/dist/server/src/modules/misc-expenses/resolvers/misc-expenses.resolver.js +2 -2
- package/dist/server/src/modules/misc-expenses/resolvers/misc-expenses.resolver.js.map +1 -1
- package/dist/server/src/modules/reports/helpers/depreciation-report.helper.js +2 -2
- package/dist/server/src/modules/reports/helpers/depreciation-report.helper.js.map +1 -1
- package/dist/server/src/modules/reports/helpers/pcn.helper.js +1 -1
- package/dist/server/src/modules/reports/helpers/pcn.helper.js.map +1 -1
- package/dist/server/src/modules/reports/helpers/profit-and-loss.helper.d.ts +2 -2
- package/dist/server/src/modules/reports/helpers/shaam6111.helper.js +3 -3
- package/dist/server/src/modules/reports/helpers/shaam6111.helper.js.map +1 -1
- package/dist/server/src/modules/reports/helpers/tax.helper.js +4 -4
- package/dist/server/src/modules/reports/helpers/tax.helper.js.map +1 -1
- package/dist/server/src/modules/reports/helpers/uniform-format.helper.js +7 -7
- package/dist/server/src/modules/reports/helpers/uniform-format.helper.js.map +1 -1
- package/dist/server/src/modules/reports/helpers/vat-report.helper.d.ts +3 -3
- package/dist/server/src/modules/reports/helpers/vat-report.helper.js +4 -4
- package/dist/server/src/modules/reports/helpers/vat-report.helper.js.map +1 -1
- package/dist/server/src/modules/reports/helpers/yearly-ledger-report.helper.d.ts +1 -1
- package/dist/server/src/modules/reports/providers/annual-revenue-report.provider.d.ts +1 -1
- package/dist/server/src/modules/reports/providers/annual-revenue-report.provider.js +1 -1
- package/dist/server/src/modules/reports/providers/annual-revenue-report.provider.js.map +1 -1
- package/dist/server/src/modules/reports/providers/balance-report.provider.d.ts +1 -1
- package/dist/server/src/modules/reports/providers/balance-report.provider.js +1 -1
- package/dist/server/src/modules/reports/providers/balance-report.provider.js.map +1 -1
- package/dist/server/src/modules/reports/providers/dynamic-report.provider.d.ts +1 -1
- package/dist/server/src/modules/reports/providers/dynamic-report.provider.js +1 -1
- package/dist/server/src/modules/reports/providers/dynamic-report.provider.js.map +1 -1
- package/dist/server/src/modules/reports/providers/vat-report.provider.d.ts +1 -1
- package/dist/server/src/modules/reports/providers/vat-report.provider.js +1 -1
- package/dist/server/src/modules/reports/providers/vat-report.provider.js.map +1 -1
- package/dist/server/src/modules/reports/resolvers/annual-revenue.resover.js +3 -3
- package/dist/server/src/modules/reports/resolvers/annual-revenue.resover.js.map +1 -1
- package/dist/server/src/modules/reports/resolvers/balance-report.resolver.js +2 -2
- package/dist/server/src/modules/reports/resolvers/balance-report.resolver.js.map +1 -1
- package/dist/server/src/modules/reports/resolvers/depreciation-report.resolver.js +4 -4
- package/dist/server/src/modules/reports/resolvers/depreciation-report.resolver.js.map +1 -1
- package/dist/server/src/modules/reports/resolvers/get-vat-records.resolver.js +7 -7
- package/dist/server/src/modules/reports/resolvers/get-vat-records.resolver.js.map +1 -1
- package/dist/server/src/modules/reports/resolvers/reports/corporate-tax-ruling-compliance-report.js +4 -4
- package/dist/server/src/modules/reports/resolvers/reports/corporate-tax-ruling-compliance-report.js.map +1 -1
- package/dist/server/src/modules/reports/resolvers/reports/profit-and-loss-report.resolver.js +4 -4
- package/dist/server/src/modules/reports/resolvers/reports/profit-and-loss-report.resolver.js.map +1 -1
- package/dist/server/src/modules/reports/resolvers/reports/tax-report.js +2 -2
- package/dist/server/src/modules/reports/resolvers/reports/tax-report.js.map +1 -1
- package/dist/server/src/modules/reports/resolvers/reports/yearly-ledger-report.resolver.js +2 -2
- package/dist/server/src/modules/reports/resolvers/reports/yearly-ledger-report.resolver.js.map +1 -1
- package/dist/server/src/modules/reports/resolvers/reports.resolver.js +2 -2
- package/dist/server/src/modules/reports/resolvers/reports.resolver.js.map +1 -1
- package/dist/server/src/modules/reports/resolvers/shaam6111.resolver.js +1 -1
- package/dist/server/src/modules/reports/resolvers/shaam6111.resolver.js.map +1 -1
- package/dist/server/src/modules/salaries/providers/employees.provider.d.ts +1 -1
- package/dist/server/src/modules/salaries/providers/employees.provider.js +1 -1
- package/dist/server/src/modules/salaries/providers/employees.provider.js.map +1 -1
- package/dist/server/src/modules/salaries/providers/funds.provider.d.ts +1 -1
- package/dist/server/src/modules/salaries/providers/funds.provider.js +1 -1
- package/dist/server/src/modules/salaries/providers/funds.provider.js.map +1 -1
- package/dist/server/src/modules/salaries/providers/recovery.provider.d.ts +1 -1
- package/dist/server/src/modules/salaries/providers/recovery.provider.js +1 -1
- package/dist/server/src/modules/salaries/providers/recovery.provider.js.map +1 -1
- package/dist/server/src/modules/salaries/providers/salaries.provider.d.ts +1 -1
- package/dist/server/src/modules/salaries/providers/salaries.provider.js +1 -1
- package/dist/server/src/modules/salaries/providers/salaries.provider.js.map +1 -1
- package/dist/server/src/modules/salaries/resolvers/insert-salary-records-from-file.resolvers.js +1 -1
- package/dist/server/src/modules/salaries/resolvers/insert-salary-records-from-file.resolvers.js.map +1 -1
- package/dist/server/src/modules/salaries/resolvers/salaries.resolvers.js +2 -2
- package/dist/server/src/modules/salaries/resolvers/salaries.resolvers.js.map +1 -1
- package/dist/server/src/modules/sort-codes/providers/sort-codes.provider.d.ts +1 -1
- package/dist/server/src/modules/sort-codes/providers/sort-codes.provider.js +1 -1
- package/dist/server/src/modules/sort-codes/providers/sort-codes.provider.js.map +1 -1
- package/dist/server/src/modules/sort-codes/resolvers/common.js +1 -1
- package/dist/server/src/modules/sort-codes/resolvers/common.js.map +1 -1
- package/dist/server/src/modules/tags/providers/charge-tags.provider.d.ts +1 -1
- package/dist/server/src/modules/tags/providers/charge-tags.provider.js +1 -1
- package/dist/server/src/modules/tags/providers/charge-tags.provider.js.map +1 -1
- package/dist/server/src/modules/tags/providers/tags.provider.d.ts +1 -1
- package/dist/server/src/modules/tags/providers/tags.provider.js +1 -1
- package/dist/server/src/modules/tags/providers/tags.provider.js.map +1 -1
- package/dist/server/src/modules/transactions/helpers/debit-date.helper.d.ts +1 -1
- package/dist/server/src/modules/transactions/helpers/effective-date.helper.d.ts +1 -1
- package/dist/server/src/modules/transactions/helpers/effective-date.helper.js.map +1 -1
- package/dist/server/src/modules/transactions/providers/creditcard-transactions.provider.d.ts +1 -1
- package/dist/server/src/modules/transactions/providers/creditcard-transactions.provider.js +1 -1
- package/dist/server/src/modules/transactions/providers/creditcard-transactions.provider.js.map +1 -1
- package/dist/server/src/modules/transactions/providers/transactions.provider.d.ts +1 -1
- package/dist/server/src/modules/transactions/providers/transactions.provider.js +1 -1
- package/dist/server/src/modules/transactions/providers/transactions.provider.js.map +1 -1
- package/dist/server/src/modules/transactions/resolvers/transaction-suggestions.resolver.js +4 -4
- package/dist/server/src/modules/transactions/resolvers/transaction-suggestions.resolver.js.map +1 -1
- package/dist/server/src/modules/transactions/resolvers/transactions.resolver.js +4 -4
- package/dist/server/src/modules/transactions/resolvers/transactions.resolver.js.map +1 -1
- package/dist/server/src/modules/vat/providers/vat.provider.d.ts +1 -1
- package/dist/server/src/modules/vat/providers/vat.provider.js +1 -1
- package/dist/server/src/modules/vat/providers/vat.provider.js.map +1 -1
- package/dist/shaam6111-generator/src/schemas/tax-adjustment.d.ts +1 -1
- package/package.json +1 -1
- package/src/__tests__/helpers/db-setup.ts +0 -3
- package/src/__tests__/helpers/seed-helpers.business.test.ts +145 -147
- package/src/__tests__/helpers/seed-helpers.concurrent.test.ts +10 -10
- package/src/__tests__/helpers/seed-helpers.financial-entity.test.ts +218 -231
- package/src/__tests__/helpers/seed-helpers.tax-category.test.ts +162 -164
- package/src/__tests__/helpers/test-db-config.ts +1 -1
- package/src/__tests__/seed-admin-context.integration.test.ts +199 -208
- package/src/modules/accountant-approval/resolvers/accountant-approval.resolver.ts +4 -4
- package/src/modules/admin-context/providers/admin-context.provider.ts +1 -1
- package/src/modules/admin-context/resolvers/admin-context.resolvers.ts +1 -1
- package/src/modules/app-providers/gmail-listener/gmail-service.provider.ts +9 -9
- package/src/modules/bank-deposits/providers/bank-deposit-transactions.provider.ts +3 -3
- package/src/modules/bank-deposits/resolvers/bank-deposit-transactions.resolver.ts +1 -1
- package/src/modules/business-trips/helpers/business-trip-report.helper.ts +5 -5
- package/src/modules/business-trips/helpers/business-trips-expenses.helper.ts +7 -7
- package/src/modules/business-trips/providers/business-trips-attendees.provider.ts +1 -1
- package/src/modules/business-trips/providers/business-trips-employee-payments.provider.ts +1 -1
- package/src/modules/business-trips/providers/business-trips-expenses-accommodations.provider.ts +1 -1
- package/src/modules/business-trips/providers/business-trips-expenses-car-rental.provider.ts +1 -1
- package/src/modules/business-trips/providers/business-trips-expenses-flights.provider.ts +1 -1
- package/src/modules/business-trips/providers/business-trips-expenses-other.provider.ts +1 -1
- package/src/modules/business-trips/providers/business-trips-expenses-transactions-match.provider.ts +2 -2
- package/src/modules/business-trips/providers/business-trips-expenses-travel-and-subsistence.provider.ts +1 -1
- package/src/modules/business-trips/providers/business-trips-expenses.provider.ts +3 -3
- package/src/modules/business-trips/providers/business-trips-tax-variables.provider.ts +1 -1
- package/src/modules/business-trips/providers/business-trips.provider.ts +1 -1
- package/src/modules/business-trips/resolvers/business-trip-attendees.resolver.ts +1 -1
- package/src/modules/business-trips/resolvers/business-trips-expenses.resolver.ts +1 -1
- package/src/modules/business-trips/resolvers/business-trips.resolver.ts +2 -2
- package/src/modules/business-trips/resolvers/common.ts +8 -8
- package/src/modules/business-trips/resolvers/credit-shareholders-business-trip-travel-and-subsistence.resolver.ts +3 -3
- package/src/modules/charges/helpers/batch-update-charges.ts +2 -2
- package/src/modules/charges/helpers/charge-type.ts +1 -1
- package/src/modules/charges/helpers/common.helper.ts +9 -9
- package/src/modules/charges/helpers/delete-charges.helper.ts +2 -2
- package/src/modules/charges/helpers/financial-charge.helper.ts +2 -2
- package/src/modules/charges/helpers/validate.helper.ts +5 -5
- package/src/modules/charges/providers/charge-spread.provider.ts +1 -1
- package/src/modules/charges/providers/charges.provider.ts +1 -1
- package/src/modules/charges/resolvers/charge-suggestions/charge-suggestions.resolver.ts +8 -11
- package/src/modules/charges/resolvers/charge-suggestions/conversion-suggeestions.resolver.ts +1 -1
- package/src/modules/charges/resolvers/charges.resolver.ts +11 -11
- package/src/modules/charges/resolvers/common.ts +1 -1
- package/src/modules/charges/resolvers/financial-charges.resolver.ts +3 -3
- package/src/modules/charges-matcher/__tests__/auto-match-integration.test.ts +4 -4
- package/src/modules/charges-matcher/__tests__/single-match-integration.test.ts +3 -3
- package/src/modules/charges-matcher/__tests__/test-helpers.ts +1 -1
- package/src/modules/charges-matcher/providers/charges-matcher.provider.ts +3 -3
- package/src/modules/charges-matcher/providers/document-aggregator.ts +1 -1
- package/src/modules/charges-matcher/providers/match-scorer.provider.ts +1 -1
- package/src/modules/charges-matcher/providers/transaction-aggregator.ts +1 -1
- package/src/modules/charges-matcher/resolvers/index.ts +1 -1
- package/src/modules/charges-matcher/types.ts +3 -10
- package/src/modules/charts/resolvers/charts.resolver.ts +3 -3
- package/src/modules/common/resolvers/gmail-listener.resolver.ts +2 -2
- package/src/modules/contracts/providers/contracts.provider.ts +2 -2
- package/src/modules/contracts/resolvers/contracts.resolver.ts +2 -2
- package/src/modules/corn-jobs/providers/corn-jobs.provider.ts +1 -1
- package/src/modules/corn-jobs/resolvers/corn-jobs.resolver.ts +3 -3
- package/src/modules/corporate-taxes/providers/corporate-taxes.provider.ts +1 -1
- package/src/modules/countries/providers/countries.provider.ts +1 -1
- package/src/modules/deel/helpers/deel.helper.ts +10 -10
- package/src/modules/deel/providers/deel-contracts.provider.ts +1 -1
- package/src/modules/deel/providers/deel-invoices.provider.ts +1 -1
- package/src/modules/deel/resolvers/deel.resolvers.ts +5 -5
- package/src/modules/depreciation/providers/depreciation-categories.provider.ts +1 -1
- package/src/modules/depreciation/providers/depreciation.provider.ts +1 -1
- package/src/modules/depreciation/resolvers/depreciation.resolver.ts +2 -2
- package/src/modules/dividends/providers/dividends.provider.ts +1 -1
- package/src/modules/documents/helpers/upload.helper.ts +2 -2
- package/src/modules/documents/helpers/validate-document.helper.ts +1 -1
- package/src/modules/documents/providers/documents.provider.ts +1 -1
- package/src/modules/documents/providers/issued-documents.provider.ts +1 -1
- package/src/modules/documents/resolvers/document-suggestions.resolver.ts +6 -6
- package/src/modules/documents/resolvers/documents.resolver.ts +5 -5
- package/src/modules/exchange-rates/helpers/exchange.helper.ts +1 -1
- package/src/modules/exchange-rates/providers/crypto-exchange.provider.ts +2 -2
- package/src/modules/exchange-rates/providers/fiat-exchange.provider.ts +1 -1
- package/src/modules/exchange-rates/resolvers/common.ts +1 -1
- package/src/modules/exchange-rates/resolvers/exchange.resolver.ts +5 -5
- package/src/modules/financial-accounts/providers/financial-accounts.provider.ts +1 -1
- package/src/modules/financial-accounts/providers/financial-bank-accounts.provider.ts +1 -1
- package/src/modules/financial-accounts/resolvers/common.ts +2 -2
- package/src/modules/financial-entities/helpers/business-transactions.helper.ts +1 -1
- package/src/modules/financial-entities/helpers/businesses.helper.ts +1 -1
- package/src/modules/financial-entities/providers/admin-businesses.provider.ts +1 -1
- package/src/modules/financial-entities/providers/businesses-operation.provider.ts +7 -7
- package/src/modules/financial-entities/providers/businesses.provider.ts +2 -2
- package/src/modules/financial-entities/providers/clients.provider.ts +1 -1
- package/src/modules/financial-entities/providers/financial-entities.provider.ts +1 -1
- package/src/modules/financial-entities/providers/tax-categories.provider.ts +1 -1
- package/src/modules/financial-entities/resolvers/business-transactions-sum-from-ledger-records.resolver.ts +4 -4
- package/src/modules/financial-entities/resolvers/business-transactions.resolver.ts +2 -2
- package/src/modules/financial-entities/resolvers/businesses.resolver.ts +6 -6
- package/src/modules/financial-entities/resolvers/clients.resolvers.ts +2 -2
- package/src/modules/financial-entities/resolvers/common.ts +2 -2
- package/src/modules/financial-entities/resolvers/tax-categories.resolver.ts +1 -1
- package/src/modules/green-invoice/helpers/contract-to-draft.helper.ts +5 -5
- package/src/modules/green-invoice/helpers/green-invoice-clients.helper.ts +6 -6
- package/src/modules/green-invoice/helpers/green-invoice.helper.ts +9 -9
- package/src/modules/green-invoice/helpers/issue-document.helper.ts +12 -12
- package/src/modules/green-invoice/resolvers/green-invoice.resolvers.ts +17 -17
- package/src/modules/ledger/helpers/common-charge-ledger.helper.ts +8 -8
- package/src/modules/ledger/helpers/cross-year-ledger.helper.ts +6 -6
- package/src/modules/ledger/helpers/dividend-ledger.helper.ts +1 -1
- package/src/modules/ledger/helpers/fee-transactions.ts +5 -5
- package/src/modules/ledger/helpers/ledger-by-charge-type.helper.ts +3 -3
- package/src/modules/ledger/helpers/ledger-lock.ts +4 -4
- package/src/modules/ledger/helpers/misc-expenses-ledger.helper.ts +3 -3
- package/src/modules/ledger/helpers/monthly-vat-ledger-generation.helper.ts +1 -1
- package/src/modules/ledger/helpers/recovery-reserve.helper.ts +5 -5
- package/src/modules/ledger/helpers/salary-charge-ledger.helper.ts +2 -2
- package/src/modules/ledger/helpers/utils.helper.ts +6 -6
- package/src/modules/ledger/helpers/vacation-reserve.helper.ts +6 -6
- package/src/modules/ledger/providers/balance-cancellation.provider.ts +1 -1
- package/src/modules/ledger/providers/ledger.provider.ts +1 -1
- package/src/modules/ledger/providers/unbalanced-businesses.provider.ts +1 -1
- package/src/modules/ledger/resolvers/ledger-generation/bank-deposit-ledger-generation.resolver.ts +11 -11
- package/src/modules/ledger/resolvers/ledger-generation/business-trip-ledger-generation.resolver.ts +19 -19
- package/src/modules/ledger/resolvers/ledger-generation/common-ledger-generation.resolver.ts +13 -13
- package/src/modules/ledger/resolvers/ledger-generation/conversion-ledger-generation.resolver.ts +3 -3
- package/src/modules/ledger/resolvers/ledger-generation/dividend-ledger-generation.resolver.ts +7 -7
- package/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/balance-ledger-generation.resolver.ts +3 -3
- package/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/bank-deposits-revaluation-ledger-generation.resolver.ts +4 -4
- package/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/depreciation-expenses-ledger-generation.resolver.ts +3 -3
- package/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/recovery-reserve-ledger-generation.resolver.ts +3 -3
- package/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/revaluation-ledger-generation.resolver.ts +5 -5
- package/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/tax-expenses-ledger-generation.resolver.ts +8 -8
- package/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation/vacation-reserve-ledger-generation.resolver.ts +3 -3
- package/src/modules/ledger/resolvers/ledger-generation/financial-ledger-generation.resolver.ts +2 -2
- package/src/modules/ledger/resolvers/ledger-generation/foreign-securities-ledger-generation.resolver.ts +7 -7
- package/src/modules/ledger/resolvers/ledger-generation/internal-transfer-ledger-generation.resolver.ts +5 -5
- package/src/modules/ledger/resolvers/ledger-generation/monthly-vat-ledger-generation.resolver.ts +8 -8
- package/src/modules/ledger/resolvers/ledger-generation/salary-ledger-generation.resolver.ts +11 -11
- package/src/modules/ledger/resolvers/ledger.resolver.ts +4 -4
- package/src/modules/misc-expenses/providers/misc-expenses.provider.ts +1 -1
- package/src/modules/misc-expenses/resolvers/misc-expenses.resolver.ts +2 -2
- package/src/modules/reports/helpers/depreciation-report.helper.ts +2 -2
- package/src/modules/reports/helpers/pcn.helper.ts +1 -1
- package/src/modules/reports/helpers/profit-and-loss.helper.ts +2 -2
- package/src/modules/reports/helpers/shaam6111.helper.ts +4 -4
- package/src/modules/reports/helpers/tax.helper.ts +5 -5
- package/src/modules/reports/helpers/uniform-format.helper.ts +8 -8
- package/src/modules/reports/helpers/vat-report.helper.ts +10 -10
- package/src/modules/reports/helpers/yearly-ledger-report.helper.ts +1 -1
- package/src/modules/reports/providers/annual-revenue-report.provider.ts +1 -1
- package/src/modules/reports/providers/balance-report.provider.ts +1 -1
- package/src/modules/reports/providers/dynamic-report.provider.ts +1 -1
- package/src/modules/reports/providers/vat-report.provider.ts +1 -1
- package/src/modules/reports/resolvers/annual-revenue.resover.ts +3 -3
- package/src/modules/reports/resolvers/balance-report.resolver.ts +2 -2
- package/src/modules/reports/resolvers/depreciation-report.resolver.ts +5 -5
- package/src/modules/reports/resolvers/get-vat-records.resolver.ts +8 -8
- package/src/modules/reports/resolvers/reports/corporate-tax-ruling-compliance-report.ts +6 -6
- package/src/modules/reports/resolvers/reports/profit-and-loss-report.resolver.ts +5 -5
- package/src/modules/reports/resolvers/reports/tax-report.ts +2 -2
- package/src/modules/reports/resolvers/reports/yearly-ledger-report.resolver.ts +5 -5
- package/src/modules/reports/resolvers/reports.resolver.ts +2 -2
- package/src/modules/reports/resolvers/shaam6111.resolver.ts +1 -1
- package/src/modules/salaries/providers/employees.provider.ts +1 -1
- package/src/modules/salaries/providers/funds.provider.ts +1 -1
- package/src/modules/salaries/providers/recovery.provider.ts +1 -1
- package/src/modules/salaries/providers/salaries.provider.ts +1 -1
- package/src/modules/salaries/resolvers/insert-salary-records-from-file.resolvers.ts +1 -1
- package/src/modules/salaries/resolvers/salaries.resolvers.ts +2 -2
- package/src/modules/sort-codes/providers/sort-codes.provider.ts +1 -1
- package/src/modules/sort-codes/resolvers/common.ts +1 -1
- package/src/modules/tags/providers/charge-tags.provider.ts +1 -1
- package/src/modules/tags/providers/tags.provider.ts +1 -1
- package/src/modules/transactions/helpers/debit-date.helper.ts +1 -1
- package/src/modules/transactions/helpers/effective-date.helper.ts +1 -1
- package/src/modules/transactions/providers/creditcard-transactions.provider.ts +1 -1
- package/src/modules/transactions/providers/transactions.provider.ts +1 -1
- package/src/modules/transactions/resolvers/transaction-suggestions.resolver.ts +4 -4
- package/src/modules/transactions/resolvers/transactions.resolver.ts +4 -4
- package/src/modules/vat/providers/vat.provider.ts +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
# @accounter/server
|
|
2
2
|
|
|
3
|
-
## 0.0.9-alpha-
|
|
3
|
+
## 0.0.9-alpha-20251210174843-5565e7453eaaa611b548e0b47b3e32c6bd978732
|
|
4
4
|
|
|
5
5
|
### Patch Changes
|
|
6
6
|
|
|
@@ -122,6 +122,22 @@
|
|
|
122
122
|
utilize the `businessId` when constructing links to business detail pages, resolving the issue
|
|
123
123
|
of incorrect navigation.
|
|
124
124
|
|
|
125
|
+
- [#2802](https://github.com/Urigo/accounter-fullstack/pull/2802)
|
|
126
|
+
[`f37d6fd`](https://github.com/Urigo/accounter-fullstack/commit/f37d6fd3f3721663609840177c8fc077fda0c8b0)
|
|
127
|
+
Thanks [@gilgardosh](https://github.com/gilgardosh)! - - **Centralized Test Database Management**:
|
|
128
|
+
Integration tests now leverage a `TestDatabase` utility class, centralizing database connection,
|
|
129
|
+
pooling, and transaction management for improved consistency and isolation.
|
|
130
|
+
- **Transactional Test Isolation**: Individual test cases are now wrapped in `db.withTransaction`
|
|
131
|
+
blocks, ensuring that each test runs within its own transaction and automatically rolls back
|
|
132
|
+
changes, preventing data leakage between tests.
|
|
133
|
+
- **Simplified Test Setup/Teardown**: The `beforeAll`, `afterAll`, `beforeEach`, and `afterEach`
|
|
134
|
+
hooks in several test files have been streamlined, removing manual `pg.Pool` and `pg.PoolClient`
|
|
135
|
+
management in favor of the `TestDatabase` class's methods.
|
|
136
|
+
- **Removed Obsolete Function**: The `resetSetupFlags` function, previously a no-op, has been
|
|
137
|
+
removed from `db-setup.ts`.
|
|
138
|
+
- **Import Path Correction**: A minor import path correction for `DBProvider` was made in
|
|
139
|
+
`business-trips.provider.ts`.
|
|
140
|
+
|
|
125
141
|
- [#2750](https://github.com/Urigo/accounter-fullstack/pull/2750)
|
|
126
142
|
[`98b8b85`](https://github.com/Urigo/accounter-fullstack/commit/98b8b859ad566372ec3cd65bc57bcc0d6fcdd6fb)
|
|
127
143
|
Thanks [@gilgardosh](https://github.com/gilgardosh)! - - **Database Schema Update**: A new `users`
|
|
@@ -271,10 +287,10 @@
|
|
|
271
287
|
[`ef68321`](https://github.com/Urigo/accounter-fullstack/commit/ef68321608d60a7208e82a2c413f27beb502e3cc),
|
|
272
288
|
[`ef68321`](https://github.com/Urigo/accounter-fullstack/commit/ef68321608d60a7208e82a2c413f27beb502e3cc),
|
|
273
289
|
[`c7d6f21`](https://github.com/Urigo/accounter-fullstack/commit/c7d6f21ed62658159b1323334501daca03c8d3e5)]:
|
|
274
|
-
- @accounter/green-invoice-graphql@0.8.3-alpha-
|
|
275
|
-
- @accounter/pcn874-generator@0.6.4-alpha-
|
|
276
|
-
- @accounter/shaam-uniform-format-generator@0.2.3-alpha-
|
|
277
|
-
- @accounter/shaam6111-generator@0.1.5-alpha-
|
|
290
|
+
- @accounter/green-invoice-graphql@0.8.3-alpha-20251210174843-5565e7453eaaa611b548e0b47b3e32c6bd978732
|
|
291
|
+
- @accounter/pcn874-generator@0.6.4-alpha-20251210174843-5565e7453eaaa611b548e0b47b3e32c6bd978732
|
|
292
|
+
- @accounter/shaam-uniform-format-generator@0.2.3-alpha-20251210174843-5565e7453eaaa611b548e0b47b3e32c6bd978732
|
|
293
|
+
- @accounter/shaam6111-generator@0.1.5-alpha-20251210174843-5565e7453eaaa611b548e0b47b3e32c6bd978732
|
|
278
294
|
|
|
279
295
|
## 0.0.8
|
|
280
296
|
|
|
@@ -5,4 +5,3 @@ export { withTestTransaction, withConcurrentTransactions } from './test-transact
|
|
|
5
5
|
export { isPoolHealthy, debugLog, emitMetrics } from './diagnostics.js';
|
|
6
6
|
export { TestDbConnectionError, TestDbMigrationError, TestDbSeedError } from './errors.js';
|
|
7
7
|
export { TestDatabase } from './test-database.js';
|
|
8
|
-
export declare function resetSetupFlags(): void;
|
|
@@ -5,6 +5,4 @@ export { withTestTransaction, withConcurrentTransactions } from './test-transact
|
|
|
5
5
|
export { isPoolHealthy, debugLog, emitMetrics } from './diagnostics.js';
|
|
6
6
|
export { TestDbConnectionError, TestDbMigrationError, TestDbSeedError } from './errors.js';
|
|
7
7
|
export { TestDatabase } from './test-database.js';
|
|
8
|
-
// Backward-compatible no-op reset (seed flag lives in db-fixtures now)
|
|
9
|
-
export function resetSetupFlags() { }
|
|
10
8
|
//# sourceMappingURL=db-setup.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"db-setup.js","sourceRoot":"","sources":["../../../../../src/__tests__/helpers/db-setup.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAC;AACxF,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AACxE,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC3F,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC
|
|
1
|
+
{"version":3,"file":"db-setup.js","sourceRoot":"","sources":["../../../../../src/__tests__/helpers/db-setup.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAC;AACxF,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AACxE,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC3F,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC"}
|
|
@@ -1,26 +1,18 @@
|
|
|
1
|
-
import { describe, it, expect, beforeAll, afterAll
|
|
2
|
-
import pg from 'pg';
|
|
1
|
+
import { describe, it, expect, beforeAll, afterAll } from 'vitest';
|
|
3
2
|
import { ensureFinancialEntity, ensureBusinessForEntity } from './seed-helpers.js';
|
|
4
|
-
import {
|
|
3
|
+
import { qualifyTable } from './test-db-config.js';
|
|
5
4
|
import { EntityValidationError } from './seed-errors.js';
|
|
5
|
+
import { TestDatabase } from './db-setup.js';
|
|
6
6
|
describe('ensureBusinessForEntity', () => {
|
|
7
|
-
let
|
|
8
|
-
let client;
|
|
7
|
+
let db;
|
|
9
8
|
beforeAll(async () => {
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
db = new TestDatabase();
|
|
10
|
+
await db.connect();
|
|
12
11
|
});
|
|
13
12
|
afterAll(async () => {
|
|
14
|
-
|
|
15
|
-
await pool.end();
|
|
13
|
+
await db.close();
|
|
16
14
|
});
|
|
17
|
-
|
|
18
|
-
await client.query('BEGIN');
|
|
19
|
-
});
|
|
20
|
-
afterEach(async () => {
|
|
21
|
-
await client.query('ROLLBACK');
|
|
22
|
-
});
|
|
23
|
-
it('should create a new business for a financial entity', async () => {
|
|
15
|
+
it('should create a new business for a financial entity', async () => db.withTransaction(async (client) => {
|
|
24
16
|
// Create a financial entity first
|
|
25
17
|
const { id: entityId } = await ensureFinancialEntity(client, {
|
|
26
18
|
name: 'Test Business Entity',
|
|
@@ -33,8 +25,8 @@ describe('ensureBusinessForEntity', () => {
|
|
|
33
25
|
expect(result.rows).toHaveLength(1);
|
|
34
26
|
expect(result.rows[0].id).toBe(entityId);
|
|
35
27
|
expect(result.rows[0].no_invoices_required).toBe(false);
|
|
36
|
-
});
|
|
37
|
-
it('should be idempotent - repeated calls do not create duplicates', async () => {
|
|
28
|
+
}));
|
|
29
|
+
it('should be idempotent - repeated calls do not create duplicates', async () => db.withTransaction(async (client) => {
|
|
38
30
|
// Create a financial entity first
|
|
39
31
|
const { id: entityId } = await ensureFinancialEntity(client, {
|
|
40
32
|
name: 'Test Business Entity 2',
|
|
@@ -48,8 +40,8 @@ describe('ensureBusinessForEntity', () => {
|
|
|
48
40
|
const result = await client.query(`SELECT id FROM ${qualifyTable('businesses')} WHERE id = $1`, [entityId]);
|
|
49
41
|
expect(result.rows).toHaveLength(1);
|
|
50
42
|
expect(result.rows[0].id).toBe(entityId);
|
|
51
|
-
});
|
|
52
|
-
it('should support noInvoicesRequired option', async () => {
|
|
43
|
+
}));
|
|
44
|
+
it('should support noInvoicesRequired option', async () => db.withTransaction(async (client) => {
|
|
53
45
|
// Create a financial entity first
|
|
54
46
|
const { id: entityId } = await ensureFinancialEntity(client, {
|
|
55
47
|
name: 'Test Business Entity 3',
|
|
@@ -62,8 +54,8 @@ describe('ensureBusinessForEntity', () => {
|
|
|
62
54
|
expect(result.rows).toHaveLength(1);
|
|
63
55
|
expect(result.rows[0].id).toBe(entityId);
|
|
64
56
|
expect(result.rows[0].no_invoices_required).toBe(true);
|
|
65
|
-
});
|
|
66
|
-
it('should default noInvoicesRequired to false when not specified', async () => {
|
|
57
|
+
}));
|
|
58
|
+
it('should default noInvoicesRequired to false when not specified', async () => db.withTransaction(async (client) => {
|
|
67
59
|
// Create a financial entity first
|
|
68
60
|
const { id: entityId } = await ensureFinancialEntity(client, {
|
|
69
61
|
name: 'Test Business Entity 4',
|
|
@@ -75,8 +67,8 @@ describe('ensureBusinessForEntity', () => {
|
|
|
75
67
|
const result = await client.query(`SELECT no_invoices_required FROM ${qualifyTable('businesses')} WHERE id = $1`, [entityId]);
|
|
76
68
|
expect(result.rows).toHaveLength(1);
|
|
77
69
|
expect(result.rows[0].no_invoices_required).toBe(false);
|
|
78
|
-
});
|
|
79
|
-
it('should not modify existing business when called again', async () => {
|
|
70
|
+
}));
|
|
71
|
+
it('should not modify existing business when called again', async () => db.withTransaction(async (client) => {
|
|
80
72
|
// Create a financial entity first
|
|
81
73
|
const { id: entityId } = await ensureFinancialEntity(client, {
|
|
82
74
|
name: 'Test Business Entity 5',
|
|
@@ -90,21 +82,21 @@ describe('ensureBusinessForEntity', () => {
|
|
|
90
82
|
const result = await client.query(`SELECT no_invoices_required FROM ${qualifyTable('businesses')} WHERE id = $1`, [entityId]);
|
|
91
83
|
expect(result.rows).toHaveLength(1);
|
|
92
84
|
expect(result.rows[0].no_invoices_required).toBe(true); // Original value preserved
|
|
93
|
-
});
|
|
94
|
-
it('should not leak data between tests', async () => {
|
|
85
|
+
}));
|
|
86
|
+
it('should not leak data between tests', async () => db.withTransaction(async (client) => {
|
|
95
87
|
// This test verifies transactional isolation by checking that data
|
|
96
88
|
// from previous tests is not visible
|
|
97
89
|
const result = await client.query(`SELECT COUNT(*) as count FROM ${qualifyTable('businesses')} WHERE id IN (SELECT id FROM ${qualifyTable('financial_entities')} WHERE name LIKE 'Test Business Entity%')`);
|
|
98
90
|
// Due to ROLLBACK after each test, count should be 0
|
|
99
91
|
expect(parseInt(result.rows[0].count)).toBe(0);
|
|
100
|
-
});
|
|
92
|
+
}));
|
|
101
93
|
// Validation tests
|
|
102
|
-
it('should reject invalid UUID format', async () => {
|
|
94
|
+
it('should reject invalid UUID format', async () => db.withTransaction(async (client) => {
|
|
103
95
|
await expect(ensureBusinessForEntity(client, 'not-a-valid-uuid')).rejects.toThrow(EntityValidationError);
|
|
104
|
-
});
|
|
105
|
-
it('should reject non-existent financial entity', async () => {
|
|
96
|
+
}));
|
|
97
|
+
it('should reject non-existent financial entity', async () => db.withTransaction(async (client) => {
|
|
106
98
|
const fakeId = '00000000-0000-0000-0000-000000000000';
|
|
107
99
|
await expect(ensureBusinessForEntity(client, fakeId)).rejects.toThrow(EntityValidationError);
|
|
108
|
-
});
|
|
100
|
+
}));
|
|
109
101
|
});
|
|
110
102
|
//# sourceMappingURL=seed-helpers.business.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"seed-helpers.business.test.js","sourceRoot":"","sources":["../../../../../src/__tests__/helpers/seed-helpers.business.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,
|
|
1
|
+
{"version":3,"file":"seed-helpers.business.test.js","sourceRoot":"","sources":["../../../../../src/__tests__/helpers/seed-helpers.business.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { describe, it, expect, beforeAll, afterAll } from 'vitest';
|
|
2
|
-
import pg from 'pg';
|
|
3
2
|
import { ensureFinancialEntity } from './seed-helpers.js';
|
|
4
|
-
import { testDbConfig } from './test-db-config.js';
|
|
5
3
|
import { withConcurrentTransactions } from './test-transaction.js';
|
|
4
|
+
import { TestDatabase } from './db-setup.js';
|
|
6
5
|
describe('ensureFinancialEntity - Concurrent Access', () => {
|
|
7
|
-
let
|
|
6
|
+
let db;
|
|
8
7
|
beforeAll(async () => {
|
|
9
|
-
|
|
8
|
+
db = new TestDatabase();
|
|
9
|
+
await db.connect();
|
|
10
10
|
});
|
|
11
11
|
afterAll(async () => {
|
|
12
|
-
await
|
|
12
|
+
await db.close();
|
|
13
13
|
});
|
|
14
14
|
it('should handle concurrent inserts of same entity gracefully', async () => {
|
|
15
15
|
const params = {
|
|
@@ -17,7 +17,7 @@ describe('ensureFinancialEntity - Concurrent Access', () => {
|
|
|
17
17
|
type: 'business',
|
|
18
18
|
};
|
|
19
19
|
// Two separate transactions attempting to create the same entity
|
|
20
|
-
const [result1, result2] = await withConcurrentTransactions(
|
|
20
|
+
const [result1, result2] = await withConcurrentTransactions(db.getPool(), [
|
|
21
21
|
async (client) => ensureFinancialEntity(client, params),
|
|
22
22
|
async (client) => ensureFinancialEntity(client, params),
|
|
23
23
|
]);
|
|
@@ -29,7 +29,7 @@ describe('ensureFinancialEntity - Concurrent Access', () => {
|
|
|
29
29
|
// This is expected behavior with ROLLBACK isolation
|
|
30
30
|
});
|
|
31
31
|
it('should handle concurrent inserts of different entities', async () => {
|
|
32
|
-
const [result1, result2, result3] = await withConcurrentTransactions(
|
|
32
|
+
const [result1, result2, result3] = await withConcurrentTransactions(db.getPool(), [
|
|
33
33
|
async (client) => ensureFinancialEntity(client, {
|
|
34
34
|
name: 'Concurrent Entity A',
|
|
35
35
|
type: 'business',
|
|
@@ -51,7 +51,7 @@ describe('ensureFinancialEntity - Concurrent Access', () => {
|
|
|
51
51
|
it('should handle concurrent creation with separate namespaces', async () => {
|
|
52
52
|
// Test that concurrent operations in separate transactions don't interfere
|
|
53
53
|
const timestamp = Date.now();
|
|
54
|
-
const [result1, result2, result3] = await withConcurrentTransactions(
|
|
54
|
+
const [result1, result2, result3] = await withConcurrentTransactions(db.getPool(), [
|
|
55
55
|
async (client) => ensureFinancialEntity(client, {
|
|
56
56
|
name: `Namespace A - ${timestamp}`,
|
|
57
57
|
type: 'business',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"seed-helpers.concurrent.test.js","sourceRoot":"","sources":["../../../../../src/__tests__/helpers/seed-helpers.concurrent.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AACnE,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"seed-helpers.concurrent.test.js","sourceRoot":"","sources":["../../../../../src/__tests__/helpers/seed-helpers.concurrent.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,35 +1,18 @@
|
|
|
1
|
-
import { describe, it, expect, beforeAll, afterAll
|
|
2
|
-
import pg from 'pg';
|
|
1
|
+
import { describe, it, expect, beforeAll, afterAll } from 'vitest';
|
|
3
2
|
import { ensureFinancialEntity } from './seed-helpers.js';
|
|
4
|
-
import {
|
|
3
|
+
import { qualifyTable } from './test-db-config.js';
|
|
5
4
|
import { EntityValidationError } from './seed-errors.js';
|
|
5
|
+
import { TestDatabase } from './db-setup.js';
|
|
6
6
|
describe('ensureFinancialEntity', () => {
|
|
7
|
-
let
|
|
8
|
-
let client;
|
|
7
|
+
let db;
|
|
9
8
|
beforeAll(async () => {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
// Get a client for transactions
|
|
13
|
-
client = await pool.connect();
|
|
9
|
+
db = new TestDatabase();
|
|
10
|
+
await db.connect();
|
|
14
11
|
});
|
|
15
12
|
afterAll(async () => {
|
|
16
|
-
|
|
17
|
-
if (client) {
|
|
18
|
-
client.release();
|
|
19
|
-
}
|
|
20
|
-
if (pool) {
|
|
21
|
-
await pool.end();
|
|
22
|
-
}
|
|
13
|
+
await db.close();
|
|
23
14
|
});
|
|
24
|
-
|
|
25
|
-
// Start transaction before each test
|
|
26
|
-
await client.query('BEGIN');
|
|
27
|
-
});
|
|
28
|
-
afterEach(async () => {
|
|
29
|
-
// Rollback transaction after each test to clean up
|
|
30
|
-
await client.query('ROLLBACK');
|
|
31
|
-
});
|
|
32
|
-
it('should create a new financial entity when it does not exist', async () => {
|
|
15
|
+
it('should create a new financial entity when it does not exist', async () => db.withTransaction(async (client) => {
|
|
33
16
|
const result = await ensureFinancialEntity(client, {
|
|
34
17
|
name: 'Test Entity',
|
|
35
18
|
type: 'business',
|
|
@@ -42,8 +25,8 @@ describe('ensureFinancialEntity', () => {
|
|
|
42
25
|
expect(checkResult.rows[0].name).toBe('Test Entity');
|
|
43
26
|
expect(checkResult.rows[0].type).toBe('business');
|
|
44
27
|
expect(checkResult.rows[0].owner_id).toBeNull();
|
|
45
|
-
});
|
|
46
|
-
it('should return existing entity when called twice with same parameters', async () => {
|
|
28
|
+
}));
|
|
29
|
+
it('should return existing entity when called twice with same parameters', async () => db.withTransaction(async (client) => {
|
|
47
30
|
const firstResult = await ensureFinancialEntity(client, {
|
|
48
31
|
name: 'Duplicate Test',
|
|
49
32
|
type: 'tax_category',
|
|
@@ -56,15 +39,17 @@ describe('ensureFinancialEntity', () => {
|
|
|
56
39
|
// Verify only one row exists
|
|
57
40
|
const countResult = await client.query(`SELECT COUNT(*) FROM ${qualifyTable('financial_entities')} WHERE name = $1 AND type = $2`, ['Duplicate Test', 'tax_category']);
|
|
58
41
|
expect(parseInt(countResult.rows[0].count)).toBe(1);
|
|
59
|
-
});
|
|
60
|
-
it('should handle entities with owner_id', async () => {
|
|
42
|
+
}));
|
|
43
|
+
it('should handle entities with owner_id', async () => db.withTransaction(async (client) => {
|
|
61
44
|
// First create an owner entity (business)
|
|
62
45
|
const ownerEntityResult = await ensureFinancialEntity(client, {
|
|
63
46
|
name: 'Owner Entity',
|
|
64
47
|
type: 'business',
|
|
65
48
|
});
|
|
66
49
|
// Create corresponding business record (required for foreign key)
|
|
67
|
-
await client.query(`INSERT INTO ${qualifyTable('businesses')} (id) VALUES ($1)`, [
|
|
50
|
+
await client.query(`INSERT INTO ${qualifyTable('businesses')} (id) VALUES ($1)`, [
|
|
51
|
+
ownerEntityResult.id,
|
|
52
|
+
]);
|
|
68
53
|
// Create owned entity (tax_category)
|
|
69
54
|
const result = await ensureFinancialEntity(client, {
|
|
70
55
|
name: 'Owned Entity',
|
|
@@ -75,14 +60,16 @@ describe('ensureFinancialEntity', () => {
|
|
|
75
60
|
// Verify owner_id is set correctly
|
|
76
61
|
const checkResult = await client.query(`SELECT owner_id FROM ${qualifyTable('financial_entities')} WHERE id = $1`, [result.id]);
|
|
77
62
|
expect(checkResult.rows[0].owner_id).toBe(ownerEntityResult.id);
|
|
78
|
-
});
|
|
79
|
-
it('should be idempotent for entities with owner_id', async () => {
|
|
63
|
+
}));
|
|
64
|
+
it('should be idempotent for entities with owner_id', async () => db.withTransaction(async (client) => {
|
|
80
65
|
const ownerEntityResult = await ensureFinancialEntity(client, {
|
|
81
66
|
name: 'Owner Business',
|
|
82
67
|
type: 'business',
|
|
83
68
|
});
|
|
84
69
|
// Create corresponding business record
|
|
85
|
-
await client.query(`INSERT INTO ${qualifyTable('businesses')} (id) VALUES ($1)`, [
|
|
70
|
+
await client.query(`INSERT INTO ${qualifyTable('businesses')} (id) VALUES ($1)`, [
|
|
71
|
+
ownerEntityResult.id,
|
|
72
|
+
]);
|
|
86
73
|
const firstResult = await ensureFinancialEntity(client, {
|
|
87
74
|
name: 'Child Entity',
|
|
88
75
|
type: 'tax_category',
|
|
@@ -98,8 +85,8 @@ describe('ensureFinancialEntity', () => {
|
|
|
98
85
|
const countResult = await client.query(`SELECT COUNT(*) FROM ${qualifyTable('financial_entities')}
|
|
99
86
|
WHERE name = $1 AND type = $2 AND owner_id = $3`, ['Child Entity', 'tax_category', ownerEntityResult.id]);
|
|
100
87
|
expect(parseInt(countResult.rows[0].count)).toBe(1);
|
|
101
|
-
});
|
|
102
|
-
it('should distinguish entities by type', async () => {
|
|
88
|
+
}));
|
|
89
|
+
it('should distinguish entities by type', async () => db.withTransaction(async (client) => {
|
|
103
90
|
const businessResult = await ensureFinancialEntity(client, {
|
|
104
91
|
name: 'Same Name',
|
|
105
92
|
type: 'business',
|
|
@@ -109,18 +96,22 @@ describe('ensureFinancialEntity', () => {
|
|
|
109
96
|
type: 'tax_category',
|
|
110
97
|
});
|
|
111
98
|
expect(businessResult.id).not.toBe(taxCategoryResult.id);
|
|
112
|
-
});
|
|
113
|
-
it('should distinguish entities by owner_id', async () => {
|
|
99
|
+
}));
|
|
100
|
+
it('should distinguish entities by owner_id', async () => db.withTransaction(async (client) => {
|
|
114
101
|
const owner1Entity = await ensureFinancialEntity(client, {
|
|
115
102
|
name: 'Owner 1',
|
|
116
103
|
type: 'business',
|
|
117
104
|
});
|
|
118
|
-
await client.query(`INSERT INTO ${qualifyTable('businesses')} (id) VALUES ($1)`, [
|
|
105
|
+
await client.query(`INSERT INTO ${qualifyTable('businesses')} (id) VALUES ($1)`, [
|
|
106
|
+
owner1Entity.id,
|
|
107
|
+
]);
|
|
119
108
|
const owner2Entity = await ensureFinancialEntity(client, {
|
|
120
109
|
name: 'Owner 2',
|
|
121
110
|
type: 'business',
|
|
122
111
|
});
|
|
123
|
-
await client.query(`INSERT INTO ${qualifyTable('businesses')} (id) VALUES ($1)`, [
|
|
112
|
+
await client.query(`INSERT INTO ${qualifyTable('businesses')} (id) VALUES ($1)`, [
|
|
113
|
+
owner2Entity.id,
|
|
114
|
+
]);
|
|
124
115
|
const entity1 = await ensureFinancialEntity(client, {
|
|
125
116
|
name: 'Same Child',
|
|
126
117
|
type: 'tax_category',
|
|
@@ -132,8 +123,8 @@ describe('ensureFinancialEntity', () => {
|
|
|
132
123
|
ownerId: owner2Entity.id,
|
|
133
124
|
});
|
|
134
125
|
expect(entity1.id).not.toBe(entity2.id);
|
|
135
|
-
});
|
|
136
|
-
it('should handle null vs undefined owner_id consistently', async () => {
|
|
126
|
+
}));
|
|
127
|
+
it('should handle null vs undefined owner_id consistently', async () => db.withTransaction(async (client) => {
|
|
137
128
|
const result1 = await ensureFinancialEntity(client, {
|
|
138
129
|
name: 'No Owner Entity',
|
|
139
130
|
type: 'business',
|
|
@@ -144,8 +135,8 @@ describe('ensureFinancialEntity', () => {
|
|
|
144
135
|
type: 'business',
|
|
145
136
|
});
|
|
146
137
|
expect(result1.id).toBe(result2.id);
|
|
147
|
-
});
|
|
148
|
-
it('should not leak data between tests', async () => {
|
|
138
|
+
}));
|
|
139
|
+
it('should not leak data between tests', async () => db.withTransaction(async (client) => {
|
|
149
140
|
// This test verifies that ROLLBACK works correctly
|
|
150
141
|
// Create an entity in this test
|
|
151
142
|
await ensureFinancialEntity(client, {
|
|
@@ -156,25 +147,25 @@ describe('ensureFinancialEntity', () => {
|
|
|
156
147
|
const checkInTransaction = await client.query(`SELECT COUNT(*) FROM ${qualifyTable('financial_entities')} WHERE name = $1`, ['Transient Entity']);
|
|
157
148
|
expect(parseInt(checkInTransaction.rows[0].count)).toBe(1);
|
|
158
149
|
// After ROLLBACK in afterEach, this data won't be visible in next test
|
|
159
|
-
});
|
|
150
|
+
}));
|
|
160
151
|
// Validation tests
|
|
161
|
-
it('should reject empty entity name', async () => {
|
|
152
|
+
it('should reject empty entity name', async () => db.withTransaction(async (client) => {
|
|
162
153
|
await expect(ensureFinancialEntity(client, {
|
|
163
154
|
name: '',
|
|
164
155
|
type: 'business',
|
|
165
156
|
})).rejects.toThrow(EntityValidationError);
|
|
166
|
-
});
|
|
167
|
-
it('should reject invalid entity type', async () => {
|
|
157
|
+
}));
|
|
158
|
+
it('should reject invalid entity type', async () => db.withTransaction(async (client) => {
|
|
168
159
|
await expect(ensureFinancialEntity(client, {
|
|
169
160
|
name: 'Test Entity',
|
|
170
161
|
type: 'invalid_type',
|
|
171
162
|
})).rejects.toThrow(EntityValidationError);
|
|
172
|
-
});
|
|
173
|
-
it('should reject whitespace-only name', async () => {
|
|
163
|
+
}));
|
|
164
|
+
it('should reject whitespace-only name', async () => db.withTransaction(async (client) => {
|
|
174
165
|
await expect(ensureFinancialEntity(client, {
|
|
175
166
|
name: ' ',
|
|
176
167
|
type: 'business',
|
|
177
168
|
})).rejects.toThrow(EntityValidationError);
|
|
178
|
-
});
|
|
169
|
+
}));
|
|
179
170
|
});
|
|
180
171
|
//# sourceMappingURL=seed-helpers.financial-entity.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"seed-helpers.financial-entity.test.js","sourceRoot":"","sources":["../../../../../src/__tests__/helpers/seed-helpers.financial-entity.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,
|
|
1
|
+
{"version":3,"file":"seed-helpers.financial-entity.test.js","sourceRoot":"","sources":["../../../../../src/__tests__/helpers/seed-helpers.financial-entity.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,26 +1,18 @@
|
|
|
1
|
-
import { describe, expect, it, beforeAll, afterAll
|
|
2
|
-
import
|
|
3
|
-
import { testDbConfig, qualifyTable } from './test-db-config.js';
|
|
1
|
+
import { describe, expect, it, beforeAll, afterAll } from 'vitest';
|
|
2
|
+
import { qualifyTable } from './test-db-config.js';
|
|
4
3
|
import { ensureFinancialEntity, ensureTaxCategoryForEntity } from './seed-helpers.js';
|
|
5
4
|
import { EntityValidationError } from './seed-errors.js';
|
|
5
|
+
import { TestDatabase } from './db-setup.js';
|
|
6
6
|
describe('ensureTaxCategoryForEntity', () => {
|
|
7
|
-
let
|
|
8
|
-
let client;
|
|
7
|
+
let db;
|
|
9
8
|
beforeAll(async () => {
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
db = new TestDatabase();
|
|
10
|
+
await db.connect();
|
|
12
11
|
});
|
|
13
12
|
afterAll(async () => {
|
|
14
|
-
|
|
15
|
-
await pool.end();
|
|
13
|
+
await db.close();
|
|
16
14
|
});
|
|
17
|
-
|
|
18
|
-
await client.query('BEGIN');
|
|
19
|
-
});
|
|
20
|
-
afterEach(async () => {
|
|
21
|
-
await client.query('ROLLBACK');
|
|
22
|
-
});
|
|
23
|
-
it('should create tax category on first call', async () => {
|
|
15
|
+
it('should create tax category on first call', async () => db.withTransaction(async (client) => {
|
|
24
16
|
// Create financial entity
|
|
25
17
|
const { id: entityId } = await ensureFinancialEntity(client, {
|
|
26
18
|
name: 'VAT Category',
|
|
@@ -32,8 +24,8 @@ describe('ensureTaxCategoryForEntity', () => {
|
|
|
32
24
|
const result = await client.query(`SELECT id FROM ${qualifyTable('tax_categories')} WHERE id = $1`, [entityId]);
|
|
33
25
|
expect(result.rows).toHaveLength(1);
|
|
34
26
|
expect(result.rows[0].id).toBe(entityId);
|
|
35
|
-
});
|
|
36
|
-
it('should be idempotent (no-op on repeated calls)', async () => {
|
|
27
|
+
}));
|
|
28
|
+
it('should be idempotent (no-op on repeated calls)', async () => db.withTransaction(async (client) => {
|
|
37
29
|
// Create financial entity
|
|
38
30
|
const { id: entityId } = await ensureFinancialEntity(client, {
|
|
39
31
|
name: 'Income Tax',
|
|
@@ -45,8 +37,8 @@ describe('ensureTaxCategoryForEntity', () => {
|
|
|
45
37
|
// Verify only one row exists
|
|
46
38
|
const result = await client.query(`SELECT COUNT(*) as count FROM ${qualifyTable('tax_categories')} WHERE id = $1`, [entityId]);
|
|
47
39
|
expect(result.rows[0].count).toBe('1');
|
|
48
|
-
});
|
|
49
|
-
it('should preserve existing values on subsequent calls', async () => {
|
|
40
|
+
}));
|
|
41
|
+
it('should preserve existing values on subsequent calls', async () => db.withTransaction(async (client) => {
|
|
50
42
|
// Create financial entity
|
|
51
43
|
const { id: entityId } = await ensureFinancialEntity(client, {
|
|
52
44
|
name: 'Expense Category',
|
|
@@ -63,24 +55,24 @@ describe('ensureTaxCategoryForEntity', () => {
|
|
|
63
55
|
const finalResult = await client.query(`SELECT * FROM ${qualifyTable('tax_categories')} WHERE id = $1`, [entityId]);
|
|
64
56
|
const finalRow = finalResult.rows[0];
|
|
65
57
|
expect(finalRow).toEqual(initialRow);
|
|
66
|
-
});
|
|
67
|
-
it('should reject invalid UUID format', async () => {
|
|
58
|
+
}));
|
|
59
|
+
it('should reject invalid UUID format', async () => db.withTransaction(async (client) => {
|
|
68
60
|
await expect(ensureTaxCategoryForEntity(client, 'not-a-uuid')).rejects.toThrow(EntityValidationError);
|
|
69
61
|
await expect(ensureTaxCategoryForEntity(client, '')).rejects.toThrow(EntityValidationError);
|
|
70
62
|
await expect(ensureTaxCategoryForEntity(client, '12345')).rejects.toThrow(EntityValidationError);
|
|
71
|
-
});
|
|
72
|
-
it('should reject non-existent financial entity', async () => {
|
|
63
|
+
}));
|
|
64
|
+
it('should reject non-existent financial entity', async () => db.withTransaction(async (client) => {
|
|
73
65
|
const fakeUuid = '00000000-0000-0000-0000-000000000001';
|
|
74
66
|
await expect(ensureTaxCategoryForEntity(client, fakeUuid)).rejects.toThrow(EntityValidationError);
|
|
75
|
-
});
|
|
76
|
-
it('should not leak data between tests', async () => {
|
|
67
|
+
}));
|
|
68
|
+
it('should not leak data between tests', async () => db.withTransaction(async (client) => {
|
|
77
69
|
// This test verifies transactional isolation by checking that data
|
|
78
70
|
// from previous tests is not visible
|
|
79
71
|
const result = await client.query(`SELECT COUNT(*) as count FROM ${qualifyTable('tax_categories')} WHERE id IN (SELECT id FROM ${qualifyTable('financial_entities')} WHERE name LIKE 'VAT Category' OR name LIKE 'Income Tax' OR name LIKE 'Expense Category')`);
|
|
80
72
|
// Due to ROLLBACK after each test, count should be 0
|
|
81
73
|
expect(parseInt(result.rows[0].count)).toBe(0);
|
|
82
|
-
});
|
|
83
|
-
it('should work with entities that have owner_id', async () => {
|
|
74
|
+
}));
|
|
75
|
+
it('should work with entities that have owner_id', async () => db.withTransaction(async (client) => {
|
|
84
76
|
// Create owner business entity (without owner_id requirement)
|
|
85
77
|
const { id: _ownerId } = await ensureFinancialEntity(client, {
|
|
86
78
|
name: 'Owner Business',
|
|
@@ -97,8 +89,8 @@ describe('ensureTaxCategoryForEntity', () => {
|
|
|
97
89
|
const result = await client.query(`SELECT id FROM ${qualifyTable('tax_categories')} WHERE id = $1`, [taxCatId]);
|
|
98
90
|
expect(result.rows).toHaveLength(1);
|
|
99
91
|
expect(result.rows[0].id).toBe(taxCatId);
|
|
100
|
-
});
|
|
101
|
-
it('should handle options parameter gracefully (future-proofing)', async () => {
|
|
92
|
+
}));
|
|
93
|
+
it('should handle options parameter gracefully (future-proofing)', async () => db.withTransaction(async (client) => {
|
|
102
94
|
// Create financial entity
|
|
103
95
|
const { id: entityId } = await ensureFinancialEntity(client, {
|
|
104
96
|
name: 'Category with Options',
|
|
@@ -109,6 +101,6 @@ describe('ensureTaxCategoryForEntity', () => {
|
|
|
109
101
|
// Verify tax category exists
|
|
110
102
|
const result = await client.query(`SELECT id FROM ${qualifyTable('tax_categories')} WHERE id = $1`, [entityId]);
|
|
111
103
|
expect(result.rows).toHaveLength(1);
|
|
112
|
-
});
|
|
104
|
+
}));
|
|
113
105
|
});
|
|
114
106
|
//# sourceMappingURL=seed-helpers.tax-category.test.js.map
|