<?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.
*/namespaceSymfony\Component\DependencyInjection\Tests\Loader;
useSymfony\Component\DependencyInjection\ContainerBuilder;
useSymfony\Component\DependencyInjection\Loader\IniFileLoader;
useSymfony\Component\Config\FileLocator;
class IniFileLoaderTestextends \PHPUnit_Framework_TestCase {
protected static $fixturesPath;
protected $container;
protected $loader;
public static functionsetUpBeforeClass() {
self::$fixturesPath = realpath(__DIR__ . '/../Fixtures/');
}
protected functionsetUp() {
if (!class_exists('Symfony\\Component\\Config\\Loader\\Loader')) {
$this
->markTestSkipped('The "Config" component is not available');
}
$this->container = newContainerBuilder();
$this->loader = newIniFileLoader($this->container, newFileLocator(self::$fixturesPath . '/ini'));
}
/**
* @covers Symfony\Component\DependencyInjection\Loader\IniFileLoader::__construct
* @covers Symfony\Component\DependencyInjection\Loader\IniFileLoader::load
*/
public functiontestIniFileCanBeLoaded() {
$this->loader
->load('parameters.ini');
$this
->assertEquals(array(
'foo' => 'bar',
'bar' => '%foo%',
), $this->container
->getParameterBag()
->all(), '->load() takes a single file name as its first argument');
}
/**
* @covers Symfony\Component\DependencyInjection\Loader\IniFileLoader::__construct
* @covers Symfony\Component\DependencyInjection\Loader\IniFileLoader::load
*/
public functiontestExceptionIsRaisedWhenIniFileDoesNotExist() {
try {
$this->loader
->load('foo.ini');
$this
->fail('->load() throws an InvalidArgumentException if the loaded file does not exist');
} catch (\Exception $e) {
$this
->assertInstanceOf('\\InvalidArgumentException', $e, '->load() throws an InvalidArgumentException if the loaded file does not exist');
$this
->assertStringStartsWith('The file "foo.ini" does not exist (in: ', $e
->getMessage(), '->load() throws an InvalidArgumentException if the loaded file does not exist');
}
}
/**
* @covers Symfony\Component\DependencyInjection\Loader\IniFileLoader::__construct
* @covers Symfony\Component\DependencyInjection\Loader\IniFileLoader::load
*/
public functiontestExceptionIsRaisedWhenIniFileCannotBeParsed() {
try {
@$this->loader
->load('nonvalid.ini');
$this
->fail('->load() throws an InvalidArgumentException if the loaded file is not parseable');
} catch (\Exception $e) {
$this
->assertInstanceOf('\\InvalidArgumentException', $e, '->load() throws an InvalidArgumentException if the loaded file is not parseable');
$this
->assertEquals('The "nonvalid.ini" file is not valid.', $e
->getMessage(), '->load() throws an InvalidArgumentException if the loaded file is not parseable');
}
}
/**
* @covers Symfony\Component\DependencyInjection\Loader\IniFileLoader::supports
*/
public functiontestSupports() {
$loader = newIniFileLoader(newContainerBuilder(), newFileLocator());
$this
->assertTrue($loader
->supports('foo.ini'), '->supports() returns true if the resource is loadable');
$this
->assertFalse($loader
->supports('foo.foo'), '->supports() returns true if the resource is loadable');
}
}