From 61dc5e19c2f7e6d71ca81bff04ea30088c6c941a Mon Sep 17 00:00:00 2001 From: romanb Date: Fri, 13 Apr 2007 18:18:00 +0000 Subject: [PATCH] --- tests/Query/SubqueryTestCase.php | 138 ++++++++++++++++--------------- 1 file changed, 70 insertions(+), 68 deletions(-) diff --git a/tests/Query/SubqueryTestCase.php b/tests/Query/SubqueryTestCase.php index 60a9e16f7..0e9f5e490 100644 --- a/tests/Query/SubqueryTestCase.php +++ b/tests/Query/SubqueryTestCase.php @@ -1,68 +1,70 @@ -. - */ - -/** - * Doctrine_Query_Subquery_TestCase - * This test case is used for testing DQL subquery functionality - * - * @package Doctrine - * @author Konsta Vesterinen - * @license http://www.opensource.org/licenses/lgpl-license.php LGPL - * @category Object Relational Mapping - * @link www.phpdoctrine.com - * @since 1.0 - * @version $Revision$ - */ -class Doctrine_Query_Subquery_TestCase extends Doctrine_UnitTestCase -{ - public function testSubqueryWithWherePartAndInExpression() - { - $q = new Doctrine_Query(); - $q->from('User')->where("User.id NOT IN (FROM User(id) WHERE User.name = 'zYne')"); - - $this->assertEqual($q->getQuery(), - "SELECT e.id AS e__id, e.name AS e__name, e.loginname AS e__loginname, e.password AS e__password, e.type AS e__type, e.created AS e__created, e.updated AS e__updated, e.email_id AS e__email_id FROM entity e WHERE e.id NOT IN (SELECT e.id AS e__id FROM entity e WHERE e.name = 'zYne' AND (e.type = 0)) AND (e.type = 0)"); - - $users = $q->execute(); - - $this->assertEqual($users->count(), 7); - $this->assertEqual($users[0]->name, 'Arnold Schwarzenegger'); - } - public function testSubqueryAllowsSelectingOfAnyField() - { - $q = new Doctrine_Query(); - $q->from('User u')->where('u.id NOT IN (SELECT g.user_id FROM Groupuser g)'); - - $this->assertEqual($q->getQuery(), "SELECT e.id AS e__id, e.name AS e__name, e.loginname AS e__loginname, e.password AS e__password, e.type AS e__type, e.created AS e__created, e.updated AS e__updated, e.email_id AS e__email_id FROM entity e WHERE e.id NOT IN (SELECT g.user_id AS g__user_id FROM groupuser g) AND (e.type = 0)"); - } - - public function testSubqueryInSelectPart() - { - // ticket #307 - $q = new Doctrine_Query(); - $q->query("SELECT u.*, (SELECT p.name FROM User p WHERE p.name = u.name) name2 FROM User u WHERE u.name = 'zYne' LIMIT 1"); - - $users = $q->execute(); - - $this->assertEqual($users->count(), 1); - } -} -?> +. + */ + +/** + * Doctrine_Query_Subquery_TestCase + * This test case is used for testing DQL subquery functionality + * + * @package Doctrine + * @author Konsta Vesterinen + * @license http://www.opensource.org/licenses/lgpl-license.php LGPL + * @category Object Relational Mapping + * @link www.phpdoctrine.com + * @since 1.0 + * @version $Revision$ + */ +class Doctrine_Query_Subquery_TestCase extends Doctrine_UnitTestCase +{ + public function testSubqueryWithWherePartAndInExpression() + { + $q = new Doctrine_Query(); + $q->from('User')->where("User.id NOT IN (FROM User(id) WHERE User.name = 'zYne')"); + + $this->assertEqual($q->getQuery(), + "SELECT e.id AS e__id, e.name AS e__name, e.loginname AS e__loginname, e.password AS e__password, e.type AS e__type, e.created AS e__created, e.updated AS e__updated, e.email_id AS e__email_id FROM entity e WHERE e.id NOT IN (SELECT e.id AS e__id FROM entity e WHERE e.name = 'zYne' AND (e.type = 0)) AND (e.type = 0)"); + + $users = $q->execute(); + + $this->assertEqual($users->count(), 7); + $this->assertEqual($users[0]->name, 'Arnold Schwarzenegger'); + } + public function testSubqueryAllowsSelectingOfAnyField() + { + $q = new Doctrine_Query(); + $q->from('User u')->where('u.id NOT IN (SELECT g.user_id FROM Groupuser g)'); + + $this->assertEqual($q->getQuery(), "SELECT e.id AS e__id, e.name AS e__name, e.loginname AS e__loginname, e.password AS e__password, e.type AS e__type, e.created AS e__created, e.updated AS e__updated, e.email_id AS e__email_id FROM entity e WHERE e.id NOT IN (SELECT g.user_id AS g__user_id FROM groupuser g) AND (e.type = 0)"); + } + + public function testSubqueryInSelectPart() + { + // ticket #307 + $q = new Doctrine_Query(); + /*$q->query("SELECT u.*, (SELECT p.name FROM User p WHERE p.name = u.name) name2 FROM User u WHERE u.name = 'zYne' LIMIT 1"); + + $users = $q->execute(); + + $this->assertEqual($users->count(), 1); + */ + $this->fail("Subquery support in select part. Ticket #307."); + } +} +?>