. */ require_once 'lib/DoctrineTestInit.php'; /** * Test case for testing the saving and referencing of query identifiers. * * @package Doctrine * @subpackage Query * @author Guilherme Blanco * @author Janne Vanhala * @author Konsta Vesterinen * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @link http://www.phpdoctrine.org * @since 2.0 * @version $Revision$ * @todo 1) [romanb] We might want to split the SQL generation tests into multiple * testcases later since we'll have a lot of them and we might want to have special SQL * generation tests for some dbms specific SQL syntaxes. */ class Orm_Query_SelectSqlGenerationTest extends Doctrine_OrmTestCase { private $_em; protected function setUp() { $this->_em = $this->_getTestEntityManager(); } public function assertSqlGeneration($dqlToBeTested, $sqlToBeConfirmed) { try { $query = $this->_em->createQuery($dqlToBeTested); parent::assertEquals($sqlToBeConfirmed, $query->getSql()); $query->free(); } catch (Doctrine_Exception $e) { echo $e->getTraceAsString(); die(); $this->fail($e->getMessage()); } } public function testPlainFromClauseWithoutAlias() { $this->assertSqlGeneration( 'SELECT u FROM CmsUser u', 'SELECT cu.id AS cu__id, cu.status AS cu__status, cu.username AS cu__username, cu.name AS cu__name FROM CmsUser cu' ); $this->assertSqlGeneration( 'SELECT u.id FROM CmsUser u', 'SELECT cu.id AS cu__id FROM CmsUser cu' ); } public function testSelectSingleComponentWithMultipleColumns() { $this->assertSqlGeneration( 'SELECT u.username, u.name FROM CmsUser u', 'SELECT cu.username AS cu__username, cu.name AS cu__name FROM CmsUser cu' ); } public function testSelectWithCollectionAssociationJoin() { $this->assertSqlGeneration( 'SELECT u, p FROM CmsUser u JOIN u.phonenumbers p', 'SELECT cu.id AS cu__id, cu.status AS cu__status, cu.username AS cu__username, cu.name AS cu__name, cp.phonenumber AS cp__phonenumber FROM CmsUser cu INNER JOIN CmsPhonenumber cp ON cu.id = cp.user_id' ); } public function testSelectWithSingleValuedAssociationJoin() { $this->assertSqlGeneration( 'SELECT u, a FROM ForumUser u JOIN u.avatar a', 'SELECT fu.id AS fu__id, fu.username AS fu__username, fa.id AS fa__id FROM ForumUser fu INNER JOIN ForumAvatar fa ON fu.avatar_id = fa.id' ); } public function testSelectDistinctIsSupported() { $this->assertSqlGeneration( 'SELECT DISTINCT u.name FROM CmsUser u', 'SELECT DISTINCT cu.name AS cu__name FROM CmsUser cu' ); } public function testAggregateFunctionInSelect() { $this->assertSqlGeneration( 'SELECT COUNT(u.id) FROM CmsUser u GROUP BY u.id', 'SELECT COUNT(cu.id) AS dctrn__0 FROM CmsUser cu GROUP BY cu.id' ); } public function testWhereClauseInSelect() { $this->assertSqlGeneration( 'select u from ForumUser u where u.id = ?', 'SELECT fu.id AS fu__id, fu.username AS fu__username FROM ForumUser fu WHERE fu.id = ?' ); } /* public function testAggregateFunctionWithDistinctInSelect() { $this->assertSqlGeneration( 'SELECT COUNT(DISTINCT u.name) FROM CmsUser u', 'SELECT COUNT(DISTINCT cu.name) AS dctrn__0 FROM cms_user cu WHERE 1 = 1' ); } public function testFunctionalExpressionsSupportedInWherePart() { $this->assertSqlGeneration( "SELECT u.name FROM CmsUser u WHERE TRIM(u.name) = 'someone'", // String quoting in the SQL usually depends on the database platform. // This test works with a mock connection which uses ' for string quoting. "SELECT cu.name AS cu__name FROM cms_user cu WHERE TRIM(cu.name) = 'someone'" ); } // Ticket #668 public function testKeywordUsageInStringParam() { $this->assertSqlGeneration( "SELECT u.name FROM CmsUser u WHERE u.name LIKE '%foo OR bar%'", "SELECT cu.name AS cu__name FROM cms_user cu WHERE cu.name LIKE '%foo OR bar%'" ); } // Ticket #973 public function testSingleInValueWithoutSpace() { $this->assertSqlGeneration( "SELECT u.name FROM CmsUser u WHERE u.id IN(46)", "SELECT cu.name AS cu__name FROM cms_user cu WHERE cu.id IN (46)" ); } // Ticket 894 public function testBetweenDeclarationWithInputParameter() { $this->assertSqlGeneration( "SELECT u.name FROM CmsUser u WHERE u.id BETWEEN ? AND ?", "SELECT cu.name AS cu__name FROM cms_user cu WHERE cu.id BETWEEN ? AND ?" ); } public function testArithmeticExpressionsSupportedInWherePart() { $this->assertSqlGeneration( 'SELECT u.* FROM CmsUser u WHERE ((u.id + 5000) * u.id + 3) < 10000000', 'SELECT cu.id AS cu__id, cu.status AS cu__status, cu.username AS cu__username, cu.name AS cu__name FROM cms_user cu WHERE ((cu.id + 5000) * cu.id + 3) < 10000000' ); } public function testInExpressionSupportedInWherePart() { $this->assertSqlGeneration( 'SELECT * FROM CmsUser WHERE CmsUser.id IN (1, 2)', 'SELECT cu.id AS cu__id, cu.status AS cu__status, cu.username AS cu__username, cu.name AS cu__name FROM cms_user cu WHERE cu.id IN (1, 2)' ); } public function testNotInExpressionSupportedInWherePart() { $this->assertSqlGeneration( 'SELECT * FROM CmsUser WHERE CmsUser.id NOT IN (1)', 'SELECT cu.id AS cu__id, cu.status AS cu__status, cu.username AS cu__username, cu.name AS cu__name FROM cms_user cu WHERE cu.id NOT IN (1)' ); } public function testPlainJoinWithoutClause() { $this->assertSqlGeneration( 'SELECT u.id, a.id from CmsUser u LEFT JOIN u.articles a', 'SELECT cu.id AS cu__id, ca.id AS ca__id FROM cms_user cu LEFT JOIN cms_article ca ON cu.id = ca.user_id WHERE 1 = 1' ); $this->assertSqlGeneration( 'SELECT u.id, a.id from CmsUser u JOIN u.articles a', 'SELECT cu.id AS cu__id, ca.id AS ca__id FROM cms_user cu INNER JOIN cms_article ca ON cu.id = ca.user_id WHERE 1 = 1' ); } */ }