49 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			49 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
|   | <?php | ||
|  | 
 | ||
|  | namespace PhpOffice\PhpSpreadsheetTests\Calculation\Functions\Engineering; | ||
|  | 
 | ||
|  | use PhpOffice\PhpSpreadsheet\Calculation\Engineering; | ||
|  | use PhpOffice\PhpSpreadsheet\Calculation\Functions; | ||
|  | use PhpOffice\PhpSpreadsheetTests\Custom\ComplexAssert; | ||
|  | use PHPUnit\Framework\TestCase; | ||
|  | 
 | ||
|  | class ImSumTest extends TestCase | ||
|  | { | ||
|  |     const COMPLEX_PRECISION = 1E-8; | ||
|  | 
 | ||
|  |     /** | ||
|  |      * @var ComplexAssert | ||
|  |      */ | ||
|  |     protected $complexAssert; | ||
|  | 
 | ||
|  |     public function setUp() | ||
|  |     { | ||
|  |         Functions::setCompatibilityMode(Functions::COMPATIBILITY_EXCEL); | ||
|  |         $this->complexAssert = new ComplexAssert(); | ||
|  |     } | ||
|  | 
 | ||
|  |     public function tearDown() | ||
|  |     { | ||
|  |         $this->complexAssert = null; | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * @dataProvider providerIMSUM | ||
|  |      * | ||
|  |      * @param mixed $expectedResult | ||
|  |      */ | ||
|  |     public function testIMSUM($expectedResult, ...$args) | ||
|  |     { | ||
|  |         $result = Engineering::IMSUM(...$args); | ||
|  |         $this->assertTrue( | ||
|  |             $this->complexAssert->assertComplexEquals($expectedResult, $result, self::COMPLEX_PRECISION), | ||
|  |             $this->complexAssert->getErrorMessage() | ||
|  |         ); | ||
|  |     } | ||
|  | 
 | ||
|  |     public function providerIMSUM() | ||
|  |     { | ||
|  |         return require 'data/Calculation/Engineering/IMSUM.php'; | ||
|  |     } | ||
|  | } |