1
0
mirror of synced 2025-01-07 09:37:11 +03:00

Inlined the model for the DCC2775 test case inside the test class

This commit is contained in:
Matthieu Napoli 2013-12-23 09:55:10 +01:00
parent 602c3be3fc
commit c9791fe97f
7 changed files with 102 additions and 118 deletions

View File

@ -2232,8 +2232,6 @@ class UnitOfWork implements PropertyChangedListener
$entitiesToCascade = array(); $entitiesToCascade = array();
// We need to load all related entities beforehand so that lazy collection loading doesn't
// reload entities after they have been removed (bug DDC-2775)
foreach ($associationMappings as $assoc) { foreach ($associationMappings as $assoc) {
if ($entity instanceof Proxy && !$entity->__isInitialized__) { if ($entity instanceof Proxy && !$entity->__isInitialized__) {
$entity->__load(); $entity->__load();

View File

@ -1,8 +0,0 @@
<?php
namespace Doctrine\Tests\Models\DDC2775;
/** @Entity */
class AdminRole extends Role
{
}

View File

@ -1,25 +0,0 @@
<?php
namespace Doctrine\Tests\Models\DDC2775;
/**
* @Entity @Table(name="authorizations")
*/
class Authorization
{
/**
* @Id @Column(type="integer")
* @GeneratedValue
*/
public $id;
/**
* @ManyToOne(targetEntity="User", inversedBy="authorizations")
*/
public $user;
/**
* @ManyToOne(targetEntity="Role", inversedBy="authorizations")
*/
public $role;
}

View File

@ -1,34 +0,0 @@
<?php
namespace Doctrine\Tests\Models\DDC2775;
/**
* @Entity
* @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;
}
}

View File

@ -1,37 +0,0 @@
<?php
namespace Doctrine\Tests\Models\DDC2775;
/**
* @Entity @Table(name="users")
*/
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;
}
}

View File

@ -2,9 +2,6 @@
namespace Doctrine\Tests\ORM\Functional\Ticket; namespace Doctrine\Tests\ORM\Functional\Ticket;
use Doctrine\Tests\Models\DDC2775\AdminRole;
use Doctrine\Tests\Models\DDC2775\Authorization;
use Doctrine\Tests\Models\DDC2775\User;
use Doctrine\Tests\OrmFunctionalTestCase; use Doctrine\Tests\OrmFunctionalTestCase;
/** /**
@ -14,9 +11,16 @@ use Doctrine\Tests\OrmFunctionalTestCase;
*/ */
class DDC2775Test extends OrmFunctionalTestCase class DDC2775Test extends OrmFunctionalTestCase
{ {
protected function setUp() { protected function setUp()
$this->useModelSet('ddc2775'); {
parent::setUp(); parent::setUp();
$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',
));
} }
/** /**
@ -39,7 +43,7 @@ class DDC2775Test extends OrmFunctionalTestCase
// Need to clear so that associations are lazy-loaded // Need to clear so that associations are lazy-loaded
$this->_em->clear(); $this->_em->clear();
$user = $this->_em->find('Doctrine\Tests\Models\DDC2775\User', $user->id); $user = $this->_em->find('Doctrine\Tests\ORM\Functional\Ticket\User', $user->id);
$this->_em->remove($user); $this->_em->remove($user);
$this->_em->flush(); $this->_em->flush();
@ -48,3 +52,95 @@ class DDC2775Test extends OrmFunctionalTestCase
$this->_em->flush(); $this->_em->flush();
} }
} }
/**
* @Entity
* @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;
}
}
/** @Entity */
class AdminRole extends Role
{
}
/**
* @Entity @Table(name="authorizations")
*/
class Authorization
{
/**
* @Id @Column(type="integer")
* @GeneratedValue
*/
public $id;
/**
* @ManyToOne(targetEntity="User", inversedBy="authorizations")
*/
public $user;
/**
* @ManyToOne(targetEntity="Role", inversedBy="authorizations")
*/
public $role;
}
/**
* @Entity @Table(name="users")
*/
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;
}
}

View File

@ -162,12 +162,6 @@ abstract class OrmFunctionalTestCase extends OrmTestCase
'Doctrine\Tests\Models\Taxi\Car', 'Doctrine\Tests\Models\Taxi\Car',
'Doctrine\Tests\Models\Taxi\Driver', 'Doctrine\Tests\Models\Taxi\Driver',
), ),
'ddc2775' => array(
'Doctrine\Tests\Models\DDC2775\User',
'Doctrine\Tests\Models\DDC2775\Role',
'Doctrine\Tests\Models\DDC2775\AdminRole',
'Doctrine\Tests\Models\DDC2775\Authorization',
),
); );
/** /**