friendica-github/tests/LockTestCase.php

209 lines
5.5 KiB
PHP
Raw Permalink Normal View History

<?php
2024-08-24 12:31:41 +00:00
// Copyright (C) 2010-2024, the Friendica project
// SPDX-FileCopyrightText: 2010-2024 the Friendica project
//
// SPDX-License-Identifier: AGPL-3.0-or-later
2024-12-15 21:15:21 +00:00
namespace Friendica\Test;
2021-10-26 19:44:29 +00:00
use Friendica\Core\Lock\Capability\ICanLock;
2024-12-11 22:45:17 +00:00
use Friendica\Test\MockedTestCase;
2024-12-15 21:15:21 +00:00
abstract class LockTestCase extends MockedTestCase
{
/**
* @var int Start time of the mock (used for time operations)
*/
protected $startTime = 1417011228;
/**
2021-10-26 19:44:29 +00:00
* @var ICanLock
*/
protected $instance;
abstract protected function getInstance();
protected function setUp(): void
{
parent::setUp();
$this->instance = $this->getInstance();
2019-08-13 19:20:41 +00:00
$this->instance->releaseAll(true);
}
protected function tearDown(): void
{
2019-08-13 19:20:41 +00:00
$this->instance->releaseAll(true);
parent::tearDown();
}
/**
* @small
*/
public function testLock()
{
self::assertFalse($this->instance->isLocked('foo'));
self::assertTrue($this->instance->acquire('foo', 1));
self::assertTrue($this->instance->isLocked('foo'));
self::assertFalse($this->instance->isLocked('bar'));
}
/**
* @small
*/
public function testDoubleLock()
{
self::assertFalse($this->instance->isLocked('foo'));
self::assertTrue($this->instance->acquire('foo', 1));
self::assertTrue($this->instance->isLocked('foo'));
// We already locked it
self::assertTrue($this->instance->acquire('foo', 1));
}
/**
* @small
*/
public function testReleaseLock()
{
self::assertFalse($this->instance->isLocked('foo'));
self::assertTrue($this->instance->acquire('foo', 1));
self::assertTrue($this->instance->isLocked('foo'));
$this->instance->release('foo');
self::assertFalse($this->instance->isLocked('foo'));
}
/**
* @small
*/
public function testReleaseAll()
{
self::assertTrue($this->instance->acquire('foo', 1));
self::assertTrue($this->instance->acquire('bar', 1));
self::assertTrue($this->instance->acquire('nice', 1));
self::assertTrue($this->instance->isLocked('foo'));
self::assertTrue($this->instance->isLocked('bar'));
self::assertTrue($this->instance->isLocked('nice'));
self::assertTrue($this->instance->releaseAll());
self::assertFalse($this->instance->isLocked('foo'));
self::assertFalse($this->instance->isLocked('bar'));
self::assertFalse($this->instance->isLocked('nice'));
}
/**
* @small
*/
public function testReleaseAfterUnlock()
{
self::assertFalse($this->instance->isLocked('foo'));
self::assertFalse($this->instance->isLocked('bar'));
self::assertFalse($this->instance->isLocked('nice'));
self::assertTrue($this->instance->acquire('foo', 1));
self::assertTrue($this->instance->acquire('bar', 1));
self::assertTrue($this->instance->acquire('nice', 1));
self::assertTrue($this->instance->release('foo'));
self::assertFalse($this->instance->isLocked('foo'));
self::assertTrue($this->instance->isLocked('bar'));
self::assertTrue($this->instance->isLocked('nice'));
self::assertTrue($this->instance->releaseAll());
self::assertFalse($this->instance->isLocked('bar'));
self::assertFalse($this->instance->isLocked('nice'));
}
2019-03-04 20:28:36 +00:00
/**
* @small
*/
public function testReleaseWitTTL()
{
self::assertFalse($this->instance->isLocked('test'));
self::assertTrue($this->instance->acquire('test', 1, 10));
self::assertTrue($this->instance->isLocked('test'));
self::assertTrue($this->instance->release('test'));
self::assertFalse($this->instance->isLocked('test'));
2019-03-04 20:28:36 +00:00
}
2019-08-13 19:20:41 +00:00
/**
* @small
*/
public function testGetLocks()
{
self::assertTrue($this->instance->acquire('foo', 1));
self::assertTrue($this->instance->acquire('bar', 1));
self::assertTrue($this->instance->acquire('nice', 1));
2019-08-13 19:20:41 +00:00
self::assertTrue($this->instance->isLocked('foo'));
self::assertTrue($this->instance->isLocked('bar'));
self::assertTrue($this->instance->isLocked('nice'));
2019-08-13 19:20:41 +00:00
$locks = $this->instance->getLocks();
self::assertContains('foo', $locks);
self::assertContains('bar', $locks);
self::assertContains('nice', $locks);
2019-08-13 19:20:41 +00:00
}
/**
* @small
*/
public function testGetLocksWithPrefix()
{
self::assertTrue($this->instance->acquire('foo', 1));
self::assertTrue($this->instance->acquire('test1', 1));
self::assertTrue($this->instance->acquire('test2', 1));
2019-08-13 19:20:41 +00:00
self::assertTrue($this->instance->isLocked('foo'));
self::assertTrue($this->instance->isLocked('test1'));
self::assertTrue($this->instance->isLocked('test2'));
2019-08-13 19:20:41 +00:00
$locks = $this->instance->getLocks('test');
self::assertContains('test1', $locks);
self::assertContains('test2', $locks);
self::assertNotContains('foo', $locks);
2019-08-13 19:20:41 +00:00
}
/**
* @medium
*/
public function testLockTTL()
{
static::markTestSkipped('taking too much time without mocking');
2018-11-09 19:39:47 +00:00
self::assertFalse($this->instance->isLocked('foo'));
self::assertFalse($this->instance->isLocked('bar'));
// TODO [nupplaphil] - Because of the Datetime-Utils for the database, we have to wait a FULL second between the checks to invalidate the db-locks/cache
self::assertTrue($this->instance->acquire('foo', 2, 1));
self::assertTrue($this->instance->acquire('bar', 2, 3));
self::assertTrue($this->instance->isLocked('foo'));
self::assertTrue($this->instance->isLocked('bar'));
sleep(2);
self::assertFalse($this->instance->isLocked('foo'));
self::assertTrue($this->instance->isLocked('bar'));
sleep(2);
self::assertFalse($this->instance->isLocked('foo'));
self::assertFalse($this->instance->isLocked('bar'));
}
/**
* Test if releasing a non-existing lock doesn't throw errors
*/
public function testReleaseLockWithoutLock()
{
self::assertFalse($this->instance->isLocked('wrongLock'));
self::assertFalse($this->instance->release('wrongLock'));
}
}