1
0
mirror of synced 2024-12-15 07:36:03 +03:00
doctrine2/tests/Query/MysqlSubqueryTestCase.php
2007-06-27 16:50:27 +00:00

32 lines
1023 B
PHP

<?php
class Doctrine_Query_MysqlSubquery_TestCase extends Doctrine_UnitTestCase
{
public function testInit()
{
$this->dbh = new Doctrine_Adapter_Mock('mysql');
$this->conn = Doctrine_Manager::getInstance()->openConnection($this->dbh);
}
public function testGetLimitSubqueryOrderBy()
{
$q = new Doctrine_Query();
$q->select('u.name, COUNT(DISTINCT a.id) num_albums');
$q->from('User u, u.Album a');
$q->orderby('num_albums');
$q->groupby('u.id');
// this causes getLimitSubquery() to be used, and it fails
$q->limit(5);
try {
$q->execute();
} catch (Doctrine_Exception $e) {
$this->fail();
}
$queries = $this->dbh->getAll();
$this->assertEqual($queries[0], 'SELECT DISTINCT e2.id, COUNT(DISTINCT a.id) AS a__0 FROM entity e2 LEFT JOIN album a2 ON e2.id = a2.user_id WHERE (e2.type = 0) GROUP BY e2.id ORDER BY a__0 LIMIT 5');
}
}