101 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			3.4 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;
 | |
| 
 | |
| use PHPUnit\Framework\TestCase;
 | |
| 
 | |
| abstract class IteratorTestCase extends TestCase
 | |
| {
 | |
|     protected function assertIterator($expected, \Traversable $iterator)
 | |
|     {
 | |
|         // set iterator_to_array $use_key to false to avoid values merge
 | |
|         // this made FinderTest::testAppendWithAnArray() fail with GnuFinderAdapter
 | |
|         $values = array_map(function (\SplFileInfo $fileinfo) { return str_replace('/', \DIRECTORY_SEPARATOR, $fileinfo->getPathname()); }, iterator_to_array($iterator, false));
 | |
| 
 | |
|         $expected = array_map(function ($path) { return str_replace('/', \DIRECTORY_SEPARATOR, $path); }, $expected);
 | |
| 
 | |
|         sort($values);
 | |
|         sort($expected);
 | |
| 
 | |
|         $this->assertEquals($expected, array_values($values));
 | |
|     }
 | |
| 
 | |
|     protected function assertOrderedIterator($expected, \Traversable $iterator)
 | |
|     {
 | |
|         $values = array_map(function (\SplFileInfo $fileinfo) { return $fileinfo->getPathname(); }, iterator_to_array($iterator));
 | |
| 
 | |
|         $this->assertEquals($expected, array_values($values));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      *  Same as assertOrderedIterator, but checks the order of groups of
 | |
|      *  array elements.
 | |
|      *
 | |
|      *  @param array $expected - an array of arrays. For any two subarrays
 | |
|      *      $a and $b such that $a goes before $b in $expected, the method
 | |
|      *      asserts that any element of $a goes before any element of $b
 | |
|      *      in the sequence generated by $iterator
 | |
|      *  @param \Traversable $iterator
 | |
|      */
 | |
|     protected function assertOrderedIteratorForGroups($expected, \Traversable $iterator)
 | |
|     {
 | |
|         $values = array_values(array_map(function (\SplFileInfo $fileinfo) { return $fileinfo->getPathname(); }, iterator_to_array($iterator)));
 | |
| 
 | |
|         foreach ($expected as $subarray) {
 | |
|             $temp = array();
 | |
|             while (\count($values) && \count($temp) < \count($subarray)) {
 | |
|                 $temp[] = array_shift($values);
 | |
|             }
 | |
|             sort($temp);
 | |
|             sort($subarray);
 | |
|             $this->assertEquals($subarray, $temp);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Same as IteratorTestCase::assertIterator with foreach usage.
 | |
|      *
 | |
|      * @param array        $expected
 | |
|      * @param \Traversable $iterator
 | |
|      */
 | |
|     protected function assertIteratorInForeach($expected, \Traversable $iterator)
 | |
|     {
 | |
|         $values = array();
 | |
|         foreach ($iterator as $file) {
 | |
|             $this->assertInstanceOf('Symfony\\Component\\Finder\\SplFileInfo', $file);
 | |
|             $values[] = $file->getPathname();
 | |
|         }
 | |
| 
 | |
|         sort($values);
 | |
|         sort($expected);
 | |
| 
 | |
|         $this->assertEquals($expected, array_values($values));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Same as IteratorTestCase::assertOrderedIterator with foreach usage.
 | |
|      *
 | |
|      * @param array        $expected
 | |
|      * @param \Traversable $iterator
 | |
|      */
 | |
|     protected function assertOrderedIteratorInForeach($expected, \Traversable $iterator)
 | |
|     {
 | |
|         $values = array();
 | |
|         foreach ($iterator as $file) {
 | |
|             $this->assertInstanceOf('Symfony\\Component\\Finder\\SplFileInfo', $file);
 | |
|             $values[] = $file->getPathname();
 | |
|         }
 | |
| 
 | |
|         $this->assertEquals($expected, array_values($values));
 | |
|     }
 | |
| }
 | 
