X-Git-Url: http://git.inspyration.org/?a=blobdiff_plain;f=vendor%2Fdoctrine%2Form%2Ftests%2FDoctrine%2FTests%2FORM%2FFunctional%2FOneToOneUnidirectionalAssociationTest.php;fp=vendor%2Fdoctrine%2Form%2Ftests%2FDoctrine%2FTests%2FORM%2FFunctional%2FOneToOneUnidirectionalAssociationTest.php;h=1ffae6b13cee8079ad9b22c5fd2631ff53b88d51;hb=8b04b2d11798dee4f3e1358e4f43e97a6df851f6;hp=0000000000000000000000000000000000000000;hpb=73568cf05a785a45f94ca3f2351d9e07bf917958;p=zf2.biz%2Fapplication_blanche.git diff --git a/vendor/doctrine/orm/tests/Doctrine/Tests/ORM/Functional/OneToOneUnidirectionalAssociationTest.php b/vendor/doctrine/orm/tests/Doctrine/Tests/ORM/Functional/OneToOneUnidirectionalAssociationTest.php new file mode 100644 index 0000000..1ffae6b --- /dev/null +++ b/vendor/doctrine/orm/tests/Doctrine/Tests/ORM/Functional/OneToOneUnidirectionalAssociationTest.php @@ -0,0 +1,125 @@ +useModelSet('ecommerce'); + parent::setUp(); + $this->product = new ECommerceProduct(); + $this->product->setName('Doctrine 2 Manual'); + $this->shipping = new ECommerceShipping(); + $this->shipping->setDays('5'); + } + + public function testSavesAOneToOneAssociationWithCascadeSaveSet() { + $this->product->setShipping($this->shipping); + $this->_em->persist($this->product); + $this->_em->flush(); + + $this->assertForeignKeyIs($this->shipping->getId()); + } + + public function testRemovesOneToOneAssociation() + { + $this->product->setShipping($this->shipping); + $this->_em->persist($this->product); + $this->product->removeShipping(); + + $this->_em->flush(); + + $this->assertForeignKeyIs(null); + } + + public function _testEagerLoad() + { + $this->_createFixture(); + + $query = $this->_em->createQuery('select p, s from Doctrine\Tests\Models\ECommerce\ECommerceProduct p left join p.shipping s'); + $result = $query->getResult(); + $product = $result[0]; + + $this->assertInstanceOf('Doctrine\Tests\Models\ECommerce\ECommerceShipping', $product->getShipping()); + $this->assertEquals(1, $product->getShipping()->getDays()); + } + + public function testLazyLoadsObjects() { + $this->_createFixture(); + $metadata = $this->_em->getClassMetadata('Doctrine\Tests\Models\ECommerce\ECommerceProduct'); + $metadata->associationMappings['shipping']['fetch'] = ClassMetadata::FETCH_LAZY; + + $query = $this->_em->createQuery('select p from Doctrine\Tests\Models\ECommerce\ECommerceProduct p'); + $result = $query->getResult(); + $product = $result[0]; + + $this->assertInstanceOf('Doctrine\Tests\Models\ECommerce\ECommerceShipping', $product->getShipping()); + $this->assertEquals(1, $product->getShipping()->getDays()); + } + + public function testDoesNotLazyLoadObjectsIfConfigurationDoesNotAllowIt() { + $this->_createFixture(); + + $query = $this->_em->createQuery('select p from Doctrine\Tests\Models\ECommerce\ECommerceProduct p'); + $query->setHint(Query::HINT_FORCE_PARTIAL_LOAD, true); + + $result = $query->getResult(); + $product = $result[0]; + + $this->assertNull($product->getShipping()); + } + + protected function _createFixture() + { + $product = new ECommerceProduct; + $product->setName('Php manual'); + $shipping = new ECommerceShipping; + $shipping->setDays('1'); + $product->setShipping($shipping); + + $this->_em->persist($product); + + $this->_em->flush(); + $this->_em->clear(); + } + + public function assertForeignKeyIs($value) { + $foreignKey = $this->_em->getConnection()->executeQuery( + 'SELECT shipping_id FROM ecommerce_products WHERE id=?', + array($this->product->getId()) + )->fetchColumn(); + $this->assertEquals($value, $foreignKey); + } + + /** + * @group DDC-762 + */ + public function testNullForeignKey() + { + $product = new ECommerceProduct(); + $product->setName('Doctrine 2 Manual'); + + $this->_em->persist($product); + $this->_em->flush(); + + $product = $this->_em->find(get_class($product), $product->getId()); + + $this->assertNull($product->getShipping()); + } +}