useModelSet('ecommerce'); parent::setUp(); $this->firstProduct = new ECommerceProduct(); $this->secondProduct = new ECommerceProduct(); $this->firstRelated = new ECommerceProduct(); $this->firstRelated->setName("Business"); $this->secondRelated = new ECommerceProduct(); $this->secondRelated->setName("Home"); } public function testSavesAManyToManyAssociationWithCascadeSaveSet() { $this->firstProduct->addRelated($this->firstRelated); $this->firstProduct->addRelated($this->secondRelated); $this->_em->persist($this->firstProduct); $this->_em->flush(); $this->assertForeignKeysContain($this->firstProduct->getId(), $this->firstRelated->getId()); $this->assertForeignKeysContain($this->firstProduct->getId(), $this->secondRelated->getId()); } public function testRemovesAManyToManyAssociation() { $this->firstProduct->addRelated($this->firstRelated); $this->firstProduct->addRelated($this->secondRelated); $this->_em->persist($this->firstProduct); $this->firstProduct->removeRelated($this->firstRelated); $this->_em->flush(); $this->assertForeignKeysNotContain($this->firstProduct->getId(), $this->firstRelated->getId()); $this->assertForeignKeysContain($this->firstProduct->getId(), $this->secondRelated->getId()); } public function testEagerLoadsOwningSide() { $this->_createLoadingFixture(); list ($firstProduct, $secondProduct) = $this->_findProducts(); $this->assertEquals(2, count($firstProduct->getRelated())); $this->assertEquals(2, count($secondProduct->getRelated())); $categories = $firstProduct->getRelated(); $firstRelatedBy = $categories[0]->getRelated(); $secondRelatedBy = $categories[1]->getRelated(); $this->assertEquals(2, count($firstRelatedBy)); $this->assertEquals(2, count($secondRelatedBy)); $this->assertTrue($firstRelatedBy[0] instanceof ECommerceProduct); $this->assertTrue($firstRelatedBy[1] instanceof ECommerceProduct); $this->assertTrue($secondRelatedBy[0] instanceof ECommerceProduct); $this->assertTrue($secondRelatedBy[1] instanceof ECommerceProduct); $this->assertCollectionEquals($firstRelatedBy, $secondRelatedBy); } protected function _createLoadingFixture() { $this->firstProduct->addRelated($this->firstRelated); $this->firstProduct->addRelated($this->secondRelated); $this->secondProduct->addRelated($this->firstRelated); $this->secondProduct->addRelated($this->secondRelated); $this->_em->persist($this->firstProduct); $this->_em->persist($this->secondProduct); $this->_em->flush(); $this->_em->clear(); } protected function _findProducts() { $query = $this->_em->createQuery('SELECT p, r FROM Doctrine\Tests\Models\ECommerce\ECommerceProduct p LEFT JOIN p.related r ORDER BY p.id, r.id'); return $query->getResultList(); } /* TODO: not yet implemented public function testLazyLoad() { }*/ }