| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace PhpOffice\PhpSpreadsheetTests\Calculation\Functions\Statistical; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use PhpOffice\PhpSpreadsheet\Calculation\Functions; | 
					
						
							|  |  |  | use PhpOffice\PhpSpreadsheet\Calculation\Statistical; | 
					
						
							|  |  |  | use PHPUnit\Framework\TestCase; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class CountTest extends TestCase | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-04-27 10:28:36 +00:00
										 |  |  |     protected function setUp(): void | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         Functions::setCompatibilityMode(Functions::COMPATIBILITY_EXCEL); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @dataProvider providerBasicCOUNT | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param mixed $expectedResult | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-05-18 04:49:57 +00:00
										 |  |  |     public function testBasicCOUNT($expectedResult, ...$args): void | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         $result = Statistical::COUNT(...$args); | 
					
						
							| 
									
										
										
										
											2020-05-18 04:49:57 +00:00
										 |  |  |         self::assertEqualsWithDelta($expectedResult, $result, 1E-12); | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function providerBasicCOUNT() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-05-17 09:35:55 +00:00
										 |  |  |         return require 'tests/data/Calculation/Statistical/BasicCOUNT.php'; | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @dataProvider providerExcelCOUNT | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param mixed $expectedResult | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-05-18 04:49:57 +00:00
										 |  |  |     public function testExcelCOUNT($expectedResult, ...$args): void | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         $result = Statistical::COUNT(...$args); | 
					
						
							| 
									
										
										
										
											2020-05-18 04:49:57 +00:00
										 |  |  |         self::assertEqualsWithDelta($expectedResult, $result, 1E-12); | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function providerExcelCOUNT() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-05-17 09:35:55 +00:00
										 |  |  |         return require 'tests/data/Calculation/Statistical/ExcelCOUNT.php'; | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @dataProvider providerOpenOfficeCOUNT | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param mixed $expectedResult | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-05-18 04:49:57 +00:00
										 |  |  |     public function testOpenOfficeCOUNT($expectedResult, ...$args): void | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         Functions::setCompatibilityMode(Functions::COMPATIBILITY_OPENOFFICE); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $result = Statistical::COUNT(...$args); | 
					
						
							| 
									
										
										
										
											2020-05-18 04:49:57 +00:00
										 |  |  |         self::assertEqualsWithDelta($expectedResult, $result, 1E-12); | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function providerOpenOfficeCOUNT() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-05-17 09:35:55 +00:00
										 |  |  |         return require 'tests/data/Calculation/Statistical/OpenOfficeCOUNT.php'; | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @dataProvider providerGnumericCOUNT | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param mixed $expectedResult | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-05-18 04:49:57 +00:00
										 |  |  |     public function testGnumericCOUNT($expectedResult, ...$args): void | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         Functions::setCompatibilityMode(Functions::COMPATIBILITY_GNUMERIC); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $result = Statistical::COUNT(...$args); | 
					
						
							| 
									
										
										
										
											2020-05-18 04:49:57 +00:00
										 |  |  |         self::assertEqualsWithDelta($expectedResult, $result, 1E-12); | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function providerGnumericCOUNT() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-05-17 09:35:55 +00:00
										 |  |  |         return require 'tests/data/Calculation/Statistical/GnumericCOUNT.php'; | 
					
						
							| 
									
										
										
										
											2019-07-20 16:40:05 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | } |