Author: fabien
Date: 2010-01-15 12:13:51 +0100 (Fri, 15 Jan 2010)
New Revision: 26672

Added:
   
branches/2.0/tests/unit/Symfony/Components/DependencyInjection/BuilderConfigurationTest.php
Modified:
   
branches/2.0/src/Symfony/Components/DependencyInjection/BuilderConfiguration.php
   
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/DoctrineExtension.php
   
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/SwiftMailerExtension.php
   
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/SymfonyTemplatingExtension.php
   
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/ZendExtension.php
   
branches/2.0/tests/unit/Symfony/Components/DependencyInjection/BuilderTest.php
Log:
Merge branch 'master' of git://github.com/symfony/symfony

Modified: 
branches/2.0/src/Symfony/Components/DependencyInjection/BuilderConfiguration.php
===================================================================
--- 
branches/2.0/src/Symfony/Components/DependencyInjection/BuilderConfiguration.php
    2010-01-15 11:13:50 UTC (rev 26671)
+++ 
branches/2.0/src/Symfony/Components/DependencyInjection/BuilderConfiguration.php
    2010-01-15 11:13:51 UTC (rev 26672)
@@ -265,4 +265,25 @@
 
     return $this->definitions[$id];
   }
+
+  /**
+   * Gets a service definition by id or alias.
+   *
+   * The method "unaliases" recursively to return a Definition instance.
+   *
+   * @param  string  $id The service identifier or alias
+   *
+   * @return Definition A Definition instance
+   *
+   * @throws \InvalidArgumentException if the service definition does not exist
+   */
+  public function findDefinition($id)
+  {
+    if ($this->hasAlias($id))
+    {
+      return $this->findDefinition($this->getAlias($id));
+    }
+
+    return $this->getDefinition($id);
+  }
 }

Modified: 
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/DoctrineExtension.php
===================================================================
--- 
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/DoctrineExtension.php
      2010-01-15 11:13:50 UTC (rev 26671)
+++ 
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/DoctrineExtension.php
      2010-01-15 11:13:51 UTC (rev 26672)
