From 7e36131229afefb94752c6e697eaa896747abd0b Mon Sep 17 00:00:00 2001 From: Michael Bromley Date: Mon, 14 Oct 2024 22:02:27 +0200 Subject: [PATCH] fix(core): Improve error message on populating without tax rates Fixes #1926 --- .../providers/importer/importer.ts | 19 +++++++++++++++++-- .../providers/populator/populator.ts | 2 -- 2 files changed, 17 insertions(+), 4 deletions(-) diff --git a/packages/core/src/data-import/providers/importer/importer.ts b/packages/core/src/data-import/providers/importer/importer.ts index 3bfee91fd7..5d30b500c7 100644 --- a/packages/core/src/data-import/providers/importer/importer.ts +++ b/packages/core/src/data-import/providers/importer/importer.ts @@ -10,6 +10,7 @@ import { RequestContext } from '../../../api/common/request-context'; import { InternalServerError } from '../../../common/error/errors'; import { ConfigService } from '../../../config/config.service'; import { CustomFieldConfig } from '../../../config/custom-field/custom-field-types'; +import { Logger } from '../../../config/index'; import { Facet } from '../../../entity/facet/facet.entity'; import { FacetValue } from '../../../entity/facet-value/facet-value.entity'; import { TaxCategory } from '../../../entity/tax-category/tax-category.entity'; @@ -159,6 +160,17 @@ export class Importer { let imported = 0; const languageCode = ctx.languageCode; const taxCategories = await this.taxCategoryService.findAll(ctx); + if (taxCategories.totalItems === 0) { + Logger.error( + [ + `No TaxCategories found in the database. Ensure that at least one TaxCategory exists.`, + `If you are populating from an InitialData object, ensure the 'taxRates' array is not empty.`, + ].join('\n'), + ); + throw new Error( + `No TaxCategories found in the database. Ensure the IntialData.taxRates array is not empty.`, + ); + } await this.fastImporter.initialize(ctx.channel); for (const { product, variants } of rows) { const productMainTranslation = this.getTranslationByCodeOrFirst( @@ -207,7 +219,7 @@ export class Importer { ); const groupId = await this.fastImporter.createProductOptionGroup({ code, - options: optionGroupMainTranslation.values.map(name => ({} as any)), + options: optionGroupMainTranslation.values.map(name => ({}) as any), translations: optionGroup.translations.map(translation => { return { languageCode: translation.languageCode, @@ -363,7 +375,10 @@ export class Importer { return facetValueIds; } - protected processCustomFieldValues(customFields: { [field: string]: string }, config: CustomFieldConfig[]) { + protected processCustomFieldValues( + customFields: { [field: string]: string }, + config: CustomFieldConfig[], + ) { const processed: { [field: string]: string | string[] | boolean | undefined } = {}; for (const fieldDef of config) { const value = customFields[fieldDef.name]; diff --git a/packages/core/src/data-import/providers/populator/populator.ts b/packages/core/src/data-import/providers/populator/populator.ts index e389cec936..99cef051fe 100644 --- a/packages/core/src/data-import/providers/populator/populator.ts +++ b/packages/core/src/data-import/providers/populator/populator.ts @@ -271,8 +271,6 @@ export class Populator { taxRates: Array<{ name: string; percentage: number }>, zoneMap: ZoneMap, ) { - const taxCategories: TaxCategory[] = []; - for (const taxRate of taxRates) { const category = await this.taxCategoryService.create(ctx, { name: taxRate.name });