123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- declare(strict_types=1);
- namespace Magento\InventoryIndexer\Test\Integration\Indexer;
- use Magento\InventoryIndexer\Indexer\Source\SourceIndexer;
- use Magento\InventoryIndexer\Model\ResourceModel\GetStockItemData;
- use Magento\InventorySalesApi\Model\GetStockItemDataInterface;
- use Magento\TestFramework\Helper\Bootstrap;
- use PHPUnit\Framework\TestCase;
- class SourceIndexerTest extends TestCase
- {
- /**
- * @var SourceIndexer
- */
- private $sourceIndexer;
- /**
- * @var GetStockItemData
- */
- private $getStockItemData;
- /**
- * @var RemoveIndexData
- */
- private $removeIndexData;
- protected function setUp()
- {
- $this->sourceIndexer = Bootstrap::getObjectManager()->get(SourceIndexer::class);
- $this->getStockItemData = Bootstrap::getObjectManager()->get(GetStockItemData::class);
- $this->removeIndexData = Bootstrap::getObjectManager()->get(RemoveIndexData::class);
- $this->removeIndexData->execute([10, 20, 30]);
- }
- /**
- * We broke transaction during indexation so we need to clean db state manually
- */
- protected function tearDown()
- {
- $this->removeIndexData->execute([10, 20, 30]);
- }
- /**
- * Source 'eu-1' is assigned on EU-stock(id:10) and Global-stock(id:30)
- * Thus these stocks stocks be reindexed
- *
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/products.php
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/sources.php
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/stocks.php
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/source_items.php
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/stock_source_links.php
- *
- * @param string $sku
- * @param int $stockId
- * @param array|null $expectedData
- *
- * @dataProvider reindexRowDataProvider
- *
- * @magentoDbIsolation disabled
- */
- public function testReindexRow(string $sku, int $stockId, $expectedData)
- {
- $this->sourceIndexer->executeRow('eu-1');
- $stockItemData = $this->getStockItemData->execute($sku, $stockId);
- self::assertEquals($expectedData, $stockItemData);
- }
- /**
- * @return array
- */
- public function reindexRowDataProvider(): array
- {
- return [
- ['SKU-1', 10, [GetStockItemDataInterface::QUANTITY => 8.5, GetStockItemDataInterface::IS_SALABLE => 1]],
- ['SKU-1', 30, [GetStockItemDataInterface::QUANTITY => 8.5, GetStockItemDataInterface::IS_SALABLE => 1]],
- ['SKU-2', 10, null],
- ['SKU-2', 30, [GetStockItemDataInterface::QUANTITY => 5, GetStockItemDataInterface::IS_SALABLE => 1]],
- ['SKU-3', 10, [GetStockItemDataInterface::QUANTITY => 0, GetStockItemDataInterface::IS_SALABLE => 0]],
- ['SKU-3', 30, [GetStockItemDataInterface::QUANTITY => 0, GetStockItemDataInterface::IS_SALABLE => 0]],
- ];
- }
- /**
- * Source 'eu-1' and 'us-1' are assigned on EU-stock(id:10), US-stock(id:20) and Global-stock(id:30)
- * Thus these stocks should be reindexed
- *
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/products.php
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/sources.php
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/stocks.php
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/source_items.php
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/stock_source_links.php
- *
- * @param string $sku
- * @param int $stockId
- * @param array|null $expectedData
- *
- * @dataProvider reindexListDataProvider
- *
- * @magentoDbIsolation disabled
- */
- public function testReindexList(string $sku, int $stockId, $expectedData)
- {
- $this->sourceIndexer->executeList(['eu-1', 'us-1']);
- $stockItemData = $this->getStockItemData->execute($sku, $stockId);
- self::assertEquals($expectedData, $stockItemData);
- }
- /**
- * All of stocks should be reindexed
- *
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/products.php
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/sources.php
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/stocks.php
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/source_items.php
- * @magentoDataFixture ../../../../app/code/Magento/InventoryApi/Test/_files/stock_source_links.php
- *
- * @param string $sku
- * @param int $stockId
- * @param array|null $expectedData
- *
- * @dataProvider reindexListDataProvider
- *
- * @magentoDbIsolation disabled
- */
- public function testReindexAll(string $sku, int $stockId, $expectedData)
- {
- $this->sourceIndexer->executeFull();
- $stockItemData = $this->getStockItemData->execute($sku, $stockId);
- self::assertEquals($expectedData, $stockItemData);
- }
- /**
- * @return array
- */
- public function reindexListDataProvider(): array
- {
- return [
- ['SKU-1', 10, [GetStockItemDataInterface::QUANTITY => 8.5, GetStockItemDataInterface::IS_SALABLE => 1]],
- ['SKU-1', 20, null],
- ['SKU-1', 30, [GetStockItemDataInterface::QUANTITY => 8.5, GetStockItemDataInterface::IS_SALABLE => 1]],
- ['SKU-2', 10, null],
- ['SKU-2', 20, [GetStockItemDataInterface::QUANTITY => 5, GetStockItemDataInterface::IS_SALABLE => 1]],
- ['SKU-2', 30, [GetStockItemDataInterface::QUANTITY => 5, GetStockItemDataInterface::IS_SALABLE => 1]],
- ['SKU-3', 10, [GetStockItemDataInterface::QUANTITY => 0, GetStockItemDataInterface::IS_SALABLE => 0]],
- ['SKU-3', 20, null],
- ['SKU-3', 30, [GetStockItemDataInterface::QUANTITY => 0, GetStockItemDataInterface::IS_SALABLE => 0]],
- ];
- }
- }
|