Skip to content

Commit

Permalink
[Process] Fix ExecutableFinder with open basedir
Browse files Browse the repository at this point in the history
  • Loading branch information
cs278 authored and romainneutron committed Jun 28, 2014
1 parent eeeae94 commit b8f8c0e
Show file tree
Hide file tree
Showing 2 changed files with 113 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/Symfony/Component/Process/ExecutableFinder.php
Expand Up @@ -53,7 +53,7 @@ public function addSuffix($suffix)
public function find($name, $default = null, array $extraDirs = array())
{
if (ini_get('open_basedir')) {
$searchPath = explode(PATH_SEPARATOR, getenv('open_basedir'));
$searchPath = explode(PATH_SEPARATOR, ini_get('open_basedir'));
$dirs = array();
foreach ($searchPath as $path) {
if (is_dir($path)) {
Expand Down
112 changes: 112 additions & 0 deletions src/Symfony/Component/Process/Tests/ExecutableFinderTest.php
@@ -0,0 +1,112 @@
<?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\Process\Tests;

use Symfony\Component\Process\ExecutableFinder;

/**
* @author Chris Smith <chris@cs278.org>
*/
class ExecutableFinderTest extends \PHPUnit_Framework_TestCase
{
private $path;

public function tearDown()
{
if ($this->path) {
// Restore path if it was changed.
putenv('PATH='.$this->path);
}
}

private function setPath($path)
{
$this->path = getenv('PATH');
putenv('PATH='.$path);
}

public function testFind()
{
if (!defined('PHP_BINARY')) {
$this->markTestSkipped('Requires the PHP_BINARY constant');
}

if (ini_get('open_basedir')) {
$this->markTestSkipped('Cannot test when open_basedir is set');
}

$this->setPath(dirname(PHP_BINARY));

$finder = new ExecutableFinder;
$result = $finder->find(basename(PHP_BINARY));

$this->assertEquals($result, PHP_BINARY);
}

public function testFindWithDefault()
{
if (ini_get('open_basedir')) {
$this->markTestSkipped('Cannot test when open_basedir is set');
}

$expected = 'defaultValue';

$this->setPath('');

$finder = new ExecutableFinder;
$result = $finder->find('foo', $expected);

$this->assertEquals($expected, $result);
}

public function testFindWithExtraDirs()
{
if (!defined('PHP_BINARY')) {
$this->markTestSkipped('Requires the PHP_BINARY constant');
}

if (ini_get('open_basedir')) {
$this->markTestSkipped('Cannot test when open_basedir is set');
}

$this->setPath('');

$extraDirs = array(dirname(PHP_BINARY));

$finder = new ExecutableFinder;
$result = $finder->find(basename(PHP_BINARY), null, $extraDirs);

$this->assertEquals(PHP_BINARY, $result);
}

public function testFindWithOpenBaseDir()
{
if (!defined('PHP_BINARY')) {
$this->markTestSkipped('Requires the PHP_BINARY constant');
}

if (defined('PHP_WINDOWS_VERSION_BUILD')) {
$this->markTestSkipped('Cannot run test on windows');
}

if (ini_get('open_basedir')) {
$this->markTestSkipped('Cannot test when open_basedir is set');
}

ini_set('open_basedir', dirname(PHP_BINARY).PATH_SEPARATOR.'/');

$finder = new ExecutableFinder;
$result = $finder->find(basename(PHP_BINARY));

$this->assertEquals(PHP_BINARY, $result);
}
}

0 comments on commit b8f8c0e

Please sign in to comment.