120 lines
3.9 KiB
PHP
120 lines
3.9 KiB
PHP
<?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\Component\Config\Tests;
|
|
|
|
use Symfony\Component\Config\FileLocator;
|
|
|
|
class FileLocatorTest extends \PHPUnit_Framework_TestCase
|
|
{
|
|
/**
|
|
* @dataProvider getIsAbsolutePathTests
|
|
*/
|
|
public function testIsAbsolutePath($path)
|
|
{
|
|
$loader = new FileLocator(array());
|
|
$r = new \ReflectionObject($loader);
|
|
$m = $r->getMethod('isAbsolutePath');
|
|
$m->setAccessible(true);
|
|
|
|
$this->assertTrue($m->invoke($loader, $path), '->isAbsolutePath() returns true for an absolute path');
|
|
}
|
|
|
|
public function getIsAbsolutePathTests()
|
|
{
|
|
return array(
|
|
array('/foo.xml'),
|
|
array('c:\\\\foo.xml'),
|
|
array('c:/foo.xml'),
|
|
array('\\server\\foo.xml'),
|
|
array('https://server/foo.xml'),
|
|
array('phar://server/foo.xml'),
|
|
);
|
|
}
|
|
|
|
public function testLocate()
|
|
{
|
|
$loader = new FileLocator(__DIR__.'/Fixtures');
|
|
|
|
$this->assertEquals(
|
|
__DIR__.DIRECTORY_SEPARATOR.'FileLocatorTest.php',
|
|
$loader->locate('FileLocatorTest.php', __DIR__),
|
|
'->locate() returns the absolute filename if the file exists in the given path'
|
|
);
|
|
|
|
$this->assertEquals(
|
|
__DIR__.'/Fixtures'.DIRECTORY_SEPARATOR.'foo.xml',
|
|
$loader->locate('foo.xml', __DIR__),
|
|
'->locate() returns the absolute filename if the file exists in one of the paths given in the constructor'
|
|
);
|
|
|
|
$this->assertEquals(
|
|
__DIR__.'/Fixtures'.DIRECTORY_SEPARATOR.'foo.xml',
|
|
$loader->locate(__DIR__.'/Fixtures'.DIRECTORY_SEPARATOR.'foo.xml', __DIR__),
|
|
'->locate() returns the absolute filename if the file exists in one of the paths given in the constructor'
|
|
);
|
|
|
|
$loader = new FileLocator(array(__DIR__.'/Fixtures', __DIR__.'/Fixtures/Again'));
|
|
|
|
$this->assertEquals(
|
|
array(__DIR__.'/Fixtures'.DIRECTORY_SEPARATOR.'foo.xml', __DIR__.'/Fixtures/Again'.DIRECTORY_SEPARATOR.'foo.xml'),
|
|
$loader->locate('foo.xml', __DIR__, false),
|
|
'->locate() returns an array of absolute filenames'
|
|
);
|
|
|
|
$this->assertEquals(
|
|
array(__DIR__.'/Fixtures'.DIRECTORY_SEPARATOR.'foo.xml', __DIR__.'/Fixtures/Again'.DIRECTORY_SEPARATOR.'foo.xml'),
|
|
$loader->locate('foo.xml', __DIR__.'/Fixtures', false),
|
|
'->locate() returns an array of absolute filenames'
|
|
);
|
|
|
|
$loader = new FileLocator(__DIR__.'/Fixtures/Again');
|
|
|
|
$this->assertEquals(
|
|
array(__DIR__.'/Fixtures'.DIRECTORY_SEPARATOR.'foo.xml', __DIR__.'/Fixtures/Again'.DIRECTORY_SEPARATOR.'foo.xml'),
|
|
$loader->locate('foo.xml', __DIR__.'/Fixtures', false),
|
|
'->locate() returns an array of absolute filenames'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @expectedException \InvalidArgumentException
|
|
* @expectedExceptionMessage The file "foobar.xml" does not exist
|
|
*/
|
|
public function testLocateThrowsAnExceptionIfTheFileDoesNotExists()
|
|
{
|
|
$loader = new FileLocator(array(__DIR__.'/Fixtures'));
|
|
|
|
$loader->locate('foobar.xml', __DIR__);
|
|
}
|
|
|
|
/**
|
|
* @expectedException \InvalidArgumentException
|
|
*/
|
|
public function testLocateThrowsAnExceptionIfTheFileDoesNotExistsInAbsolutePath()
|
|
{
|
|
$loader = new FileLocator(array(__DIR__.'/Fixtures'));
|
|
|
|
$loader->locate(__DIR__.'/Fixtures/foobar.xml', __DIR__);
|
|
}
|
|
|
|
/**
|
|
* @expectedException \InvalidArgumentException
|
|
* @expectedExceptionMessage An empty file name is not valid to be located.
|
|
*/
|
|
public function testLocateEmpty()
|
|
{
|
|
$loader = new FileLocator(array(__DIR__.'/Fixtures'));
|
|
|
|
$loader->locate(null, __DIR__);
|
|
}
|
|
}
|