mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-18 02:26:17 +00:00
Adding tests for tinyint(1) -> boolean typecasting in DboMysql, closes #4568
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@6885 3807eeeb-6ff5-0310-8944-8be069107fe0
This commit is contained in:
parent
ffd272901c
commit
6614bc96ab
1 changed files with 38 additions and 2 deletions
|
@ -43,10 +43,15 @@ class DboMysqlTestDb extends DboMysql {
|
||||||
|
|
||||||
var $simulated = array();
|
var $simulated = array();
|
||||||
|
|
||||||
|
var $testing = true;
|
||||||
|
|
||||||
function _execute($sql) {
|
function _execute($sql) {
|
||||||
|
if ($this->testing) {
|
||||||
$this->simulated[] = $sql;
|
$this->simulated[] = $sql;
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
return parent::_execute($sql);
|
||||||
|
}
|
||||||
|
|
||||||
function getLastQuery() {
|
function getLastQuery() {
|
||||||
return $this->simulated[count($this->simulated) - 1];
|
return $this->simulated[count($this->simulated) - 1];
|
||||||
|
@ -185,5 +190,36 @@ class DboMysqlTest extends CakeTestCase {
|
||||||
$result = $this->db->value('00010010001');
|
$result = $this->db->value('00010010001');
|
||||||
$this->assertEqual($expected, $result);
|
$this->assertEqual($expected, $result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function testTinyintCasting() {
|
||||||
|
$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));');
|
||||||
|
|
||||||
|
$this->model = new Model(array('name' => 'Tinyint', 'table' => $this->db->fullTableName('tinyint', false)));
|
||||||
|
$result = $this->model->schema();
|
||||||
|
$this->assertEqual($result['bool']['type'], 'boolean');
|
||||||
|
$this->assertEqual($result['small_int']['type'], 'integer');
|
||||||
|
|
||||||
|
$this->assertTrue($this->model->save(array('bool' => 5, 'small_int' => 5)));
|
||||||
|
$result = $this->model->find('first');
|
||||||
|
$this->assertIdentical($result['Tinyint']['bool'], '1');
|
||||||
|
$this->assertIdentical($result['Tinyint']['small_int'], '5');
|
||||||
|
$this->model->deleteAll(true);
|
||||||
|
|
||||||
|
$this->assertTrue($this->model->save(array('bool' => 0, 'small_int' => 100)));
|
||||||
|
$result = $this->model->find('first');
|
||||||
|
$this->assertIdentical($result['Tinyint']['bool'], '0');
|
||||||
|
$this->assertIdentical($result['Tinyint']['small_int'], '100');
|
||||||
|
$this->model->deleteAll(true);
|
||||||
|
|
||||||
|
$this->assertTrue($this->model->save(array('bool' => true, 'small_int' => 0)));
|
||||||
|
$result = $this->model->find('first');
|
||||||
|
$this->assertIdentical($result['Tinyint']['bool'], '1');
|
||||||
|
$this->assertIdentical($result['Tinyint']['small_int'], '0');
|
||||||
|
$this->model->deleteAll(true);
|
||||||
|
|
||||||
|
$this->db->query('DROP TABLE ' . $this->db->fullTableName('tinyint'));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
?>
|
?>
|
Loading…
Add table
Reference in a new issue