2012-07-01 01:15:09 +04:00
< ? php
namespace Doctrine\Tests\ORM\Functional ;
use Doctrine\Tests\Models\CMS\CmsUser ;
use Doctrine\Tests\Models\CMS\CmsEmail ;
use Doctrine\Tests\Models\CMS\CmsAddress ;
use Doctrine\Tests\Models\CMS\CmsPhonenumber ;
/**
* @ group DDC - 1574
*/
class NewOperatorTest extends \Doctrine\Tests\OrmFunctionalTestCase
{
/**
* @ var array
*/
private $fixtures ;
protected function setUp ()
{
$this -> useModelSet ( 'cms' );
parent :: setUp ();
$this -> loadFixtures ();
}
private function loadFixtures ()
{
$u1 = new CmsUser ;
$u2 = new CmsUser ;
$u3 = new CmsUser ;
$u1 -> setEmail ( new CmsEmail ());
$u1 -> setAddress ( new CmsAddress ());
2012-07-10 01:56:16 +04:00
$u1 -> addPhonenumber ( new CmsPhonenumber ());
2012-07-01 01:15:09 +04:00
$u2 -> setEmail ( new CmsEmail ());
$u2 -> setAddress ( new CmsAddress ());
2012-07-10 01:56:16 +04:00
$u2 -> addPhonenumber ( new CmsPhonenumber ());
$u2 -> addPhonenumber ( new CmsPhonenumber ());
2012-07-01 01:15:09 +04:00
$u3 -> setEmail ( new CmsEmail ());
$u3 -> setAddress ( new CmsAddress ());
2012-07-10 01:56:16 +04:00
$u3 -> addPhonenumber ( new CmsPhonenumber ());
$u3 -> addPhonenumber ( new CmsPhonenumber ());
$u3 -> addPhonenumber ( new CmsPhonenumber ());
2012-07-01 01:15:09 +04:00
$u1 -> name = 'Test 1' ;
$u1 -> username = '1test' ;
$u1 -> status = 'developer' ;
$u1 -> email -> email = 'email@test1.com' ;
$u1 -> address -> zip = '111111111' ;
$u1 -> address -> city = 'Some City 1' ;
$u1 -> address -> country = 'Some Country 2' ;
2012-07-10 01:56:16 +04:00
$u1 -> phonenumbers [ 0 ] -> phonenumber = " (11) 1111-1111 " ;
2012-07-01 01:15:09 +04:00
$u2 -> name = 'Test 2' ;
$u2 -> username = '2test' ;
$u2 -> status = 'developer' ;
$u2 -> email -> email = 'email@test2.com' ;
$u2 -> address -> zip = '222222222' ;
$u2 -> address -> city = 'Some City 2' ;
$u2 -> address -> country = 'Some Country 2' ;
2012-07-10 01:56:16 +04:00
$u2 -> phonenumbers [ 0 ] -> phonenumber = " (22) 1111-1111 " ;
$u2 -> phonenumbers [ 1 ] -> phonenumber = " (22) 2222-2222 " ;
2012-07-01 01:15:09 +04:00
$u3 -> name = 'Test 3' ;
$u3 -> username = '3test' ;
$u3 -> status = 'developer' ;
$u3 -> email -> email = 'email@test3.com' ;
$u3 -> address -> zip = '33333333' ;
$u3 -> address -> city = 'Some City 3' ;
$u3 -> address -> country = 'Some Country 3' ;
2012-07-10 01:56:16 +04:00
$u3 -> phonenumbers [ 0 ] -> phonenumber = " (33) 1111-1111 " ;
$u3 -> phonenumbers [ 1 ] -> phonenumber = " (33) 2222-2222 " ;
$u3 -> phonenumbers [ 2 ] -> phonenumber = " (33) 3333-3333 " ;
2012-07-01 01:15:09 +04:00
$this -> _em -> persist ( $u1 );
$this -> _em -> persist ( $u2 );
$this -> _em -> persist ( $u3 );
$this -> _em -> flush ();
$this -> _em -> clear ();
$this -> fixtures = array ( $u1 , $u2 , $u3 );
}
public function testShouldSupportsBasicUsage ()
{
$dql = "
SELECT
new Doctrine\Tests\Models\CMS\CmsUserDTO (
u . name ,
e . email ,
a . city
)
2012-08-12 06:08:34 +04:00
FROM
2012-07-01 01:15:09 +04:00
Doctrine\Tests\Models\CMS\CmsUser u
JOIN
u . email e
JOIN
u . address a
2012-07-10 01:56:16 +04:00
ORDER BY
u . name " ;
2012-07-01 01:15:09 +04:00
$query = $this -> _em -> createQuery ( $dql );
$result = $query -> getResult ();
$this -> assertCount ( 3 , $result );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 0 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 1 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 2 ]);
$this -> assertEquals ( $this -> fixtures [ 0 ] -> name , $result [ 0 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> name , $result [ 1 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> name , $result [ 2 ] -> name );
2012-08-12 06:08:34 +04:00
2012-07-01 01:15:09 +04:00
$this -> assertEquals ( $this -> fixtures [ 0 ] -> email -> email , $result [ 0 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> email -> email , $result [ 1 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> email -> email , $result [ 2 ] -> email );
2012-08-12 06:08:34 +04:00
2012-07-01 01:15:09 +04:00
$this -> assertEquals ( $this -> fixtures [ 0 ] -> address -> city , $result [ 0 ] -> address );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> address -> city , $result [ 1 ] -> address );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> address -> city , $result [ 2 ] -> address );
}
2012-08-12 06:08:34 +04:00
public function testShouldAssumeFromEntityNamespaceWhenNotGiven ()
{
$dql = "
SELECT
new CmsUserDTO ( u . name , e . email , a . city )
FROM
Doctrine\Tests\Models\CMS\CmsUser u
JOIN
u . email e
JOIN
u . address a
ORDER BY
u . name " ;
$query = $this -> _em -> createQuery ( $dql );
$result = $query -> getResult ();
$this -> assertCount ( 3 , $result );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 0 ]);
2012-08-15 04:02:52 +04:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 1 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 2 ]);
}
public function testShouldSupportFromEntityNamespaceAlias ()
{
$dql = "
SELECT
new CmsUserDTO ( u . name , e . email , a . city )
FROM
cms : CmsUser u
JOIN
u . email e
JOIN
u . address a
ORDER BY
u . name " ;
$this -> _em -> getConfiguration ()
-> addEntityNamespace ( 'cms' , 'Doctrine\Tests\Models\CMS' );
$query = $this -> _em -> createQuery ( $dql );
$result = $query -> getResult ();
$this -> assertCount ( 3 , $result );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 0 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 1 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 2 ]);
}
public function testShouldSupportValueObjectNamespaceAlias ()
{
$dql = "
SELECT
new cms : CmsUserDTO ( u . name , e . email , a . city )
FROM
cms : CmsUser u
JOIN
u . email e
JOIN
u . address a
ORDER BY
u . name " ;
$this -> _em -> getConfiguration ()
-> addEntityNamespace ( 'cms' , 'Doctrine\Tests\Models\CMS' );
$query = $this -> _em -> createQuery ( $dql );
$result = $query -> getResult ();
$this -> assertCount ( 3 , $result );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 0 ]);
2012-08-12 06:08:34 +04:00
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 1 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 2 ]);
}
2012-08-11 23:37:09 +04:00
public function testShouldSupportLiteralExpression ()
2012-08-11 21:01:57 +04:00
{
$dql = "
SELECT
new Doctrine\Tests\Models\CMS\CmsUserDTO (
u . name ,
'fabio.bat.silva@gmail.com' ,
FALSE ,
123
)
FROM
Doctrine\Tests\Models\CMS\CmsUser u
JOIN
u . email e
JOIN
u . address a
JOIN
u . phonenumbers p
GROUP BY
u , e , a
ORDER BY
u . name " ;
$query = $this -> _em -> createQuery ( $dql );
$result = $query -> getResult ();
$this -> assertCount ( 3 , $result );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 0 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 1 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 2 ]);
$this -> assertEquals ( $this -> fixtures [ 0 ] -> name , $result [ 0 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> name , $result [ 1 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> name , $result [ 2 ] -> name );
$this -> assertEquals ( 'fabio.bat.silva@gmail.com' , $result [ 0 ] -> email );
$this -> assertEquals ( 'fabio.bat.silva@gmail.com' , $result [ 1 ] -> email );
$this -> assertEquals ( 'fabio.bat.silva@gmail.com' , $result [ 2 ] -> email );
$this -> assertEquals ( false , $result [ 0 ] -> address );
$this -> assertEquals ( false , $result [ 1 ] -> address );
$this -> assertEquals ( false , $result [ 2 ] -> address );
$this -> assertEquals ( 123 , $result [ 0 ] -> phonenumbers );
$this -> assertEquals ( 123 , $result [ 1 ] -> phonenumbers );
$this -> assertEquals ( 123 , $result [ 2 ] -> phonenumbers );
}
2012-08-11 23:37:09 +04:00
public function testShouldSupportCaseExpression ()
{
$dql = "
SELECT
new Doctrine\Tests\Models\CMS\CmsUserDTO (
u . name ,
CASE WHEN ( e . email = 'email@test1.com' ) THEN 'TEST1' ELSE 'OTHER_TEST' END
)
FROM
Doctrine\Tests\Models\CMS\CmsUser u
JOIN
u . email e
JOIN
u . address a
JOIN
u . phonenumbers p
GROUP BY
u , e , a
ORDER BY
u . name " ;
$query = $this -> _em -> createQuery ( $dql );
$result = $query -> getResult ();
$this -> assertCount ( 3 , $result );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 0 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 1 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 2 ]);
$this -> assertEquals ( $this -> fixtures [ 0 ] -> name , $result [ 0 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> name , $result [ 1 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> name , $result [ 2 ] -> name );
$this -> assertEquals ( 'TEST1' , $result [ 0 ] -> email );
$this -> assertEquals ( 'OTHER_TEST' , $result [ 1 ] -> email );
$this -> assertEquals ( 'OTHER_TEST' , $result [ 2 ] -> email );
}
2012-08-11 21:01:57 +04:00
public function testShouldSupportSimpleArithmeticExpression ()
{
$dql = "
SELECT
new Doctrine\Tests\Models\CMS\CmsUserDTO (
u . name ,
e . email ,
a . city ,
a . id + u . id
)
FROM
Doctrine\Tests\Models\CMS\CmsUser u
JOIN
u . email e
JOIN
u . address a
JOIN
u . phonenumbers p
GROUP BY
u , e , a
ORDER BY
u . name " ;
$query = $this -> _em -> createQuery ( $dql );
$result = $query -> getResult ();
$this -> assertCount ( 3 , $result );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 0 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 1 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 2 ]);
$this -> assertEquals ( $this -> fixtures [ 0 ] -> name , $result [ 0 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> name , $result [ 1 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> name , $result [ 2 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 0 ] -> email -> email , $result [ 0 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> email -> email , $result [ 1 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> email -> email , $result [ 2 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 0 ] -> address -> city , $result [ 0 ] -> address );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> address -> city , $result [ 1 ] -> address );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> address -> city , $result [ 2 ] -> address );
$this -> assertEquals (
( $this -> fixtures [ 0 ] -> address -> id + $this -> fixtures [ 0 ] -> id ),
$result [ 0 ] -> phonenumbers
);
$this -> assertEquals (
( $this -> fixtures [ 1 ] -> address -> id + $this -> fixtures [ 1 ] -> id ),
$result [ 1 ] -> phonenumbers
);
$this -> assertEquals (
( $this -> fixtures [ 2 ] -> address -> id + $this -> fixtures [ 2 ] -> id ),
$result [ 2 ] -> phonenumbers
);
}
2012-07-01 01:15:09 +04:00
public function testShouldSupportAggregateFunctions ()
{
2012-07-10 01:56:16 +04:00
$dql = "
SELECT
new Doctrine\Tests\Models\CMS\CmsUserDTO (
u . name ,
e . email ,
a . city ,
COUNT ( p )
)
FROM
Doctrine\Tests\Models\CMS\CmsUser u
JOIN
u . email e
JOIN
u . address a
JOIN
u . phonenumbers p
GROUP BY
2012-07-22 01:07:56 +04:00
u , e , a
2012-07-10 01:56:16 +04:00
ORDER BY
u . name " ;
$query = $this -> _em -> createQuery ( $dql );
$result = $query -> getResult ();
$this -> assertCount ( 3 , $result );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 0 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 1 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 2 ]);
$this -> assertEquals ( $this -> fixtures [ 0 ] -> name , $result [ 0 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> name , $result [ 1 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> name , $result [ 2 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 0 ] -> email -> email , $result [ 0 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> email -> email , $result [ 1 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> email -> email , $result [ 2 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 0 ] -> address -> city , $result [ 0 ] -> address );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> address -> city , $result [ 1 ] -> address );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> address -> city , $result [ 2 ] -> address );
$this -> assertEquals (
( count ( $this -> fixtures [ 0 ] -> phonenumbers )),
$result [ 0 ] -> phonenumbers
);
$this -> assertEquals (
( count ( $this -> fixtures [ 1 ] -> phonenumbers )),
$result [ 1 ] -> phonenumbers
);
$this -> assertEquals (
( count ( $this -> fixtures [ 2 ] -> phonenumbers )),
$result [ 2 ] -> phonenumbers
);
}
public function testShouldSupportArithmeticExpression ()
{
$dql = "
SELECT
new Doctrine\Tests\Models\CMS\CmsUserDTO (
u . name ,
e . email ,
a . city ,
COUNT ( p ) + u . id
)
FROM
Doctrine\Tests\Models\CMS\CmsUser u
JOIN
u . email e
JOIN
u . address a
JOIN
u . phonenumbers p
GROUP BY
2012-08-11 04:36:47 +04:00
u , e , a
2012-07-10 01:56:16 +04:00
ORDER BY
u . name " ;
$query = $this -> _em -> createQuery ( $dql );
$result = $query -> getResult ();
$this -> assertCount ( 3 , $result );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 0 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 1 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 2 ]);
$this -> assertEquals ( $this -> fixtures [ 0 ] -> name , $result [ 0 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> name , $result [ 1 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> name , $result [ 2 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 0 ] -> email -> email , $result [ 0 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> email -> email , $result [ 1 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> email -> email , $result [ 2 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 0 ] -> address -> city , $result [ 0 ] -> address );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> address -> city , $result [ 1 ] -> address );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> address -> city , $result [ 2 ] -> address );
$this -> assertEquals (
( count ( $this -> fixtures [ 0 ] -> phonenumbers ) + $this -> fixtures [ 0 ] -> id ),
$result [ 0 ] -> phonenumbers
);
$this -> assertEquals (
( count ( $this -> fixtures [ 1 ] -> phonenumbers ) + $this -> fixtures [ 1 ] -> id ),
$result [ 1 ] -> phonenumbers
);
$this -> assertEquals (
( count ( $this -> fixtures [ 2 ] -> phonenumbers ) + $this -> fixtures [ 2 ] -> id ),
$result [ 2 ] -> phonenumbers
);
2012-07-01 01:15:09 +04:00
}
2012-08-12 04:22:16 +04:00
public function testShouldSupportMultipleNewOperators ()
{
$dql = "
SELECT
2012-08-12 06:08:34 +04:00
new CmsUserDTO (
2012-08-12 04:22:16 +04:00
u . name ,
e . email
),
2012-08-12 06:08:34 +04:00
new CmsAddressDTO (
2012-08-12 04:22:16 +04:00
a . country ,
a . city
)
FROM
Doctrine\Tests\Models\CMS\CmsUser u
JOIN
u . email e
JOIN
u . address a
ORDER BY
u . name " ;
$query = $this -> _em -> createQuery ( $dql );
$result = $query -> getResult ();
$this -> assertCount ( 3 , $result );
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 0 ][ 0 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 1 ][ 0 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsUserDTO' , $result [ 2 ][ 0 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsAddressDTO' , $result [ 0 ][ 1 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsAddressDTO' , $result [ 1 ][ 1 ]);
$this -> assertInstanceOf ( 'Doctrine\Tests\Models\CMS\CmsAddressDTO' , $result [ 2 ][ 1 ]);
$this -> assertEquals ( $this -> fixtures [ 0 ] -> name , $result [ 0 ][ 0 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> name , $result [ 1 ][ 0 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> name , $result [ 2 ][ 0 ] -> name );
$this -> assertEquals ( $this -> fixtures [ 0 ] -> email -> email , $result [ 0 ][ 0 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> email -> email , $result [ 1 ][ 0 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> email -> email , $result [ 2 ][ 0 ] -> email );
$this -> assertEquals ( $this -> fixtures [ 0 ] -> address -> city , $result [ 0 ][ 1 ] -> city );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> address -> city , $result [ 1 ][ 1 ] -> city );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> address -> city , $result [ 2 ][ 1 ] -> city );
$this -> assertEquals ( $this -> fixtures [ 0 ] -> address -> country , $result [ 0 ][ 1 ] -> country );
$this -> assertEquals ( $this -> fixtures [ 1 ] -> address -> country , $result [ 1 ][ 1 ] -> country );
$this -> assertEquals ( $this -> fixtures [ 2 ] -> address -> country , $result [ 2 ][ 1 ] -> country );
}
2012-08-12 04:52:03 +04:00
/**
* @ expectedException Doctrine\ORM\Query\QueryException
* @ expectedExceptionMessage [ Semantical Error ] line 0 , col 11 near '\InvalidClass(u.name)' : Error : Class " \InvalidClass " is not defined.
*/
public function testInvalidClassException ()
{
$dql = " SELECT new \ InvalidClass(u.name) FROM Doctrine \T ests \ Models \ CMS \ CmsUser u " ;
$this -> _em -> createQuery ( $dql ) -> getResult ();
}
/**
* @ expectedException Doctrine\ORM\Query\QueryException
2013-03-11 04:08:58 +04:00
* @ expectedExceptionMessage [ Semantical Error ] line 0 , col 11 near '\stdClass(u.name)' : Error : Class " \stdClass " has not a valid constructor.
2012-08-12 04:52:03 +04:00
*/
public function testInvalidClassConstructorException ()
{
$dql = " SELECT new \ stdClass(u.name) FROM Doctrine \T ests \ Models \ CMS \ CmsUser u " ;
$this -> _em -> createQuery ( $dql ) -> getResult ();
}
/**
* @ expectedException Doctrine\ORM\Query\QueryException
2012-08-12 06:08:34 +04:00
* @ expectedExceptionMessage [ Semantical Error ] line 0 , col 11 near 'Doctrine\Tests\ORM\Functional\ClassWithTooMuchArgs(u.name)' : Error : Number of arguments does not match with " Doctrine \T ests \ ORM \ Functional \ ClassWithTooMuchArgs " constructor declaration .
2012-08-12 04:52:03 +04:00
*/
public function testInvalidClassWithoutConstructorException ()
{
$dql = " SELECT new Doctrine \T ests \ ORM \ Functional \ ClassWithTooMuchArgs(u.name) FROM Doctrine \T ests \ Models \ CMS \ CmsUser u " ;
$this -> _em -> createQuery ( $dql ) -> getResult ();
}
2012-08-12 21:40:26 +04:00
/**
* @ expectedException Doctrine\ORM\Query\QueryException
* @ expectedExceptionMessage [ Semantical Error ] line 0 , col 11 near 'Doctrine\Tests\ORM\Functional\ClassWithPrivateConstructor(u.name)' : Error : Class " Doctrine\Tests\ORM\Functional\ClassWithPrivateConstructor " can not be instantiated.
*/
public function testClassCantBeInstantiatedException ()
{
$dql = " SELECT new Doctrine \T ests \ ORM \ Functional \ ClassWithPrivateConstructor(u.name) FROM Doctrine \T ests \ Models \ CMS \ CmsUser u " ;
$this -> _em -> createQuery ( $dql ) -> getResult ();
}
2012-08-12 04:52:03 +04:00
}
class ClassWithTooMuchArgs
{
public function __construct ( $foo , $bar )
{
$this -> foo = $foo ;
$this -> bor = $bar ;
}
2012-08-12 21:40:26 +04:00
}
class ClassWithPrivateConstructor
{
private function __construct ( $foo )
{
$this -> foo = $foo ;
}
2014-04-07 16:43:25 +04:00
}