X-Git-Url: http://git.inspyration.org/?a=blobdiff_plain;f=vendor%2Fdoctrine%2Form%2Ftests%2FDoctrine%2FTests%2FORM%2FFunctional%2FTicket%2FDDC163Test.php;fp=vendor%2Fdoctrine%2Form%2Ftests%2FDoctrine%2FTests%2FORM%2FFunctional%2FTicket%2FDDC163Test.php;h=3126d5491daf099aaac9f5b9e49005aacc15d583;hb=8b04b2d11798dee4f3e1358e4f43e97a6df851f6;hp=0000000000000000000000000000000000000000;hpb=73568cf05a785a45f94ca3f2351d9e07bf917958;p=zf2.biz%2Fapplication_blanche.git diff --git a/vendor/doctrine/orm/tests/Doctrine/Tests/ORM/Functional/Ticket/DDC163Test.php b/vendor/doctrine/orm/tests/Doctrine/Tests/ORM/Functional/Ticket/DDC163Test.php new file mode 100644 index 0000000..3126d54 --- /dev/null +++ b/vendor/doctrine/orm/tests/Doctrine/Tests/ORM/Functional/Ticket/DDC163Test.php @@ -0,0 +1,65 @@ +useModelSet('company'); + parent::setUp(); + } + + /** + * @group DDC-163 + */ + public function testQueryWithOrConditionUsingTwoRelationOnSameEntity() + { + $p1 = new CompanyPerson; + $p1->setName('p1'); + + $p2 = new CompanyPerson; + $p2->setName('p2'); + + $p3 = new CompanyPerson; + $p3->setName('p3'); + + $p4 = new CompanyPerson; + $p4->setName('p4'); + + $p1->setSpouse($p3); + $p1->addFriend($p2); + $p2->addFriend($p3); + + $p3->addFriend($p4); + + $this->_em->persist($p1); + $this->_em->persist($p2); + $this->_em->persist($p3); + $this->_em->persist($p4); + + $this->_em->flush(); + $this->_em->clear(); + + $dql = 'SELECT PARTIAL person.{id,name}, PARTIAL spouse.{id,name}, PARTIAL friend.{id,name} + FROM Doctrine\Tests\Models\Company\CompanyPerson person + LEFT JOIN person.spouse spouse + LEFT JOIN person.friends friend + LEFT JOIN spouse.friends spouse_friend + LEFT JOIN friend.friends friend_friend + WHERE person.name=:name AND (spouse_friend.name=:name2 OR friend_friend.name=:name2)'; + + $q = $this->_em->createQuery($dql); + $q->setParameter('name', "p1"); + $q->setParameter('name2', "p4"); + $result = $q->getScalarResult(); + + $this->assertEquals('p3', $result[0]['spouse_name']); + $this->assertEquals('p1', $result[0]['person_name']); + $this->assertEquals('p2', $result[0]['friend_name']); + } +} \ No newline at end of file