20250217
[Д] [BoolExtensions]: Добавлен новый статический класс, расширяющий возможности типа bool.
This commit is contained in:
		
							
								
								
									
										73
									
								
								sources/extensions/BoolExtensions.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								sources/extensions/BoolExtensions.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,73 @@ | ||||
| <?php | ||||
|  | ||||
| namespace goodboyalex\php_components_pack\extensions; | ||||
|  | ||||
| use Exception; | ||||
|  | ||||
| /** | ||||
|  * Расширение типа "правда/ложь". | ||||
|  * | ||||
|  * @author Александр Бабаев | ||||
|  * @package php_components_pack | ||||
|  * @version 1.0 | ||||
|  * @since 1.0.7 | ||||
|  */ | ||||
| final class BoolExtensions | ||||
| { | ||||
|     /** | ||||
|      * Вывод в строку <code>ifTrue</code>, если выражение <code>b</code> правдиво и <code>ifFalse</code> в противном | ||||
|      * случае. | ||||
|      * | ||||
|      * @param bool $b Выражение типа правда/ложь. | ||||
|      * @param string $ifTrue Строка для правдивого выражения. По умолчанию "true". | ||||
|      * @param string $ifFalse Строка для лживого выражения. По умолчанию "false". | ||||
|      * | ||||
|      * @return string Вывод строки. | ||||
|      */ | ||||
|     public static function ExportToString (bool $b, string $ifTrue = "true", string $ifFalse = "false"): string | ||||
|     { | ||||
|         return $b ? $ifTrue : $ifFalse; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Вычисляет, есть ли хотя бы одно из переменных формата правда/ложь <code>expressions</code> в значении | ||||
|      * <code>true</code>. | ||||
|      * | ||||
|      * @param array $expressions Переменные формата правда/ложь. | ||||
|      * | ||||
|      * @return bool Есть ли хотя бы одно в значении true. | ||||
|      * | ||||
|      * @throws Exception Выбрасывается, если хотя бы один аргумент <code>expressions</code> не являются типом | ||||
|      *     правда/ложь. | ||||
|      */ | ||||
|     public static function AnyTrue (array $expressions): bool | ||||
|     { | ||||
|         return self::TrueCount($expressions) > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Вычисляет количество переменных формата правда/ложь <code>expressions</code> в значении <code>true</code>. | ||||
|      * | ||||
|      * @param array $expressions Переменные формата правда/ложь. | ||||
|      * | ||||
|      * @return int Количество переменных в значении true. | ||||
|      * | ||||
|      * @throws Exception Выбрасывается, если хотя бы один аргумент <code>expressions</code> не являются типом | ||||
|      *     правда/ложь. | ||||
|      */ | ||||
|     public static function TrueCount (array $expressions): int | ||||
|     { | ||||
|         // Проверяем все аргументы | ||||
|         foreach ($expressions as $expression) | ||||
|             // - если аргумент не является типом правда/ложь | ||||
|             if (!is_bool($expression)) | ||||
|                 // -- то выбрасываем исключение | ||||
|                 throw new Exception('All arguments must be bool. / Все аргументы должны быть типа «правда/ложь».'); | ||||
|  | ||||
|         // Используем array_filter для фильтрации всех истинных значений | ||||
|         $filtered = array_filter($expressions); | ||||
|  | ||||
|         // Возвращаем количество элементов в отфильтрованном массиве | ||||
|         return count($filtered); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										68
									
								
								tests/extensions/BoolExtensionsTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								tests/extensions/BoolExtensionsTest.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | ||||
| <?php | ||||
|  | ||||
| namespace goodboyalex\php_components_pack\tests\extensions; | ||||
|  | ||||
| use Exception; | ||||
| use goodboyalex\php_components_pack\extensions\BoolExtensions; | ||||
| use PHPUnit\Framework\TestCase; | ||||
|  | ||||
| class BoolExtensionsTest extends TestCase | ||||
| { | ||||
|     public function testAnyTrue () | ||||
|     { | ||||
|         $this->PrepareForTest(); | ||||
|  | ||||
|         $hasTrue = [ | ||||
|             true, false, true, false, true, false, true, false, true, false, true, false, true, false, true, false, | ||||
|             true, false, true, false, true, false, true, false, true, false, true, false | ||||
|         ]; | ||||
|  | ||||
|         $noTrue = [ | ||||
|             false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, | ||||
|             false, false, false, false, false, false, false, false, false, false, false | ||||
|         ]; | ||||
|  | ||||
|         $this->assertTrue(BoolExtensions::AnyTrue($hasTrue)); | ||||
|  | ||||
|         $this->assertFalse(BoolExtensions::AnyTrue($noTrue)); | ||||
|  | ||||
|     } | ||||
|  | ||||
|     private function PrepareForTest (): void | ||||
|     { | ||||
|         require_once __DIR__ . '/../../sources/extensions/BoolExtensions.php'; | ||||
|     } | ||||
|  | ||||
|     public function testTrueCount () | ||||
|     { | ||||
|         $this->PrepareForTest(); | ||||
|  | ||||
|         $array = [ | ||||
|             true, false, true, false, true, false, true, false, true, false, true, false, | ||||
|             true, false, true, false, true, false, true, false, true, false, true, false, true, false, true, | ||||
|             false | ||||
|         ]; | ||||
|  | ||||
|         $this->assertEquals(14, | ||||
|             BoolExtensions::TrueCount($array)); | ||||
|  | ||||
|         $this->expectException(Exception::class); | ||||
|  | ||||
|         $array[] = "ПРЕДАТЕЛЬ!"; | ||||
|  | ||||
|         BoolExtensions::TrueCount($array); | ||||
|     } | ||||
|  | ||||
|     public function testExportToString () | ||||
|     { | ||||
|         $this->PrepareForTest(); | ||||
|  | ||||
|         $b = true; | ||||
|  | ||||
|         $this->assertEquals('О, да!', BoolExtensions::ExportToString($b, 'О, да!', 'О, нет!')); | ||||
|  | ||||
|         $b = false; | ||||
|  | ||||
|         $this->assertEquals('О, нет!', BoolExtensions::ExportToString($b, 'О, да!', 'О, нет!')); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user