Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
merged branch Burgov/doctrine_orm_type_guesser_tests (PR #5793)
This PR was merged into the 2.1 branch. Commits ------- 5d2525b [Form] Created test for DoctrineOrmTypeGuesser see #5790 b844d6b [Form] Fixed DoctrineOrmTypeGuesser to guess the "required" option for to-one associations Discussion ---------- [Form] Doctrine orm type guesser tests This PR adds tests to #5790 --------------------------------------------------------------------------- by Tobion at 2012-10-20T10:53:56Z Using real test entities would be better IMO. Using mocks ties it pretty much to the implementation. --------------------------------------------------------------------------- by sstok at 2012-10-21T10:38:53Z @Tobion thats true, but Doctrine Class meta data takes quite some coding to set-up. For instance you need the EntityManager to get even get the meta data set! So you'd end having more code to set-up then your actually testing. --------------------------------------------------------------------------- by Burgov at 2012-10-21T12:58:58Z I wasn't sure whether do use a test entity manager, or do it the way I finally did it. @sstok true, it's quite some work to set it up, but on the other hand there's the base OrmTestCase class which does it for you, so it'd actually mean I'd only have to create one entity for all the cases: https://github.com/symfony/symfony/blob/master/src/Symfony/Bridge/Doctrine/Tests/DoctrineOrmTestCase.php @Tobion on the other hand I tend to use a test EM only when I actually need to test persisting and loading, while this test case here is so isolated that I didn't really feel it would be necessary. I'd like to know which method is preferred though, I'll change it if necessary, and other tests can be added to test the rest of this specific class
- Loading branch information
Showing
2 changed files
with
118 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
89 changes: 89 additions & 0 deletions
89
src/Symfony/Bridge/Doctrine/Tests/Form/DoctrineOrmTypeGuesserTest.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
<?php | ||
|
||
namespace Symfony\Bridge\Doctrine\Tests\Form; | ||
|
||
use Doctrine\Common\Persistence\Mapping\ClassMetadata; | ||
use Symfony\Bridge\Doctrine\Form\DoctrineOrmTypeGuesser; | ||
use Symfony\Component\Form\Guess\Guess; | ||
use Symfony\Component\Form\Guess\ValueGuess; | ||
|
||
class DoctrineOrmTypeGuesserTest extends \PHPUnit_Framework_TestCase | ||
{ | ||
/** | ||
* @dataProvider requiredProvider | ||
*/ | ||
public function testRequiredGuesser($classMetadata, $expected) | ||
{ | ||
$this->assertEquals($expected, $this->getGuesser($classMetadata)->guessRequired('TestEntity', 'field')); | ||
} | ||
|
||
public function requiredProvider() | ||
{ | ||
$return = array(); | ||
|
||
// Simple field, not nullable | ||
$classMetadata = $this->getMockBuilder('Doctrine\ORM\Mapping\ClassMetadata')->disableOriginalConstructor()->getMock(); | ||
$classMetadata->expects($this->once())->method('hasField')->with('field')->will($this->returnValue(true)); | ||
$classMetadata->expects($this->once())->method('isNullable')->with('field')->will($this->returnValue(false)); | ||
|
||
$return[] = array($classMetadata, new ValueGuess(true, Guess::HIGH_CONFIDENCE)); | ||
|
||
// Simple field, nullable | ||
$classMetadata = $this->getMockBuilder('Doctrine\ORM\Mapping\ClassMetadata')->disableOriginalConstructor()->getMock(); | ||
$classMetadata->expects($this->once())->method('hasField')->with('field')->will($this->returnValue(true)); | ||
$classMetadata->expects($this->once())->method('isNullable')->with('field')->will($this->returnValue(true)); | ||
|
||
$return[] = array($classMetadata, new ValueGuess(false, Guess::MEDIUM_CONFIDENCE)); | ||
|
||
// One-to-one, nullable (by default) | ||
$classMetadata = $this->getMockBuilder('Doctrine\ORM\Mapping\ClassMetadata')->disableOriginalConstructor()->getMock(); | ||
$classMetadata->expects($this->once())->method('hasField')->with('field')->will($this->returnValue(false)); | ||
$classMetadata->expects($this->once())->method('isAssociationWithSingleJoinColumn')->with('field')->will($this->returnValue(true)); | ||
|
||
$mapping = array('joinColumns' => array(array())); | ||
$classMetadata->expects($this->once())->method('getAssociationMapping')->with('field')->will($this->returnValue($mapping)); | ||
|
||
$return[] = array($classMetadata, new ValueGuess(false, Guess::HIGH_CONFIDENCE)); | ||
|
||
// One-to-one, nullable (explicit) | ||
$classMetadata = $this->getMockBuilder('Doctrine\ORM\Mapping\ClassMetadata')->disableOriginalConstructor()->getMock(); | ||
$classMetadata->expects($this->once())->method('hasField')->with('field')->will($this->returnValue(false)); | ||
$classMetadata->expects($this->once())->method('isAssociationWithSingleJoinColumn')->with('field')->will($this->returnValue(true)); | ||
|
||
$mapping = array('joinColumns' => array(array('nullable'=>true))); | ||
$classMetadata->expects($this->once())->method('getAssociationMapping')->with('field')->will($this->returnValue($mapping)); | ||
|
||
$return[] = array($classMetadata, new ValueGuess(false, Guess::HIGH_CONFIDENCE)); | ||
|
||
// One-to-one, not nullable | ||
$classMetadata = $this->getMockBuilder('Doctrine\ORM\Mapping\ClassMetadata')->disableOriginalConstructor()->getMock(); | ||
$classMetadata->expects($this->once())->method('hasField')->with('field')->will($this->returnValue(false)); | ||
$classMetadata->expects($this->once())->method('isAssociationWithSingleJoinColumn')->with('field')->will($this->returnValue(true)); | ||
|
||
$mapping = array('joinColumns' => array(array('nullable'=>false))); | ||
$classMetadata->expects($this->once())->method('getAssociationMapping')->with('field')->will($this->returnValue($mapping)); | ||
|
||
$return[] = array($classMetadata, new ValueGuess(true, Guess::HIGH_CONFIDENCE)); | ||
|
||
// One-to-many, no clue | ||
$classMetadata = $this->getMockBuilder('Doctrine\ORM\Mapping\ClassMetadata')->disableOriginalConstructor()->getMock(); | ||
$classMetadata->expects($this->once())->method('hasField')->with('field')->will($this->returnValue(false)); | ||
$classMetadata->expects($this->once())->method('isAssociationWithSingleJoinColumn')->with('field')->will($this->returnValue(false)); | ||
|
||
$return[] = array($classMetadata, null); | ||
|
||
return $return; | ||
} | ||
|
||
private function getGuesser(ClassMetadata $classMetadata) | ||
{ | ||
$em = $this->getMock('Doctrine\Common\Persistence\ObjectManager'); | ||
$em->expects($this->once())->method('getClassMetaData')->with('TestEntity')->will($this->returnValue($classMetadata)); | ||
|
||
$registry = $this->getMock('Doctrine\Common\Persistence\ManagerRegistry'); | ||
$registry->expects($this->once())->method('getManagers')->will($this->returnValue(array($em))); | ||
|
||
return new DoctrineOrmTypeGuesser($registry); | ||
} | ||
|
||
} |