2009-07-02 09:37:59 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Doctrine\Tests\ORM\Functional;
|
|
|
|
|
|
|
|
use Doctrine\Common\Collections\Collection;
|
|
|
|
use Doctrine\Tests\Models\ECommerce\ECommerceProduct;
|
|
|
|
use Doctrine\Tests\Models\ECommerce\ECommerceCategory;
|
2009-07-28 11:43:42 +00:00
|
|
|
use Doctrine\ORM\Mapping\AssociationMapping;
|
2009-07-02 09:37:59 +00:00
|
|
|
|
|
|
|
require_once __DIR__ . '/../../TestInit.php';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Tests a bidirectional many-to-many association mapping (without inheritance).
|
2009-07-28 11:43:42 +00:00
|
|
|
* Owning side is ECommerceProduct, inverse side is ECommerceCategory.
|
2009-07-02 09:37:59 +00:00
|
|
|
*/
|
|
|
|
class ManyToManyBidirectionalAssociationTest extends AbstractManyToManyAssociationTestCase
|
|
|
|
{
|
2009-07-02 11:48:44 +00:00
|
|
|
protected $_firstField = 'product_id';
|
|
|
|
protected $_secondField = 'category_id';
|
|
|
|
protected $_table = 'ecommerce_products_categories';
|
2009-07-02 09:37:59 +00:00
|
|
|
private $firstProduct;
|
|
|
|
private $secondProduct;
|
|
|
|
private $firstCategory;
|
|
|
|
private $secondCategory;
|
|
|
|
|
|
|
|
protected function setUp()
|
|
|
|
{
|
|
|
|
$this->useModelSet('ecommerce');
|
|
|
|
parent::setUp();
|
|
|
|
$this->firstProduct = new ECommerceProduct();
|
|
|
|
$this->secondProduct = new ECommerceProduct();
|
|
|
|
$this->firstCategory = new ECommerceCategory();
|
|
|
|
$this->firstCategory->setName("Business");
|
|
|
|
$this->secondCategory = new ECommerceCategory();
|
|
|
|
$this->secondCategory->setName("Home");
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSavesAManyToManyAssociationWithCascadeSaveSet()
|
|
|
|
{
|
|
|
|
$this->firstProduct->addCategory($this->firstCategory);
|
|
|
|
$this->firstProduct->addCategory($this->secondCategory);
|
2009-07-19 16:54:53 +00:00
|
|
|
$this->_em->persist($this->firstProduct);
|
2009-07-02 09:37:59 +00:00
|
|
|
$this->_em->flush();
|
|
|
|
|
|
|
|
$this->assertForeignKeysContain($this->firstProduct->getId(),
|
|
|
|
$this->firstCategory->getId());
|
|
|
|
$this->assertForeignKeysContain($this->firstProduct->getId(),
|
|
|
|
$this->secondCategory->getId());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testRemovesAManyToManyAssociation()
|
|
|
|
{
|
|
|
|
$this->firstProduct->addCategory($this->firstCategory);
|
|
|
|
$this->firstProduct->addCategory($this->secondCategory);
|
2009-07-19 16:54:53 +00:00
|
|
|
$this->_em->persist($this->firstProduct);
|
2009-07-02 09:37:59 +00:00
|
|
|
$this->firstProduct->removeCategory($this->firstCategory);
|
|
|
|
|
|
|
|
$this->_em->flush();
|
|
|
|
|
|
|
|
$this->assertForeignKeysNotContain($this->firstProduct->getId(),
|
|
|
|
$this->firstCategory->getId());
|
|
|
|
$this->assertForeignKeysContain($this->firstProduct->getId(),
|
|
|
|
$this->secondCategory->getId());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testEagerLoadsInverseSide()
|
|
|
|
{
|
|
|
|
$this->_createLoadingFixture();
|
|
|
|
list ($firstProduct, $secondProduct) = $this->_findProducts();
|
|
|
|
$categories = $firstProduct->getCategories();
|
2009-07-28 11:43:42 +00:00
|
|
|
$this->assertLoadingOfInverseSide($categories);
|
|
|
|
$this->assertLoadingOfInverseSide($secondProduct->getCategories());
|
2009-07-02 09:37:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testEagerLoadsOwningSide()
|
|
|
|
{
|
|
|
|
$this->_createLoadingFixture();
|
2009-07-28 11:43:42 +00:00
|
|
|
$products = $this->_findProducts();
|
|
|
|
$this->assertLoadingOfOwningSide($products);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testLazyLoadsCollectionOnTheInverseSide()
|
|
|
|
{
|
|
|
|
$this->_createLoadingFixture();
|
2009-07-02 09:37:59 +00:00
|
|
|
|
2009-07-28 11:43:42 +00:00
|
|
|
$this->_em->getConfiguration()->setAllowPartialObjects(false);
|
|
|
|
$metadata = $this->_em->getClassMetadata('Doctrine\Tests\Models\ECommerce\ECommerceCategory');
|
|
|
|
$metadata->getAssociationMapping('products')->fetchMode = AssociationMapping::FETCH_LAZY;
|
|
|
|
|
|
|
|
$query = $this->_em->createQuery('SELECT c FROM Doctrine\Tests\Models\ECommerce\ECommerceCategory c order by c.id');
|
|
|
|
$categories = $query->getResultList();
|
|
|
|
$this->assertLoadingOfInverseSide($categories);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testLazyLoadsCollectionOnTheOwningSide()
|
|
|
|
{
|
|
|
|
$this->_createLoadingFixture();
|
|
|
|
|
|
|
|
$this->_em->getConfiguration()->setAllowPartialObjects(false);
|
|
|
|
$metadata = $this->_em->getClassMetadata('Doctrine\Tests\Models\ECommerce\ECommerceProduct');
|
|
|
|
$metadata->getAssociationMapping('categories')->fetchMode = AssociationMapping::FETCH_LAZY;
|
|
|
|
|
|
|
|
$query = $this->_em->createQuery('SELECT p FROM Doctrine\Tests\Models\ECommerce\ECommerceProduct p order by p.id');
|
|
|
|
$products = $query->getResultList();
|
|
|
|
$this->assertLoadingOfOwningSide($products);
|
2009-07-02 09:37:59 +00:00
|
|
|
}
|
|
|
|
|
2009-07-28 11:43:42 +00:00
|
|
|
|
|
|
|
private function _createLoadingFixture()
|
2009-07-02 09:37:59 +00:00
|
|
|
{
|
|
|
|
$this->firstProduct->addCategory($this->firstCategory);
|
|
|
|
$this->firstProduct->addCategory($this->secondCategory);
|
|
|
|
$this->secondProduct->addCategory($this->firstCategory);
|
|
|
|
$this->secondProduct->addCategory($this->secondCategory);
|
2009-07-19 16:54:53 +00:00
|
|
|
$this->_em->persist($this->firstProduct);
|
|
|
|
$this->_em->persist($this->secondProduct);
|
2009-07-02 09:37:59 +00:00
|
|
|
|
|
|
|
$this->_em->flush();
|
|
|
|
$this->_em->clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function _findProducts()
|
|
|
|
{
|
|
|
|
$query = $this->_em->createQuery('SELECT p, c FROM Doctrine\Tests\Models\ECommerce\ECommerceProduct p LEFT JOIN p.categories c ORDER BY p.id, c.id');
|
|
|
|
return $query->getResultList();
|
|
|
|
}
|
|
|
|
|
2009-07-28 11:43:42 +00:00
|
|
|
public function assertLoadingOfOwningSide($products)
|
|
|
|
{
|
|
|
|
list ($firstProduct, $secondProduct) = $products;
|
|
|
|
$this->assertEquals(2, count($firstProduct->getCategories()));
|
|
|
|
$this->assertEquals(2, count($secondProduct->getCategories()));
|
|
|
|
|
|
|
|
$categories = $firstProduct->getCategories();
|
|
|
|
$firstCategoryProducts = $categories[0]->getProducts();
|
|
|
|
$secondCategoryProducts = $categories[1]->getProducts();
|
2009-07-28 12:30:35 +00:00
|
|
|
|
2009-07-28 11:43:42 +00:00
|
|
|
$this->assertEquals(2, count($firstCategoryProducts));
|
|
|
|
$this->assertEquals(2, count($secondCategoryProducts));
|
|
|
|
|
|
|
|
$this->assertTrue($firstCategoryProducts[0] instanceof ECommerceProduct);
|
|
|
|
$this->assertTrue($firstCategoryProducts[1] instanceof ECommerceProduct);
|
|
|
|
$this->assertTrue($secondCategoryProducts[0] instanceof ECommerceProduct);
|
|
|
|
$this->assertTrue($secondCategoryProducts[1] instanceof ECommerceProduct);
|
|
|
|
|
|
|
|
$this->assertCollectionEquals($firstCategoryProducts, $secondCategoryProducts);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function assertLoadingOfInverseSide($categories)
|
|
|
|
{
|
|
|
|
$this->assertTrue($categories[0] instanceof ECommerceCategory);
|
|
|
|
$this->assertTrue($categories[1] instanceof ECommerceCategory);
|
|
|
|
}
|
2009-07-02 09:37:59 +00:00
|
|
|
}
|