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
|
<?php
declare(strict_types=1);
namespace Doctrine\Tests\ORM\Functional\Ticket;
use Doctrine\ORM\Mapping\Column;
use Doctrine\ORM\Mapping\DiscriminatorColumn;
use Doctrine\ORM\Mapping\DiscriminatorMap;
use Doctrine\ORM\Mapping\Entity;
use Doctrine\ORM\Mapping\GeneratedValue;
use Doctrine\ORM\Mapping\Id;
use Doctrine\ORM\Mapping\InheritanceType;
use Doctrine\ORM\Mapping\Table;
use Doctrine\Tests\OrmFunctionalTestCase;
class Ticket4646InstanceOfTest extends OrmFunctionalTestCase
{
protected function setUp(): void
{
parent::setUp();
$this->createSchemaForModels(
PersonTicket4646::class,
EmployeeTicket4646::class
);
}
public function testInstanceOf(): void
{
$this->_em->persist(new PersonTicket4646());
$this->_em->persist(new EmployeeTicket4646());
$this->_em->flush();
$dql = 'SELECT p FROM Doctrine\Tests\ORM\Functional\Ticket\PersonTicket4646 p
WHERE p INSTANCE OF Doctrine\Tests\ORM\Functional\Ticket\PersonTicket4646';
$query = $this->_em->createQuery($dql);
$result = $query->getResult();
self::assertCount(2, $result);
self::assertContainsOnlyInstancesOf(PersonTicket4646::class, $result);
}
}
/**
* @Entity()
* @Table(name="instance_of_test_person")
* @InheritanceType(value="JOINED")
* @DiscriminatorColumn(name="kind", type="string")
* @DiscriminatorMap(value={
* "person": "Doctrine\Tests\ORM\Functional\Ticket\PersonTicket4646",
* "employee": "Doctrine\Tests\ORM\Functional\Ticket\EmployeeTicket4646"
* })
*/
class PersonTicket4646
{
/**
* @var int
* @Id()
* @GeneratedValue()
* @Column(type="integer")
*/
private $id;
public function getId(): ?int
{
return $this->id;
}
}
/**
* @Entity()
* @Table(name="instance_of_test_employee")
*/
class EmployeeTicket4646 extends PersonTicket4646
{
}
|