commerce-8.x-2.8/modules/order/tests/src/Kernel/OrderAccessControlHandlerTest.php
modules/order/tests/src/Kernel/OrderAccessControlHandlerTest.php
<?php
namespace Drupal\Tests\commerce_order\Kernel;
use Drupal\commerce_order\Entity\Order;
use Drupal\commerce_order\Entity\OrderItem;
use Drupal\commerce_order\Entity\OrderItemType;
use Drupal\commerce_price\Price;
use Drupal\Tests\commerce\Kernel\CommerceKernelTestBase;
/**
* Tests the order access control handler.
*
* @group commerce
*/
class OrderAccessControlHandlerTest extends CommerceKernelTestBase {
/**
* Modules to enable.
*
* @var array
*/
public static $modules = [
'entity_reference_revisions',
'path',
'profile',
'state_machine',
'commerce_product',
'commerce_order',
'commerce_test',
];
/**
* {@inheritdoc}
*/
protected function setUp() {
parent::setUp();
$this->installEntitySchema('profile');
$this->installEntitySchema('commerce_order');
$this->installEntitySchema('commerce_order_item');
$this->installEntitySchema('commerce_product');
$this->installEntitySchema('commerce_product_variation');
$this->installConfig(['commerce_product', 'commerce_order']);
OrderItemType::create([
'id' => 'test',
'label' => 'Test',
'orderType' => 'default',
])->save();
}
/**
* Tests the access checking.
*/
public function testOrderAccess() {
$user = $this->createUser(['mail' => $this->randomString() . '@example.com'], ['view own commerce_order']);
$different_user = $this->createUser(['mail' => $this->randomString() . '@example.com'], ['view own commerce_order']);
$admin_user = $this->createUser(['mail' => $this->randomString() . '@example.com'], ['administer commerce_order']);
$order_item = OrderItem::create([
'type' => 'test',
'quantity' => 1,
'unit_price' => new Price('12.00', 'USD'),
]);
$order_item->save();
$order = Order::create([
'type' => 'default',
'store_id' => $this->store->id(),
'state' => 'draft',
'mail' => 'text@example.com',
'uid' => $user->id(),
'ip_address' => '127.0.0.1',
'order_items' => [$order_item],
]);
$order->save();
// Tests the 'view own commerce_order' access checking.
$this->assertTrue($order->access('view', $user));
$this->assertFalse($order->access('view', $different_user));
// Tests the access checking for locked orders.
$this->assertTrue($order->access('update', $admin_user));
$this->assertTrue($order->access('delete', $admin_user));
$this->assertFalse($order->access('unlock', $admin_user));
$order->lock();
\Drupal::entityTypeManager()->getAccessControlHandler('commerce_order')->resetCache();
$this->assertFalse($order->access('update', $admin_user));
$this->assertFalse($order->access('delete', $admin_user));
$this->assertTrue($order->access('unlock', $admin_user));
}
}
