2013-11-04 12:40:51 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Doctrine\Tests\ORM\Functional\Ticket;
|
|
|
|
|
2013-12-14 19:57:53 +01:00
|
|
|
use Doctrine\Tests\OrmFunctionalTestCase;
|
2013-11-04 12:40:51 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Functional tests for cascade remove with class table inheritance.
|
|
|
|
*
|
|
|
|
* @author Matthieu Napoli <matthieu@mnapoli.fr>
|
|
|
|
*/
|
2013-12-14 19:57:53 +01:00
|
|
|
class DDC2775Test extends OrmFunctionalTestCase
|
2013-11-04 12:40:51 +01:00
|
|
|
{
|
2013-12-23 09:55:10 +01:00
|
|
|
protected function setUp()
|
|
|
|
{
|
2013-11-04 12:40:51 +01:00
|
|
|
parent::setUp();
|
2013-12-23 09:55:10 +01:00
|
|
|
|
|
|
|
$this->setUpEntitySchema(array(
|
|
|
|
'Doctrine\Tests\ORM\Functional\Ticket\User',
|
|
|
|
'Doctrine\Tests\ORM\Functional\Ticket\Role',
|
|
|
|
'Doctrine\Tests\ORM\Functional\Ticket\AdminRole',
|
|
|
|
'Doctrine\Tests\ORM\Functional\Ticket\Authorization',
|
|
|
|
));
|
2013-11-04 12:40:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @group DDC-2775
|
|
|
|
*/
|
|
|
|
public function testIssueCascadeRemove()
|
|
|
|
{
|
|
|
|
$user = new User();
|
|
|
|
|
|
|
|
$role = new AdminRole();
|
|
|
|
$user->addRole($role);
|
|
|
|
|
|
|
|
$authorization = new Authorization();
|
|
|
|
$user->addAuthorization($authorization);
|
|
|
|
$role->addAuthorization($authorization);
|
|
|
|
|
|
|
|
$this->_em->persist($user);
|
|
|
|
$this->_em->flush();
|
|
|
|
|
|
|
|
// Need to clear so that associations are lazy-loaded
|
|
|
|
$this->_em->clear();
|
|
|
|
|
2013-12-23 09:55:10 +01:00
|
|
|
$user = $this->_em->find('Doctrine\Tests\ORM\Functional\Ticket\User', $user->id);
|
2013-11-04 12:40:51 +01:00
|
|
|
|
|
|
|
$this->_em->remove($user);
|
|
|
|
$this->_em->flush();
|
|
|
|
|
|
|
|
// With the bug, the second flush throws an error because the cascade remove didn't work correctly
|
|
|
|
$this->_em->flush();
|
|
|
|
}
|
|
|
|
}
|
2013-12-23 09:55:10 +01:00
|
|
|
|
|
|
|
/**
|
2014-01-02 23:11:07 +01:00
|
|
|
* @Entity @Table(name="ddc2775_role")
|
2013-12-23 09:55:10 +01:00
|
|
|
* @InheritanceType("JOINED")
|
|
|
|
* @DiscriminatorColumn(name="role_type", type="string")
|
|
|
|
* @DiscriminatorMap({"admin"="AdminRole"})
|
|
|
|
*/
|
|
|
|
abstract class Role
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @Id @Column(type="integer")
|
|
|
|
* @GeneratedValue
|
|
|
|
*/
|
|
|
|
public $id;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ManyToOne(targetEntity="User", inversedBy="roles")
|
|
|
|
*/
|
|
|
|
public $user;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @OneToMany(targetEntity="Authorization", mappedBy="role", cascade={"all"}, orphanRemoval=true)
|
|
|
|
*/
|
|
|
|
public $authorizations;
|
|
|
|
|
|
|
|
public function addAuthorization(Authorization $authorization)
|
|
|
|
{
|
|
|
|
$this->authorizations[] = $authorization;
|
|
|
|
$authorization->role = $this;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-01-02 23:11:07 +01:00
|
|
|
/** @Entity @Table(name="ddc2775_admin_role") */
|
2013-12-23 09:55:10 +01:00
|
|
|
class AdminRole extends Role
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-01-02 23:11:07 +01:00
|
|
|
* @Entity @Table(name="ddc2775_authorizations")
|
2013-12-23 09:55:10 +01:00
|
|
|
*/
|
|
|
|
class Authorization
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @Id @Column(type="integer")
|
|
|
|
* @GeneratedValue
|
|
|
|
*/
|
|
|
|
public $id;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ManyToOne(targetEntity="User", inversedBy="authorizations")
|
|
|
|
*/
|
|
|
|
public $user;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ManyToOne(targetEntity="Role", inversedBy="authorizations")
|
|
|
|
*/
|
|
|
|
public $role;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-01-02 23:11:07 +01:00
|
|
|
* @Entity @Table(name="ddc2775_users")
|
2013-12-23 09:55:10 +01:00
|
|
|
*/
|
|
|
|
class User
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @Id @Column(type="integer")
|
|
|
|
* @GeneratedValue(strategy="AUTO")
|
|
|
|
*/
|
|
|
|
public $id;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @OneToMany(targetEntity="Role", mappedBy="user", cascade={"all"}, orphanRemoval=true)
|
|
|
|
*/
|
|
|
|
public $roles;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @OneToMany(targetEntity="Authorization", mappedBy="user", cascade={"all"}, orphanRemoval=true)
|
|
|
|
*/
|
|
|
|
public $authorizations;
|
|
|
|
|
|
|
|
public function addRole(Role $role)
|
|
|
|
{
|
|
|
|
$this->roles[] = $role;
|
|
|
|
$role->user = $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function addAuthorization(Authorization $authorization)
|
|
|
|
{
|
|
|
|
$this->authorizations[] = $authorization;
|
|
|
|
$authorization->user = $this;
|
|
|
|
}
|
|
|
|
}
|