markTestSkipped( 'The Redis extension is not available.' ); } $this->cache = new RedisCache($GLOBALS['CONFIG']['cache']['redis']); } protected function tearDown(): void { $this->cache->flushAll(); } /** * @testdox The redis cache connection has the expected default values after initialization * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testDefault() : void { self::assertEquals('', $this->cache->getPrefix()); self::assertEquals(CacheType::REDIS, $this->cache->getType()); self::assertTrue($this->cache->flushAll()); self::assertEquals(0, $this->cache->getThreshold()); self::assertNull($this->cache->get('test')); self::assertEquals( [ 'status' => CacheStatus::OK, 'count' => 0, 'size' => 0, ], $this->cache->stats() ); } /** * @testdox The connection to a cache can be established (none-exising directories get created) * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testConnect() : void { $cache = new RedisCache($GLOBALS['CONFIG']['cache']['redis']); self::assertEquals(CacheStatus::OK, $cache->getStatus()); self::assertEquals($GLOBALS['CONFIG']['cache']['redis']['db'], $cache->getCache()); self::assertEquals($GLOBALS['CONFIG']['cache']['redis']['host'], $cache->getHost()); self::assertEquals((int) $GLOBALS['CONFIG']['cache']['redis']['port'], $cache->getPort()); } /** * @testdox Different cache data (types) can be set and returned * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testSetInputOutput() : void { $this->cache->set('key1', 'testVal'); self::assertEquals('testVal', $this->cache->get('key1')); $this->cache->set('key2', false); self::assertFalse($this->cache->get('key2')); $this->cache->set('key3', null); self::assertNull($this->cache->get('key3')); $this->cache->set('key4', 4); self::assertEquals(4, $this->cache->get('key4')); $this->cache->set('key5', 5.12); self::assertEquals(5.12, $this->cache->get('key5')); $this->cache->set('key6', ['asdf', 1, true, 2.3]); self::assertEquals(['asdf', 1, true, 2.3], $this->cache->get('key6')); $this->cache->set('key7', new FileCacheSerializable()); self::assertEquals('abc', $this->cache->get('key7')->val); $this->cache->set('key8', new FileCacheJsonSerializable()); self::assertEquals('asdf', $this->cache->get('key8')->val); // todo: different from file cache fix! } /** * @testdox Cache data can bet added and returned * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testAddInputOutput() : void { self::assertTrue($this->cache->add('addKey', 'testValAdd')); self::assertEquals('testValAdd', $this->cache->get('addKey')); } /** * @testdox Cache data cannot be added if it already exists * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testInvalidOverwrite() : void { self::assertTrue($this->cache->add('addKey', 'testValAdd')); self::assertFalse($this->cache->add('addKey', 'testValAdd2')); self::assertEquals('testValAdd', $this->cache->get('addKey')); } /** * @testdox Existing cache data can be replaced * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testReplace() : void { $this->cache->set('key4', 4); self::assertEquals(4, $this->cache->get('key4')); self::assertTrue($this->cache->replace('key4', 5)); self::assertEquals(5, $this->cache->get('key4')); } /** * @testdox None-existing cache data cannot be replaced * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testInvalidReplace() : void { self::assertFalse($this->cache->replace('keyInvalid', 5)); } /** * @testdox Existing cache data can be deleted * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testDelete() : void { $this->cache->set('key4', 4); self::assertEquals(4, $this->cache->get('key4')); self::assertTrue($this->cache->delete('key4')); self::assertNull($this->cache->get('key4')); } /** * @testdox The cache correctly handles general cache information * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testStats() : void { $this->cache->set('key1', 'testVal'); self::assertEquals('testVal', $this->cache->get('key1')); $this->cache->set('key2', false); self::assertFalse($this->cache->get('key2')); self::assertEquals( [ 'status' => CacheStatus::OK, 'count' => 2, 'size' => 17, ], $this->cache->stats() ); } /** * @testdox The cache can be flushed * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testFlush() : void { $this->cache->set('key1', 'testVal'); self::assertEquals('testVal', $this->cache->get('key1')); $this->cache->set('key2', false); self::assertFalse($this->cache->get('key2')); self::assertTrue($this->cache->flushAll()); self::assertNull($this->cache->get('key5')); self::assertEquals( [ 'status' => CacheStatus::OK, 'count' => 0, 'size' => 0, ], $this->cache->stats() ); } /** * @testdox Cache data can be set and returned with expiration limits * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testUnexpiredInputOutput() : void { $this->cache->set('key1', 'testVal', 1); self::assertEquals('testVal', $this->cache->get('key1')); } /** * @testdox Expired cache data cannot be returned * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testExpiredInputOutput() : void { $this->cache->set('key2', 'testVal2', 1); self::assertEquals('testVal2', $this->cache->get('key2', 1)); \sleep(2); self::assertNull($this->cache->get('key2', 1)); self::assertNull($this->cache->get('key2')); // this causes a side effect of deleting the outdated cache element!!! } /** * @testdox Expired cache data can be forced to return * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testForceExpiredInputOutput() : void { $this->cache->set('key2', 'testVal2', 1); \sleep(2); self::assertEquals('testVal2', $this->cache->get('key2', 10)); } /** * @testdox Unexpired cache data connot be delete if lower expiration is defined * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testInvalidDeleteUnexpired() : void { $this->cache->set('key4', 'testVal4', 60); self::assertFalse($this->cache->delete('key4', 0)); } /** * @testdox Expired cache data can be deleted if equal expiration is defined * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testDeleteExpired() : void { $this->cache->set('key4', 'testVal4', 1); \sleep(2); self::assertTrue($this->cache->delete('key4', 1)); } /** * @testdox Unexpired data can be force deleted with lower expiration date * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testForceDeleteUnexpired() : void { $this->cache->set('key5', 'testVal5', 10000); \sleep(2); self::assertFalse($this->cache->delete('key5', 1000000)); self::assertTrue($this->cache->delete('key5', 1)); } /** * @testdox Cach data can be flushed by expiration date * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testFlushExpired() : void { $this->cache->set('key6', 'testVal6', 1); \sleep(2); $this->cache->flush(0); self::assertNull($this->cache->get('key6', 0)); } /** * @testdox A bad cache status will prevent all cache actions * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testBadCacheStatus() : void { TestUtils::setMember($this->cache, 'status', CacheStatus::FAILURE); $this->cache->set('key1', 'testVal'); self::assertFalse($this->cache->add('key2', 'testVal2')); self::assertNull($this->cache->get('key1')); self::assertFalse($this->cache->replace('key1', 5)); self::assertFalse($this->cache->delete('key1')); self::assertFalse($this->cache->flushAll()); self::assertFalse($this->cache->flush()); self::assertEquals([], $this->cache->stats()); } /** * @testdox A invalid host throws a InvalidConnectionConfigException * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testInvalidCacheHost() : void { self::expectException(\phpOMS\DataStorage\Cache\Exception\InvalidConnectionConfigException::class); $db = $GLOBALS['CONFIG']['cache']['redis']; unset($db['host']); $cache = new RedisCache($db); } /** * @testdox A invalid port throws a InvalidConnectionConfigException * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testInvalidCachePort() : void { self::expectException(\phpOMS\DataStorage\Cache\Exception\InvalidConnectionConfigException::class); $db = $GLOBALS['CONFIG']['cache']['redis']; unset($db['port']); $cache = new RedisCache($db); } /** * @testdox A invalid database throws a InvalidConnectionConfigException * @covers phpOMS\DataStorage\Cache\Connection\RedisCache * @group framework */ public function testInvalidCacheDatabase() : void { self::expectException(\phpOMS\DataStorage\Cache\Exception\InvalidConnectionConfigException::class); $db = $GLOBALS['CONFIG']['cache']['redis']; unset($db['db']); $cache = new RedisCache($db); } }