2009-04-12 19:02:12 +00:00
< ? php
namespace Doctrine\Tests\ORM\Functional ;
use Doctrine\ORM\Query\ResultSetMapping ;
2011-03-30 10:27:31 -04:00
use Doctrine\ORM\Query\ResultSetMappingBuilder ;
2009-04-12 19:02:12 +00:00
use Doctrine\Tests\Models\CMS\CmsUser ;
2009-08-15 18:11:51 +00:00
use Doctrine\Tests\Models\CMS\CmsPhonenumber ;
2009-10-22 09:10:59 +00:00
use Doctrine\Tests\Models\CMS\CmsAddress ;
2011-04-14 20:55:03 -04:00
use Doctrine\Tests\Models\Company\CompanyFixContract ;
use Doctrine\Tests\Models\Company\CompanyEmployee ;
2009-04-12 19:02:12 +00:00
require_once __DIR__ . '/../../TestInit.php' ;
/**
* NativeQueryTest
*
* @ author robo
*/
class NativeQueryTest extends \Doctrine\Tests\OrmFunctionalTestCase
{
2010-04-18 19:12:38 +02:00
private $platform = null ;
2009-04-12 19:02:12 +00:00
protected function setUp () {
$this -> useModelSet ( 'cms' );
parent :: setUp ();
2010-04-18 19:12:38 +02:00
$this -> platform = $this -> _em -> getConnection () -> getDatabasePlatform ();
2009-04-12 19:02:12 +00:00
}
public function testBasicNativeQuery ()
{
$user = new CmsUser ;
$user -> name = 'Roman' ;
$user -> username = 'romanb' ;
$user -> status = 'dev' ;
2009-07-19 16:54:53 +00:00
$this -> _em -> persist ( $user );
2009-04-12 19:02:12 +00:00
$this -> _em -> flush ();
2009-08-15 18:11:51 +00:00
$this -> _em -> clear ();
2009-04-12 19:02:12 +00:00
$rsm = new ResultSetMapping ;
2009-05-21 19:18:14 +00:00
$rsm -> addEntityResult ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
2010-04-18 19:12:38 +02:00
$rsm -> addFieldResult ( 'u' , $this -> platform -> getSQLResultCasing ( 'id' ), 'id' );
$rsm -> addFieldResult ( 'u' , $this -> platform -> getSQLResultCasing ( 'name' ), 'name' );
2009-04-12 19:02:12 +00:00
$query = $this -> _em -> createNativeQuery ( 'SELECT id, name FROM cms_users WHERE username = ?' , $rsm );
$query -> setParameter ( 1 , 'romanb' );
2009-08-03 17:18:37 +00:00
$users = $query -> getResult ();
2009-04-12 19:02:12 +00:00
$this -> assertEquals ( 1 , count ( $users ));
2011-07-26 15:22:57 +02:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $users [ 0 ]);
2009-04-12 19:02:12 +00:00
$this -> assertEquals ( 'Roman' , $users [ 0 ] -> name );
}
2011-07-26 17: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 );
}
2009-08-15 18:11:51 +00:00
2009-10-22 09:10:59 +00:00
public function testJoinedOneToManyNativeQuery ()
2009-08-15 18:11:51 +00: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 ();
$rsm = new ResultSetMapping ;
$rsm -> addEntityResult ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
2010-04-18 19:12:38 +02: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 18:11:51 +00:00
$rsm -> addJoinedEntityResult ( 'Doctrine\Tests\Models\CMS\CmsPhonenumber' , 'p' , 'u' , 'phonenumbers' );
2010-04-18 19:12:38 +02:00
$rsm -> addFieldResult ( 'p' , $this -> platform -> getSQLResultCasing ( 'phonenumber' ), 'phonenumber' );
2009-08-15 18:11:51 +00: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 15:22:57 +02:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $users [ 0 ]);
2009-08-15 18:11:51 +00:00
$this -> assertEquals ( 'Roman' , $users [ 0 ] -> name );
2011-07-26 15:22:57 +02:00
$this -> assertInstanceOf ( 'Doctrine\ORM\PersistentCollection' , $users [ 0 ] -> getPhonenumbers ());
2009-10-22 09:10:59 +00:00
$this -> assertTrue ( $users [ 0 ] -> getPhonenumbers () -> isInitialized ());
2009-08-15 18:11:51 +00: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 ]);
}
2009-10-22 09:10:59 +00:00
public function testJoinedOneToOneNativeQuery ()
{
$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\CmsUser' , 'u' );
2010-04-18 19:12:38 +02: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 09:10:59 +00:00
$rsm -> addJoinedEntityResult ( 'Doctrine\Tests\Models\CMS\CmsAddress' , 'a' , 'u' , 'address' );
2010-04-18 19:12:38 +02: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' );
2009-10-22 09:10:59 +00: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' );
$users = $query -> getResult ();
$this -> assertEquals ( 1 , count ( $users ));
2011-07-26 15:22:57 +02:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $users [ 0 ]);
2009-10-22 09:10:59 +00:00
$this -> assertEquals ( 'Roman' , $users [ 0 ] -> name );
2011-07-26 15:22:57 +02:00
$this -> assertInstanceOf ( 'Doctrine\ORM\PersistentCollection' , $users [ 0 ] -> getPhonenumbers ());
2009-10-22 09:10:59 +00:00
$this -> assertFalse ( $users [ 0 ] -> getPhonenumbers () -> isInitialized ());
2011-07-26 15:22:57 +02:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsAddress' , $users [ 0 ] -> getAddress ());
2009-10-22 09:10:59 +00: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 13:13:19 +00:00
public function testFluentInterface ()
{
$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' )
-> setParameters ( array ( 2 => 'bar' ))
-> setResultCacheDriver ( null )
-> setResultCacheLifetime ( 3500 );
$this -> assertSame ( $q , $q2 );
}
2011-03-29 20:35:01 -04:00
2011-03-30 10:27:31 -04:00
public function testJoinedOneToManyNativeQueryWithRSMBuilder ()
2011-03-29 20: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 10:27:31 -04:00
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
2011-04-14 20: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-29 20:35:01 -04:00
$query -> setParameter ( 1 , 'romanb' );
$users = $query -> getResult ();
$this -> assertEquals ( 1 , count ( $users ));
2011-07-26 15:22:57 +02:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $users [ 0 ]);
2011-03-29 20:35:01 -04:00
$this -> assertEquals ( 'Roman' , $users [ 0 ] -> name );
2011-07-26 15:22:57 +02:00
$this -> assertInstanceOf ( 'Doctrine\ORM\PersistentCollection' , $users [ 0 ] -> getPhonenumbers ());
2011-03-29 20: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-26 17: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-29 20:35:01 -04:00
}
2011-03-30 10:27:31 -04:00
public function testJoinedOneToOneNativeQueryWithRSMBuilder ()
2011-03-29 20: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 10:27:31 -04:00
$rsm = new ResultSetMappingBuilder ( $this -> _em );
$rsm -> addRootEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsUser' , 'u' );
2011-04-14 20:55:03 -04:00
$rsm -> addJoinedEntityFromClassMetadata ( 'Doctrine\Tests\Models\CMS\CmsAddress' , 'a' , 'u' , 'address' , array ( 'id' => 'a_id' ));
2011-03-29 20:35:01 -04:00
2011-04-14 20: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-29 20:35:01 -04:00
$query -> setParameter ( 1 , 'romanb' );
$users = $query -> getResult ();
$this -> assertEquals ( 1 , count ( $users ));
2011-07-26 15:22:57 +02:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUser' , $users [ 0 ]);
2011-03-29 20:35:01 -04:00
$this -> assertEquals ( 'Roman' , $users [ 0 ] -> name );
2011-07-26 15:22:57 +02:00
$this -> assertInstanceOf ( 'Doctrine\ORM\PersistentCollection' , $users [ 0 ] -> getPhonenumbers ());
2011-03-29 20:35:01 -04:00
$this -> assertFalse ( $users [ 0 ] -> getPhonenumbers () -> isInitialized ());
2011-07-26 15:22:57 +02:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsAddress' , $users [ 0 ] -> getAddress ());
2011-03-29 20: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-26 17: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-29 20:35:01 -04:00
}
2011-04-14 20: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 00:17:40 +02: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 ();
}
2009-04-12 19:02:12 +00:00
}