123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- <?php
-
- namespace Doctrine\Tests\ORM\Functional;
-
- use Doctrine\Tests\Models\Routing\RoutingRoute;
- use Doctrine\Tests\Models\Routing\RoutingLocation;
- use Doctrine\Tests\Models\Routing\RoutingLeg;
-
- require_once __DIR__ . '/../../TestInit.php';
-
- /**
- * Tests a bidirectional one-to-one association mapping (without inheritance).
- */
- class OneToManyUnidirectionalAssociationTest extends \Doctrine\Tests\OrmFunctionalTestCase
- {
- protected $locations = array();
-
- public function setUp()
- {
- $this->useModelSet('routing');
- parent::setUp();
-
- $locations = array("Berlin", "Bonn", "Brasilia", "Atlanta");
-
- foreach ($locations AS $locationName) {
- $location = new RoutingLocation();
- $location->name = $locationName;
- $this->_em->persist($location);
- $this->locations[$locationName] = $location;
- }
- $this->_em->flush();
- }
-
- public function testPersistOwning_InverseCascade()
- {
- $leg = new RoutingLeg();
- $leg->fromLocation = $this->locations['Berlin'];
- $leg->toLocation = $this->locations['Bonn'];
- $leg->departureDate = new \DateTime("now");
- $leg->arrivalDate = new \DateTime("now +5 hours");
-
- $route = new RoutingRoute();
- $route->legs[] = $leg;
-
- $this->_em->persist($route);
- $this->_em->flush();
- $this->_em->clear();
-
- $routes = $this->_em->createQuery(
- "SELECT r, l, f, t FROM Doctrine\Tests\Models\Routing\RoutingRoute r ".
- "JOIN r.legs l JOIN l.fromLocation f JOIN l.toLocation t"
- )->getSingleResult();
-
- $this->assertEquals(1, count($routes->legs));
- $this->assertEquals("Berlin", $routes->legs[0]->fromLocation->name);
- $this->assertEquals("Bonn", $routes->legs[0]->toLocation->name);
- }
-
- public function testLegsAreUniqueToRoutes()
- {
- $leg = new RoutingLeg();
- $leg->fromLocation = $this->locations['Berlin'];
- $leg->toLocation = $this->locations['Bonn'];
- $leg->departureDate = new \DateTime("now");
- $leg->arrivalDate = new \DateTime("now +5 hours");
-
- $routeA = new RoutingRoute();
- $routeA->legs[] = $leg;
-
- $routeB = new RoutingRoute();
- $routeB->legs[] = $leg;
-
- $this->_em->persist($routeA);
- $this->_em->persist($routeB);
-
- $exceptionThrown = false;
- try {
- // exception depending on the underyling Database Driver
- $this->_em->flush();
- } catch(\Exception $e) {
- $exceptionThrown = true;
- }
-
- $this->assertTrue($exceptionThrown, "The underlying database driver throws an exception.");
- }
- }
|