Rajout de doctrine/orm
[zf2.biz/application_blanche.git] / vendor / doctrine / orm / tests / Doctrine / Tests / ORM / Functional / Ticket / DDC832Test.php
diff --git a/vendor/doctrine/orm/tests/Doctrine/Tests/ORM/Functional/Ticket/DDC832Test.php b/vendor/doctrine/orm/tests/Doctrine/Tests/ORM/Functional/Ticket/DDC832Test.php
new file mode 100644 (file)
index 0000000..599218b
--- /dev/null
@@ -0,0 +1,194 @@
+<?php
+
+namespace Doctrine\Tests\ORM\Functional\Ticket;
+
+use Doctrine\Common\Collections\ArrayCollection;
+use Doctrine\Tests\Models\CMS\CmsUser;
+use Doctrine\Tests\Models\CMS\CmsGroup;
+
+require_once __DIR__ . '/../../../TestInit.php';
+
+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;
+    }
+}
\ No newline at end of file