You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					70 lines
				
				1.5 KiB
			
		
		
			
		
	
	
					70 lines
				
				1.5 KiB
			| 
											13 years ago
										 | <?php
 | ||
|  | namespace yiiunit\framework\caching;
 | ||
|  | use yii\caching\DbCache;
 | ||
|  | use yiiunit\TestCase;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Class for testing file cache backend
 | ||
|  |  */
 | ||
|  | class DbCacheTest extends CacheTest
 | ||
|  | {
 | ||
|  | 	private $_cacheInstance;
 | ||
|  | 	private $_connection;
 | ||
|  | 
 | ||
|  | 	function __construct()
 | ||
|  | 	{
 | ||
|  | 		if (!extension_loaded('pdo') || !extension_loaded('pdo_mysql')) {
 | ||
|  | 			$this->markTestSkipped('pdo and pdo_mysql extensions are required.');
 | ||
|  | 		}
 | ||
|  | 
 | ||
|  | 		$this->getConnection()->createCommand("
 | ||
|  | 			CREATE TABLE IF NOT EXISTS tbl_cache (
 | ||
|  | 				id char(128) NOT NULL,
 | ||
|  | 				expire int(11) DEFAULT NULL,
 | ||
|  | 				data LONGBLOB,
 | ||
|  | 				PRIMARY KEY (id),
 | ||
|  | 				KEY expire (expire)
 | ||
|  | 			);
 | ||
|  | 		")->execute();
 | ||
|  | 	}
 | ||
|  | 
 | ||
|  | 	/**
 | ||
|  | 	 * @param bool $reset whether to clean up the test database
 | ||
|  | 	 * @return \yii\db\Connection
 | ||
|  | 	 */
 | ||
|  | 	function getConnection($reset = true)
 | ||
|  | 	{
 | ||
|  | 		if($this->_connection === null) {
 | ||
|  | 			$params = $this->getParam('mysql');
 | ||
|  | 			$db = new \yii\db\Connection;
 | ||
|  | 			$db->dsn = $params['dsn'];
 | ||
|  | 			$db->username = $params['username'];
 | ||
|  | 			$db->password = $params['password'];
 | ||
|  | 			if ($reset) {
 | ||
|  | 				$db->open();
 | ||
|  | 				$lines = explode(';', file_get_contents($params['fixture']));
 | ||
|  | 				foreach ($lines as $line) {
 | ||
|  | 					if (trim($line) !== '') {
 | ||
|  | 						$db->pdo->exec($line);
 | ||
|  | 					}
 | ||
|  | 				}
 | ||
|  | 			}
 | ||
|  | 			$this->_connection = $db;
 | ||
|  | 		}
 | ||
|  | 		return $this->_connection;
 | ||
|  | 	}
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 	/**
 | ||
|  | 	 * @return DbCache
 | ||
|  | 	 */
 | ||
|  | 	protected function getCacheInstance()
 | ||
|  | 	{
 | ||
|  | 		if($this->_cacheInstance === null) {
 | ||
|  | 			$this->_cacheInstance = new DbCache(array(
 | ||
|  | 				'db' => $this->getConnection(),
 | ||
|  | 			));
 | ||
|  | 		}
 | ||
|  | 		return $this->_cacheInstance;
 | ||
|  | 	}
 | ||
|  | }
 |