Function EXACT(arg1, arg2) support (#595)
This commit is contained in:
		
							parent
							
								
									043327bb7d
								
							
						
					
					
						commit
						eb31899225
					
				| @ -9,6 +9,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/). | ||||
| 
 | ||||
| ### Added | ||||
| 
 | ||||
| - Add excel function EXACT(value1, value2) support | ||||
| - Support workbook view attributes for Xlsx format - [#523](https://github.com/PHPOffice/PhpSpreadsheet/issues/523) | ||||
| 
 | ||||
| ### Fixed | ||||
|  | ||||
| @ -752,7 +752,7 @@ class Calculation | ||||
|         ], | ||||
|         'EXACT' => [ | ||||
|             'category' => Category::CATEGORY_TEXT_AND_DATA, | ||||
|             'functionCall' => [Functions::class, 'DUMMY'], | ||||
|             'functionCall' => [TextData::class, 'EXACT'], | ||||
|             'argumentCount' => '2', | ||||
|         ], | ||||
|         'EXP' => [ | ||||
|  | ||||
| @ -577,4 +577,22 @@ class TextData | ||||
| 
 | ||||
|         return (float) $value; | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Compares two text strings and returns TRUE if they are exactly the same, FALSE otherwise. | ||||
|      * EXACT is case-sensitive but ignores formatting differences. | ||||
|      * Use EXACT to test text being entered into a document. | ||||
|      * | ||||
|      * @param $value1 | ||||
|      * @param $value2 | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public static function EXACT($value1, $value2) | ||||
|     { | ||||
|         $value1 = Functions::flattenSingleValue($value1); | ||||
|         $value2 = Functions::flattenSingleValue($value2); | ||||
| 
 | ||||
|         return (string) $value2 === (string) $value1; | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -359,4 +359,28 @@ class TextDataTest extends TestCase | ||||
|     { | ||||
|         return require 'data/Calculation/TextData/VALUE.php'; | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * @dataProvider providerEXACT | ||||
|      * | ||||
|      * @param mixed $expectedResult | ||||
|      * @param array $args | ||||
|      */ | ||||
|     public function testEXACT($expectedResult, ...$args) | ||||
|     { | ||||
|         StringHelper::setDecimalSeparator('.'); | ||||
|         StringHelper::setThousandsSeparator(' '); | ||||
|         StringHelper::setCurrencyCode('$'); | ||||
| 
 | ||||
|         $result = TextData::EXACT(...$args); | ||||
|         self::assertSame($expectedResult, $result, null); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function providerEXACT() | ||||
|     { | ||||
|         return require 'data/Calculation/TextData/EXACT.php'; | ||||
|     } | ||||
| } | ||||
|  | ||||
							
								
								
									
										39
									
								
								tests/data/Calculation/TextData/EXACT.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								tests/data/Calculation/TextData/EXACT.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,39 @@ | ||||
| <?php | ||||
| 
 | ||||
| return [ | ||||
|     [ | ||||
|         true, | ||||
|         '', | ||||
|         '', | ||||
|     ], | ||||
|     [ | ||||
|         true, | ||||
|         '1000', | ||||
|         1000, | ||||
|     ], | ||||
|     [ | ||||
|         true, | ||||
|         1000, | ||||
|         '1000', | ||||
|     ], | ||||
|     [ | ||||
|         true, | ||||
|         'Abč', | ||||
|         'Abč', | ||||
|     ], | ||||
|     [ | ||||
|         false, | ||||
|         'abč', | ||||
|         'Abč', | ||||
|     ], | ||||
|     [ | ||||
|         false, | ||||
|         '10.010', | ||||
|         10.01, | ||||
|     ], | ||||
|     [ | ||||
|         false, | ||||
|         '  ', | ||||
|         '', | ||||
|     ], | ||||
| ]; | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Rolands Usāns
						Rolands Usāns