useModelSet('cms'); parent::setUp(); } public function loadFixture() { $user = new CmsUser; $user->name = 'Roman'; $user->username = 'romanb'; $user->status = 'freak'; $this->_em->persist($user); $user2 = new CmsUser; $user2->name = 'Guilherme'; $user2->username = 'gblanco'; $user2->status = 'dev'; $this->_em->persist($user2); $this->_em->flush(); $user1Id = $user->getId(); unset($user); unset($user2); $this->_em->clear(); return $user1Id; } public function testBasicFind() { $user1Id = $this->loadFixture(); $repos = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser'); $user = $repos->find($user1Id); $this->assertTrue($user instanceof CmsUser); $this->assertEquals('Roman', $user->name); $this->assertEquals('freak', $user->status); } public function testFindByField() { $user1Id = $this->loadFixture(); $repos = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser'); $users = $repos->findBy(array('status' => 'dev')); $this->assertEquals(1, count($users)); $this->assertTrue($users[0] instanceof CmsUser); $this->assertEquals('Guilherme', $users[0]->name); $this->assertEquals('dev', $users[0]->status); } public function testFindFieldByMagicCall() { $user1Id = $this->loadFixture(); $repos = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser'); $users = $repos->findByStatus('dev'); $this->assertEquals(1, count($users)); $this->assertTrue($users[0] instanceof CmsUser); $this->assertEquals('Guilherme', $users[0]->name); $this->assertEquals('dev', $users[0]->status); } public function testFindAll() { $user1Id = $this->loadFixture(); $repos = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser'); $users = $repos->findAll(); $this->assertEquals(2, count($users)); } public function testFindByAlias() { $user1Id = $this->loadFixture(); $repos = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser'); $this->_em->getConfiguration()->addEntityNamespace('CMS', 'Doctrine\Tests\Models\CMS'); $repos = $this->_em->getRepository('CMS:CmsUser'); $users = $repos->findAll(); $this->assertEquals(2, count($users)); } public function tearDown() { $this->_em->getConfiguration()->setEntityNamespaces(array()); parent::tearDown(); } /** * @expectedException \Doctrine\ORM\ORMException */ public function testExceptionIsThrownWhenCallingFindByWithoutParameter() { $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser') ->findByStatus(); } /** * @expectedException \Doctrine\ORM\ORMException */ public function testExceptionIsThrownWhenUsingInvalidFieldName() { $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser') ->findByThisFieldDoesNotExist('testvalue'); } /** * @group locking * @group DDC-178 */ public function testPessimisticReadLockWithoutTransaction_ThrowsException() { $this->setExpectedException('Doctrine\ORM\TransactionRequiredException'); $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser') ->find(1, \Doctrine\DBAL\LockMode::PESSIMISTIC_READ); } /** * @group locking * @group DDC-178 */ public function testPessimisticWriteLockWithoutTransaction_ThrowsException() { $this->setExpectedException('Doctrine\ORM\TransactionRequiredException'); $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser') ->find(1, \Doctrine\DBAL\LockMode::PESSIMISTIC_WRITE); } /** * @group locking * @group DDC-178 */ public function testOptimisticLockUnversionedEntity_ThrowsException() { $this->setExpectedException('Doctrine\ORM\OptimisticLockException'); $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser') ->find(1, \Doctrine\DBAL\LockMode::OPTIMISTIC); } /** * @group locking * @group DDC-178 */ public function testIdentityMappedOptimisticLockUnversionedEntity_ThrowsException() { $user = new CmsUser; $user->name = 'Roman'; $user->username = 'romanb'; $user->status = 'freak'; $this->_em->persist($user); $this->_em->flush(); $userId = $user->id; $this->_em->find('Doctrine\Tests\Models\CMS\CmsUser', $userId); $this->setExpectedException('Doctrine\ORM\OptimisticLockException'); $this->_em->find('Doctrine\Tests\Models\CMS\CmsUser', $userId, \Doctrine\DBAL\LockMode::OPTIMISTIC); } /** * @group DDC-819 */ public function testFindMagicCallByNullValue() { $this->loadFixture(); $repos = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser'); $this->setExpectedException('Doctrine\ORM\ORMException'); $users = $repos->findByStatus(null); } /** * @group DDC-819 */ public function testInvalidMagicCall() { $this->setExpectedException('BadMethodCallException'); $repos = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser'); $repos->foo(); } public function loadAssociatedFixture() { $address = new CmsAddress(); $address->city = "Berlin"; $address->country = "Germany"; $address->street = "Foostreet"; $address->zip = "12345"; $user = new CmsUser(); $user->name = 'Roman'; $user->username = 'romanb'; $user->status = 'freak'; $user->setAddress($address); $this->_em->persist($user); $this->_em->persist($address); $this->_em->flush(); $this->_em->clear(); return array($user->id, $address->id); } /** * @group DDC-817 */ public function testFindByAssociationKey_ExceptionOnInverseSide() { list($userId, $addressId) = $this->loadAssociatedFixture(); $repos = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser'); $this->setExpectedException('Doctrine\ORM\ORMException', "You cannot search for the association field 'Doctrine\Tests\Models\CMS\CmsUser#address', because it is the inverse side of an association. Find methods only work on owning side associations."); $user = $repos->findBy(array('address' => $addressId)); } /** * @group DDC-817 */ public function testFindOneByAssociationKey() { list($userId, $addressId) = $this->loadAssociatedFixture(); $repos = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsAddress'); $address = $repos->findOneBy(array('user' => $userId)); $this->assertType('Doctrine\Tests\Models\CMS\CmsAddress', $address); $this->assertEquals($addressId, $address->id); } /** * @group DDC-817 */ public function testFindByAssociationKey() { list($userId, $addressId) = $this->loadAssociatedFixture(); $repos = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsAddress'); $addresses = $repos->findBy(array('user' => $userId)); $this->assertContainsOnly('Doctrine\Tests\Models\CMS\CmsAddress', $addresses); $this->assertEquals(1, count($addresses)); $this->assertEquals($addressId, $addresses[0]->id); } /** * @group DDC-817 */ public function testFindAssociationByMagicCall() { list($userId, $addressId) = $this->loadAssociatedFixture(); $repos = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsAddress'); $addresses = $repos->findByUser($userId); $this->assertContainsOnly('Doctrine\Tests\Models\CMS\CmsAddress', $addresses); $this->assertEquals(1, count($addresses)); $this->assertEquals($addressId, $addresses[0]->id); } /** * @group DDC-817 */ public function testFindOneAssociationByMagicCall() { list($userId, $addressId) = $this->loadAssociatedFixture(); $repos = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsAddress'); $address = $repos->findOneByUser($userId); $this->assertType('Doctrine\Tests\Models\CMS\CmsAddress', $address); $this->assertEquals($addressId, $address->id); } }