From 63d21ca4b28cb0e9192dadf6ff9d9dd17f0c2e4c Mon Sep 17 00:00:00 2001 From: Guilherme Blanco Date: Mon, 21 Apr 2014 04:01:19 +0000 Subject: [PATCH] DDC-3085 Verify ResultVariable works in combination with NullComparisonExpression wihle in HAVING clause. --- .../Tests/ORM/Query/LanguageRecognitionTest.php | 8 ++++++++ .../Tests/ORM/Query/SelectSqlGenerationTest.php | 11 +++++++++++ 2 files changed, 19 insertions(+) diff --git a/tests/Doctrine/Tests/ORM/Query/LanguageRecognitionTest.php b/tests/Doctrine/Tests/ORM/Query/LanguageRecognitionTest.php index 096a1115d..85a5a810c 100644 --- a/tests/Doctrine/Tests/ORM/Query/LanguageRecognitionTest.php +++ b/tests/Doctrine/Tests/ORM/Query/LanguageRecognitionTest.php @@ -596,6 +596,14 @@ class LanguageRecognitionTest extends \Doctrine\Tests\OrmTestCase { $this->assertValidDQL("SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u HAVING u.username IS NULL"); } + + /** + * @group DDC-3085 + */ + public function testHavingSupportResultVariableInNullComparisonExpression() + { + $this->assertValidDQL("SELECT u AS user, SUM(a.id) AS score FROM Doctrine\Tests\Models\CMS\CmsUser u LEFT JOIN Doctrine\Tests\Models\CMS\CmsAddress a WITH a.user = u GROUP BY u HAVING score IS NOT NULL AND score >= 5"); + } /** * @group DDC-1858 diff --git a/tests/Doctrine/Tests/ORM/Query/SelectSqlGenerationTest.php b/tests/Doctrine/Tests/ORM/Query/SelectSqlGenerationTest.php index 918433ff1..207f37a69 100644 --- a/tests/Doctrine/Tests/ORM/Query/SelectSqlGenerationTest.php +++ b/tests/Doctrine/Tests/ORM/Query/SelectSqlGenerationTest.php @@ -2185,6 +2185,17 @@ class SelectSqlGenerationTest extends \Doctrine\Tests\OrmTestCase "SELECT c0_.name AS name_0 FROM cms_users c0_ HAVING name_0 LIKE '3'" ); } + + /** + * @group DDC-3085 + */ + public function testHavingSupportResultVariableNullComparisonExpression() + { + $this->assertSqlGeneration( + "SELECT u AS user, SUM(a.id) AS score FROM Doctrine\Tests\Models\CMS\CmsUser u LEFT JOIN Doctrine\Tests\Models\CMS\CmsAddress a WITH a.user = u GROUP BY u HAVING score IS NOT NULL AND score >= 5", + "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, SUM(c1_.id) AS sclr_4 FROM cms_users c0_ LEFT JOIN cms_addresses c1_ ON (c1_.user_id = c0_.id) GROUP BY c0_.id, c0_.status, c0_.username, c0_.name, c0_.email_id HAVING sclr_4 IS NOT NULL AND sclr_4 >= 5" + ); + } /** * @group DDC-1858