334 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			334 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| use Codeception\Util\Fixtures;
 | |
| use Grav\Common\Grav;
 | |
| use Grav\Common\Utils;
 | |
| 
 | |
| /**
 | |
|  * Class UtilsTest
 | |
|  */
 | |
| class UtilsTest extends \Codeception\TestCase\Test
 | |
| {
 | |
|     /** @var Grav $grav */
 | |
|     protected $grav;
 | |
| 
 | |
|     protected function _before()
 | |
|     {
 | |
|         $grav = Fixtures::get('grav');
 | |
|         $this->grav = $grav();
 | |
|     }
 | |
| 
 | |
|     protected function _after()
 | |
|     {
 | |
|     }
 | |
| 
 | |
|     public function testStartsWith()
 | |
|     {
 | |
|         $this->assertTrue(Utils::startsWith('english', 'en'));
 | |
|         $this->assertTrue(Utils::startsWith('English', 'En'));
 | |
|         $this->assertTrue(Utils::startsWith('ENGLISH', 'EN'));
 | |
|         $this->assertTrue(Utils::startsWith('ENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISH',
 | |
|             'EN'));
 | |
| 
 | |
|         $this->assertFalse(Utils::startsWith('english', 'En'));
 | |
|         $this->assertFalse(Utils::startsWith('English', 'EN'));
 | |
|         $this->assertFalse(Utils::startsWith('ENGLISH', 'en'));
 | |
|         $this->assertFalse(Utils::startsWith('ENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISH',
 | |
|             'e'));
 | |
|     }
 | |
| 
 | |
|     public function testEndsWith()
 | |
|     {
 | |
|         $this->assertTrue(Utils::endsWith('english', 'sh'));
 | |
|         $this->assertTrue(Utils::endsWith('EngliSh', 'Sh'));
 | |
|         $this->assertTrue(Utils::endsWith('ENGLISH', 'SH'));
 | |
|         $this->assertTrue(Utils::endsWith('ENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISH',
 | |
|             'ENGLISH'));
 | |
| 
 | |
|         $this->assertFalse(Utils::endsWith('english', 'de'));
 | |
|         $this->assertFalse(Utils::endsWith('EngliSh', 'sh'));
 | |
|         $this->assertFalse(Utils::endsWith('ENGLISH', 'Sh'));
 | |
|         $this->assertFalse(Utils::endsWith('ENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISH',
 | |
|             'DEUSTCH'));
 | |
|     }
 | |
| 
 | |
|     public function testContains()
 | |
|     {
 | |
|         $this->assertTrue(Utils::contains('english', 'nglis'));
 | |
|         $this->assertTrue(Utils::contains('EngliSh', 'gliSh'));
 | |
|         $this->assertTrue(Utils::contains('ENGLISH', 'ENGLI'));
 | |
|         $this->assertTrue(Utils::contains('ENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISH',
 | |
|             'ENGLISH'));
 | |
| 
 | |
|         $this->assertFalse(Utils::contains('EngliSh', 'GLI'));
 | |
|         $this->assertFalse(Utils::contains('EngliSh', 'English'));
 | |
|         $this->assertFalse(Utils::contains('ENGLISH', 'SCH'));
 | |
|         $this->assertFalse(Utils::contains('ENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISHENGLISH',
 | |
|             'DEUSTCH'));
 | |
|     }
 | |
| 
 | |
|     public function testSubstrToString()
 | |
|     {
 | |
|         $this->assertEquals('en', Utils::substrToString('english', 'glish'));
 | |
|         $this->assertEquals('english', Utils::substrToString('english', 'test'));
 | |
|         $this->assertNotEquals('en', Utils::substrToString('english', 'lish'));
 | |
|     }
 | |
| 
 | |
|     public function testMergeObjects()
 | |
|     {
 | |
|         $obj1 = new stdClass();
 | |
|         $obj1->test1 = 'x';
 | |
|         $obj2 = new stdClass();
 | |
|         $obj2->test2 = 'y';
 | |
| 
 | |
|         $objMerged = Utils::mergeObjects($obj1, $obj2);
 | |
| 
 | |
|         $this->assertObjectHasAttribute('test1', $objMerged);
 | |
|         $this->assertObjectHasAttribute('test2', $objMerged);
 | |
|     }
 | |
| 
 | |
|     public function testDateFormats()
 | |
|     {
 | |
|         $dateFormats = Utils::dateFormats();
 | |
|         $this->assertInternalType('array', $dateFormats);
 | |
|         $this->assertContainsOnly('string', $dateFormats);
 | |
| 
 | |
|         $default_format = $this->grav['config']->get('system.pages.dateformat.default');
 | |
| 
 | |
|         if ($default_format !== null) {
 | |
|             $this->assertArrayHasKey($default_format, $dateFormats);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public function testTruncate()
 | |
|     {
 | |
|         $this->assertEquals('engli' . '…', Utils::truncate('english', 5));
 | |
|         $this->assertEquals('english', Utils::truncate('english'));
 | |
|         $this->assertEquals('This is a string to truncate', Utils::truncate('This is a string to truncate'));
 | |
|         $this->assertEquals('Th' . '…', Utils::truncate('This is a string to truncate', 2));
 | |
|         $this->assertEquals('engli' . '...', Utils::truncate('english', 5, true, " ", "..."));
 | |
|         $this->assertEquals('english', Utils::truncate('english'));
 | |
|         $this->assertEquals('This is a string to truncate', Utils::truncate('This is a string to truncate'));
 | |
|         $this->assertEquals('This' . '…', Utils::truncate('This is a string to truncate', 3, true));
 | |
|         $this->assertEquals('<input' . '…', Utils::truncate('<input type="file" id="file" multiple />', 6, true));
 | |
| 
 | |
|     }
 | |
| 
 | |
|     public function testSafeTruncate()
 | |
|     {
 | |
|         $this->assertEquals('This' . '…', Utils::safeTruncate('This is a string to truncate', 1));
 | |
|         $this->assertEquals('This' . '…', Utils::safeTruncate('This is a string to truncate', 4));
 | |
|         $this->assertEquals('This is' . '…', Utils::safeTruncate('This is a string to truncate', 5));
 | |
|     }
 | |
| 
 | |
|     public function testTruncateHtml()
 | |
|     {
 | |
|         $this->assertEquals('<p>T...</p>', Utils::truncateHtml('<p>This is a string to truncate</p>', 1));
 | |
|         $this->assertEquals('<p>This...</p>', Utils::truncateHtml('<p>This is a string to truncate</p>', 4));
 | |
|         $this->assertEquals('<p>This is a...</p>', Utils::truncateHtml('<p>This is a string to truncate</p>', 10));
 | |
|         $this->assertEquals('<p>This is a string to truncate</p>', Utils::truncateHtml('<p>This is a string to truncate</p>', 100));
 | |
|         $this->assertEquals('<input type="file" id="file" multiple />', Utils::truncateHtml('<input type="file" id="file" multiple />', 6));
 | |
|         $this->assertEquals('<ol><li>item 1 <i>so...</i></li></ol>', Utils::truncateHtml('<ol><li>item 1 <i>something</i></li><li>item 2 <strong>bold</strong></li></ol>', 10));
 | |
| 		$this->assertEquals("<p>This is a string.</p>\n<p>It splits two lines.</p>", Utils::truncateHtml("<p>This is a string.</p>\n<p>It splits two lines.</p>", 100));
 | |
|     }
 | |
| 
 | |
|     public function testSafeTruncateHtml()
 | |
|     {
 | |
|         $this->assertEquals('<p>This...</p>', Utils::safeTruncateHtml('<p>This is a string to truncate</p>', 1));
 | |
|         $this->assertEquals('<p>This is...</p>', Utils::safeTruncateHtml('<p>This is a string to truncate</p>', 2));
 | |
|         $this->assertEquals('<p>This is a string to...</p>', Utils::safeTruncateHtml('<p>This is a string to truncate</p>', 5));
 | |
|         $this->assertEquals('<p>This is a string to truncate</p>', Utils::safeTruncateHtml('<p>This is a string to truncate</p>', 20));
 | |
|         $this->assertEquals('<input type="file" id="file" multiple />', Utils::safeTruncateHtml('<input type="file" id="file" multiple />', 6));
 | |
|         $this->assertEquals('<ol><li>item 1 <i>something</i></li><li>item 2...</li></ol>', Utils::safeTruncateHtml('<ol><li>item 1 <i>something</i></li><li>item 2 <strong>bold</strong></li></ol>', 5));
 | |
|     }
 | |
| 
 | |
|     public function testGenerateRandomString()
 | |
|     {
 | |
|         $this->assertNotEquals(Utils::generateRandomString(), Utils::generateRandomString());
 | |
|         $this->assertNotEquals(Utils::generateRandomString(20), Utils::generateRandomString(20));
 | |
|     }
 | |
| 
 | |
|     public function download()
 | |
|     {
 | |
| 
 | |
|     }
 | |
| 
 | |
|     public function testGetMimeByExtension()
 | |
|     {
 | |
|         $this->assertEquals('application/octet-stream', Utils::getMimeByExtension(''));
 | |
|         $this->assertEquals('text/html', Utils::getMimeByExtension('html'));
 | |
|         $this->assertEquals('application/json', Utils::getMimeByExtension('json'));
 | |
|         $this->assertEquals('application/atom+xml', Utils::getMimeByExtension('atom'));
 | |
|         $this->assertEquals('application/rss+xml', Utils::getMimeByExtension('rss'));
 | |
|         $this->assertEquals('image/jpeg', Utils::getMimeByExtension('jpg'));
 | |
|         $this->assertEquals('image/png', Utils::getMimeByExtension('png'));
 | |
|         $this->assertEquals('text/plain', Utils::getMimeByExtension('txt'));
 | |
|         $this->assertEquals('application/msword', Utils::getMimeByExtension('doc'));
 | |
|         $this->assertEquals('application/octet-stream', Utils::getMimeByExtension('foo'));
 | |
|         $this->assertEquals('foo/bar', Utils::getMimeByExtension('foo', 'foo/bar'));
 | |
|         $this->assertEquals('text/html', Utils::getMimeByExtension('foo', 'text/html'));
 | |
|     }
 | |
| 
 | |
|     public function testGetExtensionByMime()
 | |
|     {
 | |
|         $this->assertEquals('html', Utils::getExtensionByMime('*/*'));
 | |
|         $this->assertEquals('html', Utils::getExtensionByMime('text/*'));
 | |
|         $this->assertEquals('html', Utils::getExtensionByMime('text/html'));
 | |
|         $this->assertEquals('json', Utils::getExtensionByMime('application/json'));
 | |
|         $this->assertEquals('atom', Utils::getExtensionByMime('application/atom+xml'));
 | |
|         $this->assertEquals('rss', Utils::getExtensionByMime('application/rss+xml'));
 | |
|         $this->assertEquals('jpg', Utils::getExtensionByMime('image/jpeg'));
 | |
|         $this->assertEquals('png', Utils::getExtensionByMime('image/png'));
 | |
|         $this->assertEquals('txt', Utils::getExtensionByMime('text/plain'));
 | |
|         $this->assertEquals('doc', Utils::getExtensionByMime('application/msword'));
 | |
|         $this->assertEquals('html', Utils::getExtensionByMime('foo/bar'));
 | |
|         $this->assertEquals('baz', Utils::getExtensionByMime('foo/bar', 'baz'));
 | |
|     }
 | |
| 
 | |
|     public function testNormalizePath()
 | |
|     {
 | |
|         $this->assertEquals('/test', Utils::normalizePath('/test'));
 | |
|         $this->assertEquals('test', Utils::normalizePath('test'));
 | |
|         $this->assertEquals('test', Utils::normalizePath('../test'));
 | |
|         $this->assertEquals('/test', Utils::normalizePath('/../test'));
 | |
|         $this->assertEquals('/test2', Utils::normalizePath('/test/../test2'));
 | |
|         $this->assertEquals('/test/test2', Utils::normalizePath('/test/./test2'));
 | |
|     }
 | |
| 
 | |
|     public function testIsFunctionDisabled()
 | |
|     {
 | |
|         $disabledFunctions = explode(',', ini_get('disable_functions'));
 | |
| 
 | |
|         if ($disabledFunctions[0]) {
 | |
|             $this->assertEquals(Utils::isFunctionDisabled($disabledFunctions[0]), true);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public function testTimezones()
 | |
|     {
 | |
|         $timezones = Utils::timezones();
 | |
| 
 | |
|         $this->assertInternalType('array', $timezones);
 | |
|         $this->assertContainsOnly('string', $timezones);
 | |
|     }
 | |
| 
 | |
|     public function testArrayFilterRecursive()
 | |
|     {
 | |
|         $array = [
 | |
|             'test'  => '',
 | |
|             'test2' => 'test2'
 | |
|         ];
 | |
| 
 | |
|         $array = Utils::arrayFilterRecursive($array, function ($k, $v) {
 | |
|             return !(is_null($v) || $v === '');
 | |
|         });
 | |
| 
 | |
|         $this->assertContainsOnly('string', $array);
 | |
|         $this->assertArrayNotHasKey('test', $array);
 | |
|         $this->assertArrayHasKey('test2', $array);
 | |
|         $this->assertEquals('test2', $array['test2']);
 | |
|     }
 | |
| 
 | |
|     public function testPathPrefixedByLangCode()
 | |
|     {
 | |
|         $languagesEnabled = $this->grav['config']->get('system.languages.supported', []);
 | |
|         $arrayOfLanguages = ['en', 'de', 'it', 'es', 'dk', 'el'];
 | |
|         $languagesNotEnabled = array_diff($arrayOfLanguages, $languagesEnabled);
 | |
|         $oneLanguageNotEnabled = reset($languagesNotEnabled);
 | |
| 
 | |
|         if (count($languagesEnabled)) {
 | |
|             $this->assertTrue(Utils::pathPrefixedByLangCode('/' . $languagesEnabled[0] . '/test'));
 | |
|         }
 | |
| 
 | |
|         $this->assertFalse(Utils::pathPrefixedByLangCode('/' . $oneLanguageNotEnabled . '/test'));
 | |
|         $this->assertFalse(Utils::pathPrefixedByLangCode('/test'));
 | |
|         $this->assertFalse(Utils::pathPrefixedByLangCode('/xx'));
 | |
|         $this->assertFalse(Utils::pathPrefixedByLangCode('/xx/'));
 | |
|         $this->assertFalse(Utils::pathPrefixedByLangCode('/'));
 | |
|     }
 | |
| 
 | |
|     public function testDate2timestamp()
 | |
|     {
 | |
|         $timestamp = strtotime('10 September 2000');
 | |
|         $this->assertSame($timestamp, Utils::date2timestamp('10 September 2000'));
 | |
|         $this->assertSame($timestamp, Utils::date2timestamp('2000-09-10 00:00:00'));
 | |
|     }
 | |
| 
 | |
|     public function testResolve()
 | |
|     {
 | |
|         $array = [
 | |
|             'test' => [
 | |
|                 'test2' => 'test2Value'
 | |
|             ]
 | |
|         ];
 | |
| 
 | |
|         $this->assertEquals('test2Value', Utils::resolve($array, 'test.test2'));
 | |
|     }
 | |
| 
 | |
|     public function testGetDotNotation()
 | |
|     {
 | |
|         $array = [
 | |
|             'test' => [
 | |
|                 'test2' => 'test2Value',
 | |
|                 'test3' => [
 | |
|                     'test4' => 'test4Value'
 | |
|                 ]
 | |
|             ]
 | |
|         ];
 | |
| 
 | |
|         $this->assertEquals('test2Value', Utils::getDotNotation($array, 'test.test2'));
 | |
|         $this->assertEquals('test4Value', Utils::getDotNotation($array, 'test.test3.test4'));
 | |
|         $this->assertEquals('defaultValue', Utils::getDotNotation($array, 'test.non_existent', 'defaultValue'));
 | |
|     }
 | |
| 
 | |
|     public function testSetDotNotation()
 | |
|     {
 | |
|         $array = [
 | |
|             'test' => [
 | |
|                 'test2' => 'test2Value',
 | |
|                 'test3' => [
 | |
|                     'test4' => 'test4Value'
 | |
|                 ]
 | |
|             ]
 | |
|         ];
 | |
| 
 | |
|         $new = [
 | |
|             'test1' => 'test1Value'
 | |
|         ];
 | |
| 
 | |
|         Utils::setDotNotation($array, 'test.test3.test4' , $new);
 | |
|         $this->assertEquals('test1Value', $array['test']['test3']['test4']['test1']);
 | |
|     }
 | |
| 
 | |
|     public function testIsPositive()
 | |
|     {
 | |
|         $this->assertTrue(Utils::isPositive(true));
 | |
|         $this->assertTrue(Utils::isPositive(1));
 | |
|         $this->assertTrue(Utils::isPositive('1'));
 | |
|         $this->assertTrue(Utils::isPositive('yes'));
 | |
|         $this->assertTrue(Utils::isPositive('on'));
 | |
|         $this->assertTrue(Utils::isPositive('true'));
 | |
|         $this->assertFalse(Utils::isPositive(false));
 | |
|         $this->assertFalse(Utils::isPositive(0));
 | |
|         $this->assertFalse(Utils::isPositive('0'));
 | |
|         $this->assertFalse(Utils::isPositive('no'));
 | |
|         $this->assertFalse(Utils::isPositive('off'));
 | |
|         $this->assertFalse(Utils::isPositive('false'));
 | |
|         $this->assertFalse(Utils::isPositive('some'));
 | |
|         $this->assertFalse(Utils::isPositive(2));
 | |
|     }
 | |
| 
 | |
|     public function testGetNonce()
 | |
|     {
 | |
|         $this->assertInternalType('string', Utils::getNonce('test-action'));
 | |
|         $this->assertInternalType('string', Utils::getNonce('test-action', true));
 | |
|         $this->assertSame(Utils::getNonce('test-action'), Utils::getNonce('test-action'));
 | |
|         $this->assertNotSame(Utils::getNonce('test-action'), Utils::getNonce('test-action2'));
 | |
|     }
 | |
| 
 | |
|     public function testVerifyNonce()
 | |
|     {
 | |
|         $this->assertTrue(Utils::verifyNonce(Utils::getNonce('test-action'), 'test-action'));
 | |
|     }
 | |
| }
 |