788f79c1bb
Fix: Return #NUM! if values and dates contain a different number of values Fix: Return #NUM! if there is not at least one positive cash flow and one negative cash flow Fix: Return #NUM! if any number in dates precedes the starting date Fix: Return #NUM! if a result that works cannot be found after max iteration tries Fix: Correct DocBlocks for XIRR & XNPV Add: Validate XIRR with unit tests Closes #1177
581 lines
14 KiB
PHP
581 lines
14 KiB
PHP
<?php
|
|
|
|
namespace PhpOffice\PhpSpreadsheetTests\Calculation;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Calculation\Financial;
|
|
use PhpOffice\PhpSpreadsheet\Calculation\Functions;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
class FinancialTest extends TestCase
|
|
{
|
|
public function setUp()
|
|
{
|
|
Functions::setCompatibilityMode(Functions::COMPATIBILITY_EXCEL);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerAMORDEGRC
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testAMORDEGRC($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::AMORDEGRC(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerAMORDEGRC()
|
|
{
|
|
return require 'data/Calculation/Financial/AMORDEGRC.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerAMORLINC
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testAMORLINC($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::AMORLINC(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerAMORLINC()
|
|
{
|
|
return require 'data/Calculation/Financial/AMORLINC.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerCOUPDAYBS
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testCOUPDAYBS($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::COUPDAYBS(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerCOUPDAYBS()
|
|
{
|
|
return require 'data/Calculation/Financial/COUPDAYBS.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerCOUPDAYS
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testCOUPDAYS($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::COUPDAYS(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerCOUPDAYS()
|
|
{
|
|
return require 'data/Calculation/Financial/COUPDAYS.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerCOUPDAYSNC
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testCOUPDAYSNC($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::COUPDAYSNC(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerCOUPDAYSNC()
|
|
{
|
|
return require 'data/Calculation/Financial/COUPDAYSNC.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerCOUPNCD
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testCOUPNCD($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::COUPNCD(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerCOUPNCD()
|
|
{
|
|
return require 'data/Calculation/Financial/COUPNCD.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerCOUPNUM
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testCOUPNUM($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::COUPNUM(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerCOUPNUM()
|
|
{
|
|
return require 'data/Calculation/Financial/COUPNUM.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerCOUPPCD
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testCOUPPCD($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::COUPPCD(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerCOUPPCD()
|
|
{
|
|
return require 'data/Calculation/Financial/COUPPCD.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerCUMIPMT
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testCUMIPMT($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::CUMIPMT(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerCUMIPMT()
|
|
{
|
|
return require 'data/Calculation/Financial/CUMIPMT.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerCUMPRINC
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testCUMPRINC($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::CUMPRINC(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerCUMPRINC()
|
|
{
|
|
return require 'data/Calculation/Financial/CUMPRINC.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerDB
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testDB($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::DB(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerDB()
|
|
{
|
|
return require 'data/Calculation/Financial/DB.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerDDB
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testDDB($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::DDB(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerDDB()
|
|
{
|
|
return require 'data/Calculation/Financial/DDB.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerDISC
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testDISC($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::DISC(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerDISC()
|
|
{
|
|
return require 'data/Calculation/Financial/DISC.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerDOLLARDE
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testDOLLARDE($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::DOLLARDE(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerDOLLARDE()
|
|
{
|
|
return require 'data/Calculation/Financial/DOLLARDE.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerDOLLARFR
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testDOLLARFR($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::DOLLARFR(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerDOLLARFR()
|
|
{
|
|
return require 'data/Calculation/Financial/DOLLARFR.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerEFFECT
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testEFFECT($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::EFFECT(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerEFFECT()
|
|
{
|
|
return require 'data/Calculation/Financial/EFFECT.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerFV
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testFV($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::FV(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerFV()
|
|
{
|
|
return require 'data/Calculation/Financial/FV.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerFVSCHEDULE
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testFVSCHEDULE($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::FVSCHEDULE(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerFVSCHEDULE()
|
|
{
|
|
return require 'data/Calculation/Financial/FVSCHEDULE.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerINTRATE
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testINTRATE($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::INTRATE(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerINTRATE()
|
|
{
|
|
return require 'data/Calculation/Financial/INTRATE.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerIPMT
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testIPMT($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::IPMT(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerIPMT()
|
|
{
|
|
return require 'data/Calculation/Financial/IPMT.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerIRR
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testIRR($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::IRR(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerIRR()
|
|
{
|
|
return require 'data/Calculation/Financial/IRR.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerISPMT
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testISPMT($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::ISPMT(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerISPMT()
|
|
{
|
|
return require 'data/Calculation/Financial/ISPMT.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerMIRR
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testMIRR($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::MIRR(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerMIRR()
|
|
{
|
|
return require 'data/Calculation/Financial/MIRR.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerNOMINAL
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testNOMINAL($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::NOMINAL(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerNOMINAL()
|
|
{
|
|
return require 'data/Calculation/Financial/NOMINAL.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerNPER
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testNPER($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::NPER(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerNPER()
|
|
{
|
|
return require 'data/Calculation/Financial/NPER.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerNPV
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testNPV($expectedResult, ...$args)
|
|
{
|
|
$result = Financial::NPV(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerNPV()
|
|
{
|
|
return require 'data/Calculation/Financial/NPV.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerPRICE
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testPRICE($expectedResult, ...$args)
|
|
{
|
|
$this->markTestIncomplete('TODO: This test should be fixed');
|
|
|
|
$result = Financial::PRICE(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerPRICE()
|
|
{
|
|
return require 'data/Calculation/Financial/PRICE.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerPRICEDISC
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testPRICEDISC($expectedResult, array $args)
|
|
{
|
|
$result = Financial::PRICEDISC(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerPRICEDISC()
|
|
{
|
|
return require 'data/Calculation/Financial/PRICEDISC.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerPV
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testPV($expectedResult, array $args)
|
|
{
|
|
$result = Financial::PV(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerPV()
|
|
{
|
|
return require 'data/Calculation/Financial/PV.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerRATE
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testRATE($expectedResult, ...$args)
|
|
{
|
|
$this->markTestIncomplete('TODO: This test should be fixed');
|
|
|
|
$result = Financial::RATE(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerRATE()
|
|
{
|
|
return require 'data/Calculation/Financial/RATE.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerXIRR
|
|
*
|
|
* @param mixed $expectedResult
|
|
* @param mixed $message
|
|
*/
|
|
public function testXIRR($expectedResult, $message, ...$args)
|
|
{
|
|
$result = Financial::XIRR(...$args);
|
|
self::assertEquals($expectedResult, $result, $message, Financial::FINANCIAL_PRECISION);
|
|
}
|
|
|
|
public function providerXIRR()
|
|
{
|
|
return require 'data/Calculation/Financial/XIRR.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerPDURATION
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testPDURATION($expectedResult, array $args)
|
|
{
|
|
$result = Financial::PDURATION(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerPDURATION()
|
|
{
|
|
return require 'data/Calculation/Financial/PDURATION.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerRRI
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testRRI($expectedResult, array $args)
|
|
{
|
|
$result = Financial::RRI(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerRRI()
|
|
{
|
|
return require 'data/Calculation/Financial/RRI.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerSLN
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testSLN($expectedResult, array $args)
|
|
{
|
|
$result = Financial::SLN(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerSLN()
|
|
{
|
|
return require 'data/Calculation/Financial/SLN.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerSYD
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testSYD($expectedResult, array $args)
|
|
{
|
|
$result = Financial::SYD(...$args);
|
|
self::assertEquals($expectedResult, $result, '', 1E-8);
|
|
}
|
|
|
|
public function providerSYD()
|
|
{
|
|
return require 'data/Calculation/Financial/SYD.php';
|
|
}
|
|
}
|