]> git.mxchange.org Git - friendica.git/blobdiff - tests/src/Core/Lock/LockTest.php
Replace global $a with BaseObject::getApp()
[friendica.git] / tests / src / Core / Lock / LockTest.php
index ec7b97a9c78d102052016cae292548e62bc942d4..79ee023bd8b98b88e5208828c6d7d7d53f2bd0f5 100644 (file)
@@ -2,11 +2,10 @@
 
 namespace Friendica\Test\src\Core\Lock;
 
-use Friendica\App;
 use Friendica\Core\Config;
-use PHPUnit\Framework\TestCase;
+use Friendica\Test\DatabaseTest;
 
-abstract class LockTest extends TestCase
+abstract class LockTest extends DatabaseTest
 {
        /**
         * @var \Friendica\Core\Lock\ILockDriver
@@ -17,13 +16,11 @@ abstract class LockTest extends TestCase
 
        protected function setUp()
        {
-               global $a;
                parent::setUp();
                $this->instance = $this->getInstance();
 
                // Reusable App object
-               $this->app = new App(__DIR__.'/../');
-               $a = $this->app;
+               $this->app = \Friendica\BaseObject::getApp();
 
                // Default config
                Config::set('config', 'hostname', 'localhost');
@@ -56,25 +53,53 @@ abstract class LockTest extends TestCase
        public function testReleaseAll() {
                $this->instance->acquireLock('foo', 1);
                $this->instance->acquireLock('bar', 1);
-               $this->instance->acquireLock('#/$%§', 1);
+               $this->instance->acquireLock('nice', 1);
+
+               $this->assertTrue($this->instance->isLocked('foo'));
+               $this->assertTrue($this->instance->isLocked('bar'));
+               $this->assertTrue($this->instance->isLocked('nice'));
 
                $this->instance->releaseAll();
 
                $this->assertFalse($this->instance->isLocked('foo'));
                $this->assertFalse($this->instance->isLocked('bar'));
-               $this->assertFalse($this->instance->isLocked('#/$%§'));
+               $this->assertFalse($this->instance->isLocked('nice'));
        }
 
        public function testReleaseAfterUnlock() {
                $this->instance->acquireLock('foo', 1);
                $this->instance->acquireLock('bar', 1);
-               $this->instance->acquireLock('#/$%§', 1);
+               $this->instance->acquireLock('nice', 1);
 
                $this->instance->releaseLock('foo');
 
+               $this->assertFalse($this->instance->isLocked('foo'));
+               $this->assertTrue($this->instance->isLocked('bar'));
+               $this->assertTrue($this->instance->isLocked('nice'));
+
                $this->instance->releaseAll();
 
                $this->assertFalse($this->instance->isLocked('bar'));
-               $this->assertFalse($this->instance->isLocked('#/$%§'));
+               $this->assertFalse($this->instance->isLocked('nice'));
+       }
+
+       function testLockTTL() {
+
+               // 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
+               $this->instance->acquireLock('foo', 1, 1);
+               $this->instance->acquireLock('bar', 1, 3);
+
+               $this->assertTrue($this->instance->isLocked('foo'));
+               $this->assertTrue($this->instance->isLocked('bar'));
+
+               sleep(2);
+
+               $this->assertFalse($this->instance->isLocked('foo'));
+               $this->assertTrue($this->instance->isLocked('bar'));
+
+               sleep(2);
+
+               $this->assertFalse($this->instance->isLocked('foo'));
+               $this->assertFalse($this->instance->isLocked('bar'));
        }
-}
\ No newline at end of file
+}