3 namespace Doctrine\Tests\ORM\Functional;
5 use Doctrine\Tests\Models\ECommerce\ECommerceCart;
6 use Doctrine\Tests\Models\ECommerce\ECommerceCustomer;
7 use Doctrine\ORM\Mapping\AssociationMapping;
8 use Doctrine\ORM\Mapping\ClassMetadata;
10 require_once __DIR__ . '/../../TestInit.php';
13 * Tests a bidirectional one-to-one association mapping (without inheritance).
15 class OneToOneBidirectionalAssociationTest extends \Doctrine\Tests\OrmFunctionalTestCase
20 protected function setUp()
22 $this->useModelSet('ecommerce');
24 $this->customer = new ECommerceCustomer();
25 $this->customer->setName('John Doe');
26 $this->cart = new ECommerceCart();
27 $this->cart->setPayment('Credit card');
30 public function testSavesAOneToOneAssociationWithCascadeSaveSet() {
31 $this->customer->setCart($this->cart);
32 $this->_em->persist($this->customer);
35 $this->assertCartForeignKeyIs($this->customer->getId());
38 public function testDoesNotSaveAnInverseSideSet() {
39 $this->customer->brokenSetCart($this->cart);
40 $this->_em->persist($this->customer);
43 $this->assertCartForeignKeyIs(null);
46 public function testRemovesOneToOneAssociation()
48 $this->customer->setCart($this->cart);
49 $this->_em->persist($this->customer);
50 $this->customer->removeCart();
54 $this->assertCartForeignKeyIs(null);
57 public function testEagerLoad()
59 $this->_createFixture();
61 $query = $this->_em->createQuery('select c, ca from Doctrine\Tests\Models\ECommerce\ECommerceCustomer c join c.cart ca');
62 $result = $query->getResult();
63 $customer = $result[0];
65 $this->assertInstanceOf('Doctrine\Tests\Models\ECommerce\ECommerceCart', $customer->getCart());
66 $this->assertEquals('paypal', $customer->getCart()->getPayment());
69 public function testLazyLoadsObjectsOnTheOwningSide() {
70 $this->_createFixture();
71 $metadata = $this->_em->getClassMetadata('Doctrine\Tests\Models\ECommerce\ECommerceCart');
72 $metadata->associationMappings['customer']['fetchMode'] = ClassMetadata::FETCH_LAZY;
74 $query = $this->_em->createQuery('select c from Doctrine\Tests\Models\ECommerce\ECommerceCart c');
75 $result = $query->getResult();
78 $this->assertInstanceOf('Doctrine\Tests\Models\ECommerce\ECommerceCustomer', $cart->getCustomer());
79 $this->assertEquals('Giorgio', $cart->getCustomer()->getName());
82 public function testInverseSideIsNeverLazy()
84 $this->_createFixture();
85 $metadata = $this->_em->getClassMetadata('Doctrine\Tests\Models\ECommerce\ECommerceCustomer');
86 $metadata->associationMappings['mentor']['fetch'] = ClassMetadata::FETCH_EAGER;
88 $query = $this->_em->createQuery('select c from Doctrine\Tests\Models\ECommerce\ECommerceCustomer c');
89 $result = $query->getResult();
90 $customer = $result[0];
92 $this->assertNull($customer->getMentor());
93 $this->assertInstanceOF('Doctrine\Tests\Models\ECommerce\ECommerceCart', $customer->getCart());
94 $this->assertNotInstanceOf('Doctrine\ORM\Proxy\Proxy', $customer->getCart());
95 $this->assertEquals('paypal', $customer->getCart()->getPayment());
98 public function testUpdateWithProxyObject()
100 $cust = new ECommerceCustomer;
101 $cust->setName('Roman');
102 $cart = new ECommerceCart;
103 $cart->setPayment('CARD');
104 $cust->setCart($cart);
106 $this->_em->persist($cust);
110 $this->assertInstanceOf('Doctrine\Tests\Models\ECommerce\ECommerceCart', $cust->getCart());
111 $this->assertEquals('Roman', $cust->getName());
112 $this->assertSame($cust, $cart->getCustomer());
114 $query = $this->_em->createQuery('select ca from Doctrine\Tests\Models\ECommerce\ECommerceCart ca where ca.id =?1');
115 $query->setParameter(1, $cart->getId());
117 $cart2 = $query->getSingleResult();
119 $cart2->setPayment('CHEQUE');
124 $query2 = $this->_em->createQuery('select ca, c from Doctrine\Tests\Models\ECommerce\ECommerceCart ca left join ca.customer c where ca.id =?1');
125 $query2->setParameter(1, $cart->getId());
127 $cart3 = $query2->getSingleResult();
129 $this->assertInstanceOf('Doctrine\Tests\Models\ECommerce\ECommerceCustomer', $cart3->getCustomer());
130 $this->assertEquals('Roman', $cart3->getCustomer()->getName());
133 protected function _createFixture()
135 $customer = new ECommerceCustomer;
136 $customer->setName('Giorgio');
137 $cart = new ECommerceCart;
138 $cart->setPayment('paypal');
139 $customer->setCart($cart);
141 $this->_em->persist($customer);
147 public function assertCartForeignKeyIs($value) {
148 $foreignKey = $this->_em->getConnection()->executeQuery('SELECT customer_id FROM ecommerce_carts WHERE id=?', array($this->cart->getId()))->fetchColumn();
149 $this->assertEquals($value, $foreignKey);