1
0
mirror of synced 2025-01-22 08:11:40 +03:00
This commit is contained in:
zYne 2007-06-28 21:43:31 +00:00
parent 2d2e01a783
commit 5b2c57af1f
2 changed files with 43 additions and 24 deletions

View File

@ -623,13 +623,14 @@ class Doctrine_Hydrate extends Doctrine_Object implements Serializable
if (isset($this->_aliasMap[$alias]['agg'][$index])) { if (isset($this->_aliasMap[$alias]['agg'][$index])) {
$agg = $this->_aliasMap[$alias]['agg'][$index]; $agg = $this->_aliasMap[$alias]['agg'][$index];
} }
if ($agg) {
if (is_array($record)) { if (is_array($record)) {
$record[$agg] = $value; $record[$agg] = $value;
} else { } else {
$record->mapValue($agg, $value); $record->mapValue($agg, $value);
}
$found = true;
} }
$found = true;
} }
return $found; return $found;

View File

@ -34,14 +34,14 @@ class Doctrine_Record_ZeroValues_TestCase extends Doctrine_UnitTestCase
{ {
public function prepareTables() public function prepareTables()
{ {
$this->tables[] = 'MyUser2'; $this->tables[] = 'ZeroValueTest';
parent::prepareTables(); parent::prepareTables();
} }
public function prepareData() public function prepareData()
{ {
$user = new MyUser2(); $user = new ZeroValueTest();
$user['is_super_admin'] = 0; // set it to 0 and it should be 0 when we pull it back from the database $user['is_super_admin'] = 0; // set it to 0 and it should be 0 when we pull it back from the database
$user['username'] = 'jwage'; $user['username'] = 'jwage';
$user['salt'] = 'test'; $user['salt'] = 'test';
@ -50,31 +50,49 @@ class Doctrine_Record_ZeroValues_TestCase extends Doctrine_UnitTestCase
} }
public function testZeroValuesMaintained() public function testZeroValuesMaintained()
{
$users = $this->dbh->query('SELECT * FROM zero_value_test')->fetchAll(PDO::FETCH_ASSOC);
$this->assertIdentical($users[0]['is_super_admin'], '0');
}
public function testZeroValuesMaintained2()
{ {
$q = new Doctrine_Query(); $q = new Doctrine_Query();
$q->from('MyUser2'); $q->from('ZeroValueTest');
$users = $q->execute(array(), Doctrine::FETCH_ARRAY);
$this->assertIdentical($users[0]['is_super_admin'], '0');
// check for aggregate bug
$this->assertTrue( ! isset($users[0][0]));
}
public function testZeroValuesMaintained3()
{
$q = new Doctrine_Query();
$q->from('ZeroValueTest');
$users = $q->execute(); $users = $q->execute();
$this->assertIdentical($users[0]['is_super_admin'], 0); $this->assertIdentical($users[0]['is_super_admin'], false);
} }
} }
class MyUser2 extends Doctrine_Record class ZeroValueTest extends Doctrine_Record
{ {
public function setTableDefinition() public function setTableDefinition()
{ {
$this->setTableName('my_user2'); $this->hasColumn('id', 'integer', 4, array('primary' => true, 'autoincrement' => true,));
$this->hasColumn('username', 'string', 128, array('notnull' => true,));
$this->hasColumn('id', 'integer', 4, array ( 'primary' => true, 'autoincrement' => true,)); $this->hasColumn('algorithm', 'string', 128, array('default' => 'sha1', 'notnull' => true,));
$this->hasColumn('username', 'string', 128, array ( 'notnull' => true,)); $this->hasColumn('salt', 'string', 128, array('notnull' => true,));
$this->hasColumn('algorithm', 'string', 128, array ( 'default' => 'sha1', 'notnull' => true,)); $this->hasColumn('password', 'string', 128, array('notnull' => true,));
$this->hasColumn('salt', 'string', 128, array ( 'notnull' => true,)); $this->hasColumn('created_at', 'timestamp', null, array());
$this->hasColumn('password', 'string', 128, array ( 'notnull' => true,)); $this->hasColumn('last_login', 'timestamp', null, array());
$this->hasColumn('created_at', 'timestamp', null, array ()); $this->hasColumn('is_active', 'boolean', null, array('default' => true, 'notnull' => true,));
$this->hasColumn('last_login', 'timestamp', null, array ()); $this->hasColumn('is_super_admin', 'boolean', null, array('default' => false, 'notnull' => true,));
$this->hasColumn('is_active', 'boolean', null, array ( 'default' => true, 'notnull' => true,));
$this->hasColumn('is_super_admin', 'boolean', null, array ( 'default' => false, 'notnull' => true,));
} }
public function setUp() { } public function setUp()
{ }
} }