123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- <?php
- namespace Doctrine\Tests\ORM\Functional\Ticket;
- use DateTime;
- require_once __DIR__ . '/../../../TestInit.php';
- class DDC698Test extends \Doctrine\Tests\OrmFunctionalTestCase
- {
- protected function setUp()
- {
- parent::setUp();
- try {
- $this->_schemaTool->createSchema(array(
- $this->_em->getClassMetadata(__NAMESPACE__ . '\DDC698Role'),
- $this->_em->getClassMetadata(__NAMESPACE__ . '\DDC698Privilege')
- ));
- } catch(\Exception $e) {
- }
- }
- public function testTicket()
- {
- $qb = $this->_em->createQueryBuilder();
- $qb->select('p', 'r')
- ->from(__NAMESPACE__ . '\DDC698Privilege', 'p')
- ->leftJoin('p.roles', 'r');
- $sql = $qb->getQuery()->getSQL();
- $this->assertEquals(
- strtolower('SELECT p0_.privilegeID AS privilegeID0, p0_.name AS name1, r1_.roleID AS roleID2, r1_.name AS name3, r1_.shortName AS shortName4 FROM Privileges p0_ LEFT JOIN RolePrivileges r2_ ON p0_.privilegeID = r2_.privilegeID LEFT JOIN Roles r1_ ON r1_.roleID = r2_.roleID'),
- strtolower($sql)
- );
- }
- }
- /**
- *
- * @Table(name="Roles")
- * @Entity
- */
- class DDC698Role
- {
- /**
- * @Id @Column(name="roleID", type="integer")
- * @GeneratedValue(strategy="AUTO")
- *
- */
- protected $roleID;
- /**
- * @Column(name="name", type="string", length=45)
- *
- *
- */
- protected $name;
- /**
- * @Column(name="shortName", type="string", length=45)
- *
- *
- */
- protected $shortName;
- /**
- * @ManyToMany(targetEntity="DDC698Privilege", inversedBy="roles")
- * @JoinTable(name="RolePrivileges",
- * joinColumns={@JoinColumn(name="roleID", referencedColumnName="roleID")},
- * inverseJoinColumns={@JoinColumn(name="privilegeID", referencedColumnName="privilegeID")}
- * )
- */
- protected $privilege;
- }
- /**
- *
- * @Table(name="Privileges")
- * @Entity()
- */
- class DDC698Privilege
- {
- /**
- * @Id @Column(name="privilegeID", type="integer")
- * @GeneratedValue(strategy="AUTO")
- *
- */
- protected $privilegeID;
- /**
- * @Column(name="name", type="string", length=45)
- *
- *
- */
- protected $name;
- /**
- * @ManyToMany(targetEntity="DDC698Role", mappedBy="privilege")
- */
- protected $roles;
- }
|