_em; $exporter = new ClassExporter($this->_em); $exporter->exportClasses(array( $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsUser'), $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsPhonenumber'), $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsAddress'), $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsGroup') )); // Create $user = new CmsUser; $user->name = 'Roman'; $user->username = 'romanb'; $user->status = 'developer'; $em->save($user); $this->assertTrue(is_numeric($user->id)); $this->assertTrue($em->contains($user)); // Read $user2 = $em->find('Doctrine\Tests\Models\CMS\CmsUser', $user->id); $this->assertTrue($user === $user2); // Add a phonenumber $ph = new CmsPhonenumber; $ph->phonenumber = "12345"; $user->addPhonenumber($ph); $em->flush(); $this->assertTrue($em->contains($ph)); $this->assertTrue($em->contains($user)); //$this->assertTrue($user->phonenumbers instanceof \Doctrine\ORM\PersistentCollection); // Update name $user->name = 'guilherme'; $em->flush(); $this->assertEquals('guilherme', $user->name); // Add another phonenumber $ph2 = new CmsPhonenumber; $ph2->phonenumber = "6789"; $user->addPhonenumber($ph2); $em->flush(); $this->assertTrue($em->contains($ph2)); // Delete $em->delete($user); $this->assertTrue($em->getUnitOfWork()->isRegisteredRemoved($user)); $this->assertTrue($em->getUnitOfWork()->isRegisteredRemoved($ph)); $this->assertTrue($em->getUnitOfWork()->isRegisteredRemoved($ph2)); $em->flush(); $this->assertFalse($em->getUnitOfWork()->isRegisteredRemoved($user)); $this->assertFalse($em->getUnitOfWork()->isRegisteredRemoved($ph)); $this->assertFalse($em->getUnitOfWork()->isRegisteredRemoved($ph2)); } public function testOneToManyAssociationModification() { $user = new CmsUser; $user->name = 'Roman'; $user->username = 'romanb'; $user->status = 'developer'; $ph1 = new CmsPhonenumber; $ph1->phonenumber = "0301234"; $ph2 = new CmsPhonenumber; $ph2->phonenumber = "987654321"; $user->addPhonenumber($ph1); $user->addPhonenumber($ph2); $this->_em->save($user); $this->_em->flush(); //$this->assertTrue($user->phonenumbers instanceof \Doctrine\ORM\PersistentCollection); // Remove the first element from the collection unset($user->phonenumbers[0]); $ph1->user = null; // owning side! $this->_em->flush(); $this->assertEquals(1, count($user->phonenumbers)); $this->assertNull($ph1->user); } public function testBasicOneToOne() { $user = new CmsUser; $user->name = 'Roman'; $user->username = 'romanb'; $user->status = 'developer'; $address = new CmsAddress; $address->country = 'Germany'; $address->city = 'Berlin'; $address->zip = '12345'; $user->address = $address; // inverse side $address->user = $user; // owning side! $this->_em->save($user); $this->_em->flush(); // Check that the foreign key has been set $userId = $this->_em->getConnection()->execute("SELECT user_id FROM cms_addresses WHERE id=?", array($address->id))->fetchColumn(); $this->assertTrue(is_numeric($userId)); } public function testBasicManyToMany() { $user = new CmsUser; $user->name = 'Guilherme'; $user->username = 'gblanco'; $user->status = 'developer'; $group = new CmsGroup; $group->name = 'Developers'; $user->groups[] = $group; $group->users[] = $user; $this->_em->save($user); $this->_em->save($group); $this->_em->flush(); unset($group->users[0]); // inverse side unset($user->groups[0]); // owning side! $this->_em->flush(); // Check that the link in the association table has been deleted $count = $this->_em->getConnection()->execute("SELECT COUNT(*) FROM cms_users_groups", array())->fetchColumn(); $this->assertEquals(0, $count); } public function testManyToManyCollectionClearing() { echo PHP_EOL . "MANY-MANY" . PHP_EOL; $user = new CmsUser; $user->name = 'Guilherme'; $user->username = 'gblanco'; $user->status = 'developer'; for ($i=0; $i<10; ++$i) { $group = new CmsGroup; $group->name = 'Developers_' . $i; $user->groups[] = $group; $group->users[] = $user; } $this->_em->save($user); // Saves the user, cause of post-insert ID $this->_em->flush(); // Check that there are indeed 10 links in the association table $count = $this->_em->getConnection()->execute("SELECT COUNT(*) FROM cms_users_groups", array())->fetchColumn(); $this->assertEquals(10, $count); //$user->groups->clear(); unset($user->groups); echo PHP_EOL . "FINAL FLUSH" . PHP_EOL; $this->_em->flush(); // Check that the links in the association table have been deleted $count = $this->_em->getConnection()->execute("SELECT COUNT(*) FROM cms_users_groups", array())->fetchColumn(); $this->assertEquals(0, $count); } }