mirror of
https://github.com/phpbb/phpbb.git
synced 2025-02-25 12:33:29 +01:00
92 lines
2.3 KiB
PHP
92 lines
2.3 KiB
PHP
<?php
|
|
/**
|
|
*
|
|
* @package testing
|
|
* @copyright (c) 2012 phpBB Group
|
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
|
*
|
|
*/
|
|
|
|
require_once dirname(__FILE__) . '/common_test_case.php';
|
|
|
|
class phpbb_cache_redis_driver_test extends phpbb_cache_common_test_case
|
|
{
|
|
protected static $config;
|
|
protected $driver;
|
|
|
|
public function getDataSet()
|
|
{
|
|
return $this->createXMLDataSet(dirname(__FILE__) . '/fixtures/config.xml');
|
|
}
|
|
|
|
static public function setUpBeforeClass()
|
|
{
|
|
if (!extension_loaded('redis'))
|
|
{
|
|
self::markTestSkipped('redis extension is not loaded');
|
|
}
|
|
|
|
$config = phpbb_test_case_helpers::get_test_config();
|
|
if (isset($config['redis_host']) || isset($config['redis_port']))
|
|
{
|
|
$host = isset($config['redis_host']) ? $config['redis_host'] : 'localhost';
|
|
$port = isset($config['redis_port']) ? $config['redis_port'] : 6379;
|
|
self::$config = array('host' => $host, 'port' => $port);
|
|
}
|
|
else
|
|
{
|
|
self::markTestSkipped('Test redis host/port is not specified');
|
|
}
|
|
}
|
|
|
|
protected function setUp()
|
|
{
|
|
parent::setUp();
|
|
|
|
$this->driver = new phpbb_cache_driver_redis(self::$config['host'], self::$config['port']);
|
|
$this->driver->purge();
|
|
}
|
|
|
|
public function test_cache_sql()
|
|
{
|
|
global $db, $cache;
|
|
$db = $this->new_dbal();
|
|
$cache = new phpbb_cache_service($this->driver);
|
|
|
|
$redis = new Redis();
|
|
$ok = $redis->connect(self::$config['host'], self::$config['port']);
|
|
$this->assertTrue($ok);
|
|
|
|
$sql = "SELECT * FROM phpbb_config
|
|
WHERE config_name = 'foo'";
|
|
|
|
$key = $this->driver->key_prefix . 'sql_' . md5(preg_replace('/[\n\r\s\t]+/', ' ', $sql));
|
|
$this->assertFalse($redis->exists($key));
|
|
|
|
$result = $db->sql_query($sql, 300);
|
|
$first_result = $db->sql_fetchrow($result);
|
|
$expected = array('config_name' => 'foo', 'config_value' => '23', 'is_dynamic' => 0);
|
|
$this->assertEquals($expected, $first_result);
|
|
|
|
$this->assertTrue($redis->exists($key));
|
|
|
|
$sql = 'DELETE FROM phpbb_config';
|
|
$result = $db->sql_query($sql);
|
|
|
|
$sql = "SELECT * FROM phpbb_config
|
|
WHERE config_name = 'foo'";
|
|
$result = $db->sql_query($sql, 300);
|
|
|
|
$this->assertEquals($expected, $db->sql_fetchrow($result));
|
|
|
|
$sql = "SELECT * FROM phpbb_config
|
|
WHERE config_name = 'foo'";
|
|
$result = $db->sql_query($sql);
|
|
|
|
$no_cache_result = $db->sql_fetchrow($result);
|
|
$this->assertSame(false, $no_cache_result);
|
|
|
|
$db->sql_close();
|
|
}
|
|
}
|