@@ -27,6 +27,10 @@
   /**
    * Loads the DBAL configuration.
    *
+   * Usage example:
+   *
+   *      <doctrine:dbal dbname="sfweb" username="root" />
+   *
    * @param array $config A configuration array
    *
    * @return BuilderConfiguration A BuilderConfiguration instance

Modified: 
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/SwiftMailerExtension.php
===================================================================
--- 
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/SwiftMailerExtension.php
   2010-01-15 11:13:50 UTC (rev 26671)
+++ 
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/SwiftMailerExtension.php
   2010-01-15 11:13:51 UTC (rev 26672)
@@ -27,6 +27,14 @@
   /**
    * Loads the Swift Mailer configuration.
    *
+   * Usage example:
+   *
+   *      <swift:mailer transport="gmail" delivery_strategy="spool">
+   *        <swift:username>fabien</swift:username>
+   *        <swift:password>xxxxx</swift:password>
+   *        <swift:spool path="/path/to/spool/" />
+   *      </swift:mailer>
+   *
    * @param array $config A configuration array
    *
    * @return BuilderConfiguration A BuilderConfiguration instance

Modified: 
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/SymfonyTemplatingExtension.php
===================================================================
--- 
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/SymfonyTemplatingExtension.php
     2010-01-15 11:13:50 UTC (rev 26671)
+++ 
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/SymfonyTemplatingExtension.php
     2010-01-15 11:13:51 UTC (rev 26672)
@@ -26,8 +26,16 @@
 class SymfonyTemplatingExtension extends LoaderExtension
 {
   /**
-   * Loads the template configuration.
+   * Loads the templating configuration.
    *
+   * Usage example:
+   *
+   *      <symfony:templating path="/path/to/templates" cache="/path/to/cache">
+   *        
<symfony:loader>symfony.templating.loader.filesystem</symfony:loader>
+   *        
<symfony:helper>symfony.templating.helper.javascripts</symfony:helper>
+   *        
<symfony:helper>symfony.templating.helper.stylesheets</symfony:helper>
+   *      </symfony:templating>
+   *
    * @param array $config A configuration array
    *
    * @return BuilderConfiguration A BuilderConfiguration instance
@@ -89,8 +97,8 @@
     if (isset($config['cache']))
     {
       // wrap the loader with some cache
-      $configuration->setAlias('symfony.templating.loader.wrapped', 
$configuration->getAlias('symfony.templating.loader'));
-      $configuration->setAlias('symfony.templating.loader', 
'symfony.templating.loader.cache');
+      $configuration->setDefinition('symfony.templating.loader.wrapped', 
$configuration->findDefinition('symfony.templating.loader'));
+      $configuration->setDefinition('symfony.templating.loader', 
$configuration->getDefinition('symfony.templating.loader.cache'));
       $configuration->setParameter('symfony.templating.loader.cache.path', 
$config['cache']);
     }
 

Modified: 
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/ZendExtension.php
===================================================================
--- 
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/ZendExtension.php
  2010-01-15 11:13:50 UTC (rev 26671)
+++ 
branches/2.0/src/Symfony/Components/DependencyInjection/Loader/Extension/ZendExtension.php
  2010-01-15 11:13:51 UTC (rev 26672)
@@ -27,6 +27,10 @@
   /**
    * Loads the logger configuration.
    *
+   * Usage example:
+   *
+   *      <zend:logger priority="info" path="/path/to/some.log" />
+   *
    * @param array $config A configuration array
    *
    * @return BuilderConfiguration A BuilderConfiguration instance
@@ -54,6 +58,13 @@
   /**
    * Loads the mail configuration.
    *
+   * Usage example:
+   *
+   *      <zend:mail transport="gmail">
+   *        <zend:username>fabien</zend:username>
+   *        <zend:password>xxxxxx</zend:password>
+   *      </zend:mail>
+   *
    * @param array $config A configuration array
    *
    * @return BuilderConfiguration A BuilderConfiguration instance

Added: 
branches/2.0/tests/unit/Symfony/Components/DependencyInjection/BuilderConfigurationTest.php
===================================================================
--- 
branches/2.0/tests/unit/Symfony/Components/DependencyInjection/BuilderConfigurationTest.php
                         (rev 0)
+++ 
branches/2.0/tests/unit/Symfony/Components/DependencyInjection/BuilderConfigurationTest.php
 2010-01-15 11:13:51 UTC (rev 26672)
@@ -0,0 +1,177 @@
+<?php
+
+/*
+ * This file is part of the symfony package.
+ * (c) Fabien Potencier <[email protected]>
+ * 
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+require_once __DIR__.'/../../../bootstrap.php';
+
+use Symfony\Components\DependencyInjection\Builder;
+use Symfony\Components\DependencyInjection\BuilderConfiguration;
+use Symfony\Components\DependencyInjection\Definition;
+use Symfony\Components\DependencyInjection\Reference;
+
+$fixturesPath = 
__DIR__.'/../../../../fixtures/Symfony/Components/DependencyInjection/';
+
+$t = new LimeTest(1);
+
+// __construct()
+$t->diag('__construct()');
+$definitions = array(
+  'foo' => new Definition('FooClass'),
+  'bar' => new Definition('BarClass'),
+);
+$parameters = array(
+  'foo' => 'foo',
+  'bar' => 'bar',
+);
+$configuration = new BuilderConfiguration($definitions, $parameters);
+$t->is($configuration->getDefinitions(), $definitions, '__construct() takes an 
array of definitions as its first argument');
+$t->is($configuration->getParameters(), $parameters, '__construct() takes an 
array of parameters as its second argument');
+
+// ->merge()
+$t->diag('->merge()');
+$configuration = new BuilderConfiguration();
+$configuration->merge(null);
+$t->is($configuration->getParameters(), array(), '->merge() accepts null as an 
argument');
+$t->is($configuration->getDefinitions(), array(), '->merge() accepts null as 
an argument');
+
+$configuration = new BuilderConfiguration(array(), array('bar' => 'foo'));
+$configuration1 = new BuilderConfiguration(array(), array('foo' => 'bar'));
+$configuration->merge($configuration1);
+$t->is($configuration->getParameters(), array('bar' => 'foo', 'foo' => 'bar'), 
'->merge() merges current parameters with the loaded ones');
+
+$configuration = new BuilderConfiguration(array(), array('bar' => 'foo', 'foo' 
=> 'baz'));
+$config = new BuilderConfiguration(array(), array('foo' => 'bar'));
+$configuration->merge($config);
+$t->is($configuration->getParameters(), array('bar' => 'foo', 'foo' => 'bar'), 
'->merge() overrides existing parameters');
+
+$configuration = new BuilderConfiguration(array('foo' => new 
Definition('FooClass'), 'bar' => new Definition('BarClass')));
+$config = new BuilderConfiguration(array('baz' => new Definition('BazClass')));
+$config->setAlias('alias_for_foo', 'foo');
+$configuration->merge($config);
+$t->is(array_keys($configuration->getDefinitions()), array('foo', 'bar', 
'baz'), '->merge() merges definitions already defined ones');
+$t->is($configuration->getAliases(), array('alias_for_foo' => 'foo'), 
'->merge() registers defined aliases');
+
+$configuration = new BuilderConfiguration(array('foo' => new 
Definition('FooClass')));
+$config->setDefinition('foo', new Definition('BazClass'));
+$configuration->merge($config);
+$t->is($configuration->getDefinition('foo')->getClass(), 'BazClass', 
'->merge() overrides already defined services');
+
+// ->setParameters() ->getParameters()
+$t->diag('->setParameters() ->getParameters()');
+
+$configuration = new BuilderConfiguration();
+$t->is($configuration->getParameters(), array(), '->getParameters() returns an 
empty array if no parameter has been defined');
+
+$configuration->setParameters(array('foo' => 'bar'));
+$t->is($configuration->getParameters(), array('foo' => 'bar'), 
'->setParameters() sets the parameters');
+
+$configuration->setParameters(array('bar' => 'foo'));
+$t->is($configuration->getParameters(), array('bar' => 'foo'), 
'->setParameters() overrides the previous defined parameters');
+
+$configuration->setParameters(array('Bar' => 'foo'));
+$t->is($configuration->getParameters(), array('bar' => 'foo'), 
'->setParameters() converts the key to lowercase');
+
+// ->setParameter() ->getParameter()
+$t->diag('->setParameter() ->getParameter() ');
+
+$configuration = new BuilderConfiguration(array(), array('foo' => 'bar'));
+$configuration->setParameter('bar', 'foo');
+$t->is($configuration->getParameter('bar'), 'foo', '->setParameter() sets the 
value of a new parameter');
+
+$configuration->setParameter('foo', 'baz');
+$t->is($configuration->getParameter('foo'), 'baz', '->setParameter() overrides 
previously set parameter');
+
+$configuration->setParameter('Foo', 'baz1');
+$t->is($configuration->getParameter('foo'), 'baz1', '->setParameter() converts 
the key to lowercase');
+$t->is($configuration->getParameter('FOO'), 'baz1', '->getParameter() converts 
the key to lowercase');
+
+try
+{
+  $configuration->getParameter('baba');
+  $t->fail('->getParameter() throws an \InvalidArgumentException if the key 
does not exist');
+}
+catch (\InvalidArgumentException $e)
+{
+  $t->pass('->getParameter() throws an \InvalidArgumentException if the key 
does not exist');
+}
+
+// ->hasParameter()
+$t->diag('->hasParameter()');
+$configuration = new BuilderConfiguration(array(), array('foo' => 'bar'));
+$t->ok($configuration->hasParameter('foo'), '->hasParameter() returns true if 
a parameter is defined');
+$t->ok($configuration->hasParameter('Foo'), '->hasParameter() converts the key 
to lowercase');
+$t->ok(!$configuration->hasParameter('bar'), '->hasParameter() returns false 
if a parameter is not defined');
+
+// ->addParameters()
+$t->diag('->addParameters()');
+$configuration = new BuilderConfiguration(array(), array('foo' => 'bar'));
+$configuration->addParameters(array('bar' => 'foo'));
+$t->is($configuration->getParameters(), array('foo' => 'bar', 'bar' => 'foo'), 
'->addParameters() adds parameters to the existing ones');
+$configuration->addParameters(array('Bar' => 'fooz'));
+$t->is($configuration->getParameters(), array('foo' => 'bar', 'bar' => 
'fooz'), '->addParameters() converts keys to lowercase');
+
+// ->setAlias() ->getAlias() ->hasAlias() ->getAliases() ->addAliases()
+$t->diag('->setAlias() ->getAlias() ->hasAlias()');
+$configuration = new BuilderConfiguration();
+$configuration->setAlias('bar', 'foo');
+$t->is($configuration->getAlias('bar'), 'foo', '->setAlias() defines a new 
alias');
+$t->ok($configuration->hasAlias('bar'), '->hasAlias() returns true if the 
alias is defined');
+$t->ok(!$configuration->hasAlias('baba'), '->hasAlias() returns false if the 
alias is not defined');
+
+try
+{
+  $configuration->getAlias('baba');
+  $t->fail('->getAlias() throws an \InvalidArgumentException if the alias does 
not exist');
+}
+catch (\InvalidArgumentException $e)
+{
+  $t->pass('->getAlias() throws an \InvalidArgumentException if the alias does 
not exist');
+}
+
+$configuration->setAlias('barbar', 'foofoo');
+$t->is($configuration->getAliases(), array('bar' => 'foo', 'barbar' => 
'foofoo'), '->getAliases() returns an array of all defined aliases');
+
+$configuration->addAliases(array('foo' => 'bar'));
+$t->is($configuration->getAliases(), array('bar' => 'foo', 'barbar' => 
'foofoo', 'foo' => 'bar'), '->addAliases() adds some aliases');
+
+// ->setDefinitions() ->addDefinitions() ->getDefinitions() ->setDefinition() 
->getDefinition() ->hasDefinition()
+$t->diag('->setDefinitions() ->addDefinitions() ->getDefinitions() 
->setDefinition() ->getDefinition() ->hasDefinition()');
+$configuration = new BuilderConfiguration();
+$definitions = array(
+  'foo' => new Definition('FooClass'),
+  'bar' => new Definition('BarClass'),
+);
+$configuration->setDefinitions($definitions);
+$t->is($configuration->getDefinitions(), $definitions, '->setDefinitions() 
sets the service definitions');
+$t->ok($configuration->hasDefinition('foo'), '->hasDefinition() returns true 
if a service definition exists');
+$t->ok(!$configuration->hasDefinition('foobar'), '->hasDefinition() returns 
false if a service definition does not exist');
+
+$configuration->setDefinition('foobar', $foo = new Definition('FooBarClass'));
+$t->is($configuration->getDefinition('foobar'), $foo, '->getDefinition() 
returns a service definition if defined');
+$t->ok($configuration->setDefinition('foobar', $foo = new 
Definition('FooBarClass')) === $foo, '->setDefinition() implements a fuild 
interface by returning the service reference');
+
+$configuration->addDefinitions($defs = array('foobar' => new 
Definition('FooBarClass')));
+$t->is($configuration->getDefinitions(), array_merge($definitions, $defs), 
'->addDefinitions() adds the service definitions');
+
+try
+{
+  $configuration->getDefinition('baz');
+  $t->fail('->getDefinition() throws an InvalidArgumentException if the 
service definition does not exist');
+}
+catch (InvalidArgumentException $e)
+{
+  $t->pass('->getDefinition() throws an InvalidArgumentException if the 
service definition does not exist');
+}
+
+// ->findDefinition()
+$t->diag('->findDefinition()');
+$configuration = new BuilderConfiguration(array('foo' => $definition = new 
Definition('FooClass')));
+$configuration->setAlias('bar', 'foo');
+$configuration->setAlias('foobar', 'bar');
+$t->is($configuration->findDefinition('foobar'), $definition, 
'->findDefinition() returns a Definition');

Modified: 
branches/2.0/tests/unit/Symfony/Components/DependencyInjection/BuilderTest.php
===================================================================
--- 
branches/2.0/tests/unit/Symfony/Components/DependencyInjection/BuilderTest.php  
    2010-01-15 11:13:50 UTC (rev 26671)
+++ 
branches/2.0/tests/unit/Symfony/Components/DependencyInjection/BuilderTest.php  
    2010-01-15 11:13:51 UTC (rev 26672)
@@ -269,7 +269,7 @@
 $config->setDefinition('baz', new Definition('BazClass'));
 $config->setAlias('alias_for_foo', 'foo');
 $container->merge($config);
-$t->is(array_keys($container->getDefinitions()), array('foo', 'bar', 'baz'), 
'->load() merges definitions already defined ones');
+$t->is(array_keys($container->getDefinitions()), array('foo', 'bar', 'baz'), 
'->merge() merges definitions already defined ones');
 $t->is($container->getAliases(), array('alias_for_foo' => 'foo'), '->merge() 
registers defined aliases');
 
 $container = new Builder();

-- 
You received this message because you are subscribed to the Google Groups 
"symfony SVN" group.
To post to this group, send email to [email protected].
To unsubscribe from this group, send email to 
[email protected].
For more options, visit this group at 
http://groups.google.com/group/symfony-svn?hl=en.


Reply via email to