]> git.mxchange.org Git - friendica.git/blob - tests/src/Core/Cache/MemcachedCacheTest.php
Add testmode
[friendica.git] / tests / src / Core / Cache / MemcachedCacheTest.php
1 <?php
2 /**
3  * @copyright Copyright (C) 2020, Friendica
4  *
5  * @license GNU AGPL version 3 or any later version
6  *
7  * This program is free software: you can redistribute it and/or modify
8  * it under the terms of the GNU Affero General Public License as
9  * published by the Free Software Foundation, either version 3 of the
10  * License, or (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU Affero General Public License for more details.
16  *
17  * You should have received a copy of the GNU Affero General Public License
18  * along with this program.  If not, see <https://www.gnu.org/licenses/>.
19  *
20  */
21
22 namespace Friendica\Test\src\Core\Cache;
23
24 use Friendica\Core\Cache\MemcachedCache;
25 use Friendica\Core\Config\IConfig;
26 use Psr\Log\NullLogger;
27
28 /**
29  * @requires extension memcached
30  * @group MEMCACHED
31  */
32 class MemcachedCacheTest extends MemoryCacheTest
33 {
34         protected function getInstance()
35         {
36                 $configMock = \Mockery::mock(IConfig::class);
37
38                 $host = $_SERVER['MEMCACHED_HOST'] ?? 'localhost';
39
40                 $configMock
41                         ->shouldReceive('get')
42                         ->with('system', 'memcached_hosts')
43                         ->andReturn([0 => $host . ', 11211']);
44
45                 $logger = new NullLogger();
46
47                 try {
48                         $this->cache = new MemcachedCache($host, $configMock, $logger);
49                 } catch (\Exception $exception) {
50                         $this->markTestSkipped('Memcached is not available');
51                 }
52                 return $this->cache;
53         }
54
55         public function tearDown()
56         {
57                 $this->cache->clear(false);
58                 parent::tearDown();
59         }
60
61         /**
62          * @small
63          *
64          * @dataProvider dataSimple
65          */
66         public function testGetAllKeys($value1, $value2, $value3)
67         {
68                 $this->markTestIncomplete('Race condition because of too fast getAllKeys() which uses a workaround');
69         }
70 }