. */ /** * Doctrine mock connection adapter. This class is used for special testing purposes. * * @package Doctrine * @subpackage Adapter * @author Konsta Vesterinen * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @link www.doctrine-project.org * @since 1.0 * @version $Revision: 7490 $ */ class Doctrine_Adapter_Mock implements Doctrine_Adapter_Interface, Countable { /** * Name of the dbms to mock * * @var string */ private $_name; /** * Array of queries executed through this instance of the mock adapter * * @var array $queries */ private $_queries = array(); /** * Array of exceptions thrown * * @var array $exceptions */ private $_exception = array(); /** * Bool true/false variable for whether or not the last insert failed * * @var boolean $lastInsertIdFail */ private $_lastInsertIdFail = false; /** * Doctrine mock adapter constructor * * * $conn = new Doctrine_Adapter_Mock('mysql'); * * * @param string $name * @return void */ public function __construct($name = null) { $this->_name = $name; } /** * Get the name of the dbms used in this instance of the mock adapter * * @return string $name Name of the dbms */ public function getName() { return $this->_name; } /** * Pop the last executed query from the array of executed queries and return it * * @return string $sql Last executed sql string */ public function pop() { return array_pop($this->_queries); } /** * Force an exception in to the array of exceptions * * @param string $name Name of exception * @param string $message Message for the exception * @param integer $code Code of the exception * @return void */ public function forceException($name, $message = '', $code = 0) { $this->_exception = array($name, $message, $code); } /** * Prepare a query statement * * @param string $query Query to prepare * @return Doctrine_Adapter_Statement_Mock $mock Mock prepared statement */ public function prepare($query) { $mock = new Doctrine_Adapter_Statement_Mock($this, $query); $mock->queryString = $query; return $mock; } /** * Add query to the stack of executed queries * * @param string $query * @return void */ public function addQuery($query) { $this->_queries[] = $query; } /** * Fake the execution of query and add it to the stack of executed queries * * @param string $query * @return Doctrine_Adapter_Statement_Mock $stmt */ public function query($query) { $this->_queries[] = $query; $e = $this->_exception; if ( ! empty($e)) { $name = $e[0]; $this->_exception = array(); throw new $name($e[1], $e[2]); } $stmt = new Doctrine_Adapter_Statement_Mock($this, $query); $stmt->queryString = $query; return $stmt; } /** * Get all the executed queries * * @return array $queries Array of all executed queries */ public function getAll() { return $this->_queries; } /** * Quote a value for the dbms * * @param string $input * @return string $quoted */ public function quote($input) { return "'" . addslashes($input) . "'"; } /** * Execute a raw sql statement * * @param string $statement * @return void */ public function exec($statement) { $this->_queries[] = $statement; $e = $this->_exception; if ( ! empty($e)) { $name = $e[0]; $this->_exception = array(); throw new $name($e[1], $e[2]); } return 0; } /** * Force last insert to be failed * * @param boolean $fail * @return void */ public function forceLastInsertIdFail($fail = true) { if ($fail) { $this->_lastInsertIdFail = true; } else { $this->_lastInsertIdFail = false; } } /** * Get the id of the last inserted record * * @return integer $id */ public function lastInsertId() { $this->_queries[] = 'LAST_INSERT_ID()'; if ($this->_lastInsertIdFail) { return null; } else { return 1; } } /** * Get the number of queries executed * * @return integer $count */ public function count() { return count($this->_queries); } /** * Begin a transaction * * @return void */ public function beginTransaction() { $this->_queries[] = 'BEGIN TRANSACTION'; } /** * Commit a transaction * * @return void */ public function commit() { $this->_queries[] = 'COMMIT'; } /** * Rollback a transaction * * @return void */ public function rollBack() { $this->_queries[] = 'ROLLBACK'; } public function getAttribute($attribute) { if ($attribute == Doctrine_Core::ATTR_DRIVER_NAME) { return strtolower($this->_name); } } public function errorCode() { } public function errorInfo() { } public function setAttribute($attribute, $value) { } public function sqliteCreateFunction() { } }