]> git.mxchange.org Git - friendica.git/blobdiff - tests/src/Core/Lock/MemcachedCacheLockTest.php
Merge pull request #8075 from annando/html-escaping
[friendica.git] / tests / src / Core / Lock / MemcachedCacheLockTest.php
index 8b59f91bb79a14b09f2670cc4fb3b4d71ddd47c7..41b16abc7fbcaa76e371771f6e683b9cef64802c 100644 (file)
@@ -4,26 +4,48 @@
 namespace Friendica\Test\src\Core\Lock;
 
 use Friendica\Core\Cache\MemcachedCache;
-use Friendica\Core\Config\Configuration;
+use Friendica\Core\Config\IConfiguration;
 use Friendica\Core\Lock\CacheLock;
 use Psr\Log\NullLogger;
 
 /**
  * @requires extension memcached
+ * @group MEMCACHED
  */
 class MemcachedCacheLockTest extends LockTest
 {
        protected function getInstance()
        {
-               $configMock = \Mockery::mock(Configuration::class);
+               $configMock = \Mockery::mock(IConfiguration::class);
+
+               $host = $_SERVER['MEMCACHED_HOST'] ?? 'localhost';
 
                $configMock
                        ->shouldReceive('get')
                        ->with('system', 'memcached_hosts')
-                       ->andReturn([0 => 'localhost, 11211']);
+                       ->andReturn([0 => $host . ', 11211']);
 
                $logger = new NullLogger();
 
-               return new CacheLock(new MemcachedCache('localhost', $configMock, $logger));
+               $lock = null;
+
+               try {
+                       $cache = new MemcachedCache($host, $configMock, $logger);
+                       $lock = new CacheLock($cache);
+               } catch (\Exception $e) {
+                       $this->markTestSkipped('Memcached is not available');
+               }
+
+               return $lock;
+       }
+
+       public function testGetLocks()
+       {
+               $this->markTestIncomplete('Race condition because of too fast getLocks() which uses a workaround');
+       }
+
+       public function testGetLocksWithPrefix()
+       {
+               $this->markTestIncomplete('Race condition because of too fast getLocks() which uses a workaround');
        }
 }