2006-05-10 01:39:07 +04:00
< ? php
class Doctrine_QueryTestCase extends Doctrine_UnitTestCase {
2006-05-19 00:44:02 +04:00
public function prepareTables () {
$this -> tables [] = " Forum_Category " ;
$this -> tables [] = " Forum_Entry " ;
$this -> tables [] = " Forum_Board " ;
$this -> tables [] = " Forum_Thread " ;
2006-06-03 13:10:43 +04:00
$this -> tables [] = " ORM_TestEntry " ;
$this -> tables [] = " ORM_TestItem " ;
$this -> tables [] = " Log_Status " ;
$this -> tables [] = " Log_Entry " ;
$this -> dbh -> query ( " DROP TABLE IF EXISTS test_items " );
$this -> dbh -> query ( " DROP TABLE IF EXISTS test_entries " );
2006-05-19 00:44:02 +04:00
parent :: prepareTables ();
}
2006-06-05 13:57:53 +04:00
public function testOneToOneSharedRelations () {
2006-06-03 13:10:43 +04:00
$status = new Log_Status ();
$status -> name = 'success' ;
$entries [ 0 ] = new Log_Entry ();
$entries [ 0 ] -> stamp = '2006-06-06' ;
$entries [ 0 ] -> Log_Status = $status ;
$this -> assertTrue ( $entries [ 0 ] -> Log_Status instanceof Log_Status );
$entries [ 1 ] = new Log_Entry ();
$entries [ 1 ] -> stamp = '2006-06-06' ;
$entries [ 1 ] -> Log_Status = $status ;
$this -> session -> flush ();
// clear the identity maps
$entries [ 0 ] -> Log_Status -> getTable () -> clear ();
$entries [ 0 ] -> getTable () -> clear ();
$entries = $this -> session -> query ( " FROM Log_Entry-I.Log_Status-i " );
$this -> assertEqual ( $entries -> count (), 2 );
$this -> assertTrue ( $entries [ 0 ] -> Log_Status instanceof Log_Status );
$this -> assertEqual ( $entries [ 0 ] -> Log_Status -> name , 'success' );
// the second Log_Status is fetched from identityMap
2006-06-05 13:57:53 +04:00
2006-06-03 13:10:43 +04:00
$this -> assertTrue ( $entries [ 1 ] -> Log_Status instanceof Log_Status );
$this -> assertEqual ( $entries [ 1 ] -> Log_Status -> name , 'success' );
// the following line is possible since doctrine uses identityMap
$this -> assertEqual ( $entries [ 0 ] -> Log_Status , $entries [ 1 ] -> Log_Status );
$entries [ 0 ] -> Log_Status -> delete ();
$this -> assertEqual ( $entries [ 0 ] -> Log_Status , $entries [ 1 ] -> Log_Status );
$this -> assertEqual ( $entries [ 0 ] -> Log_Status -> getState (), Doctrine_Record :: STATE_TCLEAN );
2006-06-07 00:37:56 +04:00
2006-06-03 13:10:43 +04:00
// clear the identity maps
$entries [ 0 ] -> Log_Status -> getTable () -> clear ();
$entries [ 0 ] -> getTable () -> clear ();
2006-06-07 00:37:56 +04:00
2006-06-03 13:10:43 +04:00
$entries = $this -> session -> query ( " FROM Log_Entry-I.Log_Status-i " );
$this -> assertEqual ( $entries -> count (), 2 );
2006-06-07 00:37:56 +04:00
$this -> assertTrue ( $entries [ 0 ] -> Log_Status instanceof Log_Status );
2006-06-03 13:10:43 +04:00
$this -> assertEqual ( $entries [ 0 ] -> Log_Status -> name , null );
$this -> assertEqual ( $entries [ 1 ] -> Log_Status -> name , null );
2006-06-07 00:37:56 +04:00
2006-06-03 13:10:43 +04:00
}
2006-06-07 00:37:56 +04:00
2006-06-03 13:10:43 +04:00
public function testOneToOneRelationFetchingWithCustomTableNames () {
$entry = new ORM_TestEntry ();
$entry -> name = 'entry 1' ;
$entry -> amount = '123.123' ;
$entry -> ORM_TestItem -> name = 'item 1' ;
$entry = new ORM_TestEntry ();
$entry -> name = 'entry 2' ;
$entry -> amount = '123.123' ;
$entry -> ORM_TestItem -> name = 'item 2' ;
$this -> session -> flush ();
$count = $this -> dbh -> count ();
$entries = $this -> session -> query ( " FROM ORM_TestEntry-i.ORM_TestItem-i " );
$this -> assertEqual ( $entries -> count (), 2 );
$this -> assertTrue ( $entries [ 0 ] instanceof ORM_TestEntry );
$this -> assertTrue ( $entries [ 0 ] -> getState (), Doctrine_Record :: STATE_CLEAN );
$this -> assertEqual ( $entries [ 0 ] -> name , 'entry 1' );
$this -> assertTrue ( $entries [ 1 ] instanceof ORM_TestEntry );
$this -> assertTrue ( $entries [ 1 ] -> getState (), Doctrine_Record :: STATE_CLEAN );
$this -> assertEqual ( $entries [ 1 ] -> name , 'entry 2' );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertTrue ( $entries [ 0 ] -> ORM_TestItem instanceof ORM_TestItem );
$this -> assertEqual ( $entries [ 0 ] -> ORM_TestItem -> getState (), Doctrine_Record :: STATE_CLEAN );
$this -> assertEqual ( $entries [ 0 ] -> ORM_TestItem -> name , 'item 1' );
$this -> assertTrue ( $entries [ 1 ] -> ORM_TestItem instanceof ORM_TestItem );
$this -> assertEqual ( $entries [ 1 ] -> ORM_TestItem -> getState (), Doctrine_Record :: STATE_CLEAN );
$this -> assertEqual ( $entries [ 1 ] -> ORM_TestItem -> name , 'item 2' );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
}
2006-05-31 12:46:44 +04:00
public function testImmediateFetching () {
$count = $this -> dbh -> count ();
$this -> session -> getTable ( 'User' ) -> clear ();
$this -> session -> getTable ( 'Email' ) -> clear ();
$this -> session -> getTable ( 'Phonenumber' ) -> clear ();
$users = $this -> query -> from ( " User-i.Email-i " ) -> execute ();
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( count ( $users ), 8 );
$this -> assertEqual ( get_class ( $users [ 0 ] -> Email ), 'Email' );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 0 ] -> Email -> address , 'zYne@example.com' );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
2006-06-01 15:58:05 +04:00
$this -> assertEqual ( get_class ( $users [ 1 ] -> Email ), 'Email' );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 1 ] -> Email -> address , 'arnold@example.com' );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
2006-05-31 12:46:44 +04:00
}
2006-05-31 02:14:50 +04:00
public function testLazyPropertyFetchingWithMultipleColumns () {
2006-05-29 12:43:21 +04:00
2006-05-31 02:14:50 +04:00
$q = new Doctrine_Query ( $this -> session );
$q -> from ( " User-l(name, email_id) " );
$users = $q -> execute ();
$this -> assertEqual ( $users -> count (), 8 );
$this -> assertTrue ( $users instanceof Doctrine_Collection_Lazy );
$count = count ( $this -> dbh );
$this -> assertTrue ( is_string ( $users [ 0 ] -> name ));
$this -> assertEqual ( $count , count ( $this -> dbh ));
$count = count ( $this -> dbh );
$this -> assertTrue ( is_numeric ( $users [ 0 ] -> email_id ));
$this -> assertEqual ( $count , count ( $this -> dbh ));
$users [ 0 ] -> getTable () -> clear ();
$q -> from ( " User-b(name, email_id) " );
$users = $q -> execute ();
$this -> assertEqual ( $users -> count (), 8 );
$this -> assertTrue ( $users instanceof Doctrine_Collection_Batch );
$count = count ( $this -> dbh );
$this -> assertTrue ( is_string ( $users [ 0 ] -> name ));
$this -> assertEqual ( $count , count ( $this -> dbh ));
$count = count ( $this -> dbh );
$this -> assertTrue ( is_numeric ( $users [ 0 ] -> email_id ));
$this -> assertEqual ( $count , count ( $this -> dbh ));
$this -> assertTrue ( is_numeric ( $users [ 1 ] -> email_id ));
$this -> assertEqual ( $count , count ( $this -> dbh ));
$this -> assertTrue ( is_numeric ( $users [ 2 ] -> email_id ));
$this -> assertEqual ( $count , count ( $this -> dbh ));
$q -> from ( " User-b(name, email_id):Email, User-b(name, email_id).Phonenumber " );
$users = $q -> execute ();
$this -> assertEqual ( $users -> count (), 8 );
$this -> assertTrue ( $users instanceof Doctrine_Collection_Batch );
$count = count ( $this -> dbh );
$this -> assertTrue ( is_string ( $users [ 0 ] -> name ));
$this -> assertEqual ( $count , count ( $this -> dbh ));
$count = count ( $this -> dbh );
$this -> assertTrue ( is_numeric ( $users [ 0 ] -> email_id ));
$this -> assertEqual ( $count , count ( $this -> dbh ));
$this -> assertTrue ( is_numeric ( $users [ 1 ] -> email_id ));
$this -> assertEqual ( $count , count ( $this -> dbh ));
$this -> assertTrue ( is_numeric ( $users [ 2 ] -> email_id ));
$this -> assertEqual ( $count , count ( $this -> dbh ));
}
2006-05-31 02:35:00 +04:00
2006-05-29 20:12:43 +04:00
public function testMultipleFetching () {
$count = $this -> dbh -> count ();
$this -> session -> getTable ( 'User' ) -> clear ();
$this -> session -> getTable ( 'Email' ) -> clear ();
$this -> session -> getTable ( 'Phonenumber' ) -> clear ();
$users = $this -> query -> from ( " User-l.Phonenumber-i, User-l:Email-i " ) -> execute ();
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( count ( $users ), 8 );
$this -> assertEqual ( $users [ 0 ] -> Phonenumber -> count (), 1 );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 0 ] -> Phonenumber [ 0 ] -> phonenumber , " 123 123 " );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 1 ] -> Phonenumber -> count (), 3 );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 1 ] -> Phonenumber [ 0 ] -> phonenumber , " 123 123 " );
$this -> assertEqual ( $users [ 1 ] -> Phonenumber [ 1 ] -> phonenumber , " 456 456 " );
$this -> assertEqual ( $users [ 1 ] -> Phonenumber [ 2 ] -> phonenumber , " 789 789 " );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 7 ] -> Phonenumber -> count (), 1 );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 7 ] -> Phonenumber [ 0 ] -> phonenumber , " 111 567 333 " );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertTrue ( $users [ 0 ] -> Email instanceof Email );
$this -> assertEqual ( $users [ 0 ] -> Email -> address , " zYne@example.com " );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 0 ] -> email_id , $users [ 0 ] -> Email -> id );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertTrue ( $users [ 1 ] -> Email instanceof Email );
$this -> assertEqual ( $users [ 1 ] -> Email -> address , " arnold@example.com " );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 1 ] -> email_id , $users [ 1 ] -> Email -> id );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
}
public function testForeignKeyRelationFetching () {
$count = $this -> dbh -> count ();
$users = $this -> query -> from ( " User-l.Phonenumber-i " ) -> execute ();
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( count ( $users ), 8 );
$this -> assertEqual ( $users [ 0 ] -> Phonenumber -> count (), 1 );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 0 ] -> Phonenumber [ 0 ] -> phonenumber , " 123 123 " );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 1 ] -> Phonenumber -> count (), 3 );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 1 ] -> Phonenumber [ 0 ] -> phonenumber , " 123 123 " );
$this -> assertEqual ( $users [ 1 ] -> Phonenumber [ 1 ] -> phonenumber , " 456 456 " );
$this -> assertEqual ( $users [ 1 ] -> Phonenumber [ 2 ] -> phonenumber , " 789 789 " );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 7 ] -> Phonenumber -> count (), 1 );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 7 ] -> Phonenumber [ 0 ] -> phonenumber , " 111 567 333 " );
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertEqual ( $users [ 0 ] -> name , " zYne " );
$this -> assertEqual (( $count + 2 ), $this -> dbh -> count ());
}
2006-05-29 12:43:21 +04:00
public function testOneToOneRelationFetching () {
$count = $this -> dbh -> count ();
$users = $this -> query -> from ( " User-l:Email-i " ) -> execute ();
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertTrue ( $users instanceof Doctrine_Collection_Lazy );
$count = $this -> dbh -> count ();
foreach ( $users as $user ) {
// iterate through users and test that no additional queries are needed
$user -> Email -> address ;
$this -> assertEqual ( $count , $this -> dbh -> count ());
}
$users [ 0 ] -> Account -> amount = 3000 ;
$this -> assertEqual ( $users [ 0 ] -> Account -> amount , 3000 );
$this -> assertTrue ( $users [ 0 ] -> Account instanceof Account );
$this -> assertEqual ( $users [ 0 ] -> id , $users [ 0 ] -> Account -> entity_id );
$users [ 0 ] -> Account -> save ();
$users [ 0 ] -> refresh ();
$this -> assertEqual ( $users [ 0 ] -> Account -> amount , 3000 );
$this -> assertTrue ( $users [ 0 ] -> Account instanceof Account );
$this -> assertEqual ( $users [ 0 ] -> id , $users [ 0 ] -> Account -> entity_id );
$this -> assertEqual ( $users [ 0 ] -> Account -> getState (), Doctrine_Record :: STATE_CLEAN );
$users [ 0 ] -> getTable () -> clear ();
$users [ 0 ] -> Account -> getTable () -> clear ();
$count = $this -> dbh -> count ();
$users = $this -> query -> from ( " User-l:Account-i " ) -> execute ();
$this -> assertEqual (( $count + 1 ), $this -> dbh -> count ());
$this -> assertTrue ( $users instanceof Doctrine_Collection_Lazy );
$this -> assertEqual ( $users -> count (), 1 );
$this -> assertEqual ( $users [ 0 ] -> Account -> amount , 3000 );
}
2006-05-27 00:15:27 +04:00
public function testNotValidLazyPropertyFetching () {
$q = new Doctrine_Query ( $this -> session );
$f = false ;
try {
$q -> from ( " User(name) " );
} catch ( Doctrine_Exception $e ) {
$f = true ;
}
$this -> assertTrue ( $f );
}
2006-05-31 02:14:50 +04:00
2006-05-27 00:15:27 +04:00
public function testValidLazyPropertyFetching () {
$q = new Doctrine_Query ( $this -> session );
$q -> from ( " User-l(name) " );
$users = $q -> execute ();
$this -> assertEqual ( $users -> count (), 8 );
$this -> assertTrue ( $users instanceof Doctrine_Collection_Lazy );
$count = count ( $this -> dbh );
$this -> assertTrue ( is_string ( $users [ 0 ] -> name ));
$this -> assertEqual ( $count , count ( $this -> dbh ));
$count = count ( $this -> dbh );
$this -> assertTrue ( is_numeric ( $users [ 0 ] -> email_id ));
$this -> assertEqual ( $count + 1 , count ( $this -> dbh ));
$users [ 0 ] -> getTable () -> clear ();
$q -> from ( " User-b(name) " );
$users = $q -> execute ();
$this -> assertEqual ( $users -> count (), 8 );
$this -> assertTrue ( $users instanceof Doctrine_Collection_Batch );
$count = count ( $this -> dbh );
$this -> assertTrue ( is_string ( $users [ 0 ] -> name ));
$this -> assertEqual ( $count , count ( $this -> dbh ));
$count = count ( $this -> dbh );
$this -> assertTrue ( is_numeric ( $users [ 0 ] -> email_id ));
$this -> assertEqual ( $count + 1 , count ( $this -> dbh ));
$this -> assertTrue ( is_numeric ( $users [ 1 ] -> email_id ));
$this -> assertEqual ( $count + 1 , count ( $this -> dbh ));
$this -> assertTrue ( is_numeric ( $users [ 2 ] -> email_id ));
$this -> assertEqual ( $count + 1 , count ( $this -> dbh ));
}
2006-05-19 00:44:02 +04:00
public function testQueryWithComplexAliases () {
2006-05-25 16:25:26 +04:00
$q = new Doctrine_Query ( $this -> session );
2006-05-19 14:22:15 +04:00
2006-05-19 00:44:02 +04:00
$board = new Forum_Board ();
$table = $board -> getTable ();
2006-05-19 14:22:15 +04:00
$fk = $table -> getForeignKey ( " Threads " );
$this -> assertEqual ( $table -> getComponentName (), " Forum_Board " );
$this -> assertTrue ( $fk instanceof Doctrine_ForeignKey );
$this -> assertEqual ( $fk -> getTable () -> getComponentName (), " Forum_Thread " );
2006-05-19 00:44:02 +04:00
$entry = new Forum_Entry ();
$this -> assertTrue ( $entry -> getTable () -> getForeignKey ( " Thread " ) instanceof Doctrine_LocalKey );
$board -> name = " Doctrine Forum " ;
$board -> Threads [ 0 ];
$board -> Category -> name = " General discussion " ;
$this -> assertEqual ( $board -> name , " Doctrine Forum " );
$this -> assertEqual ( $board -> Category -> name , " General discussion " );
$this -> assertEqual ( $board -> Category -> getState (), Doctrine_Record :: STATE_TDIRTY );
2006-05-19 14:22:15 +04:00
$this -> assertEqual ( $board -> Threads [ 0 ] -> getState (), Doctrine_Record :: STATE_TDIRTY );
2006-05-19 00:44:02 +04:00
$this -> assertTrue ( $board -> Threads [ 0 ] instanceof Forum_Thread );
2006-05-19 14:22:15 +04:00
$thread = $board -> Threads [ 0 ];
$thread -> Entries [ 0 ] -> topic = " My first topic " ;
2006-05-23 16:12:54 +04:00
$thread -> Entries [ 1 ] -> topic = " My second topic " ;
2006-05-19 14:22:15 +04:00
$this -> assertEqual ( $thread -> Entries [ 0 ] -> topic , " My first topic " );
$this -> assertEqual ( $thread -> Entries [ 0 ] -> getState (), Doctrine_Record :: STATE_TDIRTY );
$this -> assertTrue ( $thread -> Entries [ 0 ] instanceof Forum_Entry );
2006-05-19 00:44:02 +04:00
$this -> session -> flush ();
2006-05-25 16:25:26 +04:00
2006-05-19 00:44:02 +04:00
$board -> getTable () -> clear ();
2006-05-23 16:12:54 +04:00
2006-05-19 00:44:02 +04:00
$board = $board -> getTable () -> find ( $board -> getID ());
$this -> assertEqual ( $board -> Threads -> count (), 1 );
$this -> assertEqual ( $board -> name , " Doctrine Forum " );
$this -> assertEqual ( $board -> Category -> name , " General discussion " );
2006-05-19 14:22:15 +04:00
$this -> assertEqual ( $board -> Category -> getState (), Doctrine_Record :: STATE_CLEAN );
2006-05-19 00:44:02 +04:00
$this -> assertEqual ( $board -> Threads [ 0 ] -> getState (), Doctrine_Record :: STATE_CLEAN );
$this -> assertTrue ( $board -> Threads [ 0 ] instanceof Forum_Thread );
2006-05-19 14:22:15 +04:00
2006-05-23 16:12:54 +04:00
2006-05-19 14:22:15 +04:00
$q -> from ( " Forum_Board " );
$coll = $q -> execute ();
$this -> assertEqual ( $coll -> count (), 1 );
2006-05-25 16:25:26 +04:00
$table = $this -> session -> getTable ( " Forum_Board " ) -> setAttribute ( Doctrine :: ATTR_FETCHMODE , Doctrine :: FETCH_LAZY );
$table = $this -> session -> getTable ( " Forum_Thread " ) -> setAttribute ( Doctrine :: ATTR_FETCHMODE , Doctrine :: FETCH_LAZY );
$q -> from ( " Forum_Board.Threads " );
$this -> assertEqual ( $q -> getQuery (), " SELECT forum_board.id AS Forum_Board__id, forum_thread.id AS Forum_Thread__id FROM forum_board LEFT JOIN forum_thread ON forum_board.id = forum_thread.board_id " );
2006-05-19 14:22:15 +04:00
$coll = $q -> execute ();
$this -> assertEqual ( $coll -> count (), 1 );
2006-05-23 16:12:54 +04:00
2006-05-25 16:25:26 +04:00
$q -> from ( " Forum_Board-l.Threads-l " );
2006-05-23 16:12:54 +04:00
$this -> assertEqual ( $q -> getQuery (), " SELECT forum_board.id AS Forum_Board__id, forum_thread.id AS Forum_Thread__id FROM forum_board LEFT JOIN forum_thread ON forum_board.id = forum_thread.board_id " );
2006-05-25 16:25:26 +04:00
$q -> from ( " Forum_Board.Threads.Entries-l " );
2006-05-23 16:12:54 +04:00
$this -> assertEqual ( $q -> getQuery (), " SELECT forum_board.id AS Forum_Board__id, forum_thread.id AS Forum_Thread__id, forum_entry.id AS Forum_Entry__id FROM forum_board LEFT JOIN forum_thread ON forum_board.id = forum_thread.board_id LEFT JOIN forum_entry ON forum_thread.id = forum_entry.thread_id " );
$boards = $q -> execute ();
$this -> assertEqual ( $boards -> count (), 1 );
$count = count ( $this -> dbh );
$this -> assertEqual ( $boards [ 0 ] -> Threads -> count (), 1 );
$this -> assertEqual ( count ( $this -> dbh ), $count );
$this -> assertEqual ( $boards [ 0 ] -> Threads [ 0 ] -> Entries -> count (), 1 );
2006-05-25 16:32:57 +04:00
$q -> from ( " Forum_Board-l.Threads-l.Entries-i " );
$this -> assertEqual ( $boards -> count (), 1 );
$count = count ( $this -> dbh );
$this -> assertEqual ( $boards [ 0 ] -> Threads -> count (), 1 );
$this -> assertEqual ( count ( $this -> dbh ), $count );
$this -> assertEqual ( $boards [ 0 ] -> Threads [ 0 ] -> Entries -> count (), 1 );
2006-05-19 00:44:02 +04:00
}
2006-05-17 21:58:40 +04:00
public function testQueryWithAliases () {
2006-05-25 16:25:26 +04:00
$query = new Doctrine_Query ( $this -> session );
2006-05-17 21:58:40 +04:00
$task = new Task ();
$task -> name = " Task 1 " ;
$task -> ResourceAlias [ 0 ] -> name = " Resource 1 " ;
$task -> ResourceAlias [ 1 ] -> name = " Resource 2 " ;
$task -> save ();
2006-05-25 16:25:26 +04:00
2006-05-17 21:58:40 +04:00
$coll = $query -> query ( " FROM Task WHERE Task.ResourceAlias.name = 'Resource 1' " );
$this -> assertEqual ( $coll -> count (), 1 );
$this -> assertTrue ( $coll [ 0 ] instanceof Task );
}
2006-05-10 01:39:07 +04:00
public function testQueryArgs () {
$query = new Doctrine_Query ( $this -> session );
$query = $query -> from ( " User-l " );
$this -> assertTrue ( $query instanceof Doctrine_Query );
$this -> assertEqual ( $query -> get ( " from " ), array ( " entity " => true ));
$query = $query -> orderby ( " User.name " );
$this -> assertTrue ( $query instanceof Doctrine_Query );
$this -> assertEqual ( $query -> get ( " orderby " ), array ( " entity.name " ));
$query = $query -> orderby ( " User.created " );
$this -> assertTrue ( $query instanceof Doctrine_Query );
$this -> assertEqual ( $query -> get ( " orderby " ), array ( " entity.created " ));
$query = $query -> where ( " User.name LIKE 'zYne%' " );
$this -> assertTrue ( $query instanceof Doctrine_Query );
$this -> assertEqual ( $query -> get ( " where " ), array ( " entity.name LIKE 'zYne%' " ));
$query = $query -> where ( " User.name LIKE 'Arnold%' " );
$this -> assertTrue ( $query instanceof Doctrine_Query );
$this -> assertEqual ( $query -> get ( " where " ), array ( " entity.name LIKE 'Arnold%' " ));
$query = $query -> limit ( 5 );
$this -> assertTrue ( $query instanceof Doctrine_Query );
$this -> assertEqual ( $query -> get ( " limit " ), 5 );
$query = $query -> offset ( 5 );
$this -> assertTrue ( $query instanceof Doctrine_Query );
$this -> assertEqual ( $query -> get ( " offset " ), 5 );
$query -> offset = 7 ;
$this -> assertEqual ( $query -> get ( " offset " ), 7 );
$query -> limit = 10 ;
$this -> assertEqual ( $query -> limit , 10 );
$this -> assertTrue ( strpos ( $query -> getQuery (), " LIMIT " ));
$query -> limit = null ;
$this -> assertFalse ( strpos ( $query -> getQuery (), " LIMIT " ));
$coll = $query -> execute ();
$this -> assertTrue ( $coll instanceof Doctrine_Collection_Lazy );
$this -> assertEqual ( $coll -> count (), 1 );
$query -> where ( " User.name LIKE ? " ) -> limit ( 3 );
$this -> assertEqual ( $query -> limit , 3 );
$this -> assertTrue ( strpos ( $query -> getQuery (), " LIMIT " ));
}
public function testLimit () {
$query = new Doctrine_Query ( $this -> session );
$coll = $query -> query ( " FROM User LIMIT 3 " );
$this -> assertEqual ( $query -> limit , 3 );
$this -> assertEqual ( $coll -> count (), 3 );
}
public function testOffset () {
$query = new Doctrine_Query ( $this -> session );
$coll = $query -> query ( " FROM User LIMIT 3 OFFSET 3 " );
$this -> assertEqual ( $query -> offset , 3 );
$this -> assertEqual ( $coll -> count (), 3 );
}
2006-05-29 12:43:21 +04:00
public function testPreparedQuery () {
2006-05-10 01:39:07 +04:00
$coll = $this -> session -> query ( " FROM User WHERE User.name = :name " , array ( " :name " => " zYne " ));
$this -> assertEqual ( $coll -> count (), 1 );
}
public function testOrderBy () {
$query = new Doctrine_Query ( $this -> session );
2006-05-23 16:12:54 +04:00
$query -> from ( " User-b " ) -> orderby ( " User.name ASC, User.Email.address " );
$users = $query -> execute ();
2006-05-25 16:25:26 +04:00
2006-05-10 01:39:07 +04:00
$this -> assertEqual ( trim ( $query -> getQuery ()),
2006-05-24 13:27:38 +04:00
" SELECT entity.id AS User__id FROM entity LEFT JOIN email ON entity.email_id = email.id WHERE (entity.type = 0) ORDER BY entity.name ASC, email.address " );
2006-05-10 01:39:07 +04:00
$this -> assertEqual ( $users -> count (), 8 );
$this -> assertTrue ( $users [ 0 ] -> name == " Arnold Schwarzenegger " );
}
2006-05-29 12:43:21 +04:00
public function testBatchFetching () {
$query = new Doctrine_Query ( $this -> session );
$users = $query -> query ( " FROM User-b " );
$this -> assertEqual ( trim ( $query -> getQuery ()),
" SELECT entity.id AS User__id FROM entity WHERE (entity.type = 0) " );
$this -> assertEqual ( $users [ 0 ] -> name , " zYne " );
$this -> assertTrue ( $users instanceof Doctrine_Collection_Batch );
}
public function testLazyFetching () {
$query = new Doctrine_Query ( $this -> session );
$users = $query -> query ( " FROM User-l " );
$this -> assertEqual ( trim ( $query -> getQuery ()),
" SELECT entity.id AS User__id FROM entity WHERE (entity.type = 0) " );
$this -> assertEqual ( $users [ 0 ] -> name , " zYne " );
$this -> assertTrue ( $users instanceof Doctrine_Collection_Lazy );
}
2006-05-17 21:58:40 +04:00
2006-05-10 01:39:07 +04:00
public function testQuery () {
2006-05-17 21:58:40 +04:00
2006-05-10 01:39:07 +04:00
$query = new Doctrine_Query ( $this -> session );
$this -> graph = $query ;
$user = $this -> objTable -> find ( 5 );
$album = $this -> session -> create ( " Album " );
$album -> Song [ 0 ];
$user -> Album [ 0 ] -> name = " Damage Done " ;
$user -> Album [ 1 ] -> name = " Haven " ;
$user -> Album [ 0 ] -> Song [ 0 ] -> title = " Damage Done " ;
$user -> Album [ 0 ] -> Song [ 1 ] -> title = " The Treason Wall " ;
$user -> Album [ 0 ] -> Song [ 2 ] -> title = " Monochromatic Stains " ;
$this -> assertEqual ( count ( $user -> Album [ 0 ] -> Song ), 3 );
$user -> Album [ 1 ] -> Song [ 0 ] -> title = " Not Built To Last " ;
$user -> Album [ 1 ] -> Song [ 1 ] -> title = " The Wonders At Your Feet " ;
$user -> Album [ 1 ] -> Song [ 2 ] -> title = " Feast Of Burden " ;
$user -> Album [ 1 ] -> Song [ 3 ] -> title = " Fabric " ;
$this -> assertEqual ( count ( $user -> Album [ 1 ] -> Song ), 4 );
$user -> save ();
$user = $this -> objTable -> find ( 5 );
$this -> assertEqual ( count ( $user -> Album [ 0 ] -> Song ), 3 );
$this -> assertEqual ( count ( $user -> Album [ 1 ] -> Song ), 4 );
$users = $query -> query ( " FROM User WHERE User.Album.name like '%Damage%' " );
// DYNAMIC COLLECTION EXPANDING
$user = $this -> objTable -> find ( 5 );
$user -> Group [ 1 ] -> name = " Tough guys inc. " ;
$user -> Group [ 2 ] -> name = " Terminators " ;
$this -> assertEqual ( $user -> Group [ 0 ] -> name , " Action Actors " );
$user -> save ();
$this -> assertEqual ( $user -> Group [ 0 ] -> name , " Action Actors " );
$this -> assertEqual ( count ( $user -> Group ), 3 );
$user = $this -> objTable -> find ( 5 );
$this -> assertEqual ( count ( $user -> Group ), 3 );
//$users = $query->query("FROM User, User.Group WHERE User.Group.name LIKE 'Action Actors'");
//$this->assertEqual(count($users),1);
//$this->assertEqual($users[0]->Group[0]->name, "Action Actors");
//$this->assertEqual(count($users[0]->Group), 1);
//$this->assertEqual($users[0]->Group[1]->name, "Tough guys inc.");
//$this->assertEqual($users[0]->Group[2]->name, "Terminators");
//$this->assertEqual(count($users[0]->Group), 3);
2006-05-29 20:12:43 +04:00
$this -> session -> getTable ( " User " ) -> clear ();
$this -> session -> getTable ( " Phonenumber " ) -> clear ();
2006-05-10 01:39:07 +04:00
2006-05-25 16:25:26 +04:00
$users = $query -> query ( " FROM User-b.Phonenumber-l WHERE User.Phonenumber.phonenumber LIKE '%123%' " );
2006-05-10 01:39:07 +04:00
$this -> assertEqual ( trim ( $query -> getQuery ()),
" SELECT entity.id AS User__id, phonenumber.id AS Phonenumber__id FROM entity LEFT JOIN phonenumber ON entity.id = phonenumber.entity_id WHERE (phonenumber.phonenumber LIKE '%123%') AND (entity.type = 0) " );
$count = $this -> session -> getDBH () -> count ();
$users [ 1 ] -> Phonenumber [ 0 ] -> phonenumber ;
$users [ 1 ] -> Phonenumber [ 1 ] -> phonenumber ;
$this -> assertEqual ( $users [ 1 ] -> Phonenumber [ 1 ] -> getState (), Doctrine_Record :: STATE_CLEAN );
$users [ 1 ] -> Phonenumber [ 2 ] -> phonenumber ;
$this -> assertEqual ( $users [ 1 ] -> Phonenumber [ 1 ] -> getState (), Doctrine_Record :: STATE_CLEAN );
$count2 = $this -> session -> getDBH () -> count ();
$this -> assertEqual ( $count + 4 , $count2 );
// DYNAMIC FETCHMODES
$e = false ;
try {
$users = $query -> query ( " FROM User-unknown " );
} catch ( Exception $e ) {
}
$this -> assertTrue ( $e instanceof DQLException );
$users = $query -> query ( " FROM User-i " );
$this -> assertEqual ( trim ( $query -> getQuery ()),
" SELECT entity.id AS User__id, entity.name AS User__name, entity.loginname AS User__loginname, entity.password AS User__password, entity.type AS User__type, entity.created AS User__created, entity.updated AS User__updated, entity.email_id AS User__email_id FROM entity WHERE (entity.type = 0) " );
$count = $this -> session -> getDBH () -> count ();
$this -> assertEqual ( $users [ 0 ] -> name , " zYne " );
$this -> assertTrue ( $users instanceof Doctrine_Collection_Immediate );
$count2 = $this -> session -> getDBH () -> count ();
//$this->clearCache();
2006-05-25 16:25:26 +04:00
$users = $query -> query ( " FROM User-b.Phonenumber-b " );
2006-05-10 01:39:07 +04:00
$this -> assertEqual ( trim ( $query -> getQuery ()),
" SELECT entity.id AS User__id, phonenumber.id AS Phonenumber__id FROM entity LEFT JOIN phonenumber ON entity.id = phonenumber.entity_id WHERE (entity.type = 0) " );
$this -> assertEqual ( $users -> count (), 8 );
// EXPECTED THAT ONE NEW QUERY IS NEEDED TO GET THE FIRST USER's PHONENUMBER
$count = $this -> session -> getDBH () -> count ();
$users [ 0 ] -> Phonenumber [ 0 ] -> phonenumber ;
$count2 = $this -> session -> getDBH () -> count ();
$this -> assertEqual ( $count + 1 , $count2 );
2006-05-25 16:25:26 +04:00
$users = $query -> query ( " FROM User-l:Email-b " );
2006-05-10 01:39:07 +04:00
$this -> assertEqual ( trim ( $query -> getQuery ()),
2006-05-23 16:12:54 +04:00
" SELECT entity.id AS User__id, email.id AS Email__id FROM entity INNER JOIN email ON entity.email_id = email.id WHERE (entity.type = 0) " );
2006-05-10 01:39:07 +04:00
$this -> assertEqual ( $users -> count (), 8 );
$users = $query -> query ( " FROM Email-b WHERE Email.address LIKE '%@example%' " );
2006-05-23 16:12:54 +04:00
2006-05-10 01:39:07 +04:00
$this -> assertEqual ( $query -> getQuery (),
" SELECT email.id AS Email__id FROM email WHERE (email.address LIKE '%@example%') " );
$this -> assertEqual ( $users -> count (), 8 );
$users = $query -> query ( " FROM User-b WHERE User.name LIKE '%Jack%' " );
$this -> assertEqual ( $query -> getQuery (), " SELECT entity.id AS User__id FROM entity WHERE (entity.name LIKE '%Jack%') AND (entity.type = 0) " );
$this -> assertEqual ( $users -> count (), 0 );
$users = $query -> query ( " FROM User-b WHERE User.Phonenumber.phonenumber REGEXP '[123]' " );
$this -> assertEqual ( trim ( $query -> getQuery ()),
" SELECT entity.id AS User__id FROM entity LEFT JOIN phonenumber ON entity.id = phonenumber.entity_id WHERE (phonenumber.phonenumber REGEXP '[123]') AND (entity.type = 0) " );
$this -> assertEqual ( $users -> count (), 8 );
$users = $query -> query ( " FROM User-b WHERE User.Group.name = 'Action Actors' " );
$this -> assertEqual ( trim ( $query -> getQuery ()),
" SELECT entity.id AS User__id FROM entity WHERE (entity.id IN (SELECT user_id FROM groupuser WHERE group_id IN (SELECT entity.id AS Group__id FROM entity WHERE (entity.name = 'Action Actors') AND (entity.type = 1)))) AND (entity.type = 0) " );
$this -> assertTrue ( $users instanceof Doctrine_Collection );
$this -> assertEqual ( $users -> count (), 1 );
$users = $query -> query ( " FROM User-b WHERE User.Group.Phonenumber.phonenumber LIKE '123 123' " );
$this -> assertEqual ( trim ( $query -> getQuery ()),
" SELECT entity.id AS User__id FROM entity WHERE (entity.id IN (SELECT user_id FROM groupuser WHERE group_id IN (SELECT entity.id AS Group__id FROM entity, phonenumber WHERE (phonenumber.phonenumber LIKE '123 123') AND (entity.type = 1)))) AND (entity.type = 0) " );
$this -> assertTrue ( $users instanceof Doctrine_Collection );
$this -> assertEqual ( $users -> count (), 1 );
2006-05-27 00:15:27 +04:00
//$values = $query->query("SELECT COUNT(User.name) AS users, MAX(User.name) AS max FROM User");
//$this->assertEqual(trim($query->getQuery()),"SELECT COUNT(entity.name) AS users, MAX(entity.name) AS max FROM entity WHERE (entity.type = 0)");
//$this->assertTrue(is_array($values));
//$this->assertTrue(isset($values['users']));
//$this->assertTrue(isset($values['max']));
2006-05-25 16:25:26 +04:00
}
2006-06-07 00:37:56 +04:00
2006-05-10 01:39:07 +04:00
}
?>