123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Tests\Component\Validator\Mapping;
- require_once __DIR__.'/../Fixtures/Entity.php';
- require_once __DIR__.'/../Fixtures/ConstraintA.php';
- require_once __DIR__.'/../Fixtures/ConstraintB.php';
- use Symfony\Tests\Component\Validator\Fixtures\Entity;
- use Symfony\Tests\Component\Validator\Fixtures\ConstraintA;
- use Symfony\Tests\Component\Validator\Fixtures\ConstraintB;
- use Symfony\Component\Validator\Mapping\ClassMetadataFactory;
- use Symfony\Component\Validator\Mapping\ClassMetadata;
- use Symfony\Component\Validator\Mapping\Loader\LoaderInterface;
- class ClassMetadataFactoryTest extends \PHPUnit_Framework_TestCase
- {
- const CLASSNAME = 'Symfony\Tests\Component\Validator\Fixtures\Entity';
- const PARENTCLASS = 'Symfony\Tests\Component\Validator\Fixtures\EntityParent';
- public function testLoadClassMetadata()
- {
- $factory = new ClassMetadataFactory(new TestLoader());
- $metadata = $factory->getClassMetadata(self::PARENTCLASS);
- $constraints = array(
- new ConstraintA(array('groups' => array('Default', 'EntityParent'))),
- );
- $this->assertEquals($constraints, $metadata->getConstraints());
- }
- public function testMergeParentConstraints()
- {
- $factory = new ClassMetadataFactory(new TestLoader());
- $metadata = $factory->getClassMetadata(self::CLASSNAME);
- $constraints = array(
- new ConstraintA(array('groups' => array(
- 'Default',
- 'EntityParent',
- 'Entity',
- ))),
- new ConstraintA(array('groups' => array(
- 'Default',
- 'EntityInterface',
- 'Entity',
- ))),
- new ConstraintA(array('groups' => array(
- 'Default',
- 'Entity',
- ))),
- );
- $this->assertEquals($constraints, $metadata->getConstraints());
- }
- public function testWriteMetadataToCache()
- {
- $cache = $this->getMock('Symfony\Component\Validator\Mapping\Cache\CacheInterface');
- $factory = new ClassMetadataFactory(new TestLoader(), $cache);
- $tester = $this;
- $constraints = array(
- new ConstraintA(array('groups' => array('Default', 'EntityParent'))),
- );
- $cache->expects($this->never())
- ->method('has');
- $cache->expects($this->once())
- ->method('read')
- ->with($this->equalTo(self::PARENTCLASS))
- ->will($this->returnValue(false));
- $cache->expects($this->once())
- ->method('write')
- ->will($this->returnCallback(function($metadata) use ($tester, $constraints) {
- $tester->assertEquals($constraints, $metadata->getConstraints());
- }));
- $metadata = $factory->getClassMetadata(self::PARENTCLASS);
- $this->assertEquals(self::PARENTCLASS, $metadata->getClassName());
- $this->assertEquals($constraints, $metadata->getConstraints());
- }
- public function testReadMetadataFromCache()
- {
- $loader = $this->getMock('Symfony\Component\Validator\Mapping\Loader\LoaderInterface');
- $cache = $this->getMock('Symfony\Component\Validator\Mapping\Cache\CacheInterface');
- $factory = new ClassMetadataFactory($loader, $cache);
- $tester = $this;
- $metadata = new ClassMetadata(self::PARENTCLASS);
- $metadata->addConstraint(new ConstraintA());
- $loader->expects($this->never())
- ->method('loadClassMetadata');
- $cache->expects($this->never())
- ->method('has');
- $cache->expects($this->once())
- ->method('read')
- ->will($this->returnValue($metadata));
- $this->assertEquals($metadata,$factory->getClassMetadata(self::PARENTCLASS));
- }
- }
- class TestLoader implements LoaderInterface
- {
- public function loadClassMetadata(ClassMetadata $metadata)
- {
- $metadata->addConstraint(new ConstraintA());
- }
- }
|