1
0
mirror of synced 2025-02-03 13:59:27 +03:00
doctrine2/tests/Doctrine/Tests/ORM/Functional/CascadeRemoveOrderTest.php

167 lines
3.8 KiB
PHP
Raw Normal View History

<?php
namespace Doctrine\Tests\ORM\Functional;
use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\Tests\OrmFunctionalTestCase;
/**
* @group CascadeRemoveOrderTest
*/
class CascadeRemoveOrderTest extends OrmFunctionalTestCase
{
protected function setUp()
{
parent::setUp();
$this->_schemaTool->createSchema(
[
2017-05-31 07:59:04 +02:00
$this->_em->getClassMetadata(CascadeRemoveOrderEntityO::class),
$this->_em->getClassMetadata(CascadeRemoveOrderEntityG::class),
]
);
}
protected function tearDown()
{
parent::tearDown();
$this->_schemaTool->dropSchema(
[
2017-05-31 07:59:04 +02:00
$this->_em->getClassMetadata(CascadeRemoveOrderEntityO::class),
$this->_em->getClassMetadata(CascadeRemoveOrderEntityG::class),
]
);
}
public function testSingle()
{
$eO = new CascadeRemoveOrderEntityO();
$eG = new CascadeRemoveOrderEntityG($eO);
$this->_em->persist($eO);
$this->_em->flush();
$this->_em->clear();
$eOloaded = $this->_em->find(CascadeRemoveOrderEntityO::class, $eO->getId());
$this->_em->remove($eOloaded);
$this->_em->flush();
self::assertNull($this->_em->find(CascadeRemoveOrderEntityG::class, $eG->getId()));
}
public function testMany()
{
$eO = new CascadeRemoveOrderEntityO();
$eG1 = new CascadeRemoveOrderEntityG($eO);
$eG2 = new CascadeRemoveOrderEntityG($eO);
$eG3 = new CascadeRemoveOrderEntityG($eO);
$eO->setOneToOneG($eG2);
$this->_em->persist($eO);
$this->_em->flush();
$this->_em->clear();
$eOloaded = $this->_em->find(CascadeRemoveOrderEntityO::class, $eO->getId());
$this->_em->remove($eOloaded);
$this->_em->flush();
self::assertNull($this->_em->find(CascadeRemoveOrderEntityG::class, $eG1->getId()));
self::assertNull($this->_em->find(CascadeRemoveOrderEntityG::class, $eG2->getId()));
self::assertNull($this->_em->find(CascadeRemoveOrderEntityG::class, $eG3->getId()));
}
}
/**
* @Entity
*/
class CascadeRemoveOrderEntityO
{
/**
* @Id @Column(type="integer")
* @GeneratedValue
*/
private $id;
/**
* @OneToOne(targetEntity="Doctrine\Tests\ORM\Functional\CascadeRemoveOrderEntityG")
* @JoinColumn(nullable=true, onDelete="SET NULL")
*/
private $oneToOneG;
/**
* @OneToMany(
* targetEntity="Doctrine\Tests\ORM\Functional\CascadeRemoveOrderEntityG",
* mappedBy="ownerO",
* cascade={"persist", "remove"}
* )
*/
private $oneToManyG;
public function __construct()
{
$this->oneToManyG = new ArrayCollection();
}
public function getId()
{
return $this->id;
}
public function setOneToOneG(CascadeRemoveOrderEntityG $eG)
{
$this->oneToOneG = $eG;
}
public function getOneToOneG()
{
return $this->oneToOneG;
}
public function addOneToManyG(CascadeRemoveOrderEntityG $eG)
{
$this->oneToManyG->add($eG);
}
public function getOneToManyGs()
{
return $this->oneToManyG->toArray();
}
}
/**
* @Entity
*/
class CascadeRemoveOrderEntityG
{
/**
* @Id @Column(type="integer")
* @GeneratedValue
*/
private $id;
/**
* @ManyToOne(
* targetEntity="Doctrine\Tests\ORM\Functional\CascadeRemoveOrderEntityO",
* inversedBy="oneToMany"
* )
*/
private $ownerO;
public function __construct(CascadeRemoveOrderEntityO $eO, $position=1)
{
$this->position = $position;
$this->ownerO= $eO;
$this->ownerO->addOneToManyG($this);
}
public function getId()
{
return $this->id;
}
}