mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-08 04:18:52 +00:00
[ticket/13568] Add unit tests for validating absolute path
PHPBB3-13568
This commit is contained in:
parent
cd85f1b632
commit
1da6b30cf0
1 changed files with 87 additions and 0 deletions
|
@ -162,4 +162,91 @@ class phpbb_functions_acp_validate_config_vars_test extends phpbb_test_case
|
||||||
|
|
||||||
$this->assertEquals($expected, $phpbb_error);
|
$this->assertEquals($expected, $phpbb_error);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function data_validate_path_linux()
|
||||||
|
{
|
||||||
|
return array(
|
||||||
|
array('/usr/bin', 'absolute_path', true),
|
||||||
|
array('/usr/bin/', 'absolute_path:50:200', true),
|
||||||
|
array('/usr/bin/which', 'absolute_path', 'DIRECTORY_NOT_DIR'),
|
||||||
|
array('/foo/bar', 'absolute_path', 'DIRECTORY_DOES_NOT_EXIST'),
|
||||||
|
array('C:\Windows', 'absolute_path', 'DIRECTORY_DOES_NOT_EXIST'),
|
||||||
|
array('.', 'absolute_path', true),
|
||||||
|
array('', 'absolute_path', true),
|
||||||
|
array('mkdir /foo/bar', 'absolute_path', 'DIRECTORY_DOES_NOT_EXIST'),
|
||||||
|
// Make sure above command didn't do anything
|
||||||
|
array('/foo/bar', 'absolute_path', 'DIRECTORY_DOES_NOT_EXIST'),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dataProvider data_validate_path_linux
|
||||||
|
*/
|
||||||
|
public function test_validate_path_linux($path, $validation_type, $expected)
|
||||||
|
{
|
||||||
|
if (strtolower(substr(PHP_OS, 0, 5)) !== 'linux')
|
||||||
|
{
|
||||||
|
$this->markTestSkipped('Unable to test linux specific paths on other OS.');
|
||||||
|
}
|
||||||
|
|
||||||
|
$error = array();
|
||||||
|
$config_ary = array(
|
||||||
|
'path' => $path,
|
||||||
|
);
|
||||||
|
|
||||||
|
validate_config_vars(array(
|
||||||
|
'path' => array('lang' => 'FOOBAR', 'validate' => $validation_type),
|
||||||
|
),
|
||||||
|
$config_ary,
|
||||||
|
$error
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function data_validate_path_windows()
|
||||||
|
{
|
||||||
|
return array(
|
||||||
|
array('C:\Windows', 'absolute_path', true),
|
||||||
|
array('C:\Windows\\', 'absolute_path:50:200', true),
|
||||||
|
array('C:\Windows\explorer.exe', 'absolute_path', 'DIRECTORY_NOT_DIR'),
|
||||||
|
array('C:\foobar', 'absolute_path', 'DIRECTORY_DOES_NOT_EXIST'),
|
||||||
|
array('/usr/bin', 'absolute_path', 'DIRECTORY_DOES_NOT_EXIST'),
|
||||||
|
array('.', 'absolute_path', true),
|
||||||
|
array('', 'absolute_path', true),
|
||||||
|
array('mkdir C:\Windows\foobar', 'absolute_path', 'DIRECTORY_DOES_NOT_EXIST'),
|
||||||
|
// Make sure above command didn't do anything
|
||||||
|
array('C:\Windows\foobar', 'absolute_path', 'DIRECTORY_DOES_NOT_EXIST'),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dataProvider data_validate_path_windows
|
||||||
|
*/
|
||||||
|
public function test_validate_path_windows($path, $validation_type, $expected)
|
||||||
|
{
|
||||||
|
if (strtolower(substr(PHP_OS, 0, 3)) !== 'win')
|
||||||
|
{
|
||||||
|
$this->markTestSkipped('Unable to test windows specific paths on other OS.');
|
||||||
|
}
|
||||||
|
|
||||||
|
$error = array();
|
||||||
|
$config_ary = array(
|
||||||
|
'path' => $path,
|
||||||
|
);
|
||||||
|
|
||||||
|
validate_config_vars(array(
|
||||||
|
'path' => array('lang' => 'FOOBAR', 'validate' => $validation_type),
|
||||||
|
),
|
||||||
|
$config_ary,
|
||||||
|
$error
|
||||||
|
);
|
||||||
|
|
||||||
|
if ($expected === true)
|
||||||
|
{
|
||||||
|
$this->assertEmpty($error);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$this->assertEquals(array($expected), $error);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue