aboutsummaryrefslogtreecommitdiffstats
path: root/tests/cache/redis_driver_test.php
diff options
context:
space:
mode:
authorOleg Pudeyev <oleg@bsdpower.com>2012-12-01 15:03:44 -0500
committerOleg Pudeyev <oleg@bsdpower.com>2012-12-01 15:03:44 -0500
commit1e3dff83b3e56353fd97a6581989c478e52ed892 (patch)
tree7f1f39991ae897f1d3818414c4b67a2b0eef00b9 /tests/cache/redis_driver_test.php
parentc852044d6eecc0a652800b1661491c0f9c545054 (diff)
downloadforums-1e3dff83b3e56353fd97a6581989c478e52ed892.tar
forums-1e3dff83b3e56353fd97a6581989c478e52ed892.tar.gz
forums-1e3dff83b3e56353fd97a6581989c478e52ed892.tar.bz2
forums-1e3dff83b3e56353fd97a6581989c478e52ed892.tar.xz
forums-1e3dff83b3e56353fd97a6581989c478e52ed892.zip
[ticket/9983] Split cache test into per-driver files.
PHPBB3-9983
Diffstat (limited to 'tests/cache/redis_driver_test.php')
-rw-r--r--tests/cache/redis_driver_test.php89
1 files changed, 89 insertions, 0 deletions
diff --git a/tests/cache/redis_driver_test.php b/tests/cache/redis_driver_test.php
new file mode 100644
index 0000000000..be8b518dca
--- /dev/null
+++ b/tests/cache/redis_driver_test.php
@@ -0,0 +1,89 @@
+<?php
+/**
+*
+* @package testing
+* @copyright (c) 2012 phpBB Group
+* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
+*
+*/
+
+class phpbb_cache_redis_driver_test extends phpbb_database_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
+ {
+ $this->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_redis()
+ {
+ 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();
+ }
+}