testing) { $this->simulated[] = $sql; return null; } return parent::_execute($sql); } /** * getLastQuery method * * @access public * @return void */ function getLastQuery() { return $this->simulated[count($this->simulated) - 1]; } } /** * MysqliTestModel class * * @package cake * @subpackage cake.tests.cases.libs.model.datasources */ class MysqliTestModel extends Model { /** * name property * * @var string 'MysqlTestModel' * @access public */ var $name = 'MysqliTestModel'; /** * useTable property * * @var bool false * @access public */ var $useTable = false; /** * schema method * * @access public * @return void */ function schema() { return array( 'id' => array('type' => 'integer', 'null' => '', 'default' => '', 'length' => '8'), 'client_id' => array('type' => 'integer', 'null' => '', 'default' => '0', 'length' => '11'), 'name' => array('type' => 'string', 'null' => '', 'default' => '', 'length' => '255'), 'login' => array('type' => 'string', 'null' => '', 'default' => '', 'length' => '255'), 'passwd' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '255'), 'addr_1' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '255'), 'addr_2' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '25'), 'zip_code' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'), 'city' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'), 'country' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'), 'phone' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'), 'fax' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'), 'url' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '255'), 'email' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'), 'comments' => array('type' => 'text', 'null' => '1', 'default' => '', 'length' => ''), 'last_login'=> array('type' => 'datetime', 'null' => '1', 'default' => '', 'length' => ''), 'created' => array('type' => 'date', 'null' => '1', 'default' => '', 'length' => ''), 'updated' => array('type' => 'datetime', 'null' => '1', 'default' => '', 'length' => null) ); } } /** * DboMysqliTest class * * @package cake * @subpackage cake.tests.cases.libs.model.datasources.dbo */ class DboMysqliTest extends CakeTestCase { var $fixtures = array('core.datatype'); /** * The Dbo instance to be tested * * @var DboSource * @access public */ var $Db = null; /** * Skip if cannot connect to mysqli * * @access public */ function skip() { $this->_initDb(); $this->skipUnless($this->db->config['driver'] == 'mysqli', '%s MySQLi connection not available'); } /** * Sets up a Dbo class instance for testing * * @access public */ function setUp() { $this->model = new MysqliTestModel(); } /** * Sets up a Dbo class instance for testing * * @access public */ function tearDown() { unset($this->model); ClassRegistry::flush(); } /** * testIndexDetection method * * @return void * @access public */ function testIndexDetection() { $this->db->cacheSources = false; $name = $this->db->fullTableName('simple'); $this->db->query('CREATE TABLE ' . $name . ' (id int(11) AUTO_INCREMENT, bool tinyint(1), small_int tinyint(2), primary key(id));'); $expected = array('PRIMARY' => array('column' => 'id', 'unique' => 1)); $result = $this->db->index($name, false); $this->assertEqual($expected, $result); $this->db->query('DROP TABLE ' . $name); $name = $this->db->fullTableName('with_a_key'); $this->db->query('CREATE TABLE ' . $name . ' (id int(11) AUTO_INCREMENT, bool tinyint(1), small_int tinyint(2), primary key(id), KEY `pointless_bool` ( `bool` ));'); $expected = array( 'PRIMARY' => array('column' => 'id', 'unique' => 1), 'pointless_bool' => array('column' => 'bool', 'unique' => 0), ); $result = $this->db->index($name, false); $this->assertEqual($expected, $result); $this->db->query('DROP TABLE ' . $name); $name = $this->db->fullTableName('with_two_keys'); $this->db->query('CREATE TABLE ' . $name . ' (id int(11) AUTO_INCREMENT, bool tinyint(1), small_int tinyint(2), primary key(id), KEY `pointless_bool` ( `bool` ), KEY `pointless_small_int` ( `small_int` ));'); $expected = array( 'PRIMARY' => array('column' => 'id', 'unique' => 1), 'pointless_bool' => array('column' => 'bool', 'unique' => 0), 'pointless_small_int' => array('column' => 'small_int', 'unique' => 0), ); $result = $this->db->index($name, false); $this->assertEqual($expected, $result); $this->db->query('DROP TABLE ' . $name); $name = $this->db->fullTableName('with_compound_keys'); $this->db->query('CREATE TABLE ' . $name . ' (id int(11) AUTO_INCREMENT, bool tinyint(1), small_int tinyint(2), primary key(id), KEY `pointless_bool` ( `bool` ), KEY `pointless_small_int` ( `small_int` ), KEY `one_way` ( `bool`, `small_int` ));'); $expected = array( 'PRIMARY' => array('column' => 'id', 'unique' => 1), 'pointless_bool' => array('column' => 'bool', 'unique' => 0), 'pointless_small_int' => array('column' => 'small_int', 'unique' => 0), 'one_way' => array('column' => array('bool', 'small_int'), 'unique' => 0), ); $result = $this->db->index($name, false); $this->assertEqual($expected, $result); $this->db->query('DROP TABLE ' . $name); $name = $this->db->fullTableName('with_multiple_compound_keys'); $this->db->query('CREATE TABLE ' . $name . ' (id int(11) AUTO_INCREMENT, bool tinyint(1), small_int tinyint(2), primary key(id), KEY `pointless_bool` ( `bool` ), KEY `pointless_small_int` ( `small_int` ), KEY `one_way` ( `bool`, `small_int` ), KEY `other_way` ( `small_int`, `bool` ));'); $expected = array( 'PRIMARY' => array('column' => 'id', 'unique' => 1), 'pointless_bool' => array('column' => 'bool', 'unique' => 0), 'pointless_small_int' => array('column' => 'small_int', 'unique' => 0), 'one_way' => array('column' => array('bool', 'small_int'), 'unique' => 0), 'other_way' => array('column' => array('small_int', 'bool'), 'unique' => 0), ); $result = $this->db->index($name, false); $this->assertEqual($expected, $result); $this->db->query('DROP TABLE ' . $name); } /** * testColumn method * * @return void * @access public */ function testColumn() { $result = $this->db->column('varchar(50)'); $expected = 'string'; $this->assertEqual($result, $expected); $result = $this->db->column('text'); $expected = 'text'; $this->assertEqual($result, $expected); $result = $this->db->column('int(11)'); $expected = 'integer'; $this->assertEqual($result, $expected); $result = $this->db->column('int(11) unsigned'); $expected = 'integer'; $this->assertEqual($result, $expected); $result = $this->db->column('tinyint(1)'); $expected = 'boolean'; $this->assertEqual($result, $expected); $result = $this->db->column('boolean'); $expected = 'boolean'; $this->assertEqual($result, $expected); $result = $this->db->column('float'); $expected = 'float'; $this->assertEqual($result, $expected); $result = $this->db->column('float unsigned'); $expected = 'float'; $this->assertEqual($result, $expected); $result = $this->db->column('double unsigned'); $expected = 'float'; $this->assertEqual($result, $expected); $result = $this->db->column('decimal(14,7) unsigned'); $expected = 'float'; $this->assertEqual($result, $expected); } /** * test transaction commands. * * @return void * @access public */ function testTransactions() { $this->db->testing = false; $result = $this->db->begin($this->model); $this->assertTrue($result); $beginSqlCalls = Set::extract('/.[query=START TRANSACTION]', $this->db->_queriesLog); $this->assertEqual(1, count($beginSqlCalls)); $result = $this->db->commit($this->model); $this->assertTrue($result); } /** * test that float values are correctly identified * * @return void */ function testFloatParsing() { $model =& new Model(array('ds' => 'test_suite', 'table' => 'datatypes', 'name' => 'Datatype')); $result = $this->db->describe($model); $this->assertEqual((string)$result['float_field']['length'], '5,2'); } /** * test that tableParameters like collation, charset and engine are functioning. * * @access public * @return void */ function testReadTableParameters() { $this->db->cacheSources = $this->db->testing = false; $this->db->query('CREATE TABLE ' . $this->db->fullTableName('tinyint') . ' (id int(11) AUTO_INCREMENT, bool tinyint(1), small_int tinyint(2), primary key(id)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;'); $result = $this->db->readTableParameters('tinyint'); $expected = array( 'charset' => 'utf8', 'collate' => 'utf8_unicode_ci', 'engine' => 'InnoDB'); $this->assertEqual($result, $expected); $this->db->query('DROP TABLE ' . $this->db->fullTableName('tinyint')); $this->db->query('CREATE TABLE ' . $this->db->fullTableName('tinyint') . ' (id int(11) AUTO_INCREMENT, bool tinyint(1), small_int tinyint(2), primary key(id)) ENGINE=MyISAM DEFAULT CHARSET=cp1250 COLLATE=cp1250_general_ci;'); $result = $this->db->readTableParameters('tinyint'); $expected = array( 'charset' => 'cp1250', 'collate' => 'cp1250_general_ci', 'engine' => 'MyISAM'); $this->assertEqual($result, $expected); $this->db->query('DROP TABLE ' . $this->db->fullTableName('tinyint')); } }