X-Git-Url: http://git.inspyration.org/?a=blobdiff_plain;f=vendor%2Fdoctrine%2Form%2Ftests%2FDoctrine%2FTests%2FORM%2FFunctional%2FTicket%2FDDC522Test.php;fp=vendor%2Fdoctrine%2Form%2Ftests%2FDoctrine%2FTests%2FORM%2FFunctional%2FTicket%2FDDC522Test.php;h=f029e95e9576b9393d2fdf56cee3f838e2670189;hb=8b04b2d11798dee4f3e1358e4f43e97a6df851f6;hp=0000000000000000000000000000000000000000;hpb=73568cf05a785a45f94ca3f2351d9e07bf917958;p=zf2.biz%2Fgalerie.git diff --git a/vendor/doctrine/orm/tests/Doctrine/Tests/ORM/Functional/Ticket/DDC522Test.php b/vendor/doctrine/orm/tests/Doctrine/Tests/ORM/Functional/Ticket/DDC522Test.php new file mode 100644 index 0000000..f029e95 --- /dev/null +++ b/vendor/doctrine/orm/tests/Doctrine/Tests/ORM/Functional/Ticket/DDC522Test.php @@ -0,0 +1,121 @@ +_schemaTool->createSchema(array( + $this->_em->getClassMetadata(__NAMESPACE__ . '\DDC522Customer'), + $this->_em->getClassMetadata(__NAMESPACE__ . '\DDC522Cart'), + $this->_em->getClassMetadata(__NAMESPACE__ . '\DDC522ForeignKeyTest') + )); + } catch(\Exception $e) { + + } + } + + /** + * @group DDC-522 + */ + public function testJoinColumnWithSameNameAsAssociationField() + { + //$this->_em->getConnection()->getConfiguration()->setSQLLogger(new \Doctrine\DBAL\Logging\EchoSQLLogger); + + $cust = new DDC522Customer; + $cust->name = "name"; + $cart = new DDC522Cart; + $cart->total = 0; + $cust->cart = $cart; + $cart->customer = $cust; + $this->_em->persist($cust); + $this->_em->persist($cart); + $this->_em->flush(); + + $this->_em->clear(); + + $r = $this->_em->createQuery("select ca,c from ".get_class($cart)." ca join ca.customer c") + ->getResult(); + + $this->assertInstanceOf(__NAMESPACE__ . '\DDC522Cart', $r[0]); + $this->assertInstanceOf(__NAMESPACE__ . '\DDC522Customer', $r[0]->customer); + $this->assertNotInstanceOf('Doctrine\ORM\Proxy\Proxy', $r[0]->customer); + $this->assertEquals('name', $r[0]->customer->name); + + $fkt = new DDC522ForeignKeyTest(); + $fkt->cartId = $r[0]->id; // ignored for persistence + $fkt->cart = $r[0]; // must be set properly + $this->_em->persist($fkt); + $this->_em->flush(); + $this->_em->clear(); + + $fkt2 = $this->_em->find(get_class($fkt), $fkt->id); + $this->assertEquals($fkt->cart->id, $fkt2->cartId); + $this->assertInstanceOf('Doctrine\ORM\Proxy\Proxy', $fkt2->cart); + $this->assertFalse($fkt2->cart->__isInitialized__); + } + + /** + * @group DDC-522 + * @group DDC-762 + */ + public function testJoinColumnWithNullSameNameAssociationField() + { + $fkCust = new DDC522ForeignKeyTest; + $fkCust->name = "name"; + $fkCust->cart = null; + + $this->_em->persist($fkCust); + $this->_em->flush(); + $this->_em->clear(); + + $newCust = $this->_em->find(get_class($fkCust), $fkCust->id); + } +} + +/** @Entity */ +class DDC522Customer { + /** @Id @Column(type="integer") @GeneratedValue */ + public $id; + /** @Column */ + public $name; + /** @OneToOne(targetEntity="DDC522Cart", mappedBy="customer") */ + public $cart; +} + +/** @Entity */ +class DDC522Cart { + /** @Id @Column(type="integer") @GeneratedValue */ + public $id; + /** @Column(type="integer") */ + public $total; + /** + * @OneToOne(targetEntity="DDC522Customer", inversedBy="cart") + * @JoinColumn(name="customer", referencedColumnName="id") + */ + public $customer; +} + +/** @Entity */ +class DDC522ForeignKeyTest { + /** @Id @Column(type="integer") @GeneratedValue */ + public $id; + /** @Column(type="integer", name="cart_id", nullable=true) */ + public $cartId; + /** + * @OneToOne(targetEntity="DDC522Cart") + * @JoinColumn(name="cart_id", referencedColumnName="id") + */ + public $cart; +}