phpOMS/tests/Business/Finance/DepreciationTest.php

104 lines
3.8 KiB
PHP

<?php
/**
* Karaka
*
* PHP Version 8.1
*
* @package tests
* @copyright Dennis Eichhorn
* @license OMS License 1.0
* @version 1.0.0
* @link https://karaka.app
*/
declare(strict_types=1);
namespace phpOMS\tests\Business\Finance;
use phpOMS\Business\Finance\Depreciation;
/**
* @testdox phpOMS\tests\Business\Finance\DepreciationTest: Depreciation calculations
*
* @internal
*/
final class DepreciationTest extends \PHPUnit\Framework\TestCase
{
/**
* @testdox The straight line depreciation and reverse value calculations are correct
* @group framework
*/
public function testStraightLine() : void
{
$start = 23280;
$duration = 6;
$t = 2;
self::assertEqualsWithDelta(3880, Depreciation::getStraightLineDepreciation($start, $duration), 5);
self::assertEqualsWithDelta(23280 - 3880 * $t, Depreciation::getStraightLineResidualInT($start, $duration, $t), 5);
}
/**
* @testdox The arithmetic degressive depreciation and reverse value calculations are correct
* @group framework
*/
public function testArithmeticDegressiveDepreciation() : void
{
$start = 150000;
$residual = 18000;
$duration = 5;
$t = 2;
self::assertEqualsWithDelta(8800, Depreciation::getArithmeticDegressiveDepreciationFactor($start, $residual, $duration), 5);
self::assertEqualsWithDelta(35200, Depreciation::getArithmeticDegressiveDepreciationInT($start, $residual,$duration, $t), 5);
self::assertEqualsWithDelta(70800, Depreciation::getArithmeticDegressiveDepreciationResidualInT($start, $residual, $duration, $t), 5);
}
/**
* @testdox The arithmetic progressive depreciation and reverse value calculations are correct
* @group framework
*/
public function testArithmeticProgressiveDepreciation() : void
{
$start = 40000;
$residual = 4700;
$duration = 4;
$t = 2;
self::assertEqualsWithDelta(3530, Depreciation::getArithmeticProgressiveDepreciationFactor($start, $residual, $duration), 5);
self::assertEqualsWithDelta(7060, Depreciation::getArithmeticProgressiveDepreciationInT($start, $residual, $duration, $t), 5);
self::assertEqualsWithDelta(29410, Depreciation::getArithmeticProgressiveDepreciationResidualInT($start, $residual, $duration, $t), 5);
}
/**
* @testdox The geometric progressive depreciation and reverse value calculations are correct
* @group framework
*/
public function testGeometricProgressiveDepreciation() : void
{
$start = 150000;
$residual = 18000;
$duration = 5;
$t = 2;
self::assertEqualsWithDelta(0.3456, Depreciation::getGeometicProgressiveDepreciationRate($start, $residual, $duration), 0.01);
self::assertEqualsWithDelta(14527, Depreciation::getGeometicProgressiveDepreciationInT($start, $residual, $duration, $t), 5);
self::assertEqualsWithDelta(125965, Depreciation::getGeometicProgressiveDepreciationResidualInT($start, $residual, $duration, $t), 5);
}
/**
* @testdox The geometric degressive depreciation and reverse value calculations are correct
* @group framework
*/
public function testGeometricDegressiveDepreciation() : void
{
$start = 150000;
$residual = 18000;
$duration = 5;
$t = 2;
self::assertEqualsWithDelta(0.3456, Depreciation::getGeometicDegressiveDepreciationRate($start, $residual, $duration), 0.01);
self::assertEqualsWithDelta(33924, Depreciation::getGeometicDegressiveDepreciationInT($start, $residual, $duration, $t), 5);
self::assertEqualsWithDelta(64236, Depreciation::getGeometicDegressiveDepreciationResidualInT($start, $residual, $duration, $t), 5);
}
}