2011-02-27 13:41:54 +11:00
|
|
|
<?php
|
2016-08-19 10:51:35 +12:00
|
|
|
|
2016-09-09 18:43:05 +12:00
|
|
|
use SilverStripe\Assets\FileFinder;
|
2016-08-19 10:51:35 +12:00
|
|
|
use SilverStripe\Dev\SapphireTest;
|
|
|
|
|
2011-02-27 13:41:54 +11:00
|
|
|
/**
|
|
|
|
* Tests for the {@link SS_FileFinder} class.
|
|
|
|
*
|
2012-04-12 18:02:46 +12:00
|
|
|
* @package framework
|
2011-02-27 13:41:54 +11:00
|
|
|
* @subpackage tests
|
|
|
|
*/
|
|
|
|
class FileFinderTest extends SapphireTest {
|
|
|
|
|
|
|
|
protected $base;
|
|
|
|
|
|
|
|
public function __construct() {
|
|
|
|
$this->base = dirname(__FILE__) . '/fixtures/filefinder';
|
|
|
|
parent::__construct();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testBasicOperation() {
|
2016-09-09 18:43:05 +12:00
|
|
|
$this->assertFinderFinds(new FileFinder(), array(
|
2011-02-27 13:41:54 +11:00
|
|
|
'file1.txt',
|
|
|
|
'file2.txt',
|
|
|
|
'dir1/dir1file1.txt',
|
|
|
|
'dir1/dir1file2.txt',
|
|
|
|
'dir1/dir2/dir2file1.txt',
|
|
|
|
'dir1/dir2/dir3/dir3file1.txt'
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException InvalidArgumentException
|
|
|
|
*/
|
|
|
|
public function testInvalidOptionThrowsException() {
|
2016-09-09 18:43:05 +12:00
|
|
|
$finder = new FileFinder();
|
2011-02-27 13:41:54 +11:00
|
|
|
$finder->setOption('this_doesnt_exist', 'ok');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testFilenameRegex() {
|
2016-09-09 18:43:05 +12:00
|
|
|
$finder = new FileFinder();
|
2011-02-27 13:41:54 +11:00
|
|
|
$finder->setOption('name_regex', '/file2\.txt$/');
|
|
|
|
|
|
|
|
$this->assertFinderFinds(
|
|
|
|
$finder,
|
|
|
|
array(
|
|
|
|
'file2.txt',
|
|
|
|
'dir1/dir1file2.txt'),
|
|
|
|
'The finder only returns files matching the name regex.');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testIgnoreFiles() {
|
2016-09-09 18:43:05 +12:00
|
|
|
$finder = new FileFinder();
|
2011-02-27 13:41:54 +11:00
|
|
|
$finder->setOption('ignore_files', array('file1.txt', 'dir1file1.txt', 'dir2file1.txt'));
|
|
|
|
|
|
|
|
$this->assertFinderFinds(
|
|
|
|
$finder,
|
|
|
|
array(
|
|
|
|
'file2.txt',
|
|
|
|
'dir1/dir1file2.txt',
|
|
|
|
'dir1/dir2/dir3/dir3file1.txt'),
|
|
|
|
'The finder ignores files with the basename in the ignore_files setting.');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testIgnoreDirs() {
|
2016-09-09 18:43:05 +12:00
|
|
|
$finder = new FileFinder();
|
2011-02-27 13:41:54 +11:00
|
|
|
$finder->setOption('ignore_dirs', array('dir2'));
|
|
|
|
|
|
|
|
$this->assertFinderFinds(
|
|
|
|
$finder,
|
|
|
|
array(
|
|
|
|
'file1.txt',
|
|
|
|
'file2.txt',
|
|
|
|
'dir1/dir1file1.txt',
|
|
|
|
'dir1/dir1file2.txt'),
|
|
|
|
'The finder ignores directories in ignore_dirs.');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testMinDepth() {
|
2016-09-09 18:43:05 +12:00
|
|
|
$finder = new FileFinder();
|
2011-02-27 13:41:54 +11:00
|
|
|
$finder->setOption('min_depth', 2);
|
|
|
|
|
|
|
|
$this->assertFinderFinds(
|
|
|
|
$finder,
|
|
|
|
array(
|
|
|
|
'dir1/dir2/dir2file1.txt',
|
|
|
|
'dir1/dir2/dir3/dir3file1.txt'),
|
|
|
|
'The finder respects the min depth setting.');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testMaxDepth() {
|
2016-09-09 18:43:05 +12:00
|
|
|
$finder = new FileFinder();
|
2011-02-27 13:41:54 +11:00
|
|
|
$finder->setOption('max_depth', 1);
|
|
|
|
|
|
|
|
$this->assertFinderFinds(
|
|
|
|
$finder,
|
|
|
|
array(
|
|
|
|
'file1.txt',
|
|
|
|
'file2.txt',
|
|
|
|
'dir1/dir1file1.txt',
|
|
|
|
'dir1/dir1file2.txt'),
|
|
|
|
'The finder respects the max depth setting.');
|
|
|
|
}
|
|
|
|
|
2016-09-09 18:43:05 +12:00
|
|
|
public function assertFinderFinds(FileFinder $finder, $expect, $message = null) {
|
2011-02-27 13:41:54 +11:00
|
|
|
$found = $finder->find($this->base);
|
|
|
|
|
|
|
|
foreach ($expect as $k => $file) {
|
|
|
|
$expect[$k] = "{$this->base}/$file";
|
|
|
|
}
|
|
|
|
|
|
|
|
sort($expect);
|
|
|
|
sort($found);
|
|
|
|
|
|
|
|
$this->assertEquals($expect, $found, $message);
|
|
|
|
}
|
|
|
|
|
2012-03-24 16:04:52 +13:00
|
|
|
}
|