This commit is contained in:
parent
2d2e01a783
commit
5b2c57af1f
@ -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;
|
||||||
|
@ -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()
|
||||||
}
|
{ }
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user