Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
declare(strict_types=1);

namespace Magento\InventoryReservationCli\Test\Integration\Model;

use Magento\InventoryReservationCli\Model\GetSalableQuantityInconsistencies;
use Magento\TestFramework\Helper\Bootstrap;
use PHPUnit\Framework\TestCase;

/**
* Test to check ability to work correctly with entity id and increment id for inconsistencies
*/
class GetSalableQuantityInconsistenciesWithDifferentOrderIdentitiesTest extends TestCase
{
/**
* @var GetSalableQuantityInconsistencies
*/
private $getSalableQuantityInconsistencies;

/**
* Initialize test dependencies
*/
protected function setUp(): void
{
$this->getSalableQuantityInconsistencies
= Bootstrap::getObjectManager()->get(GetSalableQuantityInconsistencies::class);
}

/**
* Verify Reservation with only objectId in the metadata
*
* @magentoDataFixture Magento/Sales/_files/order.php
* @magentoDataFixture Magento_InventoryReservationCli::Test/Integration/_files/delete_reservations.php
* @magentoDataFixture Magento_InventoryReservationCli::Test/Integration/_files/reservation_with_order_id_only.php
* @magentoAppIsolation enabled
* @magentoDbIsolation disabled
* @throws \Magento\Framework\Validation\ValidationException
*/
public function testReservationWithObjectId(): void
{
$inconsistencies = $this->getSalableQuantityInconsistencies->execute();
self::assertSame([], $inconsistencies);
}

/**
* Verify Reservation with only objectIncrementId in the metadata
*
* @magentoDataFixture Magento/Sales/_files/order.php
* @magentoDataFixture Magento_InventoryReservationCli::Test/Integration/_files/delete_reservations.php
* @magentoDataFixture Magento_InventoryReservationCli::Test/Integration/_files/reservation_with_order_increment_id_only.php
* @magentoAppIsolation enabled
* @magentoDbIsolation disabled
* @throws \Magento\Framework\Validation\ValidationException
*/
public function testReservationWithObjectIncrementId(): void
{
$inconsistencies = $this->getSalableQuantityInconsistencies->execute();
self::assertSame([], $inconsistencies);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
declare(strict_types=1);

use Magento\TestFramework\Helper\Bootstrap;
use Magento\Sales\Model\Order;
use Magento\InventorySalesApi\Api\Data\SalesEventInterface;

/** @var \Magento\Framework\ObjectManagerInterface $objectManager */
$objectManager = Bootstrap::getObjectManager();

/** @var Magento\Framework\App\ResourceConnection $resourceConnection */
$resourceConnection = $objectManager->create(Magento\Framework\App\ResourceConnection::class);

/** @var \Magento\Sales\Model\Order $order */
$order = $objectManager->create(Order::class)->loadByIncrementId('100000001');

$connection = $resourceConnection->getConnection();
$tableName = $resourceConnection->getTableName('inventory_reservation');

$payload = [
'stock_id' => 1,
'sku' => 'simple',
'quantity' => -2,
'metadata' => '{"event_type":"' . SalesEventInterface::EVENT_ORDER_PLACED
. '","object_type":"order","object_id":"' . (string)$order->getEntityId() . '","objectIncrementId":""}'
];

$qry = $connection->insert($tableName, $payload);
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
declare(strict_types=1);

use Magento\TestFramework\Helper\Bootstrap;
use Magento\Sales\Model\Order;

/** @var \Magento\Framework\ObjectManagerInterface $objectManager */
$objectManager = Bootstrap::getObjectManager();

/** @var Magento\Framework\App\ResourceConnection $resourceConnection */
$resourceConnection = $objectManager->create(Magento\Framework\App\ResourceConnection::class);

$connection = $resourceConnection->getConnection();
$tableName = $resourceConnection->getTableName('inventory_reservation');

$payload = [
'stock_id' => 1,
'sku' => 'simple'
];

$qry = $connection->delete($tableName, $payload);
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
declare(strict_types=1);

use Magento\TestFramework\Helper\Bootstrap;
use Magento\InventorySalesApi\Api\Data\SalesEventInterface;

/** @var \Magento\Framework\ObjectManagerInterface $objectManager */
$objectManager = Bootstrap::getObjectManager();

/** @var Magento\Framework\App\ResourceConnection $resourceConnection */
$resourceConnection = $objectManager->create(Magento\Framework\App\ResourceConnection::class);

$connection = $resourceConnection->getConnection();
$tableName = $resourceConnection->getTableName('inventory_reservation');

$payload = [
'stock_id' => 1,
'sku' => 'simple',
'quantity' => -2,
'metadata' => '{"event_type":"' . SalesEventInterface::EVENT_ORDER_PLACED
. '","object_type":"order","object_id":"","objectIncrementId":"100000001"}'
];

$qry = $connection->insert($tableName, $payload);
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
declare(strict_types=1);

use Magento\TestFramework\Helper\Bootstrap;
use Magento\Sales\Model\Order;

/** @var \Magento\Framework\ObjectManagerInterface $objectManager */
$objectManager = Bootstrap::getObjectManager();

/** @var Magento\Framework\App\ResourceConnection $resourceConnection */
$resourceConnection = $objectManager->create(Magento\Framework\App\ResourceConnection::class);

$connection = $resourceConnection->getConnection();
$tableName = $resourceConnection->getTableName('inventory_reservation');

$payload = [
'stock_id' => 1,
'sku' => 'simple'
];

$qry = $connection->delete($tableName, $payload);