From e8e59be8948a1fb6d62e367d6df6fd4e3974f173 Mon Sep 17 00:00:00 2001 From: salander85 Date: Thu, 26 Oct 2023 11:54:00 +0200 Subject: [PATCH] Migrate ITs for productsync with references --- .../sync/ProductSyncWithReferencesIT.java | 542 +++++++++--------- .../project/sync/util/CtpClientUtils.java | 17 +- 2 files changed, 287 insertions(+), 272 deletions(-) diff --git a/src/integration-test/java/com/commercetools/project/sync/ProductSyncWithReferencesIT.java b/src/integration-test/java/com/commercetools/project/sync/ProductSyncWithReferencesIT.java index 7a7bf0b9..02eefe9b 100644 --- a/src/integration-test/java/com/commercetools/project/sync/ProductSyncWithReferencesIT.java +++ b/src/integration-test/java/com/commercetools/project/sync/ProductSyncWithReferencesIT.java @@ -1,270 +1,272 @@ -// package com.commercetools.project.sync; -// -// import static com.commercetools.project.sync.util.CtpClientUtils.CTP_SOURCE_CLIENT; -// import static com.commercetools.project.sync.util.CtpClientUtils.CTP_TARGET_CLIENT; -// import static com.commercetools.project.sync.util.IntegrationTestUtils.assertProductTypeExists; -// import static com.commercetools.project.sync.util.IntegrationTestUtils.cleanUpProjects; -// import static com.commercetools.project.sync.util.IntegrationTestUtils.createITSyncerFactory; -// import static com.commercetools.project.sync.util.IntegrationTestUtils.createReferenceObject; -// import static -// com.commercetools.project.sync.util.TestUtils.assertCartDiscountSyncerLoggingEvents; -// import static com.commercetools.project.sync.util.TestUtils.assertCategorySyncerLoggingEvents; -// import static -// com.commercetools.project.sync.util.TestUtils.assertCustomObjectSyncerLoggingEvents; -// import static com.commercetools.project.sync.util.TestUtils.assertCustomerSyncerLoggingEvents; -// import static -// com.commercetools.project.sync.util.TestUtils.assertInventoryEntrySyncerLoggingEvents; -// import static com.commercetools.project.sync.util.TestUtils.assertProductSyncerLoggingEvents; -// import static com.commercetools.project.sync.util.TestUtils.assertProductTypeSyncerLoggingEvents; -// import static -// com.commercetools.project.sync.util.TestUtils.assertShoppingListSyncerLoggingEvents; -// import static com.commercetools.project.sync.util.TestUtils.assertStateSyncerLoggingEvents; -// import static com.commercetools.project.sync.util.TestUtils.assertTaxCategorySyncerLoggingEvents; -// import static com.commercetools.project.sync.util.TestUtils.assertTypeSyncerLoggingEvents; -// import static io.sphere.sdk.models.LocalizedString.ofEnglish; -// import static java.lang.String.format; -// import static java.util.Collections.emptyList; -// import static java.util.Collections.singletonList; -// import static org.assertj.core.api.Assertions.assertThat; -// -// import com.commercetools.project.sync.cartdiscount.CartDiscountSyncer; -// import com.commercetools.project.sync.category.CategorySyncer; -// import com.commercetools.project.sync.customer.CustomerSyncer; -// import com.commercetools.project.sync.customobject.CustomObjectSyncer; -// import com.commercetools.project.sync.inventoryentry.InventoryEntrySyncer; -// import com.commercetools.project.sync.product.ProductSyncer; -// import com.commercetools.project.sync.producttype.ProductTypeSyncer; -// import com.commercetools.project.sync.shoppinglist.ShoppingListSyncer; -// import com.commercetools.project.sync.state.StateSyncer; -// import com.commercetools.project.sync.taxcategory.TaxCategorySyncer; -// import com.commercetools.project.sync.type.TypeSyncer; -// import com.commercetools.sync.commons.models.WaitingToBeResolved; -// import com.commercetools.sync.commons.utils.CtpQueryUtils; -// import com.fasterxml.jackson.databind.node.ArrayNode; -// import com.fasterxml.jackson.databind.node.JsonNodeFactory; -// import com.fasterxml.jackson.databind.node.ObjectNode; -// import io.sphere.sdk.client.SphereClient; -// import io.sphere.sdk.customobjects.CustomObject; -// import io.sphere.sdk.customobjects.queries.CustomObjectQuery; -// import io.sphere.sdk.products.Product; -// import io.sphere.sdk.products.ProductDraft; -// import io.sphere.sdk.products.ProductDraftBuilder; -// import io.sphere.sdk.products.ProductVariantDraft; -// import io.sphere.sdk.products.ProductVariantDraftBuilder; -// import io.sphere.sdk.products.attributes.AttributeConstraint; -// import io.sphere.sdk.products.attributes.AttributeDefinitionDraft; -// import io.sphere.sdk.products.attributes.AttributeDefinitionDraftBuilder; -// import io.sphere.sdk.products.attributes.AttributeDraft; -// import io.sphere.sdk.products.attributes.ReferenceAttributeType; -// import io.sphere.sdk.products.attributes.SetAttributeType; -// import io.sphere.sdk.products.commands.ProductCreateCommand; -// import io.sphere.sdk.products.queries.ProductQuery; -// import io.sphere.sdk.producttypes.ProductType; -// import io.sphere.sdk.producttypes.ProductTypeDraft; -// import io.sphere.sdk.producttypes.ProductTypeDraftBuilder; -// import io.sphere.sdk.producttypes.commands.ProductTypeCreateCommand; -// import io.sphere.sdk.queries.PagedQueryResult; -// import java.util.List; -// import java.util.Set; -// import java.util.concurrent.CompletableFuture; -// import java.util.concurrent.ConcurrentHashMap; -// import java.util.function.Function; -// import java.util.stream.Collectors; -// import java.util.stream.IntStream; -// import javax.annotation.Nonnull; -// import org.junit.jupiter.api.AfterAll; -// import org.junit.jupiter.api.BeforeEach; -// import org.junit.jupiter.api.Test; -// import uk.org.lidalia.slf4jext.Level; -// import uk.org.lidalia.slf4jtest.TestLogger; -// import uk.org.lidalia.slf4jtest.TestLoggerFactory; -// -//// This will suppress MoreThanOneLogger warnings in this class -// @SuppressWarnings("PMD.MoreThanOneLogger") -// class ProductSyncWithReferencesIT { -// -// private static final TestLogger productSyncerTestLogger = -// TestLoggerFactory.getTestLogger(ProductSyncer.class); -// private static final TestLogger cliRunnerTestLogger = -// TestLoggerFactory.getTestLogger(CliRunner.class); -// private static final TestLogger productTypeSyncerTestLogger = -// TestLoggerFactory.getTestLogger(ProductTypeSyncer.class); -// private static final TestLogger customerSyncerTestLogger = -// TestLoggerFactory.getTestLogger(CustomerSyncer.class); -// private static final TestLogger shoppingListSyncerTestLogger = -// TestLoggerFactory.getTestLogger(ShoppingListSyncer.class); -// private static final TestLogger stateSyncerTestLogger = -// TestLoggerFactory.getTestLogger(StateSyncer.class); -// private static final TestLogger inventoryEntrySyncerTestLogger = -// TestLoggerFactory.getTestLogger(InventoryEntrySyncer.class); -// private static final TestLogger customObjectSyncerTestLogger = -// TestLoggerFactory.getTestLogger(CustomObjectSyncer.class); -// private static final TestLogger typeSyncerTestLogger = -// TestLoggerFactory.getTestLogger(TypeSyncer.class); -// private static final TestLogger categorySyncerTestLogger = -// TestLoggerFactory.getTestLogger(CategorySyncer.class); -// private static final TestLogger cartDiscountSyncerTestLogger = -// TestLoggerFactory.getTestLogger(CartDiscountSyncer.class); -// private static final TestLogger taxCategorySyncerTestLogger = -// TestLoggerFactory.getTestLogger(TaxCategorySyncer.class); -// -// private static final String MAIN_PRODUCT_TYPE_KEY = "main-product-type"; -// private static final String MAIN_PRODUCT_MASTER_VARIANT_KEY = "main-product-master-variant-key"; -// private static final String MAIN_PRODUCT_KEY = "product-with-references"; -// -// @BeforeEach -// void setup() { -// cliRunnerTestLogger.clearAll(); -// productSyncerTestLogger.clearAll(); -// productTypeSyncerTestLogger.clearAll(); -// customerSyncerTestLogger.clearAll(); -// shoppingListSyncerTestLogger.clearAll(); -// stateSyncerTestLogger.clearAll(); -// inventoryEntrySyncerTestLogger.clearAll(); -// customObjectSyncerTestLogger.clearAll(); -// typeSyncerTestLogger.clearAll(); -// categorySyncerTestLogger.clearAll(); -// cartDiscountSyncerTestLogger.clearAll(); -// taxCategorySyncerTestLogger.clearAll(); -// cleanUpProjects(CTP_SOURCE_CLIENT, CTP_TARGET_CLIENT); -// setupSourceProjectData(CTP_SOURCE_CLIENT); -// } -// -// static void setupSourceProjectData(@Nonnull final SphereClient sourceProjectClient) { -// final AttributeDefinitionDraft setOfProductsAttributeDef = -// AttributeDefinitionDraftBuilder.of( -// SetAttributeType.of(ReferenceAttributeType.ofProduct()), -// "products", -// ofEnglish("products"), -// false) -// .searchable(false) -// .attributeConstraint(AttributeConstraint.NONE) -// .build(); -// -// final ProductTypeDraft productTypeDraft = -// ProductTypeDraftBuilder.of( -// MAIN_PRODUCT_TYPE_KEY, -// MAIN_PRODUCT_TYPE_KEY, -// "a productType for t-shirts", -// emptyList()) -// .attributes(singletonList(setOfProductsAttributeDef)) -// .build(); -// -// final ProductType productType = -// sourceProjectClient -// .execute(ProductTypeCreateCommand.of(productTypeDraft)) -// .toCompletableFuture() -// .join(); -// -// final ConcurrentHashMap.KeySetView productIds = -// ConcurrentHashMap.newKeySet(); -// -// // create 500 products -// final CompletableFuture[] creationFutures = -// IntStream.range(0, 500) -// .mapToObj( -// index -> { -// final ProductVariantDraft masterVariant = -// ProductVariantDraftBuilder.of() -// .key(format("%d-mv-key", index)) -// .sku(format("%d-mv-sku", index)) -// .build(); -// -// final ProductDraft draft = -// ProductDraftBuilder.of( -// productType, -// ofEnglish(Integer.toString(index)), -// ofEnglish(format("%d-slug", index)), -// masterVariant) -// .key(format("%d-key", index)) -// .build(); -// return CTP_SOURCE_CLIENT -// .execute(ProductCreateCommand.of(draft)) -// .thenAccept(createdProduct -> productIds.add(createdProduct.getId())) -// .toCompletableFuture(); -// }) -// .toArray(CompletableFuture[]::new); -// -// CompletableFuture.allOf(creationFutures).join(); -// -// final ArrayNode setAttributeValue = JsonNodeFactory.instance.arrayNode(); -// final Set productReferences = -// productIds.stream() -// .map(productId -> createReferenceObject(Product.referenceTypeId(), productId)) -// .collect(Collectors.toSet()); -// setAttributeValue.addAll(productReferences); -// -// final ProductVariantDraft masterVariant = -// ProductVariantDraftBuilder.of() -// .key(MAIN_PRODUCT_MASTER_VARIANT_KEY) -// .sku(MAIN_PRODUCT_MASTER_VARIANT_KEY) -// .attributes(AttributeDraft.of(setOfProductsAttributeDef.getName(), setAttributeValue)) -// .build(); -// -// final ProductDraft draft = -// ProductDraftBuilder.of( -// productType, -// ofEnglish(MAIN_PRODUCT_KEY), -// ofEnglish(MAIN_PRODUCT_KEY), -// masterVariant) -// .key(MAIN_PRODUCT_KEY) -// .build(); -// -// sourceProjectClient.execute(ProductCreateCommand.of(draft)).toCompletableFuture().join(); -// } -// -// @AfterAll -// static void tearDownSuite() { -// cleanUpProjects(CTP_SOURCE_CLIENT, CTP_TARGET_CLIENT); -// } -// -// @Test -// void run_WithAProductWith500DistinctReferences_ShouldSyncCorrectly() { -// // test -// CliRunner.of() -// .run(new String[] {"-s", "all", "-r", "runnerName", "-f"}, createITSyncerFactory()); -// -// // assertions -// assertThat(cliRunnerTestLogger.getAllLoggingEvents()) -// .allMatch(loggingEvent -> !Level.ERROR.equals(loggingEvent.getLevel())); -// -// assertTypeSyncerLoggingEvents(typeSyncerTestLogger, 0); -// assertProductTypeSyncerLoggingEvents(productTypeSyncerTestLogger, 1); -// assertTaxCategorySyncerLoggingEvents(taxCategorySyncerTestLogger, 0); -// assertCategorySyncerLoggingEvents(categorySyncerTestLogger, 0); -// assertProductSyncerLoggingEvents(productSyncerTestLogger, 501); -// assertInventoryEntrySyncerLoggingEvents(inventoryEntrySyncerTestLogger, 0); -// assertCartDiscountSyncerLoggingEvents(cartDiscountSyncerTestLogger, 0); -// assertCustomerSyncerLoggingEvents(customerSyncerTestLogger, 0); -// assertShoppingListSyncerLoggingEvents(shoppingListSyncerTestLogger, 0); -// assertStateSyncerLoggingEvents( -// stateSyncerTestLogger, 1); // 1 state is built-in and it cant be deleted -// assertCustomObjectSyncerLoggingEvents(customObjectSyncerTestLogger, 0); -// -// assertAllResourcesAreSyncedToTarget(CTP_TARGET_CLIENT); -// } -// -// private static void assertAllResourcesAreSyncedToTarget( -// @Nonnull final SphereClient targetClient) { -// -// assertProductTypeExists(targetClient, MAIN_PRODUCT_TYPE_KEY); -// -// final List products = -// CtpQueryUtils.queryAll(targetClient, ProductQuery.of(), Function.identity()) -// .thenApply( -// fetchedProducts -> -// fetchedProducts.stream().flatMap(List::stream).collect(Collectors.toList())) -// .toCompletableFuture() -// .join(); -// assertThat(products).hasSize(501); -// -// final CustomObjectQuery customObjectQuery = -// CustomObjectQuery.of(WaitingToBeResolved.class) -// .byContainer("commercetools-sync-java.UnresolvedReferencesService.productDrafts"); -// -// final PagedQueryResult> queryResult = -// targetClient.execute(customObjectQuery).toCompletableFuture().join(); -// -// assertThat(queryResult.getResults()).isEmpty(); -// } -// } +package com.commercetools.project.sync; + +import static com.commercetools.api.models.common.LocalizedString.ofEnglish; +import static com.commercetools.project.sync.util.CtpClientUtils.CTP_SOURCE_CLIENT; +import static com.commercetools.project.sync.util.CtpClientUtils.CTP_TARGET_CLIENT; +import static com.commercetools.project.sync.util.IntegrationTestUtils.assertProductTypeExists; +import static com.commercetools.project.sync.util.IntegrationTestUtils.cleanUpProjects; +import static com.commercetools.project.sync.util.IntegrationTestUtils.createITSyncerFactory; +import static com.commercetools.project.sync.util.IntegrationTestUtils.createReferenceOfType; +import static com.commercetools.project.sync.util.TestUtils.assertCartDiscountSyncerLoggingEvents; +import static com.commercetools.project.sync.util.TestUtils.assertCategorySyncerLoggingEvents; +import static com.commercetools.project.sync.util.TestUtils.assertCustomObjectSyncerLoggingEvents; +import static com.commercetools.project.sync.util.TestUtils.assertCustomerSyncerLoggingEvents; +import static com.commercetools.project.sync.util.TestUtils.assertInventoryEntrySyncerLoggingEvents; +import static com.commercetools.project.sync.util.TestUtils.assertProductSyncerLoggingEvents; +import static com.commercetools.project.sync.util.TestUtils.assertProductTypeSyncerLoggingEvents; +import static com.commercetools.project.sync.util.TestUtils.assertShoppingListSyncerLoggingEvents; +import static com.commercetools.project.sync.util.TestUtils.assertStateSyncerLoggingEvents; +import static com.commercetools.project.sync.util.TestUtils.assertTaxCategorySyncerLoggingEvents; +import static com.commercetools.project.sync.util.TestUtils.assertTypeSyncerLoggingEvents; +import static java.lang.String.format; +import static org.assertj.core.api.Assertions.assertThat; + +import com.commercetools.api.client.ProjectApiRoot; +import com.commercetools.api.client.QueryUtils; +import com.commercetools.api.models.common.ReferenceTypeId; +import com.commercetools.api.models.custom_object.CustomObjectPagedQueryResponse; +import com.commercetools.api.models.product.AttributeBuilder; +import com.commercetools.api.models.product.Product; +import com.commercetools.api.models.product.ProductDraft; +import com.commercetools.api.models.product.ProductDraftBuilder; +import com.commercetools.api.models.product.ProductVariantDraft; +import com.commercetools.api.models.product.ProductVariantDraftBuilder; +import com.commercetools.api.models.product_type.AttributeConstraintEnum; +import com.commercetools.api.models.product_type.AttributeDefinitionDraft; +import com.commercetools.api.models.product_type.AttributeDefinitionDraftBuilder; +import com.commercetools.api.models.product_type.AttributeReferenceTypeId; +import com.commercetools.api.models.product_type.ProductType; +import com.commercetools.api.models.product_type.ProductTypeDraft; +import com.commercetools.api.models.product_type.ProductTypeDraftBuilder; +import com.commercetools.project.sync.cartdiscount.CartDiscountSyncer; +import com.commercetools.project.sync.category.CategorySyncer; +import com.commercetools.project.sync.customer.CustomerSyncer; +import com.commercetools.project.sync.customobject.CustomObjectSyncer; +import com.commercetools.project.sync.inventoryentry.InventoryEntrySyncer; +import com.commercetools.project.sync.product.ProductSyncer; +import com.commercetools.project.sync.producttype.ProductTypeSyncer; +import com.commercetools.project.sync.shoppinglist.ShoppingListSyncer; +import com.commercetools.project.sync.state.StateSyncer; +import com.commercetools.project.sync.taxcategory.TaxCategorySyncer; +import com.commercetools.project.sync.type.TypeSyncer; +import com.fasterxml.jackson.databind.node.ArrayNode; +import com.fasterxml.jackson.databind.node.JsonNodeFactory; +import com.fasterxml.jackson.databind.node.ObjectNode; +import io.vrap.rmf.base.client.ApiHttpResponse; +import java.util.List; +import java.util.Set; +import java.util.concurrent.CompletableFuture; +import java.util.concurrent.ConcurrentHashMap; +import java.util.function.Function; +import java.util.stream.Collectors; +import java.util.stream.IntStream; +import javax.annotation.Nonnull; +import org.junit.jupiter.api.AfterAll; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import uk.org.lidalia.slf4jext.Level; +import uk.org.lidalia.slf4jtest.TestLogger; +import uk.org.lidalia.slf4jtest.TestLoggerFactory; + +// This will suppress MoreThanOneLogger warnings in this class +@SuppressWarnings("PMD.MoreThanOneLogger") +class ProductSyncWithReferencesIT { + + private static final TestLogger productSyncerTestLogger = + TestLoggerFactory.getTestLogger(ProductSyncer.class); + private static final TestLogger cliRunnerTestLogger = + TestLoggerFactory.getTestLogger(CliRunner.class); + private static final TestLogger productTypeSyncerTestLogger = + TestLoggerFactory.getTestLogger(ProductTypeSyncer.class); + private static final TestLogger customerSyncerTestLogger = + TestLoggerFactory.getTestLogger(CustomerSyncer.class); + private static final TestLogger shoppingListSyncerTestLogger = + TestLoggerFactory.getTestLogger(ShoppingListSyncer.class); + private static final TestLogger stateSyncerTestLogger = + TestLoggerFactory.getTestLogger(StateSyncer.class); + private static final TestLogger inventoryEntrySyncerTestLogger = + TestLoggerFactory.getTestLogger(InventoryEntrySyncer.class); + private static final TestLogger customObjectSyncerTestLogger = + TestLoggerFactory.getTestLogger(CustomObjectSyncer.class); + private static final TestLogger typeSyncerTestLogger = + TestLoggerFactory.getTestLogger(TypeSyncer.class); + private static final TestLogger categorySyncerTestLogger = + TestLoggerFactory.getTestLogger(CategorySyncer.class); + private static final TestLogger cartDiscountSyncerTestLogger = + TestLoggerFactory.getTestLogger(CartDiscountSyncer.class); + private static final TestLogger taxCategorySyncerTestLogger = + TestLoggerFactory.getTestLogger(TaxCategorySyncer.class); + + private static final String MAIN_PRODUCT_TYPE_KEY = "main-product-type"; + private static final String MAIN_PRODUCT_MASTER_VARIANT_KEY = "main-product-master-variant-key"; + private static final String MAIN_PRODUCT_KEY = "product-with-references"; + + @BeforeEach + void setup() { + cleanUpProjects(CTP_SOURCE_CLIENT, CTP_TARGET_CLIENT); + cliRunnerTestLogger.clearAll(); + productSyncerTestLogger.clearAll(); + productTypeSyncerTestLogger.clearAll(); + customerSyncerTestLogger.clearAll(); + shoppingListSyncerTestLogger.clearAll(); + stateSyncerTestLogger.clearAll(); + inventoryEntrySyncerTestLogger.clearAll(); + customObjectSyncerTestLogger.clearAll(); + typeSyncerTestLogger.clearAll(); + categorySyncerTestLogger.clearAll(); + cartDiscountSyncerTestLogger.clearAll(); + taxCategorySyncerTestLogger.clearAll(); + setupSourceProjectData(CTP_SOURCE_CLIENT); + } + + static void setupSourceProjectData(@Nonnull final ProjectApiRoot sourceProjectClient) { + final AttributeDefinitionDraft setOfProductsAttributeDef = + AttributeDefinitionDraftBuilder.of() + .type( + attributeTypeBuilder -> + attributeTypeBuilder + .setBuilder() + .elementType( + elementBuilder -> + elementBuilder + .referenceBuilder() + .referenceTypeId(AttributeReferenceTypeId.PRODUCT))) + .name("products") + .label(ofEnglish("products")) + .isRequired(false) + .isSearchable(false) + .attributeConstraint(AttributeConstraintEnum.NONE) + .build(); + + final ProductTypeDraft productTypeDraft = + ProductTypeDraftBuilder.of() + .key(MAIN_PRODUCT_TYPE_KEY) + .name(MAIN_PRODUCT_TYPE_KEY) + .description("an inner productType for t-shirts") + .attributes(setOfProductsAttributeDef) + .build(); + + final ProductType productType = + sourceProjectClient.productTypes().post(productTypeDraft).executeBlocking().getBody(); + + final ConcurrentHashMap.KeySetView productIds = ConcurrentHashMap.newKeySet(); + + CompletableFuture.allOf( + IntStream.range(0, 500) + .mapToObj(value -> createProduct(sourceProjectClient, productType, value)) + .toArray(CompletableFuture[]::new)) + .join(); + + final ArrayNode setAttributeValue = JsonNodeFactory.instance.arrayNode(); + final Set productReferences = + productIds.stream() + .map( + productId -> + createReferenceOfType(ReferenceTypeId.PRODUCT.getJsonName(), productId)) + .collect(Collectors.toSet()); + setAttributeValue.addAll(productReferences); + + final ProductVariantDraft masterVariant = + ProductVariantDraftBuilder.of() + .key(MAIN_PRODUCT_MASTER_VARIANT_KEY) + .sku(MAIN_PRODUCT_MASTER_VARIANT_KEY) + .attributes( + AttributeBuilder.of() + .name(setOfProductsAttributeDef.getName()) + .value(setAttributeValue) + .build()) + .build(); + + final ProductDraft draft = + ProductDraftBuilder.of() + .productType(productType.toResourceIdentifier()) + .name(ofEnglish(MAIN_PRODUCT_KEY)) + .slug(ofEnglish(MAIN_PRODUCT_KEY)) + .masterVariant(masterVariant) + .key(MAIN_PRODUCT_KEY) + .build(); + + sourceProjectClient.products().post(draft).executeBlocking(); + } + + private static CompletableFuture createProduct( + @Nonnull final ProjectApiRoot sourceProjectClient, + @Nonnull final ProductType productType, + int index) { + final ProductVariantDraft masterVariant = + ProductVariantDraftBuilder.of() + .key(format("%d-mv-key", index)) + .sku(format("%d-mv-sku", index)) + .build(); + final ProductDraft draft = + ProductDraftBuilder.of() + .productType(productType.toResourceIdentifier()) + .name(ofEnglish(Integer.toString(index))) + .slug(ofEnglish(format("%d-slug", index))) + .masterVariant(masterVariant) + .key(format("%d-key", index)) + .build(); + return sourceProjectClient + .products() + .create(draft) + .execute() + .thenApply(ApiHttpResponse::getBody) + .toCompletableFuture(); + } + + @AfterAll + static void tearDownSuite() { + cleanUpProjects(CTP_SOURCE_CLIENT, CTP_TARGET_CLIENT); + } + + @Test + void run_WithAProductWith500DistinctReferences_ShouldSyncCorrectly() { + // test + CliRunner.of() + .run(new String[] {"-s", "all", "-r", "runnerName", "-f"}, createITSyncerFactory()); + + // assertions + assertThat(cliRunnerTestLogger.getAllLoggingEvents()) + .allMatch(loggingEvent -> !Level.ERROR.equals(loggingEvent.getLevel())); + + assertTypeSyncerLoggingEvents(typeSyncerTestLogger, 0); + assertProductTypeSyncerLoggingEvents(productTypeSyncerTestLogger, 1); + assertTaxCategorySyncerLoggingEvents(taxCategorySyncerTestLogger, 0); + assertCategorySyncerLoggingEvents(categorySyncerTestLogger, 0); + assertProductSyncerLoggingEvents(productSyncerTestLogger, 501); + assertInventoryEntrySyncerLoggingEvents(inventoryEntrySyncerTestLogger, 0); + assertCartDiscountSyncerLoggingEvents(cartDiscountSyncerTestLogger, 0); + assertCustomerSyncerLoggingEvents(customerSyncerTestLogger, 0); + assertShoppingListSyncerLoggingEvents(shoppingListSyncerTestLogger, 0); + assertStateSyncerLoggingEvents( + stateSyncerTestLogger, 1); // 1 state is built-in and it cant be deleted + assertCustomObjectSyncerLoggingEvents(customObjectSyncerTestLogger, 0); + + assertAllResourcesAreSyncedToTarget(CTP_TARGET_CLIENT); + } + + private static void assertAllResourcesAreSyncedToTarget( + @Nonnull final ProjectApiRoot targetClient) { + + assertProductTypeExists(targetClient, MAIN_PRODUCT_TYPE_KEY); + + final List products = + QueryUtils.queryAll(targetClient.products().get(), Function.identity()) + .thenApply( + fetchedProducts -> + fetchedProducts.stream().flatMap(List::stream).collect(Collectors.toList())) + .toCompletableFuture() + .join(); + assertThat(products).hasSize(501); + + final CustomObjectPagedQueryResponse queryResult = + targetClient + .customObjects() + .withContainer("commercetools-sync-java.UnresolvedReferencesService" + ".productDrafts") + .get() + .executeBlocking() + .getBody(); + + assertThat(queryResult.getResults()).isEmpty(); + } +} diff --git a/src/main/java/com/commercetools/project/sync/util/CtpClientUtils.java b/src/main/java/com/commercetools/project/sync/util/CtpClientUtils.java index 265a2d68..fc66a9bf 100644 --- a/src/main/java/com/commercetools/project/sync/util/CtpClientUtils.java +++ b/src/main/java/com/commercetools/project/sync/util/CtpClientUtils.java @@ -3,10 +3,12 @@ import static java.lang.String.format; import com.commercetools.api.client.ProjectApiRoot; +import com.commercetools.api.defaultconfig.ApiRootBuilder; import com.commercetools.api.defaultconfig.ServiceRegion; -import com.commercetools.sync.commons.utils.ClientConfigurationUtils; +import com.commercetools.http.okhttp4.CtOkHttp4Client; import io.vrap.rmf.base.client.oauth2.ClientCredentials; import java.io.InputStream; +import java.util.Arrays; import java.util.InvalidPropertiesFormatException; import java.util.Properties; import javax.annotation.Nonnull; @@ -80,7 +82,7 @@ private static ProjectApiRoot getCtpClient(@Nonnull final String propertiesPrefi .withScopes(scopes) .build(); - return ClientConfigurationUtils.createClient(projectKey, credentials, authUrl, apiUrl); + return createCtpClient(authUrl, apiUrl, credentials, projectKey); } catch (Exception exception) { throw new IllegalStateException( format( @@ -91,6 +93,17 @@ private static ProjectApiRoot getCtpClient(@Nonnull final String propertiesPrefi } } + private static ProjectApiRoot createCtpClient( + @Nonnull String authUrl, + @Nonnull String apiUrl, + @Nonnull ClientCredentials credentials, + @Nonnull String projectKey) { + return ApiRootBuilder.of(new CtOkHttp4Client(200, 200)) + .defaultClient(credentials, authUrl, apiUrl) + .withRetryMiddleware(5, Arrays.asList(500, 502, 503, 504)) + .build(projectKey); + } + private static Properties loadFromEnvVars(String propertiesPrefix) { String projectKeyKey = propertiesPrefix.toUpperCase().replace(".", "_") + "PROJECT_KEY"; String projectKey = System.getenv(projectKeyKey);