Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

DDC-1400 working testcase

  • Loading branch information...
commit dc0a03ab3074c090153050c117dc828d37855abc 1 parent f9a4dcb
@beberlei beberlei authored
Showing with 136 additions and 0 deletions.
  1. +136 −0 tests/Doctrine/Tests/ORM/Functional/Ticket/DDC1400Test.php
View
136 tests/Doctrine/Tests/ORM/Functional/Ticket/DDC1400Test.php
@@ -0,0 +1,136 @@
+<?php
+
+namespace Doctrine\Tests\ORM\Functional\Ticket;
+use Doctrine\ORM\UnitOfWork;
+
+require_once __DIR__ . '/../../../TestInit.php';
+
+/**
+ * @group DDC-1400
+ */
+class DDC1400Test extends \Doctrine\Tests\OrmFunctionalTestCase
+{
+ protected function setUp()
+ {
+ parent::setUp();
+
+ try {
+ $this->_schemaTool->createSchema(array(
+ $this->_em->getClassMetadata(__NAMESPACE__ . '\DDC1400Article'),
+ $this->_em->getClassMetadata(__NAMESPACE__ . '\DDC1400User'),
+ $this->_em->getClassMetadata(__NAMESPACE__ . '\DDC1400UserState'),
+ ));
+ } catch (\Exception $ignored) {
+ }
+ }
+
+ public function testFailingCase()
+ {
+ $article = new DDC1400Article;
+ $user1 = new DDC1400User;
+ $user2 = new DDC1400User;
+
+ $this->_em->persist($article);
+ $this->_em->persist($user1);
+ $this->_em->persist($user2);
+ $this->_em->flush();
+
+ $userState1 = new DDC1400UserState;
+ $userState1->article = $article;
+ $userState1->articleId = $article->id;
+ $userState1->user = $user1;
+ $userState1->userId = $user1->id;
+
+ $userState2 = new DDC1400UserState;
+ $userState2->article = $article;
+ $userState2->articleId = $article->id;
+ $userState2->user = $user2;
+ $userState2->userId = $user2->id;
+
+ $this->_em->persist($userState1);
+ $this->_em->persist($userState2);
+
+ $this->_em->flush();
+ $this->_em->clear();
+
+ $user1 = $this->_em->getReference(__NAMESPACE__.'\DDC1400User', $user1->id);
+
+ $q = $this->_em->createQuery("SELECT a, s FROM ".__NAMESPACE__."\DDC1400Article a JOIN a.userStates s WITH s.user = :activeUser");
+ $q->setParameter('activeUser', $user1);
+ $articles = $q->getResult();
+
+ var_dump(array_keys($articles[0]->userStates->toArray()));
+
+ $this->_em->flush();
+ var_dump($this->_sqlLoggerStack);
+
+
+ }
+}
+
+/**
+ * @Entity
+ */
+class DDC1400Article
+{
+ /**
+ * @Id
+ * @Column(type="integer")
+ * @GeneratedValue
+ */
+ public $id;
+
+ /**
+ * @OneToMany(targetEntity="DDC1400UserState", mappedBy="article", indexBy="userId", fetch="EXTRA_LAZY")
+ */
+ public $userStates;
+}
+
+/**
+ * @Entity
+ */
+class DDC1400User
+{
+
+ /**
+ * @Id
+ * @Column(type="integer")
+ * @GeneratedValue
+ */
+ public $id;
+
+ /**
+ * @OneToMany(targetEntity="DDC1400UserState", mappedBy="user", indexBy="articleId", fetch="EXTRA_LAZY")
+ */
+ public $userStates;
+}
+
+/**
+ * @Entity
+ */
+class DDC1400UserState
+{
+
+ /**
+ * @Id
+ * @ManyToOne(targetEntity="DDC1400Article", inversedBy="userStates")
+ */
+ public $article;
+
+ /**
+ * @Id
+ * @ManyToOne(targetEntity="DDC1400User", inversedBy="userStates")
+ */
+ public $user;
+
+ /**
+ * @Column(name="user_id", type="integer")
+ */
+ public $userId;
+
+ /**
+ * @Column(name="article_id", type="integer")
+ */
+ public $articleId;
+
+}
Please sign in to comment.
Something went wrong with that request. Please try again.