LockTest.php

Same filename in other branches
  1. 9 core/tests/Drupal/KernelTests/Core/Lock/LockTest.php
  2. 8.9.x core/tests/Drupal/KernelTests/Core/Lock/LockTest.php
  3. 10 core/tests/Drupal/KernelTests/Core/Lock/LockTest.php

Namespace

Drupal\KernelTests\Core\Lock

File

core/tests/Drupal/KernelTests/Core/Lock/LockTest.php

View source
<?php

declare (strict_types=1);
namespace Drupal\KernelTests\Core\Lock;

use Drupal\Core\Lock\DatabaseLockBackend;
use Drupal\KernelTests\KernelTestBase;

/**
 * Tests the Database lock backend.
 *
 * @group Lock
 */
class LockTest extends KernelTestBase {
    
    /**
     * Database lock backend to test.
     *
     * @var \Drupal\Core\Lock\DatabaseLockBackend
     */
    protected $lock;
    
    /**
     * {@inheritdoc}
     */
    protected function setUp() : void {
        parent::setUp();
        $this->lock = new DatabaseLockBackend($this->container
            ->get('database'));
    }
    
    /**
     * Tests backend release functionality.
     */
    public function testBackendLockRelease() : void {
        $success = $this->lock
            ->acquire('lock_a');
        $this->assertTrue($success, 'Could acquire first lock.');
        // This function is not part of the backend, but the default database
        // backend implement it, we can here use it safely.
        $is_free = $this->lock
            ->lockMayBeAvailable('lock_a');
        $this->assertFalse($is_free, 'First lock is unavailable.');
        $this->lock
            ->release('lock_a');
        $is_free = $this->lock
            ->lockMayBeAvailable('lock_a');
        $this->assertTrue($is_free, 'First lock has been released.');
        $success = $this->lock
            ->acquire('lock_b');
        $this->assertTrue($success, 'Could acquire second lock.');
        $success = $this->lock
            ->acquire('lock_b');
        $this->assertTrue($success, 'Could acquire second lock a second time within the same request.');
        $this->lock
            ->release('lock_b');
        // Test acquiring and releasing a lock with a long key (over 255 chars).
        $long_key = 'long_key:BZoMiSf9IIPULsJ98po18TxJ6T4usd3MZrLE0d3qMgG6iAgDlOi1G3oMap7zI5df84l7LtJBg4bOj6XvpO6vDRmP5h5QbA0Bj9rVFiPIPAIQZ9qFvJqTALiK1OR3GpOkWQ4vgEA4LkY0UfznrWBeuK7IWZfv1um6DLosnVXd1z1cJjvbEUqYGJj92rwHfhYihLm8IO9t3P2gAvEkH5Mhc8GBoiTsIDnP01Te1kxGFHO3RuvJIxPnHmZtSdBggmuVN7x9';
        $success = $this->lock
            ->acquire($long_key);
        $this->assertTrue($success, 'Could acquire long key lock.');
        // This function is not part of the backend, but the default database
        // backend implement it, we can here use it safely.
        $is_free = $this->lock
            ->lockMayBeAvailable($long_key);
        $this->assertFalse($is_free, 'Long key lock is unavailable.');
        $this->lock
            ->release($long_key);
        $is_free = $this->lock
            ->lockMayBeAvailable($long_key);
        $this->assertTrue($is_free, 'Long key lock has been released.');
    }
    
    /**
     * Tests backend release functionality.
     */
    public function testBackendLockReleaseAll() : void {
        $success = $this->lock
            ->acquire('lock_a');
        $this->assertTrue($success, 'Could acquire first lock.');
        $success = $this->lock
            ->acquire('lock_b');
        $this->assertTrue($success, 'Could acquire second lock.');
        $this->lock
            ->releaseAll();
        $is_free = $this->lock
            ->lockMayBeAvailable('lock_a');
        $this->assertTrue($is_free, 'First lock has been released.');
        $is_free = $this->lock
            ->lockMayBeAvailable('lock_b');
        $this->assertTrue($is_free, 'Second lock has been released.');
    }

}

Classes

Title Deprecated Summary
LockTest Tests the Database lock backend.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.