2007-09-03 21:13:31 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Doctrine_Ticket_428_TestCase
|
|
|
|
*
|
|
|
|
* @package Doctrine
|
|
|
|
* @author Tamcy <7am.online@gmail.com>
|
|
|
|
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
|
|
|
|
* @category Object Relational Mapping
|
2008-02-22 18:11:35 +00:00
|
|
|
* @link www.phpdoctrine.org
|
2007-09-03 21:13:31 +00:00
|
|
|
* @since 1.0
|
|
|
|
* @version $Revision$
|
|
|
|
*/
|
|
|
|
class Doctrine_Ticket_428_TestCase extends Doctrine_UnitTestCase
|
|
|
|
{
|
2008-03-05 11:24:33 +00:00
|
|
|
private $_albums;
|
|
|
|
|
2008-02-03 21:29:57 +00:00
|
|
|
public function prepareTables()
|
|
|
|
{
|
|
|
|
$this->tables = array('Album', 'Song');
|
|
|
|
parent::prepareTables();
|
|
|
|
}
|
|
|
|
|
2007-09-03 21:13:31 +00:00
|
|
|
public function prepareData()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testInitData()
|
|
|
|
{
|
|
|
|
// Since the tests do a $this->objTable()->clear() before each method call
|
|
|
|
// using the User model is not recommended for this test
|
|
|
|
$albums = new Doctrine_Collection('Album');
|
|
|
|
|
|
|
|
$albums[0]->name = 'Revolution';
|
|
|
|
$albums[0]->Song[0]->title = 'Revolution';
|
|
|
|
$albums[0]->Song[1]->title = 'Hey Jude';
|
|
|
|
$albums[0]->Song[2]->title = 'Across the Universe';
|
|
|
|
$albums[0]->Song[3]->title = 'Michelle';
|
|
|
|
$albums->save();
|
|
|
|
$this->assertEqual(count($albums[0]->Song), 4);
|
2008-03-05 11:24:33 +00:00
|
|
|
$this->_albums = $albums;
|
2007-09-03 21:13:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testAggregateValueMappingSupportsLeftJoins()
|
|
|
|
{
|
2008-03-05 11:24:33 +00:00
|
|
|
foreach ($this->_albums as $album) {
|
|
|
|
$album->clearRelated();
|
|
|
|
}
|
|
|
|
|
2007-09-03 21:13:31 +00:00
|
|
|
$q = new Doctrine_Query();
|
|
|
|
|
|
|
|
$q->select('a.name, COUNT(s.id) count')->from('Album a')->leftJoin('a.Song s')->groupby('a.id');
|
|
|
|
$albums = $q->execute();
|
2008-02-03 21:29:57 +00:00
|
|
|
|
2007-09-03 21:13:31 +00:00
|
|
|
// Should not reuse the existing collection in this case
|
|
|
|
$this->assertEqual(count($albums[0]->Song), 1);
|
|
|
|
|
|
|
|
try {
|
|
|
|
// Collection[0] should refer to the object with aggregate value
|
|
|
|
$this->assertEqual($albums[0]['Song'][0]['count'], 4);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
$this->fail('count aggregate value should be available');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|