2010-04-13 07:29:29 +04:00
< ? php
namespace Doctrine\Tests\ORM\Functional\Ticket ;
class DDC448Test extends \Doctrine\Tests\OrmFunctionalTestCase
{
protected function setUp ()
{
parent :: setUp ();
$this -> _schemaTool -> createSchema ( array (
$this -> _em -> getClassMetadata ( __NAMESPACE__ . '\DDC448MainTable' ),
$this -> _em -> getClassMetadata ( __NAMESPACE__ . '\DDC448ConnectedClass' ),
$this -> _em -> getClassMetadata ( __NAMESPACE__ . '\DDC448SubTable' ),
));
}
public function testIssue ()
{
$q = $this -> _em -> createQuery ( " select b from " . __NAMESPACE__ . " \\ DDC448SubTable b where b.connectedClassId = ?1 " );
2011-10-29 20:48:34 +04:00
$this -> assertEquals (
2014-03-21 22:39:51 +04:00
strtolower ( 'SELECT d0_.id AS id_0, d0_.discr AS discr_1, d0_.connectedClassId AS connectedClassId_2 FROM SubTable s1_ INNER JOIN DDC448MainTable d0_ ON s1_.id = d0_.id WHERE d0_.connectedClassId = ?' ),
2011-10-29 20:48:34 +04:00
strtolower ( $q -> getSQL ())
);
2010-04-13 07:29:29 +04:00
}
}
/**
* @ Entity
* @ InheritanceType ( " JOINED " )
* @ DiscriminatorColumn ( name = " discr " , type = " smallint " )
* @ DiscriminatorMap ({
* " 0 " = " DDC448MainTable " ,
* " 1 " = " DDC448SubTable "
* })
*/
class DDC448MainTable
{
/**
* @ Id
* @ Column ( name = " id " , type = " integer " )
* @ GeneratedValue ( strategy = " AUTO " )
*/
private $id ;
/**
* @ ManyToOne ( targetEntity = " DDC448ConnectedClass " , cascade = { " all " }, fetch = " EAGER " )
2011-06-28 23:50:14 +04:00
* @ JoinColumn ( name = " connectedClassId " , referencedColumnName = " id " , onDelete = " CASCADE " , nullable = true )
2010-04-13 07:29:29 +04:00
*/
private $connectedClassId ;
}
/**
* @ Entity
* @ Table ( name = " connectedClass " )
* @ HasLifecycleCallbacks
*/
class DDC448ConnectedClass
{
/**
* @ Id
* @ Column ( name = " id " , type = " integer " )
* @ GeneratedValue ( strategy = " AUTO " )
*/
protected $id ; // connected with DDC448MainTable
}
/**
* @ Entity
* @ Table ( name = " SubTable " )
*/
class DDC448SubTable extends DDC448MainTable
{
}