| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198 | 
							- <?php
 
- /*
 
-  * This file is part of sebastian/diff.
 
-  *
 
-  * (c) Sebastian Bergmann <sebastian@phpunit.de>
 
-  *
 
-  * For the full copyright and license information, please view the LICENSE
 
-  * file that was distributed with this source code.
 
-  */
 
- namespace SebastianBergmann\Diff\LCS;
 
- use PHPUnit\Framework\TestCase;
 
- abstract class LongestCommonSubsequenceTest extends TestCase
 
- {
 
-     /**
 
-      * @var LongestCommonSubsequence
 
-      */
 
-     private $implementation;
 
-     /**
 
-      * @var string
 
-      */
 
-     private $memoryLimit;
 
-     /**
 
-      * @var int[]
 
-      */
 
-     private $stress_sizes = array(1, 2, 3, 100, 500, 1000, 2000);
 
-     protected function setUp()
 
-     {
 
-         $this->memoryLimit = \ini_get('memory_limit');
 
-         \ini_set('memory_limit', '256M');
 
-         $this->implementation = $this->createImplementation();
 
-     }
 
-     /**
 
-      * @return LongestCommonSubsequence
 
-      */
 
-     abstract protected function createImplementation();
 
-     protected function tearDown()
 
-     {
 
-         \ini_set('memory_limit', $this->memoryLimit);
 
-     }
 
-     public function testBothEmpty()
 
-     {
 
-         $from   = array();
 
-         $to     = array();
 
-         $common = $this->implementation->calculate($from, $to);
 
-         $this->assertEquals(array(), $common);
 
-     }
 
-     public function testIsStrictComparison()
 
-     {
 
-         $from = array(
 
-             false, 0, 0.0, '', null, array(),
 
-             true, 1, 1.0, 'foo', array('foo', 'bar'), array('foo' => 'bar')
 
-         );
 
-         $to     = $from;
 
-         $common = $this->implementation->calculate($from, $to);
 
-         $this->assertEquals($from, $common);
 
-         $to = array(
 
-             false, false, false, false, false, false,
 
-             true, true, true, true, true, true
 
-         );
 
-         $expected = array(
 
-             false,
 
-             true,
 
-         );
 
-         $common = $this->implementation->calculate($from, $to);
 
-         $this->assertEquals($expected, $common);
 
-     }
 
-     public function testEqualSequences()
 
-     {
 
-         foreach ($this->stress_sizes as $size) {
 
-             $range  = \range(1, $size);
 
-             $from   = $range;
 
-             $to     = $range;
 
-             $common = $this->implementation->calculate($from, $to);
 
-             $this->assertEquals($range, $common);
 
-         }
 
-     }
 
-     public function testDistinctSequences()
 
-     {
 
-         $from   = array('A');
 
-         $to     = array('B');
 
-         $common = $this->implementation->calculate($from, $to);
 
-         $this->assertEquals(array(), $common);
 
-         $from   = array('A', 'B', 'C');
 
-         $to     = array('D', 'E', 'F');
 
-         $common = $this->implementation->calculate($from, $to);
 
-         $this->assertEquals(array(), $common);
 
-         foreach ($this->stress_sizes as $size) {
 
-             $from   = \range(1, $size);
 
-             $to     = \range($size + 1, $size * 2);
 
-             $common = $this->implementation->calculate($from, $to);
 
-             $this->assertEquals(array(), $common);
 
-         }
 
-     }
 
-     public function testCommonSubsequence()
 
-     {
 
-         $from     = array('A',      'C',      'E', 'F', 'G');
 
-         $to       = array('A', 'B',      'D', 'E',           'H');
 
-         $expected = array('A',                'E');
 
-         $common   = $this->implementation->calculate($from, $to);
 
-         $this->assertEquals($expected, $common);
 
-         $from     = array('A',      'C',      'E', 'F', 'G');
 
-         $to       = array('B', 'C', 'D', 'E', 'F',      'H');
 
-         $expected = array('C',                'E', 'F');
 
-         $common   = $this->implementation->calculate($from, $to);
 
-         $this->assertEquals($expected, $common);
 
-         foreach ($this->stress_sizes as $size) {
 
-             $from     = $size < 2 ? array(1) : \range(1, $size + 1, 2);
 
-             $to       = $size < 3 ? array(1) : \range(1, $size + 1, 3);
 
-             $expected = $size < 6 ? array(1) : \range(1, $size + 1, 6);
 
-             $common   = $this->implementation->calculate($from, $to);
 
-             $this->assertEquals($expected, $common);
 
-         }
 
-     }
 
-     public function testSingleElementSubsequenceAtStart()
 
-     {
 
-         foreach ($this->stress_sizes as $size) {
 
-             $from   = \range(1, $size);
 
-             $to     = \array_slice($from, 0, 1);
 
-             $common = $this->implementation->calculate($from, $to);
 
-             $this->assertEquals($to, $common);
 
-         }
 
-     }
 
-     public function testSingleElementSubsequenceAtMiddle()
 
-     {
 
-         foreach ($this->stress_sizes as $size) {
 
-             $from   = \range(1, $size);
 
-             $to     = \array_slice($from, (int) $size / 2, 1);
 
-             $common = $this->implementation->calculate($from, $to);
 
-             $this->assertEquals($to, $common);
 
-         }
 
-     }
 
-     public function testSingleElementSubsequenceAtEnd()
 
-     {
 
-         foreach ($this->stress_sizes as $size) {
 
-             $from   = \range(1, $size);
 
-             $to     = \array_slice($from, $size - 1, 1);
 
-             $common = $this->implementation->calculate($from, $to);
 
-             $this->assertEquals($to, $common);
 
-         }
 
-     }
 
-     public function testReversedSequences()
 
-     {
 
-         $from     = array('A', 'B');
 
-         $to       = array('B', 'A');
 
-         $expected = array('A');
 
-         $common   = $this->implementation->calculate($from, $to);
 
-         $this->assertEquals($expected, $common);
 
-         foreach ($this->stress_sizes as $size) {
 
-             $from   = \range(1, $size);
 
-             $to     = \array_reverse($from);
 
-             $common = $this->implementation->calculate($from, $to);
 
-             $this->assertEquals(array(1), $common);
 
-         }
 
-     }
 
-     public function testStrictTypeCalculate()
 
-     {
 
-         $diff = $this->implementation->calculate(array('5'), array('05'));
 
-         $this->assertInternalType('array', $diff);
 
-         $this->assertCount(0, $diff);
 
-     }
 
- }
 
 
  |