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
|
<?php
declare(strict_types=1);
namespace Doctrine\Tests\ORM\Functional\Ticket;
use Doctrine\ORM\Mapping as ORM;
use Doctrine\ORM\Mapping\Column;
use Doctrine\ORM\Mapping\Entity;
use Doctrine\ORM\Mapping\Id;
use Doctrine\ORM\Mapping\ManyToOne;
use Doctrine\ORM\Mapping\MappedSuperclass;
use Doctrine\ORM\Mapping\OneToMany;
use Doctrine\Tests\OrmFunctionalTestCase;
class GH9516Test extends OrmFunctionalTestCase
{
public function testEntityCanHaveInverseOneToManyAssociationWithChildMappedSuperclass(): void
{
$sportsCarMetadata = $this->_em->getClassMetadata(GH9516SportsCar::class);
$this->assertTrue($sportsCarMetadata->hasAssociation('passengers'));
}
}
#[Entity]
class GH9516Passenger
{
/** @var int $id */
#[Id]
#[Column(type: 'integer')]
private $id;
/** @var GH9516Vehicle $vehicle */
#[ManyToOne(targetEntity: GH9516Vehicle::class, inversedBy: 'passengers')]
private $vehicle;
}
#[ORM\DiscriminatorColumn(name: 'type', type: 'string')]
#[ORM\DiscriminatorMap(['sports' => GH9516SportsCar::class])]
#[ORM\InheritanceType('SINGLE_TABLE')]
#[Entity]
abstract class GH9516Vehicle
{
/** @var int $id */
#[Id]
#[Column(type: 'integer')]
private $id;
/** @var GH9516Passenger[] $passengers */
#[OneToMany(targetEntity: GH9516Passenger::class, mappedBy: 'vehicle')]
private $passengers;
}
#[MappedSuperclass]
abstract class GH9516Car extends GH9516Vehicle
{
}
#[Entity]
class GH9516SportsCar extends GH9516Car
{
}
|