1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
|
<?php
declare(strict_types=1);
namespace Doctrine\Tests\ORM\Hydration;
use Doctrine\ORM\Internal\Hydration\ScalarHydrator;
use Doctrine\ORM\Query\ResultSetMapping;
use Doctrine\Tests\Models\CMS\CmsUser;
use PHPUnit\Framework\Attributes\Group;
use PHPUnit\Framework\Attributes\RequiresPhpunit;
#[RequiresPhpunit('< 12')]
class ScalarHydratorTest extends HydrationTestCase
{
/**
* Select u.id, u.name from CmsUser u
*/
public function testNewHydrationSimpleEntityQuery(): void
{
$rsm = new ResultSetMapping();
$rsm->addEntityResult(CmsUser::class, 'u');
$rsm->addFieldResult('u', 'u__id', 'id');
$rsm->addFieldResult('u', 'u__name', 'name');
// Faked result set
$resultSet = [
[
'u__id' => '1',
'u__name' => 'romanb',
],
[
'u__id' => '2',
'u__name' => 'jwage',
],
];
$stmt = $this->createResultMock($resultSet);
$hydrator = new ScalarHydrator($this->entityManager);
$result = $hydrator->hydrateAll($stmt, $rsm);
self::assertIsArray($result);
self::assertCount(2, $result);
self::assertEquals('romanb', $result[0]['u_name']);
self::assertEquals(1, $result[0]['u_id']);
self::assertEquals('jwage', $result[1]['u_name']);
self::assertEquals(2, $result[1]['u_id']);
}
#[Group('DDC-407')]
public function testHydrateScalarResults(): void
{
$rsm = new ResultSetMapping();
$rsm->addScalarResult('foo1', 'foo', 'string');
$rsm->addScalarResult('bar2', 'bar', 'string');
$rsm->addScalarResult('baz3', 'baz', 'string');
$resultSet = [
[
'foo1' => 'A',
'bar2' => 'B',
'baz3' => 'C',
],
];
$stmt = $this->createResultMock($resultSet);
$hydrator = new ScalarHydrator($this->entityManager);
self::assertCount(1, $hydrator->hydrateAll($stmt, $rsm));
}
#[Group('DDC-644')]
public function testSkipUnknownColumns(): void
{
$rsm = new ResultSetMapping();
$rsm->addEntityResult(CmsUser::class, 'u');
$rsm->addFieldResult('u', 'u__id', 'id');
$rsm->addFieldResult('u', 'u__name', 'name');
$rsm->addScalarResult('foo1', 'foo', 'string');
$rsm->addScalarResult('bar2', 'bar', 'string');
$rsm->addScalarResult('baz3', 'baz', 'string');
$resultSet = [
[
'u__id' => '1',
'u__name' => 'romanb',
'foo1' => 'A',
'bar2' => 'B',
'baz3' => 'C',
'foo' => 'bar', // Unknown!
],
];
$stmt = $this->createResultMock($resultSet);
$hydrator = new ScalarHydrator($this->entityManager);
self::assertCount(1, $hydrator->hydrateAll($stmt, $rsm));
}
}
|