* @license GNU General Public License, version 2 (GPL-2.0) * * For full copyright and license information, please see * the docs/CREDITS.txt file. * */ require_once dirname(__FILE__) . '/cache_memory.php'; class phpbb_cache_memory_test extends phpbb_database_test_case { protected $cache; protected $db; public function getDataSet() { return $this->createXMLDataSet(dirname(__FILE__).'/fixtures/cache_memory.xml'); } protected function setUp() { global $db; parent::setUp(); $this->cache = new phpbb_cache_memory(); $db = $this->new_dbal(); $this->db = $db; } static public function cache_single_query_data() { return array( array( array( array( 'SELECT * FROM ' . POSTS_TABLE, 3, ), ), POSTS_TABLE, ), array( array( array( 'SELECT * FROM ' . POSTS_TABLE, 3, ), array( 'SELECT * FROM ' . POSTS_TABLE . ' p LEFT JOIN ' . TOPICS_TABLE . ' t ON p.topic_id = t.topic_id', 3, ), ), POSTS_TABLE, ), array( array( array( 'SELECT * FROM ' . POSTS_TABLE, 3, ), array( 'SELECT * FROM ' . POSTS_TABLE . ' p LEFT JOIN ' . TOPICS_TABLE . ' t ON p.topic_id = t.topic_id', 3, ), array( 'SELECT * FROM ' . POSTS_TABLE . ' p LEFT JOIN ' . TOPICS_TABLE . ' t ON p.topic_id = t.topic_id LEFT JOIN ' . USERS_TABLE . ' u ON p.poster_id = u.user_id', 3, ), ), POSTS_TABLE, ), array( array( array( 'SELECT * FROM ' . POSTS_TABLE . ' p LEFT JOIN ' . TOPICS_TABLE . ' t ON p.topic_id = t.topic_id', 3, ), array( 'SELECT * FROM ' . POSTS_TABLE . ' p LEFT JOIN ' . TOPICS_TABLE . ' t ON p.topic_id = t.topic_id LEFT JOIN ' . USERS_TABLE . ' u ON p.poster_id = u.user_id', 3, ), ), TOPICS_TABLE, ), ); } /** * @dataProvider cache_single_query_data */ public function test_cache_single_query($sql_queries, $table) { foreach ($sql_queries as $query) { $sql_request_res = $this->db->sql_query($query[0]); $this->cache->sql_save($this->db, $query[0], $sql_request_res, 1); $results = array(); $query_id = $this->cache->sql_load($query[0]); while ($row = $this->cache->sql_fetchrow($query_id)) { $results[] = $row; } $this->cache->sql_freeresult($query_id); $this->assertEquals($query[1], count($results)); } $this->cache->destroy('sql', $table); foreach ($sql_queries as $query) { $this->assertNotEquals(false, $this->cache->sql_load($query[0])); } } }