193 lines
4.3 KiB
PHP
193 lines
4.3 KiB
PHP
<?php
|
|
|
|
namespace Doctrine\Tests\ORM\Functional\Ticket;
|
|
|
|
use Doctrine\Common\Collections\ArrayCollection;
|
|
use Doctrine\Tests\Models\CMS\CmsUser;
|
|
use Doctrine\Tests\Models\CMS\CmsGroup;
|
|
|
|
class DDC832Test extends \Doctrine\Tests\OrmFunctionalTestCase
|
|
{
|
|
public function setUp()
|
|
{
|
|
parent::setUp();
|
|
$platform = $this->_em->getConnection()->getDatabasePlatform();
|
|
if ($platform->getName() == "oracle") {
|
|
$this->markTestSkipped('Doesnt run on Oracle.');
|
|
}
|
|
|
|
$this->_em->getConfiguration()->setSQLLogger(new \Doctrine\DBAL\Logging\EchoSQLLogger());
|
|
try {
|
|
$this->_schemaTool->createSchema(array(
|
|
$this->_em->getClassMetadata(__NAMESPACE__ . '\DDC832JoinedIndex'),
|
|
$this->_em->getClassMetadata(__NAMESPACE__ . '\DDC832JoinedTreeIndex'),
|
|
$this->_em->getClassMetadata(__NAMESPACE__ . '\DDC832Like'),
|
|
));
|
|
} catch(\Exception $e) {
|
|
|
|
}
|
|
}
|
|
|
|
public function tearDown()
|
|
{
|
|
/* @var $sm \Doctrine\DBAL\Schema\AbstractSchemaManager */
|
|
$platform = $this->_em->getConnection()->getDatabasePlatform();
|
|
$sm = $this->_em->getConnection()->getSchemaManager();
|
|
$sm->dropTable($platform->quoteIdentifier('TREE_INDEX'));
|
|
$sm->dropTable($platform->quoteIdentifier('INDEX'));
|
|
$sm->dropTable($platform->quoteIdentifier('LIKE'));
|
|
}
|
|
|
|
/**
|
|
* @group DDC-832
|
|
*/
|
|
public function testQuotedTableBasicUpdate()
|
|
{
|
|
$like = new DDC832Like("test");
|
|
$this->_em->persist($like);
|
|
$this->_em->flush();
|
|
|
|
$like->word = "test2";
|
|
$this->_em->flush();
|
|
}
|
|
|
|
/**
|
|
* @group DDC-832
|
|
*/
|
|
public function testQuotedTableBasicRemove()
|
|
{
|
|
$like = new DDC832Like("test");
|
|
$this->_em->persist($like);
|
|
$this->_em->flush();
|
|
|
|
$this->_em->remove($like);
|
|
$this->_em->flush();
|
|
}
|
|
|
|
/**
|
|
* @group DDC-832
|
|
*/
|
|
public function testQuotedTableJoinedUpdate()
|
|
{
|
|
$index = new DDC832JoinedIndex("test");
|
|
$this->_em->persist($index);
|
|
$this->_em->flush();
|
|
|
|
$index->name = "asdf";
|
|
$this->_em->flush();
|
|
}
|
|
|
|
/**
|
|
* @group DDC-832
|
|
*/
|
|
public function testQuotedTableJoinedRemove()
|
|
{
|
|
$index = new DDC832JoinedIndex("test");
|
|
$this->_em->persist($index);
|
|
$this->_em->flush();
|
|
|
|
$this->_em->remove($index);
|
|
$this->_em->flush();
|
|
}
|
|
|
|
/**
|
|
* @group DDC-832
|
|
*/
|
|
public function testQuotedTableJoinedChildUpdate()
|
|
{
|
|
$index = new DDC832JoinedTreeIndex("test", 1, 2);
|
|
$this->_em->persist($index);
|
|
$this->_em->flush();
|
|
|
|
$index->name = "asdf";
|
|
$this->_em->flush();
|
|
}
|
|
|
|
/**
|
|
* @group DDC-832
|
|
*/
|
|
public function testQuotedTableJoinedChildRemove()
|
|
{
|
|
$index = new DDC832JoinedTreeIndex("test", 1, 2);
|
|
$this->_em->persist($index);
|
|
$this->_em->flush();
|
|
|
|
$this->_em->remove($index);
|
|
$this->_em->flush();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Entity
|
|
* @Table(name="`LIKE`")
|
|
*/
|
|
class DDC832Like
|
|
{
|
|
/**
|
|
* @Id @Column(type="integer") @GeneratedValue
|
|
*/
|
|
public $id;
|
|
|
|
/** @Column(type="string") */
|
|
public $word;
|
|
|
|
/**
|
|
* @version
|
|
* @Column(type="integer")
|
|
*/
|
|
public $version;
|
|
|
|
public function __construct($word)
|
|
{
|
|
$this->word = $word;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Entity
|
|
* @Table(name="`INDEX`")
|
|
* @InheritanceType("JOINED")
|
|
* @DiscriminatorColumn(name="discr", type="string")
|
|
* @DiscriminatorMap({"like" = "DDC832JoinedIndex", "fuzzy" = "DDC832JoinedTreeIndex"})
|
|
*/
|
|
class DDC832JoinedIndex
|
|
{
|
|
/**
|
|
* @Id @Column(type="integer") @GeneratedValue
|
|
*/
|
|
public $id;
|
|
|
|
/** @Column(type="string") */
|
|
public $name;
|
|
|
|
/**
|
|
* @version
|
|
* @Column(type="integer")
|
|
*/
|
|
public $version;
|
|
|
|
public function __construct($name)
|
|
{
|
|
$this->name = $name;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Entity
|
|
* @Table(name="`TREE_INDEX`")
|
|
*/
|
|
class DDC832JoinedTreeIndex extends DDC832JoinedIndex
|
|
{
|
|
/** @Column(type="integer") */
|
|
public $lft;
|
|
/** @Column(type="integer") */
|
|
public $rgt;
|
|
|
|
public function __construct($name, $lft, $rgt)
|
|
{
|
|
$this->name = $name;
|
|
$this->lft = $lft;
|
|
$this->rgt = $rgt;
|
|
}
|
|
}
|