133 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			3.3 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\Finder\Tests\Iterator;
 | |
| 
 | |
| class MockSplFileInfo extends \SplFileInfo
 | |
| {
 | |
|     const TYPE_DIRECTORY = 1;
 | |
|     const TYPE_FILE = 2;
 | |
|     const TYPE_UNKNOWN = 3;
 | |
| 
 | |
|     private $contents = null;
 | |
|     private $mode = null;
 | |
|     private $type = null;
 | |
|     private $relativePath = null;
 | |
|     private $relativePathname = null;
 | |
| 
 | |
|     public function __construct($param)
 | |
|     {
 | |
|         if (\is_string($param)) {
 | |
|             parent::__construct($param);
 | |
|         } elseif (\is_array($param)) {
 | |
|             $defaults = array(
 | |
|                 'name' => 'file.txt',
 | |
|                 'contents' => null,
 | |
|                 'mode' => null,
 | |
|                 'type' => null,
 | |
|                 'relativePath' => null,
 | |
|                 'relativePathname' => null,
 | |
|             );
 | |
|             $defaults = array_merge($defaults, $param);
 | |
|             parent::__construct($defaults['name']);
 | |
|             $this->setContents($defaults['contents']);
 | |
|             $this->setMode($defaults['mode']);
 | |
|             $this->setType($defaults['type']);
 | |
|             $this->setRelativePath($defaults['relativePath']);
 | |
|             $this->setRelativePathname($defaults['relativePathname']);
 | |
|         } else {
 | |
|             throw new \RuntimeException(sprintf('Incorrect parameter "%s"', $param));
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public function isFile()
 | |
|     {
 | |
|         if (null === $this->type) {
 | |
|             return false !== strpos($this->getFilename(), 'file');
 | |
|         }
 | |
| 
 | |
|         return self::TYPE_FILE === $this->type;
 | |
|     }
 | |
| 
 | |
|     public function isDir()
 | |
|     {
 | |
|         if (null === $this->type) {
 | |
|             return false !== strpos($this->getFilename(), 'directory');
 | |
|         }
 | |
| 
 | |
|         return self::TYPE_DIRECTORY === $this->type;
 | |
|     }
 | |
| 
 | |
|     public function isReadable()
 | |
|     {
 | |
|         if (null === $this->mode) {
 | |
|             return preg_match('/r\+/', $this->getFilename());
 | |
|         }
 | |
| 
 | |
|         return preg_match('/r\+/', $this->mode);
 | |
|     }
 | |
| 
 | |
|     public function getContents()
 | |
|     {
 | |
|         return $this->contents;
 | |
|     }
 | |
| 
 | |
|     public function setContents($contents)
 | |
|     {
 | |
|         $this->contents = $contents;
 | |
|     }
 | |
| 
 | |
|     public function setMode($mode)
 | |
|     {
 | |
|         $this->mode = $mode;
 | |
|     }
 | |
| 
 | |
|     public function setType($type)
 | |
|     {
 | |
|         if (\is_string($type)) {
 | |
|             switch ($type) {
 | |
|                 case 'directory':
 | |
|                 case 'd':
 | |
|                     $this->type = self::TYPE_DIRECTORY;
 | |
|                     break;
 | |
|                 case 'file':
 | |
|                 case 'f':
 | |
|                     $this->type = self::TYPE_FILE;
 | |
|                     break;
 | |
|                 default:
 | |
|                     $this->type = self::TYPE_UNKNOWN;
 | |
|             }
 | |
|         } else {
 | |
|             $this->type = $type;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public function setRelativePath($relativePath)
 | |
|     {
 | |
|         $this->relativePath = $relativePath;
 | |
|     }
 | |
| 
 | |
|     public function setRelativePathname($relativePathname)
 | |
|     {
 | |
|         $this->relativePathname = $relativePathname;
 | |
|     }
 | |
| 
 | |
|     public function getRelativePath()
 | |
|     {
 | |
|         return $this->relativePath;
 | |
|     }
 | |
| 
 | |
|     public function getRelativePathname()
 | |
|     {
 | |
|         return $this->relativePathname;
 | |
|     }
 | |
| }
 | 
