mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-12 13:24:25 +00:00
check config of available language
check that the configuration is consistent with fallback locale : the fallback locale must be comprised in chill_main.available_languages. +tests refs #332
This commit is contained in:
parent
904fb633ff
commit
722709c432
@ -5,6 +5,7 @@ namespace Chill\MainBundle;
|
|||||||
use Symfony\Component\HttpKernel\Bundle\Bundle;
|
use Symfony\Component\HttpKernel\Bundle\Bundle;
|
||||||
use Symfony\Component\DependencyInjection\ContainerBuilder;
|
use Symfony\Component\DependencyInjection\ContainerBuilder;
|
||||||
use Chill\MainBundle\DependencyInjection\SearchableServicesCompilerPass;
|
use Chill\MainBundle\DependencyInjection\SearchableServicesCompilerPass;
|
||||||
|
use Chill\MainBundle\DependencyInjection\ConfigConsistencyCompilerPass;
|
||||||
|
|
||||||
class ChillMainBundle extends Bundle
|
class ChillMainBundle extends Bundle
|
||||||
{
|
{
|
||||||
@ -12,5 +13,6 @@ class ChillMainBundle extends Bundle
|
|||||||
{
|
{
|
||||||
parent::build($container);
|
parent::build($container);
|
||||||
$container->addCompilerPass(new SearchableServicesCompilerPass());
|
$container->addCompilerPass(new SearchableServicesCompilerPass());
|
||||||
|
$container->addCompilerPass(new ConfigConsistencyCompilerPass());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
61
DependencyInjection/ConfigConsistencyCompilerPass.php
Normal file
61
DependencyInjection/ConfigConsistencyCompilerPass.php
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Chill is a software for social workers
|
||||||
|
* Copyright (C) 2015 Julien Fastré <julien.fastre@champs-libres.coop>
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Chill\MainBundle\DependencyInjection;
|
||||||
|
|
||||||
|
use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
|
||||||
|
use Symfony\Component\DependencyInjection\ContainerBuilder;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Description of ConfigConsistencyCompilerPass
|
||||||
|
*
|
||||||
|
* @author Julien Fastré <julien.fastre@champs-libres.coop>
|
||||||
|
*/
|
||||||
|
class ConfigConsistencyCompilerPass implements CompilerPassInterface
|
||||||
|
{
|
||||||
|
public function process(ContainerBuilder $container)
|
||||||
|
{
|
||||||
|
$availableLanguages = $container
|
||||||
|
->getParameter('chill_main.available_languages');
|
||||||
|
$methodCallsTranslator = $container
|
||||||
|
->findDefinition('translator.default')
|
||||||
|
->getMethodCalls();
|
||||||
|
|
||||||
|
$fallbackLocales = array();
|
||||||
|
foreach($methodCallsTranslator as $call) {
|
||||||
|
if ($call[0] === 'setFallbackLocales') {
|
||||||
|
$fallbackLocales = array_merge($fallbackLocales,
|
||||||
|
$call[1][0]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (count($fallbackLocales) === 0) {
|
||||||
|
throw new \LogicException('the fallback locale are not defined. '
|
||||||
|
. 'The framework config should not allow this.');
|
||||||
|
}
|
||||||
|
|
||||||
|
$diff = array_diff($fallbackLocales, $availableLanguages);
|
||||||
|
if (count($diff) > 0) {
|
||||||
|
throw new \RuntimeException(sprintf('The chill_main.available_languages'
|
||||||
|
. ' parameter does not contains fallback locales. The languages %s'
|
||||||
|
. ' are missing.', implode(', ', $diff)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
179
Tests/DependencyInjection/ConfigConsistencyCompilerPassTest.php
Normal file
179
Tests/DependencyInjection/ConfigConsistencyCompilerPassTest.php
Normal file
@ -0,0 +1,179 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Chill is a software for social workers
|
||||||
|
* Copyright (C) 2015 Julien Fastré <julien.fastre@champs-libres.coop>
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Chill\MainBundle\Tests\DependencyInjection;
|
||||||
|
|
||||||
|
use Chill\MainBundle\DependencyInjection\ConfigConsistencyCompilerPass;
|
||||||
|
use Symfony\Component\DependencyInjection\ContainerBuilderInterface;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Description of ConfigConsistencyCompilerPassTest
|
||||||
|
*
|
||||||
|
* @author Julien Fastré <julien.fastre@champs-libres.coop>
|
||||||
|
*/
|
||||||
|
class ConfigConsistencyCompilerPassTest extends \PHPUnit_Framework_TestCase
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @var \Chill\MainBundle\DependencyInjection\ConfigConsistencyCompilerPass
|
||||||
|
*/
|
||||||
|
private $configConsistencyCompilerPass;
|
||||||
|
|
||||||
|
public function setUp()
|
||||||
|
{
|
||||||
|
$this->configConsistencyCompilerPass = new ConfigConsistencyCompilerPass();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test that everything is fine is configuration is correct
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public function testLanguagesArePresent()
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$this ->configConsistencyCompilerPass
|
||||||
|
->process(
|
||||||
|
$this->mockContainer(
|
||||||
|
$this->mockTranslatorDefinition(array('fr')),
|
||||||
|
array('fr', 'nl')
|
||||||
|
)
|
||||||
|
);
|
||||||
|
$this->assertTrue(TRUE, 'the config consistency can process');
|
||||||
|
} catch (\Exception $ex) {
|
||||||
|
$this->assertTrue(FALSE,
|
||||||
|
'the config consistency can process');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test that everything is fine is configuration is correct
|
||||||
|
* if multiple fallback languages are present
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public function testMultiplesLanguagesArePresent()
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$this ->configConsistencyCompilerPass
|
||||||
|
->process(
|
||||||
|
$this->mockContainer(
|
||||||
|
$this->mockTranslatorDefinition(array('fr', 'nl')),
|
||||||
|
array('fr', 'nl', 'en')
|
||||||
|
)
|
||||||
|
);
|
||||||
|
$this->assertTrue(TRUE, 'the config consistency can process');
|
||||||
|
} catch (\Exception $ex) {
|
||||||
|
$this->assertTrue(FALSE,
|
||||||
|
'the config consistency can process');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test that a runtime exception is throw if the available language does
|
||||||
|
* not contains the fallback locale
|
||||||
|
*
|
||||||
|
* @expectedException \RuntimeException
|
||||||
|
* @expectedExceptionMessageRegExp /The chill_main.available_languages parameter does not contains fallback locales./
|
||||||
|
*/
|
||||||
|
public function testLanguageNotPresent()
|
||||||
|
{
|
||||||
|
$container = $this->mockContainer(
|
||||||
|
$this->mockTranslatorDefinition(array('en')), array('fr')
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->configConsistencyCompilerPass->process($container);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test that a logic exception is thrown if the setFallbackLocale
|
||||||
|
* method is not defined in translator definition
|
||||||
|
*
|
||||||
|
* @expectedException \LogicException
|
||||||
|
*/
|
||||||
|
public function testSetFallbackNotDefined()
|
||||||
|
{
|
||||||
|
$container = $this->mockContainer(
|
||||||
|
$this->mockTranslatorDefinition(NULL), array('fr')
|
||||||
|
);
|
||||||
|
$this->configConsistencyCompilerPass->process($container);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return ContainerBuilder
|
||||||
|
*/
|
||||||
|
private function mockContainer($definition, $availableLanguages)
|
||||||
|
{
|
||||||
|
$container = $this
|
||||||
|
->getMockBuilder('Symfony\Component\DependencyInjection\ContainerBuilder')
|
||||||
|
->getMock();
|
||||||
|
|
||||||
|
$container->method('getParameter')
|
||||||
|
->will($this->returnCallback(
|
||||||
|
function($parameter) use ($availableLanguages) {
|
||||||
|
if ($parameter === 'chill_main.available_languages') {
|
||||||
|
return $availableLanguages;
|
||||||
|
} else {
|
||||||
|
throw new \LogicException("the parameter '$parameter' "
|
||||||
|
. "is not defined in stub test");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
));
|
||||||
|
|
||||||
|
$container->method('findDefinition')
|
||||||
|
->will($this->returnCallback(
|
||||||
|
function($id) use ($definition) {
|
||||||
|
if (in_array($id, array('translator', 'translator.default'))) {
|
||||||
|
return $definition;
|
||||||
|
} else {
|
||||||
|
throw new \LogicException("the id $id is not defined in test");
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
|
||||||
|
|
||||||
|
return $container;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param type $languages
|
||||||
|
* @return 'Symfony\Component\DependencyInjection\Definition'
|
||||||
|
*/
|
||||||
|
private function mockTranslatorDefinition(array $languages = NULL)
|
||||||
|
{
|
||||||
|
$definition = $this
|
||||||
|
->getMockBuilder('Symfony\Component\DependencyInjection\Definition')
|
||||||
|
->getMock();
|
||||||
|
|
||||||
|
if (NULL !== $languages) {
|
||||||
|
$definition->method('getMethodCalls')
|
||||||
|
->willReturn(array(
|
||||||
|
['setFallbackLocales', array($languages)]
|
||||||
|
));
|
||||||
|
} else {
|
||||||
|
$definition->method('getMethodCalls')
|
||||||
|
->willReturn(array(['nothing', array()]));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $definition;
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user