1
0
mirror of synced 2025-02-09 00:39:25 +03:00

Merge branch 'hotfix/#1572-target-entity-resolver-dql-with-interfaces-support' into 2.5

Close #1572
This commit is contained in:
Marco Pivetta 2015-12-11 21:35:18 +01:00
commit 7065ff0ac9
2 changed files with 31 additions and 5 deletions

View File

@ -965,7 +965,7 @@ class Parser
$schemaName = $this->em->getConfiguration()->getEntityNamespace($namespaceAlias) . '\\' . $simpleClassName; $schemaName = $this->em->getConfiguration()->getEntityNamespace($namespaceAlias) . '\\' . $simpleClassName;
} }
$exists = class_exists($schemaName, true); $exists = class_exists($schemaName, true) || interface_exists($schemaName, true);
if ( ! $exists) { if ( ! $exists) {
$this->semanticalError("Class '$schemaName' is not defined.", $this->lexer->token); $this->semanticalError("Class '$schemaName' is not defined.", $this->lexer->token);

View File

@ -9,19 +9,19 @@ use Doctrine\ORM\Events;
class ResolveTargetEntityListenerTest extends \Doctrine\Tests\OrmTestCase class ResolveTargetEntityListenerTest extends \Doctrine\Tests\OrmTestCase
{ {
/** /**
* @var EntityManager * @var \Doctrine\ORM\EntityManager
*/ */
private $em = null; private $em;
/** /**
* @var ResolveTargetEntityListener * @var ResolveTargetEntityListener
*/ */
private $listener = null; private $listener;
/** /**
* @var ClassMetadataFactory * @var ClassMetadataFactory
*/ */
private $factory = null; private $factory;
public function setUp() public function setUp()
{ {
@ -106,6 +106,32 @@ class ResolveTargetEntityListenerTest extends \Doctrine\Tests\OrmTestCase
$this->assertSame('Doctrine\Tests\ORM\Tools\TargetEntity', $meta['targetEntity']); $this->assertSame('Doctrine\Tests\ORM\Tools\TargetEntity', $meta['targetEntity']);
$this->assertEquals(array('resolvetargetentity_id', 'targetinterface_id'), $meta['joinTableColumns']); $this->assertEquals(array('resolvetargetentity_id', 'targetinterface_id'), $meta['joinTableColumns']);
} }
/**
* @group 1572
* @group functional
*
* @coversNothing
*/
public function testDoesResolveTargetEntitiesInDQLAlsoWithInterfaces()
{
$evm = $this->em->getEventManager();
$this->listener->addResolveTargetEntity(
'Doctrine\Tests\ORM\Tools\ResolveTargetInterface',
'Doctrine\Tests\ORM\Tools\ResolveTargetEntity',
array()
);
$evm->addEventSubscriber($this->listener);
$this->assertStringMatchesFormat(
'SELECT%AFROM ResolveTargetEntity%A',
$this
->em
->createQuery('SELECT f FROM Doctrine\Tests\ORM\Tools\ResolveTargetInterface f')
->getSQL()
);
}
} }
interface ResolveTargetInterface interface ResolveTargetInterface