3 namespace Doctrine\Tests\ORM\Hydration;
5 use Doctrine\ORM\Query\ResultSetMapping;
6 use Doctrine\ORM\Mapping\ClassMetadata;
8 require_once __DIR__ . '/../../TestInit.php';
11 * Description of ResultSetMappingTest
15 class ResultSetMappingTest extends \Doctrine\Tests\OrmTestCase
18 * @var ResultSetMapping
23 * @var \Doctrine\ORM\EntityManager
27 protected function setUp() {
29 $this->_rsm = new ResultSetMapping;
30 $this->_em = $this->_getTestEntityManager();
34 * For SQL: SELECT id, status, username, name FROM cms_users
36 public function testBasicResultSetMapping()
38 $this->_rsm->addEntityResult(
39 'Doctrine\Tests\Models\CMS\CmsUser',
42 $this->_rsm->addFieldResult('u', 'id', 'id');
43 $this->_rsm->addFieldResult('u', 'status', 'status');
44 $this->_rsm->addFieldResult('u', 'username', 'username');
45 $this->_rsm->addFieldResult('u', 'name', 'name');
47 $this->assertFalse($this->_rsm->isScalarResult('id'));
48 $this->assertFalse($this->_rsm->isScalarResult('status'));
49 $this->assertFalse($this->_rsm->isScalarResult('username'));
50 $this->assertFalse($this->_rsm->isScalarResult('name'));
52 $this->assertTrue($this->_rsm->getClassName('u') == 'Doctrine\Tests\Models\CMS\CmsUser');
53 $class = $this->_rsm->getDeclaringClass('id');
54 $this->assertTrue($class == 'Doctrine\Tests\Models\CMS\CmsUser');
56 $this->assertEquals('u', $this->_rsm->getEntityAlias('id'));
57 $this->assertEquals('u', $this->_rsm->getEntityAlias('status'));
58 $this->assertEquals('u', $this->_rsm->getEntityAlias('username'));
59 $this->assertEquals('u', $this->_rsm->getEntityAlias('name'));
61 $this->assertEquals('id', $this->_rsm->getFieldName('id'));
62 $this->assertEquals('status', $this->_rsm->getFieldName('status'));
63 $this->assertEquals('username', $this->_rsm->getFieldName('username'));
64 $this->assertEquals('name', $this->_rsm->getFieldName('name'));
70 * Fluent interface test, not a real result set mapping
72 public function testFluentInterface()
76 $rms->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser','u')
77 ->addJoinedEntityResult('Doctrine\Tests\Models\CMS\CmsPhonenumber','p','u','phonenumbers')
78 ->addFieldResult('u', 'id', 'id')
79 ->addFieldResult('u', 'name', 'name')
80 ->setDiscriminatorColumn('name', 'name')
81 ->addIndexByColumn('id', 'id')
82 ->addIndexBy('username', 'username')
83 ->addIndexByScalar('sclr0')
84 ->addScalarResult('sclr0', 'numPhones')
85 ->addMetaResult('a', 'user_id', 'user_id');
88 $this->assertTrue($rms->hasIndexBy('id'));
89 $this->assertTrue($rms->isFieldResult('id'));
90 $this->assertTrue($rms->isFieldResult('name'));
91 $this->assertTrue($rms->isScalarResult('sclr0'));
92 $this->assertTrue($rms->isRelation('p'));
93 $this->assertTrue($rms->hasParentAlias('p'));
94 $this->assertTrue($rms->isMixedResult());
100 public function testAddNamedNativeQueryResultSetMapping()
102 $cm = new ClassMetadata('Doctrine\Tests\Models\CMS\CmsUser');
103 $cm->initializeReflection(new \Doctrine\Common\Persistence\Mapping\RuntimeReflectionService);
105 $cm->mapOneToOne(array(
106 'fieldName' => 'email',
107 'targetEntity' => 'Doctrine\Tests\Models\CMS\CmsEmail',
108 'cascade' => array('persist'),
109 'inversedBy' => 'user',
110 'orphanRemoval' => false,
111 'joinColumns' => array(array(
113 'referencedColumnName' => 'id',
118 $cm->addNamedNativeQuery(array(
119 'name' => 'find-all',
120 'query' => 'SELECT u.id AS user_id, e.id AS email_id, u.name, e.email, u.id + e.id AS scalarColumn FROM cms_users u INNER JOIN cms_emails e ON e.id = u.email_id',
121 'resultSetMapping' => 'find-all',
123 $cm->addSqlResultSetMapping(array(
124 'name' => 'find-all',
127 'entityClass' => '__CLASS__',
140 'entityClass' => 'CmsEmail',
144 'column'=> 'email_id'
155 'name' => 'scalarColumn'
161 $queryMapping = $cm->getNamedNativeQuery('find-all');
163 $rsm = new \Doctrine\ORM\Query\ResultSetMappingBuilder($this->_em);
164 $rsm->addNamedNativeQueryMapping($cm, $queryMapping);
166 $this->assertEquals('scalarColumn', $rsm->getScalarAlias('scalarColumn'));
168 $this->assertEquals('c0', $rsm->getEntityAlias('user_id'));
169 $this->assertEquals('c0', $rsm->getEntityAlias('name'));
170 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getClassName('c0'));
171 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getDeclaringClass('name'));
172 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getDeclaringClass('user_id'));
175 $this->assertEquals('c1', $rsm->getEntityAlias('email_id'));
176 $this->assertEquals('c1', $rsm->getEntityAlias('email'));
177 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsEmail', $rsm->getClassName('c1'));
178 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsEmail', $rsm->getDeclaringClass('email'));
179 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsEmail', $rsm->getDeclaringClass('email_id'));
185 public function testAddNamedNativeQueryResultSetMappingWithoutFields()
187 $cm = new ClassMetadata('Doctrine\Tests\Models\CMS\CmsUser');
188 $cm->initializeReflection(new \Doctrine\Common\Persistence\Mapping\RuntimeReflectionService);
190 $cm->addNamedNativeQuery(array(
191 'name' => 'find-all',
192 'query' => 'SELECT u.id AS user_id, e.id AS email_id, u.name, e.email, u.id + e.id AS scalarColumn FROM cms_users u INNER JOIN cms_emails e ON e.id = u.email_id',
193 'resultSetMapping' => 'find-all',
195 $cm->addSqlResultSetMapping(array(
196 'name' => 'find-all',
199 'entityClass' => '__CLASS__',
204 'name' => 'scalarColumn'
210 $queryMapping = $cm->getNamedNativeQuery('find-all');
212 $rsm = new \Doctrine\ORM\Query\ResultSetMappingBuilder($this->_em);
213 $rsm->addNamedNativeQueryMapping($cm, $queryMapping);
215 $this->assertEquals('scalarColumn', $rsm->getScalarAlias('scalarColumn'));
217 $this->assertEquals('c0', $rsm->getEntityAlias('id'));
218 $this->assertEquals('c0', $rsm->getEntityAlias('name'));
219 $this->assertEquals('c0', $rsm->getEntityAlias('status'));
220 $this->assertEquals('c0', $rsm->getEntityAlias('username'));
221 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getClassName('c0'));
222 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getDeclaringClass('id'));
223 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getDeclaringClass('name'));
224 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getDeclaringClass('status'));
225 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getDeclaringClass('username'));
231 public function testAddNamedNativeQueryResultClass()
233 $cm = new ClassMetadata('Doctrine\Tests\Models\CMS\CmsUser');
234 $cm->initializeReflection(new \Doctrine\Common\Persistence\Mapping\RuntimeReflectionService);
236 $cm->addNamedNativeQuery(array(
237 'name' => 'find-all',
238 'resultClass' => '__CLASS__',
239 'query' => 'SELECT * FROM cms_users',
242 $queryMapping = $cm->getNamedNativeQuery('find-all');
244 $rsm = new \Doctrine\ORM\Query\ResultSetMappingBuilder($this->_em);
245 $rsm->addNamedNativeQueryMapping($cm, $queryMapping);
248 $this->assertEquals('c0', $rsm->getEntityAlias('id'));
249 $this->assertEquals('c0', $rsm->getEntityAlias('name'));
250 $this->assertEquals('c0', $rsm->getEntityAlias('status'));
251 $this->assertEquals('c0', $rsm->getEntityAlias('username'));
252 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getClassName('c0'));
253 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getDeclaringClass('id'));
254 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getDeclaringClass('name'));
255 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getDeclaringClass('status'));
256 $this->assertEquals('Doctrine\Tests\Models\CMS\CmsUser', $rsm->getDeclaringClass('username'));