2009-04-12 23:02:12 +04:00
< ? php
namespace Doctrine\Tests\ORM\Functional ;
2012-05-28 20:16:42 +04:00
use Doctrine\Common\Collections\ArrayCollection ;
2009-04-12 23:02:12 +04:00
use Doctrine\ORM\Query\ResultSetMapping ;
2011-03-30 18:27:31 +04:00
use Doctrine\ORM\Query\ResultSetMappingBuilder ;
2012-05-28 20:16:42 +04:00
use Doctrine\ORM\Query\Parameter ;
2009-04-12 23:02:12 +04:00
use Doctrine\Tests\Models\CMS\CmsUser ;
2009-08-15 22:11:51 +04:00
use Doctrine\Tests\Models\CMS\CmsPhonenumber ;
2009-10-22 13:10:59 +04:00
use Doctrine\Tests\Models\CMS\CmsAddress ;
2012-02-28 04:16:35 +04:00
use Doctrine\Tests\Models\CMS\CmsEmail ;
2012-03-11 19:10:15 +04:00
use Doctrine\Tests\Models\CMS\CmsArticle ;
2011-04-15 04:55:03 +04:00
use Doctrine\Tests\Models\Company\CompanyFixContract ;
use Doctrine\Tests\Models\Company\CompanyEmployee ;
2012-02-29 06:17:29 +04:00
use Doctrine\Tests\Models\Company\CompanyPerson ;
2009-04-12 23:02:12 +04:00
/**
* NativeQueryTest
*
* @ author robo
*/
class NativeQueryTest extends \Doctrine\Tests\OrmFunctionalTestCase
{
2010-04-18 21:12:38 +04:00
private $platform = null ;
2009-04-12 23:02:12 +04:00
protected function setUp () {
$this -> useModelSet ( 'cms' );
2012-02-29 06:17:29 +04:00
$this -> useModelSet ( 'company' );
2009-04-12 23:02:12 +04:00
parent :: setUp ();
2010-04-18 21:12:38 +04:00
$this -> platform = $this -> _em -> getConnection () -> getDatabasePlatform ();
2009-04-12 23:02:12 +04:00
}
public function testBasicNativeQuery ()
{
$user = new CmsUser ;
$user -> name = 'Roman' ;
$user -> username = 'romanb' ;
$user -> status = 'dev' ;
2009-07-19 20:54:53 +04:00
$this -> _em -> persist ( $user );
2009-04-12 23:02:12 +04:00
$this -> _em -> flush ();
2011-10-29 22:42:44 +04:00
2009-08-15 22:11:51 +04:00
$this -> _em -> clear ();
2009-04-12 23:02:12 +04:00
$rsm = new ResultSetMapping ;
2009-05-21 23:18:14 +04:00
$rsm -> addEntityResult ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
2010-04-18 21:12:38 +04:00
$rsm -> addFieldResult ( 'u' , $this -> platform -> getSQLResultCasing ( 'id' ), 'id' );
$rsm -> addFieldResult ( 'u' , $this -> platform -> getSQLResultCasing ( 'name' ), 'name' );
2009-04-12 23:02:12 +04:00
$query = $this -> _em -> createNativeQuery ( 'SELECT id, name FROM cms_users WHERE username = ?' , $rsm );
$query -> setParameter ( 1 , 'romanb' );
2009-08-03 21:18:37 +04:00
$users = $query -> getResult ();
2009-04-12 23:02:12 +04:00
$this -> assertEquals ( 1 , count ( $users ));
2011-07-26 17:22:57 +04:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $users [ 0 ]);
2009-04-12 23:02:12 +04:00
$this -> assertEquals ( 'Roman' , $users [ 0 ] -> name );
}
2011-07-27 01:35:06 +04:00
public function testBasicNativeQueryWithMetaResult ()
{
$user = new CmsUser ;
$user -> name = 'Roman' ;
$user -> username = 'romanb' ;
$user -> status = 'dev' ;
$addr = new CmsAddress ;
$addr -> country = 'germany' ;
$addr -> zip = 10827 ;
$addr -> city = 'Berlin' ;
$user -> setAddress ( $addr );
$this -> _em -> persist ( $user );
$this -> _em -> flush ();
$this -> _em -> clear ();
$rsm = new ResultSetMapping ;
$rsm -> addEntityResult ( 'Doctrine\Tests\Models\CMS\CmsAddress' , 'a' );
$rsm -> addFieldResult ( 'a' , $this -> platform -> getSQLResultCasing ( 'id' ), 'id' );
$rsm -> addFieldResult ( 'a' , $this -> platform -> getSQLResultCasing ( 'country' ), 'country' );
$rsm -> addFieldResult ( 'a' , $this -> platform -> getSQLResultCasing ( 'zip' ), 'zip' );
$rsm -> addFieldResult ( 'a' , $this -> platform -> getSQLResultCasing ( 'city' ), 'city' );
$rsm -> addMetaResult ( 'a' , $this -> platform -> getSQLResultCasing ( 'user_id' ), 'user_id' );
$query = $this -> _em -> createNativeQuery ( 'SELECT a.id, a.country, a.zip, a.city, a.user_id FROM cms_addresses a WHERE a.id = ?' , $rsm );
$query -> setParameter ( 1 , $addr -> id );
$addresses = $query -> getResult ();
$this -> assertEquals ( 1 , count ( $addresses ));
$this -> assertTrue ( $addresses [ 0 ] instanceof CmsAddress );
$this -> assertEquals ( $addr -> country , $addresses [ 0 ] -> country );
$this -> assertEquals ( $addr -> zip , $addresses [ 0 ] -> zip );
$this -> assertEquals ( $addr -> city , $addresses [ 0 ] -> city );
$this -> assertEquals ( $addr -> street , $addresses [ 0 ] -> street );
$this -> assertTrue ( $addresses [ 0 ] -> user instanceof CmsUser );
}
2011-10-29 22:42:44 +04:00
2009-10-22 13:10:59 +04:00
public function testJoinedOneToManyNativeQuery ()
2009-08-15 22:11:51 +04:00
{
$user = new CmsUser ;
$user -> name = 'Roman' ;
$user -> username = 'romanb' ;
$user -> status = 'dev' ;
2011-10-29 22:42:44 +04:00
2009-08-15 22:11:51 +04:00
$phone = new CmsPhonenumber ;
$phone -> phonenumber = 424242 ;
2011-10-29 22:42:44 +04:00
2009-08-15 22:11:51 +04:00
$user -> addPhonenumber ( $phone );
2011-10-29 22:42:44 +04:00
2009-08-15 22:11:51 +04:00
$this -> _em -> persist ( $user );
$this -> _em -> flush ();
2011-10-29 22:42:44 +04:00
2009-08-15 22:11:51 +04:00
$this -> _em -> clear ();
2011-10-29 22:42:44 +04:00
2009-08-15 22:11:51 +04:00
$rsm = new ResultSetMapping ;
$rsm -> addEntityResult ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
2010-04-18 21:12:38 +04:00
$rsm -> addFieldResult ( 'u' , $this -> platform -> getSQLResultCasing ( 'id' ), 'id' );
$rsm -> addFieldResult ( 'u' , $this -> platform -> getSQLResultCasing ( 'name' ), 'name' );
$rsm -> addFieldResult ( 'u' , $this -> platform -> getSQLResultCasing ( 'status' ), 'status' );
2009-08-15 22:11:51 +04:00
$rsm -> addJoinedEntityResult ( 'Doctrine\Tests\Models\CMS\CmsPhonenumber' , 'p' , 'u' , 'phonenumbers' );
2010-04-18 21:12:38 +04:00
$rsm -> addFieldResult ( 'p' , $this -> platform -> getSQLResultCasing ( 'phonenumber' ), 'phonenumber' );
2011-10-29 22:42:44 +04:00
2009-08-15 22:11:51 +04:00
$query = $this -> _em -> createNativeQuery ( 'SELECT id, name, status, phonenumber FROM cms_users INNER JOIN cms_phonenumbers ON id = user_id WHERE username = ?' , $rsm );
$query -> setParameter ( 1 , 'romanb' );
$users = $query -> getResult ();
$this -> assertEquals ( 1 , count ( $users ));
2011-07-26 17:22:57 +04:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $users [ 0 ]);
2009-08-15 22:11:51 +04:00
$this -> assertEquals ( 'Roman' , $users [ 0 ] -> name );
2011-07-26 17:22:57 +04:00
$this -> assertInstanceOf ( 'Doctrine\ORM\PersistentCollection' , $users [ 0 ] -> getPhonenumbers ());
2009-10-22 13:10:59 +04:00
$this -> assertTrue ( $users [ 0 ] -> getPhonenumbers () -> isInitialized ());
2009-08-15 22:11:51 +04:00
$this -> assertEquals ( 1 , count ( $users [ 0 ] -> getPhonenumbers ()));
$phones = $users [ 0 ] -> getPhonenumbers ();
$this -> assertEquals ( 424242 , $phones [ 0 ] -> phonenumber );
$this -> assertTrue ( $phones [ 0 ] -> getUser () === $users [ 0 ]);
2011-10-29 22:42:44 +04:00
2009-08-15 22:11:51 +04:00
}
2011-10-29 22:42:44 +04:00
2009-10-22 13:10:59 +04:00
public function testJoinedOneToOneNativeQuery ()
{
$user = new CmsUser ;
$user -> name = 'Roman' ;
$user -> username = 'romanb' ;
$user -> status = 'dev' ;
2011-10-29 22:42:44 +04:00
2009-10-22 13:10:59 +04:00
$addr = new CmsAddress ;
$addr -> country = 'germany' ;
$addr -> zip = 10827 ;
$addr -> city = 'Berlin' ;
2011-10-29 22:42:44 +04:00
2009-10-22 13:10:59 +04:00
$user -> setAddress ( $addr );
2011-10-29 22:42:44 +04:00
2009-10-22 13:10:59 +04:00
$this -> _em -> persist ( $user );
$this -> _em -> flush ();
2011-10-29 22:42:44 +04:00
2009-10-22 13:10:59 +04:00
$this -> _em -> clear ();
2011-10-29 22:42:44 +04:00
2009-10-22 13:10:59 +04:00
$rsm = new ResultSetMapping ;
$rsm -> addEntityResult ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
2010-04-18 21:12:38 +04:00
$rsm -> addFieldResult ( 'u' , $this -> platform -> getSQLResultCasing ( 'id' ), 'id' );
$rsm -> addFieldResult ( 'u' , $this -> platform -> getSQLResultCasing ( 'name' ), 'name' );
$rsm -> addFieldResult ( 'u' , $this -> platform -> getSQLResultCasing ( 'status' ), 'status' );
2009-10-22 13:10:59 +04:00
$rsm -> addJoinedEntityResult ( 'Doctrine\Tests\Models\CMS\CmsAddress' , 'a' , 'u' , 'address' );
2010-04-18 21:12:38 +04:00
$rsm -> addFieldResult ( 'a' , $this -> platform -> getSQLResultCasing ( 'a_id' ), 'id' );
$rsm -> addFieldResult ( 'a' , $this -> platform -> getSQLResultCasing ( 'country' ), 'country' );
$rsm -> addFieldResult ( 'a' , $this -> platform -> getSQLResultCasing ( 'zip' ), 'zip' );
$rsm -> addFieldResult ( 'a' , $this -> platform -> getSQLResultCasing ( 'city' ), 'city' );
2011-10-29 22:42:44 +04:00
2009-10-22 13:10:59 +04:00
$query = $this -> _em -> createNativeQuery ( 'SELECT u.id, u.name, u.status, a.id AS a_id, a.country, a.zip, a.city FROM cms_users u INNER JOIN cms_addresses a ON u.id = a.user_id WHERE u.username = ?' , $rsm );
$query -> setParameter ( 1 , 'romanb' );
2011-10-29 22:42:44 +04:00
2009-10-22 13:10:59 +04:00
$users = $query -> getResult ();
2011-10-29 22:42:44 +04:00
2009-10-22 13:10:59 +04:00
$this -> assertEquals ( 1 , count ( $users ));
2011-07-26 17:22:57 +04:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $users [ 0 ]);
2009-10-22 13:10:59 +04:00
$this -> assertEquals ( 'Roman' , $users [ 0 ] -> name );
2011-07-26 17:22:57 +04:00
$this -> assertInstanceOf ( 'Doctrine\ORM\PersistentCollection' , $users [ 0 ] -> getPhonenumbers ());
2009-10-22 13:10:59 +04:00
$this -> assertFalse ( $users [ 0 ] -> getPhonenumbers () -> isInitialized ());
2011-07-26 17:22:57 +04:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsAddress' , $users [ 0 ] -> getAddress ());
2009-10-22 13:10:59 +04:00
$this -> assertTrue ( $users [ 0 ] -> getAddress () -> getUser () == $users [ 0 ]);
$this -> assertEquals ( 'germany' , $users [ 0 ] -> getAddress () -> getCountry ());
$this -> assertEquals ( 10827 , $users [ 0 ] -> getAddress () -> getZipCode ());
$this -> assertEquals ( 'Berlin' , $users [ 0 ] -> getAddress () -> getCity ());
}
2009-11-21 16:13:19 +03:00
public function testFluentInterface ()
{
2012-05-28 20:16:42 +04:00
$parameters = new ArrayCollection ;
$parameters -> add ( new Parameter ( 1 , 'foo' ));
$parameters -> add ( new Parameter ( 2 , 'bar' ));
2009-11-21 16:13:19 +03:00
$rsm = new ResultSetMapping ;
$q = $this -> _em -> createNativeQuery ( 'SELECT id, name, status, phonenumber FROM cms_users INNER JOIN cms_phonenumbers ON id = user_id WHERE username = ?' , $rsm );
$q2 = $q -> setSql ( 'foo' , $rsm )
-> setResultSetMapping ( $rsm )
-> expireResultCache ( true )
-> setHint ( 'foo' , 'bar' )
-> setParameter ( 1 , 'foo' )
2012-05-28 20:16:42 +04:00
-> setParameters ( $parameters )
2009-11-21 16:13:19 +03:00
-> setResultCacheDriver ( null )
-> setResultCacheLifetime ( 3500 );
$this -> assertSame ( $q , $q2 );
}
2011-03-30 04:35:01 +04:00
2011-03-30 18:27:31 +04:00
public function testJoinedOneToManyNativeQueryWithRSMBuilder ()
2011-03-30 04:35:01 +04:00
{
$user = new CmsUser ;
$user -> name = 'Roman' ;
$user -> username = 'romanb' ;
$user -> status = 'dev' ;
$phone = new CmsPhonenumber ;
$phone -> phonenumber = 424242 ;
$user -> addPhonenumber ( $phone );
$this -> _em -> persist ( $user );
$this -> _em -> flush ();
$this -> _em -> clear ();
2011-03-30 18:27:31 +04:00
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
2011-04-15 04:55:03 +04:00
$rsm -> addJoinedEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsPhonenumber' , 'p' , 'u' , 'phonenumbers' );
$query = $this -> _em -> createNativeQuery ( 'SELECT u.*, p.* FROM cms_users u LEFT JOIN cms_phonenumbers p ON u.id = p.user_id WHERE username = ?' , $rsm );
2011-03-30 04:35:01 +04:00
$query -> setParameter ( 1 , 'romanb' );
$users = $query -> getResult ();
$this -> assertEquals ( 1 , count ( $users ));
2011-07-26 17:22:57 +04:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $users [ 0 ]);
2011-03-30 04:35:01 +04:00
$this -> assertEquals ( 'Roman' , $users [ 0 ] -> name );
2011-07-26 17:22:57 +04:00
$this -> assertInstanceOf ( 'Doctrine\ORM\PersistentCollection' , $users [ 0 ] -> getPhonenumbers ());
2011-03-30 04:35:01 +04:00
$this -> assertTrue ( $users [ 0 ] -> getPhonenumbers () -> isInitialized ());
$this -> assertEquals ( 1 , count ( $users [ 0 ] -> getPhonenumbers ()));
$phones = $users [ 0 ] -> getPhonenumbers ();
$this -> assertEquals ( 424242 , $phones [ 0 ] -> phonenumber );
$this -> assertTrue ( $phones [ 0 ] -> getUser () === $users [ 0 ]);
2011-07-27 01:35:06 +04:00
$this -> _em -> clear ();
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsPhonenumber' , 'p' );
$query = $this -> _em -> createNativeQuery ( 'SELECT p.* FROM cms_phonenumbers p WHERE p.phonenumber = ?' , $rsm );
$query -> setParameter ( 1 , $phone -> phonenumber );
$phone = $query -> getSingleResult ();
$this -> assertNotNull ( $phone -> getUser ());
$this -> assertEquals ( $user -> name , $phone -> getUser () -> getName ());
2011-03-30 04:35:01 +04:00
}
2011-03-30 18:27:31 +04:00
public function testJoinedOneToOneNativeQueryWithRSMBuilder ()
2011-03-30 04:35:01 +04:00
{
$user = new CmsUser ;
$user -> name = 'Roman' ;
$user -> username = 'romanb' ;
$user -> status = 'dev' ;
$addr = new CmsAddress ;
$addr -> country = 'germany' ;
$addr -> zip = 10827 ;
$addr -> city = 'Berlin' ;
$user -> setAddress ( $addr );
$this -> _em -> persist ( $user );
$this -> _em -> flush ();
$this -> _em -> clear ();
2011-03-30 18:27:31 +04:00
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
2011-04-15 04:55:03 +04:00
$rsm -> addJoinedEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsAddress' , 'a' , 'u' , 'address' , array ( 'id' => 'a_id' ));
2011-03-30 04:35:01 +04:00
2011-04-15 04:55:03 +04:00
$query = $this -> _em -> createNativeQuery ( 'SELECT u.*, a.*, a.id AS a_id FROM cms_users u INNER JOIN cms_addresses a ON u.id = a.user_id WHERE u.username = ?' , $rsm );
2011-03-30 04:35:01 +04:00
$query -> setParameter ( 1 , 'romanb' );
$users = $query -> getResult ();
$this -> assertEquals ( 1 , count ( $users ));
2011-07-26 17:22:57 +04:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $users [ 0 ]);
2011-03-30 04:35:01 +04:00
$this -> assertEquals ( 'Roman' , $users [ 0 ] -> name );
2011-07-26 17:22:57 +04:00
$this -> assertInstanceOf ( 'Doctrine\ORM\PersistentCollection' , $users [ 0 ] -> getPhonenumbers ());
2011-03-30 04:35:01 +04:00
$this -> assertFalse ( $users [ 0 ] -> getPhonenumbers () -> isInitialized ());
2011-07-26 17:22:57 +04:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsAddress' , $users [ 0 ] -> getAddress ());
2011-03-30 04:35:01 +04:00
$this -> assertTrue ( $users [ 0 ] -> getAddress () -> getUser () == $users [ 0 ]);
$this -> assertEquals ( 'germany' , $users [ 0 ] -> getAddress () -> getCountry ());
$this -> assertEquals ( 10827 , $users [ 0 ] -> getAddress () -> getZipCode ());
$this -> assertEquals ( 'Berlin' , $users [ 0 ] -> getAddress () -> getCity ());
2011-07-27 01:35:06 +04:00
$this -> _em -> clear ();
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsAddress' , 'a' );
$query = $this -> _em -> createNativeQuery ( 'SELECT a.* FROM cms_addresses a WHERE a.id = ?' , $rsm );
$query -> setParameter ( 1 , $addr -> getId ());
$address = $query -> getSingleResult ();
$this -> assertNotNull ( $address -> getUser ());
$this -> assertEquals ( $user -> name , $address -> getUser () -> getName ());
2011-03-30 04:35:01 +04:00
}
2011-04-15 04:55:03 +04:00
2014-01-04 21:06:16 +04:00
/**
* @ group rsm - sti
*/
public function testConcreteClassInSingleTableInheritanceSchemaWithRSMBuilderIsFine ()
{
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\Company\CompanyFixContract' , 'c' );
}
/**
* @ group rsm - sti
*/
public function testAbstractClassInSingleTableInheritanceSchemaWithRSMBuilderThrowsException ()
{
$this -> setExpectedException ( '\InvalidArgumentException' , 'ResultSetMapping builder does not currently support your inheritance scheme.' );
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\Company\CompanyContract' , 'c' );
}
2011-04-15 04:55:03 +04:00
/**
* @ expectedException \InvalidArgumentException
*/
public function testRSMBuilderThrowsExceptionOnColumnConflict ()
{
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
$rsm -> addJoinedEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsAddress' , 'a' , 'u' , 'address' );
}
2011-05-01 02:17:40 +04:00
/**
* @ group PR - 39
*/
public function testUnknownParentAliasThrowsException ()
{
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
$rsm -> addJoinedEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsAddress' , 'a' , 'un' , 'address' , array ( 'id' => 'a_id' ));
$query = $this -> _em -> createNativeQuery ( 'SELECT u.*, a.*, a.id AS a_id FROM cms_users u INNER JOIN cms_addresses a ON u.id = a.user_id WHERE u.username = ?' , $rsm );
$query -> setParameter ( 1 , 'romanb' );
$this -> setExpectedException (
" Doctrine \ ORM \ Internal \ Hydration \ HydrationException " ,
" The parent object of entity result with alias 'a' was not found. The parent alias is 'un'. "
);
$users = $query -> getResult ();
}
2012-02-26 23:51:39 +04:00
/**
* @ group DDC - 1663
*/
2012-02-28 04:16:35 +04:00
public function testBasicNativeNamedQueryWithSqlResultSetMapping ()
2012-02-26 23:51:39 +04:00
{
$user = new CmsUser ;
$user -> name = 'Fabio B. Silva' ;
$user -> username = 'FabioBatSilva' ;
$user -> status = 'dev' ;
$addr = new CmsAddress ;
$addr -> country = 'Brazil' ;
$addr -> zip = 10827 ;
$addr -> city = 'São Paulo' ;
$user -> setAddress ( $addr );
$this -> _em -> clear ();
$this -> _em -> persist ( $user );
$this -> _em -> flush ();
$this -> _em -> clear ();
$repository = $this -> _em -> getRepository ( 'Doctrine\Tests\Models\CMS\CmsAddress' );
$query = $repository -> createNativeNamedQuery ( 'find-all' );
$result = $query -> getResult ();
2012-05-28 20:16:42 +04:00
2012-02-26 23:51:39 +04:00
$this -> assertCount ( 1 , $result );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsAddress' , $result [ 0 ]);
$this -> assertEquals ( $addr -> id , $result [ 0 ] -> id );
$this -> assertEquals ( $addr -> city , $result [ 0 ] -> city );
$this -> assertEquals ( $addr -> country , $result [ 0 ] -> country );
}
2012-02-28 04:16:35 +04:00
/**
* @ group DDC - 1663
*/
2012-02-28 06:46:27 +04:00
public function testBasicNativeNamedQueryWithResultClass ()
2012-02-28 04:16:35 +04:00
{
$user = new CmsUser ;
$user -> name = 'Fabio B. Silva' ;
$user -> username = 'FabioBatSilva' ;
$user -> status = 'dev' ;
$email = new CmsEmail ();
$email -> email = 'fabio.bat.silva@gmail.com' ;
$user -> setEmail ( $email );
$this -> _em -> clear ();
$this -> _em -> persist ( $user );
$this -> _em -> flush ();
$this -> _em -> clear ();
$repository = $this -> _em -> getRepository ( 'Doctrine\Tests\Models\CMS\CmsUser' );
2012-02-28 06:46:27 +04:00
$result = $repository -> createNativeNamedQuery ( 'fetchIdAndUsernameWithResultClass' )
2012-02-28 04:16:35 +04:00
-> setParameter ( 1 , 'FabioBatSilva' ) -> getResult ();
2012-05-28 20:16:42 +04:00
2012-02-28 04:16:35 +04:00
$this -> assertEquals ( 1 , count ( $result ));
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $result [ 0 ]);
$this -> assertNull ( $result [ 0 ] -> name );
$this -> assertNull ( $result [ 0 ] -> email );
$this -> assertEquals ( $user -> id , $result [ 0 ] -> id );
$this -> assertEquals ( 'FabioBatSilva' , $result [ 0 ] -> username );
$this -> _em -> clear ();
2012-02-29 05:18:25 +04:00
$result = $repository -> createNativeNamedQuery ( 'fetchAllColumns' )
2012-02-28 04:16:35 +04:00
-> setParameter ( 1 , 'FabioBatSilva' ) -> getResult ();
$this -> assertEquals ( 1 , count ( $result ));
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $result [ 0 ]);
$this -> assertEquals ( $user -> id , $result [ 0 ] -> id );
$this -> assertEquals ( 'Fabio B. Silva' , $result [ 0 ] -> name );
$this -> assertEquals ( 'FabioBatSilva' , $result [ 0 ] -> username );
$this -> assertEquals ( 'dev' , $result [ 0 ] -> status );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsEmail' , $result [ 0 ] -> email );
2012-02-28 06:46:27 +04:00
}
2012-02-29 05:18:25 +04:00
/**
* @ group DDC - 1663
*/
2012-02-28 06:46:27 +04:00
public function testJoinedOneToOneNativeNamedQueryWithResultSetMapping ()
{
$user = new CmsUser ;
$user -> name = 'Fabio B. Silva' ;
$user -> username = 'FabioBatSilva' ;
$user -> status = 'dev' ;
$addr = new CmsAddress ;
$addr -> country = 'Brazil' ;
$addr -> zip = 10827 ;
$addr -> city = 'São Paulo' ;
$user -> setAddress ( $addr );
$this -> _em -> persist ( $user );
$this -> _em -> flush ();
$this -> _em -> clear ();
$repository = $this -> _em -> getRepository ( 'Doctrine\Tests\Models\CMS\CmsUser' );
2012-02-29 05:18:25 +04:00
$result = $repository -> createNativeNamedQuery ( 'fetchJoinedAddress' )
2012-02-28 06:46:27 +04:00
-> setParameter ( 1 , 'FabioBatSilva' ) -> getResult ();
$this -> assertEquals ( 1 , count ( $result ));
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $result [ 0 ]);
$this -> assertEquals ( 'Fabio B. Silva' , $result [ 0 ] -> name );
$this -> assertInstanceOf ( 'Doctrine\ORM\PersistentCollection' , $result [ 0 ] -> getPhonenumbers ());
$this -> assertFalse ( $result [ 0 ] -> getPhonenumbers () -> isInitialized ());
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsAddress' , $result [ 0 ] -> getAddress ());
$this -> assertTrue ( $result [ 0 ] -> getAddress () -> getUser () == $result [ 0 ]);
$this -> assertEquals ( 'Brazil' , $result [ 0 ] -> getAddress () -> getCountry ());
$this -> assertEquals ( 10827 , $result [ 0 ] -> getAddress () -> getZipCode ());
$this -> assertEquals ( 'São Paulo' , $result [ 0 ] -> getAddress () -> getCity ());
}
2012-02-29 05:18:25 +04:00
/**
* @ group DDC - 1663
*/
2012-02-28 06:46:27 +04:00
public function testJoinedOneToManyNativeNamedQueryWithResultSetMapping ()
{
$user = new CmsUser ;
$user -> name = 'Fabio B. Silva' ;
$user -> username = 'FabioBatSilva' ;
$user -> status = 'dev' ;
$phone = new CmsPhonenumber ;
$phone -> phonenumber = 424242 ;
$user -> addPhonenumber ( $phone );
2012-02-28 04:16:35 +04:00
2012-02-28 06:46:27 +04:00
$this -> _em -> persist ( $user );
$this -> _em -> flush ();
2012-02-28 04:16:35 +04:00
$this -> _em -> clear ();
2012-02-28 06:46:27 +04:00
$repository = $this -> _em -> getRepository ( 'Doctrine\Tests\Models\CMS\CmsUser' );
2012-02-29 05:18:25 +04:00
$result = $repository -> createNativeNamedQuery ( 'fetchJoinedPhonenumber' )
2012-02-28 06:46:27 +04:00
-> setParameter ( 1 , 'FabioBatSilva' ) -> getResult ();
$this -> assertEquals ( 1 , count ( $result ));
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $result [ 0 ]);
$this -> assertEquals ( 'Fabio B. Silva' , $result [ 0 ] -> name );
$this -> assertInstanceOf ( 'Doctrine\ORM\PersistentCollection' , $result [ 0 ] -> getPhonenumbers ());
$this -> assertTrue ( $result [ 0 ] -> getPhonenumbers () -> isInitialized ());
$this -> assertEquals ( 1 , count ( $result [ 0 ] -> getPhonenumbers ()));
$phones = $result [ 0 ] -> getPhonenumbers ();
$this -> assertEquals ( 424242 , $phones [ 0 ] -> phonenumber );
$this -> assertTrue ( $phones [ 0 ] -> getUser () === $result [ 0 ]);
2012-02-28 04:16:35 +04:00
}
2012-02-28 06:46:27 +04:00
2012-02-29 05:18:25 +04:00
/**
* @ group DDC - 1663
*/
public function testMixedNativeNamedQueryNormalJoin ()
{
$user1 = new CmsUser ;
$user1 -> name = 'Fabio B. Silva' ;
$user1 -> username = 'FabioBatSilva' ;
$user1 -> status = 'dev' ;
$user2 = new CmsUser ;
$user2 -> name = 'test tester' ;
$user2 -> username = 'test' ;
$user2 -> status = 'tester' ;
2012-05-28 20:16:42 +04:00
2012-02-29 05:18:25 +04:00
$phone1 = new CmsPhonenumber ;
$phone2 = new CmsPhonenumber ;
$phone3 = new CmsPhonenumber ;
$phone1 -> phonenumber = 11111111 ;
$phone2 -> phonenumber = 22222222 ;
$phone3 -> phonenumber = 33333333 ;
$user1 -> addPhonenumber ( $phone1 );
$user1 -> addPhonenumber ( $phone2 );
$user2 -> addPhonenumber ( $phone3 );
$this -> _em -> persist ( $user1 );
$this -> _em -> persist ( $user2 );
$this -> _em -> flush ();
$this -> _em -> clear ();
2012-05-28 20:16:42 +04:00
2012-02-29 05:18:25 +04:00
$repository = $this -> _em -> getRepository ( 'Doctrine\Tests\Models\CMS\CmsUser' );
$result = $repository -> createNativeNamedQuery ( 'fetchUserPhonenumberCount' )
-> setParameter ( 1 , array ( 'test' , 'FabioBatSilva' )) -> getResult ();
2012-02-28 06:46:27 +04:00
2012-02-29 05:18:25 +04:00
$this -> assertEquals ( 2 , count ( $result ));
$this -> assertTrue ( is_array ( $result [ 0 ]));
$this -> assertTrue ( is_array ( $result [ 1 ]));
2012-02-28 06:46:27 +04:00
2012-02-29 05:18:25 +04:00
// first user => 2 phonenumbers
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $result [ 0 ][ 0 ]);
$this -> assertEquals ( 'Fabio B. Silva' , $result [ 0 ][ 0 ] -> name );
2012-02-29 06:46:28 +04:00
$this -> assertEquals ( 2 , $result [ 0 ][ 'numphones' ]);
2012-02-29 05:18:25 +04:00
// second user => 1 phonenumbers
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $result [ 1 ][ 0 ]);
$this -> assertEquals ( 'test tester' , $result [ 1 ][ 0 ] -> name );
2012-02-29 06:46:28 +04:00
$this -> assertEquals ( 1 , $result [ 1 ][ 'numphones' ]);
2012-02-29 05:18:25 +04:00
}
2009-04-12 23:02:12 +04:00
2012-02-29 06:17:29 +04:00
/**
* @ group DDC - 1663
*/
public function testNativeNamedQueryInheritance ()
{
$person = new CompanyPerson ;
$person -> setName ( 'Fabio B. Silva' );
$employee = new CompanyEmployee ;
$employee -> setName ( 'Fabio Silva' );
$employee -> setSalary ( 100000 );
$employee -> setDepartment ( 'IT' );
$this -> _em -> persist ( $person );
$this -> _em -> persist ( $employee );
$this -> _em -> flush ();
$this -> _em -> clear ();
$repository = $this -> _em -> getRepository ( 'Doctrine\Tests\Models\Company\CompanyPerson' );
$result = $repository -> createNativeNamedQuery ( 'fetchAllWithSqlResultSetMapping' )
-> getResult ();
$this -> assertEquals ( 2 , count ( $result ));
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\Company\CompanyPerson' , $result [ 0 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\Company\CompanyEmployee' , $result [ 1 ]);
$this -> assertTrue ( is_numeric ( $result [ 0 ] -> getId ()));
$this -> assertTrue ( is_numeric ( $result [ 1 ] -> getId ()));
$this -> assertEquals ( 'Fabio B. Silva' , $result [ 0 ] -> getName ());
$this -> assertEquals ( 'Fabio Silva' , $result [ 1 ] -> getName ());
$this -> _em -> clear ();
2012-05-28 20:16:42 +04:00
2012-02-29 06:17:29 +04:00
$result = $repository -> createNativeNamedQuery ( 'fetchAllWithResultClass' )
-> getResult ();
$this -> assertEquals ( 2 , count ( $result ));
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\Company\CompanyPerson' , $result [ 0 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\Company\CompanyEmployee' , $result [ 1 ]);
$this -> assertTrue ( is_numeric ( $result [ 0 ] -> getId ()));
$this -> assertTrue ( is_numeric ( $result [ 1 ] -> getId ()));
$this -> assertEquals ( 'Fabio B. Silva' , $result [ 0 ] -> getName ());
$this -> assertEquals ( 'Fabio Silva' , $result [ 1 ] -> getName ());
}
2012-03-11 19:10:15 +04:00
/**
* @ group DDC - 1663
* DQL : SELECT u , a , COUNT ( p ) AS numphones FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u . address a JOIN u . phonenumbers p
*/
public function testMultipleEntityResults ()
{
$user = new CmsUser ;
$user -> name = 'Fabio B. Silva' ;
$user -> username = 'FabioBatSilva' ;
$user -> status = 'dev' ;
$addr = new CmsAddress ;
$addr -> country = 'Brazil' ;
$addr -> zip = 10827 ;
$addr -> city = 'São Paulo' ;
$phone = new CmsPhonenumber ;
$phone -> phonenumber = 424242 ;
$user -> setAddress ( $addr );
$user -> addPhonenumber ( $phone );
$this -> _em -> clear ();
$this -> _em -> persist ( $user );
$this -> _em -> flush ();
$this -> _em -> clear ();
$repository = $this -> _em -> getRepository ( 'Doctrine\Tests\Models\CMS\CmsUser' );
$query = $repository -> createNativeNamedQuery ( 'fetchMultipleJoinsEntityResults' );
$result = $query -> getResult ();
$this -> assertEquals ( 1 , count ( $result ));
$this -> assertTrue ( is_array ( $result [ 0 ]));
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $result [ 0 ][ 0 ]);
$this -> assertEquals ( 'Fabio B. Silva' , $result [ 0 ][ 0 ] -> name );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsAddress' , $result [ 0 ][ 0 ] -> getAddress ());
$this -> assertTrue ( $result [ 0 ][ 0 ] -> getAddress () -> getUser () == $result [ 0 ][ 0 ]);
$this -> assertEquals ( 'Brazil' , $result [ 0 ][ 0 ] -> getAddress () -> getCountry ());
$this -> assertEquals ( 10827 , $result [ 0 ][ 0 ] -> getAddress () -> getZipCode ());
$this -> assertEquals ( 1 , $result [ 0 ][ 'numphones' ]);
}
2012-03-12 04:46:31 +04:00
/**
* @ group DDC - 1663
*/
public function testNamedNativeQueryInheritance ()
{
$contractMetadata = $this -> _em -> getClassMetadata ( 'Doctrine\Tests\Models\Company\CompanyContract' );
$flexMetadata = $this -> _em -> getClassMetadata ( 'Doctrine\Tests\Models\Company\CompanyFlexContract' );
$contractQueries = $contractMetadata -> getNamedNativeQueries ();
$flexQueries = $flexMetadata -> getNamedNativeQueries ();
$contractMappings = $contractMetadata -> getSqlResultSetMappings ();
$flexMappings = $flexMetadata -> getSqlResultSetMappings ();
// contract queries
$this -> assertEquals ( 'all-contracts' , $contractQueries [ 'all-contracts' ][ 'name' ]);
$this -> assertEquals ( 'Doctrine\Tests\Models\Company\CompanyContract' , $contractQueries [ 'all-contracts' ][ 'resultClass' ]);
$this -> assertEquals ( 'all' , $contractQueries [ 'all' ][ 'name' ]);
$this -> assertEquals ( 'Doctrine\Tests\Models\Company\CompanyContract' , $contractQueries [ 'all' ][ 'resultClass' ]);
// flex contract queries
$this -> assertEquals ( 'all-contracts' , $flexQueries [ 'all-contracts' ][ 'name' ]);
$this -> assertEquals ( 'Doctrine\Tests\Models\Company\CompanyFlexContract' , $flexQueries [ 'all-contracts' ][ 'resultClass' ]);
$this -> assertEquals ( 'all-flex' , $flexQueries [ 'all-flex' ][ 'name' ]);
$this -> assertEquals ( 'Doctrine\Tests\Models\Company\CompanyFlexContract' , $flexQueries [ 'all-flex' ][ 'resultClass' ]);
$this -> assertEquals ( 'all' , $flexQueries [ 'all' ][ 'name' ]);
$this -> assertEquals ( 'Doctrine\Tests\Models\Company\CompanyFlexContract' , $flexQueries [ 'all' ][ 'resultClass' ]);
// contract result mapping
$this -> assertEquals ( 'mapping-all-contracts' , $contractMappings [ 'mapping-all-contracts' ][ 'name' ]);
$this -> assertEquals ( 'Doctrine\Tests\Models\Company\CompanyContract' , $contractMappings [ 'mapping-all-contracts' ][ 'entities' ][ 0 ][ 'entityClass' ]);
$this -> assertEquals ( 'mapping-all' , $contractMappings [ 'mapping-all' ][ 'name' ]);
$this -> assertEquals ( 'Doctrine\Tests\Models\Company\CompanyContract' , $contractMappings [ 'mapping-all-contracts' ][ 'entities' ][ 0 ][ 'entityClass' ]);
// flex contract result mapping
$this -> assertEquals ( 'mapping-all-contracts' , $flexMappings [ 'mapping-all-contracts' ][ 'name' ]);
$this -> assertEquals ( 'Doctrine\Tests\Models\Company\CompanyFlexContract' , $flexMappings [ 'mapping-all-contracts' ][ 'entities' ][ 0 ][ 'entityClass' ]);
$this -> assertEquals ( 'mapping-all' , $flexMappings [ 'mapping-all' ][ 'name' ]);
$this -> assertEquals ( 'Doctrine\Tests\Models\Company\CompanyFlexContract' , $flexMappings [ 'mapping-all' ][ 'entities' ][ 0 ][ 'entityClass' ]);
$this -> assertEquals ( 'mapping-all-flex' , $flexMappings [ 'mapping-all-flex' ][ 'name' ]);
$this -> assertEquals ( 'Doctrine\Tests\Models\Company\CompanyFlexContract' , $flexMappings [ 'mapping-all-flex' ][ 'entities' ][ 0 ][ 'entityClass' ]);
}
2012-10-03 14:35:14 +04:00
/**
* @ group DDC - 2055
*/
public function testGenerateSelectClauseNoRenameSingleEntity ()
{
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
$selectClause = $rsm -> generateSelectClause ();
2013-09-07 10:52:50 +04:00
$this -> assertSQLEquals ( 'u.id AS id, u.status AS status, u.username AS username, u.name AS name, u.email_id AS email_id' , $selectClause );
2012-10-03 14:35:14 +04:00
}
/**
* @ group DDC - 2055
*/
public function testGenerateSelectClauseCustomRenames ()
{
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' , array (
'id' => 'id1' ,
'username' => 'username2'
));
$selectClause = $rsm -> generateSelectClause ();
2013-09-07 10:52:50 +04:00
$this -> assertSQLEquals ( 'u.id AS id1, u.status AS status, u.username AS username2, u.name AS name, u.email_id AS email_id' , $selectClause );
2012-10-03 14:35:14 +04:00
}
/**
* @ group DDC - 2055
*/
public function testGenerateSelectClauseRenameTableAlias ()
{
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
$selectClause = $rsm -> generateSelectClause ( array ( 'u' => 'u1' ));
2013-09-07 10:52:50 +04:00
$this -> assertSQLEquals ( 'u1.id AS id, u1.status AS status, u1.username AS username, u1.name AS name, u1.email_id AS email_id' , $selectClause );
2012-10-03 14:35:14 +04:00
}
/**
* @ group DDC - 2055
*/
public function testGenerateSelectClauseIncrement ()
{
2012-11-19 19:54:56 +04:00
$rsm = new ResultSetMappingBuilder ( $this -> _em , ResultSetMappingBuilder :: COLUMN_RENAMING_INCREMENT );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
2012-10-03 14:35:14 +04:00
$selectClause = $rsm -> generateSelectClause ();
2013-09-07 10:52:50 +04:00
$this -> assertSQLEquals ( 'u.id AS id0, u.status AS status1, u.username AS username2, u.name AS name3, u.email_id AS email_id4' , $selectClause );
2012-10-03 14:35:14 +04:00
}
/**
* @ group DDC - 2055
*/
public function testGenerateSelectClauseToString ()
{
2012-11-19 19:54:56 +04:00
$rsm = new ResultSetMappingBuilder ( $this -> _em , ResultSetMappingBuilder :: COLUMN_RENAMING_INCREMENT );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
2012-10-03 14:35:14 +04:00
2013-09-07 10:52:50 +04:00
$this -> assertSQLEquals ( 'u.id AS id0, u.status AS status1, u.username AS username2, u.name AS name3, u.email_id AS email_id4' , ( string ) $rsm );
2012-10-03 14:35:14 +04:00
}
}