2009-01-13 21:56:43 +00:00
|
|
|
<?php
|
|
|
|
|
2009-01-22 19:38:10 +00:00
|
|
|
namespace Doctrine\Tests\ORM\Hydration;
|
|
|
|
|
|
|
|
use Doctrine\Tests\Mocks\HydratorMockStatement;
|
|
|
|
|
2009-01-24 16:56:44 +00:00
|
|
|
require_once __DIR__ . '/../../TestInit.php';
|
2009-01-13 21:56:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Description of ScalarHydratorTest
|
|
|
|
*
|
|
|
|
* @author robo
|
|
|
|
*/
|
2009-01-22 19:38:10 +00:00
|
|
|
class ScalarHydratorTest extends HydrationTest
|
2009-01-13 21:56:43 +00:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Select u.id, u.name from CmsUser u
|
|
|
|
*/
|
|
|
|
public function testNewHydrationSimpleEntityQuery()
|
|
|
|
{
|
|
|
|
// Faked query components
|
|
|
|
$queryComponents = array(
|
|
|
|
'u' => array(
|
2009-01-22 19:38:10 +00:00
|
|
|
'metadata' => $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsUser'),
|
2009-01-13 21:56:43 +00:00
|
|
|
'parent' => null,
|
|
|
|
'relation' => null,
|
|
|
|
'map' => null
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
// Faked table alias map
|
|
|
|
$tableAliasMap = array(
|
|
|
|
'u' => 'u'
|
|
|
|
);
|
|
|
|
|
|
|
|
// Faked result set
|
|
|
|
$resultSet = array(
|
|
|
|
array(
|
|
|
|
'u__id' => '1',
|
|
|
|
'u__name' => 'romanb'
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'u__id' => '2',
|
|
|
|
'u__name' => 'jwage'
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2009-01-22 19:38:10 +00:00
|
|
|
$stmt = new HydratorMockStatement($resultSet);
|
|
|
|
$hydrator = new \Doctrine\ORM\Internal\Hydration\ScalarHydrator($this->_em);
|
2009-01-13 21:56:43 +00:00
|
|
|
|
|
|
|
$result = $hydrator->hydrateAll($stmt, $this->_createParserResult(
|
2009-01-15 13:30:44 +00:00
|
|
|
$queryComponents, $tableAliasMap));
|
2009-01-13 21:56:43 +00:00
|
|
|
|
|
|
|
$this->assertTrue(is_array($result));
|
|
|
|
$this->assertEquals(2, count($result));
|
|
|
|
$this->assertEquals('romanb', $result[0]['u_name']);
|
|
|
|
$this->assertEquals(1, $result[0]['u_id']);
|
|
|
|
$this->assertEquals('jwage', $result[1]['u_name']);
|
|
|
|
$this->assertEquals(2, $result[1]['u_id']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|