2010-06-07 08:08:35 +01:00
< ? php
/*
* This file is part of the Symfony package .
*
2011-03-06 11:40:06 +00:00
* ( c ) Fabien Potencier < fabien @ symfony . com >
2010-06-07 08:08:35 +01:00
*
* For the full copyright and license information , please view the LICENSE
* file that was distributed with this source code .
*/
2010-07-09 09:05:26 +01:00
namespace Symfony\Bundle\FrameworkBundle\Tests\DependencyInjection ;
2010-06-07 08:08:35 +01:00
2010-07-09 09:05:26 +01:00
use Symfony\Bundle\FrameworkBundle\Tests\TestCase ;
2010-09-20 20:01:41 +01:00
use Symfony\Bundle\FrameworkBundle\DependencyInjection\FrameworkExtension ;
2016-02-20 23:25:19 +00:00
use Symfony\Component\Cache\Adapter\ApcuAdapter ;
use Symfony\Component\Cache\Adapter\DoctrineAdapter ;
use Symfony\Component\Cache\Adapter\FilesystemAdapter ;
2010-08-20 22:09:55 +01:00
use Symfony\Component\DependencyInjection\ContainerBuilder ;
2015-06-26 17:55:11 +01:00
use Symfony\Component\DependencyInjection\DefinitionDecorator ;
2015-01-17 07:35:04 +00:00
use Symfony\Component\DependencyInjection\Loader\ClosureLoader ;
2010-08-20 22:09:55 +01:00
use Symfony\Component\DependencyInjection\ParameterBag\ParameterBag ;
2014-03-18 16:36:12 +00:00
use Symfony\Component\DependencyInjection\Reference ;
2016-01-31 20:58:26 +00:00
use Symfony\Component\Serializer\Normalizer\DataUriNormalizer ;
2016-01-31 20:54:05 +00:00
use Symfony\Component\Serializer\Normalizer\DateTimeNormalizer ;
2016-01-29 15:26:46 +00:00
use Symfony\Component\Serializer\Normalizer\JsonSerializableNormalizer ;
2010-06-07 08:08:35 +01:00
2011-01-24 19:50:31 +00:00
abstract class FrameworkExtensionTest extends TestCase
2010-06-07 08:08:35 +01:00
{
2016-01-16 12:37:00 +00:00
private static $containerCache = array ();
2011-01-24 19:50:31 +00:00
abstract protected function loadFromFile ( ContainerBuilder $container , $file );
2015-11-10 23:41:32 +00:00
public function testFormCsrfProtection ()
2011-01-24 19:50:31 +00:00
{
$container = $this -> createContainerFromFile ( 'full' );
2011-04-28 10:28:44 +01:00
$def = $container -> getDefinition ( 'form.type_extension.csrf' );
2011-05-13 10:57:05 +01:00
$this -> assertTrue ( $container -> getParameter ( 'form.type_extension.csrf.enabled' ));
2012-04-13 13:11:09 +01:00
$this -> assertEquals ( '%form.type_extension.csrf.enabled%' , $def -> getArgument ( 1 ));
2011-05-13 10:57:05 +01:00
$this -> assertEquals ( '_csrf' , $container -> getParameter ( 'form.type_extension.csrf.field_name' ));
2012-04-13 13:11:09 +01:00
$this -> assertEquals ( '%form.type_extension.csrf.field_name%' , $def -> getArgument ( 2 ));
2011-01-24 19:50:31 +00:00
}
2014-08-21 18:05:54 +01:00
public function testPropertyAccessWithDefaultValue ()
{
$container = $this -> createContainerFromFile ( 'full' );
$def = $container -> getDefinition ( 'property_accessor' );
2014-09-20 01:33:54 +01:00
$this -> assertFalse ( $def -> getArgument ( 0 ));
$this -> assertFalse ( $def -> getArgument ( 1 ));
2014-08-21 18:05:54 +01:00
}
public function testPropertyAccessWithOverriddenValues ()
{
$container = $this -> createContainerFromFile ( 'property_accessor' );
$def = $container -> getDefinition ( 'property_accessor' );
2014-09-20 01:33:54 +01:00
$this -> assertTrue ( $def -> getArgument ( 0 ));
$this -> assertTrue ( $def -> getArgument ( 1 ));
2014-08-21 18:05:54 +01:00
}
2013-10-09 09:42:58 +01:00
/**
* @ expectedException \LogicException
* @ expectedExceptionMessage CSRF protection needs sessions to be enabled .
*/
public function testCsrfProtectionNeedsSessionToBeEnabled ()
{
$this -> createContainerFromFile ( 'csrf_needs_session' );
}
2013-11-30 10:58:54 +00:00
public function testCsrfProtectionForFormsEnablesCsrfProtectionAutomatically ()
2013-10-09 09:42:58 +01:00
{
2013-11-30 10:58:54 +00:00
$container = $this -> createContainerFromFile ( 'csrf' );
$this -> assertTrue ( $container -> hasDefinition ( 'security.csrf.token_manager' ));
2013-10-09 09:42:58 +01:00
}
2012-12-20 07:58:18 +00:00
public function testProxies ()
{
$container = $this -> createContainerFromFile ( 'full' );
$this -> assertEquals ( array ( '127.0.0.1' , '10.0.0.1' ), $container -> getParameter ( 'kernel.trusted_proxies' ));
}
2011-01-24 19:50:31 +00:00
2013-02-27 13:12:14 +00:00
public function testHttpMethodOverride ()
{
$container = $this -> createContainerFromFile ( 'full' );
$this -> assertFalse ( $container -> getParameter ( 'kernel.http_method_override' ));
}
2011-01-24 19:50:31 +00:00
public function testEsi ()
{
$container = $this -> createContainerFromFile ( 'full' );
$this -> assertTrue ( $container -> hasDefinition ( 'esi' ), '->registerEsiConfiguration() loads esi.xml' );
}
2013-04-26 14:53:58 +01:00
public function testEnabledProfiler ()
2011-01-24 19:50:31 +00:00
{
2013-04-26 14:53:58 +01:00
$container = $this -> createContainerFromFile ( 'profiler' );
2011-01-24 19:50:31 +00:00
$this -> assertTrue ( $container -> hasDefinition ( 'profiler' ), '->registerProfilerConfiguration() loads profiling.xml' );
$this -> assertTrue ( $container -> hasDefinition ( 'data_collector.config' ), '->registerProfilerConfiguration() loads collectors.xml' );
2013-02-14 15:42:17 +00:00
}
public function testDisabledProfiler ()
{
2013-04-26 14:53:58 +01:00
$container = $this -> createContainerFromFile ( 'full' );
2012-07-13 14:40:24 +01:00
2013-02-14 15:42:17 +00:00
$this -> assertFalse ( $container -> hasDefinition ( 'profiler' ), '->registerProfilerConfiguration() does not load profiling.xml' );
$this -> assertFalse ( $container -> hasDefinition ( 'data_collector.config' ), '->registerProfilerConfiguration() does not load collectors.xml' );
2011-01-24 19:50:31 +00:00
}
public function testRouter ()
{
$container = $this -> createContainerFromFile ( 'full' );
2011-07-18 09:10:04 +01:00
$this -> assertTrue ( $container -> has ( 'router' ), '->registerRouterConfiguration() loads routing.xml' );
$arguments = $container -> findDefinition ( 'router' ) -> getArguments ();
2011-05-13 10:57:05 +01:00
$this -> assertEquals ( $container -> getParameter ( 'kernel.root_dir' ) . '/config/routing.xml' , $container -> getParameter ( 'router.resource' ), '->registerRouterConfiguration() sets routing resource' );
$this -> assertEquals ( '%router.resource%' , $arguments [ 1 ], '->registerRouterConfiguration() sets routing resource' );
2011-04-23 14:27:35 +01:00
$this -> assertEquals ( 'xml' , $arguments [ 2 ][ 'resource_type' ], '->registerRouterConfiguration() sets routing resource type' );
2011-01-24 19:50:31 +00:00
}
/**
2013-01-05 17:52:40 +00:00
* @ expectedException \Symfony\Component\Config\Definition\Exception\InvalidConfigurationException
2011-01-24 19:50:31 +00:00
*/
public function testRouterRequiresResourceOption ()
2010-06-07 08:08:35 +01:00
{
2011-01-24 19:50:31 +00:00
$container = $this -> createContainer ();
2010-09-20 20:01:41 +01:00
$loader = new FrameworkExtension ();
2011-02-15 04:58:18 +00:00
$loader -> load ( array ( array ( 'router' => true )), $container );
2011-01-24 19:50:31 +00:00
}
public function testSession ()
{
$container = $this -> createContainerFromFile ( 'full' );
$this -> assertTrue ( $container -> hasDefinition ( 'session' ), '->registerSessionConfiguration() loads session.xml' );
2011-10-05 10:09:51 +01:00
$this -> assertEquals ( 'fr' , $container -> getParameter ( 'kernel.default_locale' ));
2012-03-03 09:03:04 +00:00
$this -> assertEquals ( 'session.storage.native' , ( string ) $container -> getAlias ( 'session.storage' ));
$this -> assertEquals ( 'session.handler.native_file' , ( string ) $container -> getAlias ( 'session.handler' ));
2011-03-02 18:51:17 +00:00
2011-04-22 11:35:09 +01:00
$options = $container -> getParameter ( 'session.storage.options' );
2011-01-24 19:50:31 +00:00
$this -> assertEquals ( '_SYMFONY' , $options [ 'name' ]);
2012-02-23 10:53:14 +00:00
$this -> assertEquals ( 86400 , $options [ 'cookie_lifetime' ]);
$this -> assertEquals ( '/' , $options [ 'cookie_path' ]);
$this -> assertEquals ( 'example.com' , $options [ 'cookie_domain' ]);
$this -> assertTrue ( $options [ 'cookie_secure' ]);
2015-07-27 08:36:17 +01:00
$this -> assertFalse ( $options [ 'cookie_httponly' ]);
2015-02-12 15:48:57 +00:00
$this -> assertTrue ( $options [ 'use_cookies' ]);
2012-03-21 03:22:23 +00:00
$this -> assertEquals ( 108 , $options [ 'gc_divisor' ]);
$this -> assertEquals ( 1 , $options [ 'gc_probability' ]);
$this -> assertEquals ( 90000 , $options [ 'gc_maxlifetime' ]);
2012-04-13 09:34:00 +01:00
$this -> assertEquals ( '/path/to/sessions' , $container -> getParameter ( 'session.save_path' ));
2011-01-24 19:50:31 +00:00
}
2013-06-07 23:05:01 +01:00
public function testNullSessionHandler ()
{
$container = $this -> createContainerFromFile ( 'session' );
$this -> assertTrue ( $container -> hasDefinition ( 'session' ), '->registerSessionConfiguration() loads session.xml' );
$this -> assertNull ( $container -> getDefinition ( 'session.storage.native' ) -> getArgument ( 1 ));
$this -> assertNull ( $container -> getDefinition ( 'session.storage.php_bridge' ) -> getArgument ( 0 ));
}
2013-12-25 21:24:54 +00:00
public function testRequest ()
{
$container = $this -> createContainerFromFile ( 'full' );
$this -> assertTrue ( $container -> hasDefinition ( 'request.add_request_formats_listener' ), '->registerRequestConfiguration() loads request.xml' );
$listenerDef = $container -> getDefinition ( 'request.add_request_formats_listener' );
$this -> assertEquals ( array ( 'csv' => array ( 'text/csv' , 'text/plain' ), 'pdf' => array ( 'application/pdf' )), $listenerDef -> getArgument ( 0 ));
}
public function testEmptyRequestFormats ()
{
$container = $this -> createContainerFromFile ( 'request' );
$this -> assertFalse ( $container -> hasDefinition ( 'request.add_request_formats_listener' ), '->registerRequestConfiguration() does not load request.xml when no request formats are defined' );
}
2011-01-24 19:50:31 +00:00
public function testTemplating ()
{
$container = $this -> createContainerFromFile ( 'full' );
2010-06-07 08:08:35 +01:00
2011-01-24 19:50:31 +00:00
$this -> assertTrue ( $container -> hasDefinition ( 'templating.name_parser' ), '->registerTemplatingConfiguration() loads templating.xml' );
2011-05-21 00:08:03 +01:00
2011-01-24 19:50:31 +00:00
$this -> assertEquals ( 'templating.engine.delegating' , ( string ) $container -> getAlias ( 'templating' ), '->registerTemplatingConfiguration() configures delegating loader if multiple engines are provided' );
2011-04-02 16:05:02 +01:00
$this -> assertEquals ( $container -> getDefinition ( 'templating.loader.chain' ), $container -> getDefinition ( 'templating.loader.wrapped' ), '->registerTemplatingConfiguration() configures loader chain if multiple loaders are provided' );
$this -> assertEquals ( $container -> getDefinition ( 'templating.loader' ), $container -> getDefinition ( 'templating.loader.cache' ), '->registerTemplatingConfiguration() configures the loader to use cache' );
2011-05-13 10:57:05 +01:00
$this -> assertEquals ( '%templating.loader.cache.path%' , $container -> getDefinition ( 'templating.loader.cache' ) -> getArgument ( 1 ));
$this -> assertEquals ( '/path/to/cache' , $container -> getParameter ( 'templating.loader.cache.path' ));
2011-02-10 21:05:04 +00:00
$this -> assertEquals ( array ( 'php' , 'twig' ), $container -> getParameter ( 'templating.engines' ), '->registerTemplatingConfiguration() sets a templating.engines parameter' );
2011-06-22 07:27:40 +01:00
$this -> assertEquals ( array ( 'FrameworkBundle:Form' , 'theme1' , 'theme2' ), $container -> getParameter ( 'templating.helper.form.resources' ), '->registerTemplatingConfiguration() registers the theme and adds the base theme' );
2014-08-10 13:44:20 +01:00
$this -> assertEquals ( 'global_hinclude_template' , $container -> getParameter ( 'fragment.renderer.hinclude.global_template' ), '->registerTemplatingConfiguration() registers the global hinclude.js template' );
2011-01-24 19:50:31 +00:00
}
2015-02-12 09:20:19 +00:00
public function testAssets ()
2011-09-26 18:19:08 +01:00
{
2015-02-12 09:20:19 +00:00
$container = $this -> createContainerFromFile ( 'assets' );
$packages = $container -> getDefinition ( 'assets.packages' );
2011-09-26 18:19:08 +01:00
2015-02-12 09:20:19 +00:00
// default package
$defaultPackage = $container -> getDefinition ( $packages -> getArgument ( 0 ));
$this -> assertUrlPackage ( $container , $defaultPackage , array ( 'http://cdn.example.com' ), 'SomeVersionScheme' , '%%s?version=%%s' );
2015-01-17 07:35:04 +00:00
2015-02-12 09:20:19 +00:00
// packages
$packages = $packages -> getArgument ( 1 );
2016-01-25 21:22:29 +00:00
$this -> assertCount ( 5 , $packages );
2015-02-12 09:20:19 +00:00
$package = $container -> getDefinition ( $packages [ 'images_path' ]);
$this -> assertPathPackage ( $container , $package , '/foo' , 'SomeVersionScheme' , '%%s?version=%%s' );
$package = $container -> getDefinition ( $packages [ 'images' ]);
$this -> assertUrlPackage ( $container , $package , array ( 'http://images1.example.com' , 'http://images2.example.com' ), '1.0.0' , '%%s?version=%%s' );
$package = $container -> getDefinition ( $packages [ 'foo' ]);
$this -> assertPathPackage ( $container , $package , '' , '1.0.0' , '%%s-%%s' );
$package = $container -> getDefinition ( $packages [ 'bar' ]);
$this -> assertUrlPackage ( $container , $package , array ( 'https://bar2.example.com' ), 'SomeVersionScheme' , '%%s?version=%%s' );
2016-01-25 21:22:29 +00:00
$package = $container -> getDefinition ( $packages [ 'bar_version_strategy' ]);
$this -> assertEquals ( 'assets.custom_version_strategy' , ( string ) $package -> getArgument ( 1 ));
}
public function testAssetsDefaultVersionStrategyAsService ()
{
$container = $this -> createContainerFromFile ( 'assets_version_strategy_as_service' );
$packages = $container -> getDefinition ( 'assets.packages' );
// default package
$defaultPackage = $container -> getDefinition ( $packages -> getArgument ( 0 ));
$this -> assertEquals ( 'assets.custom_version_strategy' , ( string ) $defaultPackage -> getArgument ( 1 ));
2011-09-26 18:19:08 +01:00
}
2011-01-24 19:50:31 +00:00
public function testTranslator ()
{
$container = $this -> createContainerFromFile ( 'full' );
2011-07-19 11:05:51 +01:00
$this -> assertTrue ( $container -> hasDefinition ( 'translator.default' ), '->registerTranslatorConfiguration() loads translation.xml' );
$this -> assertEquals ( 'translator.default' , ( string ) $container -> getAlias ( 'translator' ), '->registerTranslatorConfiguration() redefines translator service from identity to real translator' );
2015-03-24 13:45:14 +00:00
$options = $container -> getDefinition ( 'translator.default' ) -> getArgument ( 3 );
2011-01-24 19:50:31 +00:00
2015-03-24 13:45:14 +00:00
$files = array_map ( function ( $resource ) { return realpath ( $resource ); }, $options [ 'resource_files' ][ 'en' ]);
2015-01-08 16:22:13 +00:00
$ref = new \ReflectionClass ( 'Symfony\Component\Validator\Validation' );
2011-01-24 19:50:31 +00:00
$this -> assertContains (
2013-09-18 08:24:07 +01:00
strtr ( dirname ( $ref -> getFileName ()) . '/Resources/translations/validators.en.xlf' , '/' , DIRECTORY_SEPARATOR ),
2012-06-16 12:08:37 +01:00
$files ,
'->registerTranslatorConfiguration() finds Validator translation resources'
);
2013-05-13 03:46:20 +01:00
$ref = new \ReflectionClass ( 'Symfony\Component\Form\Form' );
2012-06-16 12:08:37 +01:00
$this -> assertContains (
2013-09-18 08:24:07 +01:00
strtr ( dirname ( $ref -> getFileName ()) . '/Resources/translations/validators.en.xlf' , '/' , DIRECTORY_SEPARATOR ),
2012-06-16 12:08:37 +01:00
$files ,
'->registerTranslatorConfiguration() finds Form translation resources'
2011-01-24 19:50:31 +00:00
);
2015-01-08 16:22:13 +00:00
$ref = new \ReflectionClass ( 'Symfony\Component\Security\Core\Security' );
2012-07-15 14:56:45 +01:00
$this -> assertContains (
2013-09-18 08:24:07 +01:00
strtr ( dirname ( $ref -> getFileName ()) . '/Resources/translations/security.en.xlf' , '/' , DIRECTORY_SEPARATOR ),
2012-07-15 14:56:45 +01:00
$files ,
'->registerTranslatorConfiguration() finds Security translation resources'
);
2015-05-05 20:36:55 +01:00
$this -> assertContains (
strtr ( __DIR__ . '/Fixtures/translations/test_paths.en.yml' , '/' , DIRECTORY_SEPARATOR ),
$files ,
'->registerTranslatorConfiguration() finds translation resources in custom paths'
);
2011-01-24 19:50:31 +00:00
2011-07-19 11:05:51 +01:00
$calls = $container -> getDefinition ( 'translator.default' ) -> getMethodCalls ();
2015-09-09 12:50:25 +01:00
$this -> assertEquals ( array ( 'fr' ), $calls [ 1 ][ 1 ][ 0 ]);
2011-01-24 19:50:31 +00:00
}
2015-02-04 07:25:10 +00:00
public function testTranslatorMultipleFallbacks ()
2015-01-12 11:17:42 +00:00
{
$container = $this -> createContainerFromFile ( 'translator_fallbacks' );
$calls = $container -> getDefinition ( 'translator.default' ) -> getMethodCalls ();
2015-09-09 12:50:25 +01:00
$this -> assertEquals ( array ( 'en' , 'fr' ), $calls [ 1 ][ 1 ][ 0 ]);
2015-01-12 11:17:42 +00:00
}
2011-01-24 19:50:31 +00:00
/**
2013-01-05 17:52:40 +00:00
* @ expectedException \Symfony\Component\Config\Definition\Exception\InvalidConfigurationException
2011-01-24 19:50:31 +00:00
*/
public function testTemplatingRequiresAtLeastOneEngine ()
{
$container = $this -> createContainer ();
2010-09-20 20:01:41 +01:00
$loader = new FrameworkExtension ();
2011-02-15 04:58:18 +00:00
$loader -> load ( array ( array ( 'templating' => null )), $container );
2011-01-24 19:50:31 +00:00
}
public function testValidation ()
{
$container = $this -> createContainerFromFile ( 'full' );
2010-06-16 13:19:46 +01:00
2013-05-13 03:46:20 +01:00
$ref = new \ReflectionClass ( 'Symfony\Component\Form\Form' );
2015-08-26 19:16:18 +01:00
$xmlMappings = array ( dirname ( $ref -> getFileName ()) . '/Resources/config/validation.xml' );
2014-03-18 16:36:12 +00:00
$calls = $container -> getDefinition ( 'validator.builder' ) -> getMethodCalls ();
2015-03-22 15:12:19 +00:00
$this -> assertCount ( 6 , $calls );
2014-03-18 17:23:55 +00:00
$this -> assertSame ( 'setConstraintValidatorFactory' , $calls [ 0 ][ 0 ]);
2014-03-18 16:36:12 +00:00
$this -> assertEquals ( array ( new Reference ( 'validator.validator_factory' )), $calls [ 0 ][ 1 ]);
$this -> assertSame ( 'setTranslator' , $calls [ 1 ][ 0 ]);
$this -> assertEquals ( array ( new Reference ( 'translator' )), $calls [ 1 ][ 1 ]);
$this -> assertSame ( 'setTranslationDomain' , $calls [ 2 ][ 0 ]);
$this -> assertSame ( array ( '%validator.translation_domain%' ), $calls [ 2 ][ 1 ]);
$this -> assertSame ( 'addXmlMappings' , $calls [ 3 ][ 0 ]);
$this -> assertSame ( array ( $xmlMappings ), $calls [ 3 ][ 1 ]);
$this -> assertSame ( 'addMethodMapping' , $calls [ 4 ][ 0 ]);
2014-06-03 15:40:53 +01:00
$this -> assertSame ( array ( 'loadValidatorMetadata' ), $calls [ 4 ][ 1 ]);
2014-03-18 17:23:55 +00:00
$this -> assertSame ( 'setMetadataCache' , $calls [ 5 ][ 0 ]);
2015-12-03 13:16:45 +00:00
$this -> assertEquals ( array ( new Reference ( 'validator.mapping.cache.doctrine.apc' )), $calls [ 5 ][ 1 ]);
2014-04-03 17:10:06 +01:00
}
public function testValidationService ()
{
$container = $this -> createContainerFromFile ( 'validation_annotations' );
2015-01-19 17:16:09 +00:00
$this -> assertInstanceOf ( 'Symfony\Component\Validator\Validator\ValidatorInterface' , $container -> get ( 'validator' ));
2010-06-24 09:40:05 +01:00
}
2011-05-03 13:36:42 +01:00
public function testAnnotations ()
{
$container = $this -> createContainerFromFile ( 'full' );
2015-10-08 10:44:44 +01:00
$this -> assertEquals ( $container -> getParameter ( 'kernel.cache_dir' ) . '/annotations' , $container -> getDefinition ( 'annotations.filesystem_cache' ) -> getArgument ( 0 ));
2015-09-29 14:40:49 +01:00
$this -> assertSame ( 'annotations.cached_reader' , ( string ) $container -> getAlias ( 'annotation_reader' ));
2015-10-08 10:44:44 +01:00
$this -> assertSame ( 'annotations.filesystem_cache' , ( string ) $container -> getDefinition ( 'annotations.cached_reader' ) -> getArgument ( 1 ));
2011-05-03 13:36:42 +01:00
}
2011-07-12 18:01:49 +01:00
public function testFileLinkFormat ()
{
$container = $this -> createContainerFromFile ( 'full' );
$this -> assertEquals ( 'file%link%format' , $container -> getParameter ( 'templating.helper.code.file_link_format' ));
}
2011-01-24 19:50:31 +00:00
public function testValidationAnnotations ()
{
$container = $this -> createContainerFromFile ( 'validation_annotations' );
2014-03-18 16:36:12 +00:00
$calls = $container -> getDefinition ( 'validator.builder' ) -> getMethodCalls ();
2015-03-22 15:12:19 +00:00
$this -> assertCount ( 6 , $calls );
2014-04-02 17:29:34 +01:00
$this -> assertSame ( 'enableAnnotationMapping' , $calls [ 4 ][ 0 ]);
2014-03-18 16:36:12 +00:00
$this -> assertEquals ( array ( new Reference ( 'annotation_reader' )), $calls [ 4 ][ 1 ]);
$this -> assertSame ( 'addMethodMapping' , $calls [ 5 ][ 0 ]);
2014-06-03 15:40:53 +01:00
$this -> assertSame ( array ( 'loadValidatorMetadata' ), $calls [ 5 ][ 1 ]);
2014-03-18 16:36:12 +00:00
// no cache this time
2011-01-24 19:50:31 +00:00
}
2011-04-11 22:26:11 +01:00
public function testValidationPaths ()
2010-08-10 14:55:05 +01:00
{
2015-03-21 10:51:07 +00:00
require_once __DIR__ . '/Fixtures/TestBundle/TestBundle.php' ;
2011-04-15 20:12:02 +01:00
2011-04-11 22:26:11 +01:00
$container = $this -> createContainerFromFile ( 'validation_annotations' , array (
'kernel.bundles' => array ( 'TestBundle' => 'Symfony\Bundle\FrameworkBundle\Tests\TestBundle' ),
));
2014-03-18 16:36:12 +00:00
$calls = $container -> getDefinition ( 'validator.builder' ) -> getMethodCalls ();
2015-03-22 15:12:19 +00:00
$this -> assertCount ( 7 , $calls );
2014-03-18 16:36:12 +00:00
$this -> assertSame ( 'addXmlMappings' , $calls [ 3 ][ 0 ]);
$this -> assertSame ( 'addYamlMappings' , $calls [ 4 ][ 0 ]);
2014-04-02 17:29:34 +01:00
$this -> assertSame ( 'enableAnnotationMapping' , $calls [ 5 ][ 0 ]);
2014-03-18 16:36:12 +00:00
$this -> assertSame ( 'addMethodMapping' , $calls [ 6 ][ 0 ]);
2014-06-03 15:40:53 +01:00
$this -> assertSame ( array ( 'loadValidatorMetadata' ), $calls [ 6 ][ 1 ]);
2014-03-18 16:36:12 +00:00
$xmlMappings = $calls [ 3 ][ 1 ][ 0 ];
$this -> assertCount ( 2 , $xmlMappings );
2015-04-24 20:21:36 +01:00
try {
// Testing symfony/symfony
$this -> assertStringEndsWith ( 'Component' . DIRECTORY_SEPARATOR . 'Form/Resources/config/validation.xml' , $xmlMappings [ 0 ]);
} catch ( \Exception $e ) {
// Testing symfony/framework-bundle with deps=high
$this -> assertStringEndsWith ( 'symfony' . DIRECTORY_SEPARATOR . 'form/Resources/config/validation.xml' , $xmlMappings [ 0 ]);
}
2014-03-18 16:36:12 +00:00
$this -> assertStringEndsWith ( 'TestBundle' . DIRECTORY_SEPARATOR . 'Resources' . DIRECTORY_SEPARATOR . 'config' . DIRECTORY_SEPARATOR . 'validation.xml' , $xmlMappings [ 1 ]);
$yamlMappings = $calls [ 4 ][ 1 ][ 0 ];
$this -> assertCount ( 1 , $yamlMappings );
$this -> assertStringEndsWith ( 'TestBundle' . DIRECTORY_SEPARATOR . 'Resources' . DIRECTORY_SEPARATOR . 'config' . DIRECTORY_SEPARATOR . 'validation.yml' , $yamlMappings [ 0 ]);
}
public function testValidationNoStaticMethod ()
{
$container = $this -> createContainerFromFile ( 'validation_no_static_method' );
$calls = $container -> getDefinition ( 'validator.builder' ) -> getMethodCalls ();
2015-03-22 15:12:19 +00:00
$this -> assertCount ( 4 , $calls );
2014-03-18 16:36:12 +00:00
$this -> assertSame ( 'addXmlMappings' , $calls [ 3 ][ 0 ]);
// no cache, no annotations, no static methods
}
2013-10-09 09:42:58 +01:00
public function testFormsCanBeEnabledWithoutCsrfProtection ()
{
$container = $this -> createContainerFromFile ( 'form_no_csrf' );
$this -> assertFalse ( $container -> getParameter ( 'form.type_extension.csrf.enabled' ));
}
2014-08-02 10:58:38 +01:00
public function testStopwatchEnabledWithDebugModeEnabled ()
{
$container = $this -> createContainerFromFile ( 'default_config' , array (
'kernel.container_class' => 'foo' ,
'kernel.debug' => true ,
));
$this -> assertTrue ( $container -> has ( 'debug.stopwatch' ));
}
public function testStopwatchEnabledWithDebugModeDisabled ()
{
$container = $this -> createContainerFromFile ( 'default_config' , array (
'kernel.container_class' => 'foo' ,
));
$this -> assertTrue ( $container -> has ( 'debug.stopwatch' ));
}
2014-12-25 03:17:33 +00:00
public function testSerializerDisabled ()
{
$container = $this -> createContainerFromFile ( 'default_config' );
$this -> assertFalse ( $container -> has ( 'serializer' ));
}
public function testSerializerEnabled ()
{
$container = $this -> createContainerFromFile ( 'full' );
$this -> assertTrue ( $container -> has ( 'serializer' ));
2015-06-15 08:35:28 +01:00
$argument = $container -> getDefinition ( 'serializer.mapping.chain_loader' ) -> getArgument ( 0 );
$this -> assertCount ( 1 , $argument );
$this -> assertEquals ( 'Symfony\Component\Serializer\Mapping\Loader\AnnotationLoader' , $argument [ 0 ] -> getClass ());
$this -> assertEquals ( new Reference ( 'serializer.mapping.cache.apc' ), $container -> getDefinition ( 'serializer.mapping.class_metadata_factory' ) -> getArgument ( 1 ));
$this -> assertEquals ( new Reference ( 'serializer.name_converter.camel_case_to_snake_case' ), $container -> getDefinition ( 'serializer.normalizer.object' ) -> getArgument ( 1 ));
2014-12-25 03:17:33 +00:00
}
2015-12-10 14:53:36 +00:00
public function testRegisterSerializerExtractor ()
{
$container = $this -> createContainerFromFile ( 'full' );
$serializerExtractorDefinition = $container -> getDefinition ( 'property_info.serializer_extractor' );
$this -> assertEquals ( 'serializer.mapping.class_metadata_factory' , $serializerExtractorDefinition -> getArgument ( 0 ) -> __toString ());
$this -> assertFalse ( $serializerExtractorDefinition -> isPublic ());
$tag = $serializerExtractorDefinition -> getTag ( 'property_info.list_extractor' );
$this -> assertEquals ( array ( 'priority' => - 999 ), $tag [ 0 ]);
}
2016-01-31 20:58:26 +00:00
public function testDataUriNormalizerRegistered ()
{
if ( ! class_exists ( 'Symfony\Component\Serializer\Normalizer\DataUriNormalizer' )) {
$this -> markTestSkipped ( 'The DataUriNormalizer has been introduced in the Serializer Component version 3.1.' );
}
$container = $this -> createContainerFromFile ( 'full' );
$definition = $container -> getDefinition ( 'serializer.normalizer.data_uri' );
$tag = $definition -> getTag ( 'serializer.normalizer' );
$this -> assertEquals ( DataUriNormalizer :: class , $definition -> getClass ());
$this -> assertEquals ( - 920 , $tag [ 0 ][ 'priority' ]);
}
2016-01-31 20:54:05 +00:00
public function testDateTimeNormalizerRegistered ()
{
if ( ! class_exists ( 'Symfony\Component\Serializer\Normalizer\DateTimeNormalizer' )) {
$this -> markTestSkipped ( 'The DateTimeNormalizer has been introduced in the Serializer Component version 3.1.' );
}
$container = $this -> createContainerFromFile ( 'full' );
$definition = $container -> getDefinition ( 'serializer.normalizer.datetime' );
$tag = $definition -> getTag ( 'serializer.normalizer' );
$this -> assertEquals ( DateTimeNormalizer :: class , $definition -> getClass ());
$this -> assertEquals ( - 910 , $tag [ 0 ][ 'priority' ]);
}
2016-02-26 17:18:07 +00:00
public function testJsonSerializableNormalizerRegistered ()
2016-01-29 15:26:46 +00:00
{
if ( ! class_exists ( 'Symfony\Component\Serializer\Normalizer\JsonSerializableNormalizer' )) {
$this -> markTestSkipped ( 'The JsonSerializableNormalizer has been introduced in the Serializer Component version 3.1.' );
}
$container = $this -> createContainerFromFile ( 'full' );
2016-02-26 17:18:07 +00:00
$definition = $container -> getDefinition ( 'serializer.normalizer.json_serializable' );
2016-01-29 15:26:46 +00:00
$tag = $definition -> getTag ( 'serializer.normalizer' );
$this -> assertEquals ( JsonSerializableNormalizer :: class , $definition -> getClass ());
$this -> assertEquals ( - 900 , $tag [ 0 ][ 'priority' ]);
}
2016-01-31 21:03:33 +00:00
public function testObjectNormalizerRegistered ()
{
$container = $this -> createContainerFromFile ( 'full' );
$definition = $container -> getDefinition ( 'serializer.normalizer.object' );
$tag = $definition -> getTag ( 'serializer.normalizer' );
2016-03-02 12:43:59 +00:00
$this -> assertEquals ( 'Symfony\Component\Serializer\Normalizer\ObjectNormalizer' , $definition -> getClass ());
2016-01-31 21:03:33 +00:00
$this -> assertEquals ( - 1000 , $tag [ 0 ][ 'priority' ]);
}
2015-04-20 17:28:31 +01:00
public function testAssetHelperWhenAssetsAreEnabled ()
{
$container = $this -> createContainerFromFile ( 'full' );
$packages = $container -> getDefinition ( 'templating.helper.assets' ) -> getArgument ( 0 );
$this -> assertSame ( 'assets.packages' , ( string ) $packages );
}
2016-02-20 16:27:18 +00:00
public function testAssetHelperWhenTemplatesAreEnabledAndNoAssetsConfiguration ()
2015-04-20 17:28:31 +01:00
{
2016-02-20 16:27:18 +00:00
$container = $this -> createContainerFromFile ( 'templating_no_assets' );
2016-02-02 20:19:07 +00:00
$packages = $container -> getDefinition ( 'templating.helper.assets' ) -> getArgument ( 0 );
$this -> assertSame ( 'assets.packages' , ( string ) $packages );
}
2016-02-20 16:27:18 +00:00
public function testAssetsHelperIsRemovedWhenPhpTemplatingEngineIsEnabledAndAssetsAreDisabled ()
{
$container = $this -> createContainerFromFile ( 'templating_php_assets_disabled' );
$this -> assertTrue ( ! $container -> has ( 'templating.helper.assets' ), 'The templating.helper.assets helper service is removed when assets are disabled.' );
}
2016-02-02 20:19:07 +00:00
public function testAssetHelperWhenAssetsAndTemplatesAreDisabled ()
{
$container = $this -> createContainerFromFile ( 'default_config' );
2015-04-20 17:28:31 +01:00
2015-05-06 01:54:25 +01:00
$this -> assertFalse ( $container -> hasDefinition ( 'templating.helper.assets' ));
2015-04-20 17:28:31 +01:00
}
2015-08-05 20:44:23 +01:00
public function testSerializerServiceIsRegisteredWhenEnabled ()
{
$container = $this -> createContainerFromFile ( 'serializer_enabled' );
$this -> assertTrue ( $container -> hasDefinition ( 'serializer' ));
}
public function testSerializerServiceIsNotRegisteredWhenDisabled ()
{
$container = $this -> createContainerFromFile ( 'serializer_disabled' );
$this -> assertFalse ( $container -> hasDefinition ( 'serializer' ));
}
2015-09-28 12:22:50 +01:00
public function testPropertyInfoDisabled ()
{
$container = $this -> createContainerFromFile ( 'default_config' );
$this -> assertFalse ( $container -> has ( 'property_info' ));
}
public function testPropertyInfoEnabled ()
{
$container = $this -> createContainerFromFile ( 'property_info' );
$this -> assertTrue ( $container -> has ( 'property_info' ));
}
2016-03-11 08:48:42 +00:00
public function testCachePoolServices ()
2016-02-20 23:25:19 +00:00
{
$container = $this -> createContainerFromFile ( 'cache' );
2016-03-11 08:48:42 +00:00
$this -> assertCachePoolServiceDefinitionIsCreated ( $container , 'foo' , 'apcu' , array ( 'index_1' => 30 ), 0 );
$this -> assertCachePoolServiceDefinitionIsCreated ( $container , 'bar' , 'doctrine' , array ( 'index_0' => new Reference ( 'app.doctrine_cache_provider' ), 'index_1' => 5 ));
$this -> assertCachePoolServiceDefinitionIsCreated ( $container , 'baz' , 'filesystem' , array ( 'index_0' => 'app/cache/psr' , 'index_1' => 7 ));
$this -> assertCachePoolServiceDefinitionIsCreated ( $container , 'foobar' , 'psr6' , array ( 'index_0' => new Reference ( 'app.cache_pool' ), 'index_1' => 10 ));
2016-02-20 23:25:19 +00:00
}
2011-04-11 22:26:11 +01:00
protected function createContainer ( array $data = array ())
{
return new ContainerBuilder ( new ParameterBag ( array_merge ( array (
2014-10-22 19:27:13 +01:00
'kernel.bundles' => array ( 'FrameworkBundle' => 'Symfony\\Bundle\\FrameworkBundle\\FrameworkBundle' ),
'kernel.cache_dir' => __DIR__ ,
'kernel.debug' => false ,
2013-09-12 05:41:55 +01:00
'kernel.environment' => 'test' ,
2014-10-22 19:27:13 +01:00
'kernel.name' => 'kernel' ,
'kernel.root_dir' => __DIR__ ,
2011-04-11 22:26:11 +01:00
), $data )));
2010-08-10 14:55:05 +01:00
}
2011-01-24 19:50:31 +00:00
2011-04-11 22:26:11 +01:00
protected function createContainerFromFile ( $file , $data = array ())
2011-01-24 19:50:31 +00:00
{
2016-01-30 21:24:39 +00:00
$cacheKey = md5 ( get_class ( $this ) . $file . serialize ( $data ));
2016-01-16 12:37:00 +00:00
if ( isset ( self :: $containerCache [ $cacheKey ])) {
return self :: $containerCache [ $cacheKey ];
}
2011-04-11 22:26:11 +01:00
$container = $this -> createContainer ( $data );
2011-01-24 19:50:31 +00:00
$container -> registerExtension ( new FrameworkExtension ());
$this -> loadFromFile ( $container , $file );
$container -> getCompilerPassConfig () -> setOptimizationPasses ( array ());
$container -> getCompilerPassConfig () -> setRemovingPasses ( array ());
$container -> compile ();
2016-01-16 12:37:00 +00:00
return self :: $containerCache [ $cacheKey ] = $container ;
2011-01-24 19:50:31 +00:00
}
2015-01-17 07:35:04 +00:00
protected function createContainerFromClosure ( $closure , $data = array ())
{
$container = $this -> createContainer ( $data );
$container -> registerExtension ( new FrameworkExtension ());
$loader = new ClosureLoader ( $container );
$loader -> load ( $closure );
$container -> getCompilerPassConfig () -> setOptimizationPasses ( array ());
$container -> getCompilerPassConfig () -> setRemovingPasses ( array ());
$container -> compile ();
return $container ;
}
2015-06-26 17:55:11 +01:00
private function assertPathPackage ( ContainerBuilder $container , DefinitionDecorator $package , $basePath , $version , $format )
2015-01-17 07:35:04 +00:00
{
$this -> assertEquals ( 'assets.path_package' , $package -> getParent ());
$this -> assertEquals ( $basePath , $package -> getArgument ( 0 ));
$this -> assertVersionStrategy ( $container , $package -> getArgument ( 1 ), $version , $format );
}
2015-06-26 17:55:11 +01:00
private function assertUrlPackage ( ContainerBuilder $container , DefinitionDecorator $package , $baseUrls , $version , $format )
2015-01-17 07:35:04 +00:00
{
$this -> assertEquals ( 'assets.url_package' , $package -> getParent ());
$this -> assertEquals ( $baseUrls , $package -> getArgument ( 0 ));
$this -> assertVersionStrategy ( $container , $package -> getArgument ( 1 ), $version , $format );
}
private function assertVersionStrategy ( ContainerBuilder $container , Reference $reference , $version , $format )
{
$versionStrategy = $container -> getDefinition ( $reference );
if ( null === $version ) {
$this -> assertEquals ( 'assets.empty_version_strategy' , ( string ) $reference );
} else {
$this -> assertEquals ( 'assets.static_version_strategy' , $versionStrategy -> getParent ());
$this -> assertEquals ( $version , $versionStrategy -> getArgument ( 0 ));
$this -> assertEquals ( $format , $versionStrategy -> getArgument ( 1 ));
}
}
2016-02-20 23:25:19 +00:00
2016-03-11 08:48:42 +00:00
private function assertCachePoolServiceDefinitionIsCreated ( ContainerBuilder $container , $name , $type , array $arguments , $namespaceArgumentIndex = null )
2016-02-20 23:25:19 +00:00
{
2016-03-11 08:48:42 +00:00
$id = 'cache.pool.' . $name ;
2016-02-20 23:25:19 +00:00
2016-03-11 08:48:42 +00:00
$this -> assertTrue ( $container -> has ( $id ), sprintf ( 'Service definition "%s" for cache pool of type "%s" is registered' , $id , $type ));
2016-02-20 23:25:19 +00:00
2016-03-11 08:48:42 +00:00
$poolDefinition = $container -> getDefinition ( $id );
$this -> assertInstanceOf ( DefinitionDecorator :: class , $poolDefinition , sprintf ( 'Cache pool "%s" is based on an abstract cache adapter.' , $name ));
$this -> assertEquals ( $arguments , $poolDefinition -> getArguments ());
$adapterDefinition = $container -> getDefinition ( $poolDefinition -> getParent ());
2016-02-20 23:25:19 +00:00
switch ( $type ) {
case 'apcu' :
$this -> assertSame ( ApcuAdapter :: class , $adapterDefinition -> getClass ());
break ;
case 'doctrine' :
$this -> assertSame ( DoctrineAdapter :: class , $adapterDefinition -> getClass ());
break ;
case 'filesystem' :
$this -> assertSame ( FilesystemAdapter :: class , $adapterDefinition -> getClass ());
break ;
}
$this -> assertTrue ( $adapterDefinition -> hasTag ( 'cache.adapter' ), sprintf ( 'Service definition "%s" is tagged with the "cache.adapter" tag.' , $id ));
$tag = $adapterDefinition -> getTag ( 'cache.adapter' );
if ( null !== $namespaceArgumentIndex ) {
$this -> assertTrue ( isset ( $tag [ 0 ][ 'namespace-arg-index' ]), 'The namespace argument index is given by the "namespace-arg-index" attribute of the "cache.adapter" tag.' );
$this -> assertSame ( $namespaceArgumentIndex , $tag [ 0 ][ 'namespace-arg-index' ], 'The namespace argument index is given by the "namespace-arg-index" attribute of the "cache.adapter" tag.' );
}
}
2010-06-07 08:08:35 +01:00
}