From 7587cd0a5f45b47f587d544002079ad6ab5d94b2 Mon Sep 17 00:00:00 2001 From: LevFlavien Date: Thu, 29 Sep 2022 13:39:32 +0200 Subject: [PATCH 1/3] refact(API-1835): Rename directory ProductUUID -> ProductUuid --- .../{ProductUUID => ProductUuid}/CreateProductUuidIntegration.php | 0 .../{ProductUUID => ProductUuid}/DeleteProductUuidIntegration.php | 0 .../{ProductUUID => ProductUuid}/GetProductUuidIntegration.php | 0 .../ListPerPageProductUuidIntegration.php | 0 .../UpsertListProductUuidIntegration.php | 0 .../{ProductUUID => ProductUuid}/UpsertProductUuidIntegration.php | 0 6 files changed, 0 insertions(+), 0 deletions(-) rename tests/Api/{ProductUUID => ProductUuid}/CreateProductUuidIntegration.php (100%) rename tests/Api/{ProductUUID => ProductUuid}/DeleteProductUuidIntegration.php (100%) rename tests/Api/{ProductUUID => ProductUuid}/GetProductUuidIntegration.php (100%) rename tests/Api/{ProductUUID => ProductUuid}/ListPerPageProductUuidIntegration.php (100%) rename tests/Api/{ProductUUID => ProductUuid}/UpsertListProductUuidIntegration.php (100%) rename tests/Api/{ProductUUID => ProductUuid}/UpsertProductUuidIntegration.php (100%) diff --git a/tests/Api/ProductUUID/CreateProductUuidIntegration.php b/tests/Api/ProductUuid/CreateProductUuidIntegration.php similarity index 100% rename from tests/Api/ProductUUID/CreateProductUuidIntegration.php rename to tests/Api/ProductUuid/CreateProductUuidIntegration.php diff --git a/tests/Api/ProductUUID/DeleteProductUuidIntegration.php b/tests/Api/ProductUuid/DeleteProductUuidIntegration.php similarity index 100% rename from tests/Api/ProductUUID/DeleteProductUuidIntegration.php rename to tests/Api/ProductUuid/DeleteProductUuidIntegration.php diff --git a/tests/Api/ProductUUID/GetProductUuidIntegration.php b/tests/Api/ProductUuid/GetProductUuidIntegration.php similarity index 100% rename from tests/Api/ProductUUID/GetProductUuidIntegration.php rename to tests/Api/ProductUuid/GetProductUuidIntegration.php diff --git a/tests/Api/ProductUUID/ListPerPageProductUuidIntegration.php b/tests/Api/ProductUuid/ListPerPageProductUuidIntegration.php similarity index 100% rename from tests/Api/ProductUUID/ListPerPageProductUuidIntegration.php rename to tests/Api/ProductUuid/ListPerPageProductUuidIntegration.php diff --git a/tests/Api/ProductUUID/UpsertListProductUuidIntegration.php b/tests/Api/ProductUuid/UpsertListProductUuidIntegration.php similarity index 100% rename from tests/Api/ProductUUID/UpsertListProductUuidIntegration.php rename to tests/Api/ProductUuid/UpsertListProductUuidIntegration.php diff --git a/tests/Api/ProductUUID/UpsertProductUuidIntegration.php b/tests/Api/ProductUuid/UpsertProductUuidIntegration.php similarity index 100% rename from tests/Api/ProductUUID/UpsertProductUuidIntegration.php rename to tests/Api/ProductUuid/UpsertProductUuidIntegration.php From 6596c7744f569376eaa6ce6c64f055d7943c53af Mon Sep 17 00:00:00 2001 From: LevFlavien Date: Thu, 29 Sep 2022 13:45:34 +0200 Subject: [PATCH 2/3] feat(API-1835): Add ProductDraftUuidApi --- spec/AkeneoPimClientSpec.php | 8 +++ spec/Api/ProductDraftUuidApiSpec.php | 59 ++++++++++++++++ src/AkeneoPimClient.php | 12 ++++ src/AkeneoPimClientBuilder.php | 2 + src/AkeneoPimClientInterface.php | 3 + src/Api/ProductDraftUuidApi.php | 54 +++++++++++++++ src/Api/ProductDraftUuidApiInterface.php | 19 ++++++ .../GetProductDraftUuidIntegration.php | 67 +++++++++++++++++++ 8 files changed, 224 insertions(+) create mode 100644 spec/Api/ProductDraftUuidApiSpec.php create mode 100644 src/Api/ProductDraftUuidApi.php create mode 100644 src/Api/ProductDraftUuidApiInterface.php create mode 100644 tests/Api/ProductDraftUuid/GetProductDraftUuidIntegration.php diff --git a/spec/AkeneoPimClientSpec.php b/spec/AkeneoPimClientSpec.php index 1d70aba9..49435c74 100644 --- a/spec/AkeneoPimClientSpec.php +++ b/spec/AkeneoPimClientSpec.php @@ -31,6 +31,7 @@ use Akeneo\Pim\ApiClient\Api\MediaFileApiInterface; use Akeneo\Pim\ApiClient\Api\ProductApiInterface; use Akeneo\Pim\ApiClient\Api\ProductDraftApiInterface; +use Akeneo\Pim\ApiClient\Api\ProductDraftUuidApiInterface; use Akeneo\Pim\ApiClient\Api\ProductModelApiInterface; use Akeneo\Pim\ApiClient\Api\ProductModelDraftApiInterface; use Akeneo\Pim\ApiClient\Api\ProductUuidApiInterface; @@ -81,6 +82,7 @@ function let( AssetAttributeOptionApiInterface $assetAttributeOptionApi, AssetMediaFileApiInterface $assetMediaFileApi, ProductUuidApiInterface $productUuidApi, + ProductDraftUuidApiInterface $productDraftUuidApi, AppCatalogApiInterface $appCatalogApi, AppCatalogProductApiInterface $appCatalogProductApi ) { @@ -120,6 +122,7 @@ function let( $assetAttributeOptionApi, $assetMediaFileApi, $productUuidApi, + $productDraftUuidApi, $appCatalogApi, $appCatalogProductApi ); @@ -300,6 +303,11 @@ function it_gets_product_uuid_api(ProductUuidApiInterface $productUuidApi) $this->getProductUuidApi()->shouldReturn($productUuidApi); } + function it_gets_product_draft_uuid_api(ProductDraftUuidApiInterface $productDraftUuidApi) + { + $this->getProductDraftUuidApi()->shouldReturn($productDraftUuidApi); + } + function it_gets_app_catalog_api(AppCatalogApiInterface $appCatalogApi) { $this->getAppCatalogApi()->shouldReturn($appCatalogApi); diff --git a/spec/Api/ProductDraftUuidApiSpec.php b/spec/Api/ProductDraftUuidApiSpec.php new file mode 100644 index 00000000..8272b602 --- /dev/null +++ b/spec/Api/ProductDraftUuidApiSpec.php @@ -0,0 +1,59 @@ +beConstructedWith($resourceClient, $pageFactory, $cursorFactory); + } + + function it_is_initializable() + { + $this->shouldHaveType(ProductDraftUuidApi::class); + $this->shouldImplement(ProductDraftUuidApiInterface::class); + $this->shouldImplement(GettableResourceInterface::class); + } + + function it_gets_a_product_draft($resourceClient) + { + $draft = [ + 'uuid' => '944ca210-d8e0-4c57-9529-741e17e95c8d', + 'family' => 'bar', + 'parent' => null, + 'groups' => [], + 'categories' => [], + 'enabled' => true, + 'values' => [], + 'created' => 'this is a date formatted to ISO-8601', + 'updated' => 'this is a date formatted to ISO-8601', + 'associations' => [], + 'metadata' => [ + 'workflow_status' => 'draft_in_progress', + ], + ]; + + $resourceClient->getResource(ProductDraftUuidApi::PRODUCT_DRAFT_UUID_URI, ['944ca210-d8e0-4c57-9529-741e17e95c8d'])->willReturn($draft); + + $this->get('944ca210-d8e0-4c57-9529-741e17e95c8d')->shouldReturn($draft); + } + + function it_submits_a_product_draft_for_approval($resourceClient) + { + $resourceClient->createResource(ProductDraftUuidApi::PRODUCT_PROPOSAL_UUID_URI, ['944ca210-d8e0-4c57-9529-741e17e95c8d'])->willReturn(201); + + $this->submitForApproval('944ca210-d8e0-4c57-9529-741e17e95c8d')->shouldReturn(201); + } +} diff --git a/src/AkeneoPimClient.php b/src/AkeneoPimClient.php index 6fc7bac7..4611fce4 100644 --- a/src/AkeneoPimClient.php +++ b/src/AkeneoPimClient.php @@ -29,6 +29,7 @@ use Akeneo\Pim\ApiClient\Api\MediaFileApiInterface; use Akeneo\Pim\ApiClient\Api\ProductApiInterface; use Akeneo\Pim\ApiClient\Api\ProductDraftApiInterface; +use Akeneo\Pim\ApiClient\Api\ProductDraftUuidApiInterface; use Akeneo\Pim\ApiClient\Api\ProductModelApiInterface; use Akeneo\Pim\ApiClient\Api\ProductModelDraftApiInterface; use Akeneo\Pim\ApiClient\Api\ProductUuidApiInterface; @@ -87,6 +88,7 @@ class AkeneoPimClient implements AkeneoPimClientInterface private AppCatalogProductApiInterface $appCatalogProductApi; private ProductUuidApiInterface $productUuidApi; + private ProductDraftUuidApiInterface $productDraftUuidApi; public function __construct( Authentication $authentication, @@ -124,6 +126,7 @@ public function __construct( AssetAttributeOptionApiInterface $assetAttributeOptionApi, AssetMediaFileApiInterface $assetMediaFileApi, ProductUuidApiInterface $productUuidApi, + ProductDraftUuidApiInterface $productDraftUuidApi, AppCatalogApiInterface $appCatalogApi, AppCatalogProductApiInterface $appCatalogProductApi ) { @@ -162,6 +165,7 @@ public function __construct( $this->assetAttributeOptionApi = $assetAttributeOptionApi; $this->assetMediaFileApi = $assetMediaFileApi; $this->productUuidApi = $productUuidApi; + $this->productDraftUuidApi = $productDraftUuidApi; $this->appCatalogApi = $appCatalogApi; $this->appCatalogProductApi = $appCatalogProductApi; } @@ -454,6 +458,14 @@ public function getProductUuidApi(): ProductUuidApiInterface return $this->productUuidApi; } + /** + * {@inheritDoc} + */ + public function getProductDraftUuidApi(): ProductDraftUuidApiInterface + { + return $this->productDraftUuidApi; + } + /** * {@inheritDoc} */ diff --git a/src/AkeneoPimClientBuilder.php b/src/AkeneoPimClientBuilder.php index 0e38d3a6..be777a0f 100644 --- a/src/AkeneoPimClientBuilder.php +++ b/src/AkeneoPimClientBuilder.php @@ -29,6 +29,7 @@ use Akeneo\Pim\ApiClient\Api\MeasurementFamilyApi; use Akeneo\Pim\ApiClient\Api\ProductApi; use Akeneo\Pim\ApiClient\Api\ProductDraftApi; +use Akeneo\Pim\ApiClient\Api\ProductDraftUuidApi; use Akeneo\Pim\ApiClient\Api\ProductMediaFileApi; use Akeneo\Pim\ApiClient\Api\ProductModelApi; use Akeneo\Pim\ApiClient\Api\ProductModelDraftApi; @@ -251,6 +252,7 @@ protected function buildAuthenticatedClient(Authentication $authentication): Ake new AssetAttributeOptionApi($resourceClient), new AssetMediaFileApi($resourceClient, $fileSystem), new ProductUuidApi($resourceClient, $pageFactory, $cursorFactory), + new ProductDraftUuidApi($resourceClient, $pageFactory, $cursorFactory), new AppCatalogApi($resourceClient, $pageFactory, $cursorFactory), new AppCatalogProductApi($resourceClient, $pageFactory, $cursorFactory) ); diff --git a/src/AkeneoPimClientInterface.php b/src/AkeneoPimClientInterface.php index c28c9e55..df81a3f9 100644 --- a/src/AkeneoPimClientInterface.php +++ b/src/AkeneoPimClientInterface.php @@ -29,6 +29,7 @@ use Akeneo\Pim\ApiClient\Api\MediaFileApiInterface; use Akeneo\Pim\ApiClient\Api\ProductApiInterface; use Akeneo\Pim\ApiClient\Api\ProductDraftApiInterface; +use Akeneo\Pim\ApiClient\Api\ProductDraftUuidApiInterface; use Akeneo\Pim\ApiClient\Api\ProductModelApiInterface; use Akeneo\Pim\ApiClient\Api\ProductModelDraftApiInterface; use Akeneo\Pim\ApiClient\Api\ProductUuidApiInterface; @@ -120,6 +121,8 @@ public function getAssetMediaFileApi(): AssetMediaFileApiInterface; public function getProductUuidApi() : ProductUuidApiInterface; + public function getProductDraftUuidApi() : ProductDraftUuidApiInterface; + public function getAppCatalogApi(): AppCatalogApiInterface; public function getAppCatalogProductApi(): AppCatalogProductApiInterface; diff --git a/src/Api/ProductDraftUuidApi.php b/src/Api/ProductDraftUuidApi.php new file mode 100644 index 00000000..c5c7a3c9 --- /dev/null +++ b/src/Api/ProductDraftUuidApi.php @@ -0,0 +1,54 @@ +resourceClient = $resourceClient; + $this->pageFactory = $pageFactory; + $this->cursorFactory = $cursorFactory; + } + + /** + * {@inheritdoc} + */ + public function get(string $uuid): array + { + return $this->resourceClient->getResource(static::PRODUCT_DRAFT_UUID_URI, [$uuid]); + } + + /** + * {@inheritdoc} + */ + public function submitForApproval(string $uuid): int + { + return $this->resourceClient->createResource(static::PRODUCT_PROPOSAL_UUID_URI, [$uuid]); + } +} diff --git a/src/Api/ProductDraftUuidApiInterface.php b/src/Api/ProductDraftUuidApiInterface.php new file mode 100644 index 00000000..7f513dde --- /dev/null +++ b/src/Api/ProductDraftUuidApiInterface.php @@ -0,0 +1,19 @@ +server->setResponseOfPath( + '/'.sprintf(ProductDraftUuidApi::PRODUCT_DRAFT_UUID_URI, '12951d98-210e-4bRC-ab18-7fdgf1bd14f3'), + new ResponseStack( + new Response($this->getProductDraft(), [], HttpClient::HTTP_OK) + ) + ); + + $api = $this->createClientByPassword()->getProductDraftUuidApi(); + $product = $api->get('12951d98-210e-4bRC-ab18-7fdgf1bd14f3'); + + Assert::assertSame('GET', $this->server->getLastRequest()->jsonSerialize()[RequestInfo::JSON_KEY_METHOD]); + Assert::assertEquals($product, json_decode($this->getProductDraft(), true)); + } + + public function test_get_unknown_product() + { + $this->server->setResponseOfPath( + '/'.sprintf(ProductDraftUuidApi::PRODUCT_DRAFT_UUID_URI, '12951d98-210e-4bRC-ab18-7fdgf1bd14f3'), + new ResponseStack( + new Response('{"code": 404, "message":"Resource `12951d98-210e-4bRC-ab18-7fdgf1bd14f3` does not exist."}', [], 404) + ) + ); + + $this->expectException(\Akeneo\Pim\ApiClient\Exception\NotFoundHttpException::class); + $this->expectExceptionMessage('Resource `12951d98-210e-4bRC-ab18-7fdgf1bd14f3` does not exist.'); + + $api = $this->createClientByPassword()->getProductDraftUuidApi(); + $api->get('12951d98-210e-4bRC-ab18-7fdgf1bd14f3'); + } + + private function getProductDraft(): string + { + return << Date: Thu, 29 Sep 2022 14:19:17 +0200 Subject: [PATCH 3/3] refact(API-1835): Clean some PHP doc --- src/Api/ProductDraftUuidApi.php | 15 +++++---------- 1 file changed, 5 insertions(+), 10 deletions(-) diff --git a/src/Api/ProductDraftUuidApi.php b/src/Api/ProductDraftUuidApi.php index c5c7a3c9..75c1c9d8 100644 --- a/src/Api/ProductDraftUuidApi.php +++ b/src/Api/ProductDraftUuidApi.php @@ -14,17 +14,12 @@ */ class ProductDraftUuidApi implements ProductDraftUuidApiInterface { - const PRODUCT_DRAFT_UUID_URI = '/api/rest/v1/products-uuid/%s/draft'; - const PRODUCT_PROPOSAL_UUID_URI = '/api/rest/v1/products-uuid/%s/proposal'; + public const PRODUCT_DRAFT_UUID_URI = '/api/rest/v1/products-uuid/%s/draft'; + public const PRODUCT_PROPOSAL_UUID_URI = '/api/rest/v1/products-uuid/%s/proposal'; - /** @var ResourceClientInterface */ - protected $resourceClient; - - /** @var PageFactoryInterface */ - protected $pageFactory; - - /** @var ResourceCursorFactoryInterface */ - protected $cursorFactory; + protected ResourceClientInterface $resourceClient; + protected PageFactoryInterface $pageFactory; + protected ResourceCursorFactoryInterface $cursorFactory; public function __construct( ResourceClientInterface $resourceClient,